/* ============================================================================
 *  styles.css — design language: low-lit boudoir-lounge, editorial, sensual.
 *  Evokes "night & lust" through LIGHT, FORM and MOTION — never via fixed
 *  colours. Every hue still comes from themeConfig (CSS custom properties),
 *  so any club's brand pours straight through this same design.
 * ==========================================================================*/

:root {
  /* defaults (overwritten at runtime by applyTheme from themeConfig) */
  --bg:#0a0907; --bg-elevated:#100e0a; --surface:#16130d; --surface-alt:#1f1a11;
  --line:#2c2415; --primary:#d4af37; --primary-hi:#f6e3a3; --primary-text:#0a0907;
  --text:#f6f1e6; --text-muted:#a3957a; --success:#5fd39b; --danger:#e2526b;
  --primary-rgb:212 175 55; --primary-hi-rgb:246 227 163; --text-rgb:246 241 230;
  --danger-rgb:226 82 107; --success-rgb:95 211 155; --bg-rgb:10 9 7;
  --font-heading:Georgia,serif; --font-body:system-ui,sans-serif; --font-display:Georgia,serif;
  --radius:18px; --bg-texture:none;

  --tap:56px; --rail:104px; --bar:84px;
  --gap:clamp(16px,1.8vw,26px); --pad:clamp(20px,3vw,44px);
  --ease:cubic-bezier(.22,.61,.18,1);      /* slow, luxurious */
  --ease-out:cubic-bezier(.16,.84,.28,1);
  --hair:1px solid rgba(var(--text-rgb)/.10);
  --bloom:0 0 60px rgba(var(--primary-rgb)/.18);
  --lift:0 24px 60px -28px rgba(0,0,0,.8);
}

/* --------------------------------------------------------------- reset/base */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;width:100%;overflow:hidden}
*{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}
input,textarea{-webkit-user-select:text;user-select:text}

body{
  font-family:var(--font-body); background:var(--bg); color:var(--text);
  font-size:clamp(16px,1.45vw,19px); line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overscroll-behavior:none; touch-action:manipulation; position:fixed; inset:0;
}
h1,h2,h3,.display{font-family:var(--font-heading);font-weight:600;line-height:1.04;letter-spacing:.005em}
em,.it{font-style:italic}
.eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.42em;
  font-size:.66rem;color:var(--primary);opacity:.85}
.muted{color:var(--text-muted)}

/* ============================================================== ATMOSPHERE */
/* A living, breathing room. All layers tint from --primary so they adopt any
   club's brand. This is where "night" lives — drifting light, haze, embers. */
.atmosphere{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:
    radial-gradient(140% 100% at 50% -20%, rgba(var(--primary-rgb)/.08), transparent 60%),
    var(--bg-texture),
    radial-gradient(120% 90% at 50% 120%, rgba(var(--primary-rgb)/.05), transparent 55%),
    linear-gradient(175deg, var(--bg-elevated), var(--bg) 55%);
  background-size:cover;
}
/* soft drifting light pools — like slow stage lights / candle glow */
.atm-bloom{position:absolute;border-radius:50%;filter:blur(60px);mix-blend-mode:screen;opacity:.5}
.atm-bloom.a{width:60vw;height:60vw;left:-10vw;top:-20vw;
  background:radial-gradient(circle,rgba(var(--primary-rgb)/.5),transparent 62%);
  animation:drift1 34s var(--ease) infinite}
.atm-bloom.b{width:52vw;height:52vw;right:-12vw;bottom:-18vw;
  background:radial-gradient(circle,rgba(var(--primary-hi-rgb)/.32),transparent 60%);
  animation:drift2 46s var(--ease) infinite}
.atm-bloom.c{width:40vw;height:40vw;left:30vw;top:35vh;
  background:radial-gradient(circle,rgba(var(--primary-rgb)/.28),transparent 60%);
  animation:drift3 40s var(--ease) infinite}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1);opacity:.45}50%{transform:translate(12vw,8vh) scale(1.18);opacity:.62}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1.05);opacity:.4}50%{transform:translate(-10vw,-6vh) scale(.9);opacity:.58}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(.9);opacity:.3}50%{transform:translate(-8vw,6vh) scale(1.15);opacity:.5}}

/* slow silk shimmer sweeping across, like light over satin */
.atm-sweep{position:absolute;inset:-30%;
  background:linear-gradient(115deg,transparent 38%,rgba(var(--primary-hi-rgb)/.06) 50%,transparent 62%);
  transform:translateX(-40%);animation:sweep 17s ease-in-out infinite}
