/* =========================================================
   NizzFizz PWA — Shared styles
   Two themes: [data-theme="dark"] (Night Neon) and
               [data-theme="candy"] (Arcade Candy)
   ========================================================= */

/* ---------- Theme tokens ---------- */
html[data-theme="dark"]{
  --bg:#0a0a0f;
  --bg2:#111119;
  --card:#15151f;
  --ink:#f5f5f7;
  --muted:#9a9aae;
  --line:rgba(255,255,255,.08);
  --primary:#e8ff00;   /* neon yellow */
  --secondary:#ff3c5f; /* hot pink */
  --tertiary:#22d3ee;  /* cyan */
  --quart:#a855f7;     /* purple */
  --good:#84cc16;
  --warn:#f59e0b;
  --bad:#ef4444;
  --on-primary:#0a0a0f;
  --on-secondary:#ffffff;
  --shadow:0 20px 60px rgba(0,0,0,.4);
  --shadow-hover:0 30px 70px rgba(0,0,0,.5);
  --radius:22px;
  --radius-sm:12px;
  --font-display:'Bebas Neue',sans-serif;
  --font-body:'Barlow',system-ui,sans-serif;
  --font-accent:'Space Grotesk',sans-serif;
  --display-tracking:1.5px;
  --display-weight:400;
}
html[data-theme="candy"]{
  --bg:#fff9f0;
  --bg2:#ffe8dc;
  --card:#ffffff;
  --ink:#1a1333;
  --muted:#6b5f8a;
  --line:rgba(26,19,51,.08);
  --primary:#ff3864;    /* coral */
  --secondary:#5ec8ff;  /* sky */
  --tertiary:#ffd400;   /* butter */
  --quart:#29d17b;      /* mint */
  --good:#29d17b;
  --warn:#ffb300;
  --bad:#ff3864;
  --on-primary:#ffffff;
  --on-secondary:#1a1333;
  --shadow:0 14px 34px rgba(255,56,100,.18);
  --shadow-hover:0 24px 50px rgba(94,200,255,.3);
  --radius:28px;
  --radius-sm:16px;
  --font-display:'Fraunces',serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --font-accent:'Space Grotesk',sans-serif;
  --display-tracking:-.5px;
  --display-weight:800;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .3s,color .3s;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ---------- Background decorations ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
}
html[data-theme="dark"] body::before{
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at top,black 35%,transparent 80%);
}
html[data-theme="candy"] body::before{
  background-image:
    radial-gradient(circle at 20% 10%, rgba(255,56,100,.08) 0, transparent 40%),
    radial-gradient(circle at 80% 30%, rgba(94,200,255,.10) 0, transparent 45%),
    radial-gradient(circle at 50% 90%, rgba(41,209,123,.08) 0, transparent 40%);
}

.blob{position:fixed;border-radius:50%;filter:blur(120px);opacity:.55;pointer-events:none;z-index:0}
html[data-theme="dark"] .blob.a{width:520px;height:520px;background:var(--secondary);top:-120px;left:-140px;animation:float 14s ease-in-out infinite}
html[data-theme="dark"] .blob.b{width:620px;height:620px;background:var(--primary);bottom:-200px;right:-160px;opacity:.35;animation:float 18s ease-in-out infinite reverse}
html[data-theme="dark"] .blob.c{width:460px;height:460px;background:var(--quart);top:40%;left:50%;transform:translateX(-50%);opacity:.25;animation:float 22s ease-in-out infinite}
html[data-theme="candy"] .blob{display:none}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-30px)}}

