/* ============================================================================
   WM-Tore-Bot — stadium-broadcast scoreboard aesthetic
   Display: Anton (condensed, scoreboard energy) · Body: Hanken Grotesk
   Deep-ink base + WC2026 multi-colour spectrum used as sharp accents.
   ========================================================================== */

:root {
  --ink: #0a0a12;
  --ink-2: #12121d;
  --ink-3: #191926;
  --line: rgba(255, 255, 255, .09);
  --line-2: rgba(255, 255, 255, .16);
  --fg: #f3f1fb;
  --muted: #9b97bb;

  --magenta: #ff2d6f;
  --violet: #8b3dff;
  --blue: #2f6bff;
  --cyan: #00e6cf;
  --lime: #b9ff3a;
  --orange: #ff9a1e;
  --spectrum: linear-gradient(90deg, #ff2d6f, #ff9a1e, #b9ff3a, #00e6cf, #2f6bff, #8b3dff);

  --font-display: "Anton", "Hanken Grotesk", system-ui, sans-serif;
  --font: "Hanken Grotesk", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --maxw: 1120px;
  --radius: 16px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--ink);
  color: var(--fg);
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Atmospheric background: two colour glows + a faint pitch grid. */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(60vw 60vw at 12% -8%, rgba(255, 45, 111, .20), transparent 60%),
    radial-gradient(55vw 55vw at 100% 8%, rgba(0, 230, 207, .16), transparent 55%),
    radial-gradient(70vw 50vw at 50% 120%, rgba(139, 61, 255, .18), transparent 60%);
}
body::after {
  content: "";
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, .025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .025) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(circle at 50% 30%, #000, transparent 80%);
}

a { color: inherit; text-decoration: none; }

/* ── top spectrum strip ──────────────────────────────────────────────────── */
.spectrum-bar { height: 4px; background: var(--spectrum); }

/* ── nav ─────────────────────────────────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: .9rem clamp(1rem, 4vw, 2.5rem);
  background: rgba(10, 10, 18, .72);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.brand {
  font-family: var(--font-display);
  font-size: 1.5rem; letter-spacing: 1px;
  display: inline-flex; align-items: center; gap: .55rem;
}
.brand__sep { color: var(--magenta); }
.brand__dot {
  width: 11px; height: 11px; border-radius: 50%;
  background: var(--spectrum);
  box-shadow: 0 0 14px rgba(255, 45, 111, .8);
}
.nav__links { display: flex; align-items: center; gap: clamp(.8rem, 3vw, 1.6rem); }
.nav__links > a:not(.btn) {
  font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  font-size: .82rem; color: var(--muted);
  padding: .3rem 0; border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
}
.nav__links > a:not(.btn):hover { color: var(--fg); border-color: var(--magenta); }

/* ── buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: .4rem;
  font-weight: 800; border-radius: 999px;
  padding: .6rem 1.1rem; transition: transform .15s, box-shadow .2s, background .2s;
}
.btn--cta {
  background: var(--spectrum); color: #0a0a12;
  font-size: .85rem; letter-spacing: .02em;
}
.btn--cta:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(255, 45, 111, .35); }
.btn--big {
  background: var(--spectrum); color: #0a0a12;
  font-size: 1.1rem; padding: .95rem 1.8rem;
  box-shadow: 0 10px 40px rgba(255, 45, 111, .28);
}
.btn--big:hover { transform: translateY(-3px); box-shadow: 0 16px 48px rgba(255, 45, 111, .42); }
.btn--ghost {
  border: 1.5px solid var(--line-2); color: var(--fg);
  font-size: 1.05rem; padding: .9rem 1.6rem;
}
.btn--ghost:hover { border-color: var(--cyan); color: var(--cyan); }

/* ── hero ────────────────────────────────────────────────────────────────── */
.hero {
  position: relative; max-width: var(--maxw); margin: 0 auto;
  padding: clamp(3.5rem, 9vw, 7rem) clamp(1rem, 4vw, 2.5rem) clamp(2rem, 5vw, 3.5rem);
}
.hero__year {
  position: absolute; top: -2vw; right: -1vw; z-index: -1;
  font-family: var(--font-display);
  font-size: clamp(9rem, 34vw, 32rem); line-height: .8;
  color: transparent;
  -webkit-text-stroke: 2px rgba(255, 255, 255, .05);
  pointer-events: none; user-select: none;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: .6rem;
  text-transform: uppercase; letter-spacing: .18em; font-weight: 700;
  font-size: .78rem; color: var(--muted); margin: 0 0 1.4rem;
  animation: fadeUp .6s .05s both;
}
.eyebrow__tick { width: 26px; height: 3px; background: var(--spectrum); border-radius: 2px; }
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(3.2rem, 12vw, 8.5rem); line-height: .92;
  letter-spacing: 0; margin: 0; text-transform: uppercase;
  animation: fadeUp .7s .12s both;
}
.spectrum-text {
  background: var(--spectrum); -webkit-background-clip: text;
  background-clip: text; color: transparent;
}
.hero__lead {
  max-width: 38rem; color: var(--muted);
  font-size: clamp(1.05rem, 2.4vw, 1.3rem); margin: 1.5rem 0 0;
  animation: fadeUp .7s .2s both;
}
.hero__cta {
  display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2.2rem;
  animation: fadeUp .7s .28s both;
}