@keyframes sweep{0%,72%{transform:translateX(-60%)}100%{transform:translateX(60%)}}

/* floating embers/dust (canvas) */
#embers{position:absolute;inset:0;width:100%;height:100%;opacity:.7}

/* film grain + vignette */
.atm-grain{position:absolute;inset:-50%;opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%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:grain 6s steps(5) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}25%{transform:translate(-3%,2%)}50%{transform:translate(2%,-3%)}75%{transform:translate(-2%,-2%)}}
.atm-vignette{position:absolute;inset:0;
  box-shadow:inset 0 0 min(44vw,420px) rgba(0,0,0,.72);
  animation:flicker 9s ease-in-out infinite}
@keyframes flicker{0%,100%{opacity:1}48%{opacity:.94}52%{opacity:.99}}
[data-grain="off"] .atm-grain{display:none}
[data-vignette="off"] .atm-vignette{display:none}
[data-glow="off"] .atm-bloom{opacity:.25;animation:none}

/* ============================================================== APP SHELL */
.app{position:relative;z-index:2;height:100%;width:100%;
  display:grid;grid-template-columns:var(--rail) 1fr;grid-template-areas:"nav main"}
.main{grid-area:main;position:relative;height:100%;overflow:hidden}

/* ----- navigation: slim, editorial, no boxy tiles ----------------------- */
.nav{grid-area:nav;position:relative;display:flex;flex-direction:column;align-items:center;
  padding:var(--pad) 8px;gap:4px;border-right:var(--hair);
  background:linear-gradient(180deg,rgba(var(--bg-rgb)/.4),rgba(var(--bg-rgb)/.1))}
.nav__brand{display:flex;flex-direction:column;align-items:center;gap:8px;
  padding-bottom:18px;margin-bottom:14px;border-bottom:var(--hair);width:100%}
.nav__brand img{width:40px;height:40px;filter:drop-shadow(0 0 14px rgba(var(--primary-rgb)/.4))}
.nav__brand .wordmark{font-size:.62rem;letter-spacing:.36em}
.nav__items{display:flex;flex-direction:column;gap:2px;flex:1;width:100%;align-items:center}
.navbtn{appearance:none;border:0;cursor:pointer;color:var(--text-muted);background:transparent;
  width:100%;min-height:62px;padding:8px 4px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:7px;font-family:var(--font-display);font-size:.6rem;letter-spacing:.2em;
  text-transform:uppercase;position:relative;transition:color .45s var(--ease)}
.navbtn .ic{width:26px;height:26px;display:grid;place-items:center;transition:transform .45s var(--ease),filter .45s}
.navbtn .ic svg{width:100%;height:100%;display:block}
.navbtn[aria-current="true"]{color:var(--primary)}
.navbtn[aria-current="true"] .ic{filter:drop-shadow(0 0 10px rgba(var(--primary-rgb)/.7));transform:translateY(-1px)}
.navbtn[aria-current="true"]::before{content:"";position:absolute;left:0;top:24%;bottom:24%;width:2px;
  background:linear-gradient(180deg,transparent,var(--primary),transparent);
  box-shadow:0 0 14px 2px rgba(var(--primary-rgb)/.7)}
.navbtn:active .ic{transform:scale(.86)}
.navbtn .cart-badge{position:absolute;top:8px;right:50%;transform:translateX(20px);
  min-width:20px;height:20px;padding:0 6px;border-radius:11px;background:var(--primary);
  color:var(--primary-text);font-family:var(--font-body);font-weight:700;font-size:.66rem;
  display:none;align-items:center;justify-content:center}
.navbtn .cart-badge.show{display:flex}

/* ----- floating Call Server: refined, slow breathing glow --------------- */
.fab{position:fixed;z-index:40;right:clamp(20px,2.6vw,34px);bottom:clamp(20px,2.6vw,34px);
  display:inline-flex;align-items:center;gap:11px;min-height:var(--tap);padding:0 24px 0 20px;
  border:1px solid rgba(var(--primary-rgb)/.4);cursor:pointer;border-radius:999px;
  background:linear-gradient(135deg,rgba(var(--surface-alt)/.9),rgba(var(--surface)/.9));
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  color:var(--primary);font-family:var(--font-display);font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;font-size:.78rem;box-shadow:var(--bloom);
  transition:transform .25s var(--ease),box-shadow .6s var(--ease)}
