/* Art Werkx — full site CSS extracted from v9 */


/* ═══════════════════════════════════════════════
   TOKENS
═══════════════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg0:#f7f2ea; --bg1:#f2ebe0; --bg2:#ede4d6; --bg3:#e6dac8;
  --ink:#2c2418; --ink2:#5a4a35; --ink3:#8a7560; --ink4:#b8a48c;
  --gold:#b8813a; --gold-lt:#d4a55e; --gold-pale:#e8cfa0;
  --gold-wash:rgba(184,129,58,0.08); --gold-border:rgba(184,129,58,0.22);
  --sage:#7a8c72; --sage-pale:rgba(122,140,114,0.12);
  --radius-sm:8px; --radius-md:14px; --radius-lg:22px;
  --border:1px solid var(--gold-border);
  --side:clamp(1.5rem,5vw,5rem); --max:1120px; --gap:1.5rem;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
  --t:0.22s ease;
}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{background:var(--bg1);color:var(--ink);font-family:var(--serif);overflow-x:hidden;}
img,video{display:block;width:100%;object-fit:cover;}
a{color:inherit;text-decoration:none;}

/* ═══════════════════════════════════════════════
   UTILITIES
═══════════════════════════════════════════════ */
.inner{max-width:var(--max);margin:0 auto;padding:0 var(--side);}
.label{font-family:var(--sans);font-size:10px;letter-spacing:0.26em;text-transform:uppercase;color:var(--gold);opacity:0.8;}
.btn-gold{display:inline-block;font-family:var(--sans);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;padding:13px 32px;border-radius:100px;border:none;background:var(--gold);color:#fff;cursor:pointer;transition:background var(--t),transform var(--t);}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-1px);}
.btn-ghost{display:inline-block;font-family:var(--sans);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;padding:12px 30px;border-radius:100px;border:1px solid rgba(184,129,58,0.4);background:transparent;color:var(--gold);cursor:pointer;transition:all var(--t);}
.btn-ghost:hover{background:var(--gold-wash);border-color:var(--gold);}
.divider{width:44px;height:1px;background:var(--gold-pale);margin:1.25rem 0;}
.sec{padding:5.5rem 0;} .sec.alt{background:var(--bg2);} .sec.deep{background:var(--bg3);}
.sec-title{font-size:clamp(1.85rem,3.5vw,2.9rem);font-weight:300;line-height:1.15;color:var(--ink);margin-bottom:0.5rem;}
.sec-title em{font-style:italic;color:var(--gold);}
.sec-body{font-size:1.05rem;color:var(--ink2);line-height:1.85;font-style:normal;max-width:520px;}
.fu{opacity:0;transform:translateY(22px);transition:opacity 0.65s ease,transform 0.65s ease;}
.fu.d1{transition-delay:.1s;} .fu.d2{transition-delay:.18s;} .fu.d3{transition-delay:.26s;} .fu.d4{transition-delay:.34s;}
.fu.on{opacity:1;transform:none;}

/* ═══════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:0 var(--side);height:64px;display:flex;align-items:center;justify-content:space-between;background:transparent;border-bottom:1px solid transparent;transition:background 0.4s,border-color 0.4s;}
.nav.pinned{background:rgba(242,235,224,0.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:var(--gold-border);}
.nav-logo{display:flex;align-items:center;cursor:pointer;}
.nav-logo img{height:38px;width:auto;display:block;transition:filter 0.35s ease;}
.nav.pinned .nav-logo img{filter:brightness(0) sepia(1) saturate(3) hue-rotate(5deg) brightness(0.42);}

.nav-wordmark{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--ink);letter-spacing:0.04em;}
.nav-sub{font-family:var(--sans);font-size:8.5px;letter-spacing:0.28em;text-transform:uppercase;color:var(--gold);margin-top:1px;}
.nav-links{display:flex;align-items:center;gap:0;}
.nav-link{font-family:var(--sans);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink2);padding:6px 14px;border-radius:100px;cursor:pointer;transition:all var(--t);background:transparent;border:none;}
.nav-link:hover{color:var(--gold);}
.nav-link.active{color:var(--gold);background:rgba(184,129,58,0.08);}
.nav-cta{font-family:var(--sans);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;padding:8px 20px;border-radius:100px;border:1px solid rgba(184,129,58,0.5);color:var(--gold);background:transparent;cursor:pointer;transition:all var(--t);}
.nav-cta:hover{background:var(--gold);color:#fff;}
/* mobile hamburger */
.nav-ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;}
.nav-ham span{display:block;width:22px;height:1.5px;background:var(--ink2);border-radius:2px;transition:all var(--t);}
.mob-menu{display:none;position:fixed;top:64px;left:0;right:0;background:rgba(242,235,224,0.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--gold-border);z-index:199;padding:1rem var(--side) 1.5rem;flex-direction:column;gap:0.25rem;}
.mob-menu.open{display:flex;}
.mob-link{font-family:var(--sans);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink2);padding:0.75rem 0;border-bottom:1px solid rgba(184,129,58,0.08);cursor:pointer;background:none;border-left:none;border-right:none;border-top:none;text-align:left;width:100%;transition:color var(--t);}
.mob-link:last-child{border-bottom:none;}
.mob-link:hover,.mob-link.active{color:var(--gold);}
@media(max-width:860px){.nav-links{display:none;}.nav-ham{display:flex;}}

/* ═══════════════════════════════════════════════
   PAGE SYSTEM — JS-driven multi-page
═══════════════════════════════════════════════ */
.page{display:none;}
.page.active{display:block;}

/* ═══════════════════════════════════════════════
   PAGE BANNER — every page has its own hero
═══════════════════════════════════════════════ */
/* OLD BANNER CSS REMOVED - see new banner below */





















/* ═══════════════════════════════════════════════
   PROMISE STRIP
═══════════════════════════════════════════════ */
.promise{background:var(--bg3);border-top:1px solid rgba(184,129,58,0.15);border-bottom:1px solid rgba(184,129,58,0.15);}
.promise-inner{display:grid;grid-template-columns:repeat(3,1fr);max-width:var(--max);margin:0 auto;}
.promise-cell{padding:1.75rem var(--side);text-align:center;position:relative;}
.promise-cell+.promise-cell::before{content:'';position:absolute;left:0;top:25%;bottom:25%;width:1px;background:rgba(184,129,58,0.18);}
.promise-icon{font-size:20px;margin-bottom:0.6rem;opacity:0.55;}
.promise-word{font-size:1.05rem;color:var(--ink);font-weight:400;margin-bottom:3px;}
.promise-sub{font-family:var(--sans);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold);opacity:0.75;}
@media(max-width:600px){.promise-inner{grid-template-columns:1fr;}.promise-cell+.promise-cell::before{top:0;bottom:auto;left:25%;right:25%;width:auto;height:1px;}}

/* ═══════════════════════════════════════════════
   STORY
═══════════════════════════════════════════════ */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.story-photo{border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4/5;background:var(--bg3);position:relative;}
.story-photo::after{content:'';position:absolute;inset:0;border-radius:var(--radius-md);box-shadow:inset 0 0 0 1px var(--gold-border);}
.story-photo-ph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.6rem;color:var(--ink4);font-family:var(--sans);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;}
.story-photo-ph svg{width:36px;height:36px;fill:var(--ink4);opacity:0.5;}
.story-quote{font-size:clamp(1.2rem,2.2vw,1.6rem);font-weight:300;font-style:italic;color:var(--gold);line-height:1.5;margin-bottom:1.25rem;}
.story-pillars{margin-top:2rem;display:flex;flex-direction:column;gap:0.9rem;}
.story-pillar{display:flex;align-items:flex-start;gap:0.9rem;}
.pillar-tick{width:18px;height:18px;border-radius:50%;border:1px solid var(--gold-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:3px;}
.pillar-tick::after{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);}
.pillar-text{font-size:0.95rem;color:var(--ink2);line-height:1.65;font-style:italic;}
.pillar-text strong{font-style:normal;font-weight:500;color:var(--ink);}
@media(max-width:780px){.story-grid{grid-template-columns:1fr;gap:2.5rem;}}

/* ═══════════════════════════════════════════════
   DUAL SPARK ENTRY
═══════════════════════════════════════════════ */
#spark-entry-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;}
@media(max-width:720px){#spark-entry-grid{grid-template-columns:1fr;}#spark-entry-grid>div:first-child{border-right:none!important;border-bottom:1px solid var(--gold-border);}}

/* ═══════════════════════════════════════════════
   SPARKS APP SHELL
═══════════════════════════════════════════════ */
.app-shell{background:var(--bg1);}
.app-hero-strip{text-align:center;padding:3.5rem var(--side) 0;max-width:var(--max);margin:0 auto;}
.as-sec{margin-bottom:2.5rem;text-align:center;}
#all-sparks-content{max-width:var(--max);margin:0 auto;padding:0 var(--side);}
.app-hero-label{font-family:var(--sans);font-size:10px;letter-spacing:0.28em;text-transform:uppercase;color:var(--gold);opacity:0.8;margin-bottom:0.9rem;}
.app-hero-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:300;color:var(--ink);margin-bottom:0.5rem;}
.app-hero-sub{font-size:1.05rem;color:var(--ink2);font-style:italic;line-height:1.7;margin-bottom:0.25rem;}
.app-all-sparks{font-family:var(--sans);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;padding:8px 20px;border-radius:100px;border:1px solid rgba(184,129,58,0.35);background:transparent;color:var(--gold);cursor:pointer;transition:all var(--t);margin-top:1.25rem;display:inline-block;}
.app-all-sparks:hover{background:var(--gold-wash);}
.view{display:none;padding:2.5rem 0 4rem;}
.view.active{display:block;}
.wrap-inner{padding:0 var(--side);}
.card-frame{width:min(620px,100%);} .card-frame.centered{margin:0 auto;}
.page-question{font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:300;color:var(--ink);margin-bottom:0.5rem;text-align:center;}
.page-nudge{font-family:var(--sans);font-size:12px;color:var(--ink3);text-align:center;margin-bottom:2rem;letter-spacing:0.04em;}
.breadcrumb{text-align:center;font-family:var(--sans);font-size:11px;color:var(--gold);letter-spacing:0.08em;margin-bottom:1.75rem;min-height:18px;opacity:0.7;}
.bc-sep{margin:0 8px;opacity:0.4;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;}
@media(max-width:580px){.grid-2{grid-template-columns:1fr;}}