/* ── broadcast ticker tape ───────────────────────────────────────────────── */
.tape {
  border-block: 1px solid var(--line);
  background: rgba(255, 255, 255, .03);
  overflow: hidden; white-space: nowrap;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.tape__track { display: inline-flex; gap: 2.5rem; padding: .7rem 0; animation: marquee 38s linear infinite; }
.tape:hover .tape__track { animation-play-state: paused; }
.tape__item { font-size: .92rem; color: var(--muted); display: inline-flex; align-items: center; gap: .5rem; }
.tape__item strong { color: var(--fg); }
.tape__tag {
  font-family: var(--font-display); font-size: .72rem; letter-spacing: .06em;
  padding: .12rem .5rem; border-radius: 5px; color: #0a0a12;
}

/* ── section scaffolding ─────────────────────────────────────────────────── */
.band, .page { max-width: var(--maxw); margin: 0 auto; padding: clamp(2.5rem, 6vw, 4rem) clamp(1rem, 4vw, 2.5rem); }
.label {
  text-transform: uppercase; letter-spacing: .16em; font-weight: 800;
  font-size: .8rem; color: var(--muted); margin: 0 0 1.1rem;
  display: flex; align-items: center; gap: .55rem;
}
.empty { color: var(--muted); padding: 1rem 0; }

/* ── features ────────────────────────────────────────────────────────────── */
.features { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1rem; }
.feature {
  background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.5rem 1.4rem; position: relative; overflow: hidden;
  transition: transform .2s, border-color .2s;
  animation: fadeUp .6s both;
}
.features .feature:nth-child(2) { animation-delay: .08s; }
.features .feature:nth-child(3) { animation-delay: .16s; }
.features .feature:nth-child(4) { animation-delay: .24s; }
.feature::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--spectrum); transform: scaleX(0); transform-origin: left; transition: transform .3s; }
.feature:hover { transform: translateY(-4px); border-color: var(--line-2); }
.feature:hover::before { transform: scaleX(1); }
.feature__ico { font-size: 1.8rem; }
.feature h3 { margin: .6rem 0 .35rem; font-size: 1.15rem; }
.feature p { margin: 0; color: var(--muted); font-size: .95rem; }

