/* roundd — shared stylesheet (generated by build-hosting.cjs; do not edit by hand) */

:root{
  --ink:#0B1014; --midnight:#10161C; --raised:#161E26; --card:#131B22; --line:#212C36; --lineSoft:#1A242E;
  --gold:#D8B96A; --goldSoft:rgba(216,185,106,.12); --steel:#8B97A6; --steelDim:#5C6675;
  --frost:#EAEEF2; --white:#FFFFFF; --green:#7FB890; --navy:#26333F;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth; background:#0B1014; min-height:100%; -webkit-text-size-adjust:100%;}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  background:#0B1014; color:var(--frost); line-height:1.6; min-height:100vh;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; letter-spacing:-0.01em;
}
a{color:inherit; text-decoration:none;}
svg{display:block;}
.nav{ position:sticky; top:0; z-index:50; display:flex; align-items:center; justify-content:space-between; padding:16px 32px; background:rgba(11,16,20,.72); backdrop-filter:saturate(180%) blur(16px); border-bottom:1px solid var(--lineSoft);}
.nav .wm{ font-size:21px; letter-spacing:.04em; font-weight:500; color:var(--frost);}
.nav .wm .d{color:var(--gold);}
.nav .links{ display:flex; align-items:center; gap:32px; font-size:14px; color:var(--steel); font-weight:450;}
.nav .links a{ transition:color .15s;}
.nav .links a:hover, .nav .links a.active{ color:var(--frost);}
.nav .cta{ background:var(--frost); color:var(--ink)!important; font-weight:600; padding:8px 16px; border-radius:8px; font-size:13.5px; transition:background .15s, transform .1s;}
.nav .cta:hover{ background:#fff; transform:translateY(-1px);}
.wrap{ max-width:1120px; margin:0 auto; padding:0 32px;}
section{ padding:104px 0;}
.eyebrow{ font-size:12px; letter-spacing:.16em; text-transform:lowercase; color:var(--gold); font-weight:600;}
h1,h2,h3{ letter-spacing:-0.025em; color:var(--frost); font-weight:600; line-height:1.08;}
h2{ font-size:42px;}
h2 b{ color:var(--gold); font-weight:600;}
.lede{ color:var(--steel); font-size:18px; max-width:600px; line-height:1.65; font-weight:400;}
.btn{ display:inline-flex; align-items:center; gap:8px; background:var(--gold); color:var(--ink); font-weight:600; font-size:15px; padding:13px 26px; border-radius:10px; transition:transform .12s, box-shadow .2s;}
.btn:hover{ transform:translateY(-1px); box-shadow:0 8px 24px -8px rgba(216,185,106,.5);}
.btn-ghost{ display:inline-flex; align-items:center; gap:8px; border:1px solid var(--line); color:var(--frost); font-weight:500; font-size:15px; padding:12px 24px; border-radius:10px; transition:border-color .15s, background .15s;}
.btn-ghost:hover{ border-color:var(--steel); background:var(--raised);}
.btn .arr, .btn-ghost .arr{ width:16px; height:16px;}
.hero{ position:relative; overflow:hidden; padding:120px 0 96px; background:#0B1014;}
.hero::before{ content:""; position:absolute; top:-20%; right:-10%; width:60%; height:120%; background:radial-gradient(ellipse at center, rgba(216,185,106,.10), transparent 65%); pointer-events:none;}
.hero::after{ content:""; position:absolute; inset:0; opacity:.5; background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.04) 1px, transparent 0); background-size:32px 32px; pointer-events:none; -webkit-mask-image:linear-gradient(to bottom, black, transparent 80%); mask-image:linear-gradient(to bottom, black, transparent 80%);}
.hero .inner{ position:relative; max-width:840px;}
.hero h1{ font-size:68px; margin-top:24px; color:#FCFDFE; letter-spacing:-0.035em; line-height:1.02;}
.hero h1 b{ color:var(--gold); font-weight:600;}
.hero .sub{ color:var(--steel); font-size:20px; margin-top:26px; max-width:560px; line-height:1.6; font-weight:400;}
.hero .actions{ margin-top:38px; display:flex; gap:12px; flex-wrap:wrap;}
.hero .cred{ margin-top:48px; font-size:12px; letter-spacing:.14em; text-transform:lowercase; color:var(--steelDim); display:flex; align-items:center; gap:10px;}
.hero .cred::before{ content:""; width:24px; height:1px; background:var(--line);}
.logos{ border-top:1px solid var(--lineSoft); border-bottom:1px solid var(--lineSoft); padding:26px 0;}
.logos .row{ display:flex; align-items:center; justify-content:center; gap:46px; flex-wrap:wrap;}
.logos .l{ font-size:13px; letter-spacing:.1em; text-transform:lowercase; color:var(--steelDim); font-weight:500;}
.grid3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:56px; background:var(--lineSoft); border:1px solid var(--lineSoft); border-radius:16px; overflow:hidden;}
.fcard{ background:var(--midnight); padding:32px 30px; transition:background .2s;}
.fcard:hover{ background:var(--card);}
.fcard .ic{ width:38px; height:38px; display:flex; align-items:center; justify-content:flex-start; margin-bottom:18px; color:var(--gold);}
.fcard .ic svg{ width:24px; height:24px;}
.fcard h3{ font-size:16px; font-weight:600; color:var(--frost); margin-bottom:8px; letter-spacing:-0.01em;}
.fcard p{ font-size:14px; color:var(--steel); line-height:1.6; font-weight:400;}
.band{ background:var(--midnight); border-top:1px solid var(--lineSoft); border-bottom:1px solid var(--lineSoft);}
.split{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;}
.chrome{ background:var(--card); border:1px solid var(--line); border-radius:14px; overflow:hidden; box-shadow:0 24px 60px -24px rgba(0,0,0,.6);}
.chrome .bar{ display:flex; align-items:center; gap:7px; padding:13px 16px; border-bottom:1px solid var(--lineSoft); background:var(--midnight);}
.chrome .bar i{ width:11px; height:11px; border-radius:50%; background:var(--line);}
.chrome .cbody{ padding:20px;}
.tagstrip{ text-align:center; padding:84px 0;}
.tagstrip .t{ font-size:34px; font-weight:500; letter-spacing:-0.02em; color:var(--steel);}
.tagstrip .t .d{color:var(--gold);} .tagstrip .t .g{color:var(--gold);} .tagstrip .t .w{color:var(--white);}
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:56px; align-items:stretch;}
.tier{ background:var(--midnight); border:1px solid var(--line); border-radius:18px; padding:32px 28px; display:flex; flex-direction:column; position:relative;}
.tier.feat{ border-color:rgba(216,185,106,.5); background:linear-gradient(180deg, rgba(216,185,106,.05), transparent 40%);}
.tier .badge{ position:absolute; top:-11px; left:28px; background:var(--gold); color:var(--ink); font-size:11px; letter-spacing:.06em; text-transform:lowercase; font-weight:700; padding:5px 12px; border-radius:7px;}
.tier .tn{ font-size:13px; font-weight:600; color:var(--steel); letter-spacing:.06em; text-transform:lowercase;}
.tier .pr{ font-size:44px; font-weight:680; color:var(--frost); margin:14px 0 2px; letter-spacing:-0.03em;}
.tier .pr small{ font-size:15px; color:var(--steel); font-weight:400; letter-spacing:0;}
.tier .pd{ font-size:13.5px; color:var(--steelDim); margin-bottom:22px;}
.tier ul{ list-style:none; margin:8px 0 26px; flex:1; display:flex; flex-direction:column; gap:12px;}
.tier li{ font-size:14px; color:var(--steel); padding-left:26px; position:relative; line-height:1.4;}
.tier li svg{ position:absolute; left:0; top:2px; width:16px; height:16px; color:var(--gold);}
.tier .btn, .tier .btn-ghost{ justify-content:center;}
footer{ border-top:1px solid var(--lineSoft); padding:64px 0 44px; background:var(--midnight);}
footer .frow{ display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap;}
footer .wm{ font-size:22px; letter-spacing:.04em; color:var(--frost); font-weight:500;} footer .wm .d{color:var(--gold);}
footer .tag{ font-size:13px; color:var(--steelDim); margin-top:12px; letter-spacing:-0.01em;}
footer .fcol h4{ font-size:11px; letter-spacing:.12em; text-transform:lowercase; color:var(--steelDim); margin-bottom:14px; font-weight:600;}
footer .fcol a{ display:block; font-size:14px; color:var(--steel); margin-bottom:10px; transition:color .15s;}
footer .fcol a:hover{ color:var(--frost);}
footer .legal{ margin-top:48px; padding-top:24px; border-top:1px solid var(--lineSoft); font-size:12.5px; color:var(--steelDim); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;}
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .7s cubic-bezier(.2,.6,.2,1), transform .7s cubic-bezier(.2,.6,.2,1);}
.reveal.in{ opacity:1; transform:none;}
@media (prefers-reduced-motion:reduce){ .reveal{opacity:1; transform:none; transition:none;} html{scroll-behavior:auto;}}
@media (max-width:880px){
  .nav{ padding:14px 20px;}
  .nav .links a:not(.cta){ display:none;}
  .wrap{ padding:0 22px;}
  section{ padding:72px 0;}
  .hero{ padding:80px 0 64px;}
  .hero h1{ font-size:44px;}
  .hero .sub{ font-size:18px;}
  h2{ font-size:32px;}
  .grid3{ grid-template-columns:1fr;}
  .tiers{ grid-template-columns:1fr; gap:32px;}
  .split{ grid-template-columns:1fr; gap:36px;}
  .tagstrip .t{ font-size:23px;}
  .logos .row{ gap:26px;}
}

