/**
 * File: base.css
 * Usage: 全ページ共通のスタイルを定義します。レイアウト、モジュールなど。
 * Example: ly_header, ly_footer, el_btn, el_gradientGold, el_subpTtl, el_normalTtl
*/

@charset "UTF-8";

/* ================================================  
 カスタムプロパティ
================================================ */
:root {
  --color-black: #323a3c;
  --color-white: #ebf0f2;
  --color-gray: #4f595c;
  --color-blueGray: #234f5f;
  --color-blueGray-secondary: #96a2a7;
  --color-blueGray-tertiary: #d0dade;
  --color-white-accent: #f0f2f3;

  --font-3xl: 40px;
  --font-xxl: 34px;
  --font-xl: 24px;
  --font-lg: 20px;
  --font-md: 18px;
  --font-sm: 16px;
  --font-xs: 14px;
  --font-xxs: 12px;

  --btn-gradient: linear-gradient(90deg, #f372a3 19%, #6fb2ef 100%);
  --btn-gradient-hover: linear-gradient(90deg, #f372a3 75%, #6fb2ef 100%);
}

/* ================================================  
 ローディングアニメーション
================================================ */

/* ================================================  
 リセットの記述
================================================ */
/* 管理バーの余白を削除 */
html {
  margin-top: 0 !important;
}

#wpadminbar {
  display: none;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

ul[role='list'],
ol[role='list'] {
  list-style: none;
  padding: 0;
  margin: 0;
}

html:focus-within {
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  /* Fallback */
  /* min-height: calc(var(--vh, 1vh) * 100); */
  text-rendering: optimizeSpeed;
  line-height: 1.8;
  overflow-x: hidden;
}

main {
  overflow-x: hidden;
}

a {
  text-decoration: none;
  color: inherit;
}

a:not([class]) {
  -webkit-text-decoration-skip: ink;
  text-decoration-skip-ink: auto;
}

img,
picture {
  max-width: 100%;
  width: 100%;
  height: auto;
  display: block;
  pointer-events: none;
}

input,
button,
textarea,
select {
  font: inherit;
}

pre {
  white-space: pre-line;
}

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    -webkit-animation-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* WordPress管理画面のツールバー */
#wpadminbar {
  display: none !important;
}

/* ================================================  
 フォントの読み込み
================================================ */
@font-face {
  font-family: 'ZenKakuGothicNew';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/ZenKakuGothicNew-Regular.woff');
}
@font-face {
  font-family: 'ZenKakuGothicNew';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/ZenKakuGothicNew-Medium.woff');
}
@font-face {
  font-family: 'ZenKakuGothicNew';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/ZenKakuGothicNew-Bold.woff');
}
@font-face {
  font-family: 'ShipporiMinchoB1';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/ShipporiMinchoB1-Medium.woff');
}
@font-face {
  font-family: 'ShipporiMinchoB1';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/ShipporiMinchoB1-Bold.woff');
}

/* ================================================  
 あしらい
================================================ */
.el_as_square {
  width: 40px;
  object-fit: cover;
}

/* ================================================  
 サイドバー
================================================ */

/* ================================================  
 カスタマイズ広告の設定
================================================ */
.bl_ads {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

/* ================================================  
 スタイルの適用(モバイルファーストで記述)
================================================ */
body {
  color: #333;
  -webkit-text-size-adjust: 100%;
  font-family: 'ZenKakuGothicNew', 'ShipporiMinchoB1', sans-serif;
  line-height: 180%;
  overflow-x: hidden;
  position: relative;
  min-height: 100vh;
  background-color: #f9f6ed;
  background-image: url('../img/bg_tips_pc.png'), linear-gradient(to bottom, #f9f6ed, #f9f6ed);
  background-repeat: repeat-y, no-repeat;
  background-position: center center, center center;
  background-size: 100% auto, cover;
  font-weight: 500;
}

h1 {
  font-size: 2em;
}

h2 {
  font-size: 1.5em;
}

h3 {
  font-size: 1.17em;
  margin-top: 0.6em;
  margin-bottom: 0.4em;
}

h4 {
  font-size: 1.12em;
}

h5 {
  font-size: 0.83em;
}

h6 {
  font-size: 0.75em;
}

p {
  font-size: 14px;
  line-height: 180%;
}

.clearfix::after {
  clear: both;
}

li {
  list-style: none;
}

html {
  margin-top: 0 !important;
}

/* defaultの▼アイコンを消す */
summary {
  display: block;
}
summary::-webkit-details-marker {
  display: none;
}

/* メディアクエリ用の表示・非表示 */
.sm_only {
  display: block !important;
}

.md_only,
.lg_only {
  display: none !important;
}

.xl_only {
  display: none !important;
}

/* ================================================  
  レイアウト
================================================ */
.ly_cont {
  padding-inline: 24px;
  margin-inline: auto;
}

.ly_cont_sm {
  padding-inline: 20px;
  margin-inline: auto;
}

.ly_flex {
  display: flex;
  align-items: center;
  justify-content: center;
}

.ly_section {
  padding-block: 80px;
}

/* ================================================  
  header
================================================ */
.bl_header.bl_header_pc {
  display: none;
}

.bl_header.bl_header_sp {
  display: flex;
}

.bl_header {
  background-color: #42602d;
  background-image: url('../img/green-bg-texture.webp');
  background-blend-mode: multiply;
  background-size: cover;

  padding-inline: 16px;
  height: 72px;

  align-items: center;
  justify-content: space-between;

  position: sticky;
  top: 0;
  z-index: 1000;
}

.bl_headerInner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.bl_headerInner .el_logo {
  display: block;
  width: 120px;
}

.bl_headerNav_reservation {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #b58e1f;
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding: 6px 16px;
  border-radius: 999px;
}

.bl_headerInner_right {
  gap: 12px;
}

.bl_headerNav {
  position: relative;
  width: 24px;
  height: 18px;
  cursor: pointer;
  z-index: 1000;
}

.bl_headerNav span {
  display: block;
  width: 24px;
  height: 2px;
  background: #fff;
  border-radius: 100px;
  position: absolute;
  left: 0;
  transition: all 0.3s ease;
}

.bl_headerNav span:nth-child(1) {
  top: 0;
}

.bl_headerNav span:nth-child(2) {
  top: 8px;
}

.bl_headerNav span:nth-child(3) {
  top: 16px;
}

/* ハンバーガーメニューがアクティブ時の×アニメーション */
.bl_headerNav.is_active span:nth-child(1) {
  transform: rotate(45deg);
  top: 8px;
}

.bl_headerNav.is_active span:nth-child(2) {
  opacity: 0;
}

.bl_headerNav.is_active span:nth-child(3) {
  transform: rotate(-45deg);
  top: 8px;
}

/* ================================================  
bogo 
================================================ */
.bogoflags,
.bogoflags-before:before {
  display: none;
}

.el_switchBtn {
  border: none;
  background: none;
  padding: 6px 16px;
  margin: 0;
  z-index: 1000;
  color: white;
  display: flex;
  align-items: center;
  gap: 4px;
  border: 1px solid white;
  border-radius: 999px;
  position: relative;
}

.el_switchBtn svg {
}

.bl_headerSwitcher {
  display: none;
  position: absolute;
  top: 100%;
  left: 0px;
  padding: 12px 20px;
  border-radius: 6px;
  border: #c8c8c8 1px solid;
  box-shadow: 2px 4px 4px rgba(255, 255, 255, 0.2);
  background: white;
  z-index: 1000;
  color: #323a3c;
}

.bl_headerSwitcher.is_open {
  display: block;
}

.bl_headerSwitcher ul li:not(:first-child) {
  margin-top: 12px;
}

.bl_headerSwitcher ul li span:not(:has(a)) {
  text-decoration: line-through;
  opacity: 0.3;
}

.bl_overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 999;
  display: none;
}

.bl_overlay.is_open {
  display: block;
}

/* ================================================  
モバイルメニュー 
================================================ */
.bl_mobileNav {
  position: fixed;
  top: 0;
  left: 0;
  width: 85%;
  height: 100vh;
  background-color: #42602d;
  background-image: url('../img/green-bg-texture.webp');
  background-blend-mode: multiply;
  background-size: cover;
  z-index: 9999;
  transform: translateX(120%);
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
  padding: 24px;
  color: #fff;
}

.bl_mobileNav.is_active {
  transform: translateX(20%);
}

.bl_mobileNav_header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
}

.bl_mobileNav_close {
  position: relative;
  width: 24px;
  height: 18px;
  cursor: pointer;
}

.bl_mobileNav_close span {
  display: block;
  width: 24px;
  height: 2px;
  background: #fff;
  border-radius: 100px;
  position: absolute;
  left: 0;
  transition: all 0.3s ease;
}

.bl_mobileNav_close span:nth-child(1) {
  top: 8px;
  transform: rotate(45deg);
}

.bl_mobileNav_close span:nth-child(2) {
  top: 8px;
  transform: rotate(-45deg);
}

.bl_mobileNav_lang {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 16px;
  border: 1px solid #fff;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
}

.bl_mobileNav_list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.bl_mobileNav_list a {
  color: #fff;
  text-decoration: none;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.04em;
  transition: opacity 0.3s ease;
}

.bl_mobileNav_list a:hover {
  opacity: 0.7;
}

.bl_mobileNav_btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 16px 24px;
  border-radius: 8px;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
  transition: all 0.3s ease;
}

