/* ============================================================================
   Undercover Cops — Landing-Page Designsystem
   Tokens & Look 1:1 aus der App (app/lib/core/theme.dart) übernommen.
   Hauptschrift: Chakra Petch (wie in der App), gebündelt unter assets/fonts/.
   ========================================================================== */

/* ---------- Fonts ---------- */
@font-face {
  font-family: "Chakra Petch";
  src: url("../fonts/ChakraPetch-Regular.ttf") format("truetype");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Chakra Petch";
  src: url("../fonts/ChakraPetch-SemiBold.ttf") format("truetype");
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Chakra Petch";
  src: url("../fonts/ChakraPetch-Bold.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: swap;
}

/* ---------- Tokens ---------- */
:root {
  --bg: #0b0a14;
  --bg-2: #110f1f;
  --card: #1a1730;
  --card-2: #211d3a;
  --border: #322c52;
  --text: #ecebf7;
  --muted: #a6a1c9;

  --good: #2dd4bf;        /* Festival / Gut (Türkis) */
  --good-soft: rgba(45, 212, 191, .14);
  --bad: #ff4d6d;         /* Polizei / Böse (Rot) */
  --bad-soft: rgba(255, 77, 109, .14);
  --accent: #ff2e88;      /* Magenta */
  --accent-soft: rgba(255, 46, 136, .14);
  --cyan: #22d3ee;        /* Cyan */
  --violet: #c084fc;      /* Violett */
  --amber: #fbbf24;       /* Amber */
  --amber-soft: rgba(251, 191, 36, .13);

  --font: "Chakra Petch", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --radius: 16px;
  --radius-lg: 22px;
  --shadow: 0 14px 40px rgba(0, 0, 0, .45);
  --shadow-glow: 0 0 30px rgba(255, 46, 136, .25);
  --maxw: 1120px;
  --nav-h: 66px;
}

/* ---------- Reset / Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--nav-h) + 18px);
  -webkit-text-size-adjust: 100%;
}
body {
  margin: 0;
  font-family: var(--font);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.7;
  color: var(--text);
  background:
    radial-gradient(1100px 620px at 8% -10%, rgba(255, 46, 136, .20), transparent 60%),
    radial-gradient(1000px 640px at 100% 0%, rgba(34, 211, 238, .16), transparent 55%),
    radial-gradient(960px 760px at 50% 118%, rgba(192, 132, 252, .14), transparent 60%),
    var(--bg);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: var(--cyan); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--text); }
h1, h2, h3, h4 { line-height: 1.18; margin: 0; font-weight: 700; letter-spacing: -.01em; }
p { margin: 0 0 1em; }
ul, ol { margin: 0 0 1em; }
strong, b { font-weight: 700; }

::selection { background: var(--accent); color: #fff; }

:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 3px;
  border-radius: 6px;
}

.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 200;
  background: var(--accent); color: #fff; padding: 10px 16px; border-radius: 0 0 10px 0;
  font-weight: 700;
}
.skip-link:focus { left: 0; }

/* ---------- Layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }
.wrap-narrow { max-width: 820px; margin: 0 auto; padding: 0 22px; }
section { padding: 64px 0; }
.section-line { border-top: 1px solid rgba(255, 255, 255, .06); }

.eyebrow {
  display: inline-block; font-size: .76rem; font-weight: 700; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--cyan);
  border: 1px solid var(--border); border-radius: 999px; padding: 6px 14px; margin-bottom: 18px;
  background: rgba(34, 211, 238, .06);
}

.section-head { margin-bottom: 30px; }
.section-head h2 {
  font-size: clamp(1.6rem, 3.6vw, 2.3rem);
  display: flex; align-items: center; gap: 14px;
}
.section-head h2 .num {
  font-size: .8rem; font-weight: 800; color: var(--bg);
  background: linear-gradient(135deg, var(--accent), var(--violet));
  width: 34px; height: 34px; border-radius: 10px;
  display: inline-grid; place-items: center; flex: none;
}
.lead { color: var(--muted); font-size: 1.08rem; max-width: 68ch; margin: 10px 0 0; }
h3 { font-size: 1.2rem; margin: 26px 0 8px; }
h4 { font-size: 1.05rem; margin: 18px 0 6px; }

.text-good { color: var(--good); }
.text-bad { color: var(--bad); }
.text-accent { color: var(--accent); }
.text-cyan { color: var(--cyan); }
.text-violet { color: var(--violet); }
.text-amber { color: var(--amber); }
.muted { color: var(--muted); }
.center { text-align: center; }

/* ============================================================================
   NAVIGATION
   ========================================================================== */
.nav {
  position: sticky; top: 0; z-index: 100;
  height: var(--nav-h);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  background: rgba(11, 10, 20, .72);
  border-bottom: 1px solid var(--border);
}
.nav-inner {
  max-width: var(--maxw); height: 100%; margin: 0 auto;
  display: flex; align-items: center; gap: 18px;
  padding: 0 22px;
}
.nav-brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 1.02rem; letter-spacing: .3px; white-space: nowrap;
  color: var(--text);
}
.nav-brand img { height: 30px; width: auto; filter: drop-shadow(0 0 10px rgba(255, 46, 136, .5)); }
.nav-brand:hover { color: var(--text); }
.nav-links { margin-left: auto; display: flex; align-items: center; gap: 4px; }
.nav-links a {
  color: var(--muted); font-size: .9rem; font-weight: 600;
  padding: 8px 13px; border-radius: 999px; transition: .15s;
}
.nav-links a:hover { color: var(--text); background: rgba(255, 255, 255, .07); }
.nav-links a.active { color: var(--text); background: rgba(255, 46, 136, .14); }
.nav-cta {
  margin-left: 6px;
  background: linear-gradient(135deg, var(--accent), var(--violet)) !important;
  color: #fff !important; font-weight: 700;
  padding: 9px 18px !important; box-shadow: 0 0 18px rgba(255, 46, 136, .4);
}
.nav-cta:hover { filter: brightness(1.08); }
.nav-toggle {
  display: none; margin-left: auto;
  background: none; border: 1px solid var(--border); color: var(--text);
  border-radius: 10px; padding: 8px 12px; font-size: 1.1rem; cursor: pointer; line-height: 1;
}

