@charset "utf-8";

body {
  overflow: clip;
}
.opening {
  position: fixed;
  z-index: 10001;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
}
.opening__content {
  grid-template-columns: auto;
  justify-content: center;
  justify-items: stretch;
  align-content: center;
  align-items: center;
  height: 100%;
  background: url(../img/home/bg_opening.jpg) no-repeat center/cover rgb(var(--color-deepblue));
  opacity: 0;
}
/* .opening__content__group {
} */
.opening__content__group__copy {
  font-size: clamp(30px, calc(50 / 1200 * 100vw), 50px);
  line-height: 1.5;
  color: #cac299;
}
.opening__content__group2 {
  margin-top: clamp(30px, calc(50 / 1200 * 100vw), 50px);
  border-top: 1px solid rgba(var(--color-white), .4);
  padding-top: clamp(30px, calc(50 / 1200 * 100vw), 50px);
}
.opening__content__group2__copy {
  font-size: clamp(30px, calc(50 / 1200 * 100vw), 50px);
  line-height: 2;
  color: #cac299;
}
.opening__content__group2__copy em {
  font-size: 150%;
}
.opening__content__group2__copy em.bodoni {
  font-size: 175%;
  vertical-align: -.05em;
}
@media screen and (max-width: 480px) {
  .opening__content__group__copy {
    font-size: 22px;
    line-height: 1.75;
  }
  .opening__content__group2 {
    margin-top: 30px;
    padding-top: 20px;
  }
  .opening__content__group2__copy {
    font-size: 22px;
  }
}



.mv {
  opacity: 0;
}
/* .mv__slide {
}
.mv__slide__list {
} */
.mv__slide__list__item {
  position: relative;
  z-index: 1;
}
.mv__slide__list__item__photo {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
}
.mv__slide__list__item__photo--1 {
  position: relative;
}
.mv__slide__list__item .p-caption {
  z-index: 2;
}
/* .mv__control {
}
.mv__control__btn {
}
.mv__control__btn--prev {
}
.mv__control__btn--next {
}
.mv__control__pagination {
}
@media screen and (max-width: 480px){
} */



/* .news {
} */
.news__content {
  grid-template-columns: auto auto auto;
  justify-content: center;
  align-content: stretch;
  align-items: center;
  gap: 30px;
  box-sizing: border-box;
  padding: 10px;
  background: linear-gradient(90deg, rgb(var(--color-deepblue)), rgb(var(--color-blue)), rgb(var(--color-deepblue)));
}
.news__content::before {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background: rgba(var(--color-blue), .5);
  background: color-mix(in srgb, rgb(var(--color-blue)) 50%, #fff 100%);
}
.news__content__heading {
  font-size: clamp(11px, calc(16 / 1200 * 100vw), 16px);
  order: -1;
}
.news__content__group {
  box-sizing: border-box;
}
.news__content__group__item {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 14px;
  padding-block: 7px;
}
.news__content__group__item__date {
  font-size: clamp(11px, calc(16 / 1200 * 100vw), 16px);
}
.news__content__group__item__copy {
  font-size: clamp(11px, calc(16 / 1200 * 100vw), 16px);
  line-height: 1.4;
}
@media screen and (max-width: 480px){
  .news__content {
    grid-template-columns: auto auto minmax(0, 1fr);
    gap: 20px;
    padding: 10px 30px;
  }
  .news__content__heading {
    font-size: 14px;
  }
  .news__content__group__item {
    grid-template-columns: 100%;
    gap: 6px 0;
    padding-block: 4px;
  }
  .news__content__group__item + .news__content__group__item {
    padding-block: 11px;
  }
  .news__content__group__item__date {
    font-size: 13px;
  }
  .news__content__group__item__copy {
    font-size: 13px;
    line-height: 1.2;
  }
}



.merit {
  position: relative;
  z-index: 1;
}
.merit::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: -30px;
  background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(244, 244, 244, 0.01) 1.48%, rgba(193, 193, 193, 0.05) 9.01%, rgba(147, 147, 147, 0.09) 17.08%, rgba(108, 108, 108, 0.13) 25.51%, rgba(74, 74, 74, 0.17) 34.38%, rgba(47, 47, 47, 0.22) 43.84%, rgba(26, 26, 26, 0.27) 54.07%, rgba(11, 11, 11, 0.33) 65.48%, rgba(3, 3, 3, 0.39) 78.99%, rgba(0, 0, 0, 0.5) 100%);
}
.merit__content {
  padding-block: 20px;
  background: #fff;
}
.merit__content__copy {
  max-width: fit-content;
}
@media screen and (max-width: 480px){
  .merit::before {
    bottom: -60px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0) 0%, rgba(244, 244, 244, 0.01) 1.09%, rgba(193, 193, 193, 0.05) 6.58%, rgba(147, 147, 147, 0.09) 12.49%, rgba(108, 108, 108, 0.13) 18.65%, rgba(74, 74, 74, 0.17) 25.13%, rgba(47, 47, 47, 0.22) 32.05%, rgba(26, 26, 26, 0.27) 39.53%, rgba(11, 11, 11, 0.33) 47.86%, rgba(3, 3, 3, 0.39) 57.74%, rgba(0, 0, 0, 0.5) 73.1%);
  }
  .merit__content {
    padding-block: 35px;
  }
}



