@charset "utf-8";
/* ---------------------------------------------------------------------------------
Copyright© SOL*Z GROUP All Rights Reserved.

HTML CSS Selectors staff

$Revision: 1.0 $
--------------------------------------------------------------------------------- */
.mv {
  height: 600px;
}
.mv-name {
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.2em;
  text-align: center;
  color: #fff;
  position: absolute;
  right: 0;
  bottom: 158px;
  left: 0;
  margin: auto;
  transition-delay:600ms;
}
.mv-name .en {
  display: block;
  padding-top: 10px;
  font-family: var(--font-en);
  font-size: 42px;
  font-weight: 700;
}

/*---------------------------------------------------------------------------------
About
--------------------------------------------------------------------------------- */
.about {
  padding-bottom: 345px;
  position: relative;
}
.about::before {
  display: block;
  width: 1px;
  height: 100vw;
  background-color: #404040;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -108px;
  transform-origin: right bottom;
  transform: rotate(-45deg);
  content:"";
  z-index: -1;
}
.about::after {
  display: block;
  width: 200px;
  height: 244px;
  background-color: #fff;
  position: absolute;
  bottom: 332px;
  left: 50%;
  margin-left: -512px;
  z-index: 1;
  content:"";
}
.about-ttl {
  width: 76px;
  font-family: var(--font-en);
  font-size: 72px;
  line-height: 1;
  letter-spacing: 0.2em;
  writing-mode: vertical-rl;
  white-space: nowrap;
  position: absolute;
  bottom: 250px;
  left: 50%;
  margin-left: -700px;
  z-index: 3;
}

.staff-main-photo {
  width: 520px;
  margin: 0 auto 140px;
  position: relative;
  top: -55px;
  z-index: 2;
  transition-delay:800ms;
}
.staff-main-photo::before {
  display: block;
  width: 2px;
  height: 275px;
  background-color: #000;
  position: absolute;
  right: 18px;
  bottom: -110px;
  transform-origin: center;
  transform: rotate(-140deg);
  z-index: -1;
  content:"";
}
.staff-main-photo::after {
  width: 26px;
  height: 26px;
  background-image: url("../img/staff/icon_name.png");
  position: absolute;
  right: 0;
  bottom: -115px;
  left: 0;
  margin: auto;
  content:"";
}
.staff-sns {
  position: absolute;
  bottom: 120px;
  left: -158px;
  transition-delay:1700ms;
}
.staff-sns-ttl {
  padding-bottom: 60px;
  margin-bottom: 10px;
  font-family: var(--font-en);
  font-size: 34px;
  line-height: 1;
  letter-spacing: 0.2em;
  writing-mode: vertical-rl;
  white-space: nowrap;
  position: relative;
}
.staff-sns-ttl::after {
  width: 1px;
  height: 52px;
  background-color: #000;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content:"";
}
.staff-sns a {
  display: block;
  width: 20px;
  margin: 0 auto 15px;
}
.staff-reserve {
  width: 248px;
  position: absolute;
  top: 550px;
  right: 50%;
  margin-right: -550px;
}
.staff-reserve__ttl {
  width: fit-content;
  padding-bottom: 2px;
  border-bottom: 1px solid #000;
  margin-bottom: 18px;
  font-size: 22px;
  line-height: 1;
  letter-spacing: 0.1em;
}
.staff-reserve a {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  height: 80px;
  background-color: #000;
  font-family: var(--font-en);
  font-size: 36px;
  line-height: 1;
  text-align: center;
  letter-spacing: 0.2em;
  color: #fff!important;
}

.about-inner {
  width: 810px;
  padding-bottom: 50px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.about-inner-read {
  margin-bottom: 65px;
  font-size: 48px;
  line-height: 1.8;
  text-align: center;
  text-decoration: underline;
  font-weight: 700;
}
.staff-data {
  display: flex;
  flex-wrap: wrap;
  width: 390px;
  margin: 0 auto 72px;
}
.staff-data dt {
  width: 170px;
  padding-bottom: 38px;
  font-family: var(--font-en);
  font-size: 24px;
  line-height: 1;
}
.staff-data dd {
  width: calc(100% - 170px);
  padding-bottom: 38px;
  font-size: 20px;
  line-height: 1;
}
.staff-data dd a {
  text-decoration: underline;
}
.about-inner-txt {
  font-size: 16px;
  line-height: 1.875;
}

/*---------------------------------------------------------------------------------
Calender
--------------------------------------------------------------------------------- */
.calender {
  padding: 55px 0 30px;
  background-color: #65c4c6;
  margin-bottom: 160px;
}
.staff-cal-list {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  align-content: flex-start;
  flex-wrap: wrap;
  width: 880px;
  margin: 0 auto 35px;
}
.staff-cal-list li {
  width: 400px;
  padding: 38px 53px;
  background-color: #fff;
  font-family: 'Cormorant Unicase', serif;
  line-height: 1;
  font-weight: 700;
}

.calender-info {
  width: 405px;
  margin: 0 auto;
}
.calender-info ul {
  display: flex;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.calender-info li {
  padding: 0 40px 0 24px;
  font-size: 12px;
  line-height: 1;
  position: relative;
}
.calender-info li::before {
  display: block;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  position: absolute;
  top: -2px;
  left: 0;
  content:"";
}
.calender-info li.info01::before {
  background-color: #ee5b79;
}
.calender-info li.info02::before {
  background-color: #4885d8;
}
.calender-info li.info03::before {
  background-color: #d6dfe1;
}
.calender-info p {
  font-size: 12px;
  line-height: 2.166;
}

/*calender*/
.calendar_year {
  padding-bottom: 45px;
  font-size: 14px;
  text-align: center;
}
.calendar_month {
  padding-bottom: 12px;
  font-size: 42px;
  line-height: 1;
  text-align: center;
}
.uk-text-center {
  text-align: center;
}
.uk-table {
  width: 100%;
  color: #000;
}
.uk-table thead {
  margin-bottom: 25px;
  font-size: 20px;
}
.uk-table thead th:first-child {
  color: #b92f7c;
}
.uk-table td {
  width: 14.2%;
  padding-bottom: 10px;
  text-align: center;
  font-size: 17px;
  line-height: 1;
}
.uk-table td div {
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  width: 24px;
  height:24px;
  padding-bottom: 3px;
  margin-bottom: 5px;
  margin: 0 auto;
  position: relative;
  border: 1px solid #fff;
  border-radius: 50%;
}
.uk-table td div.Red::after,
.uk-table td div.Blue::after,
.uk-table td div.Green::after {
  box-sizing: border-box;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
  content:"";
}
.uk-table td div.calendar_event {
  color: #fff!important;
}


/*---------------------------------------------------------------------------------
MOVIE 
--------------------------------------------------------------------------------- */
.movie {
  width: 860px;
  margin: 0 auto 260px;
}
.movie-in {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.movie-in iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
/*---------------------------------------------------------------------------------
Other
--------------------------------------------------------------------------------- */
.other {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  width: 1300px;
  margin: 0 auto 398px;
}
.other li {
  margin: 0 45px 170px;
  position: relative;
}
.other li.big {
  width: 870px;
}
.other li.middle {
  width: 600px;
}
.other li.small {
  width: 480px;
}

.other__txt {
  width: 238px;
  padding: 18px 0 0 24px;
  background-color: #fff;
  position: absolute;
  right: -26px;
  bottom: -32px;
  z-index: 2;
  font-size: 14px;
  line-height: 1.7;
}

/*---------------------------------------------------------------------------------
BLOG
--------------------------------------------------------------------------------- */



