/* ============================================================
   OttoLux V2, "L'Atelier Obsidienne" design system
   Shared across every page. Canonical source of all tokens.
   ============================================================ */
:root{
  --noir:#0A0A0B; --noir-2:#111113; --noir-3:#19191C; --noir-4:#202024;
  --or:#D4AF37; --or-fonce:#9A7B1E; --or-pale:#E8CC7A; --or-glow:rgba(212,175,55,.25);
  --ivoire:#F4EFE6; --ivoire-60:rgba(244,239,230,.6); --ivoire-40:rgba(244,239,230,.4); --ivoire-20:rgba(244,239,230,.2);
  --hair:rgba(212,175,55,.22); --hair-soft:rgba(244,239,230,.1);
  --display:'Marcellus',serif; --body:'Jost',sans-serif;
  --ease:cubic-bezier(.22,.8,.24,1); --ease-out:cubic-bezier(.16,1,.3,1);
  --maxw:1280px; --pad:6vw;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--noir)}
body{background:transparent;color:var(--ivoire);font-family:var(--body);font-weight:300;overflow-x:hidden;line-height:1.5}

/* ---------- liquid-gold field: one fixed WebGL background site-wide ----------
   Normal sections paint solid noir and occlude it; .gold-bg sections reveal it
   through a translucent pool. Its intensity is driven by what is in view. */
#goldfield{position:fixed;inset:0;width:100%;height:100%;z-index:-1;display:block;pointer-events:none}
section{background:var(--noir)}            /* solid by default, hides the field */
footer{background:var(--noir)}
.gold-bg{background:linear-gradient(180deg,var(--noir) 0%,rgba(10,10,11,.5) 16%,rgba(10,10,11,.5) 84%,var(--noir) 100%)!important;position:relative}
.gold-bg .sec-head h2,.gold-bg h2{text-shadow:0 2px 30px rgba(10,10,11,.6)}
@media (prefers-reduced-motion: reduce){#goldfield{opacity:.5}}
::selection{background:var(--or);color:var(--noir)}
img{display:block;max-width:100%}
a{color:inherit}
h1,h2,h3,h4,.display{font-family:var(--display);font-weight:400;letter-spacing:.01em}

/* grain + vignette atmosphere on every page */
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E")}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem var(--pad);transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s}
nav.scrolled{background:rgba(10,10,11,.82);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);padding:.9rem var(--pad);border-bottom:1px solid var(--hair)}
.wordmark{font-family:var(--display);font-size:1.35rem;letter-spacing:.42em;text-decoration:none;color:var(--ivoire)}
.wordmark b{color:var(--or);font-weight:400}
.wordmark small{display:block;font-family:var(--body);font-size:.55rem;letter-spacing:.34em;color:var(--ivoire-60);margin-top:.15rem}
.nav-links{display:flex;gap:2rem;align-items:center;list-style:none}
.nav-links a{color:var(--ivoire-60);text-decoration:none;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;transition:color .3s;position:relative}
.nav-links a:hover{color:var(--or)}
.nav-links a.active{color:var(--ivoire)}
.lang-toggle{border:1px solid var(--hair);background:none;color:var(--ivoire);font-family:var(--body);font-size:.72rem;letter-spacing:.2em;padding:.45rem .9rem;cursor:pointer;transition:all .3s}
.lang-toggle:hover{border-color:var(--or);color:var(--or)}
.nav-cta{border:1px solid var(--or);color:var(--or)!important;padding:.5rem 1.2rem}
.nav-cta:hover{background:var(--or);color:var(--noir)!important}
.burger{display:none;background:none;border:none;color:var(--ivoire);font-size:1.5rem;cursor:pointer}
@media(max-width:920px){
  .nav-links{position:fixed;inset:0;background:rgba(8,8,9,.97);backdrop-filter:blur(20px);flex-direction:column;justify-content:center;gap:2.4rem;transform:translateX(100%);transition:transform .5s var(--ease)}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.1rem}
  .burger{display:block;z-index:101}
}

