/* Demo Nights, shared design system. Tokens + atoms lifted verbatim from index.html so the
   /vote, /admin, /gallery surfaces are pixel-coherent with the marketing site. No framework. */

:root{
  --midnight:#16151D;--bg:#0B0A0E;--lemon:#F5E400;--cloud:#F0EEE4;
  --muted:rgba(240,238,228,.55);--line:rgba(240,238,228,.13);
  --teal:#1ED1C2;--violet:#7D5FFF;--pink:#FF76BC;
  --ok:#3Fcaa0;--warn:#e6a86a;--bad:#ff7878;
  --r:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{background:var(--bg);color:var(--cloud);font-family:'Satoshi',system-ui,sans-serif;overflow-x:hidden;position:relative;min-height:100vh}
body::before{content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;background:radial-gradient(48% 44% at 62% 0%,rgba(245,228,0,.18),transparent 62%),radial-gradient(46% 46% at 100% 100%,rgba(125,95,255,.14),transparent 62%),radial-gradient(44% 44% at 0% 72%,rgba(245,228,0,.09),transparent 60%)}
body::after{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.55;mix-blend-mode:overlay;background-image:url('grain.png');background-repeat:repeat;background-size:130px 130px;transform:translateZ(0)}
::selection{background:var(--lemon);color:var(--midnight)}
a{color:inherit;text-decoration:none}
.mono{font-family:'Geist Mono',monospace}
.muted{color:var(--muted)}
.display{font-family:'Clash Display',sans-serif;font-weight:600;letter-spacing:-.01em}

/* topbar (shared with the marketing site) */
.topbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:14px;padding:12px 22px;border-bottom:1px solid var(--line);background:rgba(11,10,14,.66);-webkit-backdrop-filter:blur(14px) saturate(1.25);backdrop-filter:blur(14px) saturate(1.25)}
.topbar .brand{display:inline-flex;align-items:center;gap:9px;font-family:'Clash Display',sans-serif;font-weight:600;font-size:20px;letter-spacing:-.01em;white-space:nowrap}
.topbar .brand::before{content:"";width:18px;height:18px;border-radius:6px;background:linear-gradient(135deg,var(--lemon),#b9a800);box-shadow:0 0 0 1px rgba(245,228,0,.3),0 6px 16px -6px rgba(245,228,0,.55);flex:none}
.topbar .brand i{color:var(--lemon);font-style:normal}
.topbar .nav{display:flex;align-items:center;gap:2px;margin-left:auto;min-width:0}
.topbar .nav a{position:relative;font-family:'Geist Mono',monospace;font-size:13px;letter-spacing:.03em;color:var(--muted);padding:8px 12px;border-radius:9px;transition:.18s;white-space:nowrap}
.topbar .nav a:hover{color:var(--cloud);background:rgba(255,255,255,.06)}
.topbar .nav a.active{color:var(--cloud)}
.topbar .nav a.active::after{content:"";position:absolute;left:12px;right:12px;bottom:3px;height:2px;border-radius:2px;background:var(--lemon)}
@media(max-width:600px){.topbar{padding:10px 12px;gap:8px}.topbar .brand{font-size:17px}.topbar .brand::before{width:16px;height:16px}.topbar .nav{gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.topbar .nav::-webkit-scrollbar{display:none}.topbar .nav a{font-size:12px;padding:7px 9px}}

.kicker{font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--lemon)}

/* buttons, ≥48px tall tap targets */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:13px 20px;border-radius:12px;font-family:'Satoshi',sans-serif;font-weight:700;font-size:15px;cursor:pointer;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--cloud);transition:.16s;width:100%}
.btn:hover{background:rgba(255,255,255,.08)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-lemon{background:var(--lemon);color:var(--midnight);border-color:var(--lemon)}
.btn-lemon:hover{filter:brightness(1.05);background:var(--lemon)}
.btn-ghost{background:transparent}
.btn-sm{min-height:38px;padding:8px 13px;font-size:13px;width:auto}

/* panels / cards */
.panel{background:var(--midnight);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 24px 60px -30px #000}
.wrap{max-width:560px;margin:0 auto;padding:24px 18px 64px}
.wrap-wide{max-width:1080px;margin:0 auto;padding:22px 22px 64px}

/* form fields (from the marketing modal) */
label.fld{display:block;font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:15px 0 7px}
input,textarea,select{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:11px;padding:13px 14px;color:var(--cloud);font-family:'Satoshi',sans-serif;font-size:16px}
input::placeholder,textarea::placeholder{color:rgba(240,238,228,.38)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--lemon)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* winner + demo atoms (verbatim from index.html detail modal) */
.win{border-top:1px solid var(--line);padding:13px 0;display:flex;gap:13px;align-items:baseline}
.win:first-of-type{border-top:none}
.win .rk{font-size:16px;min-width:28px}
.win .wn{font-weight:700;font-size:16px}
.win .wd{display:block;font-weight:400;font-size:13px;color:var(--muted);margin-top:3px;line-height:1.4}
.demo{border-top:1px solid var(--line);padding:13px 0;display:flex;gap:13px;align-items:baseline}
.demo .dn{font-family:'Geist Mono',monospace;font-size:12px;color:var(--lemon);min-width:28px}
.demo .dt b{font-size:15px;font-weight:700}
.demo .dt span{display:block;font-size:12.5px;color:var(--muted);margin-top:2px}
.pill{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.04em;color:var(--lemon);border:1px solid rgba(245,228,0,.4);border-radius:999px;padding:3px 8px;white-space:nowrap}

/* toast / status line */
.note{font-size:13.5px;line-height:1.5;border-radius:11px;padding:11px 13px;margin-top:12px}
.note.ok{color:var(--ok);background:rgba(63,202,160,.08);border:1px solid rgba(63,202,160,.3)}
.note.warn{color:var(--warn);background:rgba(230,168,106,.08);border:1px solid rgba(230,168,106,.3)}
.note.bad{color:var(--bad);background:rgba(255,120,120,.08);border:1px solid rgba(255,120,120,.3)}

/* skeleton shimmer (no layout jank while loading) */
.skel{background:linear-gradient(100deg,rgba(255,255,255,.04) 30%,rgba(255,255,255,.09) 50%,rgba(255,255,255,.04) 70%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:10px}
@keyframes shimmer{to{background-position:-200% 0}}
[hidden]{display:none!important}
@media(prefers-reduced-motion:reduce){.skel{animation:none}*{scroll-behavior:auto}}
