@charset "utf-8";

/* 
Theme Name: theterrace
*/
@font-face {
  font-family: 'YonagaOldMincho';
  src: url("../font/YonagaOldMincho-Regular.ttf") format("truetype");
}
@font-face {
  font-family: 'YonagaOldMinchoBold';
  src: url("../font/YonagaOldMincho-Bold.ttf") format("truetype");
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
html{
    overflow-x: hidden;
  }
body {
    font-family: 'Noto Sans JP','YuGothic','Yu Gothic','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
    background-color:#FFFFFF;
    color: #272C26;
    /* overflow-y: scroll; */
    overflow-x: clip;
    box-sizing: border-box;
}

img,
video {
    width: 100%;
}

a {
    text-decoration: none;
    color: #3f4e64;
 
}
a:hover {
    opacity: 0.7;
}
li {
    list-style: none;
}
/* 共通 */
.pc {
    display: block;
}

.sp,.sp_2 {
    display: none!important;
}

@media (max-width: 768px) {
    .pc {
        display: none!important;
    }

    .sp {
        display: block!important;
    }
}
@media (max-width: 480px) {
  .sp_2 {
    display: block!important;

  }
}
/* ヘッダー */

/* ヘッダー共通 */
.header {
    width: 100%;
    height: 90px;
    background-color: rgba(63, 78, 100,0.4);
    backdrop-filter: blur(8px);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
  }
  
  .header_inner {
    /* max-width: 1280px; */
    /* margin: 0 auto; */
    padding: 0 40px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    height: 100%;
    margin-left: auto;
  }
  .headerNav .header_inner {
    height:auto;
    margin-right: 80px;
    margin-top: 30px;

  }
  .logo {
    position: absolute;
    top:0;
    left:0;
    width:180px;
    height:250px;
    z-index: 99;
  }

  .nav_sns_wrapper {
    display:flex;
    gap:26px;
  }
  .nav_sns  {
    width:20px;
    height:20px;
  }
  .nav_sns img {
    width: 20px;
    height:20px;
    object-fit: contain;
  }
  /* メニュー */
  .headerMenu {
    display: flex;
    align-items: center;
    gap: 20px;
    list-style: none;
  }
  .headerNav .headerMenu {
    gap:30px;
  }
  .headerMenu li a,
  .headerMenu li button {
    color: #fff;
    font-size: 16px;

  }
  .header_btn{
    border:1px solid #fff;
    border-radius: 30px;
    padding: 6px 14px;
  }
  .header_sns_icon,.header_sns_icon img {
    width:20px;
    height:20px;
  }
  /* Reserve ボタン */
  .reserve_btn {
    background-color: #B0A38F;
    border-radius: 30px;
    color: #fff;
    text-decoration: none;
    font-size: 13px;
    font-family: YonagaOldMincho, serif;
    letter-spacing: 0.7px;
    padding: 8px 16px;
  }
  
  /* ハンバーガーボタン */
  .hamburger_btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 24px;
    height: 24px;
    background: none;
    border: none;
    cursor: pointer;
  }
  .hamburger_line {
    height: 2px;
    width: 100%;
    background-color: white;
  }
  

  .headerNav.active {
    opacity: 1;
    pointer-events: auto;
    overflow-y: scroll;
    overflow-x: hidden;
  }
  .headerNav.active .logo {
    z-index: 100;
  }
  .close_btn {
    position: absolute;
    top: 24px;
    right: 32px;
    font-size: 32px;
    color: #fff;
    background: none;
    border: none;
    cursor: pointer;
    z-index: 1001;
  }
  
  .navmenu {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
	margin: 130px auto 0;
    /* margin-left:250px; */
  }
  
  .navmenu-columns {
    display: flex;
	gap: 100px;
    justify-content: center;
    align-items: flex-start;
  }
  
  .navList {
    list-style: none;
    padding: 0;
    margin: 0;
    min-width: 220px;
  }

  
  .headerMenu li.navItem a {
    font-family: HiraginoSans-W3,'Noto Serif JP';
  font-size: 20px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height:60px;
  letter-spacing: 2px;
  text-align: left;
  color:#fff;
    text-decoration: none;
    font-size: 15px;
    transition: opacity 0.2s;
  }

  .headerMenu li.navItem02 a {
    font-family: HiraginoSans-W3,'Noto Serif JP';
  font-size: 20px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height:45px;
  letter-spacing: 2px;
  text-align: left;
  color:#fff;
    text-decoration: none;
    font-size: 15px;
    transition: opacity 0.2s;
  }

  
  .navItem a:hover {
    opacity: 0.7;
  }

  .navItem02 a:hover {
    opacity: 0.7;
  }
  
  .headerMenu li.navTitle a{
    font-family: YonagaOldMincho;
  font-size: 21px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 2.08;
  letter-spacing: 2.4px;
  line-height:60px;
}

  .headerMenu li.navTitle02 a{
  font-family: YonagaOldMincho;
  font-size: 21px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 2.08;
  letter-spacing: 2.4px;
  line-height:60px;
}

  .headerMenu li.navTitle {
    font-family: YonagaOldMincho;
  font-size: 21px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 2.08;
  letter-spacing: 2.4px;
  line-height:60px;
  color:#fff;
}

  .headerMenu li.navTitle02 {
    font-family: YonagaOldMincho;
  font-size: 21px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 2.08;
  letter-spacing: 2.4px;
  line-height:60px;
  color:#fff;
}

  .headerMenu li.navTitle_pc a{
    font-family: YonagaOldMincho;
  font-size: 21px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 2.08;
  letter-spacing: 2.4px;
  line-height:60px;
  display: block;
  margin-top: 15px;
}

  .headerMenu li.navTitle_sp a{
    font-family: YonagaOldMincho;
  font-size: 21px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 2.08;
  letter-spacing: 2.4px;
  line-height:60px;
  display: none;
  margin-top: 25px;
}
span.link-icon {
    background: url(../images/page/link-icon.png) no-repeat;
    padding: 0 0 0 24px;
    margin-left: 20px;
}
  #drawer {
    position: relative;
    z-index: 1000;
  }
  
 /* ハンバーガーアイコン */