/* Universal Card */
.uc{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;position:relative;transition:border-color var(--t),transform var(--t),box-shadow var(--t),background var(--t);display:flex;flex-direction:column;box-shadow:0 2px 8px rgba(44,36,24,0.04);}
.uc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:transparent;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:background var(--t);}
.uc:hover{border-color:rgba(184,129,58,0.55);transform:translateY(-3px);box-shadow:0 6px 20px rgba(184,129,58,0.12);}
.uc:hover::before{background:var(--gold);}
.uc.selected{border-color:var(--gold);background:rgba(184,129,58,0.04);}
.uc.selected::before{background:var(--gold);}
.uc.flash{border-color:var(--gold);background:rgba(184,129,58,0.08);box-shadow:0 0 0 3px rgba(184,129,58,0.2);transform:translateY(-2px);}
.uc.flash::before{background:var(--gold);}
.uc-body{padding:0.85rem 1.4rem 0.9rem;}
.uc-tag{font-family:var(--sans);font-size:9.5px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);opacity:0.75;margin-bottom:0.35rem;}
.uc-name{font-size:1.15rem;font-weight:400;color:var(--ink);margin-bottom:0.3rem;line-height:1.25;}
.uc-feel{font-size:0.9rem;color:var(--gold-lt);font-style:italic;margin-bottom:0.5rem;}
.uc-desc{display:none;}
.uc-img{width:100%;height:clamp(160px,30vw,220px);background:var(--bg2);border-top:1px solid rgba(184,129,58,0.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.uc-img-ph{font-family:var(--sans);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink4);}
.bottom-nav{display:flex;align-items:center;gap:0.9rem;margin-top:2.5rem;padding:0 var(--side);}
.nav-btn{font-family:var(--sans);font-size:12px;letter-spacing:0.08em;color:var(--ink2);background:transparent;border:1px solid rgba(184,129,58,0.3);border-radius:100px;cursor:pointer;padding:9px 20px;transition:all var(--t);}
.nav-btn:hover{color:var(--gold);border-color:var(--gold);}
.nav-btn.ghost{color:var(--ink4);border-color:rgba(184,129,58,0.15);}
.nav-btn.ghost:hover{color:var(--ink3);border-color:rgba(184,129,58,0.3);}

/* Sip & Mess */
.sip-header{text-align:center;margin-bottom:2.5rem;}
.sip-title{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:300;color:var(--ink);margin-bottom:0.4rem;}
.sip-sub{font-size:1rem;color:var(--ink2);font-style:italic;}
.arc-strip{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--gold-border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:2rem;background:#fff;}
@media(max-width:480px){.arc-strip{grid-template-columns:1fr;}.arc-cell{border-right:none;border-bottom:1px solid var(--gold-border);}.arc-cell:last-child{border-bottom:none;}.arc-arr{display:none;}}
.arc-cell{padding:1.4rem 1rem;border-right:1px solid var(--gold-border);text-align:center;position:relative;}
.arc-cell:last-child{border-right:none;}
.arc-ep{font-family:var(--sans);font-size:8.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink4);margin-bottom:0.4rem;}
.arc-word{font-size:1.1rem;color:var(--ink);margin-bottom:0.25rem;}
.arc-sub{font-size:0.85rem;color:var(--gold-lt);font-style:italic;}
.arc-arr{position:absolute;right:-10px;top:50%;transform:translateY(-50%);width:19px;height:19px;background:var(--bg1);border:1px solid var(--gold-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--gold);z-index:2;}
.ep{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-sm);margin-bottom:10px;overflow:hidden;cursor:pointer;position:relative;transition:border-color var(--t);box-shadow:0 1px 4px rgba(44,36,24,0.04);}
.ep::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.ep-1::before{background:linear-gradient(90deg,transparent,rgba(184,129,58,0.35),transparent);}
.ep-2::before{background:linear-gradient(90deg,transparent,rgba(184,129,58,0.65),transparent);}
.ep-3::before{background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.ep:hover{border-color:rgba(184,129,58,0.45);}
.ep-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.35rem;}
.ep-num{font-family:var(--sans);font-size:10px;letter-spacing:0.12em;color:var(--gold);opacity:0.6;flex-shrink:0;}
.ep-head-text{flex:1;}
.ep-name{font-size:0.95rem;color:var(--ink);margin-bottom:2px;}
.ep-feel{font-size:1rem;color:var(--ink2);font-style:italic;}
.ep-icon{font-size:18px;opacity:0.5;}
.ep-chevron{font-size:9px;color:var(--ink4);transition:transform 0.3s;}
.ep.open .ep-chevron{transform:rotate(180deg);}
.ep-body{max-height:0;overflow:hidden;transition:max-height 0.45s ease;}
.ep.open .ep-body{max-height:520px;}
.ep-body-inner{padding:1.25rem;border-top:1px solid var(--gold-border);display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
@media(max-width:580px){.ep-body-inner{grid-template-columns:1fr;}}
.ep-img{grid-column:1/-1;height:120px;background:var(--bg2);border:1px dashed rgba(184,129,58,0.2);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;overflow:hidden;}
.ep-img-label{font-family:var(--sans);font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink4);}
.ep-desc{font-size:1rem;color:var(--ink2);line-height:1.8;font-style:italic;}
.ep-reveal-box{background:rgba(184,129,58,0.06);border:1px solid rgba(184,129,58,0.18);border-radius:6px;padding:0.9rem;display:flex;flex-direction:column;justify-content:center;}
.ep-reveal-label{font-family:var(--sans);font-size:8.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink4);margin-bottom:0.3rem;}
.ep-reveal-text{font-size:1rem;color:var(--ink);line-height:1.6;font-style:italic;}
.dinner-note{grid-column:1/-1;display:flex;align-items:center;gap:0.65rem;padding:0.75rem 0.9rem;border:1px solid rgba(184,129,58,0.18);border-radius:6px;background:rgba(122,140,114,0.07);}
.dinner-note-bar{width:3px;min-height:26px;border-radius:2px;background:var(--sage);opacity:0.7;flex-shrink:0;}
.dinner-note-text{font-size:1rem;color:var(--sage);font-style:italic;line-height:1.6;}
.sip-cta{text-align:center;margin-top:1.75rem;}
.p3-header{text-align:center;margin-bottom:2rem;}
.p3-title{font-size:clamp(1.3rem,2.5vw,1.9rem);font-weight:300;color:var(--ink);line-height:1.2;margin-bottom:0.5rem;}
.p3-title em{font-style:italic;color:var(--gold);}
.p3-sub-text{font-size:0.95rem;color:var(--ink3);font-style:italic;line-height:1.75;}
.reserve-card-wrap{width:min(520px,100%);margin:0 auto;padding:0 0.25rem;}
.reserve-card{background:#fff;border:1px solid rgba(184,129,58,0.3);border-radius:var(--radius-md);overflow:hidden;position:relative;box-shadow:0 4px 18px rgba(44,36,24,0.07);}
.reserve-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);}
.reserve-card-top{padding:1.6rem 1.75rem 1.25rem;}
.rc-line1{font-family:var(--sans);font-size:9.5px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);opacity:0.7;margin-bottom:0.55rem;}
.rc-line2{font-size:1.25rem;font-weight:400;color:var(--ink);margin-bottom:0.25rem;}
.rc-line3{font-size:0.88rem;color:var(--ink3);font-style:italic;}
.rc-episodes{border-top:1px solid rgba(184,129,58,0.15);}
.rc-ep{display:flex;align-items:center;gap:1rem;padding:0.9rem 1.75rem;border-bottom:1px solid rgba(184,129,58,0.1);cursor:pointer;transition:background var(--t);}
.rc-ep:last-child{border-bottom:none;}
.rc-ep:hover{background:rgba(184,129,58,0.04);}
.rc-ep.selected{background:rgba(184,129,58,0.07);}
.rc-ep-num{font-family:var(--sans);font-size:10px;color:var(--gold);opacity:0.55;width:22px;flex-shrink:0;}
.rc-ep-body{flex:1;}
.rc-ep-name{font-size:0.95rem;color:var(--ink);margin-bottom:2px;}
.rc-ep-tag{font-size:0.8rem;color:var(--gold-lt);font-style:italic;}
.rc-ep-check{width:18px;height:18px;border-radius:50%;border:1px solid rgba(184,129,58,0.3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;transition:all var(--t);}
.rc-ep.selected .rc-ep-check{background:var(--gold);border-color:var(--gold);color:#fff;}
.rc-ep.full-journey{background:rgba(184,129,58,0.03);}
.rc-ep.full-journey .rc-ep-name{color:var(--gold);}
.rc-ep.full-journey.selected{background:rgba(184,129,58,0.1);}
.rc-cta{padding:1.5rem 1.75rem;text-align:center;}
.btn-reserve-single{font-family:var(--sans);font-size:13px;letter-spacing:0.12em;text-transform:uppercase;padding:13px 36px;border-radius:100px;border:none;background:var(--gold);color:#fff;cursor:pointer;transition:all var(--t);opacity:0.35;}
.btn-reserve-single.active{opacity:1;}
.btn-reserve-single.active:hover{background:var(--gold-lt);}
.p3-note{font-size:0.82rem;color:var(--ink4);font-style:italic;margin:1.25rem 0;text-align:center;}
.p3-philosophy{border-top:1px solid rgba(184,129,58,0.15);padding-top:1.25rem;font-family:var(--sans);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink4);text-align:center;width:min(480px,100%);margin:0 auto;}
.hero-card{background:#fff;border:1px solid rgba(184,129,58,0.25);border-radius:var(--radius-md);padding:2rem 2.5rem;margin-bottom:1.5rem;text-align:center;position:relative;overflow:hidden;box-shadow:0 4px 18px rgba(44,36,24,0.06);}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);}
.hero-tag{font-family:var(--sans);font-size:9.5px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);opacity:0.75;margin-bottom:0.75rem;}
.hero-name{font-size:1.7rem;font-weight:400;color:var(--ink);margin-bottom:0.35rem;}
.hero-feel{font-size:1rem;color:var(--gold-lt);font-style:italic;margin-bottom:0.6rem;}
.hero-desc{font-size:0.9rem;color:var(--ink2);line-height:1.75;font-style:italic;}
.photo-wrap{display:flex;justify-content:center;margin-bottom:1.75rem;}
.photo-placeholder{width:min(420px,100%);aspect-ratio:4/3;background:var(--bg2);border:1px solid rgba(184,129,58,0.15);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.photo-placeholder::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);}
.photo-inner{text-align:center;color:var(--ink4);}
.photo-icon{font-size:20px;margin-bottom:6px;display:block;opacity:0.4;}
.photo-label{font-family:var(--sans);font-size:9px;letter-spacing:0.14em;text-transform:uppercase;}
.photo-sub{font-size:0.78rem;color:var(--ink4);font-style:italic;margin-top:4px;opacity:0.7;}
.book-wrap{text-align:center;}
.reserve-btn{font-family:var(--sans);font-size:13px;letter-spacing:0.12em;text-transform:uppercase;padding:13px 36px;border-radius:100px;border:none;background:var(--gold);color:#fff;cursor:pointer;transition:all var(--t);}
.reserve-btn:hover{background:var(--gold-lt);}
.as-sec{margin-bottom:2.5rem;}
.as-mood-title{font-size:1.2rem;font-weight:400;color:var(--ink);margin-bottom:0.2rem;}
.as-mood-sub{font-size:0.88rem;color:var(--gold-lt);font-style:italic;margin-bottom:0.9rem;}
.as-feeling{margin-bottom:1rem;text-align:center;}
.as-feeling .card-frame{margin:0 auto;}
.as-feeling-label{font-family:var(--sans);font-size:9.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink4);margin-bottom:0.6rem;border-left:2px solid var(--gold-pale);padding-left:8px;text-align:left;}
.mood-divider{border:none;border-top:1px solid rgba(184,129,58,0.15);margin:1.5rem 0;}

/* ═══════════════════════════════════════════════
   GALLERY
═══════════════════════════════════════════════ */
.gallery-head{text-align:center;margin-bottom:2.5rem;padding:0 var(--side);}
.gallery-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:3px;}
.gallery-cell{aspect-ratio:3/4;background:var(--bg3);overflow:hidden;position:relative;}
.gallery-cell:nth-child(2),.gallery-cell:nth-child(5){aspect-ratio:3/5;}
.gallery-cell-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:8.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink4);}
@media(max-width:780px){.gallery-strip{grid-template-columns:repeat(3,1fr);}}
@media(max-width:480px){.gallery-strip{grid-template-columns:1fr 1fr;}}

