@charset "UTF-8";
/*
  css設定 @charsetが消されるsass仕様へのハック用コメントです。削除しないでください。新規作成時も必須！
 */
/*==================================================================================
 top
==================================================================================*/
.site-header .text {
  color: #fff;
}

figure figcaption {
  position: absolute;
  bottom: 4px;
  right: 4px;
  color: #fff;
  text-align: right;
  font-size: 12px;
  letter-spacing: 0;
}

@media screen and (min-width: 769px) {
  .swipe-mark {
    display: none !important;
  }
}
.scroll-mark {
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
          writing-mode: vertical-rl;
  font-size: 12px;
  color: #fff;
  position: fixed;
  bottom: 80px;
  left: 4%;
  padding-bottom: 25px;
  line-height: 1.5;
  letter-spacing: 0;
  z-index: 10;
  opacity: 0;
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}

.scroll-mark.on {
  opacity: 1;
}

@-webkit-keyframes circle {
  0% {
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
  }
  30% {
    -webkit-transform: translate(-50%, -50%) scale(1);
            transform: translate(-50%, -50%) scale(1);
  }
}

@keyframes circle {
  0% {
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
  }
  30% {
    -webkit-transform: translate(-50%, -50%) scale(1);
            transform: translate(-50%, -50%) scale(1);
  }
}
@-webkit-keyframes circle2 {
  50% {
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
    opacity: 1;
  }
  70% {
    -webkit-transform: translate(-50%, -50%) scale(1);
            transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(-50%, -50%) scale(1);
            transform: translate(-50%, -50%) scale(1);
    opacity: 0;
  }
}
@keyframes circle2 {
  50% {
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
    opacity: 1;
  }
  70% {
    -webkit-transform: translate(-50%, -50%) scale(1);
            transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(-50%, -50%) scale(1);
            transform: translate(-50%, -50%) scale(1);
    opacity: 0;
  }
}
.scroll-mark .circle {
  position: absolute;
  width: 16px;
  height: 16px;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-55%);
          transform: translateX(-55%);
  border-radius: 50%;
  background-color: rgba(246, 202, 70, 0.6);
  overflow: hidden;
}

.scroll-mark .circle::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) scale(1);
          transform: translate(-50%, -50%) scale(1);
  width: 110%;
  height: 110%;
  border-radius: 50%;
  background-color: rgba(246, 202, 70, 0.6);
  -webkit-animation: circle 2s infinite forwards linear;
          animation: circle 2s infinite forwards linear;
}

.scroll-mark .circle::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) scale(0);
          transform: translate(-50%, -50%) scale(0);
  width: 110%;
  height: 110%;
  border-radius: 50%;
  background-color: #fff;
  -webkit-animation: circle2 2s infinite forwards linear;
          animation: circle2 2s infinite forwards linear;
  z-index: 2;
}

.top-infoes-wrap {
  position: relative;
  margin-bottom: 25px;
  padding: 10px 0 4px;
  z-index: 99;
}

.top-infoes-wrap.none {
  display: none !important;
}

.top-infoes-wrap .btns {
  margin: 0;
  padding-top: 8px;
  float: right;
  display: none;
}

.top-infoes-wrap .btns li {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  float: left;
  width: 140px;
  text-align: center;
  border: none;
}

.top-infoes-wrap .btns li:not(:last-child) {
  margin-right: 1px;
}

.top-infoes-wrap .btns li a {
  border-color: #000;
  color: #000;
}

@media (min-width: 1025px) {
  .top-infoes-wrap .btns li a:hover {
    opacity: 1 !important;
    color: #fff;
  }
}
.top-infoes-wrap .btns li .caption {
  position: absolute;
  right: 1%;
  bottom: 1%;
  line-height: 1;
  font-size: 10px;
  color: #000;
}

.top-infoes-wrap .links {
  float: right;
  padding: 18px 10px 0 0;
  font-size: 11px;
  letter-spacing: 0.12em;
}

.top-infoes-wrap .links li a {
  position: relative;
  padding-left: 8px;
  color: #000;
  overflow-x: hidden;
}

.top-infoes-wrap .links li a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: -2px;
  margin-top: -2px;
  width: 4px;
  height: 4px;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

