@layer global {

:root {

  --color-back: #fff;
  --color-text: #000;
  --color-primary: #5cabb8;

  --fontFamily-default: "Zen Maru Gothic", "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Lucida Grande", "Osaka", "Verdana", "ＭＳ Ｐゴシック", sans-serif;
  --fontFamily-maru: "Zen Maru Gothic", "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Lucida Grande", "Osaka", "Verdana", "ＭＳ Ｐゴシック", sans-serif;

  --gutter: 20px;

  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);

}

}

@layer reset {

/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */

/* Reset box-model and set borders */
/* ============================================ */

*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

/* ローカルサーバー環境でのレイアウト調整 */
html, body {
  box-sizing: border-box;
}

*, *::before, *::after {
  box-sizing: inherit;
}

/* Document */
/* ============================================ */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */

html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */

/**
 * Remove the margin in all browsers.
 */

body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */

dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */

/**
 * Remove the gray background on active links in IE 10.
 */

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

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Replaced content */
/* ============================================ */

/**
 * Prevent vertical alignment issues.
 */

svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */

/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none; /* 1 */
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit; /* 2 */
}

/**
 * Correct cursors for clickable elements.
 */

button,
[type="button"],
[type="reset"],
[type="submit"] {
  cursor: pointer;
}

button:disabled,
[type="button"]:disabled,
[type="reset"]:disabled,
[type="submit"]:disabled {
  cursor: default;
}

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

/**
 * Remove padding
 */

option {
  padding: 0;
}

/**
 * Reset to invisible
 */

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
  overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * Correct the outline style in Safari.
 */

[type="search"] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Fix font inheritance.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Fix appearance for Firefox
 */
[type="number"] {
  -moz-appearance: textfield;
}

/**
 * Clickable labels
 */

label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */

[contenteditable]:focus {
  outline: auto;
}

/* Tables */
/* ============================================ */

/**
1. Correct table border color inheritance in all Chrome and Safari.
*/

table {
  border-color: inherit; /* 1 */
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}
}

@layer base {

/* base style */

html {
  scroll-padding-top: calc(var(--scroll-padding-top) * 1px);
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  background: var(--color-back);
  color: var(--color-text);
  font-family: var(--fontFamily-default);
  overflow-wrap: break-word;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
  text-decoration-skip-ink: auto;
}

code,
pre {
  font-family: var(--fontFamily-default);
  white-space: pre-wrap;
}

img,
picture > img,
picture > source,
figure {
  max-width: 100%;
}

img {
  height: auto;
  image-rendering: optimize-contrast;
  display: block;
}

picture {
  display: contents;
}

iframe {
  border: 0;
}

li,
summary {
  list-style: none;
}

summary {
  display: block;
}

summary::-webkit-details-marker {
  display: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  cursor: pointer;
  touch-action: manipulation;
  font-size: 1rem;
}

:where(
    :any-link,
    button,
    [type="button"],
    [type="reset"],
    [type="submit"],
    label[for],
    select,
    summary,
    [role="tab"],
    [role="button"]
  ) {
  cursor: pointer;
}

:focus:not(:focus-visible) {
  outline: none;
}

main {
  display: block;
}

dt {
  font-weight: 400;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}
:where(dialog) {
  width: unset;
  max-width: unset;
  height: unset;
  max-height: unset;
  padding: unset;
color: unset; 
  background-color: unset;
  border: unset;
  overflow: unset;
  outline: unset;
}

input,
textarea,
select {
  min-width: 0;
  font-size: 1rem;
}

input:focus,
textarea:focus,
select:focus,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline-offset: -2px;
  outline: 2px solid var(--color-primary);
}

textarea {
  resize: vertical;
}

optgroup {
  font-size: 1rem;
}

/* label: iOS対応のためにポインター指定 */
label {
  cursor: pointer;
}

/* プレースホルダー色調整 */
::placeholder {
  color: #ccc;
}

/* スピンボタン非表示 (Chrome / Safari) */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button,
input[type="month"]::-webkit-outer-spin-button,
input[type="month"]::-webkit-inner-spin-button,
input[type="datetime-local"]::-webkit-outer-spin-button,
input[type="datetime-local"]::-webkit-inner-spin-button,
input[type="week"]::-webkit-outer-spin-button,
input[type="week"]::-webkit-inner-spin-button,
input[type="time"]::-webkit-outer-spin-button,
input[type="time"]::-webkit-inner-spin-button,
input[type="date"]::-webkit-outer-spin-button,
input[type="date"]::-webkit-inner-spin-button {
  appearance: none;
  display: none;
  margin: 0;
}

/* スピンボタン非表示 (FireFox) */
input[type="number"],
input[type="month"],
input[type="datetime-local"],
input[type="week"],
input[type="time"],
input[type="date"] {
  appearance: textfield;
}

/* クリアボタン非表示 */
input[type="date"]::-webkit-clear-button,
input[type="month"]::-webkit-clear-button,
input[type="datetime-local"]::-webkit-clear-button,
input[type="time"]::-webkit-clear-button,
input[type="week"]::-webkit-clear-button {
  appearance: none;
}

select::-ms-expand {
  display: none;
}

option:disabled {
  color: #ccc;
  opacity: 1;
}

/* 共通スタイル */
input[type="number"],
input[type="range"] {
  font-size: 1rem;
  padding: 0.5em;
  border: 1px solid #ccc;
  border-radius: 4px;
  background-color: #fff;
  width: 100%;
  box-sizing: border-box;
}

/* type="number" 専用 */
input[type="number"]:focus {
  border-color: var(--color-primary);
  outline: none;
}

/* type="range" 専用 */
input[type="range"] {
  appearance: none;
  height: 4px;
  background: #ddd;
  margin: 0.5em 0;
}

/* スライダーのつまみ部分（WebKitブラウザ） */
input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  width: 16px;
  height: 16px;
  background: var(--color-primary);
  border-radius: 50%;
  cursor: pointer;
  margin-top: -6px; /* スライダートラックと垂直中央に合わせる */
}

/* スライダーのつまみ部分（Firefox） */
input[type="range"]::-moz-range-thumb {
  width: 16px;
  height: 16px;
  background: var(--color-primary);
  border-radius: 50%;
  cursor: pointer;
}

/* スライダートラック（Firefox） */
input[type="range"]::-moz-range-track {
  height: 4px;
  background: #ddd;
}

