/* =====================
   Design Tokens
   ===================== */
:root {
  --forest:#1E5631; /* 深緑 */
  --orange:#F29D38; /* 夕陽 */
  --blue:  #3A7CA5; /* 川の青 */
  --washi: #FFFFFF; /* 白 */
  --ink:   #1F2937; /* 本文チャコール */
  --ink2:  #475569; /* 補助 */
  --card:  rgba(255,255,255,.85);
  --bd:    rgba(15,23,42,.15);
  --sh:    0 6px 18px rgba(2,6,23,.08);
  --rad:   18px;
}

[data-theme="dark"]{
  --washi:#0f172a; 
  --ink:#f8fafc; 
  --ink2:#e2e8f0; 
  --card:rgba(255,255,255,.08); 
  --bd:rgba(255,255,255,.15); 
  --sh:0 6px 18px rgba(0,0,0,.6);
}

/* =====================
   Reset & Base Styles
   ===================== */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Noto Sans JP","BIZ UDGothic",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial; 
  background:var(--washi); 
  color:var(--ink); 
  line-height:1.6
}
h1,h2,h3,h4{font-family:"Noto Serif JP",serif;line-height:1.25;margin:0 0 .5rem}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
.container{max-width:1200px;margin-inline:auto;padding:3rem 16px}

/* =====================
   Header & Navigation
   ===================== */
header.sticky{
  position:absolute;top:0;left:0;right:0;z-index:50;
  backdrop-filter:saturate(150%) blur(8px);
  background:color-mix(in hsl, var(--washi) 85%, transparent);
  border-bottom:1px solid var(--bd);
  transition:transform 0.3s ease-in-out
}
header{position:relative}
header.sticky.is-fixed{
  position:fixed !important;top:0 !important;left:0 !important;right:0 !important;
  background:color-mix(in hsl, var(--washi) 95%, transparent) !important;
  z-index:100 !important;backdrop-filter:saturate(150%) blur(8px) !important;
  border-bottom:1px solid var(--bd) !important;transition:transform 0.3s ease-in-out !important
}
header.sticky.is-hidden{transform:translateY(-100%) !important}
header.sticky.no-transition{transition:none !important}

.nav{height:60px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800}
.brand-logo{width:clamp(120px, 15vw, 190px);height:clamp(48px, 6vw, 78px);border-radius:6px;object-fit:contain}
.nav-links{display:none;gap:1.2rem;align-items:center}
.nav-acts{display:none;gap:.6rem;align-items:center}
.instagram-link{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;transition:background-color 0.2s ease}
.instagram-link:hover{background:color-mix(in hsl, var(--ink) 8%, transparent)}
.instagram-link img{filter:opacity(0.8);transition:opacity 0.2s ease}
.instagram-link:hover img{opacity:1}
.hamb{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;background:none;border:none;cursor:pointer;position:relative}
.hamb:hover{background:color-mix(in hsl, var(--ink) 8%, transparent)}
.hamb .icon{width:24px;height:24px;transition:opacity 0.3s ease}
.hamb .icon:last-child{position:absolute;opacity:0}
.hamb.open .icon:first-child{opacity:0}
.hamb.open .icon:last-child{opacity:1}
.mobile{display:none;border-top:1px solid var(--bd);background:var(--washi);position:absolute;top:100%;left:0;right:0;z-index:1000}
.mobile.open{display:block}
.mobile a,.mobile button{display:block;padding:12px 16px;text-decoration:none;color:var(--ink)}
.mobile a:not(:last-child),.mobile button:not(:last-child){border-bottom:1px solid var(--bd)}
.mobile a:hover,.mobile button:hover{background:color-mix(in hsl, var(--ink) 8%, transparent)}
.mobile button#reserveBtnSp{color:#ffffff}
.mobile-instagram-link{transition:background-color 0.2s ease}
.mobile-instagram-link:hover{background:color-mix(in hsl, var(--ink) 8%, transparent)}

/* =====================
   Buttons
   ===================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.7rem 1.1rem;border-radius:16px;border:1px solid transparent;
  font-weight:800;transition:.18s transform,.18s box-shadow
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--forest);color:#fff;box-shadow:var(--sh)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{border-color:var(--forest);color:color-mix(in hsl,var(--forest) 85%, black)}
.btn-ghost:hover{background:color-mix(in hsl,var(--forest) 8%, transparent)}

/* =====================
   Layout & Grid
   ===================== */
section{padding:0}
.head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;width:100%}
.head > div:first-child{flex:1;width:100%;min-width:0}
.head > div:last-child{flex:0 0 auto;min-width:fit-content}

/* Responsive head layout */
@media (max-width: 768px) {
  .head{flex-direction:column;align-items:flex-start;gap:1rem}
  .head > div:first-child{flex:none;width:100%}
  .head > div:last-child{flex:none;width:100%}
  .head .action-link{width:100%;text-align:center;padding:0.8rem 1rem;border-radius:12px;background:var(--card);color:var(--ink2);border:1px solid var(--bd);font-weight:600;transition:all 0.3s ease}
  .head .action-link:hover{background:color-mix(in hsl,var(--forest) 8%, transparent);color:var(--forest);border-color:var(--forest);transform:translateY(-1px)}
}
.muted{color:var(--ink2)}

