/* =========================================================
   100FreiSpiele.de — Stylesheet
   Design language: "Casino-Nacht" — tiefes Violett-Schwarz,
   Antik-Gold, mit Markenakzenten in Magenta/Cyan.
   ========================================================= */

:root{
  /* --- Farbpalette (6 Kernfarben) --- */
  --c-bg:        #120B1E;   /* Bühne: tiefes Violett-Schwarz */
  --c-surface:   #1C1230;   /* Kartenflächen */
  --c-surface-2: #241A3D;   /* erhöhte Flächen / Hover */
  --c-gold:      #D8A646;   /* Antik-Gold: Vertrauen, Premium */
  --c-gold-2:    #F2C572;   /* helles Gold: Glanzlicht/Hover */
  --c-magenta:   #FF2E92;   /* Markenakzent (Logo) */
  --c-cyan:      #19E6D2;   /* Markenakzent (Logo) */
  --c-cream:     #F5EFE3;   /* Primärtext auf Dunkel */
  --c-muted:     #B5ABC8;   /* Sekundärtext */
  --c-line:      rgba(216,166,70,.20);
  --c-line-soft: rgba(245,239,227,.10);
  --c-success:   #6FCF8E;

  /* --- Typografie --- */
  --f-display: "Fraunces", "Iowan Old Style", Georgia, serif;
  --f-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --f-mono: "Space Mono", "DejaVu Sans Mono", ui-monospace, monospace;

  /* --- Layout --- */
  --max-w: 1180px;
  --radius-s: 10px;
  --radius-m: 16px;
  --radius-l: 24px;
  --shadow-card: 0 14px 34px -16px rgba(0,0,0,.55);
  --shadow-glow-gold: 0 0 0 1px rgba(216,166,70,.35), 0 10px 30px -10px rgba(216,166,70,.45);
  --header-h: 76px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 14px); }
body{
  margin:0;
  background: var(--c-bg);
  color: var(--c-cream);
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration: none; }
ul,ol{ padding-left: 1.25em; }
button{ font: inherit; color: inherit; background:none; border:none; cursor:pointer; }
table{ border-collapse: collapse; width:100%; }
h1,h2,h3,h4{ font-family: var(--f-display); font-weight: 700; line-height: 1.15; margin: 0 0 .5em; color: var(--c-cream); }
p{ margin: 0 0 1em; }

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

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

.container{ max-width: var(--max-w); margin-inline:auto; padding-inline: 20px; }
.visually-hidden{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.skip-link{
  position:absolute; left:12px; top:-60px; background:var(--c-gold); color:var(--c-bg);
  padding:.6em 1em; border-radius: var(--radius-s); font-weight:700; z-index:200; transition: top .2s ease;
}
.skip-link:focus{ top:12px; }

/* ---------- Buttons & Badges ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  padding: .85em 1.5em;
  border-radius: 999px;
  font-weight: 700;
  font-size: .98rem;
  white-space: nowrap;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn-gold{
  background: linear-gradient(135deg, var(--c-gold-2), var(--c-gold));
  color: #241608;
  box-shadow: var(--shadow-glow-gold);
}
.btn-gold:hover, .btn-gold:focus-visible{ transform: translateY(-2px); filter: brightness(1.06); }
.btn-ghost{
  background: transparent;
  color: var(--c-cream);
  border: 1.5px solid rgba(245,239,227,.35);
}
.btn-ghost:hover{ border-color: var(--c-gold); color: var(--c-gold-2); }
.btn-block{ width:100%; }
.btn-sm{ padding: .55em 1em; font-size: .85rem; }
.btn svg{ width:16px; height:16px; flex:none; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-family: var(--f-mono);
  font-size: .76rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--c-cyan);
}
.eyebrow::before{ content:""; width:7px; height:7px; border-radius:50%; background: var(--c-magenta); box-shadow: 0 0 0 3px rgba(255,46,146,.18); }

.pill{
  display:inline-flex; align-items:center; gap:.4em;
  font-family: var(--f-mono);
  font-size: .74rem;
  padding: .3em .7em;
  border-radius: 999px;
  border: 1px solid var(--c-line);
  color: var(--c-muted);
}

/* ============ HEADER ============ */
.site-header{
  position: sticky; top:0; z-index:100;
  height: var(--header-h);
  display:flex; align-items:center;
  background: rgba(18,11,30,.86);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--c-line-soft);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:1rem; width:100%; }