[data-glow="on"] .fab{animation:breatheGlow 5s var(--ease) infinite}
.fab:active{transform:scale(.94)}
.fab .ic{width:22px;height:22px}
@keyframes breatheGlow{0%,100%{box-shadow:0 0 34px -6px rgba(var(--primary-rgb)/.3)}50%{box-shadow:0 0 52px 2px rgba(var(--primary-rgb)/.6)}}

/* ================================================================ SCREENS */
.screen{position:absolute;inset:0;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:var(--pad);padding-bottom:calc(var(--pad) + 96px);
  opacity:0;visibility:hidden;transform:translateY(14px);filter:blur(6px);
  transition:opacity .5s var(--ease),transform .55s var(--ease),filter .5s var(--ease),visibility .5s}
.screen.is-active{opacity:1;visibility:visible;transform:none;filter:none}
.screen::-webkit-scrollbar{width:0}

/* staggered reveal of children when a screen becomes active */
.screen.entering .stagger>*{animation:rise .7s var(--ease-out) both}
.screen.entering .stagger>*:nth-child(2){animation-delay:.06s}
.screen.entering .stagger>*:nth-child(3){animation-delay:.12s}
.screen.entering .stagger>*:nth-child(4){animation-delay:.18s}
.screen.entering .stagger>*:nth-child(5){animation-delay:.24s}
.screen.entering .stagger>*:nth-child(n+6){animation-delay:.3s}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

.screen__head{margin-bottom:var(--gap)}
.screen__head h1{font-size:clamp(2.2rem,4.4vw,3.5rem);font-weight:600}
.screen__head h1 .it{color:var(--primary)}
.screen__head .sub{color:var(--text-muted);margin-top:6px;max-width:60ch}
.rule{height:1px;border:0;margin:6px 0 22px;
  background:linear-gradient(90deg,transparent,rgba(var(--primary-rgb)/.5) 20%,rgba(var(--primary-rgb)/.5) 80%,transparent)}

/* ---------- soft card (no harsh borders) ---------- */
.card{position:relative;border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(var(--surface-alt)/.7),rgba(var(--surface)/.55));
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  border:1px solid rgba(var(--text-rgb)/.06);overflow:hidden}
.card--tap{cursor:pointer;transition:transform .3s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.card--tap:active{transform:scale(.985)}
.card--tap:hover{border-color:rgba(var(--primary-rgb)/.35);box-shadow:var(--bloom)}

/* refined marker (replaces chunky badges) */
.mark{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);
  font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--primary);opacity:.9}
.mark::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--primary);
  box-shadow:0 0 8px rgba(var(--primary-rgb)/.8)}
.mark--hh{color:var(--success)}.mark--hh::before{background:var(--success);box-shadow:0 0 8px rgba(var(--success-rgb)/.8)}
.mark--soft{color:var(--text-muted)}.mark--soft::before{background:var(--text-muted);box-shadow:none}

/* buttons */
.btn{appearance:none;cursor:pointer;font-family:var(--font-display);font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;min-height:var(--tap);padding:0 26px;border-radius:999px;font-size:.82rem;
  border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:transform .22s var(--ease),box-shadow .5s,filter .3s,background .3s}
.btn:active{transform:scale(.95)}
.btn .ic{width:18px;height:18px}
.btn--primary{background:linear-gradient(135deg,var(--primary-hi),var(--primary));color:var(--primary-text);
  box-shadow:0 10px 34px -12px rgba(var(--primary-rgb)/.7)}
.btn--primary:disabled{filter:grayscale(.6) brightness(.7);cursor:not-allowed;box-shadow:none}
.btn--ghost{background:transparent;color:var(--primary);border-color:rgba(var(--primary-rgb)/.45)}
.btn--soft{background:rgba(var(--text-rgb)/.05);color:var(--text);border-color:rgba(var(--text-rgb)/.1)}
.btn--block{width:100%}
.btn--lg{min-height:64px;font-size:.92rem}
/* text-link CTA (very non-HUD) */
.cta-link{appearance:none;background:none;border:0;cursor:pointer;color:var(--primary);
  font-family:var(--font-display);letter-spacing:.16em;text-transform:uppercase;font-size:.78rem;
  display:inline-flex;align-items:center;gap:10px;padding:10px 2px;position:relative}