@media (max-width: 860px) {
  .nav-links {
    position: fixed; inset: var(--nav-h) 0 auto 0;
    flex-direction: column; align-items: stretch; gap: 2px;
    background: rgba(11, 10, 20, .97); backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border); padding: 12px 16px;
    transform: translateY(-130%); transition: transform .28s ease; pointer-events: none;
  }
  .nav-links.open { transform: translateY(0); pointer-events: auto; }
  .nav-links a { padding: 13px 14px; font-size: 1rem; }
  .nav-cta { margin: 6px 0 0; text-align: center; }
  .nav-toggle { display: block; }
}

/* ============================================================================
   BUTTONS
   ========================================================================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font); font-weight: 700; font-size: 1rem; line-height: 1;
  padding: 15px 26px; border-radius: 999px; border: 1px solid transparent;
  cursor: pointer; transition: transform .12s ease, filter .15s ease, background .15s ease;
  text-align: center; white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--violet));
  color: #fff; box-shadow: 0 8px 26px rgba(255, 46, 136, .35);
}
.btn-primary:hover { filter: brightness(1.08); color: #fff; }
.btn-ghost {
  background: rgba(255, 255, 255, .04); color: var(--text); border-color: var(--border);
}
.btn-ghost:hover { background: rgba(255, 255, 255, .09); color: var(--text); }
.btn-soon { position: relative; }
.btn-soon::after {
  content: "Bald"; font-size: .62rem; font-weight: 800; letter-spacing: .5px;
  background: rgba(255, 255, 255, .22); color: #fff; padding: 2px 7px; border-radius: 999px;
}
.btn-lg { padding: 17px 32px; font-size: 1.06rem; }

/* ============================================================================
   PILLS / BADGES / CHIPS
   ========================================================================== */
.badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--card); border: 1px solid var(--border); border-radius: 999px;
  padding: 9px 16px; font-size: .92rem; font-weight: 600;
}
.badge b { color: var(--cyan); }

.pill {
  font-size: .74rem; font-weight: 700; padding: 5px 11px; border-radius: 999px;
  border: 1px solid var(--border); display: inline-flex; align-items: center; gap: 5px;
  letter-spacing: .2px;
}
.pill.band     { color: var(--good); border-color: rgba(45, 212, 191, .45); background: var(--good-soft); }
.pill.noband   { color: var(--bad); border-color: rgba(255, 77, 109, .45); background: var(--bad-soft); }
.pill.power    { color: var(--violet); border-color: rgba(192, 132, 252, .45); background: rgba(192, 132, 252, .12); }
.pill.faction-good { color: var(--good); border-color: rgba(45, 212, 191, .45); background: var(--good-soft); }
.pill.faction-bad  { color: var(--bad); border-color: rgba(255, 77, 109, .45); background: var(--bad-soft); }
.pill.plain    { color: var(--muted); }

/* ============================================================================
   HERO
   ========================================================================== */
.hero { padding: clamp(54px, 9vw, 96px) 0 56px; text-align: center; position: relative; }
.hero h1 {
  font-size: clamp(2.4rem, 9vw, 5.4rem); font-weight: 700; letter-spacing: -.02em; margin: 0;
  background: linear-gradient(110deg, var(--accent) 0%, var(--violet) 42%, var(--cyan) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  line-height: 1.04; overflow-wrap: break-word;
}
.hero .tagline { color: var(--muted); font-size: clamp(1.05rem, 2.4vw, 1.3rem); margin: 20px auto 0; max-width: 60ch; }
.hero .cta-row { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; margin-top: 34px; }
.hero .badges { display: flex; gap: 11px; flex-wrap: wrap; justify-content: center; margin-top: 34px; }

/* Hero collage of character art */
.hero-collage {
  display: flex; justify-content: center; align-items: flex-end; gap: clamp(-30px, -2vw, 14px);
  margin-top: 52px; perspective: 1200px;
}
.hero-collage .hc {
  width: clamp(94px, 15vw, 168px); aspect-ratio: 864 / 1184; border-radius: 16px;
  overflow: hidden; border: 2px solid var(--border);
  box-shadow: var(--shadow); background: var(--card);
  transition: transform .3s ease;
}
.hero-collage .hc img { width: 100%; height: 100%; object-fit: cover; }
.hero-collage .hc:nth-child(odd) { transform: translateY(14px) rotate(-4deg); }
.hero-collage .hc:nth-child(even) { transform: translateY(-6px) rotate(3deg) scale(1.06); z-index: 2; }
.hero-collage .hc.good { border-color: rgba(45, 212, 191, .65); box-shadow: 0 10px 36px rgba(45, 212, 191, .28); }
.hero-collage .hc.bad { border-color: rgba(255, 46, 136, .65); box-shadow: 0 10px 36px rgba(255, 46, 136, .3); }
.hero-collage .hc:hover { transform: translateY(-10px) rotate(0) scale(1.1); z-index: 5; }
@media (max-width: 620px) { .hero-collage .hc:nth-child(n+4) { display: none; } }

/* ============================================================================
   GENERIC CARDS / GRIDS
   ========================================================================== */
.grid { display: grid; gap: 18px; }
.cards-2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.cards-3 { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.cards-4 { grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); }

.card {
  background: linear-gradient(180deg, var(--card), var(--bg-2));
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 24px; box-shadow: var(--shadow);
}
.card h3 { margin: 0 0 8px; font-size: 1.18rem; }
.card h3:first-child { margin-top: 0; }
.card p:last-child { margin-bottom: 0; }
.card .ico { font-size: 1.7rem; display: block; margin-bottom: 10px; }

/* Feature card with neon top accent */
.feature {
  position: relative; overflow: hidden;
}
.feature::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--cyan));
  opacity: .8;
}

