/* =========================================================
   Zenoid — cold minimal theme (slate + sky)
   ========================================================= */
:root {
  --bg: #0F172A;
  --bg-2: #142036;
  --panel: #1E293B;
  --panel-2: #243349;
  --grid: rgba(56, 189, 248, 0.06);
  --line: #2c3a52;
  --neon: #38BDF8;
  --neon-2: #60A5FA;
  --neon-soft: rgba(56, 189, 248, 0.18);
  --text: #E2E8F0;
  --text-dim: #94A3B8;
  --ok: #34D399;
  --warn: #FBBF24;
  --err: #F87171;
  --mono: "JetBrains Mono", "Fira Code", "SF Mono", ui-monospace, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--mono);
  font-size: 14px;
  line-height: 1.55;
  min-height: 100vh;
  overflow-x: hidden;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px),
    radial-gradient(ellipse at 20% -10%, rgba(96, 165, 250, 0.18), transparent 50%),
    radial-gradient(ellipse at 110% 10%, rgba(56, 189, 248, 0.10), transparent 55%);
  background-size: 32px 32px, 32px 32px, auto, auto;
}

/* Scanline overlay */
body::before {
  content: "";
  position: fixed; inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    rgba(56, 189, 248, 0.025) 0,
    rgba(56, 189, 248, 0.025) 1px,
    transparent 1px,
    transparent 3px
  );
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: screen;
}

/* =========================================================
   Header
   ========================================================= */