.cta-link::after{content:"";position:absolute;left:2px;right:30px;bottom:6px;height:1px;
  background:var(--primary);opacity:.5;transform-origin:left;transition:transform .4s var(--ease)}
.cta-link .ic{width:16px;height:16px;transition:transform .4s var(--ease)}
.cta-link:active .ic{transform:translateX(4px)}

/* ============================================================== ATTRACT */
#attract{position:fixed;inset:0;z-index:60;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:var(--pad);padding-bottom:clamp(70px,11vh,104px);
  background:radial-gradient(58% 46% at 50% 40%,rgba(var(--primary-rgb)/.14),transparent 72%),
    linear-gradient(180deg,var(--bg-elevated),var(--bg));
  transition:opacity .8s var(--ease),visibility .8s}
#attract.hide{opacity:0;visibility:hidden}
/* spotlight pooling onto the stage floor */
#attract::after{content:"";position:absolute;left:50%;bottom:-22%;width:120%;height:60%;transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(var(--primary-rgb)/.14),transparent 75%);filter:blur(20px);pointer-events:none}
.attract__emblem{width:clamp(92px,13vw,150px);height:clamp(92px,13vw,150px);position:relative;z-index:1;
  filter:drop-shadow(0 0 40px rgba(var(--primary-rgb)/.5));animation:breathe 6s var(--ease) infinite}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.94}50%{transform:scale(1.045);opacity:1}}
.attract__word{font-family:var(--font-display);font-size:clamp(2.8rem,8vw,5.8rem);letter-spacing:.16em;
  margin-top:6px;position:relative;z-index:1;
  background:linear-gradient(180deg,var(--primary-hi),var(--primary) 55%,var(--primary-hi));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--primary);
  background-size:100% 240%;animation:shimmer 7s linear infinite}
@keyframes shimmer{0%{background-position:0 0}100%{background-position:0 -240%}}
.attract__tag{color:var(--text-muted);letter-spacing:.46em;text-transform:uppercase;
  font-size:clamp(.72rem,1.4vw,.95rem);margin-top:14px;position:relative;z-index:1;
  font-family:var(--font-display)}
.attract__promo{margin-top:clamp(16px,3.5vh,40px);max-width:560px;position:relative;z-index:1}
.attract__promo .eyebrow{display:block;margin-bottom:8px}
.attract__promo b{font-family:var(--font-heading);font-weight:600;font-size:1.35rem}
.attract__promo div{color:var(--text-muted);margin-top:5px}
.attract__cta{margin-top:clamp(22px,4vh,44px);display:inline-flex;flex-direction:column;align-items:center;
  gap:14px;cursor:pointer;position:relative;z-index:1}
.attract__cta .tap{font-family:var(--font-display);letter-spacing:.38em;text-transform:uppercase;font-size:.92rem;
  color:var(--text);padding:18px 46px;border:1px solid rgba(var(--primary-rgb)/.5);border-radius:999px;
  position:relative;overflow:hidden}
.attract__cta .tap::before{content:"";position:absolute;inset:0;border-radius:999px;
  box-shadow:0 0 0 0 rgba(var(--primary-rgb)/.45);animation:halo 3.2s var(--ease) infinite}
@keyframes halo{0%{box-shadow:0 0 0 0 rgba(var(--primary-rgb)/.4)}70%,100%{box-shadow:0 0 0 26px rgba(var(--primary-rgb)/0)}}
.attract__legal{position:absolute;bottom:20px;left:0;right:0;color:var(--text-muted);font-size:.7rem;
  letter-spacing:.04em;padding:0 var(--pad);z-index:1}

/* ============================================================== HOME */
.hero{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:var(--gap);
  min-height:clamp(220px,34vh,340px);display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(26px,4vw,48px);
  background:linear-gradient(115deg,rgba(var(--primary-rgb)/.16),transparent 52%),
    linear-gradient(0deg,rgba(var(--bg-rgb)/.85),rgba(var(--bg-rgb)/.2) 70%),var(--surface-alt);
  border:1px solid rgba(var(--text-rgb)/.06)}
.hero::after{content:"";position:absolute;right:-10%;top:-30%;width:55%;height:160%;
  background:radial-gradient(closest-side,rgba(var(--primary-rgb)/.22),transparent 70%);filter:blur(30px)}