/* ---------- buttons ---------- */
.btn{font-family:var(--body);font-size:.8rem;letter-spacing:.26em;text-transform:uppercase;text-decoration:none;padding:1.05rem 2.2rem;transition:all .35s var(--ease);cursor:pointer;display:inline-block;border:1px solid transparent}
.btn-or{background:var(--or);color:var(--noir);border-color:var(--or)}
.btn-or:hover{background:transparent;color:var(--or);box-shadow:0 0 42px var(--or-glow)}
.btn-ghost{background:transparent;color:var(--ivoire);border-color:rgba(244,239,230,.28)}
.btn-ghost:hover{border-color:var(--or);color:var(--or)}

/* ---------- hero (home, full WebGL) ---------- */
header.hero{position:relative;height:100svh;min-height:640px;display:flex;align-items:center;overflow:hidden}
#gold,.hero-media{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:cover}
.hero-media{z-index:1;opacity:0;transition:opacity 1.2s var(--ease)}
.hero-media.loaded{opacity:1}
.hero-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg,rgba(10,10,11,.92) 0%,rgba(10,10,11,.72) 30%,rgba(10,10,11,.2) 60%,transparent 100%),
  linear-gradient(180deg,rgba(10,10,11,.55) 0%,transparent 28%,transparent 62%,rgba(10,10,11,.98) 100%)}
.hero-inner{position:relative;z-index:2;padding:0 var(--pad);max-width:var(--maxw);margin:0 auto;width:100%;will-change:transform}
.kicker{display:inline-flex;align-items:center;gap:.8rem;font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--or-pale);margin-bottom:1.7rem;text-shadow:0 1px 16px rgba(0,0,0,.7)}
.kicker::before{content:"";width:46px;height:1px;background:var(--or)}
h1{font-size:clamp(3rem,8.5vw,7.4rem);line-height:.96;letter-spacing:.01em;text-shadow:0 4px 50px rgba(0,0,0,.85),0 1px 3px rgba(0,0,0,.5)}
h1 .top-line{display:block;color:var(--ivoire)}
h1 .gold-line{display:block;background:linear-gradient(120deg,var(--or-pale),var(--or) 45%,var(--or-fonce));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--or);padding-bottom:.08em}
.hero-sub{margin-top:1.8rem;max-width:36rem;font-size:1.12rem;line-height:1.8;color:var(--ivoire);text-shadow:0 1px 20px rgba(0,0,0,.8)}
.hero-ctas{display:flex;gap:1.1rem;margin-top:2.6rem;flex-wrap:wrap}
.hero-meta{position:absolute;z-index:2;left:var(--pad);right:var(--pad);bottom:3.2rem;display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap}
.counters{display:flex;gap:3.2rem}
.counter .num{font-family:var(--display);font-size:2rem;color:var(--or)}
.counter .lab{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ivoire-60);margin-top:.2rem}
.scroll-hint{font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivoire-20);display:flex;align-items:center;gap:.7rem}
.scroll-hint::after{content:"";width:1px;height:42px;background:linear-gradient(var(--or),transparent);animation:drip 2.2s infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- page hero (subpages, cinematic still/clip) ---------- */
header.page-hero{position:relative;height:62svh;min-height:440px;display:flex;align-items:flex-end;overflow:hidden}
header.page-hero .hero-media,header.page-hero .ph-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
header.page-hero .ph-poster{background-size:cover;background-position:center}
header.page-hero .hero-veil{z-index:1}
.page-hero .ph-inner{position:relative;z-index:2;padding:0 var(--pad) 4rem;max-width:var(--maxw);margin:0 auto;width:100%}
.page-hero h1{font-size:clamp(2.4rem,6vw,5rem)}
.page-hero .ph-sub{margin-top:1rem;max-width:40rem;color:var(--ivoire-60);font-size:1.05rem;line-height:1.7}
.breadcrumb{font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;color:var(--or-pale);margin-bottom:1.2rem}
.breadcrumb a{text-decoration:none;opacity:.7}.breadcrumb a:hover{opacity:1}

/* ---------- sections ---------- */
section{padding:8rem var(--pad);position:relative;max-width:calc(var(--maxw) + 12vw);margin:0 auto}
.sec-head{display:flex;align-items:baseline;gap:2.4rem;margin-bottom:4rem;flex-wrap:wrap}
.sec-head .no{font-family:var(--display);color:var(--or);font-size:.95rem;letter-spacing:.3em}
.sec-head h2{font-size:clamp(2rem,4.6vw,3.6rem)}
.sec-head .rule{flex:1;height:1px;background:var(--hair);min-width:60px}
.lead{max-width:46rem;font-size:1.15rem;line-height:1.85;color:var(--ivoire-60)}

/* services grid */
.services{display:grid;grid-template-columns:repeat(12,1fr);gap:1.2rem}
.svc{grid-column:span 4;border:1px solid var(--hair);padding:2.4rem 2rem 3.2rem;position:relative;overflow:hidden;background:linear-gradient(180deg,var(--noir-2),var(--noir));transition:transform .5s var(--ease),border-color .5s;text-decoration:none;color:var(--ivoire);min-height:230px}
.svc.wide{grid-column:span 8}
.svc::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 200px at var(--mx,50%) var(--my,0%),var(--or-glow),transparent 70%);opacity:0;transition:opacity .4s}
.svc:hover{transform:translateY(-6px);border-color:rgba(212,175,55,.5)}
.svc:hover::before{opacity:1}
.svc .idx{font-size:.66rem;letter-spacing:.3em;color:var(--or-fonce)}
.svc h3{font-size:1.45rem;margin:.9rem 0 .6rem}
.svc p{font-size:.9rem;line-height:1.7;color:var(--ivoire-60);max-width:36rem}
.svc .price-tag{position:absolute;bottom:1.4rem;left:2rem;font-family:var(--display);color:var(--or);font-size:1.1rem}
.svc .go{position:absolute;right:1.6rem;bottom:1.4rem;color:var(--or);font-size:1.1rem;opacity:0;transform:translateX(-8px);transition:all .35s}
.svc:hover .go{opacity:1;transform:none}
@media(max-width:980px){.svc,.svc.wide{grid-column:span 12}}