/* ---------- Typography ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-accent);font-weight:700;font-size:12px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--primary);
}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--primary)}
h1,h2,h3,h4{
  font-family:var(--font-display);
  letter-spacing:var(--display-tracking);
  font-weight:var(--display-weight);
  line-height:.98;
}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:30;
  backdrop-filter:blur(16px);
  background:color-mix(in srgb,var(--bg) 70%, transparent);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:16px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:28px;
}
.logo{
  font-family:var(--font-display);font-size:32px;letter-spacing:2px;
  display:flex;align-items:center;gap:10px;
}
html[data-theme="candy"] .logo{font-size:28px;font-weight:900;letter-spacing:-.5px}
.logo .dot{
  width:14px;height:14px;background:var(--primary);border-radius:50%;
  box-shadow:0 0 18px var(--primary);animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}
.links{
  display:flex;gap:28px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;font-size:14px;
}
html[data-theme="candy"] .links{text-transform:none;letter-spacing:0;font-weight:600}
.links a{position:relative;padding:6px 2px}
.links a:hover{color:var(--primary)}
.links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:3px;
  background:var(--primary);border-radius:2px;
}

.nav-right{display:flex;align-items:center;gap:10px}
.theme-switch{
  width:40px;height:40px;border-radius:50%;border:1px solid var(--line);
  background:var(--card);color:var(--ink);font-size:18px;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.theme-switch:hover{transform:rotate(180deg);border-color:var(--primary);color:var(--primary)}
.cart-btn{
  position:relative;width:44px;height:44px;border-radius:50%;
  border:1px solid var(--line);background:var(--card);color:var(--ink);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  transition:all .15s;
}
.cart-btn:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.cart-count{
  position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 6px;
  background:var(--secondary);color:var(--on-secondary);
  border-radius:999px;font-size:11px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
}
.nav-cta{
  background:var(--primary);color:var(--on-primary);padding:10px 18px;
  border-radius:999px;font-weight:900;text-transform:uppercase;
  letter-spacing:.06em;font-size:13px;transition:transform .15s,box-shadow .2s;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px color-mix(in srgb,var(--primary) 40%,transparent)}
.burger{
  display:none;background:transparent;border:none;color:var(--ink);
  font-size:24px;cursor:pointer;
}
@media(max-width:860px){.links{display:none}.burger{display:block}}

/* ---------- Main / layout ---------- */
main{position:relative;z-index:1;min-height:calc(100vh - 80px)}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}
section{padding:72px 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:16px 26px;
  border-radius:999px;font-weight:900;letter-spacing:.06em;
  text-transform:uppercase;font-size:14px;border:none;
  transition:transform .15s,box-shadow .2s,background .2s;
}
html[data-theme="candy"] .btn{text-transform:none;letter-spacing:-.2px;font-size:15px;border-radius:18px}
.btn.primary{background:var(--primary);color:var(--on-primary)}
.btn.primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px color-mix(in srgb,var(--primary) 40%,transparent)}
.btn.secondary{background:var(--secondary);color:var(--on-secondary)}
.btn.ghost{background:transparent;color:var(--ink);border:2px solid var(--line)}
.btn.ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn.block{width:100%;justify-content:center}

/* ---------- Cards ---------- */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;transition:transform .25s,border-color .25s,box-shadow .3s;
  position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}