.hero .eyebrow{position:relative}
.hero h2{font-size:clamp(2rem,4.2vw,3.2rem);max-width:18ch;margin-top:8px;position:relative}
.hero p{color:var(--text-muted);margin-top:10px;max-width:46ch;position:relative}
.hero .cta-link,.hero .btn{margin-top:20px;align-self:flex-start;position:relative}
.hero__dots{position:absolute;bottom:22px;right:26px;display:flex;gap:8px}
.hero__dots i{width:6px;height:6px;border-radius:50%;background:rgba(var(--text-rgb)/.3);transition:.4s}
.hero__dots i.on{background:var(--primary);width:24px;border-radius:4px;box-shadow:0 0 10px rgba(var(--primary-rgb)/.7)}

.section-title{display:flex;align-items:baseline;justify-content:space-between;margin:30px 0 16px;gap:16px}
.section-title h3{font-size:1.5rem;font-weight:600}
.linkish{color:var(--primary);background:none;border:0;font-family:var(--font-display);letter-spacing:.14em;
  text-transform:uppercase;font-size:.72rem;cursor:pointer;padding:8px}

/* now on stage — soft inline strip, not a HUD pill */
.onstage{display:flex;align-items:center;gap:16px;padding:18px 22px;border-radius:var(--radius);
  background:linear-gradient(90deg,rgba(var(--primary-rgb)/.1),transparent 70%);border:var(--hair);cursor:pointer}
.onstage .pulse{width:9px;height:9px;border-radius:50%;background:var(--primary);flex:0 0 auto;position:relative}
.onstage .pulse::after{content:"";position:absolute;inset:-6px;border-radius:50%;
  background:rgba(var(--primary-rgb)/.4);animation:ripple 2.6s var(--ease) infinite}
@keyframes ripple{0%{transform:scale(.6);opacity:.8}100%{transform:scale(2.2);opacity:0}}
.onstage .label{font-family:var(--font-display);letter-spacing:.24em;text-transform:uppercase;font-size:.62rem;color:var(--primary)}
.onstage .who{font-family:var(--font-heading);font-size:1.3rem}
.onstage .next{color:var(--text-muted);font-size:.84rem;margin-top:2px}

/* quick actions — soft wide cards, thin icons (not equal glowing tiles) */
.actions{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.action{display:flex;align-items:center;gap:16px;padding:20px 22px;text-align:left}
.action .ic{width:30px;height:30px;color:var(--primary);flex:0 0 auto;
  filter:drop-shadow(0 0 10px rgba(var(--primary-rgb)/.35))}
.action .t{font-family:var(--font-heading);font-size:1.2rem}
.action .d{color:var(--text-muted);font-size:.8rem;margin-top:2px}

.wifi-card{padding:20px 24px;display:flex;gap:28px;align-items:center;flex-wrap:wrap}
.wifi-card .eyebrow{display:block;margin-bottom:5px}
.wifi-card b{color:var(--primary)}
.note{color:var(--text-muted);font-size:.8rem;margin-top:16px;line-height:1.6;letter-spacing:.01em}

.outbox{display:flex;flex-direction:column;gap:10px}
.req-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:14px;border:var(--hair)}
.req-row .ic{width:20px;height:20px;color:var(--primary)}
.req-row .st{margin-left:auto;font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;
  font-size:.62rem;padding:5px 12px;border-radius:999px}
.req-row .st.pending{color:var(--primary);background:rgba(var(--primary-rgb)/.12)}
.req-row .st.done{color:var(--success);background:rgba(var(--success-rgb)/.12)}

/* ============================================================== MENU */
.menu-tabs{display:flex;gap:26px;overflow-x:auto;padding:4px 2px 14px;margin-bottom:8px;
  border-bottom:var(--hair);scrollbar-width:none}
.menu-tabs::-webkit-scrollbar{display:none}
.menu-tab{flex:0 0 auto;appearance:none;background:none;border:0;cursor:pointer;color:var(--text-muted);
  font-family:var(--font-display);letter-spacing:.16em;text-transform:uppercase;font-size:.84rem;
  padding:8px 2px;position:relative;transition:color .4s var(--ease)}
.menu-tab[aria-pressed="true"]{color:var(--primary)}
.menu-tab[aria-pressed="true"]::after{content:"";position:absolute;left:0;right:0;bottom:-15px;height:2px;
  background:var(--primary);box-shadow:0 0 12px rgba(var(--primary-rgb)/.8)}

