/* =============== Misemaru Theme: 02 Luxury =============== */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Noto+Sans:wght@400;500;600&family=Noto+Sans+JP:wght@400;500;600&family=Noto+Sans+TC:wght@400;500;600&family=Noto+Sans+KR:wght@400;500;600&family=Noto+Serif+JP:wght@400;500;600&family=Noto+Serif+TC:wght@400;500;600&family=Noto+Serif+KR:wght@400;500;600&display=swap');
:root {
  --bg-color: #08080c;
  --text-color: #f5f2e8;
  --modal-text-color: #f5f2e8;
  --full-screen-bg: rgba(8, 8, 12, 0.98);
  --frame-bg: rgba(17, 17, 25, 0.92);
  --btn-text-color: #111119;
  --btn-hover-bg: rgba(212, 175, 55, 0.16);
  --btn-red: #d4af37;
  --btn-green: #5dd4b2;
  --btn-blue: #72b3f4;
  --btn-gray: #7c7c8c;

  --lux-panel: rgba(17, 17, 25, 0.86);
  --lux-panel-border: rgba(212, 175, 55, 0.22);
  --lux-gold: #d4af37;
  --lux-gold-soft: rgba(212, 175, 55, 0.18);
  --lux-muted: rgba(245, 242, 232, 0.74);
  --shadow-soft: 0 24px 60px rgba(0, 0, 0, 0.42);
}

body {
  font-family: 'Noto Sans', 'Noto Sans JP', 'Noto Sans TC', 'Noto Sans KR', sans-serif;
  background:
    radial-gradient(circle at top left, rgba(212, 175, 55, 0.14), transparent 55%),
    radial-gradient(circle at bottom right, rgba(212, 175, 55, 0.08), transparent 40%),
    #08080c;
  color: var(--text-color);
  letter-spacing: 0.015em;
  min-height: 100vh;
  padding:.5rem;
}

:lang(ja) body {
  font-family: 'Noto Sans JP', 'Noto Sans', sans-serif;
}
:lang(zh-TW) body {
  font-family: 'Noto Sans TC', 'Noto Sans', sans-serif;
}
:lang(ko) body {
  font-family: 'Noto Sans KR', 'Noto Sans', sans-serif;
}

#wrap {
  max-width: 960px;
  background: var(--lux-panel);
  border-radius: 30px;
  border: 1px solid var(--lux-panel-border);
  padding: 3rem 2.25rem 3.5rem;
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
}
#wrap::after {
  content: "";
  position: absolute;
  width: 240px;
  height: 240px;
  background: radial-gradient(circle, var(--lux-gold-soft), transparent 70%);
  bottom: -110px;
  right: -80px;
  pointer-events: none;
}
@media (max-width: 767.98px) {
  #wrap {
    padding: 2.5rem 1.5rem 3rem;
  }
}

/*#google-login-container {
  position: absolute;
  top: 1.5rem;
  right: 2rem;
  z-index: 5;
}
@media (max-width: 767.98px) {*/
  #google-login-container {
    position: static;
    margin-bottom: 1rem;
    margin-top: 1rem;
    display: flex;
    justify-content: flex-end;
  }
/*}*/ 

.hero {
  /*display: flex;
  flex-direction: column;
  gap: 1.75rem;*/
  align-items: center;
  text-align: center;
}
@media (min-width: 768px) {
  .hero {
    flex-direction: row;
    justify-content: center;
    text-align: center;
  }
}

.hero-visual {
  flex: 1 1 320px;
  min-height: 240px;
  min-width:240px;
  border-radius: 1.5rem;
  overflow: hidden;
  position: relative;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 26px 48px rgba(15, 23, 42, 0.3);
}
.hero-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  margin: 0;
}
.hero-fallback {
  color: var(--text-gold);
  font-family: 'Cinzel', 'Noto Sans JP', 'Noto Sans TC', 'Noto Sans KR', serif;
}