@media (min-width: 1025px) {
  .top-infoes-wrap .links li a:hover {
    opacity: 0.7;
  }
}
.top-infoes-wrap .links li:first-child {
  padding-bottom: 8px;
}

.top-infoes-wrap .infoes-base {
  position: relative;
  height: 80px;
  z-index: 20;
}

.top-infoes-wrap .base {
  position: absolute;
  padding: 10px 5% 6px 5%;
  left: 0;
  bottom: 0;
  width: 90%;
  color: #000;
  z-index: 20;
  opacity: 0;
  background-color: rgba(255, 255, 255, 0.7);
  -webkit-transition: opacity 0.9s;
  transition: opacity 0.9s;
}

.top-infoes-wrap .base.fadeIn {
  opacity: 1;
}

.top-infoes-wrap .base:not(.fixed) {
  opacity: 1;
  display: block;
}

.top-infoes-wrap .base.fixed {
  position: fixed;
}

.top-infoes-wrap .inner {
  margin: 0 auto;
  max-width: 1200px;
}

.top-infoes-wrap .inner:after {
  content: "";
  width: 1px;
  height: 1px;
  display: table;
  clear: both;
}

.top-infoes-wrap .inner {
  margin: 0 auto;
  max-width: 900px;
}

.top-infoes-wrap a {
  -webkit-transition: opacity 0.7s;
  transition: opacity 0.7s;
}

.top-infoes-wrap a:hover {
  opacity: 0.65;
}

.top-infoes-wrap img {
  max-width: 100%;
  height: auto;
}

.top-infoes-wrap .contact .num {
  pointer-events: none;
}

.top-infoes-wrap .contact {
  margin-bottom: 0;
  padding: 0 0 0;
  float: left;
  width: 54%;
  letter-spacing: 0.1em;
  text-align: left;
}

.top-infoes-wrap .contact a {
  color: #000;
}

.top-infoes-wrap .contact .title {
  display: inline-block;
  padding-bottom: 5px;
  font-size: 12px;
}

.top-infoes-wrap .contact .number {
  display: inline-block;
  padding-right: 5px;
  position: relative;
  font-size: 36px;
}

.top-infoes-wrap .contact .number span.pc {
  line-height: 0.8;
}

@media screen and (min-width: 1025px) {
  .top-infoes-wrap .contact .number span.pc {
    display: inline-block !important;
  }
}
.top-infoes-wrap .contact .number a {
  display: inline-block;
  position: relative;
  padding-left: 40px;
}

.top-infoes-wrap .contact .number a:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -10px;
  width: 33px;
  height: 25px;
  background: url(../imgs/common/icon-freecall.svg) no-repeat;
}

.top-infoes-wrap .contact .businessHours {
  display: inline-block;
  padding-top: 8px;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-size: 11px;
}