.hamburger-fade {

  width: 60px;
  height: 60px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  
}
.hamburger-fade__wrapper {
  position: relative;
  width: 30px;
  height: 20px;
  z-index: 200;  
}
.hamburger-fade__line {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #fff;
  transition: all 0.5s cubic-bezier(0.23, 1, 0.32, 1);
  /* z-index: 200; */
}
.hamburger-fade__line:nth-child(1) { top: 0; width:40px;}
.hamburger-fade__line:nth-child(2) { top: 9px; width:28px;}
.hamburger-fade__line:nth-child(3) { top: 18px; width:20px;}
.hamburger-fade.active .hamburger-fade__line {
  background-color: #fff;
}

.hamburger-fade.active .hamburger-fade__line:nth-child(1) {
  transform: translateY(9px) rotate(45deg);
  width:28px;
}
.hamburger-fade.active .hamburger-fade__line:nth-child(2) {
  opacity: 0;
  transform: translateX(20px);
}
.hamburger-fade.active .hamburger-fade__line:nth-child(3) {
  transform: translateY(-9px) rotate(-45deg);
  width:28px;
}

/* メニュー本体（フェードイン/アウト） */
.headerNav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-image: url(../images/nav_bg.webp);
  background-repeat: no-repeat;
  background-size: cover;
  /* background: rgba(34, 34, 34, 0.85); */
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s;
  /* display: flex;
  align-items: center;
  justify-content: center; */
}