/* before / after blade */
.ba-wrap{max-width:1100px;margin:0 auto}
.ba{position:relative;aspect-ratio:16/9;overflow:hidden;border:1px solid var(--hair);user-select:none;touch-action:none;cursor:ew-resize;background:var(--noir-3)}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .after{clip-path:inset(0 0 0 var(--cut,50%))}
.ba .blade{position:absolute;top:0;bottom:0;left:var(--cut,50%);width:1px;background:var(--or);z-index:3}
.ba .blade::after{content:"\25C2 \25B8";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--noir);border:1px solid var(--or);color:var(--or);font-size:.7rem;padding:.55rem .7rem;border-radius:999px;white-space:nowrap}
.ba-tags{display:flex;justify-content:space-between;margin-top:1rem;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivoire-60)}
.ba-tags b{color:var(--or);font-weight:500}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
.step{border-top:1px solid var(--hair);padding-top:1.4rem;position:relative}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--display);color:var(--or);font-size:1.6rem;display:block;margin-bottom:.8rem}
.step h4{font-size:1.05rem;margin-bottom:.5rem}
.step p{font-size:.86rem;color:var(--ivoire-60);line-height:1.7}
@media(max-width:880px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}

/* pricing tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;align-items:stretch}
.tier{border:1px solid var(--hair);padding:2.8rem 2.2rem;background:var(--noir-2);position:relative;display:flex;flex-direction:column;transition:transform .5s var(--ease),border-color .5s}
.tier:hover{transform:translateY(-8px);border-color:rgba(212,175,55,.55)}
.tier.featured{background:linear-gradient(180deg,#171407,var(--noir-2));border-color:var(--or)}
.tier .badge{position:absolute;top:-1px;right:-1px;background:var(--or);color:var(--noir);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;padding:.4rem .8rem}
.tier .tname{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--or-pale)}
.tier .price{font-family:var(--display);font-size:3rem;margin:1.1rem 0 .2rem}
.tier .price sup{font-size:1.1rem;color:var(--or)}
.tier .pnote{font-size:.78rem;color:var(--ivoire-40);margin-bottom:1.6rem}
.tier ul{list-style:none;display:grid;gap:.65rem;margin-bottom:2.2rem}
.tier li{font-size:.88rem;color:var(--ivoire-60);padding-left:1.4rem;position:relative}
.tier li::before{content:"\00B7";color:var(--or);position:absolute;left:0;font-size:1.4rem;line-height:.9}
.tier .btn{margin-top:auto;text-align:center}
.honesty{text-align:center;margin-top:2.6rem;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ivoire-40)}
.honesty b{color:var(--or);font-weight:500}
@media(max-width:980px){.tiers{grid-template-columns:1fr}}

/* proof */
.proof{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start}
.rating .stars{color:var(--or);font-size:1.4rem;letter-spacing:.3rem}
.rating .big{font-family:var(--display);font-size:5.4rem;line-height:1}
.rating a{color:var(--or);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;border-bottom:1px solid var(--or-fonce);padding-bottom:.2rem}
.quotes{display:grid;gap:1.2rem}
.quote{border-left:1px solid var(--or-fonce);padding:.4rem 0 .4rem 1.6rem;font-size:.95rem;line-height:1.75;color:var(--ivoire-60)}
.quote cite{display:block;margin-top:.7rem;font-style:normal;font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:var(--or-pale)}
@media(max-width:980px){.proof{grid-template-columns:1fr}}

