:root{
  --shadow-card: 0 14px 40px rgba(0,0,0,.55);
  --shadow-soft: 0 6px 22px rgba(0,0,0,.4);
}

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

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

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

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

.article h2{
  position:relative;
  padding-left:.7em;
}
.article h2::before{
  content:"";
  position:absolute;
  left:0; top:.12em; bottom:.12em;
  width:4px;
  border-radius:3px;
  background:linear-gradient(180deg, var(--accent), var(--accent-2));
}

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

.fact{
  background:var(--panel);
  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-soft);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card:hover,.feature:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-card);
  border-color:color-mix(in srgb, var(--accent) 45%, var(--line));
}

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

/* ---------- Buttons ---------- */
.btn{
  border-radius:12px;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease;
}
.btn-primary{
  background:linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 82%, #000));
  color:var(--on-accent);
  border:1px solid color-mix(in srgb, var(--accent) 60%, #000);
  box-shadow:0 8px 26px color-mix(in srgb, var(--accent) 38%, transparent);
}
.btn-primary:hover{
  transform:scale(1.03);
  filter:brightness(1.12);
  box-shadow:0 12px 34px color-mix(in srgb, var(--accent) 50%, transparent);
}
.btn-ghost{
  background:transparent;
  border:1px solid var(--line);
  color:var(--text);
}
.btn-ghost:hover{
  border-color:var(--accent);
  color:var(--accent-2);
  transform:scale(1.02);
}

/* ---------- Badges / tags ---------- */
.badge{
  background:color-mix(in srgb, var(--accent-2) 16%, var(--panel));
  color:var(--accent-2);
  border:1px solid color-mix(in srgb, var(--accent-2) 45%, var(--line));
  border-radius:999px;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-weight:700;
}

/* ---------- Tabs ---------- */
.tab{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:999px;
  transition:all .2s ease;
}
.tab:hover{ border-color:color-mix(in srgb, var(--accent) 45%, var(--line)); }
.tab.active{
  background:linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 80%, #000));
  color:var(--on-accent);
  border-color:transparent;
  box-shadow:0 6px 20px color-mix(in srgb, var(--accent) 40%, transparent);
}

/* ---------- Catalog tiles ---------- */
.tile{
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.tile:hover{
  transform:translateY(-5px) scale(1.01);
  box-shadow:var(--shadow-card);
  border-color:color-mix(in srgb, var(--accent) 50%, var(--line));
}
.tile .gp{
  color:var(--accent-2);
  letter-spacing:.05em;
  text-transform:uppercase;
  font-weight:700;
}
.tile .nm{ color:var(--text); font-weight:700; }
.tile.noimg{
  background:
    radial-gradient(420px 220px at 80% -20%, color-mix(in srgb, var(--accent) 24%, transparent), transparent 60%),
    linear-gradient(160deg, var(--panel-2), var(--panel));
}
.tile.noimg .nm{
  text-transform:uppercase;
  letter-spacing:.02em;
}

/* ---------- FAQ ---------- */
.faq-item{
  background:linear-gradient(180deg, var(--panel-2), 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:color-mix(in srgb, var(--accent) 40%, var(--line));
  box-shadow:var(--shadow-soft);
}
.faq-q{ color:var(--text); font-weight:700; }
.faq-q::after{ color:var(--accent); }

/* ---------- Tables ---------- */
.table th{
  background:color-mix(in srgb, var(--accent) 12%, var(--panel-2));
  color:var(--text);
  border-bottom:1px solid color-mix(in srgb, var(--accent) 35%, var(--line));
}
.table td{ border-bottom:1px solid var(--line); }

/* ---------- Header / footer accents ---------- */
.site-header{
  border-bottom:1px solid var(--line);
  background:color-mix(in srgb, var(--panel) 86%, transparent);
  backdrop-filter:blur(8px);
}
.site-footer{
  border-top:1px solid var(--line);
  background:linear-gradient(180deg, transparent, color-mix(in srgb, var(--panel) 50%, transparent));
}