/* レスポンシブ */
@media (max-width: 1100px) {

  .navmenu-columns {
    flex-direction: column;
    gap: 32px;
    width:50%;
    /* padding-top:200px; */
  }
  .navList {
    min-width: 0;
    width: 100%;
  }
  .navTitle,.navItem {
    text-align: left;
    
  }
  .navmenu {
    margin-left:100px;
    margin-top: 200px;
    margin-bottom:100px;
  }
  .header_inner {
    position: relative;
  }
}
@media (max-width: 600px) {
  .hamburger-fade {
    top: 12px;
    right: 12px;
    width: 44px;
    height: 44px;
  }
  .nav_sns img {
    width:24px;
    height:24px;
  }
  .navmenu-columns {
    gap: 40px;
    width:100%;
  }
  .navList {
    font-size: 16px;
  }
  .navmenu {
   
    margin-left:0;
    height: auto;
    width:80%;
    margin:37px auto 130px;
 
  }
  .headerMenu li.navTitle {
    margin-bottom:15px;
  }
  .headerMenu li.navTitle_pc {
    margin-bottom:15px;
  }
  .headerMenu li.navTitle_sp {
    margin-bottom:15px;
  }
  .headerMenu li.navTitle a {
    font-size:18px;
    line-height: 1.6;
 
  }

  .headerMenu li.navTitle {
    font-size:18px;
    line-height: 1.6;
 
  }
  .headerMenu li.navTitle02 {
    font-size:18px;
    text-align: left;
  }
  .headerMenu li.navTitle.member a{
    letter-spacing: 0;
  }
  .headerMenu li.navItem {
    padding:8px 0 8px 0 !important
  }
  .headerMenu li.navItem a{
    font-size:16px;
    line-height: 1.6;
   
  }
  .headerMenu li.navTitle02.member a{
    letter-spacing: 0;
  }
  .headerMenu li.navItem02 a{
    font-size:14px;
    line-height: 2.8;
   text-align: left;
  }
.headerMenu li.navTitle_pc a{
  display: none;
  font-size:18px;
  line-height: 1.6;
　text-align: left;
}

.headerMenu li.navTitle_sp a{
  display: block;
  font-size:18px;
  line-height: 1.6;
  text-align: left;
  margin-bottom: -10px;
}
.headerMenu li.navTitle02 a{
  display: block;
  font-size:18px;
  text-align: left;
}
li.navItem02 {
    text-align: left;
	margin-bottom: -10px;
}
li.navTitle02 {
    margin-bottom: -10px;
}
}
/* フッター */
.footer {
  background-color: #3F4E64;
  padding:56px;
}
.footer_nav {
  width:fit-content;
  margin:0 auto 60px;
}
.footer_nav ul{
  display: flex;
  gap:80px;
}
.footer_nav ul li a {
  color:#fff;
  font-size:18px;
  font-family: YonagaOldMincho,serif;
  font-weight: normal;
}
.footer_logo {
  width:210px;
  margin:0 auto;
}
.footer_info {
  font-family: YonagaOldMincho,serif;
  font-size: 16px;
  color:#fff;
  text-align: center;
}

.footer_sns {
  width: fit-content;
  margin:85px auto 42px;
  display:flex;
  gap:32px;
}
.footer_sns_icon {
  width:24px;
  height:24px;
  display: block;
}
.copyright {
  text-align: center;
  color: #fff;
  font-size:12px;
  font-family: YonagaOldMincho,serif;
}
/* 共通 */