/* gallery grid */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gal figure{position:relative;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--hair);background:var(--noir-3)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gal figure:hover img{transform:scale(1.07)}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:1rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ivoire);background:linear-gradient(transparent,rgba(10,10,11,.85));opacity:0;transition:opacity .4s}
.gal figure:hover figcaption{opacity:1}
@media(max-width:780px){.gal{grid-template-columns:1fr 1fr}}

/* faq */
.faq{max-width:820px;margin:0 auto}
.faq details{border-bottom:1px solid var(--hair);padding:1.4rem 0}
.faq summary{cursor:pointer;list-style:none;font-family:var(--display);font-size:1.2rem;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--or);font-size:1.4rem;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin-top:1rem;color:var(--ivoire-60);line-height:1.8;font-size:.95rem}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split .media{aspect-ratio:4/5;border:1px solid var(--hair);overflow:hidden;background:var(--noir-3);position:relative}
.split .media img{width:100%;height:100%;object-fit:cover}
.split h3{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:1.2rem}
.split p{color:var(--ivoire-60);line-height:1.85;margin-bottom:1rem}
@media(max-width:880px){.split{grid-template-columns:1fr}}

/* booking band */
.band{background:linear-gradient(180deg,var(--noir),#131006 55%,var(--noir));text-align:center;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);max-width:none}
.band h2{font-size:clamp(2.2rem,5vw,4rem);max-width:22ch;margin:0 auto}
.band p{margin:1.4rem auto 2.6rem;color:var(--ivoire-60);max-width:44ch;line-height:1.8}

/* footer */
footer{padding:4.5rem var(--pad) 3rem;border-top:1px solid var(--hair);display:flex;justify-content:space-between;gap:3rem;flex-wrap:wrap;max-width:none}
footer .col h4{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--or-pale);margin-bottom:1rem}
footer .col p,footer .col a{display:block;color:var(--ivoire-60);text-decoration:none;font-size:.9rem;line-height:2}
footer .col a:hover{color:var(--or)}
.legal{width:100%;margin-top:2.5rem;padding-top:1.6rem;border-top:1px solid rgba(212,175,55,.1);display:flex;justify-content:space-between;font-size:.7rem;color:var(--ivoire-20);letter-spacing:.12em;flex-wrap:wrap;gap:1rem}

/* voice concierge orb */
.orb{position:fixed;right:2rem;bottom:2rem;z-index:500;width:64px;height:64px;border-radius:50%;cursor:pointer;border:1px solid var(--or);background:radial-gradient(circle at 32% 30%,#f0d77b,var(--or) 42%,#6b5414 100%);box-shadow:0 0 36px var(--or-glow),inset 0 0 18px rgba(0,0,0,.35);animation:breathe 3.6s infinite var(--ease)}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
.orb::after{content:"";position:absolute;inset:-9px;border-radius:50%;border:1px solid rgba(212,175,55,.35);animation:ring 3.6s infinite}
@keyframes ring{0%{transform:scale(.9);opacity:0}40%{opacity:1}100%{transform:scale(1.25);opacity:0}}
.voice-panel{position:fixed;right:2rem;bottom:6.4rem;z-index:500;width:min(360px,calc(100vw - 4rem));background:rgba(13,13,15,.92);backdrop-filter:blur(20px);border:1px solid var(--hair);padding:1.8rem;transform:translateY(14px);opacity:0;pointer-events:none;transition:all .45s var(--ease)}
.voice-panel.open{transform:none;opacity:1;pointer-events:auto}
.voice-panel h3{font-size:1.05rem}
.voice-panel .live{display:inline-flex;align-items:center;gap:.45rem;font-size:.62rem;letter-spacing:.3em;color:var(--or-pale);text-transform:uppercase;margin-bottom:.9rem}
.voice-panel .live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--or);animation:breathe 1.6s infinite}
.voice-panel p{font-size:.84rem;line-height:1.7;color:var(--ivoire-60);margin-bottom:1.2rem}
.wave{display:flex;gap:4px;align-items:flex-end;height:34px;margin-bottom:1.2rem}
.wave i{width:3px;background:var(--or);height:30%;animation:wv 1s infinite var(--ease)}
.wave i:nth-child(2n){animation-delay:.15s}.wave i:nth-child(3n){animation-delay:.3s}.wave i:nth-child(5n){animation-delay:.45s}
@keyframes wv{0%,100%{height:18%}50%{height:96%}}
.voice-panel .btn{width:100%;text-align:center}
.voice-status{font-size:.74rem;letter-spacing:.04em;color:var(--or-pale);min-height:1.1em;margin-bottom:.7rem;text-align:center}
.voice-log{max-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.voice-log:empty{display:none}
.vmsg{font-size:.82rem;line-height:1.5;padding:.5rem .8rem;border-radius:2px;max-width:90%}
.vmsg.me{align-self:flex-end;background:rgba(212,175,55,.12);color:var(--ivoire)}
.vmsg.ai{align-self:flex-start;background:rgba(244,239,230,.06);color:var(--ivoire-60)}
.vmsg.sys{align-self:center;color:var(--or);letter-spacing:.18em;font-size:.72rem}
.voice-panel.speaking .wave i{animation-duration:.7s}
#voiceAudio{display:none}

/* booking modal */
.bk-overlay{position:fixed;inset:0;z-index:800;background:rgba(5,5,6,.78);backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.bk-overlay.open{opacity:1;pointer-events:auto}
.bk{width:min(680px,calc(100vw - 2.4rem));max-height:88svh;overflow:auto;background:var(--noir-2);border:1px solid var(--hair);padding:2.6rem;transform:translateY(18px);transition:transform .4s var(--ease)}
.bk-overlay.open .bk{transform:none}
.bk h3{font-size:1.6rem;margin-bottom:.4rem}
.bk .bk-mode{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivoire-20);margin-bottom:1.6rem}
.bk .bk-mode.live{color:var(--or-pale)}
.bk label{display:block;font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ivoire-60);margin:1.3rem 0 .5rem}
.bk select,.bk input{width:100%;background:var(--noir);border:1px solid var(--hair);color:var(--ivoire);font-family:var(--body);font-size:.95rem;padding:.85rem 1rem;outline:none;transition:border-color .3s}
.bk select:focus,.bk input:focus{border-color:var(--or)}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:.55rem;margin-top:.5rem}
.slot{border:1px solid var(--hair);background:none;color:var(--ivoire);font-family:var(--body);font-size:.85rem;padding:.6rem 0;cursor:pointer;transition:all .25s;text-align:center}
.slot:hover{border-color:var(--or);color:var(--or)}
.slot.sel{background:var(--or);color:var(--noir);border-color:var(--or)}
.slots-empty{color:var(--ivoire-20);font-size:.85rem;padding:.6rem 0}
.bk .row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.bk .bk-actions{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.bk .bk-close{position:sticky;top:0;float:right;background:none;border:none;color:var(--ivoire-60);font-size:1.5rem;cursor:pointer}
.bk .bk-close:hover{color:var(--or)}
.bk-confirm{text-align:center;padding:2rem 0}
.bk-confirm .tick{font-family:var(--display);font-size:3rem;color:var(--or)}
.bk-confirm .ticket{font-family:var(--display);font-size:1.6rem;letter-spacing:.18em;margin:.8rem 0 .3rem}
.bk-confirm p{color:var(--ivoire-60);font-size:.9rem}
@media(max-width:560px){.bk{padding:1.6rem}.bk .row2{grid-template-columns:1fr}}

/* ---------- branded preloader ---------- */
#preload{position:fixed;inset:0;z-index:9500;background:var(--noir);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.4rem;transition:opacity .7s var(--ease),visibility .7s}
#preload.done{opacity:0;visibility:hidden}
#preload .mk{width:62px;height:62px;animation:spin 2.4s linear infinite}
#preload .mk circle.ring{fill:none;stroke:var(--or);stroke-width:4;stroke-dasharray:90 200;stroke-linecap:round}
#preload .pw{font-family:var(--display);letter-spacing:.5em;font-size:.8rem;color:var(--or-pale);padding-left:.5em}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- custom gold cursor (pointer devices) ---------- */
@media (hover:hover) and (pointer:fine){
  body.cursor-on{cursor:none}
  #cursor{position:fixed;top:0;left:0;z-index:9600;pointer-events:none;width:34px;height:34px;margin:-17px 0 0 -17px;
    border:1px solid var(--or);border-radius:50%;mix-blend-mode:screen;transition:width .25s var(--ease),height .25s var(--ease),margin .25s var(--ease),opacity .3s,background .25s,border-color .25s}
  #cursor.dot{width:7px;height:7px;margin:-3.5px 0 0 -3.5px;background:var(--or);border-color:var(--or)}
  #cursor.lift{width:58px;height:58px;margin:-29px 0 0 -29px;background:var(--or-glow);border-color:var(--or-pale)}
  #cursor.hidden{opacity:0}
  a,button,.svc,.tier,.slot,summary,.ba,.gal figure{cursor:none}
}