/* classic printed-menu rows with dotted leaders */
.menu-list{display:grid;gap:6px 56px;grid-template-columns:1fr;margin-top:20px}
@media (min-width:880px){.menu-list{grid-template-columns:1fr 1fr}}
.mr{padding:18px 4px;border-bottom:var(--hair);cursor:pointer;display:flex;gap:18px;align-items:flex-start;
  transition:background .35s var(--ease)}
.mr:active{background:rgba(var(--primary-rgb)/.05)}
.mr.is-out{opacity:.42;cursor:default}
.mr__thumb{width:62px;height:62px;border-radius:12px;overflow:hidden;flex:0 0 auto;background:var(--surface)}
.mr__thumb img{width:100%;height:100%;object-fit:cover}
.mr__body{flex:1;min-width:0}
.mr__head{display:flex;align-items:baseline;gap:.5rem}
.mr__name{font-family:var(--font-heading);font-size:1.3rem;line-height:1.1}
.mr__leader{flex:1;border-bottom:1px dotted rgba(var(--text-rgb)/.28);transform:translateY(-5px);min-width:18px}
.mr__price{font-family:var(--font-heading);font-size:1.25rem;color:var(--primary);white-space:nowrap}
.mr__price s{color:var(--text-muted);font-size:.8rem;margin-right:7px}
.mr__desc{color:var(--text-muted);font-size:.9rem;margin-top:5px}
.mr__meta{display:flex;align-items:center;gap:14px;margin-top:9px;flex-wrap:wrap}
.mr__add{width:42px;height:42px;border-radius:50%;border:1px solid rgba(var(--primary-rgb)/.45);
  background:transparent;color:var(--primary);cursor:pointer;display:grid;place-items:center;flex:0 0 auto;
  align-self:center;transition:transform .2s var(--ease),background .3s}
.mr__add .ic{width:18px;height:18px}
.mr__add:active{transform:scale(.88);background:rgba(var(--primary-rgb)/.16)}
.mr .out-tag{color:var(--danger);font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;font-size:.66rem}
.hh-strip{display:flex;align-items:center;gap:14px;padding:16px 22px;border-radius:var(--radius);
  margin:20px 0 4px;border:1px solid rgba(var(--success-rgb)/.3);
  background:linear-gradient(90deg,rgba(var(--success-rgb)/.1),transparent 70%)}
.hh-strip .ic{width:22px;height:22px;color:var(--success)}

/* ============================================================== LINEUP */
.feature{position:relative;border-radius:var(--radius);overflow:hidden;margin-bottom:var(--gap);
  min-height:clamp(280px,42vh,420px);display:flex;align-items:flex-end;cursor:pointer}
.feature .bgimg{position:absolute;inset:0}
.feature .bgimg img{width:100%;height:100%;object-fit:cover}
.feature .scrim{position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(var(--bg-rgb)/.92),rgba(var(--bg-rgb)/.1) 55%,transparent),
    linear-gradient(90deg,rgba(var(--bg-rgb)/.5),transparent 60%)}
.feature__body{position:relative;padding:clamp(24px,3.5vw,44px);width:100%}
.feature__name{font-family:var(--font-heading);font-size:clamp(2.4rem,5vw,4rem);line-height:.98}
.feature__tags{display:flex;gap:18px;margin-top:12px;flex-wrap:wrap}
.feature__sched{color:var(--text);margin-top:14px;font-size:1rem}
.feature__sched b{color:var(--primary)}

.performers{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
.perf{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:4/5;
  display:flex;align-items:flex-end;transition:transform .4s var(--ease),box-shadow .6s var(--ease)}
.perf:active{transform:scale(.98)}
.perf:hover{box-shadow:var(--bloom)}
.perf .bgimg{position:absolute;inset:0}
.perf .bgimg img{width:100%;height:100%;object-fit:cover}
.perf .scrim{position:absolute;inset:0;background:linear-gradient(0deg,rgba(var(--bg-rgb)/.9),transparent 58%)}
.perf__body{position:relative;padding:16px}
.perf__name{font-family:var(--font-heading);font-size:1.5rem;line-height:1}
.perf__tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:7px}
.perf__when{position:absolute;top:14px;left:14px;z-index:2}
/* tasteful monogram fallback — soft, framed, glowing */
.monogram{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;
  font-family:var(--font-heading);font-size:clamp(3rem,7vw,5rem);color:rgba(var(--text-rgb)/.9)}