/* ── match cards (scoreboard) ────────────────────────────────────────────── */
.match-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 1rem; }
.match {
  background: var(--ink-2); border: 1px solid var(--line);
  border-left: 4px solid var(--muted); border-radius: var(--radius);
  padding: 1rem 1.1rem; transition: transform .2s, box-shadow .2s, border-color .2s;
}
.match:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0, 0, 0, .4); }
.match--live { border-left-color: var(--magenta); }
.match--halftime { border-left-color: var(--cyan); }
.match--finished { border-left-color: var(--violet); }
.match--scheduled { border-left-color: var(--muted); }
.match__head { display: flex; align-items: center; justify-content: space-between; gap: .6rem; margin-bottom: .7rem; }
.match__stage {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .1em;
  color: var(--muted); font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.match__rows { display: grid; gap: .3rem; }
.trow { display: grid; grid-template-columns: 1.6rem 1fr auto; align-items: center; gap: .6rem; }
.flag { font-size: 1.2rem; }
.tname { font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tscore { font-family: var(--font-display); font-size: 1.7rem; line-height: 1; min-width: 1.2ch; text-align: right; }

/* status pills */
.pill {
  display: inline-flex; align-items: center; gap: .35rem; flex: none;
  font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em;
  padding: .22rem .5rem; border-radius: 999px;
  background: rgba(255, 255, 255, .07); color: var(--muted);
}
.pill--live { background: rgba(255, 45, 111, .16); color: #ff8fb4; }
.pill--ht { background: rgba(0, 230, 207, .14); color: var(--cyan); }
.pill--ft { background: rgba(139, 61, 255, .16); color: #c4a0ff; }
.pill--soon { background: rgba(255, 255, 255, .06); color: var(--muted); }
.dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--magenta);
  box-shadow: 0 0 0 0 rgba(255, 45, 111, .6); animation: pulse 1.4s infinite;
}
.dot--inline { display: inline-block; }

/* ── dashboard layout ────────────────────────────────────────────────────── */
.page__head { margin-bottom: 1.6rem; }
.page__title { font-family: var(--font-display); font-size: clamp(2.4rem, 7vw, 4rem); margin: 0; text-transform: uppercase; }
.page__sub { color: var(--muted); margin: .3rem 0 0; display: flex; align-items: center; gap: .5rem; }
.dash-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 1.6rem; align-items: start; }
.dash-main .label:not(:first-child) { margin-top: 2.2rem; }
@media (max-width: 820px) { .dash-grid { grid-template-columns: 1fr; } }

.fixtures { display: grid; gap: .5rem; }
.fix {
  display: flex; align-items: center; gap: 1rem;
  background: var(--ink-2); border: 1px solid var(--line); border-radius: 12px; padding: .7rem 1rem;
}
.fix__time { font-variant-numeric: tabular-nums; color: var(--cyan); font-weight: 700; font-size: .9rem; white-space: nowrap; }
.fix__teams { font-weight: 600; }
.fix__teams i { color: var(--muted); font-style: normal; padding: 0 .3rem; }

/* ── ticker ──────────────────────────────────────────────────────────────── */
.ticker {
  list-style: none; margin: 0; padding: 0;
  background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden;
}
.tick-row { display: flex; align-items: flex-start; gap: .6rem; padding: .65rem .85rem; border-bottom: 1px solid var(--line); }
.tick-row:last-child { border-bottom: 0; }
.tick-row__main { font-size: .9rem; }
.tick-row__main em { display: block; color: var(--muted); font-style: normal; font-size: .82rem; margin-top: .1rem; }
.tag {
  font-family: var(--font-display); font-size: .68rem; letter-spacing: .05em;
  padding: .15rem .45rem; border-radius: 5px; color: #0a0a12; flex: none; margin-top: .1rem;
}
.tag--goal,    .tape__tag--goal    { background: var(--lime); }
.tag--kickoff, .tape__tag--kickoff { background: var(--cyan); }
.tag--halftime,.tape__tag--halftime{ background: var(--blue); color: #fff; }
.tag--fulltime,.tape__tag--fulltime{ background: var(--violet); color: #fff; }
.tag--card,    .tape__tag--card    { background: var(--magenta); color: #fff; }

/* ── standings ───────────────────────────────────────────────────────────── */
.groups { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1.2rem; }
.standings {
  width: 100%; border-collapse: collapse; background: var(--ink-2);
  border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden;
}
.standings caption {
  font-family: var(--font-display); font-size: 1.1rem; letter-spacing: .04em;
  text-align: left; padding: .6rem .9rem; color: #0a0a12; background: var(--spectrum);
  text-transform: uppercase;
}
.standings th, .standings td { padding: .5rem .55rem; text-align: center; font-variant-numeric: tabular-nums; }
.standings th { font-size: .7rem; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); border-bottom: 1px solid var(--line); }
.standings .l { text-align: left; }
.standings .pos { color: var(--muted); }
.standings .team { font-weight: 700; }
.standings .pts { font-weight: 800; }
.standings tbody tr { border-bottom: 1px solid var(--line); }
.standings tbody tr:last-child { border-bottom: 0; }
.standings tr.qual .pos { color: var(--lime); font-weight: 800; }
.standings tr.qual { background: linear-gradient(90deg, rgba(185, 255, 58, .08), transparent); }

/* ── spielplan ───────────────────────────────────────────────────────────── */
.schedule { display: grid; gap: .45rem; }
.srow {
  display: grid; grid-template-columns: 6.5rem 1fr auto 1fr 6.5rem; align-items: center; gap: .6rem;
  background: var(--ink-2); border: 1px solid var(--line); border-left: 3px solid var(--muted);
  border-radius: 12px; padding: .6rem .9rem;
}
.srow--live { border-left-color: var(--magenta); }
.srow--halftime { border-left-color: var(--cyan); }
.srow--finished { border-left-color: var(--violet); }
.srow--scheduled { border-left-color: var(--muted); }
.srow__time { font-variant-numeric: tabular-nums; color: var(--muted); font-size: .82rem; }
.srow__team { font-weight: 700; display: flex; align-items: center; gap: .4rem; }
.srow__team--home { justify-content: flex-end; text-align: right; }
.srow__score { font-family: var(--font-display); font-size: 1.25rem; min-width: 3.2rem; text-align: center; }
.srow__score i { color: var(--muted); font-size: .8rem; font-style: normal; }
.srow__score b { color: var(--muted); padding: 0 .1rem; }
.srow__status { justify-self: end; }
@media (max-width: 720px) {
  .srow { grid-template-columns: 1fr auto 1fr; }
  .srow__time, .srow__status { display: none; }
}

/* ── admin ───────────────────────────────────────────────────────────────── */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 2.5rem; }
.stat {
  background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.6rem 1.4rem; position: relative; overflow: hidden;
}
.stat::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 4px; }
.stat--a::before { background: var(--magenta); }
.stat--b::before { background: var(--cyan); }
.stat--c::before { background: var(--lime); }
.stat__num { display: block; font-family: var(--font-display); font-size: 3rem; line-height: 1; }
.stat--a .stat__num { color: var(--magenta); }
.stat--b .stat__num { color: var(--cyan); }
.stat--c .stat__num { color: var(--lime); }
.stat__lbl { color: var(--muted); font-size: .9rem; text-transform: uppercase; letter-spacing: .06em; }

.bars { display: grid; gap: .6rem; max-width: 640px; }
.bar { display: grid; grid-template-columns: 6rem 1fr 2.5rem; align-items: center; gap: .8rem; }
.bar__lbl { text-transform: capitalize; color: var(--muted); font-size: .88rem; }
.bar__track { height: 12px; background: rgba(255, 255, 255, .06); border-radius: 999px; overflow: hidden; }
.bar__fill { display: block; height: 100%; border-radius: 999px; background: var(--spectrum); min-width: 2px; }
.bar__fill--goal { background: var(--lime); }
.bar__fill--kickoff { background: var(--cyan); }
.bar__fill--halftime { background: var(--blue); }
.bar__fill--fulltime { background: var(--violet); }
.bar__fill--card { background: var(--magenta); }
.bar__n { font-variant-numeric: tabular-nums; font-weight: 800; text-align: right; }

/* ── footer ──────────────────────────────────────────────────────────────── */
.foot {
  border-top: 1px solid var(--line); margin-top: 2rem;
  padding: 2rem clamp(1rem, 4vw, 2.5rem);
  display: flex; flex-wrap: wrap; gap: .6rem 1.5rem; justify-content: space-between;
  color: var(--muted); font-size: .9rem;
}
.foot__brand { font-family: var(--font-display); letter-spacing: 1px; color: var(--fg); }
.foot a:hover { color: var(--cyan); }

/* ── motion ──────────────────────────────────────────────────────────────── */
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(255, 45, 111, .55); }
  70%  { box-shadow: 0 0 0 7px rgba(255, 45, 111, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 45, 111, 0); }
}
@keyframes fadeUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; }
}