@media screen and (max-width: 1024px) {
  .top-infoes-wrap {
    margin-bottom: 0;
    text-align: center;
    padding-top: 10px;
  }
  .top-infoes-wrap .infoes-base {
    height: auto;
    background: none;
  }
  .top-infoes-wrap .links {
    display: none;
  }
  .top-infoes-wrap .btns {
    float: none;
    margin: 0 auto;
    padding-top: 0;
    width: 70%;
  }
  .top-infoes-wrap .btns li {
    float: none;
    margin-right: 0 !important;
  }
  .top-infoes-wrap .btns li a {
    width: auto;
  }
  .top-infoes-wrap .btns li a:hover {
    opacity: 1 !important;
    color: #fff;
  }
  .top-infoes-wrap .base {
    position: static !important;
    background: none;
  }
  .top-infoes-wrap .contact {
    float: none;
    margin: 0 auto;
    width: 94%;
    text-align: center;
  }
  .top-infoes-wrap .contact .title {
    float: none;
    width: auto;
    line-height: 1.4;
  }
  .top-infoes-wrap .contact .title img {
    margin-bottom: 0;
  }
  .top-infoes-wrap .contact .businessHours {
    padding-top: 0;
    float: none;
    width: auto;
  }
  .top-infoes-wrap .contact .businessHours span.sp {
    display: inline !important;
  }
  .top-infoes-wrap .contact .businessHours br {
    display: none;
  }
  .top-infoes-wrap .contact .businessHours img {
    margin: 0 auto;
    height: auto;
  }
  .top-infoes-wrap .btns {
    padding-bottom: 30px;
  }
  .top-infoes-wrap .btns li {
    float: none;
    width: auto;
    height: auto;
  }
  .top-infoes-wrap .btns li:not(:last-child) {
    margin-bottom: 10px;
    padding: 0;
  }
  .top-infoes-wrap .btns li img {
    margin: 0 0 0 auto;
  }
  .top-infoes-wrap .contact {
    float: none;
    clear: both;
    width: auto;
  }
  .top-infoes-wrap .contact .title {
    padding-bottom: 10px;
  }
  .top-infoes-wrap .contact .title .pc {
    display: none !important;
  }
  .top-infoes-wrap .contact .title .sp {
    display: block !important;
  }
  .top-infoes-wrap .contact .number {
    float: none;
    clear: both;
    padding: 0 0px 10px 0;
    position: relative;
    font-size: 36px;
  }
}
@media screen and (max-width: 1024px) and (min-width: 1025px) {
  .top-infoes-wrap .contact .number span.pc {
    display: inline-block !important;
  }
}
@media screen and (max-width: 1024px) {
  .top-infoes-wrap .contact .number a {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 18px 0 18px 28px;
    width: 100%;
    color: #fff;
    font-size: 15px;
    background: #212933;
  }
  .top-infoes-wrap .contact .number a .sp {
    display: inline-block !important;
    width: auto;
  }
  .top-infoes-wrap .contact .number a:before {
    left: 50%;
    margin: -14px 0 0 -110px;
    width: 28px;
    height: 27px;
    background-image: url("../imgs/top/icon_tel.png");
    background-size: 100% auto;
  }
  .top-infoes-wrap .contact .businessHours {
    font-size: 10px;
  }
}
.infoes .bg {
  display: block;
  position: relative;
  padding-bottom: 430px;
  background: url(../imgs/top/footer-bg.jpg) no-repeat top center;
  background-size: cover;
}

.infoes .bg .caption {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 105px;
  line-height: 20px;
  background: rgba(43, 43, 43, 0.74);
  text-align: center;
}

.all-wrap-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 0;
  overflow: hidden;
}

.sp-container {
  display: block;
}

@media screen and (min-width: 768px) {
  .sp-container {
    -webkit-transform: translateY(0) !important;
            transform: translateY(0) !important;
  }
}
.image {
  position: relative;
}

.main-visual {
  position: relative;
  width: 100%;
  height: auto;
  -webkit-transition: opacity 1.8s;
  transition: opacity 1.8s;
  overflow: hidden;
}
.main-visual img {
  width: 100%;
}
.main-visual .bg {
  opacity: 0;
}
.main-visual .mv_txt {
  position: absolute;
  background: -webkit-gradient(linear, left top, right top, from(rgba(255, 246, 225, 0.6156862745)), to(#b49983));
  background: linear-gradient(to right, rgba(255, 246, 225, 0.6156862745), #b49983);
  padding: 2%;
  width: 35%;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .main-visual .mv_txt {
    width: 40%;
    padding: 3% 5%;
  }
}

.pageAnnotationArea {
  z-index: 9;
  background-color: #f1efeb;
}

.top-annotation {
  padding: 80px 0 50px;
  text-align: center;
  font-size: 14px;
  line-height: 2.2;
}

.top-annotation.text-nextday {
  padding: 0 0 168px;
}

.content-wrap-upper {
  background: #f6f1e8;
  color: #000;
}

.apeal {
  padding: 3% 0;
}
.apeal .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1200px;
  margin: auto;
}
.apeal .list li {
  border-left: 1px solid #5a6c84;
  width: 25%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-inline: auto;
}
.apeal .list li:first-child {
  border-left: none;
}
.apeal .list li a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: auto;
  width: 100%;
  max-width: 240px;
}
.apeal .list li a.none {
  pointer-events: none;
}
.apeal .list li a.none .top-btn {
  opacity: 0.5;
}
.apeal .list li a.none .btn-line {
  display: none;
}
.apeal .list li a .top-btn {
  max-width: 100px;
  padding-top: 1.3em;
}
.apeal .list li a .btn-line {
  position: absolute;
  top: 95%;
  right: 13%;
  width: 15%;
  height: 0.5px;
  background: #90640b;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .apeal .list li a .btn-line {
    height: 1px;
  }
}
.apeal .list li a .btn-line:after {
  content: "";
  position: absolute;
  /*top: 49%;*/
  right: -10%;
  width: 10px;
  height: 10px;
  border: 1px solid #90640b;
  border-radius: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
  transition: transform 0.4s ease, -webkit-transform 0.4s ease;
}
.apeal .list li a:hover {
  -webkit-filter: drop-shadow(1px 3px 4px rgba(0, 0, 0, 0.1137254902));
          filter: drop-shadow(1px 3px 4px rgba(0, 0, 0, 0.1137254902));
}
.apeal .list li a:hover .btn-line:after {
  -webkit-transform: translate(-350%, -50%);
          transform: translate(-350%, -50%);
}
.apeal a.none {
  pointer-events: none;
}