.bl_mobileNav_btn--outline {
  background: transparent;
  color: #fff;
  border: 1px solid #fff;
}

.bl_mobileNav_btn--outline:hover {
  background: rgba(255, 255, 255, 0.1);
}

.bl_mobileNav_btn--primary {
  background: #b58e1f;
  color: #fff;
  border: 1px solid #b58e1f;
}

.bl_mobileNav_btn--primary:hover {
  background: #a07a1a;
}

.bl_mobileNav_sns {
  display: flex;
  gap: 16px;
  justify-content: center;
}

.bl_mobileNav_sns_item {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #538331;
  border-radius: 999px;
  transition: opacity 0.3s ease;
}

.bl_mobileNav_sns_item:hover {
  opacity: 0.7;
}

/* ================================================  
セクションタイトル 
================================================ */
.el_secTtl {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.8;
  font-family: 'ShipporiMinchoB1', sans-serif;
  font-weight: 700;
  color: #42602d;
  text-align: center;
  letter-spacing: 0.04em;
  padding-top: 44px;
}

.el_secTtl img {
  width: 32px;
  height: 19px;
  margin-inline: auto;
  margin-bottom: 4px;
}

.el_logo_text {
  display: none;
}

/* ================================================  
ボタン 
================================================ */
.el_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 260px;
  height: 56px;
  border-radius: 999px;
  background: #538331;
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-inline: auto;
}