/* ═══════════════════════════════════════════════
   CULINARY
═══════════════════════════════════════════════ */
.food-cat{margin-bottom:1.75rem;}
.food-cat-label{font-family:var(--sans);font-size:9.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--sage);margin-bottom:0.75rem;display:flex;align-items:center;gap:8px;}
.food-cat-label::after{content:'';flex:1;height:1px;background:rgba(122,140,114,0.25);}
.food-items{display:flex;flex-direction:column;gap:0.55rem;}
.food-item{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;}
.food-item-name{font-size:1rem;color:var(--ink);}
.food-item-note{font-size:0.82rem;color:var(--ink3);font-style:italic;text-align:right;}
.food-photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:8.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink4);}
@media(max-width:680px){.food-3col{grid-template-columns:1fr!important;}}

/* ═══════════════════════════════════════════════
   EVENTS
═══════════════════════════════════════════════ */
.events-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;}
.event-card{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color var(--t),transform var(--t),box-shadow var(--t);box-shadow:0 2px 8px rgba(44,36,24,0.04);}
.event-card:hover{border-color:rgba(184,129,58,0.5);transform:translateY(-2px);box-shadow:0 6px 20px rgba(184,129,58,0.1);}
.event-card-photo{aspect-ratio:16/9;background:var(--bg2);position:relative;overflow:hidden;}
.event-card-photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink4);}
.event-card-body{padding:1.35rem 1.5rem 1.5rem;}
.event-card-tag{font-family:var(--sans);font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);opacity:0.7;margin-bottom:0.5rem;}
.event-card-name{font-size:1.1rem;color:var(--ink);margin-bottom:0.3rem;}
.event-card-feel{font-size:0.88rem;color:var(--gold-lt);font-style:italic;margin-bottom:0.65rem;}
.event-card-desc{font-size:0.83rem;color:var(--ink3);line-height:1.65;font-style:italic;}
@media(max-width:680px){.events-grid{grid-template-columns:1fr;}}

/* ═══════════════════════════════════════════════
   REVIEWS
═══════════════════════════════════════════════ */
.reviews-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:2.5rem;flex-wrap:wrap;gap:1rem;}
.rating-block{display:flex;align-items:baseline;gap:0.75rem;}
.rating-score{font-size:3.2rem;font-weight:300;color:var(--ink);line-height:1;}
.stars{display:flex;gap:3px;margin-bottom:4px;}
.star{width:13px;height:13px;background:var(--gold);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);}
.rating-count{font-family:var(--sans);font-size:11px;color:var(--ink3);}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
.review-card{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-sm);padding:1.6rem;box-shadow:0 1px 6px rgba(44,36,24,0.04);}
.review-quote-mark{font-size:2.8rem;line-height:0.5;color:var(--gold-pale);font-family:var(--serif);display:block;margin-bottom:0.75rem;}
.review-text{font-size:0.9rem;color:var(--ink2);line-height:1.7;font-style:italic;margin-bottom:1.25rem;}
.review-author{display:flex;align-items:center;gap:0.75rem;padding-top:1rem;border-top:1px solid rgba(184,129,58,0.1);}
.review-avatar{width:30px;height:30px;border-radius:50%;background:rgba(184,129,58,0.12);display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:11px;color:var(--gold);flex-shrink:0;}
.review-name{font-family:var(--sans);font-size:11px;color:var(--ink2);letter-spacing:0.04em;}
.review-stars{display:flex;gap:2px;margin-top:2px;}
.review-star{width:8px;height:8px;background:var(--gold);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);opacity:0.85;}
@media(max-width:680px){.reviews-grid{grid-template-columns:1fr;}}

