@charset "utf-8";

:root {
  --header-h-sp: 70px;
}

/* *****************************************
PC調整
******************************************** */
@media screen and (max-width:1150px) {

  /* ========MV メインビジュアル=========== */

  /* ============= サービス============= */

  /* ============= ルーム============= */

}


/* ****************************************
タブレット最大サイズ
******************************************* */
@media screen and (max-width:960px) {
  .nav-links {
    gap: 20px;
  }

  /* ========MV メインビジュアル=========== */

  /* =========== イントロ =========== */


  /* ============= サービス============= */

  /* ============= ルーム============= */


  /* ============== 施設案内 =============== */

  /* ================ フッター ============== */
  .ft-inner {
    width: 90%;
  }

  /* フッター ホテル情報 */
  .ft-left .ft-logo {
    margin-bottom: 2rem;
  }

  .ft-left address {
    margin-top: 15px;
  }

  .ft-left address div {
    margin-bottom: 2rem;
  }
}

/* *****************************************
タブレット
******************************************** */
@media screen and (max-width:768px) {

  /* =============ヘッダー============ */

  /* ======== MV メインビジュアル=========== */
  .mv-pic {
    width: 100%;
    height: 80vh;
  }

  .empty:empty {
    height: 15vh;
  }

  .mv-pic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.9;
  }

  .between-text {
    margin: -3.4rem auto;
    /* フォントサイズのネガティブマージン */
    text-align: center;
  }

  .between-text h2 {
    font-size: 3.4rem;
    line-height: 1;
  }

  .between-text .ja {
    font-size: 2rem;
  }

  /* =========== イントロ =========== */
  .intro {
    padding-top: 0;
  }

  .intro-inner {
    width: 100%;
    display: block;
  }

  .intro .pic01 {
    width: 80%;
    margin-right: 0;
    margin-left: auto;
  }

  .intro .txtWrap {
    margin-left: auto;
    margin-right: auto;
    padding: 80px;
  }

  /* pic02とpic03の大枠 */
  .intro .picWrap {
    width: 100%;
    height: auto;
    display: block;
  }

  /* picWrap内のポジションを解除 */
  .intro .pic02 {
    position: static;
    width: 50%;
    margin-left: 10%;
  }

  .intro .pic03 {
    position: static;
    width: 75%;
    margin-right: 0;
    margin-left: auto;
    margin-top: 8rem;
  }

  .intro .pic02 img,
  .intro .pic03 img {
    position: static;
    transform: none;
    -webkit-transform: none;
    -ms-transform: none;
    padding: 0;
  }

  /* ============= ルーム ============= */
  .swiper.card-swiper {
    padding: 0 30px 40px;
  }

  /* ページネーション */
  .card-swiper .swiper-button-prev,
  .card-swiper .swiper-button-next {
    width: 30px;
    height: 50px;
  }

  .card-swiper .swiper-button-prev::after,
  .card-swiper .swiper-button-next::after {
    font-size: 18px;
    /* 矢印の大きさ */
  }


  .slide-txtWrap .info {
    flex-flow: column;
    align-items: start;
  }

  /* 部屋画像 */
  .slide-media img {
    aspect-ratio: 3 / 2;
  }

  /* ============= 朝食 ============== */
  .restaurant .r-sec {
    flex-flow: column;
    gap: 5rem;
  }

  .restaurant .s-title {
    margin-right: auto;
    margin-left: auto;
  }

  /* r-sec01 */
  .restaurant .r-sec01 .picWrap,
  .restaurant .r-sec02 .picWrap {
    width: 80%;
    flex: auto;
    margin-right: auto;
    margin-left: auto;
  }

  .restaurant .r-sec01 .cont {
    flex: auto;
  }

  /* r-sec02 */
  .restaurant .r-sec02 {
    flex-direction: column-reverse;
  }

  /* メニュー */
  .menu-wrap {
    flex: auto;
  }

  .restaurant .r-sec01 .txt,
  .restaurant .r-sec02 .txt {
    width: 80%;
    padding: 0;
    margin-right: auto;
    margin-left: auto;
  }

  /* .restaurant {
    width: 100%;
    flex-flow: column;
    gap: 8rem;
  }

  .restaurant .s-title p {
    text-align: start;
  }

  .restaurant .txt {
    width: 80%;
    padding: 0;
    margin-right: auto;
    margin-left: auto;
  }

  .restaurant .pic01 {
    width: 50%;
    margin-right: auto;
    margin-left: 2rem;
  }

  .restaurant .pic02 {
    width: 70%;
    margin-top: 0;
    margin-right: 0;
    margin-left: auto;
  } */

  /* 境界線 */
  .horizon {
    aspect-ratio: 3 / 2;
  }

  /* ============= アクセス ============== */
  .access-inner {
    width: 90%;
    min-height: 100vh;
    margin-right: auto;
    margin-left: auto;
  }

  /* タイトルとコンテンツをflex */
  .sticky-box {
    flex-flow: column;
  }

  .sticky-title-wrap {
    flex: 0 0 auto;
  }

  .sticky-box .s-title {
    position: static;
  }

  /* アクセス内容ここから */
  .map {
    flex-flow: column;
    margin-bottom: 8rem;
  }

  /* ------マップ群------ */
  .gmap {
    width: 100%;
  }

  /* ============= フッター ============== */
  .ft-inner {
    width: 95%;
    flex-flow: column;
    padding-bottom: 4rem;
    justify-content: center;
    align-items: center;
  }

  .ft-left {
    flex-flow: column;
    gap: 4rem;
    margin-bottom: 3rem;
  }

  .ft-left .ft-logo {
    margin-bottom: 2rem;
  }

  .ft-left h3 {
    font-size: 2rem;
  }

  .ft-navWrap {
    margin-bottom: 3rem;
  }

  .ft-navWrap p {
    text-align: center;
  }

  .ft-nav {
    flex-flow: row;
    flex-wrap: wrap;
    justify-content: center;
  }

  .ft-nav li {
    width: calc((100% - 30px) / 2);
  }

  .ft-nav li a {
    text-align: center;
  }

  .ft-book-btn {
    margin-right: auto;
    margin-left: auto;
  }

  .ft-member a {
    font-size: 1.3rem;
  }

  .copy {
    padding: 20px 0 60px;
  }
}