/* ── Epic 4: account, personalised live, competition filter ────────────────── */
/* Competition filter chips (public dashboard + /live). */
.chips { display: flex; flex-wrap: wrap; gap: .5rem; margin: 0 0 1.4rem; }
.chip {
  padding: .4rem .85rem; border-radius: 999px; border: 1.5px solid var(--line-2);
  color: var(--muted); text-decoration: none; font-weight: 700; font-size: .82rem;
  transition: color .15s, border-color .15s, background .15s, transform .15s;
}
.chip:hover { color: var(--fg); border-color: var(--magenta); transform: translateY(-1px); }
.chip--on { background: var(--magenta); color: #fff; border-color: transparent; }

/* Competition section: a labelled block of match cards + its standings. */
.comp { margin: 0 0 2.4rem; }
.comp .standings { margin-top: 1.1rem; }

/* Account cards (subscription panel). */
.cards {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); margin: 0 0 1.6rem;
}
.card {
  padding: 1.2rem; border: 1px solid var(--line); border-radius: 14px;
  background: var(--ink-2);
}
.plan { font-family: var(--font-display); font-weight: 800; font-size: 1.35rem; margin: .2rem 0; letter-spacing: .5px; }
.plan--pro { color: var(--lime); }
.plan--free { color: var(--cyan); }
.muted { color: var(--muted); font-size: .9rem; }
.notice {
  padding: 1rem 1.1rem; border: 1px dashed var(--line-2); border-radius: 12px;
  color: var(--muted); margin: 0 0 1.6rem;
}
.notice a { color: var(--cyan); }