/* ラジオボタン、チェックボックス */
input[type="radio"],
input[type="checkbox"] {
  opacity: 0;
  position: absolute;
}

input[type="radio"] + span,
input[type="checkbox"] + span {
  cursor: pointer;
  display: inline-block;
  line-height: 1;
  padding: 0.3em 0.3em 0.3em 2em;
  position: relative;
  vertical-align: middle;
}

input[type="radio"]:focus-visible + span,
input[type="checkbox"]:focus-visible + span {
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
}

/* ラジオボタンスタイル */
input[type="radio"] + span::before {
  background: #fff;
  outline-offset: -2px;
  border: 2px solid var(--color-primary);
  border-radius: 50%;
  content: "";
  height: calc(23 / 16 * 1em);
  left: 0;
  line-height: 1;
  position: absolute;
  top: 1px;
  width: calc(23 / 16 * 1em);
}

/* ラジオボタンチェック印（未選択） */
input[type="radio"] + span::after {
  content: "";
  display: none;
}

/* ラジオボタンチェック印（選択） */
input[type="radio"]:checked + span::after {
  background: var(--color-primary);
  border-radius: 50%;
  display: block;
  height: calc(13 / 16 * 1em);
  left: calc(5 / 16 * 1em);
  line-height: 1;
  margin: 0;
  padding: 0;
  position: absolute;
  top: calc(6 / 16 * 1em);
  width: calc(13 / 16 * 1em);
}

/* チェックボックス */
input[type="checkbox"] + span::before {
  position: absolute;
  top: 0.1em;
  left: 0;
  content: "";
  width: calc(20 / 16 * 1em);
  height: calc(20 / 16 * 1em);
  border: 1px solid var(--color-primary);
  background: #fff;
  line-height: 1;
  vertical-align: middle;
}

/* チェックボックス未チェック時 */
input[type="checkbox"] + span::after {
  content: "";
  display: none;
}

/* チェックボックスチェック時 */
input[type="checkbox"]:checked + span::after {
  display: block;
  position: absolute;
  top: 0.1em;
  left: 0.4em;
  width: 0.5em;
  height: 1em;
  content: "";
  border-bottom: 3px solid var(--color-primary);
  border-right: 3px solid var(--color-primary);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
}

@layer layout {

.l-page-container {
  position: relative;
  z-index: 1;
  overflow: hidden;
  background: #36a6ce;
  background: linear-gradient(
    180deg,
    #36a6ce 0%,
    #2a8bb8 25%,
    #1e6b8a 50%,
    #144a5c 75%,
    #0a2a35 100%
  );
  container-type: inline-size;
  container-name: page-container;
}

/* 左サイドエリア（PCのみ表示） */
.l-page-container__sidebar-left {
  padding-top: calc(80 / 768 * 100dvh);
  position: fixed;
  top: 0;
  left: 0;
  width: calc((100vw - 470px) / 2);
  height: 100%;
  z-index: 0;
  padding-left: calc(2 * var(--gutter));
  padding-right: calc(2 * var(--gutter) + 50px);
  display: grid;
  overflow-y: hidden;
  justify-items: end;
  padding-bottom: 45px;
  
  /* コンテナクエリベースのレスポンシブ */
  container-type: inline-size;
  container-name: sidebar-left;
}

/* コンテナクエリでサイドバーの表示制御 */
@container sidebar-left (max-width: 1200px) {
  .l-page-container__sidebar-left {
    padding-left: calc(1.5 * var(--gutter));
    padding-right: calc(1.5 * var(--gutter));
  }
}

@container sidebar-left (max-width: 1024px) {
  .l-page-container__sidebar-left {
    display: none;
  }
}

/* 右サイドエリア（PCのみ表示） */
.l-page-container__sidebar-right {
  position: fixed;
  top: 0;
  right: 0;
  width: calc((100vw - 470px) / 2);
  height: 100%;
  padding-bottom: 45px;
  padding-left: calc(2 * var(--gutter));
  padding-right: calc(2 * var(--gutter));
  display: grid;
  justify-items: start;
  padding-top: calc(80 / 768 * 100dvh);
  overflow-y: auto;
  
  /* コンテナクエリベースのレスポンシブ */
  container-type: inline-size;
  container-name: sidebar-right;
}

/* コンテナクエリでサイドバーの表示制御 */
@container sidebar-right (max-width: 1200px) {
  .l-page-container__sidebar-right {
    padding-top: calc(80 / 768 * 100dvh);
    padding-left: calc(1.5 * var(--gutter));
    padding-right: calc(1.5 * var(--gutter));
  }
}

@container sidebar-right (max-width: 1024px) {
  .l-page-container__sidebar-right {
    display: none;
  }
}

/* スマホ表示時にPC背景要素を非表示 - コンテナクエリベース */

@container page-container (max-width: 768px) {
  .l-page-container__sidebar-left {
    display: none;
  }
  
  .l-page-container__sidebar-right {
    display: none;
  }
  
  /* 雲や星の背景要素も非表示 */
  .clouds-container {
    display: none;
  }
  
  #starsCanvas {
    display: none;
  }
}

/* 1180px以下でデスクトップ要素を非表示 */
@media (max-width: 1180px) {
  .l-page-container__desktop {
    display: none;
  }
}

/* メインコンテンツエリア */
.l-page-container__main {
  position: relative;
  max-width: 470px;
  width: 100%;
  margin-top: -20px;
  margin-left: auto;
  margin-right: auto;
  z-index: 2;
  overflow: hidden;
  
  /* 固定パディング */
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box;
}

/* ファーストビューの流動的調整 */
.p-top-fv__copy img {
  width: clamp(60%, 80%, 100%);
  height: auto;
}

.p-top-fv__logo {
  margin-top: 0;
}

.p-top-fv__logo img {
  width: 100%;
  height: auto;
}

/* コンテンツセクションの固定調整 */
.p-top-fv__content {
  margin-top: 18px;
  margin-bottom: 60px;
  z-index: 10;
  position: relative;
  color: white;
  text-align: center;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  pointer-events: none;
}

/* PC表示では余白を最小限に */
@media (min-width: 769px) {
  .p-top-fv__content {
    margin-bottom: 30px;
  }
}

.p-top-fv__text {
  font-size: clamp(15px, 3.5vw, 17px);
}