.grid{display:grid;gap:1rem}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}

/* =====================
   Cards & Components
   ===================== */
.card{
  background:var(--card);border:1px solid var(--bd);border-radius:var(--rad);
  overflow:hidden;box-shadow:var(--sh);transition:all 0.3s ease
}
.card.clickable:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,0.12)}
.body{padding:1rem}
.chip{
  display:inline-flex;align-items:center;gap:.35rem;
  background:color-mix(in hsl, var(--forest) 15%, white);
  color:color-mix(in hsl,var(--forest) 75%, black);
  padding:.25rem .6rem;border-radius:999px;font-size:.78rem;font-weight:800
}

/* =====================
   Modal System
   ===================== */
.modal{
  position:fixed;inset:0;display:none;
  background:rgba(2,6,23,.55);backdrop-filter:blur(2px);
  align-items:center;justify-content:center;padding:1rem;z-index:10000
}
.modal.open{display:flex}
.panel{
  max-width:960px;width:100%;background:var(--washi);color:var(--ink);
  border-radius:24px;box-shadow:0 25px 50px -12px rgba(0, 0, 0, 0.25);
  border:1px solid rgba(255, 255, 255, 0.1);overflow:hidden;
  backdrop-filter:blur(20px);animation:modalSlideIn 0.3s cubic-bezier(0.16, 1, 0.3, 1)
}
.panel-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid rgba(0, 0, 0, 0.06);
  background:rgba(255, 255, 255, 0.8);backdrop-filter:blur(10px)
}
.panel-body{padding:24px}

/* Dynamic Modal Background - High Specificity for Consistency */
.modal.dynamic-bg .panel,
.modal.dynamic-bg#eventModal .panel,
.modal.dynamic-bg#campModal .panel,
.modal.dynamic-bg#menuModal .panel,
.modal.dynamic-bg#vegetableModal .panel {
  background: linear-gradient(135deg, var(--modal-bg-color), color-mix(in hsl, var(--modal-bg-color) 80%, black)) !important;
  color: #ffffff !important;
}

.modal.dynamic-bg .panel-head,
.modal.dynamic-bg#eventModal .panel-head,
.modal.dynamic-bg#campModal .panel-head,
.modal.dynamic-bg#menuModal .panel-head,
.modal.dynamic-bg#vegetableModal .panel-head {
  border-bottom-color: rgba(255,255,255,0.2) !important;
  background: color-mix(in hsl, var(--modal-bg-color) 90%, black) !important;
}

.modal.dynamic-bg .panel-body,
.modal.dynamic-bg#eventModal .panel-body,
.modal.dynamic-bg#campModal .panel-body,
.modal.dynamic-bg#menuModal .panel-body,
.modal.dynamic-bg#vegetableModal .panel-body {
  color: #ffffff !important;
  background: var(--modal-bg-color) !important;
}

.modal.dynamic-bg strong,
.modal.dynamic-bg h3,
.modal.dynamic-bg#eventModal strong,
.modal.dynamic-bg#eventModal h3,
.modal.dynamic-bg#campModal strong,
.modal.dynamic-bg#campModal h3,
.modal.dynamic-bg#menuModal strong,
.modal.dynamic-bg#menuModal h3,
.modal.dynamic-bg#vegetableModal strong,
.modal.dynamic-bg#vegetableModal h3 {
  color: #ffffff !important;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.7) !important;
}

.modal.dynamic-bg p,
.modal.dynamic-bg #eventSummary,
.modal.dynamic-bg #campDescription,
.modal.dynamic-bg#eventModal p,
.modal.dynamic-bg#eventModal #eventSummary,
.modal.dynamic-bg#campModal p,
.modal.dynamic-bg#campModal #campDescription,
.modal.dynamic-bg#menuModal p,
.modal.dynamic-bg#menuModal #menuDescription,
.modal.dynamic-bg#vegetableModal p,
.modal.dynamic-bg#vegetableModal #vegetableDescription {
  color: rgba(255,255,255,0.95) !important;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.5) !important;
  font-weight: 500 !important;
}

.modal.dynamic-bg .chip,
.modal.dynamic-bg#eventModal .chip,
.modal.dynamic-bg#campModal .chip,
.modal.dynamic-bg#menuModal .chip,
.modal.dynamic-bg#vegetableModal .chip {
  background: rgba(255,255,255,0.2) !important;
  color: #ffffff !important;
  border-color: rgba(255,255,255,0.3) !important;
}

.modal.dynamic-bg .btn-primary,
.modal.dynamic-bg#eventModal .btn-primary,
.modal.dynamic-bg#campModal .btn-primary,
.modal.dynamic-bg#menuModal .btn-primary,
.modal.dynamic-bg#vegetableModal .btn-primary {
  background: rgba(255,255,255,0.9) !important;
  color: #000000 !important;
  border-color: rgba(255,255,255,0.5) !important;
  font-weight: 900 !important;
  text-shadow: none !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3) !important;
}