/* ═══════════════════════════════════════════════
   PARTNERS / CONTACT / FOOTER
═══════════════════════════════════════════════ */
.partners-inner{display:flex;align-items:center;gap:3rem;flex-wrap:wrap;padding:2.5rem 0;border-top:1px solid rgba(184,129,58,0.15);border-bottom:1px solid rgba(184,129,58,0.15);}
.partners-label{font-family:var(--sans);font-size:9px;letter-spacing:0.24em;text-transform:uppercase;color:var(--ink4);white-space:nowrap;}
.partners-logos{display:flex;align-items:center;gap:2.5rem;flex-wrap:wrap;}
.partner{font-family:var(--sans);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink4);opacity:0.6;}
.cta-strip{background:var(--bg3);padding:6rem 0;text-align:center;position:relative;overflow:hidden;}
.cta-strip::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(184,129,58,0.08),transparent 70%);pointer-events:none;}
.cta-eyebrow{font-family:var(--sans);font-size:9.5px;letter-spacing:0.28em;text-transform:uppercase;color:var(--gold);opacity:0.75;margin-bottom:1.5rem;}
.cta-h2{font-size:clamp(1.8rem,4vw,3.5rem);font-weight:300;color:var(--ink);line-height:1.1;margin-bottom:1rem;}
.cta-h2 em{font-style:italic;color:var(--gold);}
.cta-sub{font-size:1.05rem;color:var(--ink2);font-style:italic;margin-bottom:2.5rem;max-width:420px;margin-left:auto;margin-right:auto;line-height:1.7;}
.cta-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;}
.cta-address{margin-top:2.5rem;font-family:var(--sans);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink4);}
.footer{background:#4a3728;padding:2.75rem 0;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;}
.footer-brand{font-size:1.05rem;font-weight:300;color:rgba(247,240,230,0.85);letter-spacing:0.04em;}
.footer-brand span{color:var(--gold-pale);opacity:0.8;}
.footer-links{display:flex;gap:1.75rem;flex-wrap:wrap;}
.footer-link{font-family:var(--sans);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(247,240,230,0.65);cursor:pointer;transition:color var(--t);}
.footer-link:hover{color:rgba(247,240,230,1);}
.footer-tagline{font-size:1rem;font-weight:400;font-style:italic;color:rgba(247,240,230,0.82);letter-spacing:0.04em;}
@media(max-width:700px){.footer-inner{flex-direction:column;align-items:flex-start;}}

/* ═══════════════════════════════════════════════
   FIND US PAGE
═══════════════════════════════════════════════ */
.find-us-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
.contact-block{display:flex;flex-direction:column;gap:2rem;}
.contact-card{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-md);padding:1.75rem 2rem;box-shadow:0 2px 8px rgba(44,36,24,0.04);}
.contact-card-label{font-family:var(--sans);font-size:9px;letter-spacing:0.24em;text-transform:uppercase;color:var(--gold);opacity:0.75;margin-bottom:1rem;}
.contact-row{display:flex;align-items:flex-start;gap:0.75rem;margin-bottom:0.85rem;}
.contact-row:last-child{margin-bottom:0;}
.contact-icon{width:32px;height:32px;border-radius:50%;background:rgba(184,129,58,0.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px;}
.contact-detail{display:flex;flex-direction:column;gap:2px;}
.contact-key{font-family:var(--sans);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink4);}
.contact-val{font-size:1rem;color:var(--ink);font-weight:400;}
.contact-val a{color:var(--gold);}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:0.6rem 0;border-bottom:1px solid rgba(184,129,58,0.1);}
.hours-row:last-child{border-bottom:none;}
.hours-day{font-family:var(--sans);font-size:11px;letter-spacing:0.08em;color:var(--ink2);}
.hours-time{font-size:0.9rem;color:var(--ink);font-style:italic;}
.hours-time.closed{color:var(--ink3);font-style:normal;}
.map-placeholder{aspect-ratio:4/3;background:var(--bg3);border-radius:var(--radius-md);overflow:hidden;position:relative;border:1px solid var(--gold-border);}
.map-placeholder::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);}
.map-ph-inner{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.75rem;opacity:0.4;}
.map-ph-inner svg{width:36px;height:36px;fill:var(--ink3);}
.map-ph-inner p{font-family:var(--sans);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink3);}
.address-banner{background:var(--gold);color:#fff;text-align:center;padding:1.25rem var(--side);}
.address-banner p{font-family:var(--sans);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;opacity:0.9;}
@media(max-width:780px){.find-us-grid{grid-template-columns:1fr;gap:2.5rem;}}
/* ═══ MEMBERSHIP PAGE ═══ */
.membership-hero{background:linear-gradient(135deg,var(--ink) 0%,#3a2c1a 100%);padding:5rem 0;text-align:center;position:relative;overflow:hidden;}
.membership-hero::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(184,129,58,0.12),transparent 70%);pointer-events:none;}
.membership-hero-eyebrow{font-family:var(--sans);font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold-pale);opacity:0.75;margin-bottom:1.25rem;}
.membership-hero-title{font-size:clamp(2rem,4.5vw,4rem);font-weight:300;color:#f7f0e6;line-height:1.1;margin-bottom:1rem;}
.membership-hero-title em{font-style:italic;color:var(--gold-pale);}
.membership-hero-sub{font-size:1.05rem;color:rgba(247,240,230,0.65);font-style:italic;max-width:480px;margin:0 auto 2rem;line-height:1.75;}
.membership-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;}
.tier-card{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-md);overflow:hidden;position:relative;transition:transform var(--t),box-shadow var(--t);}
.tier-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(184,129,58,0.14);}
.tier-card.featured{border-color:var(--gold);}
.tier-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold-pale);}
.tier-card.featured::before{background:var(--gold);}
.tier-badge{position:absolute;top:1rem;right:1rem;font-family:var(--sans);font-size:8.5px;letter-spacing:0.18em;text-transform:uppercase;padding:3px 10px;border-radius:100px;background:var(--gold);color:#fff;}
.tier-body{padding:2rem;}
.tier-name{font-size:1.3rem;font-weight:400;color:var(--ink);margin-bottom:0.25rem;}
.tier-feel{font-size:0.88rem;color:var(--gold-lt);font-style:italic;margin-bottom:1.25rem;}
.tier-perks{display:flex;flex-direction:column;gap:0.6rem;margin-bottom:1.75rem;}
.tier-perk{display:flex;align-items:flex-start;gap:0.65rem;font-size:0.88rem;color:var(--ink2);line-height:1.55;}
.tier-perk::before{content:'✦';color:var(--gold);opacity:0.55;font-size:8px;margin-top:4px;flex-shrink:0;}
.tier-cta{display:block;text-align:center;font-family:var(--sans);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;padding:11px 24px;border-radius:100px;border:1px solid rgba(184,129,58,0.4);color:var(--gold);cursor:pointer;transition:all var(--t);background:transparent;}
.tier-cta:hover,.tier-card.featured .tier-cta{background:var(--gold);color:#fff;border-color:var(--gold);}
.member-login-card{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-md);padding:2.5rem;text-align:center;max-width:440px;margin:3rem auto 0;box-shadow:0 4px 18px rgba(44,36,24,0.06);position:relative;}
.member-login-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);border-radius:var(--radius-md) var(--radius-md) 0 0;}
.login-title{font-size:1.35rem;font-weight:400;color:var(--ink);margin-bottom:0.35rem;}
.login-sub{font-size:0.88rem;color:var(--ink3);font-style:italic;margin-bottom:1.75rem;}
.login-field{width:100%;padding:11px 14px;border:1px solid var(--gold-border);border-radius:var(--radius-sm);font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--bg1);outline:none;margin-bottom:0.75rem;transition:border-color var(--t);}
.login-field:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,129,58,0.1);}
.login-btn{width:100%;padding:13px;border-radius:100px;border:none;background:var(--gold);color:#fff;font-family:var(--sans);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;transition:background var(--t);margin-top:0.25rem;}
.login-btn:hover{background:var(--gold-lt);}
.login-forgot{font-family:var(--sans);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink4);cursor:pointer;margin-top:0.9rem;display:block;transition:color var(--t);}
.login-forgot:hover{color:var(--gold);}
@media(max-width:720px){.membership-tiers{grid-template-columns:1fr;}}

/* ═══ SHOP PAGE ═══ */
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem;}
.shop-card{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-md);overflow:hidden;transition:transform var(--t),box-shadow var(--t);}
.shop-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(184,129,58,0.1);}
.shop-card-img{aspect-ratio:1;background:var(--bg2);overflow:hidden;position:relative;}
.shop-card-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink4);}
.shop-card-body{padding:1.25rem 1.4rem 1.5rem;}
.shop-card-cat{font-family:var(--sans);font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);opacity:0.7;margin-bottom:0.4rem;}
.shop-card-name{font-size:1.05rem;font-weight:400;color:var(--ink);margin-bottom:0.2rem;}
.shop-card-desc{font-size:0.82rem;color:var(--ink3);font-style:italic;line-height:1.6;margin-bottom:0.85rem;}
.shop-card-price{font-family:var(--sans);font-size:13px;color:var(--gold);font-weight:500;}
.shop-card-btn{display:block;text-align:center;margin-top:0.75rem;font-family:var(--sans);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;padding:9px 20px;border-radius:100px;border:1px solid rgba(184,129,58,0.35);color:var(--gold);cursor:pointer;transition:all var(--t);background:transparent;}
.shop-card-btn:hover{background:var(--gold);color:#fff;}
@media(max-width:720px){.shop-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.shop-grid{grid-template-columns:1fr;}}

@media(max-width:680px){.events-teaser-4{grid-template-columns:1fr 1fr!important;}}
@media(max-width:420px){.events-teaser-4{grid-template-columns:1fr!important;}}

/* ── Location icon button ── */
.nav-location{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid rgba(184,129,58,0.5);background:transparent;color:var(--gold);cursor:pointer;transition:all var(--t);flex-shrink:0;}
.nav-location:hover{background:var(--gold);color:#fff;border-color:var(--gold);}
.nav.pinned .nav-location{color:var(--gold);border-color:rgba(184,129,58,0.5);}

/* ── WhatsApp floating button ── */
.wa-float{position:fixed;bottom:max(2rem,env(safe-area-inset-bottom,2rem));right:max(2rem,env(safe-area-inset-right,2rem));z-index:500;display:flex;flex-direction:column;align-items:flex-end;gap:0;position:fixed;}
.wa-btn{width:56px;height:56px;border-radius:50%;background:#25D366;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,0.4);transition:transform var(--t),box-shadow var(--t);}
.wa-btn:hover{transform:scale(1.08);box-shadow:0 6px 22px rgba(37,211,102,0.5);}
.wa-btn svg{width:28px;height:28px;fill:#fff;}
.wa-tooltip{background:var(--ink);color:#f7f0e6;font-family:var(--sans);font-size:11px;letter-spacing:0.08em;padding:7px 14px;border-radius:100px;white-space:nowrap;opacity:0;transform:translateX(8px);transition:opacity 0.2s,transform 0.2s;pointer-events:none;position:absolute;right:calc(100% + 0.75rem);bottom:50%;transform:translateY(50%) translateX(8px);}
.wa-float:hover .wa-tooltip{opacity:1;transform:translateY(50%) translateX(0);}
@media(max-width:600px){.wa-float{bottom:1.5rem;right:1.25rem;}}

/* ── Shop popup ── */
.shop-popup-overlay{display:none;position:fixed;inset:0;background:rgba(44,36,24,0.55);z-index:800;align-items:center;justify-content:center;padding:1.5rem;}
.shop-popup-overlay.open{display:flex;}
.shop-popup{background:#fff;border-radius:var(--radius-lg);overflow:hidden;max-width:640px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 12px 48px rgba(44,36,24,0.18);}
.shop-popup::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);}
.shop-popup-img{aspect-ratio:16/9;background:var(--bg2);overflow:hidden;}
.shop-popup-img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink4);}
.shop-popup-body{padding:2rem 2.25rem 2rem;}
.shop-popup-cat{font-family:var(--sans);font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);opacity:0.75;margin-bottom:0.5rem;}
.shop-popup-name{font-size:1.5rem;font-weight:400;color:var(--ink);margin-bottom:0.4rem;}
.shop-popup-desc{font-size:0.95rem;color:var(--ink2);font-style:italic;line-height:1.75;margin-bottom:1.25rem;}
.shop-popup-price{font-family:var(--sans);font-size:1.1rem;color:var(--gold);font-weight:500;margin-bottom:1.5rem;}
.shop-popup-actions{display:flex;gap:0.9rem;flex-wrap:wrap;}
.shop-popup-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border-radius:50%;background:var(--bg2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--ink3);transition:background var(--t);}
.shop-popup-close:hover{background:var(--bg3);}
.aw-cul-card{background:#fff;border:1px solid var(--gold-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform var(--t),box-shadow var(--t);box-shadow:0 2px 8px rgba(44,36,24,0.04);}
.aw-cul-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(122,140,114,0.15);}
.aw-cul-card.selected{border-color:var(--gold);box-shadow:0 4px 16px rgba(184,129,58,0.18);}