/* .info {
} */
.info__content {
  padding-block: 120px 180px;
}
/* .info__content__info {
} */
.info__content__info__heading {
  font-size: clamp(14px, calc(20 / 1200 * 100vw), 20px);
}
.info__content__info__group {
  margin-top: 60px;
}
.info__content__info__group__copy {
  font-size: clamp(30px, calc(50 / 1200 * 100vw), 50px);
  line-height: 1.5;
}
.info__content__info__btn {
  margin-top: 60px;
  gap: 30px;
}
.info__content__info__btn__item {
  flex: 0 1 min(100%, 360px);
}
.info__content__info__btn__item--limited a {
  font-size: clamp(10px, calc(16 / 1200 * 100vw), 16px);
}
.info__content__info__group2 {
  margin-top: 60px;
}
.info__content__info__group2__copy {
  font-size: clamp(12px, calc(18 / 1200 * 100vw), 18px);
  line-height: 2.444444444;
  text-align: center;
}
.info__content__merit {
  max-width: 1480px;
  margin-top: 100px;
  box-shadow: 0 0 40px rgba(0, 0, 0, .1);
  box-sizing: border-box;
  padding: 80px min(calc(80 / 1480 * 100%), 80px) 90px;
  background: #fff;
}
.info__content__merit__heading {
  font-size: clamp(24px, calc(34 / 1200 * 100vw), 34px);
}
.info__content__merit__copy {
  font-size: clamp(11px, calc(16 / 1200 * 100vw), 16px);
  line-height: 2.125;
  text-align: center;
  --margin-top: 50px;
}
.info__content__merit__list {
  margin-top: 50px;
  gap: 40px;
}
.info__content__merit__list__item {
  position: relative;
  z-index: 1;
  flex: 0 1 calc((100% - 120px) / 4);
}
.info__content__merit__list__item__num {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: calc(34 / 20 * 1em);
  aspect-ratio: 1 / 1;
  place-items: center;
  font-size: clamp(14px, calc(20 / 1600 * 100vw), 20px);
  background: rgb(var(--color-red));
}
/* .info__content__merit__list__item__photo {
} */
.info__content__merit__list__item__copy {
  font-size: clamp(10px, calc(14 / 1600 * 100vw), 14px);
  line-height: 1.875;
  --margin-top: 30px;
  margin-inline: -1em;
}
@media screen and (min-width: 481px) and (max-width: 1024px) {
  .info__content__merit__list__item {
    flex: 0 1 calc((100% - 40px) / 2);
  }
}
@media screen and (max-width: 480px){
  .info__content {
    padding-block: 80px;
  }
  .info__content__info__heading {
    font-size: 14px;
  }
  .info__content__info__group {
    margin-top: 30px;
  }
  .info__content__info__group__copy {
    font-size: 24px;
  }
  .info__content__info__btn {
    margin-top: 40px;
    gap: 30px 0;
    max-width: 300px;
  }
  .info__content__info__btn__item {
    flex: 1 0 100%;
  }
  .info__content__info__btn__item--limited a {
    font-size: 12px;
  }
  .info__content__info__group2 {
    margin-top: 40px;
  }
  .info__content__info__group2__copy {
    font-size: 14px;
    line-height: 2.142857143;
    text-align: justify;
  }
  .info__content__merit {
    margin-top: 60px;
    box-shadow: 0 0 24px rgba(0, 0, 0, .1);
    padding: 40px 30px;
  }
  .info__content__merit__heading {
    font-size: 22px;
  }
  .info__content__merit__copy {
    font-size: 14px;
    line-height: 2.142857143;
    text-align: justify;
    --margin-top: 40px;
  }
  .info__content__merit__list {
    margin-top: 42px;
    gap: 42px 0;
  }
  .info__content__merit__list__item {
    flex: 1 0 100%;
  }
  .info__content__merit__list__item__num {
    font-size: 20px;
  }
  .info__content__merit__list__item__copy {
    font-size: 16px;
    line-height: 1.625;
    --margin-top: 22px;
  }
}