/* ---------- Product card ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.prod-card{
  grid-column:span 4;display:block;cursor:pointer;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;transition:transform .25s,border-color .25s,box-shadow .3s;
  position:relative;overflow:hidden;
}
.prod-card:nth-child(4),.prod-card:nth-child(5){grid-column:span 6}
@media(max-width:960px){.prod-card,.prod-card:nth-child(4),.prod-card:nth-child(5){grid-column:span 6}}
@media(max-width:640px){.prod-card,.prod-card:nth-child(4),.prod-card:nth-child(5){grid-column:span 12}}
.prod-card:hover{transform:translateY(-8px);border-color:var(--accent);box-shadow:var(--shadow-hover)}
.prod-img{
  aspect-ratio:1;border-radius:calc(var(--radius) - 6px);overflow:hidden;
  background:var(--bg2);margin-bottom:20px;position:relative;
}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.prod-card:hover .prod-img img{transform:scale(1.06) rotate(-2deg)}
.tag{
  position:absolute;top:14px;left:14px;background:var(--accent);color:var(--on-primary);
  font-weight:900;font-size:11px;padding:6px 10px;border-radius:999px;
  letter-spacing:.08em;text-transform:uppercase;
}
html[data-theme="candy"] .tag{color:#fff}
.stock-chip{
  position:absolute;top:14px;right:14px;
  background:var(--card);border:1px solid var(--line);
  font-size:11px;font-weight:700;padding:6px 10px;border-radius:999px;
}
.stock-chip.low{color:var(--warn);border-color:var(--warn)}
.stock-chip.out{color:var(--bad);border-color:var(--bad);background:color-mix(in srgb,var(--bad) 10%, var(--card))}
.prod-body{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.prod-title{font-family:var(--font-display);font-size:34px;margin-bottom:4px;line-height:1}
html[data-theme="candy"] .prod-title{font-size:30px;font-weight:900;letter-spacing:-.5px}
.prod-sub{color:var(--muted);font-size:14px}
.prod-price{
  font-family:var(--font-display);font-size:38px;color:var(--accent);line-height:1;
}
html[data-theme="candy"] .prod-price{font-size:32px;font-weight:900}
.flavors-row{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap}
.flavors-row span{
  padding:5px 10px;border-radius:999px;background:var(--bg2);
  border:1px solid var(--line);font-size:12px;letter-spacing:.03em;
}

/* accent per product (applied inline via data-slug fallback) */
.prod-card{--accent:var(--primary)}
.prod-card[data-slug="poppi"]{--accent:#ff77b0}
.prod-card[data-slug="monster"]{--accent:#84cc16}
.prod-card[data-slug="sprite"]{--accent:#22c55e}
.prod-card[data-slug="cola"]{--accent:#ef4444}
.prod-card[data-slug="arizona"]{--accent:#22d3ee}

/* ---------- Hero ---------- */
.hero{padding:72px 0 100px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr}}
.hero h1{font-size:clamp(56px,9vw,148px)}
.hero h1 .pri{color:var(--primary)}
.hero h1 .sec{color:var(--secondary)}
.hero h1 em{
  font-style:italic;font-family:var(--font-accent);font-weight:700;
  font-size:.28em;letter-spacing:0;display:block;color:var(--muted);margin-top:12px;
}
.hero p.lead{font-size:19px;color:var(--ink);opacity:.85;max-width:560px;margin:28px 0 32px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}

.hero-stage{position:relative;display:flex;align-items:center;justify-content:center;height:520px}
.hero-stage::before{
  content:"";position:absolute;inset:-40px;border-radius:50%;
  background:conic-gradient(from 0deg,var(--primary),var(--secondary),var(--quart),var(--tertiary),var(--primary));
  filter:blur(70px);opacity:.55;animation:spin 18s linear infinite;
}
html[data-theme="candy"] .hero-stage::before{opacity:.35}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-stage .plate{
  position:relative;width:440px;height:440px;border-radius:50%;
  background:color-mix(in srgb,var(--card) 90%, transparent);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(10px);
}
.hero-stage img{
  width:100%;max-width:380px;
  filter:drop-shadow(0 40px 60px rgba(0,0,0,.4));
  animation:bobble 4s ease-in-out infinite;
}
@keyframes bobble{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-16px) rotate(2deg)}}
.chip{
  position:absolute;background:var(--card);border:1px solid var(--line);
  border-radius:16px;padding:12px 16px;box-shadow:var(--shadow);font-size:14px;
  display:flex;align-items:center;gap:10px;
}
.chip.one{top:40px;left:-20px;animation:bobble 5s ease-in-out infinite}
.chip.two{bottom:60px;right:-20px;animation:bobble 6s ease-in-out infinite reverse}
.chip.three{bottom:120px;left:0;animation:bobble 7s ease-in-out infinite}
.chip b{color:var(--primary)}

/* ---------- Marquee ---------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:22px 0;
  background:color-mix(in srgb,var(--primary) 5%,transparent);
}
.marquee-track{
  display:flex;gap:60px;white-space:nowrap;
  animation:scroll 30s linear infinite;
  font-family:var(--font-display);font-size:36px;letter-spacing:3px;
}
html[data-theme="candy"] .marquee-track{font-size:28px;letter-spacing:0;font-weight:900}
.marquee-track span{color:var(--ink);display:inline-flex;align-items:center;gap:60px}
.marquee-track span::after{content:"★";color:var(--primary);font-size:24px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Section headers ---------- */
.sec-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:40px;
  margin-bottom:40px;flex-wrap:wrap;
}
.sec-head h2{font-size:clamp(40px,5vw,80px);max-width:760px}
.sec-head h2 .pri{color:var(--primary)}
.sec-head p{color:var(--muted);max-width:420px}

/* ---------- CTA banner ---------- */
.cta{
  position:relative;margin:60px 0;padding:72px 40px;
  border-radius:var(--radius);overflow:hidden;text-align:center;
}
html[data-theme="dark"] .cta{background:linear-gradient(135deg,var(--secondary),#7c1d4b 70%,#0a0a0f)}
html[data-theme="candy"] .cta{background:linear-gradient(135deg,var(--secondary),var(--primary))}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,color-mix(in srgb,var(--primary) 30%,transparent),transparent 40%)}
.cta h2{position:relative;font-size:clamp(40px,6vw,88px);margin-bottom:16px;color:#fff}
.cta p{position:relative;max-width:580px;margin:0 auto 24px;color:rgba(255,255,255,.9)}
.cta .btn{position:relative;z-index:2}
.sticker{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--tertiary);color:var(--on-primary);
  padding:10px 16px;border-radius:14px;font-weight:900;
  text-transform:uppercase;letter-spacing:.1em;font-size:12px;
  transform:rotate(-6deg);box-shadow:0 8px 24px rgba(0,0,0,.2);
  margin-bottom:14px;
}

/* ---------- Forms ---------- */
.field{display:block;margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:700;letter-spacing:.02em;margin-bottom:6px;color:var(--muted);text-transform:uppercase}
html[data-theme="candy"] .field label{text-transform:none;letter-spacing:0;font-size:14px;color:var(--ink)}
.input,.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;
  background:var(--card);border:2px solid var(--line);border-radius:var(--radius-sm);
  color:var(--ink);font-size:15px;transition:border-color .15s;
}
.input:focus,.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--primary);
}