.el_btn img {
  width: 22px;
  height: 22px;
}

/* ================================================  
パンくずリスト 
================================================ */
.bl_breadcrumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
}

.bl_breadcrumbs_li {
  font-size: var(--font-xs);
  font-weight: 500;
  color: var(--color-black);
  line-height: 1;
}

.bl_breadcrumbs_separator {
  line-height: 1;
}

/* ================================================  
  footer
================================================ */

.bl_footer {
  background-color: #42602d;
  background-image: url('../img/green-bg-texture.webp');
  background-blend-mode: multiply;
  background-size: cover;
  color: #fff;
  padding: 64px 24px 24px;
}

.el_footerLogo {
  display: block;
  width: 220px;
}

.bl_footer_address {
  margin-top: 32px;
}

.el_footer_btn_ol {
  border: 1px solid #fff;
  border-radius: 999px;
  padding: 4px 16px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-top: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 230px;
}

.bl_footerSns {
  display: flex;
  gap: 16px;
  margin-top: 24px;
}

.el_footerSns_item {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #538331;
  border-radius: 999px;
}

/* ================================================  
  CTA
================================================ */
.bl_cta {
  padding-inline: 24px;
  display: block;
}

.bl_cta_inner {
  padding: 40px;
  font-size: 28px;
  color: white;
  text-align: center;
  border-radius: 8px;
  background: url(../img/green-bg-texture.webp) 50% / cover no-repeat, #b58e1f;
  background-blend-mode: multiply, normal;
  font-family: 'ShipporiMinchoB1', sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.4;
}