/* ════════════════════════════════════════════════════════════
   MOBILE FINAL — v9.1
   Single authoritative mobile block. Replaces v8 + v9.
════════════════════════════════════════════════════════════ */
html,body{overflow-x:hidden!important;width:100%;}
*,*::before,*::after{box-sizing:border-box;}
img,video,svg{max-width:100%;height:auto;display:block;}

/* All white-space:nowrap in HTML → wrap on phone */
@media(max-width:700px){
  [style*="white-space:nowrap"]{white-space:normal!important;}
  p[style*="white-space:nowrap"],div[style*="white-space:nowrap"]{white-space:normal!important;font-size:clamp(0.82rem,3.2vw,1rem)!important;line-height:1.55!important;}
  h2[style*="white-space:nowrap"]{white-space:normal!important;font-size:clamp(1.1rem,4.5vw,1.6rem)!important;}
  div[style*="position:sticky"]{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;flex-wrap:nowrap!important;scrollbar-width:none!important;}
  div[style*="position:sticky"]::-webkit-scrollbar{display:none!important;}
  div[style*="position:sticky"] button{flex-shrink:0!important;white-space:nowrap!important;}
}
@media(max-width:860px){
  .nav-links{display:none;}.nav-ham{display:flex;}
  button,.uc,.aw-cul-card,.event-card,.app-all-sparks,.ms-card,.ep-header,.footer-link,.nav-link,.mob-link{min-height:44px;}
  .banner-video-zone{padding-top:calc(58px + 0.8rem);}
}
@media(max-width:768px){
  div[style*="grid-template-columns:1.1fr 1fr"],div[style*="grid-template-columns:1fr 1.4fr"],div[style*="grid-template-columns:1.4fr 1fr"]{grid-template-columns:1fr!important;gap:2rem!important;}
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:4rem"],div[style*="grid-template-columns:1fr 1fr"][style*="gap:3rem"]{grid-template-columns:1fr!important;gap:2rem!important;}
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:repeat(2,1fr)!important;}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important;}
  .story-grid,.find-us-grid,.home-began-grid,.membership-tiers,.reviews-grid,.events-grid,.contact-info-grid{grid-template-columns:1fr!important;gap:2rem!important;}
  .shop-grid{grid-template-columns:1fr 1fr!important;}
  #spark-entry-grid{grid-template-columns:1fr!important;}
  #spark-entry-grid>div:first-child{border-right:none!important;border-bottom:1px solid var(--gold-border)!important;}
  .banner-h1{font-size:clamp(1.3rem,5vw,2.2rem)!important;white-space:normal!important;}
  .banner-tagline{font-size:clamp(0.88rem,2.8vw,1.05rem)!important;white-space:normal!important;}
  .banner-slogan-zone{padding:1.2rem 1.5rem 1.8rem!important;}
  .banner-media-inner{width:min(800px,100%)!important;aspect-ratio:16/6!important;}
  .sec{padding:3.5rem 0;}
}
@media(max-width:600px){
  :root{--side:1.25rem;}
  div[style*="grid-template-columns:1fr 1fr"],div[style*="grid-template-columns:repeat(2,1fr)"],.grid-2,.ms-grid,.aw-grid-2,.ms-home-cards{grid-template-columns:1fr!important;}
  div[style*="grid-template-columns:repeat(3,1fr)"],.aw-grid-3,.membership-tiers,.reviews-grid,.shop-grid{grid-template-columns:1fr!important;}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important;}
  .sec{padding:2.5rem 0;}.inner{padding:0 1.25rem;}
  .banner-video-zone{padding:calc(58px + 0.65rem) 0.75rem 0.65rem!important;}
  .banner-media-inner{aspect-ratio:16/7!important;border-radius:var(--radius-md)!important;}
  .banner-slogan-zone{padding:1rem 1.25rem 1.5rem!important;}
  .banner-h1{font-size:clamp(1.05rem,5vw,1.7rem)!important;white-space:normal!important;}
  .banner-tagline{font-size:clamp(0.8rem,3.5vw,0.95rem)!important;white-space:normal!important;}
  .banner-actions{flex-direction:column!important;align-items:center!important;gap:0.75rem!important;}
  .banner-actions button{width:100%!important;max-width:280px;}
  .arc-strip{grid-template-columns:1fr!important;}
  .arc-cell{border-right:none!important;border-bottom:1px solid var(--gold-border)!important;}
  .arc-cell:last-child{border-bottom:none!important;}
  .arc-arr{display:none!important;}
  .ep-body-inner{grid-template-columns:1fr!important;}
  .footer-inner{flex-direction:column!important;gap:1.25rem!important;}
  .footer-meta{flex-direction:column!important;gap:0.5rem!important;}
  .footer-links{display:grid!important;grid-template-columns:1fr 1fr!important;gap:0.5rem 1.5rem!important;}
  .footer{padding:2rem 0!important;}
  .shop-popup-overlay{padding:0!important;align-items:flex-end!important;}
  .shop-popup{border-radius:var(--radius-lg) var(--radius-lg) 0 0!important;max-height:92vh!important;}
  .nav{padding:0 1rem!important;height:58px!important;}
  .nav-cta{padding:7px 14px!important;font-size:10px!important;}
  .nav-location{width:30px!important;height:30px!important;}
  .mob-menu{top:58px!important;}
  .wa-float{bottom:1.25rem!important;right:1rem!important;}
  .wa-btn{width:48px!important;height:48px!important;}
  .wa-btn svg{width:24px!important;height:24px!important;}
  .partners-inner{flex-direction:column!important;gap:1rem!important;}
  .partners-logos{flex-wrap:wrap!important;gap:1rem!important;}
  .gallery-strip{grid-template-columns:1fr 1fr!important;}
  .cul-items-grid,#cul-items-grid{grid-template-columns:1fr!important;padding:1.25rem!important;}
  .ms-home-grid{grid-template-columns:1fr!important;gap:2rem!important;}
  .ms-grid{grid-template-columns:1fr!important;}
  .reviews-top{flex-direction:column!important;gap:0.75rem!important;}
}
@media(max-width:480px){
  :root{--side:1.1rem;}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr 1fr!important;}
  #all-sparks-inline-grid{grid-template-columns:1fr 1fr!important;}
  .sec-title{font-size:clamp(1.4rem,5vw,2rem)!important;}
  h2{font-size:clamp(1.25rem,5vw,1.8rem);}
  .reserve-card-wrap{width:100%!important;}
  .rc-ep{padding:0.9rem 1rem!important;}
  .reserve-card-top,.rc-cta{padding:1.25rem 1rem!important;}
  .bottom-nav{flex-wrap:wrap!important;}
  .bottom-nav .nav-btn{font-size:11px!important;padding:8px 14px!important;}
  div[style*="position:sticky"] button{font-size:10px!important;padding:6px 12px!important;min-height:36px!important;}
  div[style*="aspect-ratio:4/5"]{aspect-ratio:4/3!important;}
}
@media(max-width:380px){
  :root{--side:1rem;}
  .banner-h1{font-size:1rem!important;}
  .banner-tagline{font-size:0.78rem!important;}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr!important;}
  #all-sparks-inline-grid{grid-template-columns:1fr!important;}
  .nav-cta{display:none!important;}
}
@supports(padding:env(safe-area-inset-bottom)){
  .wa-float{bottom:max(1.25rem,calc(env(safe-area-inset-bottom) + 0.75rem))!important;right:max(1rem,calc(env(safe-area-inset-right) + 0.5rem))!important;}
  .mob-menu{padding-bottom:calc(1.5rem + env(safe-area-inset-bottom))!important;}
  .footer{padding-bottom:calc(2rem + env(safe-area-inset-bottom))!important;}
}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;}
@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth;}}
@media(prefers-contrast:high){:root{--ink:#000;--gold:#8B6914;--gold-border:rgba(139,105,20,0.65);}}/* ── BANNER: full-bleed gradient bg, video box floating inside ── */

.page-banner {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Full-bleed background — the gradient fills the entire section */
.banner-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

/* Dark gradient overlay at bottom — so slogan text reads clearly */
.banner-overlay-gradient {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to top,
    rgba(28,20,10,0.68) 0%,
    rgba(28,20,10,0.22) 50%,
    transparent 80%
  );
  pointer-events: none;
}


/* ════════════════════════════════════════════════════════════
   BANNER — full-bleed gradient, video box floating, slogan overlay
════════════════════════════════════════════════════════════ */
.page-banner {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.page-banner.short { /* short variant — default for all pages */ }

/* Full-bleed gradient background */
.banner-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

/* Dark overlay — fades up from bottom so slogan reads over it */
.banner-overlay-gradient {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to top,
    rgba(28,20,10,0.68) 0%,
    rgba(28,20,10,0.22) 50%,
    transparent 80%
  );
  pointer-events: none;
}

/* Video zone — sits below fixed nav, centred */
.banner-video-zone {
  position: relative;
  z-index: 2;
  padding: calc(64px + 1.05rem) 2.5rem 1.05rem;
  display: flex;
  justify-content: center;
}

/* Bordered video box — centred, constrained width */
.banner-media-inner {
  width: min(920px, 100%);
  aspect-ratio: 16 / 6;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid rgba(240,236,228,0.28);
  box-shadow: 0 4px 20px rgba(28,20,10,0.18);
  position: relative;
  background: rgba(28,20,10,0.06);
}

.banner-ph {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}
.banner-ph-inner { text-align: center; opacity: 0.45; }
.banner-ph-inner p {
  font-family: var(--sans); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(240,236,228,0.7); margin-top: 0.6rem;
}

/* Slogan zone — over the gradient overlay at the bottom */
.banner-slogan-zone {
  position: relative;
  z-index: 3;
  text-align: center;
  padding: 1.5rem var(--side) 2.1rem;
}

/* Typography — light on dark gradient */
.banner-eyebrow {
  display: block;
  font-family: var(--sans);
  font-size: 9.5px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--gold-pale); opacity: 0.85;
  margin-bottom: 0.9rem;
}
.banner-h1 {
  font-size: clamp(1.8rem, 4vw, 3.8rem);
  font-weight: 300; line-height: 1.06;
  color: #f7f0e6;
  margin: 0 0 0.55rem;
  white-space: nowrap;
}
.banner-h1 em { font-style: italic; color: var(--gold-pale); }
.banner-tagline {
  font-size: clamp(1rem, 1.8vw, 1.3rem);
  color: rgba(247,240,230,0.88);
  font-weight: 300; font-style: normal;
  line-height: 1.5; margin: 0 0 1.25rem;
  white-space: nowrap;
}
.banner-actions {
  display: flex; align-items: center;
  gap: 0.85rem; flex-wrap: wrap; justify-content: center;
}
.banner-scroll { display: none; }

/* Banner buttons — light ghost on dark gradient */
.banner-btn-p {
  font-family: var(--sans); font-size: 12px;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 12px 30px; border-radius: 100px;
  border: none; background: var(--gold); color: #fff;
  cursor: pointer; transition: background var(--t), transform var(--t);
}
.banner-btn-p:hover { background: var(--gold-lt); transform: translateY(-1px); }
.banner-btn-g {
  font-family: var(--sans); font-size: 12px;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 11px 28px; border-radius: 100px;
  border: 1px solid rgba(247,240,230,0.4);
  background: transparent; color: rgba(247,240,230,0.85);
  cursor: pointer; transition: all var(--t);
}
.banner-btn-g:hover { border-color: rgba(247,240,230,0.8); color: #f7f0e6; }


/* ── Begin Your Visit floating button ── */
.reserve-float {
  position: fixed;
  bottom: max(6.5rem, calc(env(safe-area-inset-bottom, 0px) + 6.5rem));
  right: max(2rem, env(safe-area-inset-right, 2rem));
  z-index: 499;
}
.reserve-float-btn {
  font-family: var(--sans);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 11px 18px;
  border-radius: 100px;
  border: none;
  background: rgba(184,129,58,0.72);
  color: rgba(255,255,255,0.92);
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(184,129,58,0.18);
  transition: background var(--t), transform var(--t), box-shadow var(--t);
  display: block;
}
.reserve-float-btn:hover {
  background: var(--gold);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(184,129,58,0.35);
}
/* ── Scroll to top ── */
.scroll-top-btn {
  position: fixed;
  /* Sits to the LEFT of the WA button, same row */
  bottom: max(2rem, env(safe-area-inset-bottom, 2rem));
  right: max(5.25rem, calc(env(safe-area-inset-right, 0px) + 5.25rem));
  z-index: 501;
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 1.5px solid rgba(184,129,58,0.55);
  background: rgba(247,240,230,0.82);
  color: var(--gold);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  opacity: 0; pointer-events: none;
  box-shadow: 0 2px 8px rgba(44,36,24,0.1);
  transition: opacity 0.3s, transform 0.25s, background 0.25s, box-shadow 0.25s;
}
.scroll-top-btn.visible, .scroll-top.visible { opacity: 1; pointer-events: auto; }
.scroll-top-btn:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(184,129,58,0.3);
}
@media(max-width:600px) {
  .reserve-float { bottom: 6.5rem; right: 1.25rem; }
  .reserve-float-btn { font-size: 9.5px; padding: 9px 14px; }
  .scroll-top-btn { bottom: 1.25rem; right: 5rem; width: 38px; height: 38px; }
}


/* Mood cards grid — responsive via class */
.mood-cards-grid { display: grid; gap: 1rem; max-width: 860px; margin: 0 auto; margin-top: 1.5rem; grid-template-columns: repeat(4,1fr); }
@media(max-width:768px) { .mood-cards-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:600px) { .mood-cards-grid { grid-template-columns: 1fr; } }


.spark-detail-back {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink3);
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px 0;
  transition: color var(--t);
}
.spark-detail-back:hover { color: var(--gold); }