.modal.dynamic-bg .btn-primary:hover,
.modal.dynamic-bg#eventModal .btn-primary:hover,
.modal.dynamic-bg#campModal .btn-primary:hover,
.modal.dynamic-bg#menuModal .btn-primary:hover,
.modal.dynamic-bg#vegetableModal .btn-primary:hover {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: rgba(255,255,255,0.8) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4) !important;
}

.modal.dynamic-bg .btn-ghost,
.modal.dynamic-bg#eventModal .btn-ghost,
.modal.dynamic-bg#campModal .btn-ghost,
.modal.dynamic-bg#menuModal .btn-ghost,
.modal.dynamic-bg#vegetableModal .btn-ghost {
  background: rgba(255,255,255,0.2) !important;
  color: #ffffff !important;
  border-color: rgba(255,255,255,0.5) !important;
  font-weight: 700 !important;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.5) !important;
}

.modal.dynamic-bg .btn-ghost:hover,
.modal.dynamic-bg#eventModal .btn-ghost:hover,
.modal.dynamic-bg#campModal .btn-ghost:hover,
.modal.dynamic-bg#menuModal .btn-ghost:hover,
.modal.dynamic-bg#vegetableModal .btn-ghost:hover {
  background: rgba(255,255,255,0.3) !important;
  color: #ffffff !important;
  border-color: rgba(255,255,255,0.7) !important;
}

/* =====================
   Utility Classes
   ===================== */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.main-content{padding-top:calc(60px + 3rem)}
.reveal{opacity:0;transform:translateY(8px);transition:.45s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}
.icon{width:18px;height:18px;display:inline-block;vertical-align:-3px;fill:currentColor}

/* =====================
   Back to Top Button
   ===================== */
.back-to-top{
  position:fixed;bottom:2rem;right:2rem;width:50px;height:50px;
  border-radius:50%;background:var(--forest);color:#fff;border:none;
  cursor:pointer;box-shadow:var(--sh);transition:all 0.3s ease;
  z-index:1000;opacity:0;visibility:hidden
}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,0.15)}

/* =====================
   Footer
   ===================== */
footer{border-top:1px solid var(--bd);margin-top:3rem}

/* =====================
   Placeholder
   ===================== */