@media screen and (max-width:572px) {
  .p {
    font-size: 1.4rem;
    line-height: 1.6;
    letter-spacing: 0.08em;
  }

  /* ====== MV メインビジュアル ======= */

  /* ====== MV イントロ ======= */

  .intro .txtWrap {
    width: 100%;
    flex-flow: column;
    padding: 80px 2rem;
  }

  .intro-tl {
    width: 100%;
  }

  .vertical {
    font-size: 2.4rem;
    font-weight: 400;
  }

  /* ============= 共通設定 ============= */
  .s-title h3 {
    font-size: 3.2rem;
  }

  .s-title p {
    font-size: 1.4rem;
  }

  /* =========== サービス ========== */


  /* =========== ルーム ========== */

  /* ============ 施設案内 ============ */

  /* ============アクセス============== */
  .access-route .bg {
    padding: 20px 10px;
  }

  .route-tl {
    font-size: 2rem;
  }

  .route-tl i {
    font-size: 2.4rem;
  }

  .access-route dd {
    font-size: 1.4rem;
  }

  /* オススメ欄 */
  .recommend {
    padding: 10px 0 0 15px;
  }

  /* ========= フッター ========== */
  .ft-item h3 {
    font-size: 1.6rem;
  }

  .ft-item address {
    font-size: 1.4rem;
    line-height: 1.4;
  }

  /* .ft-nav {
    width: 70%;
    display: grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(2, auto);
    gap: 10px 20px;
    margin: 0 auto;
  } */

  /* .ft-nav li {
    width: fit-content;
    border-bottom: 1px solid var(--btn-color);
    margin-right: auto;
    margin-left: auto;
  } */

  /* .ft-nav li a {
    text-align: center;
    padding: 0 3px 3px;
  } */

  /* --------コピーライト------- */
  .copy small {
    font-size: 1.2rem;

  }
}

/* *****************************************
SP最大サイズ
******************************************** */
@media screen and (max-width:375px) {

  /* ============= ヘッダー =============== */

  .nav-links li {
    padding: 15px;
  }

  .nav-links li a span {
    font-size: 1.6rem;
  }

  /* ======== MV メインビジュアル=========== */


  /* ------ご予約はこちらから------ */

  /* ======== MV イントロ=========== */


  /* ========= サービス =========== */

  /* ============= ルーム============= */

  /* ============ 施設案内 ============ */

  /* ============アクセス============== */

}