.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 28px;
  border-bottom: 1px solid var(--neon);
  background:
    linear-gradient(180deg, rgba(20, 32, 54, 0.92), rgba(15, 23, 42, 0.92)),
    linear-gradient(90deg, rgba(56, 189, 248, 0.18), rgba(96, 165, 250, 0.05) 45%, rgba(56, 189, 248, 0.15));
  background-blend-mode: normal, overlay;
  backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(56, 189, 248, 0.25), 0 8px 24px rgba(2, 6, 23, 0.45);
}
.brand {
  display: flex; align-items: center; gap: 12px;
  font-weight: 700; letter-spacing: 2px;
  font-size: 18px;
  color: var(--neon);
  text-shadow: 0 0 8px var(--neon-soft);
}
.brand .glyph {
  width: 28px; height: 28px;
  border: 1px solid var(--neon);
  border-radius: 6px;
  display: grid; place-items: center;
  font-size: 14px;
  background: linear-gradient(135deg, rgba(56, 189, 248, .35), rgba(56, 189, 248, .05));
  box-shadow: 0 0 12px var(--neon-soft), inset 0 0 8px var(--neon-soft);
}
.brand .name { color: #fff; }
.brand .name .o { color: var(--neon); text-shadow: 0 0 10px var(--neon-soft); }
.brand .name .w { color: #fff; }
.nav { display: flex; gap: 22px; }
.nav a {
  color: var(--text-dim);
  text-decoration: none;
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: color .18s, text-shadow .18s;
}
.nav a:hover { color: var(--neon); text-shadow: 0 0 6px var(--neon-soft); }

.status-pill {
  font-size: 11px; letter-spacing: 1px;
  color: var(--ok);
  border: 1px solid var(--ok);
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(95, 255, 190, 0.06);
  text-transform: uppercase;
}

/* =========================================================
   Layout
   ========================================================= */
.wrap {
  position: relative; z-index: 2;
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 28px 80px;
}
/* per-page fade-in */
.section, .hero { animation: viewIn .25s ease; }
@keyframes viewIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}
.nav a.active {
  color: var(--neon);
  text-shadow: 0 0 8px var(--neon-soft);
  border-bottom: 1px solid var(--neon);
  padding-bottom: 2px;
}
.hero {
  display: grid; gap: 28px;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
}
@media (max-width: 880px) { .hero { grid-template-columns: 1fr; } }

.hero h1 {
  margin: 0 0 6px 0;
  font-size: 44px; line-height: 1.05;
  color: #F1F5F9;
  letter-spacing: 1px;
}
.hero h1 .accent {
  color: var(--neon);
  text-shadow: 0 0 14px var(--neon-soft);
}
.hero-title .glitch {
  color: #fff;
  text-shadow: 0 0 18px rgba(255,255,255,0.25), 0 0 6px rgba(255,255,255,0.15);
}
.hero .tag {
  color: var(--text-dim);
  letter-spacing: 2px; text-transform: uppercase;
  font-size: 12px;
  margin-bottom: 14px;
}
.hero p { color: var(--text-dim); }

.section { margin-top: 48px; }
.section h2 {
  font-size: 22px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 6px 0;
}
.section h2::before {
  content: "// ";
  color: var(--neon-2);
}
.section .lead { color: var(--text-dim); margin-bottom: 18px; }

/* =========================================================
   Panels / cards
   ========================================================= */
.panel {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 22px;
  position: relative;
  overflow: hidden;
}
.panel::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(56, 189, 248, 0.06), transparent 40%);
  pointer-events: none;
}
.panel h3 {
  margin: 0 0 12px 0;
  color: #F1F5F9;
  font-size: 14px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.panel .corner {
  position: absolute; top: 8px; right: 12px;
  font-size: 10px; color: var(--text-dim);
  letter-spacing: 1px;
}

/* =========================================================
   Mac-style console
   ========================================================= */
.mac {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #0F172A;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(2, 6, 23, 0.6),
              0 0 0 1px rgba(56, 189, 248, 0.08) inset,
              0 0 40px rgba(56, 189, 248, 0.05);
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.mac:hover {
  transform: translateY(-3px) scale(1.005);
  border-color: var(--neon);
  box-shadow: 0 30px 80px rgba(2, 6, 23, 0.6),
              0 0 0 1px var(--neon) inset,
              0 0 60px rgba(56, 189, 248, 0.25);
}
.mac:hover .dot.r { box-shadow: 0 0 8px #ff5f57; }
.mac:hover .dot.y { box-shadow: 0 0 8px #ffbd2e; }
.mac:hover .dot.g { box-shadow: 0 0 8px #28c93f; }
.mac:hover .typing::after { animation: caret 1s steps(1) infinite; }

.mac .titlebar {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  background: linear-gradient(180deg, #1A2438, #0F172A);
  border-bottom: 1px solid var(--line);
}
.dot { width: 12px; height: 12px; border-radius: 50%; transition: box-shadow .25s; }
.dot.r { background: #ff5f57; }
.dot.y { background: #ffbd2e; }
.dot.g { background: #28c93f; }
.mac .title {
  flex: 1; text-align: center;
  color: var(--text-dim);
  font-size: 12px; letter-spacing: 1px;
}
.mac .body {
  padding: 18px 20px;
  font-size: 13px;
  color: #E2E8F0;
}
.mac .body .prompt { color: var(--neon); }
.mac .body .out { color: #94A3B8; }
.mac .body .ok { color: var(--ok); }
.mac .body .warn { color: var(--warn); }
.mac .body pre { margin: 0; white-space: pre-wrap; word-break: break-word; }
.mac .typing { position: relative; }
.mac .typing::after {
  content: "▌"; color: var(--neon);
  margin-left: 2px;
}
@keyframes caret {
  50% { opacity: 0; }
}

/* =========================================================
   Forms
   ========================================================= */
.input, textarea, select {
  width: 100%;
  background: #0F172A;
  border: 1px solid var(--line);
  color: var(--text);
  padding: 11px 14px;
  border-radius: 8px;
  font-family: var(--mono);
  font-size: 13px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.input:focus, textarea:focus, select:focus {
  border-color: var(--neon);
  box-shadow: 0 0 0 3px var(--neon-soft);
}
.row { display: flex; gap: 10px; flex-wrap: wrap; }
.row > * { flex: 1; min-width: 200px; }

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(180deg, var(--neon-2), #1E40AF);
  border: 1px solid var(--neon);
  color: #fff;
  padding: 10px 18px;
  border-radius: 8px;
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform .12s, box-shadow .2s, filter .2s;
  box-shadow: 0 6px 20px rgba(56, 189, 248, 0.35),
              inset 0 1px 0 rgba(255,255,255,0.15);
}
.btn:hover {
  filter: brightness(1.1);
  box-shadow: 0 8px 28px rgba(56, 189, 248, 0.55),
              inset 0 1px 0 rgba(255,255,255,0.2);
}
.btn:active { transform: translateY(1px); }
.btn.ghost {
  background: transparent;
  color: var(--neon);
  border-color: var(--line);
  box-shadow: none;
}
.btn.ghost:hover { border-color: var(--neon); }
.btn.danger {
  background: linear-gradient(180deg, #7F1D1D, #3F0E0C);
  border-color: #d9534f;
  box-shadow: 0 6px 20px rgba(248, 113, 113, 0.3);
}

/* =========================================================
   Bars / Progress
   ========================================================= */
.bar {
  height: 10px;
  background: #0F172A;
  border: 1px solid var(--line);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
}
.bar > .fill {
  height: 100%;
  background: linear-gradient(90deg, var(--neon-2), var(--neon));
  box-shadow: 0 0 10px var(--neon-soft);
  width: 0%;
  transition: width .6s ease;
}
.metric {
  display: grid; grid-template-columns: 1fr auto;
  align-items: baseline; gap: 8px;
  margin: 14px 0 6px;
}
.metric .v { color: #fff; font-size: 26px; }
.metric .v small { color: var(--text-dim); font-size: 13px; }
.kvs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px 28px; margin-top: 12px; }
.kv .k { color: var(--text-dim); font-size: 11px; letter-spacing: 1px; text-transform: uppercase; }
.kv .v { color: #F1F5F9; font-size: 14px; }

/* =========================================================
   Tutorial
   ========================================================= */
.tabs { display: flex; gap: 4px; margin-bottom: 12px; flex-wrap: wrap; }
.tab {
  padding: 8px 14px;
  border: 1px solid var(--line);
  background: #0F172A;
  color: var(--text-dim);
  border-radius: 6px 6px 0 0;
  cursor: pointer;
  font-size: 12px; letter-spacing: 1px;
  text-transform: uppercase;
}
.tab.active {
  color: var(--neon);
  border-color: var(--neon);
  background: rgba(56, 189, 248, 0.06);
}

.code {
  position: relative;
  background: #0B1220;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px 16px;
  font-size: 12.5px;
  color: #E2E8F0;
  overflow-x: auto;
  white-space: pre;
}
.code .copy {
  position: absolute; top: 8px; right: 8px;
  font-size: 10px; padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: #1E293B;
  color: var(--text-dim); cursor: pointer;
  transition: all .15s;
}
.code .copy:hover { color: var(--neon); border-color: var(--neon); }

/* =========================================================
   Models grid
   ========================================================= */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}
.model {
  border: 1px solid var(--line);
  background: #0F172A;
  padding: 12px 14px;
  border-radius: 8px;
  transition: border-color .2s, transform .2s;
}
.model:hover { border-color: var(--neon); transform: translateY(-2px); }
.model .id { color: var(--neon); font-size: 13px; }
.model .meta { color: var(--text-dim); font-size: 11px; margin-top: 4px; }

/* =========================================================
   Table
   ========================================================= */
.table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.table th, .table td {
  text-align: left;
  border-bottom: 1px solid var(--line);
  padding: 10px 8px;
}
.table th {
  color: var(--text-dim);
  text-transform: uppercase;
  font-size: 10.5px;
  letter-spacing: 1px;
  font-weight: 500;
}
.table tr:hover td { background: rgba(56, 189, 248, 0.04); }
.tag-ok { color: var(--ok); }
.tag-off { color: var(--err); }

/* =========================================================
   Stats / Live ops / Reviews (fake)
   ========================================================= */
.stats-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
}
@media (max-width: 700px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }
.stat {
  border: 1px solid var(--line);
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  padding: 18px 16px;
  border-radius: 10px;
  position: relative; overflow: hidden;
  transition: border-color .2s, transform .2s;
}
.stat::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(56, 189, 248, .06), transparent 55%);
  pointer-events: none;
}
.stat:hover { border-color: var(--neon); transform: translateY(-2px); }
.stat .k {
  font-size: 11px; letter-spacing: 1px; text-transform: uppercase;
  color: var(--text-dim);
}
.stat .v {
  margin-top: 6px;
  font-size: 26px; color: #fff;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 14px var(--neon-soft);
  transition: transform .25s, color .25s;
}
.stat .v.bump { animation: bump .35s ease; }
@keyframes bump {
  0% { transform: scale(1); }
  40% { transform: scale(1.08); color: var(--neon); }
  100% { transform: scale(1); }
}
.stat .sub {
  margin-top: 4px;
  font-size: 11px; color: var(--text-dim);
  letter-spacing: .5px;
}

/* FunPay pill + live indicator */
.funpay-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 12px;
  border: 1px solid var(--neon);
  border-radius: 999px;
  color: var(--neon);
  background: linear-gradient(135deg, rgba(56, 189, 248, .18), rgba(96, 165, 250, .06));
  text-decoration: none;
  font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  font-weight: 600;
  box-shadow: 0 0 12px var(--neon-soft);
  transition: transform .15s, filter .15s;
}
.funpay-pill:hover { filter: brightness(1.15); transform: translateY(-1px); }
.live-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border: 1px solid var(--ok);
  border-radius: 999px;
  color: var(--ok);
  font-size: 10.5px; letter-spacing: 1px; text-transform: uppercase;
  background: rgba(56, 189, 248, 0.06);
}
.dot-live {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--neon);
  box-shadow: 0 0 6px var(--neon);
  animation: pulse 1.4s ease-in-out infinite;
}
.dot-live.g { background: #34D399; box-shadow: 0 0 6px #34D399; }
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.45; transform: scale(0.8); }
}

.feed {
  height: 240px; overflow-y: auto;
  font-size: 12.5px;
  background: #0B1220;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px 14px;
  font-family: var(--mono);
  scrollbar-width: thin;
  scrollbar-color: var(--neon-2) transparent;
}
.feed::-webkit-scrollbar { width: 8px; }
.feed::-webkit-scrollbar-thumb { background: var(--neon-2); border-radius: 4px; }
.feed .line { padding: 2px 0; color: var(--text); white-space: nowrap; }
.feed .line .ts { color: var(--text-dim); }
.feed .line .lvl-i { color: var(--neon); }
.feed .line .lvl-w { color: var(--warn); }
.feed .line .lvl-e { color: var(--err); }
.feed .line .tag { color: var(--ok); }
.feed .line .id { color: #E2E8F0; }
.feed .line.new { animation: lineIn .35s ease; }
@keyframes lineIn { from { opacity: 0; transform: translateX(-6px); } to { opacity: 1; transform: none; } }

.reviews-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 700px) { .reviews-grid { grid-template-columns: 1fr; } }
.review {
  border: 1px solid var(--line);
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border-radius: 10px;
  padding: 18px;
  transition: border-color .2s, transform .2s;
}
.review:hover { border-color: var(--neon); transform: translateY(-2px); }
.review .who {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 10px;
}
.review .ava {
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, var(--neon-2), var(--neon));
  color: #fff; display: grid; place-items: center;
  font-size: 11px; font-weight: 700;
  box-shadow: 0 0 10px var(--neon-soft);
}
.review .name { color: var(--neon); font-size: 13px; }
.review .body { color: var(--text); font-size: 13px; line-height: 1.55; }
.review .stars { margin-top: 10px; color: var(--neon); letter-spacing: 2px; font-size: 14px; }

/* =========================================================
   Generated key list
   ========================================================= */
.key-list {
  display: flex; flex-direction: column; gap: 6px;
  max-height: 460px; overflow-y: auto;
  padding: 4px;
  border: 1px dashed var(--neon);
  border-radius: 8px;
  background: #0B1220;
  scrollbar-width: thin;
  scrollbar-color: var(--neon-2) transparent;
}
.key-list::-webkit-scrollbar { width: 8px; }
.key-list::-webkit-scrollbar-thumb { background: var(--neon-2); border-radius: 4px; }
.key-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: #1E293B;
  border: 1px solid var(--line);
  border-radius: 6px;
  transition: border-color .15s, background .15s;
}
.key-row:hover { border-color: var(--neon); background: #243349; }
.key-row .idx {
  color: var(--text-dim); font-size: 11px;
  min-width: 32px; text-align: right;
}
.key-row code {
  flex: 1;
  color: var(--neon);
  font-size: 13px;
  word-break: break-all;
  background: transparent;
}
.key-row .meta { color: var(--text-dim); font-size: 11px; white-space: nowrap; }
.key-row button {
  font-size: 11px;
  padding: 5px 10px;
  border: 1px solid var(--line);
  background: #0F172A;
  color: var(--text-dim);
  border-radius: 4px;
  cursor: pointer;
  transition: color .15s, border-color .15s;
}
.key-row button:hover { color: var(--neon); border-color: var(--neon); }
.key-row.copied { border-color: var(--ok); }
.key-row.copied button { color: var(--ok); border-color: var(--ok); }

/* =========================================================
   Footer
   ========================================================= */
.footer {
  margin-top: 80px;
  padding: 28px;
  border-top: 1px solid var(--line);
  color: var(--text-dim);
  text-align: center;
  font-size: 12px;
  letter-spacing: 1px;
}
.footer .mail { color: var(--neon); }
.footer .blink { animation: blink 1.4s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0.3; } }

/* =========================================================
   Toasts
   ========================================================= */
.toast {
  position: fixed; bottom: 24px; right: 24px; z-index: 100;
  background: var(--panel-2);
  border: 1px solid var(--neon);
  color: var(--text);
  padding: 12px 16px;
  border-radius: 8px;
  box-shadow: 0 10px 30px rgba(2, 6, 23, .6), 0 0 20px var(--neon-soft);
  opacity: 0; transform: translateY(8px);
  transition: opacity .25s, transform .25s;
  font-size: 13px;
  max-width: 380px;
}
.toast.show { opacity: 1; transform: translateY(0); }
.toast.err { border-color: var(--err); box-shadow: 0 10px 30px rgba(2, 6, 23, .6), 0 0 20px rgba(248, 113, 113, .25); }

/* Glitch helper for the title */
.glitch {
  position: relative;
  display: inline-block;
}
.glitch::before, .glitch::after {
  content: attr(data-text);
  position: absolute; left: 0; top: 0;
  width: 100%; overflow: hidden;
}
.glitch::before {
  color: #fff; text-shadow: 0 0 6px rgba(255,255,255,.35);
  clip-path: inset(0 0 60% 0);
  transform: translate(-1px, 0);
  animation: glitch1 4s infinite linear alternate-reverse;
}
.glitch::after {
  color: #fff; text-shadow: 0 0 6px rgba(255,255,255,.25);
  clip-path: inset(60% 0 0 0);
  transform: translate(1px, 0);
  animation: glitch2 4.5s infinite linear alternate-reverse;
}
@keyframes glitch1 {
  0%, 92%, 100% { transform: translate(-1px, 0); }
  93% { transform: translate(-3px, -1px); }
  95% { transform: translate(2px, 1px); }
  97% { transform: translate(-2px, 0); }
}
@keyframes glitch2 {
  0%, 92%, 100% { transform: translate(1px, 0); }
  93% { transform: translate(3px, 1px); }
  95% { transform: translate(-2px, -1px); }
  97% { transform: translate(2px, 0); }
}