/* ---------- magnetic CTA + card tilt ---------- */
.btn{will-change:transform}
.svc,.tier{will-change:transform;transform-style:preserve-3d}

/* ---------- 5D immersive scroll scenes ---------- */
.scene{position:relative;height:118svh;min-height:680px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--noir);padding:0}
.scene .layer{position:absolute;inset:-8% -4%;background-size:cover;background-position:center;will-change:transform}
.scene .layer.img{z-index:0}
.scene .scrim{position:absolute;inset:0;z-index:1;background:radial-gradient(80% 70% at 50% 50%,transparent 20%,rgba(10,10,11,.7) 78%),linear-gradient(180deg,var(--noir),transparent 22%,transparent 78%,var(--noir))}
.scene .scene-copy{position:relative;z-index:2;max-width:920px;text-align:center;padding:0 var(--pad);will-change:transform,opacity}
.scene .scene-kicker{font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;color:var(--or-pale);margin-bottom:1.4rem}
.scene h2{font-size:clamp(2.4rem,7vw,6rem);line-height:1.02}
.scene h2 em{font-style:normal;color:var(--or);display:block}
.scene .scene-sub{margin:1.6rem auto 0;max-width:42rem;font-size:1.1rem;line-height:1.8;color:var(--ivoire-60)}
.scene .scene-fig{position:absolute;z-index:2;bottom:2.4rem;left:var(--pad);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ivoire-40)}