.p-top-fv__link {
  font-size: clamp(15px, 3.5vw, 17px);
  padding: clamp(8px, 2vw, 11px) clamp(16px, 4vw, 22px);
}

.l-page-container {
  background: #36a6ce;
  background: linear-gradient(
    180deg,
    rgb(255, 235, 179) 0%,
    rgba(63, 148, 181,1) 30%,
    rgb(108, 64, 69) 70%,
    rgba(16, 38, 58) 100%
  );
  position: relative;
  overflow: hidden;
}

/* 美しい星の背景 */
.l-page-container::before {
  display: none;
}

/* 星のアニメーション */
@keyframes stars-fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 0.8;
  }
}

/* 美しい星の点滅効果 */
.l-page-container::after {
  display: none;
}

@keyframes stars-gentle-twinkle {
  0%, 100% {
    opacity: 0;
    transform: scale(1);
  }
  50% {
    opacity: 0.8;
    transform: scale(1.1);
  }
}

/* 星のCanvas */
#starsCanvas {
  position: absolute;
  bottom: 0; /* ページの最下部に固定 */
  left: 0;
  width: 100%;
  height: 30%; /* 完全な夜部分（100%〜70%）のみカバー */
  pointer-events: none;
  z-index: 1;
  opacity: 0.9;
}

/* 雲のコンテナ */
.clouds-container {
  position: absolute;
  top: 30%; /* 青空部分の開始位置 */
  left: 0;
  width: 100%;
  height: 40%; /* 青空部分（30%〜70%）をカバー */
  pointer-events: none;
  z-index: -1; /* 背景として最背面に配置 */
  overflow: hidden;
}

/* 個別の雲 */
.cloud {
  position: absolute;
  opacity: 0.8;
  pointer-events: none;
  /* アニメーションを無効化 */
}

/* 固定配置の雲 */
.fixed-cloud-1,
.fixed-cloud-2,
.fixed-cloud-3,
.fixed-cloud-4,
.fixed-cloud-5,

/* 月のスタイル */

.cloud-1 {
  width: 160px; /* 大きめに調整 */
  height: auto;
  top: 8%; /* より上に移動 */
  left: 15%; /* 左側により配置 */
  /* アニメーションを無効化 */
}

.cloud-2 {
  width: 180px; /* 大きめに調整 */
  height: auto;
  top: 18%; /* より上に移動 */
  left: 75%; /* 右側により配置 */
  /* アニメーションを無効化 */
}

.cloud-3 {
  width: 140px; /* 大きめに調整 */
  height: auto;
  top: 3%; /* より上に移動 */
  left: 45%; /* 中央寄りに配置 */
  /* アニメーションを無効化 */
}

/* 雲の浮遊アニメーション */
@keyframes cloudFloat {
  0% {
    transform: translateX(0px); /* 初期位置から開始 */
  }
  100% {
    transform: translateX(calc(100vw + 200px)); /* 右端まで移動 */
  }
}

/* 美しい星の追加レイヤー（テスト用に無効化） */
.l-page-container .stars-layer-1 {
  display: none;
}

@keyframes stars-very-gentle {
  0%, 100% {
    opacity: 0;
    transform: scale(0.8);
  }
  50% {
    opacity: 0.6;
    transform: scale(1.2);
  }
}

/* 美しい大きな星の効果（テスト用に無効化） */
.l-page-container .stars-layer-2 {
  display: none;
}

@keyframes stars-subtle-bright {
  0%, 100% {
    opacity: 0;
    transform: scale(0.9);
  }
  50% {
    opacity: 0.7;
    transform: scale(1.3);
  }
}

.l-top-main {
  background: white;
  border-radius: 0 0 30px 30px;
  color: #555555;
  position: relative;
  border-left: 5px solid white;
  border-right: 5px solid white;
}

.l-page-container__bubble._left {
  left: 0;
  bottom: 0;
  width: clamp(300px, 50vw, 575px);
  translate: -30% 25%;
}
.l-page-container__bubble._right {
  right: 0;
  translate: 39% -20%;
  width: 620px;
}

.l-page-container__copyright {
  font-size: clamp(10px, 2.5vw, 11px);
  font-weight: 700;
  padding-top: clamp(15px, 3vw, 20px);
  padding-bottom: clamp(20px, 4vw, 40px);
  color: white;
  text-align: center;
}

/* PC表示では余白を最小限に */
@media (min-width: 769px) {
  .l-page-container__copyright {
    padding-bottom: 20px;
  }
}

/* 固定フッターメニュー用の余白 - PC表示では不要 */
@media (max-width: 768px) {
  body {
    padding-bottom: clamp(0px, 6vw, 60px);
  }
}

}

@layer components {

.c-button-cta-tel:hover {
  opacity: 0.7;
}

.c-button-cta-web:hover {
  opacity: 0.7;
}

.c-button-reserved:hover {
  opacity: 0.7;
}

.c-button-cta-web-sp,

.c-button-cta-web-sp:hover,
.c-button-cta-tel-sp:hover {
  opacity: 0.7;
}

.c-button-cta-web-sp__wrap,

.c-button-cta-web-sp__name,

.c-button-cta-web-sp__text,

.c-button-cta-web-sp__text[data-size="12"],
.c-button-cta-tel-sp__text[data-size="12"] {
  font-size: 12px;
}

.c-button-cta-web-sp__text[data-size="13"],
.c-button-cta-tel-sp__text[data-size="13"] {
  font-size: 13px;
}

.c-button-cta-web-sp__text[data-size="15"],
.c-button-cta-tel-sp__text[data-size="15"] {
  font-size: 15px;
}

.c-button-cta-web-sp__text[data-size="20"],
.c-button-cta-tel-sp__text[data-size="20"] {
  font-size: min(20px, calc(20 / 470 * 100vw));
}

.c-button-cta-web-sp__arrow,

}

@layer components {
.c-heading-main[data-color="green"] {
  color: #0b5bc3;
}
.c-heading-main[data-color="brown"] {
  color: #a37b3a;
}
.c-heading-main[data-color="map"] {
  color: #955954;
}
.c-heading-main[data-color="faq"] {
  color: #5c3f4b;
}
.c-heading-main[data-color="access"] {
  color: #303346;
}

}

@layer components {

}