/* ---------- Callouts ---------- */
.callout {
  border-radius: var(--radius); padding: 18px 20px; margin: 22px 0;
  border: 1px solid var(--border); background: var(--card);
  display: flex; gap: 14px; align-items: flex-start;
}
.callout .ico { font-size: 1.4rem; flex: none; line-height: 1.5; }
.callout p { margin: 0; }
.callout p + p { margin-top: 8px; }
.callout.good { background: var(--good-soft); border-color: rgba(45, 212, 191, .4); }
.callout.bad  { background: var(--bad-soft); border-color: rgba(255, 77, 109, .4); }
.callout.warn { background: var(--amber-soft); border-color: rgba(251, 191, 36, .4); }
.callout.info { background: rgba(34, 211, 238, .1); border-color: rgba(34, 211, 238, .4); }

/* ---------- Faction / win cards ---------- */
.split { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); }
.win-card { border-radius: var(--radius); padding: 24px; border: 1px solid var(--border); }
.win-card h3 { margin-top: 0; }
.win-card.good { background: var(--good-soft); border-color: rgba(45, 212, 191, .4); }
.win-card.bad { background: var(--bad-soft); border-color: rgba(255, 77, 109, .4); }
.win-card .goal { font-weight: 700; font-size: 1.08rem; margin: 0 0 4px; }
.win-card.good .goal { color: var(--good); }
.win-card.bad .goal { color: var(--bad); }

/* ============================================================================
   ART CARDS (Charaktere / Floors / Ereignisse / Status) — wie App-ArtCard
   ========================================================================== */
