/* ============================================================
   WINNERBALL — CRT lottery terminal
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&family=JetBrains+Mono:wght@400;700;800&display=swap');

:root {
  --bg:        #04070a;
  --bg2:       #06100c;
  --panel:     #0a1612;
  --panel2:    #0c1d16;
  --ink:       #c8ffe6;
  --dim:       #4f8a72;
  --phos:      #00ff9c;   /* phosphor green */
  --phos-soft: #19ffb0;
  --amber:     #ffd84d;   /* prize gold */
  --orange:    #ff9d2e;
  --magenta:   #ff3df5;
  --danger:    #ff5a6e;
  --line:      rgba(0,255,156,.18);
  --line2:     rgba(0,255,156,.40);
  --display:   'Press Start 2P', monospace;
  --term:      'VT323', monospace;
  --mono:      'JetBrains Mono', monospace;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(0,255,156,.08), transparent 60%),
    radial-gradient(900px 500px at 90% 110%, rgba(255,61,245,.06), transparent 55%),
    var(--bg);
  color: var(--ink);
  font-family: var(--mono);
  min-height: 100vh;
  overflow-x: hidden;
}

/* CRT scanlines + flicker + vignette overlays */
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 9000;
  background: repeating-linear-gradient(
    to bottom, rgba(0,0,0,0) 0px, rgba(0,0,0,0) 2px, rgba(0,0,0,.22) 3px, rgba(0,0,0,0) 4px);
  mix-blend-mode: multiply;
}
body::after {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 9001;
  background: radial-gradient(120% 120% at 50% 50%, transparent 60%, rgba(0,0,0,.55) 100%);
  animation: flicker 5.5s infinite steps(60);
}
@keyframes flicker { 0%,100%{opacity:.9} 3%{opacity:.78} 6%{opacity:.95} 9%{opacity:.85} 50%{opacity:.92} }

/* ---- layout ---- */
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 20px 80px; position: relative; z-index: 1; }

/* ---- top bar ---- */
header.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px; max-width: 1120px; margin: 0 auto; position: relative; z-index: 2;
}
.brand { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.brand img { width: 52px; height: 52px; filter: drop-shadow(0 0 10px rgba(255,216,77,.5)); }
.brand b {
  font-family: var(--display); font-size: 18px; letter-spacing: 1px; color: var(--phos);
  text-shadow: 0 0 12px rgba(0,255,156,.7);
}
.brand span { color: var(--amber); }
nav.links { display: flex; gap: 8px; flex-wrap: wrap; }
nav.links a {
  font-family: var(--display); font-size: 9px; letter-spacing: 1px;
  color: var(--dim); text-decoration: none; padding: 10px 12px;
  border: 1px solid var(--line); border-radius: 8px; background: rgba(0,255,156,.03);
  transition: .15s;
}
nav.links a:hover, nav.links a.active { color: var(--bg); background: var(--phos); border-color: var(--phos);
  box-shadow: 0 0 18px rgba(0,255,156,.45); }

/* ---- generic panel ---- */
.panel {
  background: linear-gradient(180deg, var(--panel), var(--bg2));
  border: 1px solid var(--line2);
  border-radius: 14px;
  box-shadow: inset 0 0 40px rgba(0,255,156,.05), 0 0 0 1px rgba(0,0,0,.6);
  position: relative;
}
.panel .bar {
  display:flex; align-items:center; gap:8px;
  padding: 10px 14px; border-bottom: 1px solid var(--line);
  font-family: var(--mono); font-size: 11px; letter-spacing: 2px; color: var(--dim);
  text-transform: uppercase;
}
.panel .bar .dot { width:10px;height:10px;border-radius:50%; }
.dot.r{background:#ff5a6e} .dot.y{background:var(--amber)} .dot.g{background:var(--phos)}
.panel .body { padding: 22px; }

/* ---- buttons ---- */
.btn {
  display:inline-flex; align-items:center; gap:8px; cursor:pointer;
  font-family: var(--display); font-size: 11px; letter-spacing: 1px;
  color: var(--bg); background: var(--phos); border: none; border-radius: 10px;
  padding: 14px 18px; text-decoration:none;
  box-shadow: 0 4px 0 #00b36e, 0 0 18px rgba(0,255,156,.4); transition: .12s;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 6px 0 #00b36e, 0 0 26px rgba(0,255,156,.6); }
.btn:active { transform: translateY(2px); box-shadow: 0 1px 0 #00b36e; }
.btn.gold { background: var(--amber); box-shadow: 0 4px 0 #b98900, 0 0 18px rgba(255,216,77,.4); }
.btn.gold:hover { box-shadow: 0 6px 0 #b98900, 0 0 26px rgba(255,216,77,.6); }
.btn.ghost { background: transparent; color: var(--phos); border:1px solid var(--line2); box-shadow:none; }
.btn.ghost:hover { background: rgba(0,255,156,.08); transform: translateY(-1px); }

/* ---- type helpers ---- */
.kicker { font-family: var(--display); font-size: 9px; letter-spacing: 3px; color: var(--magenta); text-transform: uppercase; }
.mono { font-family: var(--mono); }
.term { font-family: var(--term); }
.amber { color: var(--amber); }
.phos { color: var(--phos); }
.dimc { color: var(--dim); }
.addr { font-family: var(--mono); font-size: 12px; word-break: break-all; color: var(--phos-soft); }
.tag {
  display:inline-block; font-family: var(--mono); font-size: 10px; letter-spacing:1px;
  padding: 3px 8px; border-radius: 6px; border:1px solid var(--line2); color: var(--phos);
}
.tag.paid { color: var(--amber); border-color: rgba(255,216,77,.5); }
.tag.skip { color: var(--dim); }
.tag.fail { color: var(--danger); border-color: rgba(255,90,110,.5); }

/* tables */
table.grid { width:100%; border-collapse: collapse; font-size: 13px; }
table.grid th { text-align:left; font-family: var(--mono); font-size: 10px; letter-spacing:2px; color: var(--dim);
  text-transform: uppercase; padding: 12px 10px; border-bottom: 1px solid var(--line2); }
table.grid td { padding: 12px 10px; border-bottom: 1px solid var(--line); vertical-align: middle; }
table.grid tr:hover td { background: rgba(0,255,156,.04); }
a.tx { color: var(--magenta); text-decoration:none; } a.tx:hover{ text-decoration: underline; }

input, textarea {
  width:100%; font-family: var(--mono); font-size: 13px; color: var(--ink);
  background: #03110b; border:1px solid var(--line2); border-radius: 10px; padding: 12px 14px;
}
input:focus, textarea:focus { outline:none; border-color: var(--phos); box-shadow: 0 0 14px rgba(0,255,156,.3); }
label { font-family: var(--mono); font-size: 10px; letter-spacing:2px; color: var(--dim); text-transform: uppercase; display:block; margin: 14px 0 6px; }

footer.foot { text-align:center; padding: 50px 20px 20px; color: var(--dim); font-size: 12px; }
footer.foot a { color: var(--phos); text-decoration:none; }

.blink { animation: blink 1.05s steps(2) infinite; }
@keyframes blink { 0%,50%{opacity:1} 51%,100%{opacity:0} }

@media (max-width: 720px){
  .brand b{font-size:14px}
  nav.links a{font-size:8px;padding:8px}
}