.section_title_line {
  max-width:100%;
  padding:0 0 68px;
  margin:0 auto;
  display: block;
}
.section_title_line2 {
  max-width:88%;
  padding:0 0 68px;
  margin:0 auto;
  display: block;
}
.top_section_title {
  width:auto;
  height: 50px;
  margin:0 auto;
  display:block;
}
.section_head span {
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  display: block;
  color: #3f4e64;
  letter-spacing: 0.9px;
  margin-top:7px;
}
.section_head {
    width: 100%;
    margin: 0 auto;
}
.more_link {
  display:block;
  width:220px;
}
.more_left {
  position: absolute;
  bottom: 10%;
  left: 57%;
  z-index: 10;
}
.more_right {
  position: absolute;
  bottom: 10%;
  right: 57%;
  z-index: 10;
}
.more_center {
  margin:0 auto;
}
.link_reserve {
  margin:45px auto;
  max-width:310px;
  width: fit-content;
}
.link_reserve .reserve_btn {
  font-size: 18px;
  color:#fff;
  font-family: YonagaOldMincho,serif;
  padding:18px 32px;
  border-radius: 50px;
  letter-spacing: 1px;
}
.link_reserve .reserve_btn span {
  font-size:20px;
  color:#fff;

}
.swiper-pagination-bullet {
  background-color: transparent; /* 背景色を透明に */
  background-image: url(../images/pagenation.png);
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: unset; /* これがないと画像が欠ける */
  height: 7px;
  opacity: 1; /* 画像の透過を無くす */
  width: 7px;
}
/* 選択されているページネーション */
.swiper-pagination-bullet-active {
  background-image: url(../images/pagenation_active.png);
  height: 13px;
  width: 13px;
}
/* TOP 2カラム*/
.top_column_section {
  position: relative;
  margin-bottom:150px;
}
.top_column_content_wrapper {
  max-width: 1920px;
  margin: 0 auto;
  display: flex;
  background: #fff;
  padding-top:81px;
  padding-right:40px;
}
.top_column_content_wrapper_reverse {
  max-width: 1920px;
  margin: 0 auto;
  display: flex;
  background: #fff;
  padding-top:65px;
  padding-left:40px;
}
.top_column_image_left,
.top_column_image_right{
  width: calc(50% + 40px);
  min-width: 0;
  position: relative;
  z-index: 1;
}
.top_column_image_left::after {
  content:"";
  background-color: #B0A38F;
  opacity:0.1;
  height:100%;
  width:320px;
  position: absolute;
  bottom:0;
  right: 0;
  z-index: -1;
}
.top_column_image_right::after {
  content:"";
  background-color: #B0A38F;
  opacity:0.1;
  height:100%;
  width:320px;
  position: absolute;
  bottom:0;
  left:0;
  z-index: -1;
}
.top_column_image_left img,
.top_column_image_right img {
  width: 100%;
  /* height: 640px; */
  object-fit: cover;
  display: block;
}

.top_column_content_left {
  width: 50%;
  /* background-color: rgba(176, 163, 143,0.1); */
  padding: 100px 0px 240px 100px;
  margin-top: 68px;
  display: flex;
  flex-direction: column;
  justify-content: start;
  height: 650px;
  position: relative;
}
.top_column_content_right {
  width: 50%;
  /* background-color: rgba(176, 163, 143,0.1); */
  padding: 100px 100px 240px 180px;
  margin-top: 68px;
  display: flex;
  flex-direction: column;
  justify-content: start;
  height: 650px;
  position: relative;
}
.top_column_content_left::after {
  content:"";
  background-color: #B0A38F;
  opacity:0.1;
  height:100%;
  width:100%;
  position: absolute;
  bottom:0;
  left:0;
}
.top_column_content_right::after {
  content:"";
  background-color: #B0A38F;
  opacity:0.1;
  height:100%;
  width:100%;
  position: absolute;
  bottom:0;
  right:0;
}
  .top_column_content_left h3 ,
  .top_column_content_right h3{
  font-size: 25px;
  color: #3f4e64;
  font-weight: 400;
  line-height: 1.56;
  letter-spacing: 1.6px;
  margin-bottom: 60px;
  font-family: YonagaOldMincho,serif;
  padding:0 20px;
}

.top_column_content_left p ,
  .top_column_content_right p {
  color: #757575;
  font-size: 15px;
  line-height: 2.15;
  letter-spacing: 1px;
  margin-bottom: 32px;
  max-width:640px;
  padding:0 20px;
}







/* メイン */
.mainVisual {
    position: relative;
    width: 100%;
	height: 115vh;
	overflow: hidden;
  padding-top:0;
  /* overflow-y: visible; */
  }
  .front-mv-slider {
	height: 100vh;
	width: 100vw;

	z-index: 0;
}