.ph{
  border-radius:var(--rad);position:relative;overflow:hidden;
  background:linear-gradient(135deg,#FEF3C7,#D1FAE5,#DBEAFE);
  min-height:260px;box-shadow:var(--sh);margin-left: unset;margin-right: unset;
}
.ph::after{
  content:attr(data-label);position:absolute;inset:0;
  display:grid;place-items:center;color:#334155;opacity:.85;font-weight:700
}

/* Google Maps iframe のクリックを可能にする */
.ph iframe {
  position: relative;
  z-index: 1;
  pointer-events: auto;
}

/* Google Maps 専用のクラス - ::after を非表示にしてiframeをクリック可能にする */
.ph.google-maps::after {
  display: none;
}

.ph.google-maps iframe {
  position: relative;
  z-index: 2;
  pointer-events: auto;
  width: 100%;
  height: 100%;
}

/* =====================
   Dark Theme Overrides
   ===================== */
[data-theme="dark"] .btn-ghost{
  border-color:#ffffff;color:#ffffff;background:rgba(255,255,255,.1)
}
[data-theme="dark"] .btn-ghost:hover{
  background:#ffffff;color:#000000
}
[data-theme="dark"] .btn-primary{
  background:var(--forest);color:#ffffff;border:1px solid rgba(255,255,255,.2)
}
[data-theme="dark"] .chip{
  background:#ffffff;color:#000000;border:1px solid rgba(255,255,255,.3);font-weight:900
}
[data-theme="dark"] .status-sold-out{background:#7f1d1d;color:#fca5a5;border:1px solid #991b1b}
[data-theme="dark"] .status-available{background:#1e3a8a;color:#93c5fd;border:1px solid #3730a3}
[data-theme="dark"] .alert-btn{color:#34d399}
[data-theme="dark"] .alert-btn:hover{color:#6ee7b7}
[data-theme="dark"] .feature-text-box {
  background: rgba(255,255,255,0.98);
  backdrop-filter: blur(15px);
  border: 1px solid rgba(255,255,255,0.2);
}
[data-theme="dark"] .tab{
  color:var(--ink);background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2)
}
[data-theme="dark"] .tab[aria-selected="true"]{
  color:#000000;background:#ffffff;border-color:#ffffff;font-weight:900
}
[data-theme="dark"] .step .num{
  background:#ffffff;color:#000000;font-weight:900;border:2px solid rgba(255,255,255,.3)
}

/* =====================
   Responsive Design
   ===================== */
/* =====================
   Responsive Design - Unified Breakpoints
   ===================== */

/* Desktop: 1025px and above */
@media (min-width: 1025px) {
  .nav-links{display:flex}
  .nav-acts{display:flex}
  .hamb{display:none}
  .mobile{display:none!important}
}

/* Tablet: 769px - 1024px */
@media (max-width: 1024px) and (min-width: 769px) {
  .grid-3,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sauna-comparison-tables{grid-template-columns:1fr 1fr !important;gap:1.5rem !important}
  .nav-links{display:flex}
  .nav-acts{display:flex}
  .hamb{display:none}
  .mobile{display:none!important}
}

/* Mobile: 768px and below */
@media (max-width: 768px) {
  .container{padding:2rem 16px}
  .main-content{padding-top:calc(60px + 2rem)}
  footer{margin-top:2rem}
  
  .head{flex-direction:column;align-items:flex-start;gap:1rem}
  .head > div:first-child{flex:none;width:100%}
  .head > div:last-child{flex:none;width:100%}
  .head .action-link{width:100%;text-align:center;padding:0.8rem 1rem;border-radius:12px;background:var(--card);color:var(--ink2);border:1px solid var(--bd);font-weight:600;transition:all 0.3s ease}
  .head .action-link:hover{background:color-mix(in hsl,var(--forest) 8%, transparent);color:var(--forest);border-color:var(--forest);transform:translateY(-1px)}
  
  /* Mobile header fix */
  header.sticky.is-fixed{
    position:fixed !important;top:0 !important;left:0 !important;right:0 !important;
    width:100% !important;z-index:9999 !important;
    transform:translateZ(0) !important;-webkit-transform:translateZ(0) !important;
  }
  
  .hamb{display:inline-grid !important}
  .nav-links{display:none}
  .nav-acts{display:none}
  
  /* All sections become single column at 768px and below */
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .sauna-comparison-tables{grid-template-columns:1fr !important;gap:1.5rem !important}
}

/* Mobile Small: 480px and below */
@media (max-width: 480px) {
  .container{padding:1.5rem 16px}
  .main-content{padding-top:calc(60px + 1.5rem)}
  footer{margin-top:1.5rem}
  
  .head{flex-direction:column;align-items:flex-start;gap:1rem}
  .head > div:first-child{flex:none;width:100%}
  .head > div:last-child{flex:none;width:100%}
  .head .action-link{width:100%;text-align:center;padding:0.8rem 1rem;border-radius:12px;background:var(--card);color:var(--ink2);border:1px solid var(--bd);font-weight:600;transition:all 0.3s ease}
  .head .action-link:hover{background:color-mix(in hsl,var(--forest) 8%, transparent);color:var(--forest);border-color:var(--forest);transform:translateY(-1px)}
  
  /* Mobile header fix */
  header.sticky.is-fixed{
    position:fixed !important;top:0 !important;left:0 !important;right:0 !important;
    width:100% !important;z-index:9999 !important;
    transform:translateZ(0) !important;-webkit-transform:translateZ(0) !important;
  }
  
  .hamb{display:inline-grid !important}
  .nav-links{display:none}
  .nav-acts{display:none}
  
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .sauna-comparison-tables{grid-template-columns:1fr !important;gap:1rem !important}
}

/* =====================
   Sauna Comparison Tables
   ===================== */
.sauna-comparison-tables .card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.15);
}

.sense-row:hover {
  background: linear-gradient(135deg, rgba(30, 86, 49, 0.05), rgba(30, 86, 49, 0.02));
  transform: translateX(4px);
}

.comparison-row:hover {
  background: linear-gradient(135deg, rgba(58, 124, 165, 0.05), rgba(58, 124, 165, 0.02));
  transform: translateX(4px);
}

.sense-row:hover .chip,
.comparison-row:hover .chip {
  transform: scale(1.05);
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.sauna-comparison-tables .chip {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.sauna-comparison-tables .chip:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(0,0,0,0.25);
}

/* =====================
   Common Modal Styles
   ===================== */

/* Event Modal Styles - High Specificity for Consistency */
#eventModal .panel,
.modal#eventModal .panel {
  border-radius: 24px !important;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  backdrop-filter: blur(20px) !important;
  animation: modalSlideIn 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

#eventModal .panel-head,
.modal#eventModal .panel-head {
  padding: 20px 24px !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
  background: rgba(255, 255, 255, 0.8) !important;
  backdrop-filter: blur(10px) !important;
}

#eventModal .panel-head strong,
.modal#eventModal .panel-head strong {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: rgba(255, 255, 255, 0.95) !important;
}

#eventModal .panel-body,
.modal#eventModal .panel-body {
  padding: 0 !important;
}

#eventModal .panel-body > .grid > div:last-child {
  padding: 24px !important;
}

#eventModal .btn,
.modal#eventModal .btn {
  border-radius: 12px !important;
  font-weight: 600 !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

#eventModal .btn-primary,
.modal#eventModal .btn-primary {
  background: linear-gradient(135deg, var(--forest), #2d5016) !important;
  border: none !important;
  color: #ffffff !important;
  box-shadow: 0 4px 14px rgba(30, 86, 49, 0.3) !important;
}