.art-grid {
  display: grid; gap: 22px;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
.art-grid.cols-2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.art-card {
  display: flex; flex-direction: column;
  background: linear-gradient(180deg, var(--card), var(--bg-2));
  border: 2px solid var(--accent); border-radius: var(--radius-lg);
  overflow: hidden; box-shadow: 0 0 28px rgba(255, 46, 136, .22);
  transition: transform .2s ease, box-shadow .2s ease;
}
.art-card:hover { transform: translateY(-6px); }
.art-card.good { border-color: var(--good); box-shadow: 0 0 28px rgba(45, 212, 191, .28); }
.art-card.good:hover { box-shadow: 0 14px 40px rgba(45, 212, 191, .4); }
.art-card.bad { border-color: var(--accent); box-shadow: 0 0 28px rgba(255, 46, 136, .28); }
.art-card.bad:hover { box-shadow: 0 14px 40px rgba(255, 46, 136, .42); }
.art-card.violet { border-color: var(--violet); box-shadow: 0 0 28px rgba(192, 132, 252, .28); }
.art-card.amber { border-color: var(--amber); box-shadow: 0 0 28px rgba(251, 191, 36, .26); }
.art-card.cyan { border-color: var(--cyan); box-shadow: 0 0 28px rgba(34, 211, 238, .26); }

.art-card .art {
  aspect-ratio: 864 / 1184; width: 100%; overflow: hidden; background: var(--card-2);
  position: relative;
}
.art-card .art img { width: 100%; height: 100%; object-fit: cover; }
.art-card .art .corner {
  position: absolute; top: 12px; right: 12px;
  background: rgba(11, 10, 20, .72); backdrop-filter: blur(6px);
  border: 1px solid rgba(255, 255, 255, .18); border-radius: 999px;
  padding: 5px 11px; font-size: .72rem; font-weight: 700;
}
.art-card .body { padding: 16px 18px 20px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.art-card .title { font-size: 1.4rem; font-weight: 700; text-transform: uppercase; margin: 0; line-height: 1.1; }
.art-card.good .title { color: var(--good); }
.art-card.bad .title  { color: var(--accent); }
.art-card.violet .title { color: var(--violet); }
.art-card.amber .title { color: var(--amber); }
.art-card.cyan .title { color: var(--cyan); }
.art-card .subtitle {
  font-size: .74rem; letter-spacing: 1.6px; font-weight: 700; text-transform: uppercase; color: var(--muted);
  margin: -4px 0 0;
}
.art-card .pills { display: flex; flex-wrap: wrap; gap: 7px; }
.art-card .desc { color: var(--text); font-size: .92rem; line-height: 1.55; margin: 0; }
.art-card .ability {
  border-top: 1px dashed var(--border); padding-top: 11px; margin-top: auto;
  font-size: .9rem; color: var(--muted);
}
.art-card .ability b { color: var(--violet); }

/* Faction group heading */
.faction-head { display: flex; align-items: center; gap: 12px; margin: 8px 0 18px; }
.faction-head .dot { width: 12px; height: 12px; border-radius: 50%; flex: none; }
.faction-head.good .dot { background: var(--good); box-shadow: 0 0 12px var(--good); }
.faction-head.bad .dot { background: var(--accent); box-shadow: 0 0 12px var(--accent); }
.faction-head h3 { margin: 0; font-size: 1.35rem; }
.faction-head.good h3 { color: var(--good); }
.faction-head.bad h3 { color: var(--bad); }
.faction-head .sub { color: var(--muted); font-size: .92rem; font-weight: 600; }

/* ============================================================================
   TABLES
   ========================================================================== */
.table-scroll { overflow-x: auto; border-radius: var(--radius); border: 1px solid var(--border); }
table { border-collapse: collapse; width: 100%; min-width: 560px; background: var(--card); }
th, td { padding: 12px 14px; text-align: center; border-bottom: 1px solid var(--border); font-size: .93rem; }
th { background: var(--card-2); font-weight: 700; color: var(--text); }
td:first-child, th:first-child { text-align: left; }
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover { background: rgba(255, 255, 255, .03); }
td.good, th.good { color: var(--good); font-weight: 700; }
td.bad, th.bad { color: var(--bad); font-weight: 700; }
.tick { color: var(--good); font-weight: 800; }
.cross { color: var(--muted); }

/* ============================================================================
   TIMELINE (Tagesablauf)
   ========================================================================== */
.timeline { display: grid; gap: 14px; counter-reset: step; }
.step {
  display: grid; grid-template-columns: 52px 1fr; gap: 18px; align-items: start;
  background: linear-gradient(180deg, var(--card), var(--bg-2));
  border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 22px;
}
.step .n {
  counter-increment: step; width: 46px; height: 46px; border-radius: 13px;
  display: grid; place-items: center; font-weight: 800; font-size: 1.25rem; color: var(--bg);
  background: linear-gradient(135deg, var(--cyan), var(--violet));
}
.step .n::before { content: counter(step); }
.step h3 { margin: 0 0 4px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 1.12rem; }
.step p { margin: 0; color: var(--muted); font-size: .96rem; }
.tag {
  font-size: .7rem; font-weight: 700; padding: 3px 10px; border-radius: 999px;
  border: 1px solid var(--border); color: var(--muted); white-space: nowrap;
}
.tag.all { color: var(--good); border-color: rgba(45, 212, 191, .4); }

/* ============================================================================
   FLOOR DEMO (Bändchen-Prinzip)
   ========================================================================== */
.floor {
  background: var(--card-2); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 20px; margin-top: 8px;
}
.floor .floor-head { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.floor .floor-head .name { font-weight: 700; }
.floor .floor-head .count { color: var(--cyan); font-weight: 700; }
.people { display: flex; gap: 14px; flex-wrap: wrap; }
.person { text-align: center; width: 78px; }
.person .fig { font-size: 2.2rem; line-height: 1; filter: drop-shadow(0 4px 8px rgba(0, 0, 0, .4)); }
.person .wrist { font-size: .66rem; font-weight: 700; margin-top: 7px; padding: 4px 0; border-radius: 8px; }
.person .wrist.yes { color: var(--good); background: var(--good-soft); }
.person .wrist.no { color: var(--bad); background: var(--bad-soft); }

/* ============================================================================
   LISTS / MESSAGE BLOCKS
   ========================================================================== */
ul.clean { list-style: none; padding: 0; margin: 0; display: grid; gap: 11px; }
ul.clean li { display: flex; gap: 11px; align-items: flex-start; }
ul.clean li::before { content: "▸"; color: var(--accent); font-weight: 800; flex: none; }

.msg {
  font-family: var(--mono);
  background: #0e0c1a; border: 1px solid var(--border); border-left: 3px solid var(--cyan);
  border-radius: 10px; padding: 11px 15px; margin: 9px 0; font-size: .87rem; color: var(--text);
}

.example-round { display: grid; gap: 12px; }
.example-round .er { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 15px 17px; }
.example-round .er b { color: var(--cyan); }

/* ============================================================================
   ACCORDION (FAQ)
   ========================================================================== */
.faq { display: grid; gap: 12px; }
.faq details {
  background: linear-gradient(180deg, var(--card), var(--bg-2));
  border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden;
}
.faq details[open] { border-color: rgba(255, 46, 136, .45); box-shadow: var(--shadow-glow); }
.faq summary {
  cursor: pointer; list-style: none; padding: 18px 22px;
  font-weight: 700; font-size: 1.05rem; display: flex; align-items: center; gap: 14px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+"; margin-left: auto; font-size: 1.5rem; font-weight: 400; color: var(--accent);
  transition: transform .25s ease; line-height: 1;
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq summary:hover { color: var(--text); }
.faq .answer { padding: 0 22px 20px; color: var(--muted); }
.faq .answer p { margin: 0 0 .8em; }
.faq .answer p:last-child { margin-bottom: 0; }

.faq-cat { margin: 34px 0 6px; font-size: .82rem; font-weight: 700; letter-spacing: 1.6px; text-transform: uppercase; color: var(--cyan); }

/* ============================================================================
   PROSE (Datenschutz / Impressum)
   ========================================================================== */
.prose { max-width: 78ch; }
.prose h2 { font-size: 1.5rem; margin: 40px 0 12px; padding-top: 10px; }
.prose h2:first-of-type { margin-top: 8px; }
.prose h3 { font-size: 1.15rem; margin: 26px 0 8px; color: var(--text); }
.prose p { color: var(--muted); margin: 0 0 1em; }
.prose ul { color: var(--muted); padding-left: 1.3em; margin: 0 0 1em; }
.prose li { margin-bottom: .5em; }
.prose a { color: var(--cyan); text-decoration: underline; text-underline-offset: 3px; }
.prose strong { color: var(--text); }
.prose address { font-style: normal; color: var(--text); line-height: 1.8; }
.prose .updated { color: var(--muted); font-size: .9rem; }

.placeholder {
  color: var(--amber); font-weight: 700;
  background: var(--amber-soft); border: 1px dashed rgba(251, 191, 36, .5);
  border-radius: 6px; padding: 1px 7px; font-size: .92em; white-space: nowrap;
}
.legal-note {
  background: var(--amber-soft); border: 1px solid rgba(251, 191, 36, .4);
  border-radius: var(--radius); padding: 16px 20px; margin: 0 0 30px;
  color: var(--text); font-size: .92rem; display: flex; gap: 12px; align-items: flex-start;
}
.legal-note .ico { font-size: 1.3rem; flex: none; }
.legal-note p { margin: 0; color: var(--text); }

.toc {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 18px 22px; margin: 0 0 30px;
}
.toc strong { display: block; margin-bottom: 8px; }
.toc ol { margin: 0; padding-left: 1.4em; color: var(--muted); }
.toc a { color: var(--cyan); text-decoration: none; }

/* ============================================================================
   PAGE HEADER (Unterseiten)
   ========================================================================== */
.page-head { padding: clamp(46px, 7vw, 76px) 0 12px; text-align: center; }
.page-head h1 {
  font-size: clamp(1.9rem, 6vw, 3.4rem); font-weight: 700; margin: 0;
  background: linear-gradient(110deg, var(--accent), var(--violet) 55%, var(--cyan));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  overflow-wrap: break-word; hyphens: auto;
}
.page-head p { color: var(--muted); font-size: 1.08rem; max-width: 64ch; margin: 16px auto 0; }

/* ============================================================================
   CTA BAND
   ========================================================================== */
.cta-band {
  text-align: center; border-radius: var(--radius-lg);
  background:
    radial-gradient(600px 300px at 20% 0%, rgba(255, 46, 136, .22), transparent 60%),
    radial-gradient(600px 300px at 100% 100%, rgba(34, 211, 238, .18), transparent 60%),
    linear-gradient(180deg, var(--card), var(--bg-2));
  border: 1px solid var(--border); padding: clamp(38px, 6vw, 64px) 26px;
}
.cta-band h2 { font-size: clamp(1.7rem, 4vw, 2.5rem); margin: 0 0 12px; }
.cta-band p { color: var(--muted); max-width: 54ch; margin: 0 auto 28px; font-size: 1.06rem; }
.cta-band .cta-row { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* ============================================================================
   FOOTER
   ========================================================================== */
.footer { border-top: 1px solid var(--border); margin-top: 30px; padding: 56px 0 34px; background: rgba(11, 10, 20, .5); }
.footer-grid { display: grid; gap: 34px; grid-template-columns: 1.6fr 1fr 1fr; }
.footer-brand .nav-brand { font-size: 1.15rem; margin-bottom: 14px; }
.footer-brand p { color: var(--muted); font-size: .94rem; max-width: 40ch; }
.footer-col h4 { font-size: .8rem; letter-spacing: 1.4px; text-transform: uppercase; color: var(--muted); margin: 0 0 14px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.footer-col a { color: var(--text); font-size: .94rem; font-weight: 600; }
.footer-col a:hover { color: var(--accent); }
.footer-bottom {
  border-top: 1px solid var(--border); margin-top: 40px; padding-top: 22px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  color: var(--muted); font-size: .86rem;
}
.footer-bottom a { color: var(--muted); }
.footer-bottom a:hover { color: var(--text); }
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } .footer-brand { grid-column: 1 / -1; } }

/* ============================================================================
   TO-TOP
   ========================================================================== */
.to-top {
  position: fixed; right: 20px; bottom: 20px; z-index: 90;
  background: linear-gradient(135deg, var(--accent), var(--violet)); color: #fff; border: none;
  width: 48px; height: 48px; border-radius: 50%; font-size: 1.2rem; cursor: pointer;
  box-shadow: var(--shadow); opacity: 0; pointer-events: none; transition: .25s; display: grid; place-items: center;
}
.to-top.show { opacity: 1; pointer-events: auto; }
.to-top:hover { filter: brightness(1.1); }

/* ============================================================================
   REVEAL ON SCROLL
   ========================================================================== */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero-collage .hc, .art-card { transition: none; }
}

/* ============================================================================
   PRINT (für die Spielanleitung)
   ========================================================================== */
@media print {
  .nav, .to-top, .footer, .cta-band, .nav-toggle { display: none !important; }
  body { background: #fff; color: #111; }
  .card, .art-card, .step, .floor, table, .callout, .win-card, .faq details { box-shadow: none; }
  a { color: #111; }
}