.information {
  max-width: 1100px;
  margin: 0 auto 6%;
  padding: 0;
  text-align: center;
  background: -webkit-gradient(linear, left top, right top, from(#fff6e1), to(#b49983));
  background: linear-gradient(to right, #fff6e1, #b49983);
}
.information .wrap {
  padding: 4em 1em;
}
@media screen and (max-width: 768px) {
  .information .wrap {
    padding: 3em 0.5em;
  }
}
.information .title {
  padding-bottom: 1.7%;
  font-size: min(3vw, 1em);
  line-height: 1.6;
  font-weight: normal;
}
.information .lead {
  padding-bottom: 4.5%;
  font-size: min(5vw, 1.6em);
  letter-spacing: 0.3em;
  line-height: 1.7;
}
.information .text01 {
  padding-bottom: 15px;
  font-size: 24px;
  line-height: 1.7;
}
.information .text01 .pb30 {
  padding-bottom: 30px;
}
.information .text02 {
  padding-bottom: 15px;
  font-size: 14px;
  line-height: 2;
}
.information .text03 {
  padding-bottom: 38px;
  font-size: 14px;
  line-height: 2;
}
.information .text03 span {
  margin-right: 10px;
}
.information .text03 span:last-child {
  margin-right: auto;
}
.information .text04 {
  font-size: 14px;
  line-height: 2.2;
  margin-bottom: 40px;
}
.information .text05 {
  font-size: 14px;
  line-height: 2.2;
  letter-spacing: 0;
}
.information .text05 span {
  margin-top: 3em;
  display: inline-block;
}
.information .text06 {
  font-size: 15px;
  line-height: 2;
  margin: 20px auto 20px;
}
.information .line {
  position: relative;
  padding-bottom: 40px;
}
.information .line:after {
  position: absolute;
  content: "";
  display: block;
  height: 1px;
  width: 100px;
  background: #fff;
  top: 0px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.information .holiday {
  margin-bottom: 50px;
  font-size: 14px;
  line-height: 1.9;
}
.information .holiday span {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-bottom: 10px;
}
.information .holiday span:before, .information .holiday span:after {
  content: "";
  height: 1px;
  width: 150px;
  background-color: #fff;
}
.information .holiday span:before {
  margin-right: 1rem;
}
.information .holiday span:after {
  margin-left: 1rem;
}
.information .text-nextday {
  font-size: 14px;
  padding-block: 2% 0;
}

.remote-bnr {
  text-align: center;
  max-width: 770px;
  margin: 0 auto 100px;
}

.page-content .content-title {
  position: relative;
  padding-bottom: 75px;
  font-size: 22px;
  color: #c9bda9;
  text-align: center;
  font-weight: normal;
}
.page-content .content-title:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 55px;
  background-color: #c9bda9;
}
.page-content .btn-line {
  top: 60% !important;
}

.concept-section {
  position: relative;
  width: 100%;
  height: 1px;
  top: 0;
  left: 0;
  z-index: 1;
  background: -webkit-gradient(linear, left top, right top, color-stop(20%, #0d4130), to(#00150e));
  background: linear-gradient(90deg, #0d4130 20%, #00150e 100%);
}
.concept-section .bg-r {
  position: absolute;
  top: 0;
  right: 0;
  width: 15%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .concept-section .bg-r {
    width: 30%;
    z-index: -1;
  }
}
.concept-section .bg-l {
  position: absolute;
  bottom: -32vh;
  left: 0;
  width: 14vw;
  z-index: 1;
}
@media screen and (max-width: 1600px) {
  .concept-section .bg-l {
    bottom: -39vh;
  }
}
@media screen and (max-width: 1440px) {
  .concept-section .bg-l {
    bottom: -33vh;
  }
}
@media screen and (max-width: 768px) {
  .concept-section .bg-l {
    z-index: -1 !important;
  }
}
.concept-section .caption {
  z-index: 2;
}
.concept-section .fix-wrap {
  position: absolute;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  overflow: hidden;
}
.concept-section.on .fix-wrap {
  position: fixed;
}
.concept-section .inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 2;
  color: #fff;
  text-align: center;
}
.concept-section .read00 {
  width: 17%;
  max-width: 100px;
  margin: 8vh auto 5vh;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
}
@media screen and (max-width: 768px) {
  .concept-section .read00 {
    margin: 5vh auto 4vh;
  }
}
.concept-section .read01 {
  margin: 9vh auto 1.5em;
  width: 80%;
  max-width: 600px;
  z-index: 2;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}
.concept-section .read01.scroll-mark {
  display: inline-block;
  display: none;
  width: 3%;
  min-width: 60px;
  top: 70vh;
  left: 48.5%;
}
.concept-section .body-concept {
  color: #fff;
}
.concept-section .body-concept .read02 {
  margin-inline: auto;
  text-align: center;
  font-size: min(4.5vw, 2em);
  line-height: 2.1;
  margin-bottom: 0.3em !important;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
  -webkit-transition-delay: 0.7s;
          transition-delay: 0.7s;
}
.concept-section .body-concept .read03 {
  padding-top: 1vh;
  margin: 0 auto;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}
.concept-section .body-concept .read03 .text03 {
  padding-bottom: 2em;
  font-size: min(3vw, 14px);
  text-align: center;
  line-height: 4vh;
}
@media screen and (max-width: 768px) {
  .concept-section .body-concept .read03 .text03 {
    line-height: 3vh;
  }
}
.concept-section .body-concept .read03 .text04 {
  padding-bottom: 2em;
  font-size: min(3.8vw, 1.1em);
  text-align: center;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .concept-section .body-concept .read03 .text04 {
    letter-spacing: 0.05em;
  }
}
.concept-section .body-concept .read04 {
  margin: 0 auto;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, transform 0.5s;
  transition: opacity 0.5s, transform 0.5s, -webkit-transform 0.5s;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}

.panels-wrap {
  position: relative;
  z-index: 3;
  background-color: #000;
}
.panels-wrap a:hover {
  opacity: 1;
}
.panels-wrap .none {
  pointer-events: none;
}

.fix-box-inner {
  left: 0;
}

.pageAnnotationArea {
  position: relative;
  z-index: 11;
}
.pageAnnotationArea .bnr {
  max-width: 600px;
  margin: 40px auto;
}

.commonBannerArea {
  position: relative;
  z-index: 11;
}

.panels {
  position: relative;
  overflow: hidden;
  top: 0;
  left: 0;
  width: 100%;
  height: 230vh;
  z-index: 2;
}
.panels .panel-inner {
  position: absolute;
  overflow: hidden;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
}
.panels .panel-inner .bg-l {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 18%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner .bg-l {
    width: 37%;
    bottom: 7vh;
  }
}
.panels .panel-inner .imglink.nolink {
  pointer-events: none;
}
.panels .panel-inner .imglink figure {
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 65vw;
  overflow: hidden;
  z-index: 1;
}
.panels .panel-inner .imglink figure img {
  -webkit-transition: 0.8s all;
  transition: 0.8s all;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner .imglink figure {
    width: 96vw;
    top: 33vh;
  }
}
.panels .panel-inner .imglink:hover figure img {
  -webkit-transform: scale(1.03);
          transform: scale(1.03);
}
.panels .panel-inner .bgs {
  position: relative;
  width: 100%;
  height: 100vh;
}
.panels .panel-inner .page-name {
  position: absolute;
  top: 30vh;
  left: 0;
  font-size: 12px;
  line-height: 12px;
  color: #fff;
  z-index: 3;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
}
.panels .panel-inner .page-name:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  width: 190px;
  height: 1px;
  background-color: #fff;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.panels .panel-inner .page-name span {
  position: relative;
  display: block;
  padding-left: 200px;
  z-index: 3;
}
.panels .panel-inner .title {
  position: absolute;
  top: 31%;
  left: 9%;
  text-align: left;
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
          writing-mode: vertical-rl;
  font-size: 1.8em;
  font-weight: normal;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  color: #fff;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner .title {
    top: 27vh;
    font-size: 5.5vw;
  }
}
.panels .panel-inner .title .num {
  text-combine-upright: all;
  font-style: normal;
  display: inline-block;
  margin-left: -0.5em;
  margin-bottom: 0.2em;
}
.panels .panel-inner .title .subs {
  display: inline-block;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
  line-height: 2;
}
.panels .panel-inner .title .sub02 {
  padding-top: 4.5em;
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.panels .panel-inner .body {
  position: absolute;
  left: 24%;
  top: 47%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 40%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  color: #fff;
  transform: translateY(-50%);
  z-index: 3;
}
.panels .panel-inner .body a {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 38%;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner .body {
    top: 63vh;
    right: auto;
    left: 11%;
    width: 80%;
  }
}
@media screen and (max-width: 375px) {
  .panels .panel-inner .body {
    top: 69%;
  }
}
.panels .panel-inner .section-concept .body {
  left: 0;
  right: 0;
  margin: auto;
}
.panels .panel-inner .common-button03 {
  margin-right: 0;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}
.panels .panel-inner .common-button03:after {
  background: -webkit-gradient(linear, left top, right top, from(#cba97d), to(#887253));
  background: linear-gradient(90deg, #cba97d, #887253);
}
.panels .panel-inner .text01 {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 2em;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
  -webkit-transition-delay: 0.75s;
          transition-delay: 0.75s;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner .text01 {
    margin-bottom: 0.7em;
  }
}
.panels .panel-inner .text01 img {
  height: 2.3em;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner .text01 img {
    height: 1.4em;
  }
}
.panels .panel-inner .text02 {
  font-size: 14px;
  line-height: 2.6;
  padding-bottom: 4%;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  opacity: 0;
  -webkit-transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, -webkit-transform 1.5s;
  transition: opacity 1.5s, transform 1.5s;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s;
  -webkit-transition-delay: 1.05s;
          transition-delay: 1.05s;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner .text02 {
    line-height: 2.2;
  }
}
.panels .panel-inner.rev .bg-r {
  position: absolute;
  top: 0;
  right: 0;
  width: 15%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner.rev .bg-r {
    width: 30%;
  }
}
.panels .panel-inner.rev figure {
  left: 0;
}
.panels .panel-inner.rev .title {
  right: 9%;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner.rev .title {
    right: auto;
    left: 7%;
    top: 24%;
  }
}
.panels .panel-inner.rev .title .sub02 {
  padding-top: 2em;
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.panels .panel-inner.rev .title .sub03 {
  padding-top: 4.5em;
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
.panels .panel-inner.rev .body {
  position: absolute;
  left: 34%;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner.rev .body {
    left: 10%;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.panels .panel-inner.rev .text01 {
  padding-right: 1%;
}
.panels .panel-inner.rev .text02 {
  text-align: right;
}
@media screen and (max-width: 768px) {
  .panels .panel-inner.rev .text02 {
    text-align: left;
  }
}
.panels .panel-inner.rev .btnlink {
  margin-right: -12%;
}
.panels .panel-inner.rev .btnlink.coming {
  margin-right: -16%;
}
.panels .panel-inner .btn_more {
  opacity: 0;
}
.panels.on .panel-inner {
  position: fixed;
}
.panels.on .page-name {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.on .title .subs {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.on .reads.subs {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.on .common-button03 {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.on .text02 {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.on .texts {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.on .btn_more {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.on .text01 {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.panels.section-access .title {
  top: 31%;
  left: 7%;
}
@media screen and (max-width: 768px) {
  .panels.section-access .title {
    top: 27vh;
  }
}
.panels.section-access .title .sub02 {
  padding-top: 1.5em;
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.panels.section-access .title .sub03 {
  padding-top: 3em;
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}

.section-concept {
  z-index: 3;
}
.section-concept .bgs {
  background-image: url(../imgs/top/bg05.jpg);
}

.section-plan {
  z-index: 4;
}
.section-plan .bgs {
  background: #b69a84;
}

.section-location {
  z-index: 5;
}
.section-location .bgs {
  background: #9b897b;
}

.section-access {
  z-index: 6;
}
.section-access .bgs {
  background: #b69a84;
}

.section-support {
  z-index: 7;
}
.section-support .bgs {
  background: #a29082;
}

.btnlink .btn_more {
  width: 43%;
}
.btnlink .btn_more .btn-line:after {
  right: -11%;
}
@media screen and (max-width: 768px) {
  .btnlink .btn_more .btn-line:after {
    right: -10%;
  }
}
@media screen and (max-width: 768px) {
  .btnlink .btn_more {
    width: 70%;
  }
}
.btnlink:hover .btn_more .btn-line:after {
  -webkit-transform: translate(-2.3vw, -50%);
          transform: translate(-2.3vw, -50%);
}
@-moz-document url-prefix() {
  .btnlink:hover .btn_more .btn-line:after {
    transform: translate(-2.25vw, -50%);
  }
}
@media screen and (max-width: 768px) {
  .btnlink:hover .btn_more .btn-line:after {
    -webkit-transform: translate(-450%, -50%);
            transform: translate(-450%, -50%);
  }
}
.btnlink.coming {
  pointer-events: none;
}
.btnlink.coming .btn_more {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.btnlink.coming .btn-line {
  display: none;
}
.btnlink.coming p {
  color: rgba(255, 255, 255, 0.4901960784);
  font-size: 1em;
}

/*==================================================================================
 top-sp
==================================================================================*/
@media (max-width: 768px) {
  .image {
    position: relative;
  }
  .main-visual-wrap {
    position: relative;
  }
  .main-visual-wrap .bg {
    opacity: 0;
  }
  .sp-container {
    display: none;
    padding: 0 10px;
  }
  .sp-container-content {
    padding: 20px 0;
  }
  .sp-container-content .information {
    padding: 0;
    background: none;
  }
  .sp-container-content .information .wrap {
    padding: 0em 0.5em;
  }
  .sp-container-content .information .title {
    padding-top: 20px;
    padding-bottom: 20px;
    line-height: 1.2;
  }
  .sp-container-content .information .lead {
    padding-bottom: 10px;
    font-size: 1.3em;
  }
  .sp-container-content .information .text01 {
    padding-bottom: 10px;
    font-size: 12px;
  }
  .sp-container-content .information .text01.pb20 {
    padding-bottom: 20px;
  }
  .sp-container-content .information .text02 {
    font-size: 10px;
    padding-bottom: 20px;
  }
  .sp-container-content .information .text03 {
    padding-bottom: 10px;
    font-size: 11px;
  }
  .sp-container-content .information .text04 {
    font-size: 11px;
    line-height: 2;
    margin-bottom: 20px;
  }
  .sp-container-content .information .text05 {
    font-size: 10px;
    line-height: 1.6;
  }
  .sp-container-content .information .text06 {
    font-size: 12px;
    padding-bottom: 10px;
    margin: auto;
  }
  .sp-container-content .information .holiday {
    font-size: 12px;
  }
  .sp-container-content .information .inner {
    border: none;
    padding-bottom: 3%;
  }
  .sp-container-content .information .button {
    padding-top: 20px;
    margin-bottom: 7%;
  }
  .sp-container-content .information .line {
    position: relative;
    padding-bottom: 20px;
  }
  .main-visual {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
    margin-top: 92px;
  }
  .main-visual .top-movie video {
    height: 84vw;
  }
  .main-visual .caption.top01 {
    bottom: 40.5%;
  }
  .main-visual .caption.top02 {
    bottom: 79.5%;
  }
  .main-visual .caption.right01 {
    right: 47%;
  }
  .main-visual .caption.right03 {
    right: 0;
    bottom: 20%;
  }
  .content-wrap {
    z-index: 99;
  }
  .top-annotation {
    padding: 0px 0 20px;
    font-size: 11px;
    line-height: 1.9;
  }
  .apeal .list {
    display: block;
    border: none;
    padding-top: 30px;
  }
  .apeal .list li {
    width: 80%;
    margin: 0 auto 8vw;
    border-left: none;
    border-bottom: 1px solid #5a6c84;
    padding-bottom: 5vw;
  }
  .content-wrap-upper {
    background: #f6f1e8;
  }
  .content-wrap-upper .common-button03 {
    border: none;
  }
  .content-wrap-upper .common-button03::after {
    opacity: 1;
  }
  .information {
    padding: 0;
    margin-bottom: 0;
  }
  .information .title {
    padding-bottom: 10px;
    line-height: 1.2;
  }
  .information .lead {
    padding-bottom: 15px;
    font-size: 22px;
  }
  .information .text01 {
    padding-bottom: 10px;
    font-size: 14px;
  }
  .information .text02 {
    font-size: 12px;
    padding-bottom: 30px;
  }
  .information .text03 {
    padding-bottom: 10px;
    font-size: 14px;
  }
  .information .text04 {
    font-size: 12px;
    line-height: 1.9;
    margin-bottom: 20px;
  }
  .information .text05 {
    font-size: 12px;
  }
  .information .text06 {
    font-size: 14px;
    padding-bottom: 10px;
    margin: auto;
  }
  .information .text-nextday {
    font-size: 12px;
  }
  .information .holiday {
    font-size: 12px;
  }
  .information .inner {
    border: none;
    padding-bottom: 3%;
  }
  .information .button {
    padding-top: 20px;
  }
  .information.sp-info {
    padding: 60px 0 0;
  }
  .information.sp-info .title {
    font-size: 16px;
    line-height: 1.5;
    padding-top: 24px;
  }
  .information.sp-info .lead {
    font-size: 20px;
    line-height: 2;
  }
  .information.sp-info .lead.pb30 {
    padding-bottom: 30px;
  }
  .information.sp-info .txt01 {
    font-size: 14px;
    line-height: 1.6;
    padding-bottom: 20px;
  }
  .information .holiday {
    font-size: 12px;
    letter-spacing: 0.08em;
  }
  .information .holiday span:before,
  .information .holiday span:after {
    content: "";
    height: 1px;
    width: 80px;
    background-color: #fff;
  }
  .remote-bnr {
    margin: 60px auto 0;
  }
  .panels .page-name {
    top: 5vh;
  }
  .panels .page-name::after {
    width: 130px;
  }
  .panels .page-name span {
    padding-left: 150px;
  }
  .panels .title {
    position: absolute;
    top: 4vh;
    left: 50%;
    font-size: 24px;
    line-height: 2;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .panels .title .num {
    text-combine-upright: all;
    font-style: normal;
  }
  .panels .body {
    position: absolute;
    top: 60vh;
    right: auto;
    left: 10%;
    width: 80%;
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  .panels .common-button03 {
    margin: 0 auto;
  }
  .panels .text01 {
    font-size: 22px;
    line-height: 1.8;
    padding-bottom: 0;
    margin-bottom: 0.5em;
  }
  .panels .text02 {
    padding-bottom: 0.5em;
  }
  .panels .text02 br {
    display: none;
  }
  .panels .bgs {
    background-image: url(../imgs/top/bg01-sp.jpg);
  }
  .section-plan .bgs {
    background: #928071;
  }
  .section-location .bgs {
    background: #827367;
  }
  .section-access .bgs {
    background: #928071;
  }
  .section-support .bgs {
    background: #827367;
  }
}