/* .concept {
} */
.concept__content {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.concept__content__photo {
  position: absolute;
  z-index: -1;
}
.concept__content__photo--1 {
  top: 0;
  left: 0;
  width: max(530px, calc(718 / 1920 * 100%));
  height: 100%;
}
.concept__content__photo--2 {
  bottom: 0;
  right: 0;
  width: calc(795 / 1920 * 100%);
  aspect-ratio: 795 / 638;
}
.concept__content__photo img {
  height: 100%;
  object-fit: cover;
}
.concept__content__photo--1 img {
  object-position: bottom right;
}
.concept__content__group {
  grid-template: ". . . . ." max(180px, calc(180 / 1920 * 100vw))
  ". logo . desc ." auto
  ". . . . ." max(190px, calc(190 / 1920 * 100vw))
  / minmax(2.5%, 1fr) max(270px, calc(480 / 1920 * 100%)) calc(160 / 1920 * 100%) auto minmax(2.5%, 1fr);
  align-items: start;
}
.concept__content__group__logo {
  grid-area: logo;
  width: 100%;
  translate: 0 -10px;
}
/* .concept__content__group__logo__item {
} */
.concept__content__group__logo__item--1 {
  fill: rgb(var(--color-blue));
}
.concept__content__group__logo__item--6 {
  fill: rgb(var(--color-red));
}
.concept__content__group__desc {
  grid-area: desc;
}
.concept__content__group__desc__enheading {
  font-size: clamp(20px, calc(30 / 1200 * 100vw), 30px);
}
.concept__content__group__desc__heading {
  font-size: clamp(25px, calc(40 / 1200 * 100vw), 40px);
  line-height: 1.75;
  --margin-top: 80px;
}
.concept__content__group__desc__copy {
  font-size: clamp(14px, calc(18 / 1200 * 100vw), 18px);
  line-height: 2.444444444;
  --margin-top: 55px;
}
.concept__content__group__desc__btn {
  margin-top: 65px;
}
.concept__content__group__desc__btn .more {
  margin-left: calc(15 / 16 * 1em);
}
@media screen and (min-width: 481px) and (max-width: 1024px) {
  .concept__content__photo--1 {
    width: 40%;
    height: auto;
  }
  .concept__content__photo--2 {
    width: 60%;
    aspect-ratio: 380 / 253;
  }
}
@media screen and (max-width: 480px){
  .concept__content__photo--1 {
    width: 208px;
    height: auto;
  }
  .concept__content__photo--2 {
    width: 100%;
    aspect-ratio: 380 / 253;
  }
  .concept__content__photo img {
    height: auto;
  }
  .concept__content__group {
    grid-template: ". . ." 80px
    ". logo ." auto
    ". . ." 60px
    ". desc ." auto
    ". . ." 80px
    / 20px minmax(0, 1fr) 20px;
  }
  .concept__content__group__logo {
    width: 200px;
    translate: 0;
    justify-self: center;
  }
  .concept__content__group__desc__enheading {
    font-size: 20px;
    text-align: center;
  }
  .concept__content__group__desc__heading {
    font-size: 24px;
    line-height: 2.083333333;
    --margin-top: 40px;
    text-align: center;
  }
  .concept__content__group__desc__copy {
    font-size: 16px;
    line-height: 2.25;
    --margin-top: 40px;
    text-align: center;
  }
  .concept__content__group__desc__btn {
    margin-top: 45px;
  }
  .concept__content__group__desc__btn .more {
    margin-inline: auto;
    display: block;
  }
}



/* .under {
} */
.under__content {
  position: relative;
  z-index: 1;
  grid-template-columns: minmax(0, 1fr) calc(200 / 1920 * 100%);
  background-attachment: fixed;
}
.under__content::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  width: calc(600 / 1920 * 100%);
  height: 100%;
  background: url(../img/home/bg_under.jpg) repeat top right/600px 800px fixed;
}
.under__content__anchor {
  position: sticky;
  z-index: 2;
  top: var(--header-height);
  right: 0;
  grid-column: 2 / 3;
  grid-row: 1 / 2;
  width: 100%;
  height: calc(100vh - var(--header-height));
  grid-template-columns: auto;
  place-content: center;
  place-items: center;
  gap: 30px;
}
.under__content__anchor__item {
  position: relative;
  z-index: 1;
  width: 10px;
  aspect-ratio: 1 / 1;
}
.under__content__anchor__item::before,
.under__content__anchor__item::after {
  content: "";
  position: absolute;
  border-radius: 100%;
}
.under__content__anchor__item::before {
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(var(--color-white), .4);
  transition: background .4s, scale .4s;
}
.under__content__anchor__item::after {
  z-index: 1;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  width: calc(30 / 10 * 100%);
  height: calc(30 / 10 * 100%);
  background: rgba(var(--color-white), .2);
  animation: more 2s ease-in-out infinite;
  pointer-events: none;
  visibility: hidden;
}
.under__content__anchor__item--active::before {
  background: rgba(var(--color-white), 1);
}
.under__content__anchor__item--active::after {
  visibility: visible;
}
.under__content__group {
  position: sticky;
  z-index: 1;
  top: var(--header-height);
  left: 0;
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  width: 100%;
  height: calc(100vh - var(--header-height));
}
.under__content__group__item {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  grid-template-columns: calc((var(--window-half-width) * 2) * .025) minmax(0, 1fr) calc(200 / 1720 * 100%) calc(700 / 1720 * 100%);
  grid-template-rows: 100%;
  justify-content: end;
  align-items: center;
  box-sizing: border-box;
  padding-block: max(100px, calc(100 / 1720 * 100%));
}
.under__content__group__item__desc {
  grid-column: 2 / 3;
  justify-self: end;
  width: min(100%, 520px);
}
.under__content__group__item__desc__enheading {
  font-size: clamp(46px, calc(66 / 1200 * 100vw), 66px);
}
.under__content__group__item__desc__enheading span:nth-of-type(1) {
  font-size: calc(100 / 66 * 100%);
  color: rgb(var(--color-red));
}
.under__content__group__item__desc__heading {
  font-size: clamp(20px, calc(40 / 1200 * 100vw), 40px);
  line-height: 1.75;
  --margin-top: calc(80 / 40 * 1em);
  margin-right: -2em;
}
.under__content__group__item__desc__copy {
  font-size: clamp(12px, calc(18 / 1200 * 100vw), 18px);
  line-height: 2.222222222;
  --margin-top: calc(55 / 18 * 1em);
  margin-right: -2.5em;
}
.under__content__group__item__desc__btn {
  margin-top: 65px;
}
.under__content__group__item__desc__btn .more {
  display: block;
  margin-left: auto;
}
.under__content__group__item__photo {
  grid-column: 4 / 5;
  justify-self: center;
  max-height: 100%;
  aspect-ratio: 1400 / 1200;
  box-shadow: 7px 7px 20px rgba(0, 0, 0, .3);
  overflow: hidden;
}
.under__content__group__item__photo img {
  height: 100%;
  object-fit: cover;
}
.under__content__spacer {
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  width: 100%;
  height: 100vh;
}
.under__content__spacer + .under__content__spacer {
  grid-row: auto;
}
@media (any-hover: hover){
  .under__content__anchor__item:hover::before {
    background: rgba(var(--color-white), 1);
    scale: 3;
  }
}
@media screen and (max-width: 480px){
  .under__content {
    grid-template-columns: minmax(0, 1fr) 40px;
    background-attachment: scroll;
    overflow: clip;
  }
  .under__content::before {
    content: none;
  }
  .under__content__anchor {
    height: calc(100svh - var(--header-height));
    gap: 27px;
    mix-blend-mode: difference;
    display: none;
  }
  .under__content__anchor__item {
    width: 9px;
  }
  .under__content__group {
    position: relative;
    top: 0;
    grid-column: 1 / 3;
    height: auto;
  }
  .under__content__group__item {
    position: relative;
    height: auto;
    grid-template-columns: 30px minmax(0, 1fr) 30px;
    grid-template-rows: 1fr auto;
    justify-content: center;
    align-content: end;
    align-items: end;
    padding-block: 75px;
  }
  .under__content__group__item::before {
    content: "";
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 170px;
    background: url(../img/home/bg_under-sp.jpg) repeat-y top center/100% auto;
  }
  .under__content__group__item__desc {
    width: 100%;
  }
  .under__content__group__item__desc__enheading {
    font-size: 28px;
    text-align: center;
  }
  .under__content__group__item__desc__enheading span:nth-of-type(1) {
    font-size: calc(44 / 28 * 100%);
  }
  .under__content__group__item__desc__heading {
    font-size: 24px;
    --margin-top: 35px;
    margin-inline: -.5em;
    text-align: center;
  }
  .under__content__group__item__desc__copy {
    font-size: 14px;
    line-height: 2.142857143;
    --margin-top: 35px;
    margin-inline: -.5em;
    text-align: center;
  }
  .under__content__group__item__desc__btn {
    margin-top: 45px;
  }
  .under__content__group__item__desc__btn .more {
    margin-inline: auto;
  }
  .under__content__group__item__photo {
    grid-column: 2 / 3;
    max-height: none;
    aspect-ratio: 280 / 170;
    box-shadow: 3px 3px 8px rgba(0, 0, 0, .3);
    max-width: calc(100% - 40px);
    margin-top: 45px;
  }
}



/* .map {
} */
.map__content {
  padding-block: 180px;
  background: rgba(var(--color-blue), .05);
}
.map__content__heading {
  font-size: clamp(20px, calc(40 / 1200 * 100vw), 40px);
}
.map__content__photo {
  max-width: 1000px;
  margin-top: 60px;
}
.map__content__photo__modalopen {
  pointer-events: none;
}
.map__content__btn {
  margin-top: 60px;
  gap: 30px;
}
.map__content__btn__item {
  flex: 0 1 min(100%, 360px);
}
@media screen and (max-width: 480px){
  .map__content {
    padding-block: 80px;
  }
  .map__content__heading {
    font-size: 24px;
  }
  .map__content__photo {
    margin-top: 30px;
  }
  .map__content__photo__modalopen {
    pointer-events: auto;
  }
  .map__content__btn {
    margin-top: 40px;
    gap: 20px;
    max-width: 300px;
  }
  .map__content__btn__item {
    flex: 1 0 100%;
  }
}