.bl_cta img {
  width: 64px;
  height: 64px;
  margin-inline: auto;
  margin-top: 16px;
}

/* ================================================  
Guide 
================================================ */
.bl_guide {
  padding: 32px 24px;
  font-weight: 500;
}

.bl_guide h2 {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.8;
  font-family: 'ShipporiMinchoB1', sans-serif;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 4px;
}

.bl_guide h2 img {
  width: 32px;
}

.bl_guide_cont {
  border: 1px solid #b58e1f;
  padding: 16px;
  margin-top: 8px;
}

.bl_guide p {
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: 0.04em;
}

.bl_guide hr {
  border-style: dashed;
  margin-top: 24px;
}

/* ================================================  
  footer
================================================ */

.bl_footerNav {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.el_footer_hr {
  opacity: 0.3;
  margin-bottom: 24px;
}

.el_footer_copy {
  text-align: center;
}

/* ================================================  
  コンタクトフォーム
================================================ */
.bl_footer_btn {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-bottom: 24px;
}

.bl_footer_btn .el_btn {
  margin-left: 0;
}

.bl_footer_btn .el_btn.el_footer_btn_contact {
  background: transparent;
  border: 1px solid #fff;
  color: #fff;
}

.bl_footer_btn .el_btn.el_footer_btn_booking {
  background: #b58e1f;
  border: 1px solid #b58e1f;
}

/* ================================================  
  エレメントモジュール
================================================ */

/* ================================================  
 ヘルパー
================================================ */

/* ================================================  
 columnパーツ
================================================ */

@media screen and (min-width: 960px) {
  body {
    font-size: 16px;
  }

  p {
    font-size: 16px;
    line-height: 1.8;
  }
  .sm_only {
    display: none !important;
  }

  .md_only {
    display: block;
  }
  .bl_header.bl_header_sp {
    display: none;
  }

  .bl_header.bl_header_pc {
    display: flex;
    padding-left: 40px;
    padding-right: 0;
    height: 88px;
  }

  .bl_headerInner .el_logo {
    position: absolute;
    top: 0;
    width: 71px;
  }

  .el_logo_text {
    display: flex;
    font-size: 20px;
    line-height: 1.3;
    color: #f9f6ed;
    position: absolute;
    top: 16px;
    left: 90px;
    width: 240px;
    font-family: 'ShipporiMinchoB1', sans-serif;
    font-weight: 500;
    letter-spacing: 0.03em;
  }

  .bl_header_pc_list {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-left: auto;
    color: #fff;
  }

  .bl_header_pc_list_left {
    display: flex;
    align-items: center;
    gap: 16px;
  }

  .bl_header_pc_list_right {
    display: flex;
    align-items: center;
    gap: 16px;
  }

  .bl_header_pc_btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 180px;
    height: 88px;
    background: #b58e1f;
    color: #fff;
  }

  .bl_header_pc_list {
    margin-right: 16px;
  }

  .bl_mobileNav_lang {
    padding: 8px 16px;
  }

  .el_btn {
    width: 300px;
    height: 64px;
    gap: 16px;
    font-size: 16px;
  }

  .bl_cta {
    max-width: 1360px;
    height: 303px;
    margin-inline: auto;
  }

  .bl_cta_inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 134px;
    padding: 108px;
    font-size: 38px;
  }

  .bl_cta img {
    width: 88px;
    height: 88px;
    margin-top: 0;
    margin: 0;
  }

  .bl_footer_inner {
    max-width: 1160px;
    margin-inline: auto;
    padding-inline: 20px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
  }

  .bl_footerNav {
    margin-top: 0;
  }

  .el_footerSns_item {
    width: 48px;
    height: 48px;
  }

  .el_footer_hr {
    max-width: 1160px;
    margin-inline: auto;
  }

  .el_footer_copy {
    margin-top: 24px;
  }

  .bl_footer_btn .el_btn {
    width: 240px;
  }
}

/* ================================================  
 会社概要パーツ
================================================ */

@media screen and (min-width: 768px) {
}