.front-mv-slider img {
	width: 100vw;
	height: 100vh;
	object-fit: cover;
	display: block;
}

.front-mv-slider .slick-slide {
	opacity: 0;
	transition: opacity 1s linear;
}
.front-mv-slider .slick-slide.slick-current {
	opacity: 1;
}
.slide-animation {
  animation: fadezoom 10s linear 0s normal forwards;
  will-change: transform;
}

@keyframes fadezoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.08);
  }
}
/* レスポンシブ対応のアニメーション */
@media (max-width: 768px) {
  .slide-animation {
    animation: fadezoom 8s linear 0s normal forwards;
  }
}

@media (max-width: 480px) {
  .slide-animation {
    animation: fadezoom 6s linear 0s normal forwards;
  }
}
.mainVisual_inner {
  position: absolute;
  bottom:20%;
  right: 6.45%;
  color:#fff;
}

.mainVisual_inner h1 {
  font-family: YonagaOldMincho,serif;
  font-size: 30px;
  font-weight: normal;
  line-height: 1.74;
  letter-spacing: 4.6px;
}
.mainVisual_inner  span {
  font-size: 30px;
  font-weight: normal;
  padding-top: 40px;
  display: block;
  font-family: 'YonagaOldMincho';
  letter-spacing: 2.4px;
}
.mv_scroll {
  position: absolute;
  left: 51px; /* 画面左からの距離は調整してください */
  bottom: 150px;  /* 上からの距離も調整 */
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  z-index: 20;
}

.mv_scroll em {
  font-size: 18px;
    font-family: 'YonagaOldMincho';
    font-weight: 400;
    font-style: normal;
    margin-top: -200px;
    /* margin-left: calc(-.5rem + 1px); */
    display: block;
    line-height: 1;
    text-decoration: none;
    color: #fff;
    letter-spacing: 2px;
    writing-mode: vertical-rl;
}

.mv_scroll span {
  display: block;
  width: 1px;
 
  background: #9F7F48; /* ゴールド系の色 */
  animation: scroll 2s infinite;
  bottom: -216px;
  content: "";
  height: 300px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
}
/* 線のアニメーション */
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
.mv_dot {
  position: absolute;
  left:50%;
  transform: translateX(-50%);
  bottom:50px;
}
.mv_dot img {
  height:70px;
  object-fit: contain;
}
/* TOP　コンセプト */
.top_column_content_left p.top_concept_text {
  line-height: 2.7;
  font-family: YonagaOldMincho;
  font-size: 16px;
  font-weight: normal;
  color: #3f4e64;

}
/* TOP ルーム */
/* #top_room {
  padding:0 20px;
} */
.top_rooms_content_wrapper {
  background-color: rgba(176, 163, 143,0.1);
  margin-top:55px;
  padding:90px 0;
}
.toproom-swiper {
  padding: 60px 0;
  overflow: hidden;
  width: 100vw; /* 画面幅に広げる */
  margin-left: calc(-50vw + 50%); /* センター起点で左にはみ出させる */
}

.toproom-swiper .swiper-wrapper {
  align-items: center;
}

.toproom-swiper .swiper-slide {
  width: 960px;
  flex-shrink: 0; /* ✅ 横並びに必要 */
  transform: scale(0.9);
  transition: transform 0.4s ease, opacity 0.4s ease;
}

.toproom-swiper .swiper-slide-active {
  transform: scale(1);
  opacity: 1;
  z-index: 2;
}

.toproom-swiper .swiper-slide img {
  width: 100%;
  display: block;
  /* box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15); */
}
.top_rooms_head {
  color:#3F4E65;
  font-family: YonagaOldMincho,serif;
  font-size: 25px;
  font-weight: normal;
  text-align: center;
  margin-top:100px;
}
.top_rooms_text {
  width: 520px;
    margin: 60px auto 70px;
    font-size: 15px;
    line-height: 2.15;
    letter-spacing: 1px;
	color: #757575;
	text-align: center;
}