.choice{
  display:flex;gap:10px;padding:18px;
  border:2px solid var(--line);border-radius:var(--radius-sm);
  background:var(--card);cursor:pointer;transition:all .2s;margin-bottom:10px;
}
.choice:hover{border-color:var(--primary)}
.choice.sel{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 8%,var(--card))}
.choice input{margin-top:2px}
.choice .title{font-weight:700;font-size:15px}
.choice .sub{font-size:13px;color:var(--muted);margin-top:2px}

/* ---------- Footer ---------- */
footer{
  border-top:1px solid var(--line);padding:60px 0 30px;
  background:var(--bg2);position:relative;z-index:1;
}
.foot{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px}
@media(max-width:860px){.foot{grid-template-columns:1fr 1fr}}
.foot h5{font-family:var(--font-display);font-size:22px;margin-bottom:18px;color:var(--primary);letter-spacing:1px}
html[data-theme="candy"] .foot h5{font-size:18px;font-weight:900;letter-spacing:-.2px}
.foot a{display:block;padding:5px 0;color:var(--muted);font-size:14px;transition:color .15s}
.foot a:hover{color:var(--ink)}
.foot p{color:var(--muted);font-size:14px;margin-bottom:14px}
.socials{display:flex;gap:10px;margin-top:14px}
.socials a{
  width:40px;height:40px;border-radius:12px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-weight:900;
  transition:all .15s;
}
.socials a:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-3px)}
.legal{
  max-width:1280px;margin:40px auto 0;padding:22px 28px;
  border-top:1px solid var(--line);display:flex;justify-content:space-between;
  color:var(--muted);font-size:13px;flex-wrap:wrap;gap:12px;
}

/* ---------- Toast ---------- */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(200%);
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:14px 20px;box-shadow:var(--shadow-hover);z-index:100;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  display:flex;align-items:center;gap:10px;font-weight:600;
}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{border-color:var(--good);color:var(--good)}
.toast.err{border-color:var(--bad);color:var(--bad)}

/* ---------- Utility ---------- */
.pad-sm{padding:12px 20px!important}
.muted{color:var(--muted)}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.grow{flex:1}
.pill{
  display:inline-flex;align-items:center;gap:6px;padding:5px 12px;
  border-radius:999px;font-size:12px;font-weight:700;
  background:var(--bg2);border:1px solid var(--line);
}
.pill.good{color:var(--good);border-color:var(--good)}
.pill.warn{color:var(--warn);border-color:var(--warn)}
.pill.bad{color:var(--bad);border-color:var(--bad)}

/* ---------- Admin-specific in styles.admin.css (loaded separately) ---------- */
