:root{
  --glow-pink:0 0 8px var(--accent);
  --glow-cyan:0 0 18px var(--accent-2);
}

body{
  background:
    radial-gradient(1200px 600px at 50% -10%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 60%),
    radial-gradient(900px 500px at 100% 0%, color-mix(in srgb, var(--accent-2) 16%, transparent), transparent 55%),
    var(--bg);
}

/* ---------- HERO: sunset gradient + perspective grid floor ---------- */
.hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 45%, var(--accent-2)) 55%, var(--accent-2));
  border-bottom:1px solid var(--line);
}
.hero::before{
  content:"";
  position:absolute;
  inset:55% -20% -2% -20%;
  background:
    repeating-linear-gradient(90deg, transparent 0 38px, color-mix(in srgb, var(--accent-2) 70%, transparent) 38px 40px),
    repeating-linear-gradient(0deg, transparent 0 38px, color-mix(in srgb, var(--accent-2) 70%, transparent) 38px 40px);
  transform:perspective(320px) rotateX(62deg);
  transform-origin:bottom;
  -webkit-mask-image:linear-gradient(180deg, transparent, #000 70%);
  mask-image:linear-gradient(180deg, transparent, #000 70%);
  pointer-events:none;
}
/* CRT scanline overlay */
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(0deg, color-mix(in srgb, var(--bg) 18%, transparent) 0 2px, transparent 2px 4px);
  mix-blend-mode:overlay;
  pointer-events:none;
}
.hero>*{position:relative;z-index:1;}

.hero-title{
  color:var(--on-accent);
  font-weight:700;
  letter-spacing:0.03em;
  text-transform:uppercase;
  text-shadow:var(--glow-pink), var(--glow-cyan);
}
.hero-sub{color:color-mix(in srgb, var(--on-accent) 92%, transparent);}

/* section headings get a neon accent */
h1,h2{letter-spacing:0.02em;font-weight:700;}
.article h2{
  color:var(--text);
  text-shadow:0 0 6px color-mix(in srgb, var(--accent) 55%, transparent);
}

/* ---------- facts ---------- */
.fact{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent);
}
.fact b{color:var(--accent-2);text-shadow:0 0 10px color-mix(in srgb, var(--accent-2) 60%, transparent);}

/* ---------- cards / panels ---------- */
.card{
  background:linear-gradient(180deg, var(--panel), var(--panel-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 10px 30px color-mix(in srgb, var(--bg) 70%, transparent);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card:hover{
  transform:translateY(-4px);
  border-color:var(--accent);
  box-shadow:0 14px 40px color-mix(in srgb, var(--accent) 28%, transparent);
}
.feature .icon{
  color:var(--on-accent);
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  border-radius:var(--radius);
  box-shadow:0 0 14px color-mix(in srgb, var(--accent-2) 55%, transparent);
}

/* ---------- buttons ---------- */
.btn{border-radius:var(--radius);transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;}
.btn-primary{
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  color:var(--on-accent);
  border:0;
  box-shadow:0 0 16px color-mix(in srgb, var(--accent) 55%, transparent);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 22px color-mix(in srgb, var(--accent-2) 70%, transparent);}
.btn-ghost{border:1px solid var(--line);color:var(--text);background:color-mix(in srgb, var(--panel) 60%, transparent);}
.btn-ghost:hover{border-color:var(--accent-2);box-shadow:var(--glow-cyan);}

/* ---------- badges / tabs ---------- */
.badge{
  background:color-mix(in srgb, var(--accent) 18%, var(--panel));
  border:1px solid var(--line);
  color:var(--text);
  border-radius:999px;
  text-shadow:0 0 6px color-mix(in srgb, var(--accent) 40%, transparent);
}
.tab{border:1px solid var(--line);border-radius:999px;background:var(--panel);color:var(--text-2);transition:all .2s ease;}
.tab:hover{color:var(--text);border-color:var(--accent-2);}
.tab.active{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:var(--on-accent);border-color:transparent;box-shadow:var(--glow-pink);}

/* ---------- catalog tiles ---------- */
.tile{
  background:linear-gradient(180deg, var(--panel), var(--panel-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.tile:hover{transform:translateY(-4px) scale(1.01);border-color:var(--accent);box-shadow:0 12px 34px color-mix(in srgb, var(--accent) 30%, transparent);}
.tile .gp{color:var(--accent-2);}
.tile .nm{color:var(--text);}
.tile.noimg{
  background:
    repeating-linear-gradient(0deg, transparent 0 14px, color-mix(in srgb, var(--accent-2) 22%, transparent) 14px 15px),
    linear-gradient(135deg, var(--panel), var(--panel-2));
}
.tile.noimg .nm{text-shadow:var(--glow-pink);font-weight:600;}

/* ---------- FAQ ---------- */
.faq-item{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.faq-item:hover{border-color:var(--accent-2);box-shadow:0 0 16px color-mix(in srgb, var(--accent-2) 22%, transparent);}
.faq-q{color:var(--text);font-weight:600;}
.faq-a{color:var(--prose);}

/* ---------- header / tables ---------- */
.site-header{background:color-mix(in srgb, var(--panel) 80%, transparent);border-bottom:1px solid var(--line);backdrop-filter:blur(8px);}
.table{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.table th{background:var(--panel-2);color:var(--accent-2);}
.table td{border-top:1px solid var(--line);color:var(--prose);}