/* ── Spark experience gallery (expands below buttons) ── */
.sd-gallery {
  display: none;
  max-width: 860px;
  margin: 2.5rem auto 0;
  animation: sdFadeIn 0.4s ease;
}
.sd-gallery.open { display: block; }
@keyframes sdFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sd-gallery-heading {
  font-family: var(--sans);
  font-size: 9.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.8;
  text-align: center;
  margin-bottom: 1.25rem;
}
.sd-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.1rem;
}
.sd-gallery-ph {
  aspect-ratio: 4 / 3;
  background: var(--bg2);
  border-radius: var(--radius-md);
  border: 1px solid var(--gold-border);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(44,36,24,0.06);
}
.sd-gallery-ph::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gold);
  opacity: 0.5;
}
.sd-gallery-ph-label {
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink4);
  margin-top: 0.4rem;
}
/* See This Experience button */
.sd-see-btn {
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 14px 28px;
  border-radius: 100px;
  border: 1.5px solid rgba(184,129,58,0.5);
  background: transparent;
  color: var(--gold);
  cursor: pointer;
  min-width: 200px;
  transition: all var(--t);
}
.sd-see-btn:hover, .sd-see-btn.active {
  background: rgba(184,129,58,0.08);
  border-color: var(--gold);
}
@media(max-width:600px) {
  .sd-gallery-grid { grid-template-columns: 1fr; gap: 0.85rem; }
}
@media(max-width:768px) and (min-width:601px) {
  .sd-gallery-grid { grid-template-columns: 1fr 1fr; }
}


/* ── Drop Us A Note — contact form modal ── */
.note-overlay{position:fixed;inset:0;background:rgba(28,20,10,0.55);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity 0.28s;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);}
.note-overlay.open{opacity:1;pointer-events:auto;}
.note-modal{background:#fff;border-radius:var(--radius-lg);padding:2.5rem 2.75rem;max-width:480px;width:100%;position:relative;box-shadow:0 20px 60px rgba(28,20,10,0.25);transform:translateY(16px);transition:transform 0.28s;}
.note-overlay.open .note-modal{transform:translateY(0);}
.note-close{position:absolute;top:1rem;right:1.25rem;background:none;border:none;font-size:1.2rem;color:var(--ink3);cursor:pointer;padding:4px 8px;border-radius:4px;transition:color var(--t);}
.note-close:hover{color:var(--ink);}
.note-modal-tag{font-family:var(--sans);font-size:9.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);opacity:0.8;margin-bottom:0.5rem;}
.note-modal-title{font-size:clamp(1.4rem,3vw,1.8rem);font-weight:300;color:var(--ink);margin-bottom:0.35rem;line-height:1.1;}
.note-modal-sub{font-size:0.88rem;color:var(--ink3);font-style:italic;margin-bottom:1.75rem;line-height:1.5;}
.note-field{width:100%;font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--bg2);border:1px solid var(--gold-border);border-radius:var(--radius-sm);padding:11px 14px;margin-bottom:0.85rem;outline:none;transition:border-color var(--t),box-shadow var(--t);box-sizing:border-box;}
.note-field:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,129,58,0.12);}
.note-field::placeholder{color:var(--ink4);}
textarea.note-field{resize:vertical;min-height:100px;line-height:1.6;}
.note-send-btn{width:100%;font-family:var(--sans);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;padding:13px;border-radius:100px;border:none;background:var(--gold);color:#fff;cursor:pointer;margin-top:0.35rem;transition:background var(--t),transform var(--t);}
.note-send-btn:hover{background:var(--gold-lt);transform:translateY(-1px);}
.note-success{display:none;text-align:center;padding:1rem 0 0.5rem;}
.note-success-icon{font-size:2rem;margin-bottom:0.5rem;}
.note-success-msg{font-size:1rem;color:var(--ink2);line-height:1.7;}
@media(max-width:500px){.note-modal{padding:2rem 1.5rem;}}


/* ── Moments Page ── */
.mom-primary-tabs {
  display: flex;
  justify-content: center;
  gap: 1rem;
  padding: 2.5rem var(--side) 0;
}
.mom-primary-btn {
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 13px 40px;
  border-radius: 100px;
  cursor: pointer;
  transition: all var(--t);
  min-width: 140px;
}
.mom-primary-btn.active {
  background: var(--gold);
  color: #fff;
  border: 1.5px solid var(--gold);
  box-shadow: 0 3px 12px rgba(184,129,58,0.25);
}
.mom-primary-btn.inactive {
  background: transparent;
  color: var(--gold);
  border: 1.5px solid rgba(184,129,58,0.45);
}
.mom-primary-btn.inactive:hover {
  border-color: var(--gold);
  background: rgba(184,129,58,0.06);
}

/* Section panels */
.mom-panel { display: none; }
.mom-panel.open { display: block; }

/* Filter tag bar */
.mom-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  padding: 2rem var(--side) 0;
  max-width: 900px;
  margin: 0 auto;
}
.mom-filter-btn {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 7px 16px;
  border-radius: 100px;
  cursor: pointer;
  transition: all var(--t);
  border: 1px solid rgba(184,129,58,0.35);
  background: transparent;
  color: var(--ink2);
  white-space: nowrap;
}
.mom-filter-btn:hover,
.mom-filter-btn.active {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
}