/* ===== cinematic hero (Adaline-inspired) ===== */
.cine{ position:relative; background:#0B1014; overflow:hidden; padding-top:64px;}
.cine .copy{ position:relative; z-index:3; text-align:center; max-width:760px; margin:0 auto; padding:64px 24px 0;}
.pill{ display:inline-flex; align-items:center; gap:8px; background:rgba(216,185,106,.1); border:1px solid rgba(216,185,106,.28); color:var(--gold); font-size:12.5px; font-weight:500; padding:7px 15px; border-radius:100px; margin-bottom:28px; letter-spacing:.01em;}
.pill .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 3px rgba(216,185,106,.2);}
.cine h1{ font-size:64px; line-height:1.03; letter-spacing:-0.04em; color:#FCFDFE; font-weight:640;}
.cine h1 b{ color:var(--gold); font-weight:640;}
.cine h1 .d{ color:var(--gold);}
.cine .sub{ font-size:20px; color:var(--steel); margin:26px auto 0; max-width:540px; line-height:1.6; font-weight:400;}
.cine .actions{ margin-top:34px; display:flex; gap:12px; justify-content:center; flex-wrap:wrap;}
.cine .scene{ position:relative; z-index:1; margin-top:8px; width:100%; height:560px; display:block;}
.cine .scene svg{ width:100%; height:100%; display:block;}
.cine .fade{ position:absolute; left:0; right:0; bottom:0; height:180px; z-index:2; background:linear-gradient(to bottom, transparent, #0B1014); pointer-events:none;}
.trust{ position:relative; z-index:3; text-align:center; padding:0 24px 64px; background:#0B1014;}
.trust .lab{ font-size:11px; letter-spacing:.18em; text-transform:lowercase; color:var(--steelDim); margin-bottom:22px;}
.trust .row{ display:flex; align-items:center; justify-content:center; gap:44px; flex-wrap:wrap; opacity:.72;}
.trust .row span{ font-size:15px; letter-spacing:.02em; color:var(--steel); font-weight:500;}
/* product showcase */
.showcase{ position:relative; margin-top:-40px;}
.showcase .frame{ max-width:980px; margin:0 auto; border-radius:16px; border:1px solid var(--line); overflow:hidden; box-shadow:0 40px 100px -40px rgba(0,0,0,.8); background:var(--card);}
@media (max-width:880px){
  .cine{ padding-top:20px;}
  .cine .copy{ padding:36px 18px 0;}
  .cine h1{ font-size:40px;}
  .cine .sub{ font-size:17px;}
  .cine .scene{ height:340px;}
  .trust .row{ gap:24px;} .trust .row span{ font-size:13px;}
}

/* ===== product showcase (clean, class-based) ===== */
.showcase .frame{ max-width:980px; margin:0 auto; border-radius:16px; border:1px solid var(--line); overflow:hidden; box-shadow:0 40px 100px -40px rgba(0,0,0,.8); background:var(--card);}
.showcase .bar{ display:flex; align-items:center; gap:7px; padding:13px 16px; border-bottom:1px solid var(--lineSoft); background:var(--midnight);}
.showcase .bar i{ width:11px; height:11px; border-radius:50%; background:var(--line);}
.showcase .barlabel{ margin-left:10px; font-size:12px; color:var(--steelDim);}
.showcase .mock{ display:flex; min-height:380px;}
.showcase .mock-side{ width:184px; background:#0C1116; border-right:1px solid var(--lineSoft); padding:20px 14px; flex-shrink:0;}
.showcase .mock-wm{ font-size:17px; letter-spacing:.04em; color:var(--frost); margin-bottom:24px; padding-left:6px;}
.showcase .mock-tab{ font-size:13px; color:var(--steel); padding:9px 12px; border-radius:8px; margin-bottom:2px; display:flex; align-items:center; gap:9px;}
.showcase .mock-tab.active{ color:var(--frost); background:var(--raised);}
.showcase .mock-tab .d{ width:5px; height:5px; border-radius:50%; background:var(--gold);}
.showcase .mock-main{ flex:1; padding:22px 26px; min-width:0;}
.showcase .mock-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; gap:12px;}
.showcase .mock-date{ font-size:18px; color:var(--frost); font-weight:500;}
.showcase .mock-book{ font-size:12px; color:var(--ink); background:var(--gold); padding:7px 13px; border-radius:7px; font-weight:600; white-space:nowrap; flex-shrink:0;}
.showcase .mock-rows{ display:flex; flex-direction:column; gap:7px;}
.showcase .mrow{ display:flex; gap:14px; align-items:center; padding:11px 14px; background:var(--raised); border:1px solid var(--line); border-radius:9px;}
.showcase .mrow.open{ background:transparent; border-style:dashed;}
.showcase .mrow b{ color:var(--gold); width:48px; font-size:13px; flex-shrink:0;}
.showcase .mrow.open b{ color:var(--steelDim);}
.showcase .mp{ color:var(--frost); font-size:13px; flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
.showcase .mrow.open .mp{ color:var(--steelDim);}
.showcase .mt{ font-size:11px; color:var(--steel); background:var(--midnight); padding:4px 10px; border-radius:6px; flex-shrink:0;}
.showcase .mt.avail{ color:var(--green); background:rgba(127,184,144,.12);}

/* ===== mobile fixes ===== */
@media (max-width:880px){
  .cine .scene{ height:300px; margin-top:18px;}
  .cine .fade{ height:120px;}
  .trust{ padding:6px 20px 44px;}
  .trust .row{ gap:14px 24px;}
  .showcase{ margin-top:-20px;}
  .showcase .barlabel{ display:none;}
  .showcase .mock{ flex-direction:column; min-height:0;}
  .showcase .mock-side{ width:100%; flex-direction:row; gap:6px; overflow-x:auto; border-right:none; border-bottom:1px solid var(--lineSoft); padding:12px 14px; -webkit-overflow-scrolling:touch;}
  .showcase .mock-wm{ display:none;}
  .showcase .mock-tab{ margin-bottom:0; white-space:nowrap; flex-shrink:0; font-size:12.5px; padding:8px 13px;}
  .showcase .mock-main{ padding:20px;}
  .showcase .mock-date{ font-size:16px;}
}
@media (max-width:560px){
  .cine .scene{ height:240px;}
}

/* ============================== demo app components ============================== */

  /* ===== interactive demo ===== */
  .demo-wrap{ max-width:1180px; margin:0 auto; padding:0 30px;}
  .app{ background:var(--midnight); border:1px solid var(--line); border-radius:16px; overflow:hidden; display:flex; min-height:560px; margin-top:30px;}
  .side{ width:208px; background:#0C1116; border-right:1px solid var(--line); padding:24px 16px; flex-shrink:0;}
  .side .lwm{ font-size:20px; letter-spacing:2px; color:var(--frost); margin-bottom:28px; padding-left:8px;} .side .lwm .d{color:var(--gold);}
  .side .nav-item{ display:flex; align-items:center; gap:10px; font-size:13.5px; color:var(--steel); padding:10px 12px; border-radius:8px; cursor:pointer; margin-bottom:3px; transition:all .12s;}
  .side .nav-item:hover{ background:var(--raised); color:var(--frost);}
  .side .nav-item.active{ background:var(--raised); color:var(--frost);}
  .side .nav-item .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); opacity:0; flex-shrink:0;}
  .side .nav-item.active .dot{ opacity:1;}
  .side .nav-item .lbl{ white-space:nowrap;}
  .addon-tag{ margin-left:auto; font-size:9.5px; letter-spacing:.04em; text-transform:lowercase; color:var(--gold); background:var(--goldSoft); border:1px solid rgba(216,185,106,.32); padding:2px 6px; border-radius:5px; font-weight:600; flex-shrink:0;}
  .main{ flex:1; padding:26px 30px; overflow:auto; min-width:0;}
  .topbar{ display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; flex-wrap:wrap; gap:12px;}
  .topbar h2{ font-size:22px; color:var(--frost); font-weight:500; letter-spacing:0;}
  .topbar .date-nav{ display:flex; align-items:center; gap:8px;}
  .topbar .date-nav button{ background:var(--raised); border:1px solid var(--line); color:var(--steel); width:30px; height:30px; border-radius:7px; cursor:pointer; font-size:14px;}
  .topbar .add{ background:var(--gold); color:var(--midnight); border:none; font-weight:600; font-size:13px; padding:9px 16px; border-radius:8px; cursor:pointer; font-family:inherit;}
  .panel{ display:none;}
  .panel.show{ display:block; animation:fade .25s ease;}
  @keyframes fade{ from{opacity:0; transform:translateY(6px);} to{opacity:1; transform:none;}}

  .addon-note{ display:flex; align-items:center; gap:8px; font-size:12px; color:var(--steel); background:rgba(216,185,106,.05); border:1px solid rgba(216,185,106,.18); border-radius:9px; padding:9px 13px; margin-bottom:18px;}
  .addon-note .ad{ color:var(--gold); font-weight:600; letter-spacing:.01em;}
  .card2{ background:var(--raised); border:1px solid var(--line); border-radius:12px; padding:18px;}
  .sectlabel{ font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--gold); margin-bottom:14px;}

  /* tee / bay sheet */
  .teerow{ display:flex; align-items:center; gap:14px; padding:13px 16px; border:1px solid var(--line); border-radius:10px; margin-bottom:8px; background:var(--raised); cursor:pointer; transition:border-color .12s;}
  .teerow:hover{ border-color:var(--gold);}
  .teerow .time{ font-size:14px; color:var(--gold); font-weight:700; width:64px; flex-shrink:0;}
  .teerow .players{ flex:1; font-size:13.5px; color:var(--frost);}
  .teerow .tag{ font-size:11px; color:var(--steel); background:var(--midnight); padding:5px 11px; border-radius:6px; flex-shrink:0;}
  .teerow.open{ background:transparent; border-style:dashed;}
  .teerow.open .players{ color:var(--steelDim);}
  .teerow.open .tag{ color:var(--green); background:rgba(127,184,144,.12);}
  .teerow.booked-flash{ border-color:var(--gold); background:rgba(216,185,106,.1);}

  /* dashboard */
  .statgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px;}
  .stat{ background:var(--raised); border:1px solid var(--line); border-radius:11px; padding:16px;}
  .stat .l{ font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--steelDim);}
  .stat .v{ font-size:26px; font-weight:700; color:var(--frost); margin-top:6px;}
  .stat .v.gold{ color:var(--gold);}
  .chart{ background:var(--raised); border:1px solid var(--line); border-radius:12px; padding:20px;}
  .bars{ display:flex; align-items:flex-end; gap:10px; height:120px;}
  .bars > div{ flex:1; border-radius:5px 5px 0 0; background:var(--navy);}
  .barscale{ display:flex; gap:10px; margin-top:8px; font-size:11px; color:var(--steelDim);}
  .barscale span{ flex:1; text-align:center;}

  /* members */
  .mlist .mrow{ display:flex; align-items:center; gap:14px; padding:13px 16px; border-bottom:1px solid var(--line);}
  .mlist .av{ width:36px; height:36px; border-radius:50%; background:var(--navy); display:flex; align-items:center; justify-content:center; font-size:13px; color:var(--gold); font-weight:600; flex-shrink:0;}
  .mlist .mn{ flex:1; font-size:14px; color:var(--frost);}
  .mlist .mt{ font-size:12px; color:var(--steel); background:var(--raised); padding:4px 10px; border-radius:6px; flex-shrink:0;}

  /* POS */
  .pos{ display:grid; grid-template-columns:1fr 296px; gap:16px;}
  .prodgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px;}
  .prod{ background:var(--raised); border:1px solid var(--line); border-radius:10px; padding:14px 12px; cursor:pointer; transition:border-color .12s, transform .08s;}
  .prod:hover{ border-color:var(--gold); transform:translateY(-1px);}
  .prod .pn{ font-size:13px; color:var(--frost); font-weight:500;}
  .prod .pp{ font-size:13.5px; color:var(--gold); margin-top:7px; font-weight:600;}
  .prod .pc{ font-size:10px; letter-spacing:.4px; text-transform:uppercase; color:var(--steelDim); margin-top:3px;}
  .cart{ background:var(--raised); border:1px solid var(--line); border-radius:12px; padding:16px; display:flex; flex-direction:column;}
  .cart .ch{ font-size:13px; color:var(--frost); font-weight:600; margin-bottom:12px; display:flex; justify-content:space-between;}
  .cart .ch span{ color:var(--green); font-weight:500; font-size:11px; background:rgba(127,184,144,.12); padding:3px 9px; border-radius:6px;}
  .cartrows{ flex:1; min-height:96px; display:flex; flex-direction:column; gap:6px; margin-bottom:6px;}
  .cartrow{ display:flex; justify-content:space-between; font-size:13px; color:var(--frost); padding:8px 10px; background:var(--midnight); border-radius:7px; cursor:pointer; transition:color .12s;}
  .cartrow:hover{ color:var(--gold);}
  .cartrow .x{ color:var(--steelDim); margin-left:4px;}
  .cartempty{ font-size:12.5px; color:var(--steelDim); text-align:center; padding:30px 10px;}
  .carttot{ display:flex; justify-content:space-between; font-size:15px; color:var(--frost); font-weight:600; padding-top:12px; border-top:1px solid var(--line); margin:6px 0 12px;}
  .carttot b{ color:var(--gold);}
  .paybtns{ display:flex; gap:8px;}
  .paybtns button{ flex:1; border-radius:8px; font-weight:600; font-size:12.5px; padding:11px 8px; cursor:pointer; font-family:inherit; transition:border-color .12s;}
  .paybtns .pay-member{ background:var(--midnight); border:1px solid var(--line); color:var(--frost);}
  .paybtns .pay-member:hover{ border-color:var(--gold);}
  .paybtns .pay-card{ background:var(--gold); border:1px solid var(--gold); color:var(--midnight);}

  /* door access */
  .acc{ display:grid; grid-template-columns:1fr 296px; gap:16px;}
  .doorlist{ display:flex; flex-direction:column; gap:8px;}
  .door{ display:flex; align-items:center; gap:12px; padding:13px 15px; background:var(--raised); border:1px solid var(--line); border-radius:10px; cursor:pointer; transition:border-color .18s;}
  .door:hover{ border-color:var(--gold);}
  .door .lock{ width:17px; height:17px; color:var(--steel); flex-shrink:0;}
  .door .dn{ flex:1; font-size:13.5px; color:var(--frost);}
  .door .ds{ font-size:11px; color:var(--steel); background:var(--midnight); padding:4px 10px; border-radius:6px; flex-shrink:0;}
  .door .ds.unlocked{ color:var(--green); background:rgba(127,184,144,.12);}
  .codebox{ background:var(--raised); border:1px solid var(--line); border-radius:12px; padding:20px 18px; text-align:center; margin-bottom:14px;}
  .codebox .cl{ font-size:12px; color:var(--steelDim);}
  .codeval{ font-size:36px; font-weight:700; letter-spacing:.16em; color:var(--gold); font-variant-numeric:tabular-nums; margin:10px 0 6px;}
  .codeexp{ font-size:12px; color:var(--steelDim);}
  .gencode{ width:100%; background:var(--gold); color:var(--midnight); border:none; font-weight:600; font-size:13px; padding:12px; border-radius:9px; cursor:pointer; font-family:inherit;}
  .tieraccess{ display:flex; flex-direction:column; gap:8px;}
  .tierrow{ display:flex; align-items:center; gap:12px; padding:11px 14px; background:var(--midnight); border:1px solid var(--line); border-radius:10px;}
  .tierrow .tn{ flex:1; font-size:13px; color:var(--frost);}

  /* switch */
  .sw{ width:38px; height:22px; border-radius:100px; background:var(--line); position:relative; cursor:pointer; transition:background .15s; flex-shrink:0;}
  .sw::after{ content:""; position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%; background:var(--steel); transition:transform .15s, background .15s;}
  .sw.on{ background:rgba(216,185,106,.35);}
  .sw.on::after{ transform:translateX(16px); background:var(--gold);}

  /* loyalty & events */
  .lev{ display:grid; grid-template-columns:1fr 296px; gap:16px;}
  .evlist{ display:flex; flex-direction:column; gap:8px;}
  .ev{ display:flex; align-items:flex-start; gap:12px; padding:14px 15px; background:var(--raised); border:1px solid var(--line); border-radius:10px;}
  .ev .evn{ flex:1; min-width:0;}
  .ev .evt{ font-size:13.5px; color:var(--frost); font-weight:500;}
  .ev .evw{ font-size:11.5px; color:var(--steel); margin-top:3px;}
  .ev .evsign{ font-size:11px; color:var(--gold); margin-top:8px;}
  .evbar{ height:4px; background:var(--midnight); border-radius:3px; margin-top:6px; overflow:hidden;}
  .evbar i{ display:block; height:100%; background:var(--gold); border-radius:3px;}
  .ev .evtag{ font-size:10px; letter-spacing:.4px; text-transform:uppercase; color:var(--steel); background:var(--midnight); padding:4px 9px; border-radius:6px; flex-shrink:0;}
  .loyrow{ display:flex; align-items:center; gap:10px; padding:11px 0; border-bottom:1px solid var(--line);}
  .loyrow .ln{ flex:1; font-size:13px; color:var(--frost);}
  .loyrow .lt{ font-size:10px; letter-spacing:.4px; text-transform:uppercase; color:var(--steelDim); margin-top:2px;}
  .loyrow .lp{ font-size:13px; color:var(--gold); font-weight:600; white-space:nowrap;}

  /* settings / branding */
  .setgrid{ display:grid; grid-template-columns:1fr 1fr; gap:16px;}
  .field{ margin-bottom:16px;}
  .field label{ display:block; font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--steelDim); margin-bottom:7px;}
  .field input, .field textarea{ width:100%; background:var(--midnight); border:1px solid var(--line); border-radius:9px; padding:11px 13px; color:var(--frost); font-size:14px; font-family:inherit;}
  .field textarea{ resize:vertical; min-height:84px; line-height:1.5;}
  .field input::placeholder, .field textarea::placeholder{ color:var(--steelDim);}
  .field input:focus, .field textarea:focus{ outline:none; border-color:var(--gold);}
  .swatches{ display:flex; gap:10px; flex-wrap:wrap;}
  .swatch{ width:42px; height:42px; border-radius:10px; border:1px solid var(--line); cursor:pointer; transition:transform .1s;}
  .swatch:hover{ transform:scale(1.07);}
  .logo-ph{ width:64px; height:64px; border-radius:12px; border:1px dashed var(--line); display:flex; align-items:center; justify-content:center; color:var(--steelDim); font-size:11px; line-height:1.3; text-align:center;}
  .brandprev{ background:var(--midnight); border:1px solid var(--line); border-radius:12px; padding:30px 20px; text-align:center;}
  .brandprev .bw{ font-size:30px; letter-spacing:2px; color:var(--frost); font-weight:500; word-break:break-word;}
  .brandprev .bw .d{ color:var(--gold);}
  .brandprev .bt{ font-size:12px; color:var(--steelDim); margin-top:12px;}
  .savebtn{ background:var(--gold); color:var(--midnight); border:none; font-weight:600; font-size:13px; padding:10px 18px; border-radius:9px; cursor:pointer; font-family:inherit;}

  /* marketing */
  .mkt{ background:var(--raised); border:1px solid var(--line); border-radius:12px; padding:22px;}
  .mkt .draft{ background:var(--midnight); border-radius:10px; padding:16px; font-size:14px; color:var(--frost); line-height:1.6; margin:12px 0;}
  .mkt button{ background:var(--gold); color:var(--midnight); border:none; font-weight:600; font-size:13px; padding:9px 16px; border-radius:7px; cursor:pointer; font-family:inherit;}
  .mkt button.sec{ background:transparent; border:1px solid var(--line); color:var(--steel); margin-left:8px;}
  .mktgrid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:16px;}
  .schlist{ display:flex; flex-direction:column; gap:8px;}
  .sch{ display:flex; align-items:center; gap:12px; padding:11px 13px; background:var(--midnight); border:1px solid var(--line); border-radius:9px;}
  .sch .sw-when{ font-size:11.5px; color:var(--gold); width:84px; flex-shrink:0; font-weight:600;}
  .sch .sw-text{ flex:1; font-size:13px; color:var(--frost); min-width:0;}
  .sch .sw-ch{ font-size:11px; color:var(--steel); flex-shrink:0;}
  .remrow{ display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--line);}
  .remrow .rn{ flex:1;}
  .remrow .rnt{ font-size:13px; color:var(--frost);}
  .remrow .rns{ font-size:11.5px; color:var(--steelDim); margin-top:2px;}

  /* demo chrome */
  .demo-banner{ background:rgba(216,185,106,.08); border:1px solid rgba(216,185,106,.3); border-radius:10px; padding:12px 18px; font-size:13px; color:var(--steel); margin-top:24px; text-align:center;}
  .demo-banner b{ color:var(--gold);}
  .toast{ position:fixed; bottom:30px; left:50%; transform:translateX(-50%) translateY(80px); background:var(--gold); color:var(--midnight); font-weight:600; font-size:14px; padding:13px 24px; border-radius:10px; transition:transform .3s; z-index:100; max-width:90vw; text-align:center;}
  .toast.show{ transform:translateX(-50%) translateY(0);}

  /* vertical toggle */
  .vtoggle{ display:inline-flex; background:var(--midnight); border:1px solid var(--line); border-radius:100px; padding:5px; margin:22px auto 0; gap:4px;}
  .vtoggle button{ display:inline-flex; align-items:center; gap:8px; background:transparent; border:none; color:var(--steel); font-size:14px; font-weight:500; padding:9px 20px; border-radius:100px; cursor:pointer; transition:all .18s; font-family:inherit; letter-spacing:-0.01em;}
  .vtoggle button .ico{ width:16px; height:16px;}
  .vtoggle button.on{ background:var(--gold); color:var(--midnight); font-weight:600;}
  .vtoggle button:not(.on):hover{ color:var(--frost);}
  .vtoggle-label{ font-size:12px; color:var(--steelDim); margin-top:12px; letter-spacing:.02em;}

  /* ===== mobile: sidebar becomes a horizontal scroll row of tabs ===== */
  @media (max-width:820px){
    .demo-wrap{ padding:0 18px;}
    .app{ flex-direction:column; min-height:0;}
    .side{ width:100%; display:flex; flex-direction:row; align-items:center; gap:6px; overflow-x:auto; border-right:none; border-bottom:1px solid var(--line); padding:12px 14px; -webkit-overflow-scrolling:touch;}
    .side::-webkit-scrollbar{ height:0;}
    .side .lwm{ display:none;}
    .side .nav-item{ margin-bottom:0; white-space:nowrap; flex-shrink:0; padding:8px 13px; font-size:12.5px;}
    .side .nav-item .dot{ display:none;}
    .addon-tag{ margin-left:4px; padding:1px 5px; font-size:9px;}
    .main{ padding:20px 16px;}
    .statgrid{ grid-template-columns:repeat(2,1fr);}
    .pos,.acc,.lev,.setgrid,.mktgrid{ grid-template-columns:1fr;}
    .prodgrid{ grid-template-columns:repeat(2,1fr);}
    .topbar h2{ font-size:18px;}
    .teerow{ gap:10px; padding:11px 13px;}
    .teerow .time{ width:50px; font-size:13px;}
    .teerow .players{ font-size:12.5px; line-height:1.3;}
    .teerow .tag{ font-size:10px; padding:4px 8px;}
    .vtoggle button{ padding:9px 14px; font-size:13px;}
  }
  @media (max-width:420px){
    .prodgrid{ grid-template-columns:1fr 1fr;}
    .statgrid{ grid-template-columns:1fr 1fr;}
  }