#eventModal .btn-primary:hover,
.modal#eventModal .btn-primary:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(30, 86, 49, 0.4) !important;
}

#eventModal .btn-ghost,
.modal#eventModal .btn-ghost {
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  background: rgba(255, 255, 255, 0.8) !important;
  color: var(--ink) !important;
}

#eventModal .btn-ghost:hover,
.modal#eventModal .btn-ghost:hover {
  background: rgba(0, 0, 0, 0.05) !important;
  transform: translateY(-1px) !important;
}

#eventModal .chip,
.modal#eventModal .chip {
  border-radius: 20px !important;
  padding: 6px 12px !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  background: rgba(30, 86, 49, 0.1) !important;
  color: var(--forest) !important;
  border: 1px solid rgba(30, 86, 49, 0.2) !important;
}

#eventModal h3,
.modal#eventModal h3 {
  font-size: 1.75rem !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  margin: 0.75rem 0 0 !important;
  color: var(--ink) !important;
}

#eventModal .muted,
.modal#eventModal .muted {
  font-size: 1rem !important;
  line-height: 1.5 !important;
  margin: 0.75rem 0 1.25rem !important;
  color: var(--ink2) !important;
}

#eventModal dl,
.modal#eventModal dl {
  background: rgba(0, 0, 0, 0.02) !important;
  border-radius: 12px !important;
  padding: 16px !important;
  margin-top: 1.5rem !important;
  display: grid !important;
  grid-template-columns: 120px 1fr !important;
  gap: 0.4rem !important;
  align-items: center !important;
}

#eventModal dt,
.modal#eventModal dt {
  font-weight: 600 !important;
  color: var(--ink2) !important;
  font-size: 0.9rem !important;
  text-align: left !important;
  padding-right: 0.5rem !important;
  margin: 0 !important;
}

#eventModal dt.muted,
.modal#eventModal dt.muted {
  font-weight: 600 !important;
  color: rgba(255, 255, 255, 0.95) !important;
  font-size: 0.9rem !important;
  text-align: left !important;
  padding-right: 0.5rem !important;
  margin: 0 !important;
}

#eventModal dd,
.modal#eventModal dd {
  color: rgba(255, 255, 255, 0.95) !important;
  font-weight: 500 !important;
  margin: 0 !important;
}

#eventModal .ph,
.modal#eventModal .ph {
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: linear-gradient(135deg, #f8fafc, #f1f5f9) !important;
  border-radius: 0 !important;
  border: none !important;
  overflow: hidden !important;
  display: block !important;
}

#eventModal .ph img,
.modal#eventModal .ph img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 0 !important;
}

/* Content Modal Styles (Camp, Menu, Vegetable) */
.content-modal-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 500px;
  max-height: 80vh;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 0;
  overflow: hidden;
}

.content-modal-images {
  position: relative;
  background: #f8fafc;
  overflow: hidden;
  height: 100%;
  max-height: 100%;
  border-radius: 0;
}

.content-modal-info {
  padding: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow-y: auto;
  margin-top: 0;
  position: relative;
  z-index: 1;
  border-left: 1px solid rgba(0, 0, 0, 0.1);
}

.content-modal-info h3 {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0 0 1rem;
  color: var(--ink);
}

.content-modal-info p {
  color: var(--ink2);
  line-height: 1.6;
  margin: 0 0 1.5rem;
}

.content-modal-info .btn {
  margin-top: auto;
}

/* =====================
   Universal Slideshow Styles
   ===================== */
.camp-slideshow,
.menu-slideshow,
.bbq-set-slideshow {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: inherit;
}

.camp-slides,
.menu-slides,
.bbq-set-slides {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
}

.camp-slide,
.menu-slide,
.bbq-set-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
  display: flex;
  align-items: center;
  justify-content: center;
}

.camp-slide.active,
.menu-slide.active,
.bbq-set-slide.active {
  opacity: 1;
}

.camp-slide img,
.menu-slide img,
.bbq-set-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 0;
}

/* Slide Navigation Buttons */
.slide-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9) !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  backdrop-filter: blur(8px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  color: var(--ink) !important;
}

.slide-nav:hover {
  background: rgba(255, 255, 255, 1) !important;
  transform: translateY(-50%) scale(1.05);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  color: var(--ink) !important;
}

.slide-nav:active {
  transform: translateY(-50%) scale(0.95);
}

.slide-prev {
  left: 16px;
}

.slide-next {
  right: 16px;
}

.slide-nav .icon {
  width: 20px;
  height: 20px;
  stroke: var(--ink) !important;
  stroke-width: 2;
  color: var(--ink) !important;
}

/* CAFE STOVE Text Slide Styles */
.stave-text-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--washi);
  padding: 2rem;
}

.stave-text-content {
  text-align: center;
  max-width: 700px;
  width: 90%;
}

.stave-text-title {
  font-size: 1.8rem;
  color: var(--ink);
  display: block;
  margin-bottom: 1rem;
  font-weight: bold;
}

.stave-text-description {
  margin: 0;
  color: var(--ink2);
  line-height: 1.6;
  font-size: 1.1rem;
}