/* Photo grid */
.mom-photo-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding: 2rem var(--side) 4rem;
  max-width: 1100px;
  margin: 0 auto;
}
.mom-photo-card {
  background: var(--bg2);
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  position: relative;
  border: 1px solid var(--gold-border);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}
.mom-photo-label {
  font-family: var(--sans);
  font-size: 8.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink4);
  text-align: center;
  padding: 0 0.5rem;
}
.mom-photo-date {
  font-family: var(--sans);
  font-size: 8px;
  letter-spacing: 0.1em;
  color: var(--gold);
  opacity: 0.7;
}

/* Article grid */
.mom-article-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  padding: 2rem var(--side) 4rem;
  max-width: 1100px;
  margin: 0 auto;
}
.mom-article-card {
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--gold-border);
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(44,36,24,0.05);
  transition: transform var(--t), box-shadow var(--t);
  cursor: pointer;
}
.mom-article-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(44,36,24,0.09);
}
.mom-article-thumb {
  aspect-ratio: 16/9;
  background: var(--bg3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sans);
  font-size: 8.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink4);
  position: relative;
}
.mom-article-thumb::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gold);
  opacity: 0.6;
}
.mom-article-body {
  padding: 1.1rem 1.25rem 1.4rem;
}
.mom-article-cat {
  font-family: var(--sans);
  font-size: 8.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.8;
  margin-bottom: 0.4rem;
}
.mom-article-title {
  font-size: 1rem;
  font-weight: 400;
  color: var(--ink);
  line-height: 1.35;
  margin-bottom: 0.3rem;
}
.mom-article-date {
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: 0.08em;
  color: var(--ink4);
  font-style: italic;
}

/* Responsive */
@media(max-width:768px) {
  .mom-photo-grid   { grid-template-columns: repeat(2,1fr); }
  .mom-article-grid { grid-template-columns: repeat(2,1fr); }
}
@media(max-width:500px) {
  .mom-primary-tabs { flex-direction: column; align-items: center; }
  .mom-photo-grid   { grid-template-columns: repeat(2,1fr); gap:0.6rem; }
  .mom-article-grid { grid-template-columns: 1fr; }
}


/* ════════════════════════════════════════════════════════════
   BOOKING CALENDAR MODAL
════════════════════════════════════════════════════════════ */
.bk-overlay {
  position: fixed; inset: 0;
  background: rgba(28,20,10,0.6);
  z-index: 3000;
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
  opacity: 0; pointer-events: none;
  transition: opacity 0.28s;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  overflow-y: auto;
}
.bk-overlay.open { opacity: 1; pointer-events: auto; }

.bk-modal {
  background: #fff;
  border-radius: var(--radius-lg);
  width: 100%;
  max-width: 560px;
  position: relative;
  box-shadow: 0 24px 64px rgba(28,20,10,0.28);
  transform: translateY(20px);
  transition: transform 0.28s;
  margin: auto;
}
.bk-overlay.open .bk-modal { transform: translateY(0); }

.bk-modal-head {
  padding: 1.75rem 2rem 1.25rem;
  border-bottom: 1px solid var(--gold-border);
  position: relative;
}
.bk-close {
  position: absolute; top: 1.1rem; right: 1.25rem;
  background: none; border: none;
  font-size: 1.2rem; color: var(--ink3);
  cursor: pointer; padding: 4px 8px; border-radius: 4px;
  transition: color var(--t);
  z-index: 10; line-height: 1;
}
.bk-close:hover { color: var(--ink); }
.bk-modal-tag {
  font-family: var(--sans); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gold); opacity: 0.8; margin-bottom: 0.35rem;
}
.bk-modal-title {
  font-size: clamp(1.3rem, 3vw, 1.7rem);
  font-weight: 300; color: var(--ink); line-height: 1.1;
}

/* Category tabs */
.bk-cat-tabs {
  display: flex; gap: 0.4rem;
  padding: 1.1rem 2rem 0;
}
.bk-cat-btn {
  font-family: var(--sans); font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 8px 16px; border-radius: 100px;
  cursor: pointer; transition: all var(--t);
  border: 1.5px solid rgba(184,129,58,0.35);
  background: transparent; color: var(--ink2);
  flex: 1; white-space: nowrap;
}
.bk-cat-btn.active {
  background: var(--gold); color: #fff;
  border-color: var(--gold);
  box-shadow: 0 2px 8px rgba(184,129,58,0.22);
}

/* Form body */
.bk-body { padding: 1.5rem 2rem 0.5rem; }

/* Section heading inside form */
.bk-section-title {
  font-family: var(--sans); font-size: 9px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink3); margin: 1.1rem 0 0.6rem;
}

/* Fields */
.bk-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-bottom: 0.75rem; }
.bk-row.full { grid-template-columns: 1fr; }
.bk-field {
  display: flex; flex-direction: column; gap: 0.2rem;
}
.bk-label {
  font-family: var(--sans); font-size: 9.5px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink3);
}
.bk-input, .bk-select {
  font-family: var(--sans); font-size: 13px;
  color: var(--ink);
  background: var(--bg2);
  border: 1px solid var(--gold-border);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
  width: 100%;
  box-sizing: border-box;
}
.bk-input:focus, .bk-select:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(184,129,58,0.1);
}
.bk-input::placeholder { color: var(--ink4); }

/* Hands-on spark picker */
.bk-spark-group {
  background: var(--bg2);
  border: 1px solid var(--gold-border);
  border-radius: var(--radius-md);
  padding: 1rem 1.1rem 0.75rem;
  margin-bottom: 0.75rem;
  position: relative;
}
.bk-spark-group-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 0.75rem;
}
.bk-spark-group-label {
  font-family: var(--sans); font-size: 9.5px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--gold); font-weight: 500;
}
.bk-remove-group {
  background: none; border: none;
  font-size: 0.85rem; color: var(--ink4);
  cursor: pointer; padding: 2px 6px;
  border-radius: 4px; transition: color var(--t);
}
.bk-remove-group:hover { color: #c0392b; }
.bk-add-group {
  font-family: var(--sans); font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--gold); background: transparent;
  border: 1px dashed rgba(184,129,58,0.4);
  border-radius: var(--radius-sm);
  padding: 8px 14px; width: 100%;
  cursor: pointer; transition: all var(--t);
  margin-top: 0.5rem;
}
.bk-add-group:hover { background: var(--gold-wash); border-color: var(--gold); }

/* Fee notice */
.bk-fee-notice {
  background: rgba(184,129,58,0.08);
  border: 1px solid rgba(184,129,58,0.22);
  border-radius: var(--radius-sm);
  padding: 0.8rem 1rem;
  margin: 0.75rem 0 0.25rem;
  display: flex; align-items: center; gap: 0.75rem;
}
.bk-fee-icon { font-size: 1.1rem; flex-shrink: 0; }
.bk-fee-text {
  font-family: var(--sans); font-size: 11.5px;
  color: var(--ink2); line-height: 1.5;
}
.bk-fee-amount {
  font-weight: 500; color: var(--gold);
  font-size: 13px; margin-left: auto;
  white-space: nowrap; flex-shrink: 0;
}

/* Footer */
.bk-footer {
  padding: 1rem 2rem 1.75rem;
  border-top: 1px solid var(--gold-border);
  margin-top: 0.75rem;
}
.bk-submit {
  width: 100%;
  font-family: var(--sans); font-size: 12px;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 14px;
  border-radius: 100px; border: none;
  background: var(--gold); color: #fff;
  cursor: pointer;
  transition: background var(--t), transform var(--t);
}
.bk-submit:hover { background: var(--gold-lt); transform: translateY(-1px); }