@layer components {
.c-top-news {
  position: relative;
}
.c-top-news__link {
  padding-bottom: 10px;
  padding-top: 5px;
  display: block;
}

.c-top-news__body {
  transition: translate var(--ease-in-out-quad) 0.3s;
}
.c-top-news__link:hover .c-top-news__body {
  translate: 20px;
}
.c-top-news__date {
  color: #0b5bc3;
  font-weight: 500;
  font-size: 12px;
  line-height: 1;
}

.c-top-news__title {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 2px;
}
}

@layer components {
}

@layer site {

}

@layer site {

.s-spmenu__inner .s-footer-nav__list {
  display: flex;
  flex-direction: column;
  row-gap: 2em;
}

.s-spmenu__term:not(:first-of-type) {
  margin-top: 20px;
}

.s-spmenu-nav__item:not(:last-of-type) {
  border-bottom: 1px solid currentColor;
}

.c-button-tel__text[data-size="16"] {
  font-size: 16px;
  line-height: 1.5;
}
.c-button-tel__text[data-size="14"] {
  font-size: 14px;
  line-height: 1.5;
}
.c-button-tel__text[data-size="21"] {
  font-size: 21px;
  line-height: 1.2;
}
.c-button-tel__text[data-size="30"] {
  font-size: 30px;
  line-height: 1.1;
}

}

@layer site {

.s-footer {
  padding-top: clamp(20px, 4vw, 25px);
  padding-bottom: clamp(20px, 4vw, 25px);
  padding-left: clamp(15px, 3vw, var(--gutter));
  padding-right: clamp(15px, 3vw, var(--gutter));
}

.s-footer__sns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin-bottom: 20px;
}

.s-footer__sns-link {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.3s ease;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: transparent;
}

.s-footer__sns-link:hover {
  color: var(--color-primary);
  background-color: rgba(92, 171, 184, 0.1);
}

.s-footer__sns-link svg {
  width: 24px;
  height: 24px;
  transition: transform 0.3s ease;
}

.s-footer__sns-link:hover svg {
  transform: scale(1.1);
}

.s-footer__logo {
  margin-top: 20px;
  display: grid;
  place-items: center;
}

/* SPサイズ用固定フッターメニュー */
.s-footer-menu-sp-fixed {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: white;
  box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  
  /* コンテナクエリベースの表示制御 */
  container-type: inline-size;
  container-name: footer-menu;
}

/* コンテナクエリでフッターメニューの表示制御（メディアクエリと併用） */
@container footer-menu (max-width: 768px) {
  .s-footer-menu-sp-fixed {
    display: block;
  }
}

.s-footer-menu-sp-fixed__toggle {
  width: 100%;
  background-color: white;
  color: #333;
  border: 1px solid #e0e0e0;
  padding: 15px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 16px;
  font-weight: 700;
  font-family: var(--fontFamily-maru);
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.s-footer-menu-sp-fixed__toggle:hover {
  background-color: #f5f5f5;
}

.s-footer-menu-sp-fixed__toggle[aria-expanded="true"] {
  background-color: #f5f5f5;
}

.s-footer-menu-sp-fixed__toggle-text {
  font-size: 16px;
  font-weight: 700;
}

.s-footer-menu-sp-fixed__toggle-icon {
  width: 24px;
  height: 18px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.s-footer-menu-sp-fixed__toggle-icon span {
  width: 100%;
  height: 2px;
  background-color: #333;
  transition: all 0.3s ease;
  transform-origin: center;
}

.s-footer-menu-sp-fixed__toggle[aria-expanded="true"] .s-footer-menu-sp-fixed__toggle-icon span:nth-child(1) {
  transform: rotate(45deg) translate(6px, 6px);
}

.s-footer-menu-sp-fixed__toggle[aria-expanded="true"] .s-footer-menu-sp-fixed__toggle-icon span:nth-child(2) {
  opacity: 0;
}

.s-footer-menu-sp-fixed__toggle[aria-expanded="true"] .s-footer-menu-sp-fixed__toggle-icon span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

.s-footer-menu-sp-fixed__nav {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  background-color: white;
  position: relative;
  z-index: 1;
  border-top: 1px solid #e0e0e0;
}

.s-footer-menu-sp-fixed__nav[aria-hidden="false"] {
  max-height: 500px;
}

.s-footer-menu-sp-fixed__list {
  list-style: none;
  padding: 20px 0;
  margin: 0;
  max-height: 70vh;
  overflow-y: auto;
}

.s-footer-menu-sp-fixed__item {
  border-bottom: 1px solid #e0e0e0;
}

.s-footer-menu-sp-fixed__item:last-child {
  border-bottom: none;
}

.s-footer-menu-sp-fixed__link {
  display: block;
  padding: 15px 20px;
  color: #333;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  font-family: var(--fontFamily-maru);
  transition: background-color 0.3s ease, color 0.3s ease;
}

.s-footer-menu-sp-fixed__link:hover {
  background-color: #f5f5f5;
  color: #000;
}

.s-footer-menu-sp-fixed__text {
  display: block;
}
}

@layer site {

.s-sidebar-left {
  max-width: 341px;
  color: white;
}

.s-sidebar-left__buttons > *:nth-child(1) {
  grid-area: 1 / 1 / 2 / 2;
}
.s-sidebar-left__buttons > *:nth-child(2) {
  grid-area: 1 / 2 / 3 / 3;
}
.s-sidebar-left__buttons > *:nth-child(3) {
  grid-area: 2 / 1 / 3 / 2;
}
/* @media screen and (max-width: 1200px) {
  
  .s-sidebar-left__buttons > *:nth-child(1) {
    grid-area: auto;
  }
  .s-sidebar-left__buttons > *:nth-child(2) {
    grid-area: auto;
  }
  .s-sidebar-left__buttons > *:nth-child(3) {
    grid-area: auto;
  }
} */

/* @media screen and (max-width: 1200px) {
  .s-sidebar-left__button img {
    width: 100%;
  }
} */

.s-sidebar-left__button[data-type="web"] {
  border-radius: 17%;
}
.s-sidebar-left__button[data-type="tel"] {
  border-radius: 15%;
}
.s-sidebar-left__button[data-type="reserved"] {
  border-radius: 28px;
}

.s-sidebar-left__button::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: color-mix(in srgb, white 30%, transparent);
  opacity: 0;
  transition: opacity 0.4s var(--ease-in-out-quad);
  z-index: 1;
}

.s-sidebar-left__button[href]:hover::before {
  opacity: 1;
}

.s-sidebar-left__button > img {
  position: relative;
  z-index: 2;
}
.s-sidebar-left-plan__heading {
  margin-top: 40px;
  width: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.s-sidebar-left-plan__heading-text {
  font-size: 18px;
  line-height: calc(34 / 18);
  border-radius: 0;
  min-width: auto;
  padding-left: 0;
  padding-right: 0;
  border: none;
  font-family: var(--fontFamily-maru);
  font-weight: 800;
  font-variation-settings: "wght" 800;
  text-align: left;
}
.s-sidebar-left-plan__heading::before {
  display: none;
}
.s-sidebar-left-plan__heading::after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: currentColor;
  flex: 1;
  margin-left: 12px;
}

.s-sidebar-left-plan__term {
  font-size: 16px;
  font-weight: 700;
  line-height: calc(24 / 16);
  margin-top: 15px;
}
.s-sidebar-left-plan__description {
  font-size: 14px;
  font-weight: 500;
  line-height: calc(22 / 14);
}

.s-sidebar-right {
  font-family: var(--fontFamily-maru);
  color: white;
}

.s-sidebar-nav {
  margin-left: 40px;
}

.s-sidebar-nav__list {
  display: flex;
  flex-direction: column;
  row-gap: 2.5dvh;
}
.s-sidebar-nav__link {
  position: relative;
  transition: padding-left var(--ease-in-out-quad) 0.15s;
  display: flex;
  align-items: center;
  column-gap: 10px;
  width: fit-content;
}

.s-sidebar-nav__link:hover {
  padding-left: 25px;
}
.s-sidebar-nav__link[aria-current="page"] {
  padding-left: 25px;
}

.s-sidebar-nav__link._active {
  padding-left: 25px;
  opacity: 1;
  font-weight: 700;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 5px;
}

.s-sidebar-nav__link::before {
  transition: width var(--ease-in-out-quad) 0.35s;
  position: absolute;
  left: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z'/%3E%3C/svg%3E");
  width: 20px;
  height: 20px;
  transform: translate3d(0, -50%, 0);
  top: 50%;
  content: "";
  display: inline-block;
  width: 0;
  background-repeat: no-repeat;
  background-size: contain;
}
.s-sidebar-nav__link[aria-current="page"]::before {
  width: 20px;
}

.s-sidebar-nav__link._active::before {
  width: 20px;
  opacity: 1;
}
.s-sidebar-nav__link:hover::before {
  width: 20px;
}

.s-sidebar-nav__text {
  font-size: 16px;
  font-weight: 700;
  line-height: calc(16.8 / 16);
}

}

