:root{
  --radius: 10px;
}

body{
  background:
    radial-gradient(900px 500px at 12% -8%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 60%),
    radial-gradient(800px 520px at 92% 0%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 62%),
    var(--bg);
  background-attachment: fixed;
}

/* faint scanline overlay */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0,
    transparent 2px,
    color-mix(in srgb, var(--line) 22%, transparent) 3px,
    transparent 4px
  );
  opacity:.5;
}

.section{
  background:
    linear-gradient(180deg, transparent, color-mix(in srgb, var(--panel) 18%, transparent));
}

/* Hero with neon grid floor */
.hero{
  position:relative;
  background:
    linear-gradient(180deg, transparent 40%, color-mix(in srgb, var(--accent) 8%, transparent)),
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--line) 30%, transparent) 0 1px, transparent 1px 56px),
    repeating-linear-gradient(0deg, color-mix(in srgb, var(--line) 24%, transparent) 0 1px, transparent 1px 56px);
  border-bottom:1px solid var(--line);
}

.hero-title{
  color:var(--text);
  font-weight:800;
  letter-spacing:.01em;
  text-transform:uppercase;
  text-shadow:0 0 5px var(--accent), 0 0 15px var(--accent), 0 0 30px color-mix(in srgb, var(--accent) 50%, transparent);
}

.section h2, .article h2{
  font-weight:700;
  letter-spacing:.01em;
  color:var(--text);
  text-shadow:0 0 12px color-mix(in srgb, var(--accent) 35%, transparent);
}

a{ color:var(--accent-2); }
a:hover{ color:var(--accent); }

/* Panels */
.card,.feature,.faq-item,.article,.tile{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:transform .2s ease, box-shadow .25s ease, border-color .25s ease;
}

.card:hover,.feature:hover{
  border-color:color-mix(in srgb, var(--accent) 60%, var(--line));
  box-shadow:0 0 5px var(--accent), 0 0 15px var(--accent), 0 0 30px color-mix(in srgb, var(--accent) 50%, transparent);
  transform:translateY(-3px);
}

.feature .icon{
  color:var(--accent);
  border:1px solid var(--line);
  border-radius:12px;
  background:color-mix(in srgb, var(--accent) 8%, var(--panel-2));
  box-shadow:inset 0 0 14px color-mix(in srgb, var(--accent) 25%, transparent), 0 0 10px color-mix(in srgb, var(--accent) 30%, transparent);
}

.badge{
  color:var(--accent-2);
  background:color-mix(in srgb, var(--accent-2) 10%, var(--panel));
  border:1px solid color-mix(in srgb, var(--accent-2) 45%, var(--line));
  border-radius:999px;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.fact{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.fact b{
  color:var(--accent);
  text-shadow:0 0 12px color-mix(in srgb, var(--accent) 55%, transparent);
}

/* Buttons */
.btn{ border-radius:8px; transition:box-shadow .25s ease, transform .15s ease, background .2s ease; }
.btn-primary{
  background:var(--accent);
  color:var(--on-accent);
  border:1px solid color-mix(in srgb, var(--accent) 70%, var(--line));
  box-shadow:0 0 5px var(--accent), 0 0 15px color-mix(in srgb, var(--accent) 60%, transparent);
}
.btn-primary:hover{
  box-shadow:0 0 5px var(--accent), 0 0 15px var(--accent), 0 0 30px color-mix(in srgb, var(--accent) 50%, transparent);
  transform:translateY(-2px);
}
.btn-ghost{
  background:transparent;
  color:var(--accent-2);
  border:1px solid color-mix(in srgb, var(--accent-2) 55%, var(--line));
}
.btn-ghost:hover{
  color:var(--on-accent);
  background:var(--accent-2);
  box-shadow:0 0 5px var(--accent-2), 0 0 18px color-mix(in srgb, var(--accent-2) 55%, transparent);
}

/* Tabs */
.tab{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--text-2);
  transition:all .2s ease;
}
.tab.active,.tab:hover{
  color:var(--on-accent);
  background:var(--accent);
  border-color:var(--accent);
  box-shadow:0 0 12px color-mix(in srgb, var(--accent) 60%, transparent);
}

/* Tiles */
.tile{ overflow:hidden; position:relative; }
.tile:hover{
  border-color:color-mix(in srgb, var(--accent-2) 60%, var(--line));
  box-shadow:0 0 5px var(--accent-2), 0 0 18px color-mix(in srgb, var(--accent-2) 50%, transparent);
  transform:translateY(-3px);
}
.tile .gp{ color:var(--accent-2); letter-spacing:.04em; text-transform:uppercase; }
.tile .nm{ color:var(--text); font-weight:700; }
.tile.noimg{
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 16%, var(--panel)), var(--panel)),
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--line) 30%, transparent) 0 1px, transparent 1px 28px);
}

/* FAQ */
.faq-item{ border-left:2px solid color-mix(in srgb, var(--accent) 50%, var(--line)); }
.faq-q{ color:var(--text); font-weight:600; }
.faq-q:hover{ color:var(--accent); }
.faq-a{ color:var(--prose); }

/* Table */
.table{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.table th{
  background:color-mix(in srgb, var(--accent) 12%, var(--panel-2));
  color:var(--text);
  border-bottom:1px solid var(--line);
}
.table td{ border-bottom:1px solid color-mix(in srgb, var(--line) 60%, transparent); color:var(--prose); }

.site-header{
  background:color-mix(in srgb, var(--panel) 88%, transparent);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}

.container{ position:relative; z-index:1; }