/* ═══════════════════════ SKY ROOF · v2 ═══════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#040405; --bg-soft:#0a0a0d; --panel:#0d0d12; --panel-2:#15151d;
  --ink:#f5f3ee; --muted:rgba(245,243,238,.56); --faint:rgba(245,243,238,.30);
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.055);
  --gold:#d9b25a;
  --gold-grad:linear-gradient(135deg,#fbeeb6 0%,#dcae54 40%,#f6dc8a 60%,#b4822e 100%);
  --irid:linear-gradient(110deg,#ff3eb5 0%,#b13cf0 26%,#6b62ff 50%,#27c6e6 74%,#33f0c4 94%);
  --display:'Archivo';
  --maxw:1280px;
  --pad:clamp(20px,5vw,84px);
  --ease:cubic-bezier(.22,1,.36,1);
}
body[data-accent="gold"]{--irid:linear-gradient(135deg,#fbeeb6,#dcae54 40%,#f6dc8a 62%,#b4822e)}
body[data-accent="aurora"]{--irid:linear-gradient(110deg,#33f0c4,#27c6e6 26%,#6b62ff 52%,#b13cf0 78%,#ff3eb5)}

/* ── SUNSET THEME ── warm golden-hour palette ── */
body[data-theme="sunset"]{
  --bg:#150a0d; --bg-soft:#1d0f12; --panel:#22141a; --panel-2:#2c1a22;
  --ink:#fdf2ea; --muted:rgba(253,242,234,.6); --faint:rgba(253,242,234,.34);
  --line:rgba(255,228,210,.12); --line-2:rgba(255,228,210,.07);
  --gold:#e8b65f;
  --gold-grad:linear-gradient(135deg,#ffe6ad,#e9b760 40%,#ffd98a 62%,#c5882f);
}
body[data-theme="sunset"][data-accent="iridescent"]{--irid:linear-gradient(110deg,#ffd27a 0%,#ff9e5e 24%,#ff6b8a 50%,#d75cc4 76%,#7d5cf0 96%)}
body[data-theme="sunset"] .aurora{background:radial-gradient(125% 90% at 50% 118%,#5a1e14,#2a0f12 46%,#150a0d 72%)}
body[data-theme="sunset"] .blob-mag{background:radial-gradient(circle,#ff7a4d,transparent 66%)}
body[data-theme="sunset"] .blob-vio{background:radial-gradient(circle,#ff5e8c,transparent 66%)}
body[data-theme="sunset"] .blob-cya{background:radial-gradient(circle,#ffae4d,transparent 66%);opacity:.5}
body[data-theme="sunset"] .blob-gold{background:radial-gradient(circle,#ffce6a,transparent 64%);opacity:.34}
body[data-theme="sunset"] .stars{opacity:.32}

html{scroll-behavior:smooth;background:var(--bg)}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--display),system-ui,sans-serif;font-size:17px;line-height:1.62;
  -webkit-font-smoothing:antialiased;overflow-x:clip;
}
body.lock{overflow:hidden;height:100vh}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:rgba(177,60,240,.4);color:#fff}

/* ── cursor (desktop) ── */
@media(hover:hover) and (pointer:fine){
  body[data-cursor="on"]{cursor:none}
  body[data-cursor="on"] a,body[data-cursor="on"] button,body[data-cursor="on"] input{cursor:none}
}
.cur{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;mix-blend-mode:screen;opacity:0;transition:opacity .3s}
.cur-dot{width:7px;height:7px;background:var(--gold);transform:translate(-50%,-50%)}
.cur-ring{width:38px;height:38px;border:1px solid rgba(245,243,238,.45);transform:translate(-50%,-50%);transition:width .25s,height .25s,opacity .3s,background .25s,border-color .25s}
.cur-ring.hot{width:64px;height:64px;background:radial-gradient(circle,rgba(217,178,90,.18),transparent 70%);border-color:rgba(217,178,90,.6)}
body.cursor-ready .cur{opacity:1}

/* ═══════ LOADER ═══════ */
.loader{position:fixed;inset:0;z-index:9000;background:var(--bg);display:grid;place-items:center;transition:opacity .7s var(--ease)}
.loader.done{opacity:0;pointer-events:none}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:1.4rem}
.loader-mark{width:84px;height:84px;border-radius:16px;filter:drop-shadow(0 0 40px rgba(177,60,240,.4));animation:floaty 3s ease-in-out infinite}
.loader-bar{width:180px;height:2px;background:var(--line);overflow:hidden;border-radius:2px}
.loader-bar span{display:block;height:100%;width:0;background:var(--gold-grad)}
.loader-pct{font-family:'Space Mono',monospace;font-size:.8rem;letter-spacing:.3em;color:var(--faint)}
.loader-pct i{font-style:normal}
@keyframes floaty{0%,100%{transform:translateY(-4px)}50%{transform:translateY(4px)}}

/* ═══════ AURORA ═══════ */
.aurora{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:radial-gradient(120% 80% at 50% -10%,#0c0a12,#040405 60%)}
.blob{position:absolute;border-radius:50%;filter:blur(110px);mix-blend-mode:screen;opacity:.55;will-change:transform}
.blob-mag{width:46vw;height:46vw;top:-8vw;right:2vw;background:radial-gradient(circle,#d6379e,transparent 66%);animation:drift1 19s ease-in-out infinite alternate}
.blob-vio{width:42vw;height:42vw;top:18vw;left:-10vw;background:radial-gradient(circle,#7b3df0,transparent 66%);animation:drift2 23s ease-in-out infinite alternate}
.blob-cya{width:40vw;height:40vw;bottom:-12vw;left:24vw;background:radial-gradient(circle,#1f8fd6,transparent 66%);opacity:.4;animation:drift3 27s ease-in-out infinite alternate}
.blob-gold{width:30vw;height:30vw;bottom:6vw;right:-6vw;background:radial-gradient(circle,#caa14e,transparent 64%);opacity:.28;animation:drift1 21s ease-in-out infinite alternate-reverse}
.aurora-veil{position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(4,4,5,.4) 60%,var(--bg))}
.grain{position:absolute;inset:-50%;width:200%;height:200%;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");animation:grainShift 6s steps(5) infinite}
@keyframes drift1{to{transform:translate(-6vw,5vw) scale(1.12)}}
@keyframes drift2{to{transform:translate(7vw,-4vw) scale(1.08)}}
@keyframes drift3{to{transform:translate(5vw,-6vw) scale(1.15)}}
@keyframes grainShift{0%{transform:translate(0,0)}20%{transform:translate(-3%,2%)}40%{transform:translate(2%,-3%)}60%{transform:translate(-2%,-2%)}80%{transform:translate(3%,3%)}100%{transform:translate(0,0)}}

main,.footer{position:relative;z-index:1}

/* ── starfield ── */
.stars{position:absolute;inset:0;width:100%;height:100%;opacity:.85;pointer-events:none}

/* ── scroll progress ── */
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:0;z-index:300;background:var(--irid);box-shadow:0 0 12px rgba(177,60,240,.6);transition:width .1s linear}

/* ── section dots ── */
.dots{position:fixed;right:clamp(14px,2.2vw,30px);top:50%;transform:translateY(-50%);z-index:180;display:flex;flex-direction:column;gap:.95rem;align-items:flex-end}
.dots a{position:relative;width:9px;height:9px;border-radius:50%;border:1px solid rgba(245,243,238,.35);transition:transform .3s var(--ease),border-color .3s,background .3s}
.dots a::after{content:attr(data-label);position:absolute;right:18px;top:50%;transform:translateY(-50%) translateX(6px);font-family:'Space Mono',monospace;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s}
.dots a:hover::after{opacity:1;transform:translateY(-50%) translateX(0)}
.dots a:hover{border-color:var(--gold)}
.dots a.is-active{background:var(--gold-grad);border-color:transparent;transform:scale(1.25)}
@media(max-width:1000px){.dots{display:none}}

/* ═══════ UTILITIES ═══════ */
.glow{background:var(--irid);-webkit-background-clip:text;background-clip:text;color:transparent}
.glow-flow{
  background:var(--irid);background-size:230% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:flow 9s linear infinite;
  filter:drop-shadow(0 6px 44px rgba(177,60,240,.28));
}
@keyframes flow{to{background-position:230% 0}}

.kicker{display:flex;align-items:center;gap:.8rem;font-family:'Space Mono',monospace;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem}
.kicker-no{color:var(--faint);font-size:.7rem}
.section-title{font-weight:800;line-height:.98;letter-spacing:-.025em;font-size:clamp(2.1rem,5.2vw,4rem);text-wrap:balance}
.lede{color:var(--muted);font-size:clamp(1rem,1.4vw,1.18rem);max-width:48ch;margin-top:1.2rem}

/* line-mask reveal (hero) */
.line-mask{overflow:hidden;display:block}
.hero-cta.line-mask{overflow:visible}
.line-mask>*{display:inline-block;transform:translateY(115%);transition:transform 1.05s var(--ease)}
.hero-cta.line-mask{transform:translateY(40px);opacity:0;transition:transform 1s var(--ease),opacity 1s var(--ease)}
.hero-cta.line-mask>*{transform:none;transition:none}
body.ready .line-mask>*{transform:translateY(0)}
body.ready .hero-cta.line-mask{transform:none;opacity:1}
/* settle: guarantees final state even if a transition froze (inactive frame) */
body.settled .line-mask>*,body.settled .hero-cta.line-mask{transition:none!important;transform:none!important;opacity:1!important}

/* scroll reveal — opacity flips instantly (only transform transitions) so nothing freezes hidden */
.reveal{opacity:0;transform:translateY(26px);transition:transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* word highlight */
.reveal-words{font-weight:800;letter-spacing:-.02em;line-height:1.06;font-size:clamp(1.7rem,4vw,3.1rem);max-width:18ch}
.reveal-words .w{color:rgba(245,243,238,.18)}
.reveal-words .w.on{color:var(--ink)}

/* ═══════ BUTTONS ═══════ */
.btn{position:relative;display:inline-flex;align-items:center;gap:.55em;font-weight:700;font-size:.92rem;letter-spacing:.01em;padding:.95em 1.8em;border-radius:999px;cursor:pointer;border:1px solid transparent;transition:transform .3s var(--ease),box-shadow .3s,background .3s,color .3s;white-space:nowrap;will-change:transform}
.btn-gold{background:var(--gold-grad);color:#1a1206;box-shadow:0 8px 30px -12px rgba(217,178,90,.75)}
.btn-gold:hover{box-shadow:0 16px 40px -12px rgba(217,178,90,.9)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:rgba(255,255,255,.02);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.btn-ghost:hover{border-color:rgba(255,255,255,.45)}
.btn-whats{background:#0e3d2e;color:#a7f3cf;border-color:rgba(80,220,160,.35)}
.btn-whats:hover{background:#114a37}
.btn-whats .whats-ico{font-size:1.1em}
.btn-block{width:100%;justify-content:center;margin-top:.4rem}
.link-gold{font-family:'Space Mono',monospace;font-size:.82rem;letter-spacing:.06em;color:var(--gold);transition:opacity .2s,letter-spacing .3s}
.link-gold:hover{opacity:.75;letter-spacing:.12em}

/* ═══════ NAV ═══════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.1rem var(--pad);transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(5,5,8,.62);-webkit-backdrop-filter:blur(16px) saturate(1.2);backdrop-filter:blur(16px) saturate(1.2);border-bottom-color:var(--line-2);padding-top:.75rem;padding-bottom:.75rem}
.brand{display:flex;align-items:center;gap:.7rem;will-change:transform}
.brand-mark{width:40px;height:40px;border-radius:9px;object-fit:cover}
.brand-word{font-weight:800;letter-spacing:.16em;font-size:.95rem}
.nav-links{display:flex;gap:2.1rem}
.nav-links a{font-size:.9rem;color:var(--muted);position:relative;transition:color .25s}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--gold-grad);transition:width .3s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:1.1rem}
.lang-toggle{display:flex;align-items:center;gap:.35rem;background:none;border:none;cursor:pointer;font-family:'Space Mono',monospace;font-size:.78rem;letter-spacing:.1em;color:var(--faint)}
.lang-opt{transition:color .2s}.lang-opt.is-active{color:var(--ink)}
.theme-toggle{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.03);cursor:pointer;transition:border-color .25s,background .25s,transform .4s var(--ease)}
.theme-toggle:hover{border-color:var(--gold);transform:rotate(25deg)}
.theme-ico{font-size:.95rem;line-height:1;color:var(--gold)}
.theme-ico::before{content:"\2600"}
body[data-theme="sunset"] .theme-ico::before{content:"\263E"}
.nav-cta{padding:.62em 1.35em;font-size:.84rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:210}
.burger span{width:24px;height:2px;background:var(--ink);transition:transform .35s var(--ease),opacity .25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){transform:translateY(-0px) rotate(-45deg)}

/* ═══════ HERO ═══════ */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:clamp(120px,16vh,200px) var(--pad) clamp(28px,5vh,56px);position:relative}
.hero-inner{display:flex;flex-direction:column;align-items:center;text-align:center;width:min(100%,1120px)}
.hero-inner>.line-mask{width:100%}
.hero-eyebrow{font-family:'Space Mono',monospace;font-size:clamp(.66rem,1.1vw,.78rem);letter-spacing:.32em;text-transform:uppercase;color:var(--faint);margin-bottom:1.7rem}
.hero-title{font-weight:900;letter-spacing:-.035em;line-height:.82;font-size:clamp(4.2rem,17vw,15rem);display:flex;flex-direction:column}
.hero-script{font-family:'Allura',cursive;font-size:clamp(1.9rem,4.6vw,3.1rem);color:var(--gold);margin-top:.55rem;line-height:1}
.hero-script>span{white-space:nowrap}
.hero-sub{color:var(--muted);max-width:44ch;margin-top:1.5rem;font-size:clamp(1rem,1.4vw,1.16rem)}
.hero-cta{display:flex;gap:1rem;margin-top:2.1rem;flex-wrap:wrap;justify-content:center}
.hero-foot{position:absolute;left:var(--pad);right:var(--pad);bottom:clamp(20px,4vh,40px);display:flex;align-items:flex-end;justify-content:space-between;color:var(--faint)}
.scroll-cue{display:flex;align-items:center;gap:.7rem;font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--faint)}
.scroll-cue-dot{width:22px;height:36px;border:1px solid var(--line);border-radius:99px;position:relative;flex:none}
.scroll-cue-dot::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:2px;background:var(--gold);transform:translateX(-50%);animation:cue 1.7s infinite}
@keyframes cue{0%{transform:translate(-50%,0);opacity:1}70%{transform:translate(-50%,13px);opacity:0}100%{opacity:0}}
.hero-meta{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.16em;display:flex;gap:.6rem;text-transform:uppercase}
.hero-meta .dot{color:var(--gold)}

/* ═══════ TICKER ═══════ */
.ticker{border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);overflow:hidden;padding:1.15rem 0;background:rgba(255,255,255,.012)}
.ticker-row{display:flex;align-items:center;gap:2.4rem;width:max-content;animation:scrollx 32s linear infinite}
.ticker-row span{font-weight:800;font-size:1.55rem;letter-spacing:.02em;opacity:.9}
.ticker-row i{color:var(--gold);font-style:normal;font-size:.85rem}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ═══════ INTRO ═══════ */
.intro{max-width:var(--maxw);margin:0 auto;padding:clamp(90px,15vh,180px) var(--pad) clamp(60px,9vh,120px)}
.intro-stats{display:flex;gap:clamp(2rem,6vw,5rem);margin-top:clamp(3rem,7vw,5.5rem);flex-wrap:wrap}
.stat{display:flex;flex-direction:column}
.stat-top{display:inline-flex;align-items:baseline}
.stat-num{font-weight:900;font-size:clamp(2.8rem,6vw,4.4rem);line-height:.9}
.stat-suf{font-weight:900;font-size:clamp(2.8rem,6vw,4.4rem);line-height:.9}
.stat-label{font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-top:.7rem}

/* ═══════ EXPERIENCE ═══════ */
.exp{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,9vh,120px) var(--pad)}
.exp-head{margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.card{position:relative;border:1px solid var(--line);border-radius:18px;padding:2rem 1.9rem 2.2rem;background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.004));overflow:hidden;transition:border-color .5s,box-shadow .5s;will-change:transform;transform-style:preserve-3d}
.card:hover{border-color:rgba(255,255,255,.24);box-shadow:0 30px 60px -30px rgba(177,60,240,.45)}
.card>*{transform:translateZ(20px)}
.card-no{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.14em;color:var(--gold)}
.card-t{font-weight:700;font-size:1.45rem;letter-spacing:-.01em;margin:1.1rem 0 .7rem}
.card p{color:var(--muted);font-size:.97rem}
.card-glow{position:absolute;inset:auto -30% -60% auto;width:70%;height:120%;background:var(--irid);filter:blur(70px);opacity:0;transition:opacity .5s;pointer-events:none}
.card:hover .card-glow{opacity:.22}

/* ═══════ EVENTS · horizontal ═══════ */
.events{position:relative;background:linear-gradient(180deg,transparent,rgba(255,255,255,.012),transparent)}
.events-sticky{display:flex;flex-direction:column;justify-content:center;gap:clamp(1.6rem,3vw,2.6rem);padding:clamp(60px,9vh,110px) 0;min-height:auto}
.events-head{padding:0 var(--pad);position:relative}
.events-hint{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.2em;color:var(--faint);margin-top:1rem;text-transform:uppercase}
.events-track{display:flex;gap:1.3rem;padding:0 var(--pad);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.events-track::-webkit-scrollbar{display:none}
.ev{flex:0 0 auto;width:min(86vw,420px);scroll-snap-align:start;border:1px solid var(--line);border-radius:20px;background:var(--panel);overflow:hidden;display:flex;flex-direction:column}
.ev-feature{width:min(92vw,760px);flex-direction:row}
.ev-poster{flex:0 0 50%;overflow:hidden}
.ev-poster img{width:100%;height:100%;object-fit:cover;min-height:340px}
.ev-feature .ev-body{flex:1;justify-content:center}
.ev-img{flex:0 0 auto;height:230px;border-radius:0;border:none}
.ev-body{padding:1.7rem 1.8rem 1.9rem;display:flex;flex-direction:column;gap:.5rem}
.ev-day{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.ev-name{font-weight:800;font-size:1.8rem;line-height:1.02;letter-spacing:-.01em}
.ev-script{font-family:'Allura',cursive;font-size:1.6rem;color:var(--muted);line-height:.9;margin-top:-.2rem}
.ev-desc{color:var(--muted);font-size:.95rem;margin-top:.3rem}
.ev-body .link-gold{margin-top:.5rem}
.ev-cta{justify-content:center;align-items:flex-start;gap:1rem;padding:2.2rem 2rem;background:linear-gradient(155deg,rgba(177,60,240,.16),rgba(39,198,230,.08));border-color:rgba(255,255,255,.16)}
.ev-cta h3{font-weight:800;font-size:1.5rem;letter-spacing:-.01em;text-wrap:balance}
.ev-cta p{color:var(--muted);font-size:.96rem}

/* events · pinned horizontal (desktop, JS-driven) */
.events.pinned{background:none}
.events.pinned .events-sticky{position:sticky;top:0;height:100vh;justify-content:center;gap:clamp(2rem,4vw,3.4rem);overflow:hidden;padding:0}
.events.pinned .events-track{overflow:visible;scroll-snap-type:none;padding-right:var(--pad);will-change:transform;cursor:default}
.events.pinned .events-head{padding-top:2vh}

/* ═══════ GALLERY ═══════ */
.gallery{max-width:1440px;margin:0 auto;padding:clamp(60px,9vh,120px) var(--pad)}
.gallery-head{margin-bottom:clamp(2rem,4vw,3rem)}
.gallery-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:clamp(150px,18vw,215px);gap:1rem}
.gallery-grid image-slot{width:100%;height:100%;color:var(--muted);font-family:'Space Mono',monospace}
image-slot::part(frame){background:repeating-linear-gradient(45deg,#101016,#101016 12px,#17171f 12px,#17171f 24px)}
image-slot::part(ring){border-color:rgba(255,255,255,.16)}
.g1{grid-column:span 4;grid-row:span 2}
.g2{grid-column:span 2;grid-row:span 1}
.g3{grid-column:span 2;grid-row:span 1}
.g4{grid-column:span 3;grid-row:span 1}
.g5{grid-column:span 3;grid-row:span 1}
.gallery-note{margin-top:1.6rem;text-align:center;font-family:'Space Mono',monospace;font-size:.74rem;letter-spacing:.1em;color:var(--faint);text-transform:uppercase}

/* ═══════ AMBIANCE BAND ═══════ */
.ambiance{position:relative;height:min(82vh,660px);margin:clamp(30px,6vh,80px) 0;overflow:hidden}
.ambiance-media{position:absolute;inset:-12% 0;will-change:transform}
.ambiance-img{display:block;width:100%;height:100%;color:var(--faint);font-family:'Space Mono',monospace}
.ambiance-img::part(frame){background:repeating-linear-gradient(45deg,#0a0a0e,#0a0a0e 14px,#101016 14px,#101016 28px)}
.ambiance-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(4,4,5,.55),rgba(4,4,5,.15) 42%,rgba(4,4,5,.9))}
.ambiance-copy{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1.1rem;padding:0 var(--pad)}
.ambiance-eyebrow{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold)}
.ambiance-script{font-family:'Allura',cursive;font-size:clamp(2.4rem,7vw,5.2rem);line-height:1.02;white-space:nowrap}

/* ═══════ WHATSAPP FAB ═══════ */
.wa-fab{position:fixed;right:clamp(16px,2.4vw,28px);bottom:clamp(16px,2.4vw,28px);z-index:190;display:flex;align-items:center;border-radius:999px;background:linear-gradient(135deg,#2bdd73,#118a4b);color:#05140b;box-shadow:0 12px 34px -10px rgba(43,221,115,.6);overflow:hidden;opacity:0;transform:scale(.55) translateY(18px);pointer-events:none;transition:transform .5s var(--ease),box-shadow .3s}
.wa-fab.show{opacity:1;transform:none;pointer-events:auto}
.wa-fab:hover{box-shadow:0 18px 44px -10px rgba(43,221,115,.85)}
.wa-ico{width:58px;height:58px;display:grid;place-items:center;font-size:1.55rem;flex:none;z-index:2}
.wa-label{font-weight:700;font-size:.9rem;white-space:nowrap;max-width:0;opacity:0;overflow:hidden;transition:max-width .45s var(--ease),opacity .3s,padding .35s;z-index:2}
.wa-fab:hover .wa-label,.wa-fab:focus-visible .wa-label{max-width:240px;opacity:1;padding-right:1.3rem}
.wa-ring{position:absolute;inset:0;width:58px;height:58px;border-radius:999px;border:2px solid #2bdd73;animation:waPulse 2.6s ease-out infinite;pointer-events:none;z-index:1}
@keyframes waPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.55);opacity:0}}
@media(max-width:560px){.wa-ico{width:52px;height:52px}.wa-ring{width:52px;height:52px}}

/* ═══════ RESERVE ═══════ */
.reserve{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,9vh,120px) var(--pad)}
.reserve-inner{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.reserve-meta{display:flex;gap:2.4rem;margin-top:2rem}
.reserve-meta>div{display:flex;flex-direction:column;gap:.25rem}
.meta-k{font-family:'Space Mono',monospace;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.meta-v{font-weight:600;border-bottom:1px solid transparent;transition:border-color .2s;width:fit-content}
a.meta-v:hover{border-color:var(--gold)}
.reserve .btn-whats{margin-top:1.9rem}
.reserve-form{border:1px solid var(--line);border-radius:22px;padding:clamp(1.6rem,3vw,2.5rem);background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.006))}
.field{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.1rem}
.field-row{display:grid;grid-template-columns:.7fr 1.1fr 1fr;gap:.9rem}
.field label{font-family:'Space Mono',monospace;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.field input{background:rgba(0,0,0,.4);border:1px solid var(--line);border-radius:11px;padding:.82em .95em;color:var(--ink);font-family:inherit;font-size:.95rem;width:100%;transition:border-color .25s,box-shadow .25s}
.field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(217,178,90,.15)}
.field input::placeholder{color:var(--faint)}
.form-hint{margin-top:.9rem;font-size:.78rem;color:var(--faint);text-align:center}

/* ═══════ CONTACT ═══════ */
.contact{max-width:var(--maxw);margin:0 auto;padding:clamp(60px,9vh,120px) var(--pad)}
.contact-inner{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:1.15rem;margin:1.9rem 0 2rem}
.contact-list li{display:flex;gap:1rem;align-items:flex-start;color:var(--muted);line-height:1.5}
.contact-list a{color:var(--ink);border-bottom:1px solid var(--line);transition:border-color .2s}
.contact-list a:hover{border-color:var(--gold)}
.ci{color:var(--gold);font-size:1rem;line-height:1.5;flex:none}
.contact-map{position:relative;display:block;min-height:380px;aspect-ratio:1/1;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:
  linear-gradient(rgba(255,255,255,.028) 1px,transparent 1px) 0 0/44px 44px,
  linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px) 0 0/44px 44px,
  radial-gradient(120% 85% at 50% 42%,#16131c,#0b0a0f)}
.map-fallback{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.3rem;transition:opacity .5s}
.map-marker{position:relative;display:grid;place-items:center;width:48px;height:48px}
.map-pin-ring{position:absolute;width:48px;height:48px;border:1px solid var(--gold);border-radius:50%;animation:mapPulse 2.6s ease-out infinite}
.map-pin{position:relative;width:26px;height:26px;background:var(--gold-grad);border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:grid;place-items:center;box-shadow:0 12px 24px -6px rgba(217,178,90,.6);margin-top:-8px}
.map-pin-dot{width:9px;height:9px;border-radius:50%;background:#160d04;transform:rotate(45deg)}
.map-label{font-family:'Space Mono',monospace;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@keyframes mapPulse{0%{transform:scale(.6);opacity:.85}100%{transform:scale(1.7);opacity:0}}
.contact-map-frame{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:1;opacity:0;transition:opacity .6s var(--ease);filter:invert(.92) hue-rotate(185deg) saturate(.85) contrast(.92) brightness(.95)}
.contact-map.map-live .contact-map-frame{opacity:1}
.contact-map.map-live .map-fallback{opacity:0}
.contact-map-link{position:absolute;left:14px;bottom:14px;z-index:2;font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.08em;color:var(--ink);background:rgba(8,8,11,.72);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);padding:.55em 1em;border-radius:99px;transition:border-color .25s,color .25s}
.contact-map-link:hover{border-color:var(--gold);color:var(--gold)}

/* ═══════ FOOTER ═══════ */
.footer{border-top:1px solid var(--line);margin-top:clamp(40px,8vh,90px);padding:clamp(3rem,6vw,5rem) var(--pad) 2rem;overflow:hidden}
.footer-big{font-weight:900;letter-spacing:-.04em;line-height:.84;font-size:clamp(3.5rem,15vw,13rem);text-align:center;margin-bottom:clamp(2rem,5vw,3.5rem)}
.footer-cols{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1.4fr;gap:2rem;align-items:start}
.footer-mark{width:52px;height:52px;border-radius:12px;margin-bottom:.9rem}
.footer-tag{color:var(--faint);font-family:'Space Mono',monospace;font-size:.74rem;letter-spacing:.1em}
.footer-nav{display:flex;flex-direction:column;gap:.7rem}
.footer-nav a{color:var(--muted);transition:color .2s;width:fit-content}
.footer-nav a:hover{color:var(--ink)}
.footer-social{display:flex;flex-direction:column;gap:.7rem;align-items:flex-start}
.social-pill{font-family:'Space Mono',monospace;font-size:.78rem;letter-spacing:.03em;border:1px solid var(--line);padding:.6em 1em;border-radius:99px;color:var(--muted);transition:border-color .25s,color .25s}
.social-pill:hover{border-color:var(--gold);color:var(--ink)}
.footer-bottom{max-width:var(--maxw);margin:2.8rem auto 0;padding-top:1.4rem;border-top:1px solid var(--line-2);display:flex;justify-content:space-between;font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.08em;color:var(--faint)}

/* ═══════ PLACEHOLDERS ═══════ */
.ph{position:relative;border-radius:16px;border:1px solid var(--line);background:repeating-linear-gradient(45deg,#0b0b10,#0b0b10 11px,#0f0f15 11px,#0f0f15 22px);display:grid;place-items:center;overflow:hidden}
.ph::before{content:attr(data-ph);font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:.5em 1em;border:1px dashed var(--line);border-radius:99px;background:rgba(0,0,0,.45);text-align:center}
.ph::after{content:"";position:absolute;inset:-30% -30% auto auto;width:60%;height:120%;background:var(--irid);filter:blur(60px);opacity:.14}

/* ═══════ RESPONSIVE ═══════ */
@media(max-width:1000px){
  .nav-links{position:fixed;inset:0 0 auto 0;flex-direction:column;background:rgba(5,5,8,.97);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:6rem var(--pad) 2.6rem;gap:1.6rem;transform:translateY(-100%);transition:transform .5s var(--ease);border-bottom:1px solid var(--line)}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.35rem;color:var(--ink)}
  .burger{display:flex}
  .nav-cta{display:none}
  .exp-grid{grid-template-columns:1fr}
  .reserve-inner,.contact-inner{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .g1{grid-column:span 2;grid-row:span 1}
  .g2,.g3,.g4,.g5{grid-column:span 1}
  .ev-feature{flex-direction:column;width:min(86vw,420px)}
  .ev-poster{flex:none}
  .ev-poster img{min-height:0;aspect-ratio:4/3}
}
/* tablet — 2-col experience cards instead of a single stretched column */
@media(max-width:1000px) and (min-width:701px){
  .exp-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .field-row{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr;gap:2.4rem}
  .footer-bottom{flex-direction:column;gap:.5rem}
  .hero-meta{display:none}
  .intro-stats{gap:1.8rem}
}

/* ═══════ MOBILE PERFORMANCE & TOUCH ═══════ */
/* remove the grey tap flash + lock font sizing on orientation change */
*{-webkit-tap-highlight-color:transparent}
html{-webkit-text-size-adjust:100%}
/* give the page a smooth, momentum-based touch scroll */
body{-webkit-overflow-scrolling:touch}

/* Phones & touch devices: lighten the heavy GPU layers so scroll, reveals
   and counters stay fluid (big blurred blobs + animated grain are the cost). */
@media(max-width:768px){
  .blob{filter:blur(74px)}
  .blob-gold{display:none}           /* one less large blurred layer */
  .grain{display:none}               /* film grain is invisible at phone DPR but costly */
  .nav.scrolled{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
  .btn{will-change:auto}             /* avoid promoting every button to its own layer */
  .ticker-row{animation-duration:24s}
}
/* coarse pointers (real touchscreens) — calmer aurora drift = steadier framerate */
@media(pointer:coarse){
  .blob{animation-duration:34s !important}
}

/* ═══════ SMALL PHONES (≤480px) ═══════ */
@media(max-width:480px){
  .nav{padding-left:16px;padding-right:16px}
  .nav-actions{gap:.65rem}
  .brand-mark{width:34px;height:34px}
  .brand-word{font-size:.82rem;letter-spacing:.12em}
  .hero{padding-left:18px;padding-right:18px}
  .hero-eyebrow{letter-spacing:.22em}
  .hero-cta .btn{width:100%;justify-content:center}
  .reserve-meta{gap:1.4rem;flex-wrap:wrap}
  .ambiance-script{white-space:normal;line-height:1.1}
  .footer-big{font-size:clamp(2.8rem,20vw,5rem)}
  .footer-social{width:100%}
  .social-pill{width:100%;text-align:center}
}

/* ═══════ HERO · MOBILE — fill the screen like desktop ═══════ */
@media(max-width:600px){
  .hero{padding:clamp(104px,15vh,150px) 18px clamp(92px,12vh,120px);min-height:100svh}
  .hero-eyebrow{font-size:.6rem;letter-spacing:.24em;margin-bottom:1.15rem}
  /* giant wordmark — scales with viewport so SKY / ROOF span the full width */
  .hero-title{font-size:clamp(5rem,29vw,9.5rem);line-height:.86;letter-spacing:-.04em}
  .hero-script{font-size:clamp(2.2rem,11vw,3.4rem);margin-top:.6rem}
  .hero-sub{margin-top:1.35rem;font-size:1.02rem;max-width:32ch;line-height:1.5}
  .hero-cta{flex-direction:column;align-items:stretch;width:100%;gap:.8rem;margin-top:1.9rem}
  .hero-cta .btn{width:100%;justify-content:center;padding-top:1.05em;padding-bottom:1.05em}
}
/* very small phones — guard against horizontal overflow on the 4-letter line */
@media(max-width:360px){
  .hero-title{font-size:26vw}
  .hero-sub{font-size:.98rem}
}
/* landscape phones — short viewport: shrink so nothing clips */
@media(max-height:520px) and (orientation:landscape){
  .hero{min-height:auto;padding:92px var(--pad) 44px}
  .hero-title{font-size:clamp(3rem,13vh,5.5rem)}
  .hero-script{font-size:clamp(1.6rem,6vh,2.4rem)}
  .hero-foot{position:static;margin-top:1.4rem}
}

/* ═══════ REDUCED MOTION ═══════ */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .line-mask>*{transform:none!important}
  .hero-cta.line-mask{opacity:1!important;transform:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .reveal-words .w{color:var(--ink)!important}
}