/* Settings form toggles. */
.settings { margin: 0 0 2rem; }
.toggles {
  display: grid; gap: .55rem;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); margin: .5rem 0 1.2rem;
}
.toggle { display: flex; align-items: center; gap: .55rem; color: var(--fg); font-size: .92rem; }
.toggle input { accent-color: var(--magenta); width: 1.05rem; height: 1.05rem; }
.toggle em { font-style: normal; }
.badge {
  font-size: .68rem; font-weight: 700; padding: .12rem .5rem; border-radius: 999px;
  background: var(--line-2); color: var(--fg); margin-left: .3rem;
}

/* Scorer detail line on a match card (Pro live view; redacted away for Free). */
.match__scorers {
  display: flex; flex-wrap: wrap; gap: .35rem 1rem; margin-top: .6rem;
  padding-top: .55rem; border-top: 1px solid var(--line);
  font-size: .82rem; color: var(--muted);
}
.match__scorers .scorer--away { margin-left: auto; text-align: right; }

/* ============================================================================
   GoalPing — marketing section system (Epic 5)
   Reuses the scoreboard tokens above; adds how-it-works, showcase, FAQ, proof,
   pricing. All dynamic widths/counters set via JS data-* (CSP: no inline style).
   ========================================================================== */

/* ── how it works ────────────────────────────────────────────────────────── */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.2rem; }
.step {
  position: relative; background: var(--ink-2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 1.6rem 1.4rem 1.4rem;
}
.step__n {
  font-family: var(--font-display); font-size: 2.4rem; line-height: 1;
  background: var(--spectrum); -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.step h3 { margin: .6rem 0 .35rem; font-size: 1.15rem; }
.step p { margin: 0; color: var(--muted); font-size: .95rem; }
.step__shot {
  display: block; width: 100%; height: auto; margin-top: 1rem;
  border-radius: 12px; border: 1px solid var(--line);
}

/* ── competitions showcase ───────────────────────────────────────────────── */
.comp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: .9rem; }
.comp {
  display: flex; align-items: center; justify-content: space-between; gap: .8rem;
  background: var(--ink-2); border: 1px solid var(--line); border-left: 4px solid var(--violet);
  border-radius: 12px; padding: .9rem 1.05rem; transition: transform .2s, border-color .2s;
}
.comp:hover { transform: translateY(-3px); border-color: var(--line-2); }
.comp--league { border-left-color: var(--cyan); }
.comp--cup { border-left-color: var(--orange); }
.comp--international { border-left-color: var(--magenta); }
.comp__name { font-weight: 800; }
.comp__meta { display: block; color: var(--muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; }
.comp__live {
  flex: none; display: inline-flex; align-items: center; gap: .35rem;
  font-family: var(--font-display); font-size: .95rem; padding: .2rem .55rem;
  border-radius: 999px; background: rgba(255, 45, 111, .16); color: #ff8fb4;
}
.comp__live[data-live="0"] { background: rgba(255, 255, 255, .06); color: var(--muted); }
.comp__live .dot { display: inline-block; }
.comp__live[data-live="0"] .dot { display: none; }

/* ── social proof ────────────────────────────────────────────────────────── */
.proof { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; }
.proof__cell {
  background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.6rem 1.4rem; text-align: center; position: relative; overflow: hidden;
}
.proof__cell::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--spectrum); }
.proof__num { display: block; font-family: var(--font-display); font-size: 2.8rem; line-height: 1; }
.proof__lbl { color: var(--muted); font-size: .85rem; text-transform: uppercase; letter-spacing: .08em; }
.proof__cell--live .proof__num { color: var(--magenta); }