/* Slide Indicators */
.slide-indicators,
.camp-indicators,
#bbqSetSlideIndicators {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}

.slide-indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(0, 0, 0, 0.1);
  cursor: pointer;
  transition: all 0.2s ease;
  padding: 0;
}

.slide-indicator.active {
  background: rgba(255, 255, 255, 1);
  transform: scale(1.2);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.slide-indicator:hover {
  background: rgba(255, 255, 255, 0.8);
  transform: scale(1.1);
}

/* Dynamic Background for Content Modals */
.modal.dynamic-bg .content-modal-images {
  background: color-mix(in hsl, var(--modal-bg-color) 90%, black);
}

.modal.dynamic-bg .content-modal-info {
  background: linear-gradient(135deg, var(--modal-bg-color), color-mix(in hsl, var(--modal-bg-color) 85%, black));
  position: relative;
}

.modal.dynamic-bg .content-modal-info::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.2);
  backdrop-filter: blur(2px);
  z-index: 1;
}

.modal.dynamic-bg .content-modal-info > * {
  position: relative;
  z-index: 2;
}

/* =====================
   Animations
   ===================== */
@keyframes modalSlideIn {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* Event Modal Responsive Styles - High Specificity for Consistency */
@media (max-width: 768px) {
  #eventModal .panel,
  .modal#eventModal .panel {
    max-width: 95vw !important;
    margin: 0 !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
  }
  
  #eventModal .panel-body,
  .modal#eventModal .panel-body {
    padding: 0 !important;
  }
  
  #eventModal .panel-body > .grid > div:last-child {
    padding: 1rem !important;
  }
  
  #eventModal .grid,
  .modal#eventModal .grid {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }
  
  #eventModal .ph,
  .modal#eventModal .ph {
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9) !important;
    border-radius: 0 !important;
    border: none !important;
    overflow: hidden !important;
    display: block !important;
  }
  
  #eventModal .ph img,
  .modal#eventModal .ph img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 0 !important;
  }
  
  #eventModal h3,
  .modal#eventModal h3 {
    font-size: 1.4rem !important;
    margin: 0.5rem 0 0 !important;
  }
  
  #eventModal .muted,
  .modal#eventModal .muted {
    font-size: 0.9rem !important;
    margin: 0.5rem 0 0.8rem !important;
  }
  
  #eventModal .btn,
  .modal#eventModal .btn {
    padding: 0.6rem 1rem !important;
    font-size: 0.9rem !important;
    min-width: auto !important;
  }
  
  #eventModal dl,
  .modal#eventModal dl {
    grid-template-columns: 80px 1fr !important;
    gap: 0.3rem !important;
    margin-top: 0.8rem !important;
    font-size: 0.9rem !important;
  }
  
  #eventModal dt,
  .modal#eventModal dt {
    font-size: 0.8rem !important;
    color: var(--ink2) !important;
  }
  
  #eventModal dt.muted,
  .modal#eventModal dt.muted {
    color: rgba(255, 255, 255, 0.95) !important;
  }
  
  #eventModal dd,
  .modal#eventModal dd {
    font-size: 0.9rem !important;
    color: rgba(255, 255, 255, 0.95) !important;
  }
}

@media (max-width: 480px) {
  #eventModal .panel,
  .modal#eventModal .panel {
    max-width: 98vw !important;
    margin: 0 !important;
    max-height: 95vh !important;
  }
  
  #eventModal .panel-head,
  .modal#eventModal .panel-head {
    padding: 12px 14px !important;
  }
  
  #eventModal .panel-body,
  .modal#eventModal .panel-body {
    padding: 0 !important;
  }
  
  #eventModal .panel-body > .grid > div:last-child {
    padding: 0.8rem !important;
  }
  
  #eventModal .ph,
  .modal#eventModal .ph {
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9) !important;
    border-radius: 0 !important;
    border: none !important;
    overflow: hidden !important;
    display: block !important;
  }
  
  #eventModal .ph img,
  .modal#eventModal .ph img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 0 !important;
  }
  
  #eventModal h3,
  .modal#eventModal h3 {
    font-size: 1.2rem !important;
    line-height: 1.2 !important;
  }
  
  #eventModal .btn,
  .modal#eventModal .btn {
    padding: 0.5rem 0.8rem !important;
    font-size: 0.85rem !important;
    width: 100% !important;
    margin-bottom: 0.5rem !important;
  }
  
  #eventModal .btn:last-child,
  .modal#eventModal .btn:last-child {
    margin-bottom: 0 !important;
  }
  
  #eventModal dl,
  .modal#eventModal dl {
    grid-template-columns: 1fr !important;
    gap: 0.2rem !important;
    margin-top: 0.6rem !important;
  }
  
  #eventModal dt,
  .modal#eventModal dt {
    font-weight: 600 !important;
    margin-bottom: 0.1rem !important;
    color: var(--ink2) !important;
  }
  
  #eventModal dt.muted,
  .modal#eventModal dt.muted {
    color: rgba(255, 255, 255, 0.95) !important;
  }
  
  #eventModal dd,
  .modal#eventModal dd {
    margin-bottom: 0.3rem !important;
    padding-left: 0.5rem !important;
    color: rgba(255, 255, 255, 0.95) !important;
  }
}