/* STAY */
.top_stay_content_wrapper {
  display: flex;
  max-width:1680px;
  margin:50px auto 200px;
  gap:35px;
  width: 88%;
}

.top_stay_head {
  color:#3F4E65;
  font-family: YonagaOldMincho,serif;
  font-size: 25px;
  font-weight: normal;
  text-align: center;
  margin-top:76px;
  letter-spacing: 1.6px;
  line-height: 1.56;
}
.top_stay_content {
  display:flex;
  flex-direction: column;
  justify-content: space-between;
  height:auto;
}
.top_stay_content h4{
  font-family: YonagaOldMincho;
  font-size: 25px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 1.56;
  letter-spacing: 1.6px;
  color:#3F4E65;
  margin:40px 0 25px 20px;
  flex: 1;
}

.top_stay_content p {
  font-size: 15px;
  font-weight: normal;
  font-stretch: normal;
  font-style: normal;
  line-height: 2.15;
  letter-spacing: 1px;
  color:#757575;
  margin-bottom:50px;
  margin-left:20px;
  flex: 1;
}
.stay_more {
  margin-left:auto;
}
/* NEWS */
.news_container {
  max-width:1050px;
  margin:0 auto 100px;
}
.news_section_head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.top_news_title img{
  height:130px;
  width:auto;
}
.news_list {
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  margin: 40px 0;
  padding: 0;
}

.news_item {
  border-bottom: 1px solid #ccc;
  padding: 24px 0;
}

.news_item:last-child {
  border-bottom: none;
}

.news_link {
  display: flex;
  align-items: flex-start;
  gap: 75px;
  text-decoration: none;
  color: inherit;
}

.news_thumb {
  width: 280px;
  max-width: 280px;
  height: 180px;
  background: #ddd;
  display: flex;
  align-items: center;
  justify-content: center;
}

.news_thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  aspect-ratio: auto 3/4;
}