.monogram::after{content:"";position:absolute;inset:14% 14% 30%;border:1px solid rgba(var(--primary-rgb)/.3);
  border-radius:50%;box-shadow:0 0 30px rgba(var(--primary-rgb)/.15) inset}

/* ============================================================== SPECIALS */
.promos{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}
.promo{padding:26px;display:flex;flex-direction:column;gap:12px;min-height:210px;position:relative;overflow:hidden}
.promo::after{content:"";position:absolute;right:-20%;top:-40%;width:60%;height:180%;
  background:radial-gradient(closest-side,rgba(var(--primary-rgb)/.16),transparent 70%);filter:blur(26px)}
.promo--wide{grid-column:1/-1;min-height:180px}
.promo__type{font-family:var(--font-display);letter-spacing:.24em;text-transform:uppercase;font-size:.66rem;color:var(--primary);position:relative}
.promo__title{font-family:var(--font-heading);font-size:1.85rem;position:relative}
.promo__desc{color:var(--text-muted);position:relative;max-width:52ch}
.promo__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;position:relative}
.countdown{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);letter-spacing:.1em;
  font-variant-numeric:tabular-nums;color:var(--primary);font-size:.82rem}
.countdown .ic{width:15px;height:15px}
.countdown.ended{color:var(--text-muted)}
.promo.is-scheduled{opacity:.58}

/* ============================================================== CART */
.cart-wrap{max-width:760px;margin:0 auto}
.cart-line{display:flex;gap:16px;padding:18px 0;border-bottom:var(--hair);align-items:flex-start}
.cart-line__name{font-family:var(--font-heading);font-size:1.25rem}
.cart-line__mods{color:var(--text-muted);font-size:.82rem;margin-top:3px}
.cart-line__price{font-family:var(--font-heading);color:var(--primary);font-size:1.15rem;white-space:nowrap}
.stepper{display:inline-flex;align-items:center;border:var(--hair);border-radius:999px;overflow:hidden;margin-top:10px}
.stepper button{width:44px;height:44px;border:0;background:transparent;color:var(--text);font-size:1.3rem;cursor:pointer}
.stepper button:active{background:rgba(var(--primary-rgb)/.16)}
.stepper .q{min-width:42px;text-align:center;font-weight:700;font-variant-numeric:tabular-nums}
.totals{margin-top:22px}
.totals .row{display:flex;align-items:baseline;gap:.6rem;padding:9px 0;color:var(--text-muted)}
.totals .row .lead{flex:1;border-bottom:1px dotted rgba(var(--text-rgb)/.18);transform:translateY(-5px)}
.totals .row.grand{color:var(--text);font-family:var(--font-heading);font-size:1.6rem;padding-top:16px;
  border-top:var(--hair);margin-top:8px}
.totals .row.grand b{color:var(--primary)}
.empty{text-align:center;padding:70px 20px;color:var(--text-muted)}
.empty .ic{width:54px;height:54px;margin:0 auto 14px;color:var(--primary);opacity:.6}
.ticket{max-width:430px;margin:26px auto;text-align:left;padding:22px}
.ticket .trow{display:flex;justify-content:space-between;padding:7px 0;border-bottom:var(--hair)}

/* ============================================================== SHEET */
.scrim-modal{position:fixed;inset:0;z-index:70;background:rgba(0,0,0,.62);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:.4s var(--ease)}
.scrim-modal.show{opacity:1;visibility:visible}
.sheet{position:fixed;z-index:71;left:50%;bottom:0;transform:translate(-50%,100%);
  width:min(700px,100%);max-height:92vh;overflow-y:auto;
  background:linear-gradient(180deg,var(--surface-alt),var(--surface));border:1px solid rgba(var(--text-rgb)/.08);
  border-bottom:0;border-radius:30px 30px 0 0;padding:var(--pad);transition:transform .5s var(--ease)}
.sheet.show{transform:translate(-50%,0)}
.sheet__grip{width:48px;height:5px;border-radius:3px;background:rgba(var(--text-rgb)/.2);margin:0 auto 20px}
.sheet h2{font-size:1.9rem}
.sheet .price-lg{font-family:var(--font-heading);font-size:1.6rem;color:var(--primary)}
.mod-group{margin-top:22px}
.mod-group .lbl{font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;font-size:.72rem;
  color:var(--text-muted);margin-bottom:12px;display:flex;gap:10px;align-items:center}