@layer site {

}

@layer site {

.s-nav-sns__link:hover {
  opacity: 0.7;
}
}

@layer site {

}

@layer page {

.p-top-fv__wrap {
  display: grid;
  position: relative;
  background-image: url("../images/bg_river.jpg");
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  z-index: 1;
}

.p-top-fv__ilu {
  grid-area: 1 / -1;
  position: relative;
}

.p-top-fv__copy {
  grid-area: 1 / -1;
  position: relative;
  z-index: 1;
  display: grid;
  align-items: center;
  justify-items: center;
}

.p-top-fv__copy img {
  width: 80%;
  height: auto;
  margin-top: 30px;
  animation: float 6s ease-in-out infinite;
}

@keyframes float {
  0%, 100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-10px);
  }
}


.p-top-fv__text {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 10px;
  color: #d32f2f;
  pointer-events: auto;
}

.p-top-fv__link {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 15px;
  padding: 12px 24px;
  background-color: #d32f2f;
  color: white;
  border-radius: 25px;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
  display: inline-block;
  border: 2px solid rgba(211, 47, 47, 0.3);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  position: relative;
  z-index: 100;
  pointer-events: auto;
}

.p-top-fv__link:hover {
  background-color: #b71c1c;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  text-decoration: none;
}

.p-top-fv__ilu { z-index: 1; }

.p-top-fv__copy { z-index: 1; }

/* ヘッダーコンテナの基本定義（全サイズ適用） */
.p-top-fv__header {
  grid-area: 1 / -1;
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}

/* スペーサー要素で高さの位置を流動的に指定（470px以上は固定） */
.p-top-fv__spacer {
  height: 260px;
  width: 100%;
}

/* 470px以下でのみ流動的な高さ調整 */
@media (max-width: 470px) {
  .p-top-fv__spacer {
    height: clamp(100px, 260px - (470px - 100vw) * 0.5, 260px);
  }
}

.p-top-fv__logo {
  display: grid;
  place-items: center;
  padding-bottom: 20px;
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 470px;
  margin-left: auto;
  margin-right: auto;
  margin-top: -10px;
}

.p-top-fv__logo img {
  width: 100%;
  height: auto;
}

/* for GSAP */

.p-top-fv__ilu {
  clip-path: polygon(0 100%, 100% 100%, 100% 150%, 0 100%);
}

/* howto */