/* Content Modal Responsive Styles */
@media (max-width: 768px) {
  .content-modal-content {
    grid-template-columns: 1fr;
    grid-template-rows: 350px 1fr;
    min-height: auto;
    max-height: 90vh;
    border-radius: 0;
  }
  
  .content-modal-images {
    min-height: 350px;
    height: 350px;
    max-height: 350px;
    border-radius: 0;
  }
  
  .content-modal-info {
    padding: 1.5rem;
    max-height: calc(90vh - 350px);
    overflow-y: auto;
    margin-top: 0;
    position: relative;
    z-index: 1;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
    border-left: none;
  }
  
  /* Slide navigation adjustments for mobile */
  .slide-nav {
    width: 40px;
    height: 40px;
  }
  
  .slide-nav .icon {
    width: 16px;
    height: 16px;
  }
  
  .slide-prev {
    left: 12px;
  }
  
  .slide-next {
    right: 12px;
  }
  
  .slide-indicators,
  .camp-indicators,
  #bbqSetSlideIndicators {
    bottom: 12px;
  }
  
  .slide-indicator {
    width: 6px;
    height: 6px;
  }
}

/* Universal Modal Responsive Styles for All Modals */
@media (max-width: 768px) {
  /* All modals - base responsive styles */
  .modal {
    padding: 0.5rem !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  .modal .panel {
    max-width: 95vw !important;
    margin: 0 !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    width: 100% !important;
    /* Smooth scrolling */
    scroll-behavior: smooth !important;
    /* Custom scrollbar for webkit browsers */
    scrollbar-width: thin !important;
    scrollbar-color: rgba(0, 0, 0, 0.3) transparent !important;
  }
  
  /* Webkit scrollbar styling */
  .modal .panel::-webkit-scrollbar {
    width: 6px !important;
  }
  
  .modal .panel::-webkit-scrollbar-track {
    background: transparent !important;
  }
  
  .modal .panel::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.3) !important;
    border-radius: 3px !important;
  }
  
  .modal .panel::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.5) !important;
  }
  
  /* News Modal specific styles */
  #newsModal .panel,
  .modal#newsModal .panel {
    max-width: 95vw !important;
    margin: 0 !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
  }
  
  #newsModal .panel-body,
  .modal#newsModal .panel-body {
    padding: 1rem !important;
  }
  
  /* Content Modals (Camp, Menu, Vegetable, BBQ Set) specific styles */
  #campModal .panel,
  .modal#campModal .panel,
  #menuModal .panel,
  .modal#menuModal .panel,
  #vegetableModal .panel,
  .modal#vegetableModal .panel,
  #bbqSetModal .panel,
  .modal#bbqSetModal .panel {
    max-width: 95vw !important;
    margin: 0 !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
  }
  
  #campModal .panel-body,
  .modal#campModal .panel-body,
  #menuModal .panel-body,
  .modal#menuModal .panel-body,
  #vegetableModal .panel-body,
  .modal#vegetableModal .panel-body,
  #bbqSetModal .panel-body,
  .modal#bbqSetModal .panel-body {
    padding: 0 !important;
  }
  
  /* Content modal layout adjustments for mobile */
  #campModal .content-modal-content,
  .modal#campModal .content-modal-content,
  #menuModal .content-modal-content,
  .modal#menuModal .content-modal-content,
  #vegetableModal .content-modal-content,
  .modal#vegetableModal .content-modal-content,
  #bbqSetModal .content-modal-content,
  .modal#bbqSetModal .content-modal-content,
  .modal#chefModal .content-modal-content {
    grid-template-columns: 1fr !important;
    grid-template-rows: 350px 1fr !important;
    max-height: 90vh !important;
    min-height: auto !important;
  }
  
  #campModal .content-modal-images,
  .modal#campModal .content-modal-images,
  #menuModal .content-modal-images,
  .modal#menuModal .content-modal-images,
  #vegetableModal .content-modal-images,
  .modal#vegetableModal .content-modal-images,
  #bbqSetModal .content-modal-images,
  .modal#bbqSetModal .content-modal-images,
  .modal#chefModal .content-modal-images {
    min-height: 350px !important;
    max-height: 350px !important;
    height: 350px !important;
    border-radius: 0 !important;
  }
  
  #campModal .content-modal-info,
  .modal#campModal .content-modal-info,
  #menuModal .content-modal-info,
  .modal#menuModal .content-modal-info,
  #vegetableModal .content-modal-info,
  .modal#vegetableModal .content-modal-info,
  #bbqSetModal .content-modal-info,
  .modal#bbqSetModal .content-modal-info,
  .modal#chefModal .content-modal-info {
    padding: 1.5rem !important;
    overflow-y: auto !important;
    max-height: calc(90vh - 350px) !important;
    margin-top: 0 !important;
    position: relative !important;
    z-index: 1 !important;
    border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
    border-left: none !important;
  }
}