.wordmark{ display:flex; align-items:center; gap:.65em; }
.wordmark-badge{
  width:42px; height:42px; border-radius:50%;
  background: conic-gradient(var(--c-gold) 0 18deg, transparent 18deg 36deg,
              var(--c-gold) 36deg 54deg, transparent 54deg 72deg,
              var(--c-magenta) 72deg 90deg, transparent 90deg 108deg,
              var(--c-gold) 108deg 126deg, transparent 126deg 144deg,
              var(--c-gold) 144deg 162deg, transparent 162deg 180deg,
              var(--c-gold) 180deg 198deg, transparent 198deg 216deg,
              var(--c-gold) 216deg 234deg, transparent 234deg 252deg,
              var(--c-magenta) 252deg 270deg, transparent 270deg 288deg,
              var(--c-gold) 288deg 306deg, transparent 306deg 324deg,
              var(--c-gold) 324deg 342deg, transparent 342deg 360deg);
  display:grid; place-items:center;
  flex: none;
}
.wordmark-badge::after{
  content:"€"; width:30px; height:30px; border-radius:50%;
  background: var(--c-bg); color: var(--c-gold-2);
  display:grid; place-items:center; font-family: var(--f-mono); font-weight:700; font-size: .85rem;
  border: 1px solid var(--c-gold-2);
}
.wordmark-text{ font-family: var(--f-display); line-height:1.05; }
.wordmark-text strong{ display:block; font-size: 1.18rem; color: var(--c-cream); }
.wordmark-text span{ display:block; font-family: var(--f-mono); font-size:.62rem; letter-spacing:.12em; color: var(--c-gold-2); text-transform:uppercase; margin-top:2px; }
.wordmark-flag{ display:inline-flex; width:18px; height:4px; border-radius:2px; overflow:hidden; margin-left:.55em; vertical-align:middle; }
.wordmark-flag span{ flex:1; }
.wordmark-flag span:nth-child(1){ background:#111; }
.wordmark-flag span:nth-child(2){ background:#D8A646; }
.wordmark-flag span:nth-child(3){ background:#c41e3a; }

.main-nav-list{ list-style:none; display:flex; align-items:center; gap: 1.6rem; margin:0; padding:0; }
.main-nav-list a{ font-size:.93rem; font-weight:600; color: var(--c-muted); transition: color .15s ease; }
.main-nav-list a:hover, .main-nav-list a:focus-visible{ color: var(--c-gold-2); }

.header-actions{ display:flex; align-items:center; gap: .9rem; }
.burger{
  display:none; width:44px; height:44px; border-radius: var(--radius-s);
  border:1px solid var(--c-line-soft); flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.burger span{ width:20px; height:2px; background: var(--c-cream); border-radius:2px; transition: transform .25s ease, opacity .25s ease; }
.burger[aria-expanded="true"] span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.burger[aria-expanded="true"] span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 880px){
  .main-nav{
    position:fixed; inset: var(--header-h) 0 0 0;
    background: var(--c-bg);
    transform: translateY(-8px);
    opacity:0; visibility:hidden;
    transition: opacity .2s ease, transform .2s ease, visibility .2s;
    overflow-y:auto;
    border-top: 1px solid var(--c-line-soft);
  }
  .main-nav.is-open{ opacity:1; visibility:visible; transform:none; }
  .main-nav-list{ flex-direction:column; align-items:stretch; gap:0; padding: 1.25rem 20px; }
  .main-nav-list li{ border-bottom:1px solid var(--c-line-soft); }
  .main-nav-list a{ display:block; padding: 1.05rem .25rem; font-size:1.05rem; }
  .header-actions .btn-gold{ display:none; }
  .main-nav .nav-cta{ display:block; margin: 1rem 20px 1.5rem; }
  .burger{ display:flex; }
}

/* ============ HERO ============ */
.hero{
  position:relative;
  padding: 2.6rem 0 2.2rem;
  overflow:hidden;
  background:
    radial-gradient(ellipse 60% 80% at 85% -10%, rgba(255,46,146,.16), transparent 60%),
    radial-gradient(ellipse 50% 60% at 0% 0%, rgba(25,230,210,.12), transparent 55%),
    var(--c-bg);
  border-bottom: 1px solid var(--c-line-soft);
}
.hero-inner{ max-width: 760px; }
.hero h1{
  font-size: clamp(1.65rem, 4.6vw, 2.85rem);
  letter-spacing: -.01em;
  margin: .5em 0 .45em;
}
.hero h1 em{ font-style:normal; color: var(--c-gold-2); }
.hero-lead{ color: var(--c-muted); font-size: clamp(.97rem, 1.6vw, 1.1rem); max-width: 62ch; margin-bottom: 1.1em; }

.trust-row{ list-style:none; display:flex; flex-wrap:wrap; gap:.6rem .8rem; margin:0 0 .3rem; padding:0; }
.trust-row li{
  display:flex; align-items:center; gap:.45em;
  font-size:.82rem; color: var(--c-cream);
  background: rgba(245,239,227,.06);
  border:1px solid var(--c-line-soft);
  padding:.45em .85em; border-radius:999px;
}
.trust-row li svg{ width:14px; height:14px; flex:none; color: var(--c-gold-2); }

/* ============ BONUS GRID ============ */
.bonus-section{ padding: 2.4rem 0 1rem; }
.section-head{ max-width: 700px; margin-bottom: 1.5rem; }
.section-head h2{ font-size: clamp(1.4rem, 3vw, 1.9rem); margin-bottom:.35em; }
.section-head p{ color: var(--c-muted); margin:0; }

.bonus-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 1.1rem;
}
@media (min-width: 640px){ .bonus-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1020px){ .bonus-grid{ grid-template-columns: repeat(3, 1fr); } }

.bonus-card{
  position:relative;
  display:flex; flex-direction:column;
  background: linear-gradient(180deg, var(--c-surface-2), var(--c-surface));
  border: 1px solid var(--c-line-soft);
  border-radius: var(--radius-m);
  padding: 1.5rem 1.25rem 1.25rem;
  box-shadow: var(--shadow-card);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.bonus-card:hover{ transform: translateY(-4px); border-color: var(--c-line); box-shadow: 0 18px 38px -16px rgba(0,0,0,.6); }
.bonus-card.is-featured{ border-color: rgba(216,166,70,.55); box-shadow: var(--shadow-glow-gold); }

.chip-rank{
  position:absolute; top:-14px; left:18px;
  width: 46px; height:46px; border-radius:50%;
  background: conic-gradient(var(--c-gold) 0 14deg, var(--c-surface) 14deg 28deg);
  display:grid; place-items:center;
  box-shadow: 0 4px 10px rgba(0,0,0,.45);
}
.chip-rank::after{
  content: attr(data-rank);
  width:34px; height:34px; border-radius:50%;
  background: var(--c-bg);
  color: var(--c-gold-2);
  display:grid; place-items:center;
  font-family: var(--f-mono); font-weight:700; font-size:.82rem;
  border: 1px solid rgba(242,197,114,.5);
}
.featured-tag{
  position:absolute; top:-13px; right:16px;
  background: var(--c-magenta); color:#2a0418;
  font-family: var(--f-mono); font-size:.62rem; letter-spacing:.08em; text-transform:uppercase;
  padding:.35em .6em; border-radius:999px; font-weight:700;
}

.card-logo-plate{
  align-self:flex-start;
  background: var(--c-cream);
  border-radius: var(--radius-s);
  padding: .65rem 1rem;
  margin: .6rem 0 .9rem;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.05);
}
.card-logo-plate img{ height:26px; width:auto; }

.bonus-card h3{ font-size: 1.18rem; margin-bottom:.3em; }
.bonus-card .bonus-headline{ color: var(--c-cream); font-size:.93rem; margin-bottom: .9rem; flex-grow: 0; }

.meta-tags{ display:flex; flex-wrap:wrap; gap:.45rem; margin-bottom: 1rem; }
.meta-tag{
  font-family: var(--f-mono); font-size:.72rem;
  display:inline-flex; align-items:center; gap:.35em;
  padding:.3em .6em; border-radius:6px;
  background: rgba(25,230,210,.08); color: var(--c-cyan);
  border: 1px solid rgba(25,230,210,.25);
}
.meta-tag.wager-high{ background: rgba(255,46,146,.08); color:#ff8fc4; border-color: rgba(255,46,146,.3); }
.meta-tag.wager-low{ background: rgba(111,207,142,.1); color: var(--c-success); border-color: rgba(111,207,142,.3); }

.code-box{
  margin-top:auto;
  display:flex; align-items:center; justify-content:space-between; gap:.5rem;
  background: var(--c-bg);
  border: 1.5px dashed rgba(216,166,70,.45);
  border-radius: var(--radius-s);
  padding: .65rem .8rem;
  margin-bottom: .9rem;
}
.code-box .code-label{ font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color: var(--c-muted); display:block; margin-bottom:2px; }
.code-box .code-value{ font-family: var(--f-mono); font-weight:700; font-size:1rem; color: var(--c-gold-2); letter-spacing:.04em; }
.copy-btn{
  flex:none; display:flex; align-items:center; gap:.35em;
  background: rgba(216,166,70,.12); border:1px solid rgba(216,166,70,.4);
  color: var(--c-gold-2); padding:.45em .65em; border-radius:8px; font-size:.74rem; font-weight:700;
  transition: background .15s ease, transform .15s ease;
}
.copy-btn:hover{ background: rgba(216,166,70,.22); }
.copy-btn:active{ transform: scale(.95); }
.copy-btn svg{ width:14px; height:14px; }
.copy-btn.is-copied{ background: rgba(111,207,142,.18); border-color: rgba(111,207,142,.5); color: var(--c-success); }

.no-code-tag{
  margin-top:auto; margin-bottom:.9rem;
  display:flex; align-items:center; gap:.5em;
  background: rgba(111,207,142,.08); border:1px solid rgba(111,207,142,.3);
  color: var(--c-success); border-radius: var(--radius-s);
  padding:.65rem .8rem; font-size:.82rem; font-weight:600;
}
.no-code-tag svg{ width:16px; height:16px; flex:none; }

.bonus-card .btn{ margin-top:0; }

.grid-disclaimer{ margin-top:1.4rem; font-size:.78rem; color: var(--c-muted); max-width: 80ch; }

/* ============ TOC ============ */
.toc-card{
  background: var(--c-surface);
  border: 1px solid var(--c-line-soft);
  border-radius: var(--radius-m);
  padding: 1.5rem 1.6rem;
  margin: 2.4rem 0;
}
.toc-card h2{ font-size:1.15rem; margin-bottom:.85em; display:flex; align-items:center; gap:.5em; }
.toc-card h2 svg{ width:20px; height:20px; color: var(--c-gold-2); }
.toc-list{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns: 1fr; gap:.35rem 1.5rem; column-count:1; }
@media (min-width:700px){ .toc-list{ grid-template-columns: 1fr 1fr; } }
.toc-list > li > a{
  display:flex; align-items:baseline; gap:.55em;
  font-size:.92rem; color: var(--c-muted); padding:.4em 0; border-bottom: 1px dashed var(--c-line-soft);
}
.toc-list > li > a:hover{ color: var(--c-gold-2); }
.toc-list .toc-num{ font-family: var(--f-mono); color: var(--c-gold); font-size:.78rem; flex:none; }
.toc-sublist{ list-style:none; margin:.25rem 0 .25rem 1.4rem; padding:0; }
.toc-sublist a{ font-size:.84rem; color: var(--c-muted); display:block; padding:.25em 0; }
.toc-sublist a:hover{ color: var(--c-gold-2); }

/* ============ ARTICLE / PROSE ============ */
.article{ padding: 1.2rem 0 2.4rem; }
.prose{ max-width: 78ch; }
.prose h2{ font-size: clamp(1.3rem, 2.6vw, 1.7rem); margin-top: 2.4em; padding-top:.2em; scroll-margin-top: calc(var(--header-h) + 16px); }
.prose h2:first-child{ margin-top:0; }
.prose h3{ font-size: clamp(1.08rem, 2vw, 1.28rem); margin-top: 1.8em; color: var(--c-gold-2); }
.prose p{ color: rgba(245,239,227,.92); }
.prose p strong{ color: var(--c-cream); }
.prose ul, .prose ol{ color: rgba(245,239,227,.92); margin-bottom: 1.2em; }
.prose li{ margin-bottom: .4em; }
.prose a.inline-link{ color: var(--c-gold-2); text-decoration: underline; text-underline-offset:3px; }

.callout{
  background: linear-gradient(135deg, rgba(216,166,70,.12), rgba(216,166,70,.03));
  border-left: 3px solid var(--c-gold);
  border-radius: 0 var(--radius-s) var(--radius-s) 0;
  padding: 1rem 1.2rem;
  margin: 1.6em 0;
  font-size: .96rem;
}
.callout strong{ color: var(--c-gold-2); }

.formula-box{
  font-family: var(--f-mono);
  background: var(--c-bg);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-m);
  padding: 1.4rem 1.2rem;
  margin: 1.6em 0;
  text-align:center;
  color: var(--c-cyan);
  font-size: clamp(.78rem, 2vw, .95rem);
  line-height: 1.9;
  overflow-x:auto;
}
.formula-box .arrow{ color: var(--c-gold); opacity:.7; }
.formula-box .result{ color: var(--c-gold-2); font-weight:700; }

.table-wrap{
  overflow-x:auto;
  margin: 1.6em 0 2em;
  border: 1px solid var(--c-line-soft);
  border-radius: var(--radius-m);
  -webkit-overflow-scrolling: touch;
}
.data-table{ min-width: 560px; }
.data-table th, .data-table td{
  text-align:left; padding: .8em 1em; font-size:.9rem;
  border-bottom: 1px solid var(--c-line-soft);
  white-space: nowrap;
}
.data-table td:first-child, .data-table th:first-child{ white-space: normal; }
.data-table thead th{
  background: var(--c-surface-2);
  font-family: var(--f-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase;
  color: var(--c-gold-2); font-weight:700;
  position: sticky; top:0;
}
.data-table tbody tr:hover{ background: rgba(245,239,227,.03); }
.data-table tbody tr:last-child td{ border-bottom:none; }
.data-table strong{ color: var(--c-gold-2); }

.steps-list{ list-style:none; margin: 1.6em 0; padding:0; counter-reset: step; display:grid; gap:.7rem; }
.steps-list li{
  counter-increment: step;
  display:flex; gap:1rem; align-items:flex-start;
  background: var(--c-surface); border:1px solid var(--c-line-soft); border-radius: var(--radius-s);
  padding: .9rem 1.1rem;
}
.steps-list li::before{
  content: counter(step);
  flex:none; width:30px; height:30px; border-radius:50%;
  background: var(--c-gold); color:#241608; font-weight:700; font-family: var(--f-mono);
  display:grid; place-items:center; font-size:.85rem;
}

.profile-card{
  background: var(--c-surface); border:1px solid var(--c-line-soft); border-radius: var(--radius-m);
  padding: 1.4rem 1.5rem; margin: 1.4em 0 2em;
}
.profile-card ul{ margin:0; }
.profile-card .profile-title{ font-family: var(--f-mono); font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; color: var(--c-cyan); margin-bottom:.6em; display:block; }

.checklist{ list-style:none; margin:1.5em 0; padding:0; display:grid; gap:.55rem; }
.checklist li{ display:flex; gap:.6em; align-items:flex-start; color: rgba(245,239,227,.92); }
.checklist li svg{ flex:none; width:18px; height:18px; margin-top:.15em; color: var(--c-gold-2); }

.compare-grid{ display:grid; grid-template-columns: 1fr; gap:1rem; margin: 1.6em 0; }
@media(min-width:640px){ .compare-grid{ grid-template-columns: 1fr 1fr; } }
.compare-col{ border-radius: var(--radius-m); padding: 1.2rem 1.3rem; }
.compare-col.pro{ background: rgba(111,207,142,.07); border:1px solid rgba(111,207,142,.3); }
.compare-col.con{ background: rgba(255,46,146,.06); border:1px solid rgba(255,46,146,.25); }
.compare-col h4{ font-family: var(--f-display); margin-bottom:.6em; }
.compare-col.pro h4{ color: var(--c-success); }
.compare-col.con h4{ color: #ff8fc4; }
.compare-col ul{ margin:0; padding-left:1.1em; }
.compare-col li{ margin-bottom:.45em; font-size:.92rem; }

/* ============ FAQ ============ */
.faq-section{ padding: 1rem 0 2.6rem; }
.faq-list{ max-width: 78ch; display:grid; gap:.7rem; }
.faq-item{
  background: var(--c-surface);
  border: 1px solid var(--c-line-soft);
  border-radius: var(--radius-s);
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer; list-style:none;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding: 1.05rem 1.25rem;
  font-weight:700; font-size:.98rem; color: var(--c-cream);
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary .q-icon{
  flex:none; width:26px; height:26px; border-radius:50%;
  border:1px solid var(--c-gold); color: var(--c-gold-2);
  display:grid; place-items:center; font-family: var(--f-mono); font-size:1rem;
  transition: transform .2s ease;
}
.faq-item[open] summary .q-icon{ transform: rotate(45deg); }
.faq-item .faq-answer{ padding: 0 1.25rem 1.25rem; color: var(--c-muted); font-size:.94rem; }

/* ============ AUTHOR ============ */
.author-section{ padding: 1.4rem 0 2.6rem; }
.author-card{
  display:flex; gap:1.4rem; align-items:flex-start; flex-wrap:wrap;
  background: linear-gradient(135deg, var(--c-surface-2), var(--c-surface));
  border: 1px solid var(--c-line-soft); border-radius: var(--radius-l);
  padding: 1.8rem;
}
.author-photo{ flex:none; width:96px; height:96px; border-radius:50%; overflow:hidden; border:2px solid var(--c-gold); }
.author-photo img{ width:100%; height:100%; object-fit:cover; }
.author-body{ flex:1; min-width:240px; }
.author-name{ font-family: var(--f-display); font-size:1.2rem; margin-bottom:.1em; }
.author-role{ font-family: var(--f-mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color: var(--c-cyan); display:block; margin-bottom:.7em; }
.author-body p{ color: var(--c-muted); font-size:.93rem; margin-bottom:0; max-width: 65ch; }

/* ============ PAGE HERO (subpages) ============ */
.page-hero{ padding: 2.4rem 0 1.8rem; border-bottom: 1px solid var(--c-line-soft);
  background: radial-gradient(ellipse 60% 80% at 90% -20%, rgba(255,46,146,.14), transparent 60%), var(--c-bg); }
.page-hero h1{ font-size: clamp(1.6rem, 4vw, 2.4rem); }
.breadcrumb{ display:flex; gap:.5em; align-items:center; font-size:.82rem; color: var(--c-muted); margin-bottom:1rem; }
.breadcrumb a{ color: var(--c-muted); }
.breadcrumb a:hover{ color: var(--c-gold-2); }

/* ============ FOOTER ============ */
.site-footer{ border-top:1px solid var(--c-line-soft); padding: 2.6rem 0 1.6rem; background: #0E0918; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; margin-bottom: 2rem; }
@media (max-width: 760px){ .footer-grid{ grid-template-columns: 1fr; gap: 1.6rem; } }
.footer-brand p{ color: var(--c-muted); font-size:.88rem; max-width: 38ch; }
.footer-col h5{ font-family: var(--f-mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color: var(--c-gold-2); margin-bottom:.9em; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.footer-col a{ color: var(--c-muted); font-size:.88rem; }
.footer-col a:hover{ color: var(--c-gold-2); }
.age-badge{
  display:inline-flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:50%; border:2px solid var(--c-magenta); color: var(--c-magenta);
  font-family: var(--f-mono); font-weight:700; font-size:.8rem; flex:none;
}
.footer-disclaimer{
  display:flex; gap:.8rem; align-items:flex-start;
  border-top: 1px solid var(--c-line-soft); padding-top: 1.4rem; margin-top:.4rem;
  color: var(--c-muted); font-size:.78rem; line-height:1.6;
}
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:.6rem; margin-top:1.3rem; font-size:.78rem; color: var(--c-muted); }

/* ============ MISC PAGE CONTENT (subpages) ============ */
.static-content{ padding: 1rem 0 3rem; }
.static-content .prose h2{ margin-top:1.8em; }
.help-box{
  background: var(--c-surface); border:1px solid var(--c-line-soft); border-radius: var(--radius-m);
  padding: 1.5rem 1.6rem; margin: 1.8em 0;
}
.help-box a{ color: var(--c-gold-2); text-decoration: underline; text-underline-offset:3px; }
.helpline{ font-family: var(--f-mono); font-size: 1.3rem; color: var(--c-gold-2); font-weight:700; }

/* Back to top */
.back-top{
  position:fixed; right:18px; bottom:18px; z-index:90;
  width:46px; height:46px; border-radius:50%;
  background: var(--c-gold); color:#241608;
  display:grid; place-items:center;
  box-shadow: var(--shadow-glow-gold);
  opacity:0; pointer-events:none; transform: translateY(10px);
  transition: opacity .2s ease, transform .2s ease;
}
.back-top.is-visible{ opacity:1; pointer-events:auto; transform:none; }
.back-top svg{ width:20px; height:20px; }
