
:root{
  --primary:#0A1B3D; --secondary:#9B6CFF; --accent:#3DF5A0;
  --bg:#04070D; --fg:#EAF6FF; --muted:#8B93A7;
  --grad: linear-gradient(100deg, #3DF5A0, #5FE9FF, #9B6CFF);
  --display:"Space Grotesk", "Space Grotesk", system-ui, sans-serif; --body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; --scale:1.25;
  --maxw: 1120px; --r: 16px; color-scheme: dark;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--body);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(900px 500px at 80% -5%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 60%),
    radial-gradient(800px 500px at 10% 0%, color-mix(in srgb, var(--primary) 55%, transparent), transparent 55%);}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.05;margin:0 0 .4em}
h1{font-size:clamp(2.4rem,6vw,4.2rem)} h2{font-size:clamp(1.6rem,3.4vw,2.6rem)} h3{font-size:1.2rem}
p{color:#cdd5e6;margin:0 0 1em} .muted{color:var(--muted)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:72px 0}

/* nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);
  background:color-mix(in srgb, var(--bg) 72%, transparent);border-bottom:1px solid rgba(255,255,255,.07)}
.nav .wrap{display:flex;align-items:center;gap:18px;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:1.1rem}
.brand .dot{width:24px;height:24px;border-radius:8px;background:var(--grad);box-shadow:0 0 22px color-mix(in srgb,var(--accent) 60%,transparent)}
.nav nav{margin-left:auto;display:flex;gap:20px;flex-wrap:wrap}
.nav nav a{color:#c4cce0;font-size:.93rem} .nav nav a:hover{color:#fff}
.nav .cta{margin-left:8px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:999px;border:0;
  font-weight:600;font-size:.98rem;cursor:pointer;color:#05060B;background:var(--grad);
  box-shadow:0 8px 30px color-mix(in srgb,var(--accent) 30%,transparent);transition:transform .15s ease,filter .15s}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn.ghost{background:transparent;color:var(--fg);border:1px solid rgba(255,255,255,.18);box-shadow:none}
.btn.lg{padding:15px 28px;font-size:1.05rem}

/* hero */
.hero{padding:90px 0 60px;position:relative}
.hero .eyebrow{display:inline-block;padding:6px 14px;border-radius:999px;font-size:.8rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);
  background:color-mix(in srgb,var(--accent) 10%,transparent);margin-bottom:20px}
.hero p.lead{font-size:1.25rem;max-width:620px;color:#dde3f0}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero .glow{position:absolute;right:-10%;top:0;width:560px;height:560px;border-radius:50%;
  background:var(--grad);filter:blur(120px);opacity:.20;z-index:-1}

/* cards / grids */
.grid{display:grid;gap:18px}
.grid.c3{grid-template-columns:repeat(3,1fr)} .grid.c2{grid-template-columns:repeat(2,1fr)}
.card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:24px}
.card h3{margin-bottom:.3em}
.pill{display:inline-block;padding:3px 11px;border-radius:999px;background:color-mix(in srgb,var(--accent) 16%,transparent);
  color:var(--accent);font-size:.78rem;font-weight:600}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery .tile{aspect-ratio:4/3;border-radius:14px;border:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden}
.gallery .tile::after{content:"";position:absolute;inset:0;mix-blend-mode:screen;opacity:.9}

