:root{
  --shadow-card: 0 14px 40px rgba(0,0,0,0.55);
}

body{
  background:
    radial-gradient(1100px 600px at 80% -10%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 60%),
    radial-gradient(900px 520px at -10% 8%, color-mix(in srgb, var(--accent-2) 9%, transparent), transparent 55%),
    var(--bg);
}

.section:nth-of-type(even){
  background:
    linear-gradient(180deg, transparent, color-mix(in srgb, var(--panel) 40%, transparent) 50%, transparent);
}

/* ---------- Headlines: poster energy ---------- */
.hero-title,
.section > h2,
.article h2{
  font-weight:800;
  letter-spacing:0.01em;
  text-transform:uppercase;
}

.hero-title{
  letter-spacing:0.02em;
  background:linear-gradient(180deg, var(--text), color-mix(in srgb, var(--accent) 40%, var(--text)));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow:0 2px 18px rgba(0,0,0,0.35);
}

.section > h2::after{
  content:"";
  display:block;
  width:64px;
  height:4px;
  margin-top:14px;
  border-radius:99px;
  background:linear-gradient(90deg, var(--accent), var(--accent-2));
}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(700px 360px at 78% 12%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 65%),
    linear-gradient(160deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-card);
}

.fact{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.fact b{ color:var(--accent-2); }

/* ---------- Cards / features ---------- */
.card,.feature{
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-card);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card:hover,.feature:hover{
  transform:translateY(-6px);
  border-color:color-mix(in srgb, var(--accent) 45%, var(--line));
  box-shadow:0 22px 56px rgba(0,0,0,0.62);
}

.feature .icon{
  color:var(--accent);
  border:1px solid var(--line);
  border-radius:14px;
  background:radial-gradient(120% 120% at 30% 20%, color-mix(in srgb, var(--accent) 22%, transparent), var(--panel-2));
  box-shadow:inset 0 1px 0 color-mix(in srgb, var(--text) 8%, transparent);
}

/* ---------- Buttons ---------- */
.btn{
  border-radius:12px;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn-primary{
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 88%, white 12%), var(--accent));
  color:var(--on-accent);
  border:1px solid color-mix(in srgb, var(--accent) 60%, var(--line));
  box-shadow:0 10px 26px color-mix(in srgb, var(--accent) 35%, transparent);
}
.btn-primary:hover{
  transform:scale(1.03);
  filter:brightness(1.12);
  box-shadow:0 16px 38px color-mix(in srgb, var(--accent) 48%, transparent);
}
.btn-ghost{
  border:1px solid var(--line);
  background:color-mix(in srgb, var(--panel-2) 70%, transparent);
}
.btn-ghost:hover{ border-color:var(--accent); transform:scale(1.02); }

/* ---------- Badges / tabs / scores ---------- */
.badge{
  background:color-mix(in srgb, var(--accent-2) 16%, var(--panel-2));
  color:var(--accent-2);
  border:1px solid color-mix(in srgb, var(--accent-2) 40%, var(--line));
  border-radius:99px;
  font-weight:700;
  letter-spacing:0.04em;
  text-transform:uppercase;
}
.tab{
  border:1px solid var(--line);
  border-radius:99px;
  background:var(--panel-2);
  transition:all .2s ease;
}
.tab.active{
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 85%, white 15%), var(--accent));
  color:var(--on-accent);
  border-color:transparent;
  box-shadow:0 8px 22px color-mix(in srgb, var(--accent) 40%, transparent);
}

/* ---------- Tiles ---------- */
.tile{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  box-shadow:var(--shadow-card);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.tile:hover{
  transform:translateY(-5px) scale(1.02);
  border-color:color-mix(in srgb, var(--accent) 50%, var(--line));
  box-shadow:0 20px 50px rgba(0,0,0,0.6);
}
.tile .gp{ color:var(--accent-2); }
.tile .nm{ color:var(--text); font-weight:700; }
.tile.noimg{
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 70%),
    linear-gradient(180deg, var(--panel-2), var(--panel));
}

/* ---------- FAQ ---------- */
.faq-item{
  background:var(--panel-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.faq-item:hover{ border-color:color-mix(in srgb, var(--accent) 38%, var(--line)); }
.faq-q{ font-weight:700; }
.faq-q::after{ color:var(--accent); }

/* ---------- Header / table ---------- */
.site-header{
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  border-bottom:1px solid var(--line);
  backdrop-filter:saturate(1.2) blur(8px);
}
.table th{
  background:var(--panel-2);
  color:var(--accent-2);
  border-bottom:1px solid var(--line);
  text-transform:uppercase;
  letter-spacing:0.03em;
}
.table td{ border-bottom:1px solid var(--line); }