.hero-copy {
  max-width: 420px;
}
.hero-eyebrow {
  font-size: 0.85rem;
  letter-spacing: 0.35em;
  color: var(--lux-muted);
}
#hero-title {
  font-family: 'Cinzel', 'Noto Sans JP', 'Noto Sans TC', 'Noto Sans KR', serif;
  font-size: clamp(2.1rem, 5.5vw, 4.2rem);
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--lux-gold);
  margin-bottom: 0.75rem;
}
#hero-tagline {
  font-size: 1.05rem;
  font-weight: 500;
  line-height: 1.8;
  color: var(--lux-muted);
  font-family: 'Cinzel', 'Noto Serif JP', 'Noto Serif TC', 'Noto Serif KR', serif;
}
#signin-note {
  font-size: 0.9rem;
  color: rgba(245, 242, 232, 0.6);
  margin-bottom: 0;
}

  #langbar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--lux-gold-soft);
    border-radius: 999px;
    padding: 0.75rem 1.25rem;
    margin: 1rem 0;
  }
  #langbar label {
    font-weight: 600;
    color: var(--lux-muted);
    margin: 0;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 0.35em;
  }
  #langSel {
    min-width: 170px;
    border-radius: 999px;
    border: 1px solid rgba(212, 175, 55, 0.4);
    background: rgba(8, 8, 12, 0.6);
    color: var(--text-color);
    padding: 0.35rem 0.75rem;
  } 

#topMenu {
  display: grid;
  gap: 1rem;
}
@media (min-width: 576px) {
  #topMenu {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.menu-btn {
  border-radius: 999px;
  padding: 1.1rem 1.5rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  border: 1px solid transparent;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease;
}
.menu-btn span {
  font-size: 1.05rem;
}
.menu-btn small {
  font-size: 0.85rem;
  color: var(--lux-muted);
}
@media (max-width: 575.98px) {
  .menu-btn small {
    font-size: 0.72rem;
  }
}
.menu-btn.primary small {
  color: rgba(34, 24, 4, 0.75);
}
.menu-btn.secondary small {
  color: var(--lux-muted);
}
.menu-btn.primary {
  background: linear-gradient(135deg, var(--lux-gold), #f8e6b0);
  color: #221804;
  border: none;
  box-shadow: 0 18px 32px rgba(212, 175, 55, 0.25);
}
.menu-btn.secondary {
  background: transparent;
  border: 1px solid var(--lux-gold);
  color: var(--lux-gold);
  box-shadow: inset 0 0 0 1px rgba(212, 175, 55, 0.25);
}
.menu-btn:hover,
.menu-btn:focus {
  transform: translateY(-4px);
}
.menu-btn.primary:hover,
.menu-btn.primary:focus {
  background: linear-gradient(135deg, #f8e6b0, var(--lux-gold));
}
.menu-btn.secondary:hover,
.menu-btn.secondary:focus {
  background: rgba(212, 175, 55, 0.12);
  color: var(--text-color);
}

.site-footer {
  color: rgba(245, 242, 232, 0.6)!important;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  margin-bottom: 1rem;
}


/* ===============================
   確認ページ（33）向け調整
   =============================== */
/* 過去/今後トグルの中央寄せと間隔 */
#display-mode-toggle { display:flex; justify-content:center; gap:8px; }

/* 予約カードを白地に黒文字で統一 
#reservationList .card,
#reservationList .card .list-group-item,
#reservationList .card .card-body,

}*/

/* 過去予約：淡色表示。ただし確認ボタンは使用可能 */
#reservationList .card.is-past {
  /*color: #999 !important;
  background: #f5f5f5 !important;*/
  pointer-events: auto !important;
}

/* トグルボタンの見た目（確認/閉じる）
#reservationList [data-role='toggle'].btn-outline-primary { color: #0d6efd; border-color: #0d6efd; }
#reservationList [data-role='toggle'].btn-primary { color: #fff !important; background-color: #0d6efd; border-color: #0d6efd; }
#reservationList [data-role='toggle'].btn-primary:hover,
#reservationList [data-role='toggle'].btn-primary:focus,
#reservationList [data-role='toggle'].btn-primary:active {
  color: #fff !important;
} 
#reservationList [data-role='toggle'].btn-outline-primary:hover,
#reservationList [data-role='toggle'].btn-outline-primary:focus,
#reservationList [data-role='toggle'].btn-outline-primary:active {
  color: #fff !important;
  background-color: #0d6efd;
}*/

/* 極小画面でのラベル文字サイズ調整 */
@media (max-width: 380px) {
  #reservationList [data-role='label'] { font-size: 0.8rem; }
}

.btn:hover {
  color: #111119;
  background-color: rgba(212, 175, 55, 0.16);
  border-color: inherit !important;
}