/* sessions / booking */
.cal{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.day{border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:14px;background:rgba(255,255,255,.03);cursor:pointer;transition:.15s}
.day:hover{border-color:color-mix(in srgb,var(--accent) 50%,transparent);transform:translateY(-2px)}
.day.sel{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent)}
.day .d{font-family:var(--display);font-weight:700;font-size:1.05rem}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:14px}
.slot{padding:11px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.2);cursor:pointer;text-align:center;font-size:.92rem}
.slot:hover{border-color:var(--accent)} .slot.sel{background:var(--grad);color:#05060B;font-weight:700;border-color:transparent}
.slot.soldout{opacity:.4;cursor:not-allowed;text-decoration:line-through}
.slot small{display:block;color:var(--muted);font-size:.72rem;margin-top:2px}
.slot.sel small{color:#05060B}

/* forms */
label{display:block;font-size:.82rem;color:var(--muted);margin:14px 0 6px}
input,select{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.25);color:#fff;font-size:1rem;font-family:var(--body)}
input:focus,select:focus{outline:2px solid var(--accent);border-color:transparent}
.qty{display:flex;align-items:center;gap:0;width:fit-content;border:1px solid rgba(255,255,255,.14);border-radius:12px;overflow:hidden}
.qty button{background:rgba(255,255,255,.06);color:#fff;border:0;width:42px;height:42px;font-size:1.3rem;cursor:pointer}
.qty input{width:64px;text-align:center;border:0;border-radius:0;background:transparent}

/* ticket */
.ticket{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:18px;overflow:hidden;max-width:380px}
.ticket .top{padding:20px 22px;background:var(--grad);color:#05060B}
.ticket .top b{font-family:var(--display);font-size:1.2rem}
.ticket .body{padding:22px;display:flex;gap:18px;align-items:center}
.qr{width:120px;height:120px;background:#fff;border-radius:10px;padding:8px;flex:none}
.qr svg{width:100%;height:100%}
.code{font-family:ui-monospace,Menlo,monospace;letter-spacing:.12em;color:var(--accent)}

/* gate + ops */
.scan{max-width:520px;margin:0 auto;text-align:center}
.verdict{margin-top:18px;padding:18px;border-radius:14px;font-weight:600}
.verdict.ok{background:color-mix(in srgb,#39d98a 22%,transparent);color:#aef5cf}
.verdict.dup{background:color-mix(in srgb,#f4b41a 22%,transparent);color:#ffe49a}
.verdict.bad{background:color-mix(in srgb,#ff5d5d 22%,transparent);color:#ffc2c2}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08)}
th{color:var(--muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
.stat{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:22px}
.stat .s{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:16px 22px;min-width:140px}
.stat .s b{font-family:var(--display);font-size:1.9rem;display:block}

/* footer + watermark */
footer{border-top:1px solid rgba(255,255,255,.08);padding:42px 0;margin-top:40px;color:var(--muted);font-size:.9rem}
footer .cols{display:flex;gap:40px;flex-wrap:wrap;justify-content:space-between}
.watermark{position:fixed;bottom:14px;left:14px;z-index:80;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.14);
  color:#fff;padding:7px 13px;border-radius:999px;font-size:.78rem;backdrop-filter:blur(8px)}
.watermark b{color:var(--accent)}

/* staff bar + POS + admin */
.staffbar{position:sticky;top:0;z-index:60;background:#0c0a14;border-bottom:1px solid rgba(255,255,255,.1)}
.staffbar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:48px;gap:12px;flex-wrap:wrap;padding-top:6px;padding-bottom:6px}
.staffbar .who{font-size:.85rem;color:var(--muted)} .staffbar .who b{color:var(--fg)}
.staffbar nav{display:flex;gap:16px} .staffbar nav a{font-size:.88rem;color:#c4cce0} .staffbar nav a:hover{color:#fff}
.posgridcols{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start;margin-top:18px}
.posgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.positem{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.2);color:var(--fg);cursor:pointer;font:inherit;text-align:center}
.positem:hover{border-color:var(--accent)} .positem .e{font-size:1.5rem} .positem small{color:var(--muted)}
.cartrow{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08)} .cartrow .lt{min-width:64px;text-align:right;font-weight:600}
.totalrow{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,.14);margin-top:12px;padding-top:12px;font-size:1.1rem}
.paybtns{display:flex;gap:8px;margin-top:8px} .paybtns .pay{flex:1;text-align:center}
.admin h4{margin:14px 0 8px;font-size:.95rem}
.camwrap{margin:14px 0}
.camwrap .cambox{position:relative;width:100%;max-width:360px;margin:0 auto}
.camwrap video{width:100%;aspect-ratio:1;object-fit:cover;border-radius:16px;background:#000;border:1px solid rgba(255,255,255,.14);display:block}
.camwrap .reticle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62%;height:62%;border:3px solid var(--accent);border-radius:14px;box-shadow:0 0 0 9999px rgba(0,0,0,.22);pointer-events:none}
@media(max-width:820px){
  .grid.c3,.grid.c2{grid-template-columns:1fr} .gallery{grid-template-columns:repeat(2,1fr)}
  .nav nav{display:none} .section{padding:52px 0}
  .posgridcols{grid-template-columns:1fr} .posgrid{grid-template-columns:repeat(2,1fr)}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}
