@media only screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

@media print, screen and (min-width: 769px) {
  .sp {
    display: none;
  }
}

.entranceScroll {
  position: relative;
  z-index: 1;
}

@media print, screen and (min-width: 769px) {
  .entranceScroll {
    margin: 0 auto;
    max-width: 1200px;
    padding: 0 0 200px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .entranceScroll {
    padding: 0 40px 200px;
  }
}

.is-tb .entranceScroll {
  padding: 0 40px 200px;
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__head {
    left: 50%;
    position: -webkit-sticky;
    position: sticky;
    top: calc(var(--header-height) + 80px);
    -webkit-transform: translateX(-50%) scale(0.58);
            transform: translateX(-50%) scale(0.58);
    -webkit-transform-origin: top center;
            transform-origin: top center;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    z-index: 2;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__head {
    background-color: #c6bda5;
    padding: 24px 0;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__head .photo__capIn {
    opacity: 0;
    -webkit-transition: opacity .2s ease, visibility .2s ease;
    transition: opacity .2s ease, visibility .2s ease;
    visibility: hidden;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__head.is-active .photo__capIn {
    opacity: 1;
    visibility: visible;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__body .featureCard:nth-child(even) {
    margin-left: auto;
    margin-right: 0;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__body .featureCard:not(:first-child) {
    margin-top: -360px;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__body .featureCard:not(:first-child) {
    margin-top: 60px;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__body .generalSlider {
    margin-top: 160px;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__body .generalSlider {
    margin-left: -32px;
    margin-right: -32px;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__body .generalSlider .swiper-wrapper {
    gap: 160px calc(1200px - var(--scrollbar) - (264px * 2) - 80px);
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__body .generalSlider .swiper-slide {
    width: 264px;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__body .generalSlider .swiper-slide {
    width: 268px;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__body .generalSlider--disableMode {
    margin-left: 0;
    margin-right: 0;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__body .generalSlider--disableMode .swiper-wrapper {
    gap: 40px 22px;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__body .generalSlider--disableMode .swiper-slide {
    width: calc(50% - 11px);
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__body {
    margin-top: 60px;
    padding: 0 32px;
  }
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__column {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 100px calc(1200px - var(--scrollbar) - (264px * 2) - 80px);
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media only screen and (max-width: 768px) {
  .entranceScroll__column {
    display: none;
  }
}

.generalSlider + .entranceScroll__column {
  margin-top: 100px;
}

@media print, screen and (min-width: 769px) {
  .entranceScroll__visual {
    width: 264px;
  }
}

.featureCard__head {
  border: 1px solid #a59c7f;
  margin: 0 auto;
  text-align: center;
}

@media print, screen and (min-width: 769px) {
  .featureCard__head {
    border-radius: 180px;
    height: 410px;
    padding: 80px 0 16px 0;
    width: 480px;
  }
}

@media only screen and (max-width: 768px) {
  .featureCard__head {
    border-radius: 100px;
    height: 254px;
    padding: 30px 0 20px 0;
    width: 296px;
  }
}

.featureCard__ttl {
  color: #a59c7f;
  font-family: "Barlow Semi Condensed", serif;
  letter-spacing: .05em;
  line-height: 1.2;
}

.featureCard__ttl:before {
  content: '';
  display: block;
  height: 0;
  margin-top: calc((1 - 1.2) * .5em);
  width: 0;
}

.featureCard__ttl:after {
  content: '';
  display: block;
  height: 0;
  margin-bottom: calc((1 - 1.2) * .5em);
  width: 0;
}

@media print, screen and (min-width: 769px) {
  .featureCard__ttl {
    font-size: 40px;
    font-weight: 400;
  }
}

@media only screen and (max-width: 768px) {
  .featureCard__ttl {
    font-size: 30px;
    font-weight: 500;
  }
}

@media print, screen and (min-width: 769px) {
  .featureCard__cont {
    margin-top: -200px;
  }
}

@media only screen and (max-width: 768px) {
  .featureCard__cont {
    margin-top: -140px;
  }
}

@media print, screen and (min-width: 769px) {
  .featureCard__cont .headingUnit {
    margin: 76px auto 0;
    max-width: 460px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}

@media only screen and (max-width: 768px) {
  .featureCard__cont .headingUnit {
    margin-top: 50px;
  }
}

@media print, screen and (min-width: 769px) {
  .featureCard__cont .headingUnit .heading {
    text-align: center;
  }
}

@media print, screen and (min-width: 769px) {
  .gateSect__desc {
    width: 472px;
  }
}

@media print, screen and (min-width: 769px) {
  .gateSect__image {
    margin-top: 80px;
    max-width: 368px;
  }
}

@media only screen and (max-width: 768px) {
  .gateSect__image {
    margin-top: 60px;
  }
}

@media only screen and (max-width: 768px) {
  .gateSect__image .heading {
    font-size: 18px;
  }
}

.gateSect__image .heading .caption {
  display: block;
}

.gateSect__image .heading + .photo {
  margin-top: 24px;
}

@media print, screen and (min-width: 769px) {
  .gateSect__cont {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 48px;
    margin: 140px auto 0;
    max-width: 888px;
  }
}

@media only screen and (max-width: 768px) {
  .gateSect__cont {
    margin-top: 80px;
    padding: 0 32px;
  }
}

@media print, screen and (min-width: 769px) {
  .gateSect__map {
    width: 368px;
  }
}

@media only screen and (max-width: 768px) {
  .gateSect__map {
    margin: 60px auto 0;
    width: 268px;
  }
}

@media print, screen and (min-width: 769px) {
  .highlightSect__cont {
    margin: 140px auto 0;
    max-width: 1200px;
  }
}

@media only screen and (max-width: 768px) {
  .highlightSect__cont {
    margin-top: 140px;
  }
}

.highlightSect__cont .generalSlider {
  margin-top: 60px;
}

.highlightSect__cont .generalSlider .swiper-wrapper {
  padding-bottom: 1em;
}

@media print, screen and (min-width: 769px) {
  .highlightSect__cont .generalSlider .swiper-container {
    overflow: visible;
  }
}

@media only screen and (max-width: 768px) {
  .highlightSect__cont .generalSlider .swiper-slide {
    width: 268px;
  }
}

.landscapeSect {
  margin: 0 auto;
}

@media print, screen and (min-width: 769px) {
  .landscapeSect {
    max-width: 992px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .landscapeSect {
    width: 100%;
  }
}

.is-tb .landscapeSect {
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .landscapeSect {
    padding: 0 32px;
  }
}

@media print, screen and (min-width: 769px) {
  .landscapeSect__head .headingUnit .heading {
    text-align: center;
  }
}

@media print, screen and (min-width: 769px) {
  .landscapeSect__head .headingUnit .txt {
    margin-left: auto;
    margin-right: auto;
    max-width: 784px;
  }
}

.landscapeSect__head .enTtl {
  text-align: center;
}

.landscapeSect__head .enTtl + .headingUnit {
  margin-top: 60px;
}

@media only screen and (max-width: 768px) {
  .landscapeSect__cont .swipeFigure__inner {
    height: 260px;
  }
}

.landscapeSect__head + .landscapeSect__cont {
  margin-top: 60px;
}

.loungeArea {
  margin: 0 auto;
}

@media print, screen and (min-width: 769px) {
  .loungeArea {
    max-width: 1200px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .loungeArea {
    padding: 0 20px;
    width: 100%;
  }
}

.is-tb .loungeArea {
  padding: 0 20px;
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .loungeArea {
    padding: 0 32px;
  }
}

.loungeArea__head {
  margin: 0 auto;
}

@media print, screen and (min-width: 769px) {
  .loungeArea__head {
    max-width: 992px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .loungeArea__head {
    width: 100%;
  }
}

.is-tb .loungeArea__head {
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .loungeArea__head .swipeFigure__inner {
    height: 260px;
  }
}

@media only screen and (max-width: 768px) {
  .loungeArea__body .loungePanel:not(:first-child) {
    margin-top: 60px;
  }
}

@media only screen and (max-width: 768px) {
  .loungeArea__head + .loungeArea__body {
    margin-top: 60px;
  }
}

@media print, screen and (min-width: 769px) {
  .loungePanel {
    padding-top: 120px;
  }
}

@media print, screen and (min-width: 769px) {
  .loungePanel__inner {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 48px;
    height: 100%;
  }
}

@media print, screen and (min-width: 769px) {
  .loungePanel__head {
    display: none;
  }
}

@media only screen and (max-width: 768px) {
  .loungePanel__head {
    border: 1px solid #a59c7f;
    border-radius: 100px;
    height: 254px;
    margin: 0 auto;
    padding: 30px 0 20px 0;
    text-align: center;
    width: 296px;
  }
}

@media print, screen and (min-width: 769px) {
  .loungePanel__visual {
    height: auto;
    width: 888px;
  }
}

@media only screen and (max-width: 768px) {
  .loungePanel__visual {
    margin-top: -140px;
  }
}

.loungePanel__visual .photo {
  height: 100%;
  width: 100%;
}

.loungePanel__visual .photo__pic, .loungePanel__visual .photo__radiusLayer, .loungePanel__visual .photo__image {
  height: 100%;
  width: 100%;
}

.loungePanel__visual .photo__image {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 50%;
     object-position: 50% 50%;
}

@media print, screen and (min-width: 769px) {
  .loungePanel__visual .photo__image {
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    -webkit-transition: -webkit-filter 2s cubic-bezier(0.45, 0, 0.55, 1), -webkit-transform 2s cubic-bezier(0.45, 0, 0.55, 1);
    transition: -webkit-filter 2s cubic-bezier(0.45, 0, 0.55, 1), -webkit-transform 2s cubic-bezier(0.45, 0, 0.55, 1);
    transition: filter 2s cubic-bezier(0.45, 0, 0.55, 1), transform 2s cubic-bezier(0.45, 0, 0.55, 1);
    transition: filter 2s cubic-bezier(0.45, 0, 0.55, 1), transform 2s cubic-bezier(0.45, 0, 0.55, 1), -webkit-filter 2s cubic-bezier(0.45, 0, 0.55, 1), -webkit-transform 2s cubic-bezier(0.45, 0, 0.55, 1);
  }
}

@media print, screen and (min-width: 769px) {
  .loungePanel__desc {
    border: 1px solid #a59c7f;
    border-radius: 180px;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding: 60px 24px 56px;
  }
}

@media only screen and (max-width: 768px) {
  .loungePanel__desc {
    margin-top: 50px;
  }
}

@media only screen and (max-width: 768px) {
  .loungePanel__desc .headingUnit .heading {
    font-size: 18px;
  }
}

.loungePanel__desc .headingUnit .heading + .txt {
  margin-top: 24px;
}

.loungePanel__ttl {
  color: #a59c7f;
  font-family: "Barlow Semi Condensed", serif;
  font-weight: 500;
  letter-spacing: .05em;
  text-align: center;
  line-height: 1.2;
}

.loungePanel__ttl:before {
  content: '';
  display: block;
  height: 0;
  margin-top: calc((1 - 1.2) * .5em);
  width: 0;
}

.loungePanel__ttl:after {
  content: '';
  display: block;
  height: 0;
  margin-bottom: calc((1 - 1.2) * .5em);
  width: 0;
}

@media print, screen and (min-width: 769px) {
  .loungePanel__ttl {
    font-size: 30px;
  }
}

@media only screen and (max-width: 768px) {
  .loungePanel__ttl {
    font-size: 30px;
  }
}

@media print, screen and (min-width: 769px) {
  .loungePanel__ttl + .headingUnit {
    margin-top: 60px;
  }
}

.loungePanel__subVisual {
  position: relative;
  z-index: 1;
}

@media print, screen and (min-width: 769px) {
  .loungePanel__subVisual {
    -webkit-filter: blur(10px);
            filter: blur(10px);
    margin: 24px auto 0;
    opacity: 0;
    -webkit-transition: opacity 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, visibility 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, -webkit-filter 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s;
    transition: opacity 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, visibility 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, -webkit-filter 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s;
    transition: filter 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, opacity 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, visibility 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s;
    transition: filter 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, opacity 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, visibility 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s, -webkit-filter 0.8s cubic-bezier(0.45, 0, 0.55, 1) 1s;
    visibility: hidden;
    width: 134px;
  }
}

@media only screen and (max-width: 768px) {
  .loungePanel__subVisual {
    display: none;
  }
}

.loungePanel__subVisual .layer {
  -webkit-animation: layerBlink 2s ease-in-out infinite;
          animation: layerBlink 2s ease-in-out infinite;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 2;
}

.loungePanel__subVisual .base {
  display: block;
  position: relative;
  z-index: 1;
}

.loungePanel.sai-animate .loungePanel__visual .photo__image {
  -webkit-filter: blur(0);
          filter: blur(0);
  -webkit-transform: scale(1);
          transform: scale(1);
}

.loungePanel.sai-animate .loungePanel__subVisual {
  -webkit-filter: blur(0);
          filter: blur(0);
  opacity: 1;
  visibility: visible;
}

@-webkit-keyframes layerBlink {
  0% {
    -webkit-filter: brightness(1);
            filter: brightness(1);
    opacity: 1;
  }
  50% {
    -webkit-filter: brightness(1.3);
            filter: brightness(1.3);
    opacity: .2;
  }
  100% {
    -webkit-filter: brightness(1);
            filter: brightness(1);
    opacity: 1;
  }
}

@keyframes layerBlink {
  0% {
    -webkit-filter: brightness(1);
            filter: brightness(1);
    opacity: 1;
  }
  50% {
    -webkit-filter: brightness(1.3);
            filter: brightness(1.3);
    opacity: .2;
  }
  100% {
    -webkit-filter: brightness(1);
            filter: brightness(1);
    opacity: 1;
  }
}

.pageIntro {
  position: relative;
  z-index: 1;
}

.pageIntro__shape {
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 2;
}

.pageIntro__shape .shapeSVG {
  height: auto;
  width: 100%;
}

.pageIntro__head .photo {
  -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, color-stop(25%, rgba(255, 255, 255, 0)), color-stop(33%, white), color-stop(66%, white), color-stop(75%, rgba(255, 255, 255, 0)));
  -webkit-mask-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 25%, white 33%, white 66%, rgba(255, 255, 255, 0) 75%);
          mask-image: -webkit-gradient(linear, left top, left bottom, color-stop(25%, rgba(255, 255, 255, 0)), color-stop(33%, white), color-stop(66%, white), color-stop(75%, rgba(255, 255, 255, 0)));
          mask-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 25%, white 33%, white 66%, rgba(255, 255, 255, 0) 75%);
  -webkit-mask-position: 100% 100%;
          mask-position: 100% 100%;
  -webkit-mask-size: 100% 400%;
          mask-size: 100% 400%;
}

.pageIntro__head.sai-animate .photo {
  -webkit-mask-position: 100% 50%;
          mask-position: 100% 50%;
  -webkit-transition: 6s cubic-bezier(0.43, 0.02, 0.05, 1) 0s !important;
  transition: 6s cubic-bezier(0.43, 0.02, 0.05, 1) 0s !important;
}

.pageIntro__txtArea {
  position: absolute;
  z-index: 3;
}

@media print, screen and (min-width: 769px) {
  .pageIntro__txtArea {
    left: calc(120 / 1440 * 100vw);
    max-width: 1200px;
    top: calc(322 / 1440 * 100vw);
  }
}

@media only screen and (max-width: 768px) {
  .pageIntro__txtArea {
    left: 0;
    padding: 0 32px;
    top: 130px;
    width: 100%;
  }
}

@media print, screen and (min-width: 769px) {
  .pageIntro__txtArea .headingUnit {
    max-width: 492px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .pageIntro__txtArea .headingUnit {
    max-width: calc(492 / 1440 * 100vw);
  }
}

.is-tb .pageIntro__txtArea .headingUnit {
  max-width: calc(492 / 1440 * 100vw);
}

@media only screen and (max-width: 768px) {
  .pageIntro__txtArea .headingUnit .heading + .txt {
    margin-top: 40px;
  }
}

.pageIntro__txtArea .enTtl + .headingUnit {
  margin-top: 60px;
}

.pageIntro__cont {
  background-color: #c6bda5;
}

@media print, screen and (min-width: 769px) {
  .pageIntro__cont {
    padding-bottom: calc(80px + 13.125vw);
  }
}

@media only screen and (max-width: 768px) {
  .pageIntro__cont {
    padding: 80px 0;
  }
}

@media print, screen and (min-width: 769px) {
  .pageIntro__cont .generalSlider {
    margin: -95px auto 0;
    max-width: 1200px;
  }
}

@media print, screen and (min-width: 769px) {
  .pageIntro__cont .generalSlider .swiper-wrapper {
    gap: 32px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media print, screen and (min-width: 769px) {
  .pageIntro__cont .generalSlider .swiper-slide {
    width: 264px;
  }
}

@media only screen and (max-width: 768px) {
  .pageIntro__cont .generalSlider .swiper-slide {
    width: 268px;
  }
}

.plantSect {
  position: relative;
  z-index: 1;
  margin: 0 auto;
}

@media print, screen and (min-width: 769px) {
  .plantSect {
    max-width: 1200px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .plantSect {
    padding: 0 20px;
    width: 100%;
  }
}

.is-tb .plantSect {
  padding: 0 20px;
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .plantSect {
    padding: 0 32px;
  }
}

@media print, screen and (min-width: 769px) {
  .plantSect__head {
    left: 0;
    position: absolute;
    top: 140px;
    width: 576px;
  }
}

.plantSect__head .usableList__inner {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media print, screen and (min-width: 769px) {
  .plantSect__head .usableList__inner {
    gap: 16px;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}

@media only screen and (max-width: 768px) {
  .plantSect__head .usableList__inner {
    gap: 8px 9px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media print, screen and (min-width: 769px) {
  .plantSect__head .usableList__item {
    width: 130px;
  }
}

@media only screen and (max-width: 768px) {
  .plantSect__head .usableList__item {
    width: calc((100% - 18px) / 3);
  }
}

@media print, screen and (min-width: 769px) {
  .plantSect__head .usableList__item:nth-child(1), .plantSect__head .usableList__item:nth-child(2) {
    width: 280px;
  }
}

@media only screen and (max-width: 768px) {
  .plantSect__head .usableList__item:nth-child(1), .plantSect__head .usableList__item:nth-child(2) {
    width: 152px;
  }
}

@media only screen and (max-width: 375px) {
  .plantSect__head .usableList__item:nth-child(1), .plantSect__head .usableList__item:nth-child(2) {
    width: calc(50% - 8px);
  }
}

.plantSect__head .usableList__note {
  text-align: right;
}

.plantSect__head .usableList__note .caption {
  color: #ffffff;
}

.plantSect__cont {
  background-color: #c6bda5;
  -webkit-box-shadow: 0 50px 50px 0 rgba(0, 0, 0, 0.08);
          box-shadow: 0 50px 50px 0 rgba(0, 0, 0, 0.08);
  color: #4b4426;
}

@media print, screen and (min-width: 769px) {
  .plantSect__cont {
    border-radius: 150px 0 0 0;
    margin-left: 324px;
    margin-right: calc(50% - 50vw);
    padding: 120px 120px 120px 300px;
  }
}

@media only screen and (max-width: 768px) {
  .plantSect__cont {
    border-radius: 80px 0 0 80px;
    margin-left: 20px;
    margin-right: -32px;
    margin-top: -168px;
    padding: 180px 32px 80px 32px;
  }
}

.systemSect {
  position: relative;
  z-index: 1;
  margin: 0 auto;
}

@media print, screen and (min-width: 769px) {
  .systemSect {
    max-width: 1200px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .systemSect {
    padding: 0 20px;
    width: 100%;
  }
}

.is-tb .systemSect {
  padding: 0 20px;
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .systemSect {
    padding: 0 32px;
  }
}

.systemSect__head {
  position: absolute;
  z-index: 2;
}

@media print, screen and (min-width: 769px) {
  .systemSect__head {
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 576px;
  }
}

@media only screen and (max-width: 768px) {
  .systemSect__head {
    right: 32px;
    top: 80px;
    width: 326px;
  }
}

.systemSect__cont {
  background-color: #ffffff;
  -webkit-box-shadow: 0 50px 50px 0 rgba(0, 0, 0, 0.08);
          box-shadow: 0 50px 50px 0 rgba(0, 0, 0, 0.08);
}

@media print, screen and (min-width: 769px) {
  .systemSect__cont {
    border-radius: 0 150px;
    margin: 0 0 0 auto;
    max-width: 1096px;
    padding: 120px 104px 120px 624px;
  }
}

@media only screen and (max-width: 768px) {
  .systemSect__cont {
    border-radius: 0 80px 80px 0;
    margin-left: -32px;
    margin-right: 26px;
    padding: 350px 32px 80px 32px;
  }
}

@media only screen and (max-width: 768px) {
  .systemSect__cont .labelTtl {
    font-size: 15px;
    padding: 16px 0;
  }
}

@media print, screen and (min-width: 769px) {
  .labelTtl + .systemSect__logo {
    margin-top: 40px;
  }
}

@media only screen and (max-width: 768px) {
  .labelTtl + .systemSect__logo {
    margin-top: 24px;
  }
}

@media print, screen and (min-width: 769px) {
  .systemSect__logo + .headingUnit {
    margin-top: 40px;
  }
}

@media only screen and (max-width: 768px) {
  .systemSect__logo + .headingUnit {
    margin-top: 24px;
  }
}

.towerVisual {
  position: relative;
  z-index: 1;
}

@media print, screen and (min-width: 769px) {
  .towerVisual {
    width: 467px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .towerVisual {
    width: calc(467 / 1440 * 100vw);
  }
}

.is-tb .towerVisual {
  width: calc(467 / 1440 * 100vw);
}

@media only screen and (max-width: 768px) {
  .towerVisual {
    width: 100%;
  }
}

.towerVisual__middle {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 3;
}

.towerVisual__low {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 2;
}

.towerVisual__guide {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 4;
}

.towerVisual__name {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 5;
}

.towerVisual__base {
  position: relative;
  z-index: 1;
}

@media print, screen and (min-width: 769px) {
  .design-landscape {
    padding: 140px 0;
  }
}

@media only screen and (max-width: 768px) {
  .design-landscape {
    padding: 80px 0 60px;
  }
}

@media only screen and (max-width: 768px) {
  .design-entrance {
    padding: 0 0 80px;
  }
}

@media print, screen and (min-width: 769px) {
  .design-lounge {
    padding: 0 0 120px;
  }
}

@media only screen and (max-width: 768px) {
  .design-lounge {
    padding: 0 0 80px;
  }
}

.design-highlight {
  background-color: #4b4426;
  color: #ffffff;
  margin-top: -13.125vw;
  padding: 0 0 calc(140px + 13.125vw);
}

.design-highlight .caption {
  color: #ffffff;
}

.design-highlight .generalSlider__dir {
  border-color: rgba(255, 255, 255, 0.6);
}

.design-highlight .generalSlider__dir .arrowSVG path {
  stroke: rgba(255, 255, 255, 0.6);
}

.design-highlight .generalSlider__progress {
  color: #ffffff;
}

@media print, screen and (min-width: 769px) {
  .design-system {
    padding: 120px 0;
  }
}

@media only screen and (max-width: 768px) {
  .design-system {
    padding: 60px 0;
  }
}

.design-gate {
  background-color: #4b4426;
  color: #ffffff;
  margin-top: -13.125vw;
  padding-bottom: 80px;
}

.design-gate .caption {
  color: #ffffff;
}

.design-plant {
  background-color: #4b4426;
  color: #ffffff;
}

@media print, screen and (min-width: 769px) {
  .design-plant {
    padding: 100px 0 176px;
  }
}

@media only screen and (max-width: 768px) {
  .design-plant {
    padding: 0 0 140px;
  }
}