@media (max-width: 480px) {
  /* Extra small screens - further optimization */
  .modal {
    padding: 0.25rem !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  .modal .panel {
    max-width: 98vw !important;
    max-height: 95vh !important;
  }
  
  /* Content modal adjustments for very small screens */
  .content-modal-content {
    grid-template-rows: 240px 1fr !important;
    max-height: 95vh !important;
    border-radius: 0 !important;
  }
  
  .content-modal-images {
    min-height: 240px !important;
    max-height: 240px !important;
    height: 240px !important;
    border-radius: 0 !important;
  }
  
  .content-modal-info {
    padding: 1rem !important;
    max-height: calc(95vh - 240px) !important;
    margin-top: 0 !important;
    position: relative !important;
    z-index: 1 !important;
    border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
    border-left: none !important;
  }
  
  #campModal .content-modal-content,
  .modal#campModal .content-modal-content,
  #menuModal .content-modal-content,
  .modal#menuModal .content-modal-content,
  #vegetableModal .content-modal-content,
  .modal#vegetableModal .content-modal-content,
  #bbqSetModal .content-modal-content,
  .modal#bbqSetModal .content-modal-content,
  .modal#chefModal .content-modal-content {
    grid-template-rows: 300px 1fr !important;
    max-height: 95vh !important;
  }
  
  #campModal .content-modal-images,
  .modal#campModal .content-modal-images,
  #menuModal .content-modal-images,
  .modal#menuModal .content-modal-images,
  #vegetableModal .content-modal-images,
  .modal#vegetableModal .content-modal-images,
  #bbqSetModal .content-modal-images,
  .modal#bbqSetModal .content-modal-images,
  .modal#chefModal .content-modal-images {
    min-height: 300px !important;
    max-height: 300px !important;
    height: 300px !important;
    border-radius: 0 !important;
  }
  
  #campModal .content-modal-info,
  .modal#campModal .content-modal-info,
  #menuModal .content-modal-info,
  .modal#menuModal .content-modal-info,
  #vegetableModal .content-modal-info,
  .modal#vegetableModal .content-modal-info,
  #bbqSetModal .content-modal-info,
  .modal#bbqSetModal .content-modal-info,
  .modal#chefModal .content-modal-info {
    padding: 1rem !important;
    max-height: calc(95vh - 300px) !important;
    margin-top: 0 !important;
    position: relative !important;
    z-index: 1 !important;
    border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
    border-left: none !important;
  }
  
  /* Slide navigation adjustments for very small screens */
  .slide-nav {
    width: 36px;
    height: 36px;
  }
  
  .slide-nav .icon {
    width: 14px;
    height: 14px;
  }
  
  .slide-prev {
    left: 8px;
  }
  
  .slide-next {
    right: 8px;
  }
  
  .slide-indicators,
  .camp-indicators,
  #bbqSetSlideIndicators {
    bottom: 8px;
  }
  
  .slide-indicator {
    width: 5px;
    height: 5px;
  }
}

/* =====================
   Instagram Selection Modal
   ===================== */
.instagram-account-btn {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem;
  background: var(--card);
  border: 1px solid var(--bd);
  border-radius: var(--rad);
  text-align: left;
  transition: all 0.2s ease;
  cursor: pointer;
  width: 100%;
}

.instagram-account-btn:hover {
  background: var(--forest);
  color: var(--washi);
  transform: translateY(-2px);
  box-shadow: var(--sh);
}

.instagram-account-btn:focus {
  outline: 2px solid var(--orange);
  outline-offset: 2px;
}

.instagram-account-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background: var(--washi);
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.instagram-account-btn:hover .instagram-account-icon {
  background: var(--washi);
}

.instagram-account-info h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 0.25rem;
  color: inherit;
}

.instagram-account-info p {
  font-size: 0.9rem;
  margin: 0;
  opacity: 0.8;
  color: inherit;
}

.instagram-account-btn:hover .instagram-account-info h3,
.instagram-account-btn:hover .instagram-account-info p {
  color: var(--washi);
}

/* Mobile responsive for Instagram modal */
@media (max-width: 768px) {
  .instagram-account-btn {
    padding: 1rem;
    gap: 0.75rem;
  }
  
  .instagram-account-icon {
    width: 40px;
    height: 40px;
  }
  
  .instagram-account-info h3 {
    font-size: 1rem;
  }
  
  .instagram-account-info p {
    font-size: 0.85rem;
  }
  
  /* モバイル時は縦並びに変更 */
  .panel-body > div {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 480px) {
  .instagram-account-btn {
    flex-direction: column;
    text-align: center;
    padding: 1.25rem;
  }
  
  .instagram-account-icon {
    width: 48px;
    height: 48px;
  }
}

/* Motion reduce */
@media (prefers-reduced-motion: reduce) {
  .reveal{transition:none!important;opacity:1!important;transform:none!important}
  .instagram-account-btn{transition:none!important;transform:none!important}
}