.news_text {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.news_date {
  font-size: 20px;
  color: #333;
  margin-bottom: 10px;
  display: block;
}

.news_title {
  font-size: 25px;
  color: #333;
  line-height: 1.6;
}

.news_category {
  font-size: 12px;
  color: #64553F ;
  margin-top: 28px;
  display: block;
}
.news_section_link {
  font-size:14px;
  border:1px solid #64553F;
  border-radius: 50px;
  padding:16px 30px;
  width:290px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.news_section_link img{
  width:10px;
}
.news_link_sp {
  display: none;
}
/* TOP review  */
.top_review_section {
  background-color: #B0A38F;
  padding:125px 20px 175px;
}
.top_review_head span {
  color:#fff;
  font-size: 14px;
  margin-top:6px;
  text-align: center;
  display: block;
  letter-spacing: 0.9px;
}
.top_review_content {
  background-color: #3F4E64;
  max-width: 1050px;
  margin:0 auto;

  margin-top: 50px;
}

/* TOP access */
.access_section {
  background-image: url(../images/access_bg.webp)  ;
  background-repeat: no-repeat;
  background-size: cover;
  padding:125px  0 0 ;
  margin-bottom:0;

}
.top_access_head span{
  color:#fff;

}
.top_access_content_wrapper {
  display:flex;
  padding:145px 0 ; 
 }
.top_access_content_text {
  width: 50%;
  color:#fff;
  padding:0 120px;
}
.top_access_content_text h3 {
  margin-bottom:48px;
  color:#fff;
  font-family: YonagaOldMincho;
  font-weight: normal;
  font-size: 30px;
  letter-spacing: 2.4px;
}
.top_access_content_text p {
  margin-bottom: 67px;
    font-size: 15px;
    line-height: 2.15;
    color: #fff;
    letter-spacing: 2.4px;
}
.top_access_content_text img {
  height:500px;
  width:auto;
}
.top_access_map {
  width: 50%;
}
.top_access_map iframe {
  width: 100%;
  height:700px;
}
@media (max-width: 1440px) {
  .top_column_content_right{
    padding: 100px 100px 240px 24px;
  }
}
@media (max-width: 1100px) {
  .logo {
    width:180px;
    height:180px;
  }
  .top_column_content_wrapper {
    padding-right:20px;
  }
  .top_column_content_wrapper_reverse {
    padding-left:20px;
  }
  .top_column_content_left {
    padding: 20px 0px 100px 40px;
  }
  .top_column_content_right {
    padding: 100px 40px 100px 0px;

  }
  .top_stay_content_wrapper {
    gap:16px;
  }
  .top_stay_content h4 {
    font-size:24px;
  }
  .more_left {
    bottom:2%;
  }
  .news_container {
    padding:0 20px;
  }
}
@media (max-width: 768px) {

  .mainVisual_inner {
    bottom:25%;
    right: 3%;
    }
    .mainVisual_inner h1 {
      font-size:40px;
    }
    .mainVisual_inner span {
      font-size: 32px;
      padding-top:49px;
    }
    .section_title_line ,
      .section_title_line2 {
      width:88%;
      padding:40px 0 60px;
    }
    .top_section_title {
      height:57px;
    }
    .section_head span {
      font-size:16px;
    }
    .top_column_content_wrapper {
      flex-direction: column;
      padding-right: 0;
    }
    .top_column_content_wrapper_reverse {
      flex-direction: column-reverse;
      padding-left:0;
    }
    .top_column_image_left, .top_column_image_right {
      width:88%;
      padding: 32px 0 0;
      margin:0 auto;
   
    }
    .top_column_image_left::after {
      width:78%;
    }
    .top_column_image_right::after {
      width:78%;
    }
    .top_column_image_left img, .top_column_image_right img {
      height:auto;
      object-fit: contain;
      
    }
    .top_column_content_left {
      width:88%;
      margin-top:0;
      padding:54px 0px ;
      height:650px;
      margin:0 auto;

    }
    .top_column_content_left::after{
      width:78%;
      right:0;
      left:auto;
    }
    .top_column_content_right {
      width:88%;
      margin-top:0;
      padding:54px 0;
      height:558px;
      margin:0 auto;
    }
    .top_column_content_right::after {
      width:78%;
      left:0;
      right:auto;
    }
    .top_column_content_left h3, .top_column_content_right h3 {
      text-align: center;
    }
    .top_column_content_left p, .top_column_content_right p {
      max-width:100%;
      padding:0 40px;
      width: fit-content;
      margin: 0 auto;
    }
    .more_left {
      left:64px;
      bottom:100px;
    }
    .more_right {
      right:65px;
      
    }
    .toproom-swiper .swiper-slide-active {
      transform: scale(1.1);
    }
    .top_rooms_content_wrapper {
      padding:0;
    }
    .top_rooms_head {
      margin-top:47px;
    }
    .top_rooms_text {
      margin: 79px 40px 93px;
      font-size: 20px;
  line-height: 2.15;
  letter-spacing: 1px;
  white-space: nowrap;
    }
    .top_stay_content_wrapper {
      flex-direction: column;
      max-width:520px;
      margin:0 auto;
      gap:58px;
      }
      .news_section_head {
        justify-content: center;
      }
      .news_container {
        width:88%;
        padding:0;
      }
      .news_link {
        gap:42px;
      }
      .news_date {
        font-size: 16px;
        margin-bottom: 23px;
      }
      
      .news_title {
        font-size: 26px;
        line-height: 1.54;
      }
      
      .news_category {
        font-size: 16px;
        margin-top: 50px;
      } 
      .news_link_sp {
        margin: 15px auto 0;
          font-size:20px;
          border:1px solid #64553F;
          border-radius: 50px;
          padding:16px 30px;
          width:290px;
          display: flex;
          justify-content: space-between;
          align-items: center;
        }
        .news_link_sp img{
          width:10px;
        }
      
      .access_section {
        background-image: url(../images/access_bg_sp.webp);
        background-size: cover;
      }

      .top_access_content_wrapper {
        flex-direction: column;
        padding:0px 0;
      }
      .top_access_content_text {
        width: 88%;
        padding:0 0 170px;
       margin:0 auto;
    }
      .top_access_content_text h3 {
        text-align: center;
        font-size:38px;
      }
      .top_access_content_text p {
        text-align: center;
      }
      .top_access_content_text img {
        width:100%;
        height:100%;
      }
      .top_access_map {
        width:100%;
      }
	.mv_scroll span {
    display: block;
    width: 1px;
    background: #9F7F48;
    animation: scroll 2s infinite;
    bottom: -50px;
    content: "";
    height: 100px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
}
	.mv_scroll em {
    font-size: 15px;
    font-family: 'YonagaOldMincho';
    font-weight: 400;
    font-style: normal;
    margin-top: -110px;
    /* margin-left: calc(-.5rem + 1px); */
    display: block;
    line-height: 1;
    text-decoration: none;
    color: #fff;
    letter-spacing: 2px;
    writing-mode: vertical-rl;
}
	.headerMenu li a, .headerMenu li button {
    color: #fff;
    font-size: 16px;
    margin-right: -10px;
}
	.header_inner {
    padding: 0 30px;
}
}
@media (max-width: 600px) {
  .logo {

    width:150px;
    height:150px;
  }
  .navmenu {
    justify-content: flex-start;
  }
  .headerNav .header_inner {
    margin-top:170px;
    margin-right:16px;
    justify-content: flex-start;
  }
  .headerNav .headerMenu {
    flex-direction: column;
    align-items: flex-start;
  }
  /* .navmenu-columns {
    margin-top: 150px;
  } */
}
@media (max-width: 480px) {
  .section_title_line,
  .section_title_line2 {
    width:88%;
  }
  .logo {
      width:90px;
      height:90px;
  }
  .headerNav .header_inner {
    margin-top:120px;
  }

  .mainVisual_inner h1 {
    font-size:24px;
  }
  .mainVisual_inner span {
    font-size:18px;
  }
  .mv_scroll {
    left:20px;
    bottom:70px;
  }
  .mv_dot {
    bottom:34px;
  }
  .top_column_content_wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;

  }
  .top_column_content_left h3, .top_column_content_right h3 {
    font-size:24px;
  }
  .top_column_content_left p.top_concept_text {
    font-size:15px;
  
    line-height:2.5;
    padding: 0 ;
  }
  .top_column_content_left p, .top_column_content_right p {
    padding:0;
    font-size: 15px;
  }
  .more_left {
    position:unset;
    margin-top:93px;
  }
  .more_right {
    bottom:-93px;
    left:50%;
    transform: translateX(-50%);
  }
  .top_rooms_head ,.top_stay_head{
    font-size:24px;
  }
  .top_rooms_text {
    width:100%;
    margin: 79px 0 93px;
    font-size: 15px;
    white-space: wrap;
  }
  .top_stay_content p {
    margin-left:0;
    padding:0 20px;
    font-size:15px;
  }
  .news_thumb {
    width:50%;
    height:auto;
  }
  .news_title {
    font-size:20px;
  }
  .top_access_content_text h3 {
    font-size:28px;
  }
  .footer {
    padding:56px 20px;
  }
  .footer_nav ul {
    gap:45px;
  }
}
@media (max-width: 768px) {
.top_review_content {
    background-color: #3F4E64;
    width: 88%;
    margin: 0 auto;
    
    margin-top: 50px;
}}
.footer_info a {
    color: #FFF;
}

#page_top {
    width: 50px;
    height: 50px;
    position: fixed;
    right: 5px;
    bottom: 5px;
    background: #3f4e64;
    opacity: 0.6;
}
#page_top a {
    position: relative;
    display: block;
    width: 50px;
    height: 50px;
    text-decoration: none;
}
#page_top a::before {
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f106';
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 30px;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}