/* ── FAQ ─────────────────────────────────────────────────────────────────── */
.faq { display: grid; gap: .6rem; max-width: 820px; }
.faq__item {
  background: var(--ink-2); border: 1px solid var(--line); border-radius: 12px;
  padding: 0 1.1rem;
}
.faq__item > summary {
  cursor: pointer; list-style: none; padding: 1rem 0; font-weight: 700;
  display: flex; justify-content: space-between; gap: 1rem;
}
.faq__item > summary::-webkit-details-marker { display: none; }
.faq__item > summary::after { content: "+"; color: var(--cyan); font-family: var(--font-display); }
.faq__item[open] > summary::after { content: "–"; }
.faq__item p { margin: 0 0 1rem; color: var(--muted); }

/* ── pricing ─────────────────────────────────────────────────────────────── */
.pricing { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.4rem; max-width: 760px; margin: 0 auto; }
.plan {
  background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.8rem 1.6rem; display: flex; flex-direction: column; gap: 1rem;
}
.plan--pro { border-color: var(--magenta); box-shadow: 0 12px 48px rgba(255, 45, 111, .14); position: relative; }
.plan--pro::before {
  content: "Empfohlen"; position: absolute; top: -.7rem; right: 1.2rem;
  background: var(--spectrum); color: #0a0a12; font-weight: 800; font-size: .72rem;
  text-transform: uppercase; letter-spacing: .06em; padding: .2rem .6rem; border-radius: 999px;
}
.plan__name { font-family: var(--font-display); font-size: 1.6rem; text-transform: uppercase; }
.plan__price { font-family: var(--font-display); font-size: 2.6rem; line-height: 1; }
.plan__price small { font-family: var(--font); font-size: .9rem; color: var(--muted); }
.plan__cycle { color: var(--muted); font-size: .85rem; }
.plan__feats { list-style: none; margin: 0; padding: 0; display: grid; gap: .5rem; }
.plan__feats li { display: flex; align-items: flex-start; gap: .55rem; font-size: .92rem; }
.plan__feats .ok { color: var(--lime); flex: none; }
.plan__feats .no { color: var(--muted); flex: none; }
.plan__feats li.off { color: var(--muted); }
.plan__cta { margin-top: auto; }
.plan__current { text-align: center; color: var(--lime); font-weight: 800; font-size: .85rem; text-transform: uppercase; letter-spacing: .06em; }
.plan__soon { text-align: center; color: var(--muted); font-size: .85rem; }

/* matrix table (compact comparison under the cards) */
.matrix { width: 100%; border-collapse: collapse; margin-top: 2.5rem; background: var(--ink-2); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.matrix caption { font-family: var(--font-display); text-align: left; padding: .6rem .9rem; background: var(--spectrum); color: #0a0a12; text-transform: uppercase; }
.matrix th, .matrix td { padding: .55rem .8rem; border-bottom: 1px solid var(--line); text-align: center; }
.matrix th:first-child, .matrix td:first-child { text-align: left; }
.matrix .ok { color: var(--lime); font-weight: 800; }
.matrix .no { color: var(--muted); }

/* ── DSGVO ───────────────────────────────────────────────────────────────── */
.legal { max-width: 760px; color: var(--muted); }
.legal h3 { color: var(--fg); margin: 1.2rem 0 .4rem; font-size: 1.05rem; }
.legal p { margin: 0 0 .6rem; }