.mod-group .req{color:var(--primary)}
.opt{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:56px;padding:0 18px;
  border:var(--hair);border-radius:14px;margin-bottom:9px;cursor:pointer;transition:.25s var(--ease)}
.opt[aria-checked="true"]{border-color:rgba(var(--primary-rgb)/.6);background:rgba(var(--primary-rgb)/.08)}
.opt .mk{width:22px;height:22px;border-radius:50%;border:2px solid var(--text-muted);display:grid;place-items:center}
.opt[aria-checked="true"] .mk{border-color:var(--primary);background:var(--primary)}
.opt[aria-checked="true"] .mk::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--primary-text)}
.sheet__foot{position:sticky;bottom:0;margin-top:24px;padding-top:16px;
  background:linear-gradient(180deg,transparent,var(--surface) 36%);display:flex;gap:12px}
.field{width:100%;min-height:56px;padding:16px 18px;border-radius:14px;border:var(--hair);
  background:rgba(var(--bg-rgb)/.5);color:var(--text);font:inherit;margin-top:8px}
.field:focus{outline:none;border-color:var(--primary)}
textarea.field{min-height:100px;resize:none}
.choice-row{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:10px}
.perf-portrait{width:120px;height:150px;border-radius:16px;overflow:hidden;flex:0 0 auto}
.perf-portrait img{width:100%;height:100%;object-fit:cover}

/* ============================================================== TOAST */
.toast-wrap{position:fixed;z-index:90;top:22px;left:50%;transform:translateX(-50%);display:flex;
  flex-direction:column;gap:12px;align-items:center;width:min(560px,92%);pointer-events:none}
.toast{pointer-events:auto;width:100%;display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:16px;
  border:1px solid rgba(var(--primary-rgb)/.35);
  background:linear-gradient(180deg,var(--surface-alt),var(--surface));box-shadow:var(--lift);
  transform:translateY(-18px);opacity:0;transition:.4s var(--ease)}
.toast.show{transform:none;opacity:1}
.toast .ic{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;flex:0 0 auto;
  background:rgba(var(--primary-rgb)/.14);color:var(--primary)}
.toast .ic svg{width:22px;height:22px}
.toast.ok .ic{background:rgba(var(--success-rgb)/.14);color:var(--success)}
.toast .tt{font-family:var(--font-heading);font-size:1.05rem}
.toast .ts{color:var(--text-muted);font-size:.84rem;margin-top:1px}

/* age gate */
#agegate{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--pad);
  background:radial-gradient(50% 40% at 50% 42%,rgba(var(--primary-rgb)/.12),transparent 72%),
    linear-gradient(180deg,var(--bg-elevated),var(--bg))}
#agegate.hide{display:none}
.gate-card{max-width:460px;text-align:center;padding:clamp(30px,5vw,48px)}
.gate-card .age{font-family:var(--font-heading);font-size:clamp(3.2rem,8vw,5rem);color:var(--primary);line-height:1;
  text-shadow:0 0 40px rgba(var(--primary-rgb)/.4)}
.gate-card h2{margin-top:12px;font-size:1.6rem}
.gate-card p{color:var(--text-muted);margin:16px 0 28px;font-size:.92rem}
.gate-card .btn{margin-bottom:12px}

/* ============================================================ RESPONSIVE */
@media (orientation:portrait){
  .app{grid-template-columns:1fr;grid-template-rows:1fr var(--bar);grid-template-areas:"main" "nav"}
  .nav{flex-direction:row;align-items:center;padding:6px 8px;border-right:0;border-top:var(--hair);
    padding-bottom:max(6px,env(safe-area-inset-bottom))}
  .nav__brand{display:none}
  .nav__items{flex-direction:row;gap:2px}
  .navbtn{flex:1;min-height:auto}
  .navbtn[aria-current="true"]::before{left:30%;right:30%;top:-6px;bottom:auto;width:auto;height:2px;
    background:linear-gradient(90deg,transparent,var(--primary),transparent)}
  .navbtn .cart-badge{top:4px;right:calc(50% - 26px);transform:none}
  .screen{padding-bottom:calc(var(--pad) + 24px)}
  .fab{bottom:calc(var(--bar) + 18px)}
}
@media (max-width:430px){.mr__name,.mr__price{font-size:1.15rem}}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.16s!important}
  .atm-bloom,.atm-sweep,.atm-grain,.atm-vignette,.attract__emblem,#embers{animation:none!important}
  .screen{filter:none!important}
}