/* Success state */
.bk-success {
  display: none; text-align: center;
  padding: 3rem 2rem;
}
.bk-success-icon { font-size: 2.5rem; margin-bottom: 0.75rem; }
.bk-success-title {
  font-size: 1.5rem; font-weight: 300;
  color: var(--ink); margin-bottom: 0.5rem;
}
.bk-success-msg {
  font-size: 0.95rem; color: var(--ink3);
  font-style: italic; line-height: 1.7;
}

@media(max-width:520px) {
  .bk-modal-head, .bk-body, .bk-footer { padding-left: 1.25rem; padding-right: 1.25rem; }
  .bk-cat-tabs { padding-left: 1.25rem; padding-right: 1.25rem; }
  .bk-row { grid-template-columns: 1fr; }
  .bk-cat-btn { font-size: 9px; padding: 7px 10px; }
}


/* ── Booking: Clear Selections button ── */
.bk-clear-btn {
  width: 100%;
  font-family: var(--sans); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 10px;
  border-radius: 100px;
  border: 1.5px solid rgba(184,129,58,0.35);
  background: transparent; color: var(--ink3);
  cursor: pointer;
  margin-bottom: 0.6rem;
  transition: all var(--t);
}
.bk-clear-btn:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-wash); }

/* ── Culinary confirmation popup ── */
.cul-confirm-overlay {
  position: fixed; inset: 0;
  background: rgba(28,20,10,0.55);
  z-index: 4000;
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s;
  backdrop-filter: blur(3px);
}
.cul-confirm-overlay.open { opacity: 1; pointer-events: auto; }
.cul-confirm-modal {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 2rem 2.5rem 2.25rem;
  max-width: 460px; width: 100%;
  position: relative;
  box-shadow: 0 20px 60px rgba(28,20,10,0.22);
  transform: translateY(14px);
  transition: transform 0.25s;
}
.cul-confirm-overlay.open .cul-confirm-modal { transform: translateY(0); }
.cul-confirm-close {
  position: absolute; top: 1rem; right: 1.25rem;
  background: none; border: none; font-size: 1.1rem;
  color: var(--ink3); cursor: pointer; z-index: 2;
}
.cul-confirm-close:hover { color: var(--ink); }
.cul-confirm-tag {
  font-family: var(--sans); font-size: 9px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold); opacity: 0.8; margin-bottom: 0.4rem;
}
.cul-confirm-title {
  font-size: clamp(1.2rem, 3vw, 1.55rem);
  font-weight: 300; color: var(--ink);
  margin-bottom: 0.3rem; line-height: 1.15;
}
.cul-confirm-sub {
  font-size: 0.87rem; color: var(--ink3);
  font-style: italic; margin-bottom: 1.5rem; line-height: 1.5;
}
.cul-confirm-summary {
  background: var(--bg2);
  border: 1px solid var(--gold-border);
  border-radius: var(--radius-sm);
  padding: 1rem 1.25rem;
  font-family: var(--sans); font-size: 12px;
  color: var(--ink2); line-height: 1.9;
  margin-bottom: 1.25rem;
  white-space: pre-wrap;
}
.cul-confirm-send {
  width: 100%; font-family: var(--sans);
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 13px; border-radius: 100px;
  border: none; background: var(--gold); color: #fff;
  cursor: pointer; transition: background var(--t), transform var(--t);
}
.cul-confirm-send:hover { background: var(--gold-lt); transform: translateY(-1px); }
.cul-confirm-sent { display:none; text-align:center; padding:1.5rem 0 0.5rem; }
.cul-confirm-sent-icon { font-size:2rem; margin-bottom:0.5rem; }
.cul-confirm-sent-msg { font-size:0.95rem; color:var(--ink3); font-style:italic; line-height:1.7; }


/* ── Payment confirmation popup (Sip & Mess / Hands-on) ── */
.pay-confirm-overlay {
  position: fixed; inset: 0;
  background: rgba(28,20,10,0.55);
  z-index: 4000;
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s;
  backdrop-filter: blur(3px);
}
.pay-confirm-overlay.open { opacity: 1; pointer-events: auto; }
.pay-confirm-modal {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 2rem 2.5rem 2.25rem;
  max-width: 460px; width: 100%;
  position: relative;
  box-shadow: 0 20px 60px rgba(28,20,10,0.22);
  transform: translateY(14px);
  transition: transform 0.25s;
  max-height: 90vh; overflow-y: auto;
}
.pay-confirm-overlay.open .pay-confirm-modal { transform: translateY(0); }
.pay-confirm-close {
  position: absolute; top: 1rem; right: 1.25rem;
  background: none; border: none; font-size: 1.1rem;
  color: var(--ink3); cursor: pointer; z-index: 2;
}
.pay-confirm-close:hover { color: var(--ink); }
.pay-confirm-tag {
  font-family: var(--sans); font-size: 9px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold); opacity: 0.8; margin-bottom: 0.4rem;
}
.pay-confirm-title {
  font-size: clamp(1.2rem, 3vw, 1.55rem);
  font-weight: 300; color: var(--ink);
  margin-bottom: 0.3rem; line-height: 1.15;
}
.pay-confirm-sub {
  font-size: 0.87rem; color: var(--ink3);
  font-style: italic; margin-bottom: 1.25rem; line-height: 1.5;
}
.pay-confirm-summary {
  background: var(--bg2);
  border: 1px solid var(--gold-border);
  border-radius: var(--radius-sm);
  padding: 1rem 1.25rem;
  font-family: var(--sans); font-size: 12px;
  color: var(--ink2); line-height: 1.9;
  margin-bottom: 1rem;
  white-space: pre-wrap;
}
.pay-confirm-fee {
  background: rgba(184,129,58,0.08);
  border: 1px solid rgba(184,129,58,0.22);
  border-radius: var(--radius-sm);
  padding: 0.75rem 1rem;
  font-family: var(--sans); font-size: 12px;
  color: var(--ink2); margin-bottom: 1.25rem;
  display: flex; align-items: center; justify-content: space-between;
}
.pay-confirm-fee-label { line-height: 1.5; }
.pay-confirm-fee-amount { font-weight:500; color:var(--gold); font-size:14px; white-space:nowrap; }
.pay-confirm-btn {
  width: 100%; font-family: var(--sans);
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 13px; border-radius: 100px;
  border: none; background: var(--gold); color: #fff;
  cursor: pointer; transition: background var(--t), transform var(--t);
}
.pay-confirm-btn:hover { background: var(--gold-lt); transform: translateY(-1px); }


/* ── Payment popup: guest/spark pax highlight ── */
.pay-pax-highlight {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
}
.pay-pax-pill {
  flex: 1;
  background: var(--bg2);
  border: 1px solid var(--gold-border);
  border-radius: var(--radius-sm);
  padding: 0.65rem 1rem;
  text-align: center;
}
.pay-pax-pill-label {
  font-family: var(--sans);
  font-size: 8.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink4);
  margin-bottom: 0.2rem;
}
.pay-pax-pill-value {
  font-size: 1.3rem;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}
.pay-pax-pill.highlight {
  border-color: rgba(184,129,58,0.45);
  background: rgba(184,129,58,0.06);
}
.pay-pax-pill.highlight .pay-pax-pill-value { color: var(--gold); }


/* ── Full Journey 3-date block ── */
.bk-journey-dates { display:none; border:1px solid var(--gold-border); border-radius:var(--radius-md); padding:1rem 1.1rem 0.5rem; background:var(--bg2); margin-top:0.75rem; margin-bottom:0.75rem; }
.bk-journey-dates.open { display:block; }
.bk-journey-ep-label { font-family:var(--sans); font-size:9px; letter-spacing:0.18em; text-transform:uppercase; color:var(--gold); margin-bottom:0.5rem; margin-top:0.85rem; padding-bottom:0.35rem; border-bottom:1px solid var(--gold-border); }
.bk-journey-ep-label:first-child { margin-top:0; }


/* ── Booking In Progress — floating pill ── */
.bk-progress-pill {
  position: fixed;
  bottom: max(6.5rem, calc(env(safe-area-inset-bottom,0px) + 6.5rem));
  left: 1.25rem;
  z-index: 498;
  background: rgba(28,20,10,0.88);
  color: #f7f0e6;
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 9px 16px 9px 14px;
  border-radius: 100px;
  display: none;
  align-items: center;
  gap: 0.6rem;
  cursor: pointer;
  box-shadow: 0 3px 12px rgba(28,20,10,0.28);
  transition: background var(--t), transform var(--t);
  max-width: calc(100vw - 10rem);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border: 1px solid rgba(184,129,58,0.35);
}
.bk-progress-pill.visible { display: flex; }
.bk-progress-pill:hover { background: rgba(44,36,24,0.95); transform: translateY(-1px); }
.bk-progress-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
  animation: bkPulse 1.8s ease-in-out infinite;
}
@keyframes bkPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.7); }
}
.bk-progress-text { flex: 1; }
.bk-progress-open {
  font-size: 9px;
  opacity: 0.65;
  margin-left: 0.3rem;
  text-transform: none;
  letter-spacing: 0;
}


/* ── Save & Browse More Sparks button (in booking footer) ── */
.bk-browse-btn {
  width: 100%;
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 10px;
  border-radius: 100px;
  border: 1.5px solid rgba(184,129,58,0.45);
  background: transparent;
  color: var(--gold);
  cursor: pointer;
  margin-bottom: 0.5rem;
  transition: all var(--t);
  display: none;
}
.bk-browse-btn.visible { display: block; }
.bk-browse-btn:hover { background: var(--gold-wash); border-color: var(--gold); }