/* brand watermark monogram in section corners */
.wm{position:absolute;right:var(--pad);top:3rem;width:40px;height:40px;opacity:.14;z-index:2;pointer-events:none}

/* legal documents */
.legal-doc{max-width:780px;margin:0 auto}
.legal-sec{padding:1.6rem 0;border-bottom:1px solid var(--hair-soft)}
.legal-sec h3{font-size:1.25rem;color:var(--ivoire);margin-bottom:.7rem}
.legal-sec p{color:var(--ivoire-60);line-height:1.85;font-size:.95rem}

/* consent notice */
.consent{position:fixed;left:1.4rem;bottom:1.4rem;z-index:520;max-width:min(420px,calc(100vw - 2.8rem));
  background:rgba(13,13,15,.94);backdrop-filter:blur(16px);border:1px solid var(--hair);padding:1rem 1.2rem;
  display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;font-size:.8rem;color:var(--ivoire-60);
  transform:translateY(140%);transition:transform .5s var(--ease)}
.consent.show{transform:none}
.consent a{color:var(--or-pale);text-decoration:none;white-space:nowrap}
.consent button{background:var(--or);color:var(--noir);border:none;font-family:var(--body);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;padding:.5rem .9rem;cursor:pointer;white-space:nowrap}
@media(max-width:520px){.consent{left:.8rem;right:.8rem;bottom:.8rem}}