.p-top-about {
  background: linear-gradient(180deg, transparent 0%, transparent 0%, #e9f7ff 0%, #e9f7ff 100%);
  padding-left: clamp(15px, 3vw, var(--gutter));
  padding-right: clamp(15px, 3vw, var(--gutter));
  position: relative;
  padding-top: 0;
  padding-bottom: clamp(30px, 6vw, 50px);
  z-index: 2;
}

.p-top-about__pic {
  width: 100%;
  max-width: 470px;
  margin-left: auto;
  margin-right: auto;
  margin-left: calc(clamp(15px, 3vw, var(--gutter)) * -1);
  margin-right: calc(clamp(15px, 3vw, var(--gutter)) * -1);
  width: calc(100% + 2 * clamp(15px, 3vw, var(--gutter)));
}

.p-top-about__wave {
  position: absolute;
  left: 0;
  width: 100%;
}

.p-top-about__wave--upper {
  top: -63px;
  width: 100%;
}

.p-top-about__inner {
  position: relative;
}

.p-top-about__pic img,
.p-top-about__svg {
  width: 100%;
  height: auto;
  display: block;
}

/* SVG内のテキスト要素のスタイル調整 */
.p-top-about__pic svg text,
.p-top-about__pic svg text.st2,
.p-top-about__pic svg text.st3 {
  font-size: 28px !important;
  font-weight: 700 !important;
  font-family: var(--fontFamily-maru) !important;
  fill: var(--color-primary) !important;
}

/* about_01.svg内のテキストを太くする - objectタグ用 */
.p-top-about__pic object {
  width: 100%;
  height: auto;
}

/* SVG内のテキストスタイル（JavaScriptで適用） */
svg text.st0,
svg text.st1 {
  font-weight: 700 !important;
  font-family: var(--fontFamily-maru) !important;
}

.p-top-news__heading {
  padding-top: 20px;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  padding-bottom: 5px;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  background-color: white;
  position: relative;
  z-index: 2;
}

.p-top-news__heading h2 {
  margin: 0;
  font-size: 24px;
  font-weight: bold;
  font-family: "AvenirNextLTPro-Demi", sans-serif;
  color: #0b5bc3;
}

.p-top-news__list {
  padding-top: 5px;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  background-color: white;
  filter: drop-shadow(0 3px 6px color-mix(in srgb, #000000 16%, transparent));
  padding-bottom: 15px;
}

.p-top-news__item {
  border-bottom: 1px solid #f8f4e9;
}

.p-top-news__item--more {
  border-bottom: none;
  padding-top: 20px;
}

.p-top-news__more {
  text-align: right;
}

.c-button-more {
  display: inline-block;
  padding: 8px 16px;
  background-color: #0b5bc3;
  color: white;
  text-decoration: none;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 500;
  transition: background-color 0.3s ease;
}

.c-button-more:hover {
  background-color: color-mix(in srgb, #0b5bc3 80%, transparent);
}

.p-top-price {
  padding-top: clamp(120px, 20vw, 180px);
  padding-bottom: clamp(50px, 8vw, 80px);
  padding-left: clamp(15px, 3vw, var(--gutter));
  padding-right: clamp(15px, 3vw, var(--gutter));
  position: relative;
  z-index: 3;
  background: linear-gradient(180deg, #586483 0%, #586483 50%, #6a7a9a 100%);
}

.p-top-price__wave {
  position: absolute;
  left: 0;
  width: 100%;
  z-index: 1;
}

.p-top-price__wave--upper {
  top: -65px;
  z-index: 1;
}

/* メニューセクションの調整 */
.p-top-menu__inner {
  margin-top: clamp(60px, 8vw, 100px);
  position: relative;
  z-index: 2;
}

.p-top-menu__subheading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: clamp(15px, 3vw, var(--gutter));
  padding-right: clamp(15px, 3vw, var(--gutter));
  margin-top: clamp(25px, 4vw, 35px);
}

.p-top-menu__info {
  padding-left: clamp(15px, 3vw, var(--gutter));
  padding-right: clamp(15px, 3vw, var(--gutter));
  margin-top: clamp(20px, 3vw, 30px);
  display: flex;
  flex-direction: column;
  row-gap: clamp(15px, 2.5vw, 20px);
}

.p-top-menu__access {
  margin-top: clamp(20px, 3vw, 30px);
  padding-left: clamp(15px, 3vw, var(--gutter));
  padding-right: clamp(15px, 3vw, var(--gutter));
}

.p-top-menu__attention {
  margin-top: clamp(20px, 3vw, 30px);
  padding-left: clamp(15px, 3vw, var(--gutter));
  padding-right: clamp(15px, 3vw, var(--gutter));
}

.p-top-plan[data-color="standard"] {
  --color-top-plan: #0b5bc3;
}
.p-top-plan[data-color="reserved"] {
  --color-top-plan: color-mix(in srgb, #0b5bc3 80%, transparent);
}

.p-top-plan__note._list {
  margin-top: 7px;
}

.p-top-plan__pic .-heading {
  color: var(--color-top-plan);
  font-size: min(18px, calc(18 / 470 * 100vw));
  line-height: calc(29 / 18);
  display: flex;
  align-items: center;
  column-gap: 10px;
  font-weight: 700;
}
.p-top-plan__pic .-heading:not(:first-of-type) {
  margin-top: 20px;
}
.p-top-plan__pic .-figure {
  margin-top: 10px;
}

.p-top-plan__pic .-img {
  border-radius: 30px;
}

.p-top-plan__pic .-figcaption {
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  margin-top: 10px;
  font-size: 14px;
  font-weight: 500;
  line-height: calc(22 / 14);
}

.p-top-menu__subheading[data-type="frame"] {
  position: absolute;
  margin-top: unset;
  top: 0;
  left: 50%;
  translate: -50% -50%;
  width: 100%;
}

.p-top-menu__subheading[data-type="frame"] > .p-top-menu__subheading-text {
}

.p-top-menu__subheading[data-type="frame"]::before {
  content: none;
}
.p-top-menu__subheading[data-type="frame"]::after {
  content: none;
}

.p-top-menu__subheading-text {
  font-size: min(18px, calc(18 / 470 * 100vw));
  line-height: calc(32 / 18);
  border-radius: min(32px, calc(32 / 470 * 100vw));
  padding-left: 1.2em;
  padding-right: 1.2em;
  border: 1px solid white;
  background-color: white;
  font-weight: 700;
  color: #586483;
}
.p-top-menu__subheading::before {
  content: "";
  width: 100%;
  height: 12px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 12'%3E%3Cpath d='M0,6 Q12.5,0 25,6 T50,6 T75,6 T100,6' stroke='white' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-size: 50px 12px;
  flex: 1;
}
.p-top-menu__subheading::after {
  content: "";
  width: 100%;
  height: 12px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 12'%3E%3Cpath d='M0,6 Q12.5,0 25,6 T50,6 T75,6 T100,6' stroke='white' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-size: 50px 12px;
  flex: 1;
}

.p-top-menu__list[data-menu="freedrink"] {
  margin-top: clamp(20px, 3vw, 25px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  column-gap: clamp(2%, 4vw, 4%);
  row-gap: clamp(8px, 1.5vw, 10px);
  text-align: center;
}

.p-top-menu__info-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}

.p-top-menu__info-item:last-child {
  border-bottom: none;
}

.p-top-menu__info-title {
  font-size: 16px;
  font-weight: 700;
  color: white;
  margin: 0;
  line-height: 1.4;
  text-align: left;
}

.p-top-menu__info-content {
  font-size: 14px;
  font-weight: 500;
  color: white;
  margin: 0;
  line-height: 1.6;
  text-align: right;
}

.p-top-menu__cta {
  background-color: white;
  border-radius: 20px;
  padding: 25px;
  margin-top: 30px;
}

.p-top-menu__cta-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.p-top-menu__cta-title {
  font-size: 18px;
  font-weight: 700;
  color: #586483;
  text-align: left;
  margin: 0;
  font-family: var(--fontFamily-maru);
  flex-shrink: 0;
}

.p-top-menu__cta-buttons {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
}

.c-button-date {
  display: block;
  background-color: #edbf00;
  color: #586483;
  text-align: center;
  padding: 12px 20px;
  border-radius: 20px;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;
  transition: opacity 0.4s;
  font-family: var(--fontFamily-maru);
  min-width: 80px;
}

.c-button-date:hover {
  opacity: 0.7;
  text-decoration: none;
  color: #586483;
}

.p-top-menu__access-info {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}

.p-top-menu__access-title-text {
  font-size: min(18px, calc(18 / 470 * 100vw));
  line-height: calc(32 / 18);
  border-radius: min(32px, calc(32 / 470 * 100vw));
  padding-left: 1.2em;
  padding-right: 1.2em;
  border: 1px solid white;
  background-color: white;
  font-weight: 700;
  color: #586483;
}

.p-top-menu__access-title::before {
  content: "";
  width: 100%;
  height: 12px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 12'%3E%3Cpath d='M0,6 Q12.5,0 25,6 T50,6 T75,6 T100,6' stroke='white' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-size: 50px 12px;
  flex: 1;
}

.p-top-menu__access-title::after {
  content: "";
  width: 100%;
  height: 12px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 12'%3E%3Cpath d='M0,6 Q12.5,0 25,6 T50,6 T75,6 T100,6' stroke='white' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-size: 50px 12px;
  flex: 1;
}

.p-top-menu__access-address {
  font-size: 14px;
  line-height: calc(17 / 14);
  font-weight: 500;
  margin: 0 0 15px 0;
  color: white;
}

.p-top-menu__access-list {
  margin: 0 0 20px 0;
  padding: 0;
  list-style: none;
}

.p-top-menu__access-item {
  font-size: 14px;
  line-height: calc(17 / 14);
  font-weight: 500;
  margin-bottom: 8px;
  color: white;
}

.p-top-menu__access-text {
  font-size: 14px;
  line-height: calc(30 / 14);
  display: block;
  font-weight: 500;
  color: white;
}

.p-top-menu__access-link:hover {
  opacity: 0.7;
}

.p-top-menu__access-link::before {
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: currentColor;
}

.p-top-menu__access-map {
  margin-top: 20px;
  background-color: white;
  border-radius: 20px;
  width: 100%;
  max-width: 430px;
  margin-left: auto;
  margin-right: auto;
}

.p-top-menu__access-map iframe {
  width: 100%;
  height: 303px;
  display: block;
}

.p-top-menu__list[data-menu="food"] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  column-gap: clamp(2%, 4vw, 4%);
  row-gap: clamp(2px, 0.5vw, 2px);
  margin-top: clamp(12px, 2vw, 15px);
}

.p-top-menu__list[data-menu="food"] .p-top-menu__item {
  padding-top: clamp(2px, 0.5vw, 3px);
  font-size: clamp(12px, 2.5vw, 14px);
  font-weight: 500;
  line-height: 1.5;
  border-bottom: 1px solid currentColor;
  padding-bottom: clamp(2px, 0.5vw, 3px);
}
.p-top-menu__list[data-menu="food"] .p-top-menu__item .p-top-menu__item-variation,
.p-top-menu__list[data-menu="food"] .p-top-menu__item .p-top-menu__item-price {
  font-size: clamp(10px, 2vw, 12px);
  line-height: 1.4;
  display: block;
}
.p-top-menu__list[data-menu="food"] .p-top-menu__item .p-top-menu__item-price {
  margin-top: 0.3em;
  padding-bottom: 2px;
}
.p-top-menu__list[data-menu="reserved"] {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: clamp(8px, 1.5vw, 10px);
  margin-top: clamp(8px, 1.5vw, 10px);
}

.p-top-menu__list[data-menu="reserved"] .p-top-menu__item {
  border-bottom: 1px solid currentColor;
  padding-bottom: clamp(1px, 0.5vw, 2px);
  padding-top: clamp(1px, 0.5vw, 1px);
}

.p-top-menu__list[data-menu="reserved"] .p-top-menu__item .p-top-menu__item-row {
  display: grid;
  grid-template-columns: clamp(8px, 2vw, 10px) 1fr auto;
  column-gap: clamp(8px, 2vw, 10px);
}

.p-top-menu__list[data-menu="reserved"] .p-top-menu__item .p-top-menu__item-num {
  font-size: clamp(12px, 2.5vw, 14px);
  font-weight: 700;
  line-height: 1.4;
  align-self: flex-start;
}
.p-top-menu__list[data-menu="reserved"] .p-top-menu__item .p-top-menu__item-name {
  font-size: clamp(12px, 2.5vw, 14px);
  font-weight: 500;
  line-height: 1.4;
}
.p-top-menu__list[data-menu="reserved"] .p-top-menu__item .p-top-menu__item-price {
  font-size: clamp(12px, 2.5vw, 14px);
  font-weight: 500;
  line-height: 1.4;
  align-self: flex-end;
  justify-self: flex-end;
}
.p-top-menu__list[data-menu="reserved"] .p-top-menu__item .p-top-menu__item-detail {
  font-size: clamp(12px, 2.5vw, 14px);
  font-weight: 500;
  line-height: 1.4;
  margin-top: clamp(8px, 1.5vw, 10px);
}
.p-top-menu__list[data-menu="reserved"] .p-top-menu__item .p-top-menu__item-note {
  font-size: clamp(10px, 2vw, 12px);
  margin-top: clamp(8px, 1.5vw, 10px);
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: clamp(3px, 1vw, 5px);
}

.p-top-menu__figures img {
  width: 100%;
}

.p-top-menu__cta {
  margin-top: clamp(20px, 3vw, 30px);
  padding: clamp(20px, 4vw, 25px);
  background-color: white;
  border-radius: clamp(15px, 3vw, 20px);
}

.p-top-menu__slider .splide__slide .p-top-menu__slide-img {
  border-radius: clamp(20px, 4vw, 30px);
  border: 1px solid #a37b3a;
  aspect-ratio: 321 / 195;
  height: auto;
  object-fit: cover;
}

.p-top-map__subheading[data-type="7f"] {
  margin-top: clamp(12px, 2vw, 15px);
}
.p-top-map__subheading[data-type="6f"] {
  margin-top: clamp(20px, 3vw, 30px);
}
.p-top-map__subheading[data-type="5f"] {
  margin-top: clamp(20px, 3vw, 30px);
}

.p-top-map__subheading::before {
  content: "";
  width: 100%;
  height: clamp(1px, 0.5vw, 2px);
  background-color: currentColor;
  flex: 1;
}
.p-top-map__subheading::after {
  content: "";
  width: 100%;
  height: clamp(1px, 0.5vw, 2px);
  background-color: currentColor;
  flex: 1;
}

.p-top-faq__wave._upper {
  top: -50px;
  z-index: 1;
}

.p-top-access__wave._upper {
  top: -50px;
  z-index: 1;
}
.p-top-access__wave._lower {
  z-index: 2;
  bottom: -50px;
}

.p-top-access__item[data-type="mt"] {
  margin-top: 10px;
}

.p-top-access__item-link:hover {
  opacity: 0.7;
}

.p-top-access__item-link::before {
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: currentColor;
}

.p-top-access__map iframe {
  max-width: 100%;
}

}

@layer javascript {
.js-animation._top-fade {
  opacity: 0;
}
.js-animation._top-fade._active {
  animation-name: top-fade;
  animation-duration: 1.2s;
  animation-delay: 0.7s;
  animation-fill-mode: forwards;
}

@keyframes top-fade {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}
}

@layer utility {

.u-clear-fix::after {
  clear: both;
  content: "";
  display: table;
}

@media screen and (max-width: 768px) {
  .u-md-hidden {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  
}
@media screen and (max-width: 1024px) {
  .u-lg-hidden {
    display: none;
  }
}

@media screen and (max-width: 1024px) {
  
}

@media screen and (max-width: 1280px) {
  .u-xl-hidden {
    display: none;
  }
}

@media screen and (max-width: 1280px) {
  
}

/* 注意事項セクション */

.p-top-menu__attention-title {
  margin-top: 30px;
  text-align: center;
  position: relative;
  z-index: 2;
}

.p-top-menu__attention-title-text {
  font-size: 18px;
  line-height: 1.4;
  padding: 8px 20px;
  border: 1px solid #8B0000;
  background-color: #8B0000;
  font-weight: 700;
  color: white;
  border-radius: 20px;
  display: inline-block;
  position: relative;
  z-index: 3;
}

.p-top-menu__attention-content {
  margin-top: -20px;
  background-color: #fdf2f2;
  border: 3px solid #8B0000;
  border-radius: 20px;
  padding: 35px 25px 25px 25px;
  position: relative;
  z-index: 1;
}

.p-top-menu__attention-section {
  margin-bottom: 30px;
}

.p-top-menu__attention-section:last-child {
  margin-bottom: 0;
}

.p-top-menu__attention-heading {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 20px 0;
  font-size: 16px;
  font-weight: 700;
  color: #8B0000;
}

.p-top-menu__attention-heading svg {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.p-top-menu__attention-heading svg path {
  stroke: #8B0000;
}

.p-top-menu__attention-heading p {
  margin: 0;
  line-height: 1.5;
}

.p-top-menu__attention-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.p-top-menu__attention-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background-color: #f8f9fa;
  border-radius: 8px;
  min-height: 44px;
}

.p-top-menu__attention-item svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.p-top-menu__attention-item svg path {
  stroke: #8B0000;
}

.p-top-menu__attention-item svg circle {
  stroke: #8B0000;
}

.p-top-menu__attention-text {
  font-size: 13px;
  font-weight: 500;
  color: #8B0000;
  margin: 0;
  line-height: 1.4;
  text-align: left;
}

}

/* 470px以下では「PC用のページ背景」を消す。FVのbg_river.jpgは維持する。 */
@media (max-width: 470px) {
  /* PC側のページ背景（グラデ/装飾）をオフ */
  .l-page-container { background: none !important; }

  /* PC専用の左右サイド装飾は非表示 */
  .l-page-container__sidebar-left,
  .l-page-container__sidebar-right { display: none !important; }

  /* FVの川背景は維持（誤って消していたのを明示的に復元） */
  .p-top-fv__wrap {
    background-image: url("../images/bg_river.jpg") !important;
    background-size: 100% auto !important;
    background-position: center top !important;
    background-repeat: no-repeat !important;
  }

  /* FVエリア内のセンター要素を横幅いっぱいに（左右パディング/マージン排除） */
  .p-top-fv .l-inner,
  .p-top-fv .l-container,
  .p-top-fv__inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: none !important;
  }

  /* メインコンテナのパディングを削除 */
  .l-page-container__main {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* 470px以下でのヘッダーコンテナ調整 */
  .p-top-fv__header {
    grid-area: 1 / -1 !important;
  }

  /* ファーストビューのコピー画像の幅を調整 */
  .p-top-fv__copy img {
    width: 80% !important;
    height: auto !important;
    margin-top: 30px !important;
    animation: float 6s ease-in-out infinite !important;
  }

  /* コンテンツセクションの位置調整 */
  .p-top-fv__content {
    margin-top: clamp(10px, 2vw, 15px) !important;
    margin-bottom: clamp(80px, 6vw, 50px) !important;
  }
}

/* 1180px以下でPCメニューが非表示になったらスマホメニューを表示 */
@media (max-width: 1180px) {
  .s-footer-menu-sp-fixed {
    display: block !important;
  }
}

/* より具体的なセレクタで確実に表示 */
@media (max-width: 1180px) {
  body .s-footer-menu-sp-fixed {
    display: block !important;
  }
}

/* 300px以下ではすべての要素のレスポンシブ対応をやめてブラウザ表示を固定 */
@media (max-width: 300px) {
  * {
    transform: scale(1) !important;
    zoom: 1 !important;
  }
  
  body {
    min-width: 300px !important;
    overflow-x: auto !important;
  }
  
  .l-page-container__main {
    min-width: 300px !important;
  }
  
  .p-top-fv__spacer {
    height: 168px !important;
  }
  
  .p-top-fv__copy img {
    width: 80% !important;
  }
  
  .p-top-fv__logo {
    margin-top: -10px !important;
  }
  
  .p-top-fv__content {
    margin-top: 15px !important;
    margin-bottom: 50px !important;
  }
}