/* ============================================================
   iOS / touch adaptation + safe areas + mobile hero (no overlap)
   ============================================================ */
nav{padding-top:max(1.4rem,env(safe-area-inset-top));padding-left:max(var(--pad),env(safe-area-inset-left));padding-right:max(var(--pad),env(safe-area-inset-right))}
nav.scrolled{padding-top:max(.9rem,env(safe-area-inset-top))}
.orb{right:max(2rem,env(safe-area-inset-right));bottom:max(2rem,env(safe-area-inset-bottom))}
.voice-panel{right:max(2rem,env(safe-area-inset-right));bottom:max(6.4rem,calc(env(safe-area-inset-bottom) + 4.4rem))}
.consent{left:max(1.4rem,env(safe-area-inset-left));bottom:max(1.4rem,env(safe-area-inset-bottom))}

/* the hero counters must never sit on top of the CTAs. On narrow or short
   viewports the hero becomes a vertical column and the meta flows below. */
@media (max-width:820px), (max-height:720px){
  header.hero{flex-direction:column;justify-content:center;align-items:stretch;height:auto;min-height:100svh;
    padding-top:calc(env(safe-area-inset-top) + 7rem);padding-bottom:calc(env(safe-area-inset-bottom) + 2.4rem)}
  .hero-inner{flex:0 0 auto}
  .hero-meta{position:static;left:auto;right:auto;bottom:auto;margin-top:2.8rem;padding:0 var(--pad);
    flex-direction:row;flex-wrap:wrap;align-items:flex-start;gap:1.6rem 2.4rem}
  .scroll-hint{display:none}
  .counters{gap:2rem 2.4rem;flex-wrap:wrap}
}
@media (max-width:480px){
  .counter .num{font-size:1.7rem}
  .hero-ctas{gap:.8rem}
  .hero-ctas .btn{flex:1 1 auto;text-align:center}
}

/* touch devices: no custom cursor, comfortable tap targets, no sticky hover */
@media (hover:none), (pointer:coarse){
  #cursor{display:none!important}
  body.cursor-on{cursor:auto}
  a,button,.slot,summary{cursor:pointer}
  .btn{padding:1.1rem 2rem}
  .nav-links a{padding:.4rem 0}
  .svc{min-height:auto}
  .svc .go{opacity:1;transform:none}            /* arrows always visible, no hover needed */
  .gal figcaption{opacity:1;background:linear-gradient(transparent,rgba(10,10,11,.65))}
  .scene{height:96svh;min-height:560px}          /* lighter parallax stage on phones */
}
/* iOS momentum scroll inside the booking slots + voice log */
.slots,.voice-log,.bk{-webkit-overflow-scrolling:touch}

/* reveals */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}.reveal[data-d="5"]{transition-delay:.4s}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .orb,.orb::after,.wave i,.scroll-hint::after,.hero-media{animation:none}
}
