/* =========================================================================
   Scriptis Verbis · Paginae de Parcae
   Design-System v2 — Dark Academia / Crime / Fantasy
   Materialität · Elevation · WCAG 2.2 AA · View Transitions
   Buildless: reines CSS, progressive enhancement.
   ========================================================================= */

:root {
  /* — Basis (kein reines Schwarz: vermeidet Halation/Astigmatismus) — */
  --bg:         #0c0b10;   /* Ink Bottle × Candlelit */
  --bg-1:       #121117;   /* Elevation 1 */
  --bg-2:       #191822;   /* Elevation 2 (Karten) */
  --bg-3:       #22212d;   /* Elevation 3 (Hover/Modal) */

  /* — Pergament-Typografie — */
  --ink:        #e9e0ca;   /* ~13:1 auf --bg */
  --ink-soft:   #cfc5ac;   /* ~9:1 */
  --muted:      #a0967f;   /* ~5.5:1 — Sekundärtext */
  --muted-2:    #7b7160;   /* nur große/dekorative Schrift */

  /* — Akzente (entsättigt für Dark-Mode-Lesbarkeit) — */
  --gold:        #c8a35c;
  --gold-bright: #e4c587;
  --gold-deep:   #8a6c34;
  --plum:        #b08aa0;  /* Velvet Plum, aufgehellt für Text auf dunkel */
  --plum-fill:   #6e4b5e;  /* Velvet Plum, Fläche (mit heller Schrift) */
  --blood:       #b1463a;

  /* — Linien & Glas — */
  --line:        rgba(200,163,92,0.14);
  --line-2:      rgba(200,163,92,0.30);
  --glass:       rgba(12,11,16,0.62);
  --hairline:    rgba(233,224,202,0.10); /* Elevation-Highlight */

  --shadow:      0 24px 60px -28px rgba(0,0,0,0.85);
  --shadow-lg:   0 40px 90px -36px rgba(0,0,0,0.95);

  --serif:  "EB Garamond", Georgia, "Times New Roman", serif;
  --display:"Cinzel", "Trajan Pro", Georgia, serif;
  --sans:   "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  --maxw: 1200px;
  --radius: 6px;
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);

  --step--1: clamp(0.83rem, 0.79rem + 0.18vw, 0.94rem);
  --step-0:  clamp(1.05rem, 1.00rem + 0.25vw, 1.20rem);
  --step-1:  clamp(1.30rem, 1.18rem + 0.55vw, 1.65rem);
  --step-2:  clamp(1.65rem, 1.40rem + 1.10vw, 2.45rem);
  --step-3:  clamp(2.10rem, 1.65rem + 2.10vw, 3.40rem);
  --step-4:  clamp(2.70rem, 1.90rem + 3.60vw, 5.10rem);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: no-preference) { html { scroll-behavior: smooth; } }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--serif);
  font-size: var(--step-0);
  line-height: 1.72;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* — Atmosphäre: warmer Lichtschein + Vignette (fixed, ohne DOM-Eingriff) — */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(1100px 620px at 50% -10%, rgba(200,163,92,0.10), transparent 60%),
    radial-gradient(900px 560px at 100% 105%, rgba(110,75,94,0.10), transparent 55%),
    radial-gradient(700px 700px at 0% 60%, rgba(177,70,58,0.05), transparent 60%);
}
body::after {
  content: ""; position: fixed; inset: 0; z-index: 2147483646; pointer-events: none;
  box-shadow: inset 0 0 220px 40px rgba(0,0,0,0.55);
}

/* — Filmkorn / Materialität — */
.grain {
  position: fixed; inset: -50%; z-index: 2147483645; pointer-events: none;
  opacity: 0.04; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@media (prefers-reduced-motion: no-preference) {
  .grain { animation: grain 7s steps(6) infinite; }
  @keyframes grain {
    0%{transform:translate(0,0)} 20%{transform:translate(-4%,2%)}
    40%{transform:translate(3%,-3%)} 60%{transform:translate(-2%,4%)}
    80%{transform:translate(4%,1%)} 100%{transform:translate(0,0)}
  }
}

img { max-width: 100%; display: block; }
a { color: var(--gold-bright); text-decoration: none; transition: color .2s var(--ease); }
a:hover { color: var(--ink); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(20px, 4vw, 40px); }

h1,h2,h3 { font-family: var(--display); font-weight: 600; line-height: 1.14; letter-spacing: .4px; margin: 0 0 .5em; }

/* — Fokus-Sichtbarkeit (Tastatur) — */
:focus-visible { outline: 2px solid var(--gold-bright); outline-offset: 3px; border-radius: 3px; }
:focus:not(:focus-visible) { outline: none; }

/* — Skip-Link — */
.skip-link {
  position: fixed; top: 10px; left: 10px; z-index: 2147483647;
  background: var(--bg-3); color: var(--ink); border: 1px solid var(--line-2);
  padding: 12px 18px; border-radius: var(--radius); font-family: var(--serif); font-size: .9rem;
  transform: translateY(-160%); transition: transform .25s var(--ease);
}
.skip-link:focus { transform: none; color: var(--ink); }

/* — Scroll-Fortschritt — */
.scroll-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 60;
  transform: scaleX(0); transform-origin: 0 50%;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold-bright), var(--plum));
}

.eyebrow {
  font-family: var(--display); font-weight: 600;
  font-size: var(--step--1); letter-spacing: .34em; text-transform: uppercase;
  color: var(--gold); margin: 0 0 1.1rem;
}

.divider { display:flex; align-items:center; justify-content:center; gap:14px; color:var(--gold-deep); }
.divider::before, .divider::after { content:""; height:1px; width:64px; background:linear-gradient(90deg,transparent,var(--line-2)); }
.divider::after { background:linear-gradient(90deg,var(--line-2),transparent); }
.divider span { font-size:.9rem; }

/* ============================ HEADER / NAV ============================ */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--glass);
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
  border-bottom: 1px solid var(--line);
  box-shadow: inset 0 1px 0 var(--hairline); /* Elevation statt Schatten */
}
.nav { display:flex; align-items:center; justify-content:space-between; height: 70px; }
.brand { font-family: var(--display); font-size: 1.05rem; letter-spacing: .26em; text-transform: uppercase; color: var(--ink); font-weight: 600; }
.brand:hover { color: var(--gold-bright); }
.brand b { color: var(--gold); font-weight: 600; }
.nav-links { display:flex; gap: 8px; align-items:center; }
.nav-links a {
  position: relative; font-family: var(--display); font-weight: 500;
  font-size: .8rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-soft); padding: 10px 14px; border-radius: var(--radius); min-height: 24px;
  display: inline-flex; align-items: center;
}
.nav-links a::after {
  content:""; position:absolute; left:14px; right:14px; bottom:6px; height:1px;
  background: var(--gold); transform: scaleX(0); transform-origin: 0 50%; transition: transform .3s var(--ease);
}
.nav-links a:hover, .nav-links a.active, .nav-links a[aria-current="page"] { color: var(--gold-bright); }
.nav-links a:hover::after, .nav-links a.active::after, .nav-links a[aria-current="page"]::after { transform: scaleX(1); }
.nav-toggle { display:none; background:none; border:0; cursor:pointer; color:var(--ink); font-size:1.5rem; line-height:1; width:44px; height:44px; }

/* ============================ HERO ============================ */
.hero { position: relative; overflow: hidden; padding: clamp(96px, 14vh, 160px) 0 clamp(72px, 10vh, 120px); text-align: center; }
.hero::before { /* atmendes Kerzenlicht */
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background: radial-gradient(56% 46% at 50% 16%, rgba(231,200,134,.16), transparent 72%);
  animation: breathe 8s ease-in-out infinite;
}
.hero::after { /* dem Cursor folgendes Licht */
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:0;
  background: radial-gradient(360px circle at var(--mx,50%) var(--my,26%), rgba(231,200,134,.14), transparent 60%);
  transition: opacity .5s var(--ease);
}
.hero.lit::after { opacity:1; }
@keyframes breathe { 0%,100%{opacity:.6; transform:scale(1)} 50%{opacity:1; transform:scale(1.05)} }
@keyframes flicker { 0%,100%{text-shadow:0 2px 50px rgba(200,163,92,.18)} 45%{text-shadow:0 2px 66px rgba(231,200,134,.34)} 55%{text-shadow:0 2px 58px rgba(231,200,134,.26)} }
.hero-canvas { position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero .wrap { position: relative; z-index: 1; }
.hero .eyebrow { animation: fade-up .9s var(--ease) both; }
.hero h1 {
  font-size: var(--step-4); margin: .12em 0 .34em;
  text-shadow: 0 2px 50px rgba(200,163,92,0.2);
  animation: fade-up 1s var(--ease) .05s both, flicker 6s ease-in-out 1.4s infinite;
}
.hero h1 .amp { color: var(--gold); font-style: italic; }
.hero .hero-logo { margin: .1em auto .55em; max-width: min(700px, 94%); animation: fade-up 1s var(--ease) .05s both; }
.hero .hero-logo img { width: 100%; height: auto; filter: drop-shadow(0 6px 34px rgba(200,163,92,.22)); }
@media (prefers-reduced-motion: no-preference) {
  .hero .hero-logo img { animation: logoGlow 6s ease-in-out 1.4s infinite; }
  @keyframes logoGlow { 0%,100%{filter:drop-shadow(0 6px 30px rgba(200,163,92,.18))} 50%{filter:drop-shadow(0 6px 46px rgba(231,200,134,.36))} }
}
.hero .lede { max-width: 720px; margin: 0 auto 2.2rem; font-size: var(--step-1); color: var(--ink-soft); font-style: italic; animation: fade-up 1s var(--ease) .12s both; }
.hero-cta { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; animation: fade-up 1s var(--ease) .2s both; }

/* ============================ BUTTONS ============================ */
.btn {
  position: relative; overflow: hidden;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family: var(--display); font-weight: 600; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase;
  min-height: 48px; padding: 0 26px; border-radius: var(--radius);
  border: 1px solid var(--line-2); color: var(--ink); background: var(--bg-1);
  transition: transform .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), background .25s var(--ease);
  cursor: pointer;
}
.btn:hover { border-color: var(--gold); color: var(--gold-bright); transform: translateY(-2px); background: var(--bg-2); }
.btn::after { /* Sheen */
  content:""; position:absolute; top:0; left:-120%; width:60%; height:100%;
  background: linear-gradient(100deg, transparent, rgba(233,224,202,0.16), transparent);
  transform: skewX(-18deg); transition: left .6s var(--ease);
}
.btn:hover::after { left: 130%; }
.btn-primary {
  background: linear-gradient(180deg, var(--gold-bright), var(--gold-deep));
  color: #1c1305; border-color: var(--gold);
  box-shadow: 0 12px 34px -14px rgba(200,163,92,.55), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-primary:hover { background: linear-gradient(180deg, #f1d69c, var(--gold)); color: #1c1305; border-color: var(--gold-bright); filter: none; }

/* ============================ SECTIONS ============================ */
.section { padding: clamp(64px, 11vh, 104px) 0; }
.section-head { text-align:center; max-width: 740px; margin: 0 auto 60px; }
.section-head h2 { font-size: var(--step-3); }
.section-head p { color: var(--muted); font-size: var(--step-1); line-height: 1.6; }
.alt { background: linear-gradient(180deg, transparent, rgba(0,0,0,0.28)), var(--bg-1); border-block: 1px solid var(--line); }

/* ============================ ZWEI STRÄNGE ============================ */
.strands { display:grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.strand {
  position: relative; overflow: hidden; padding: 40px 36px; border-radius: var(--radius);
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--line); box-shadow: inset 0 1px 0 var(--hairline);
  transition: transform .35s var(--ease), border-color .35s var(--ease);
}
.strand:hover { transform: translateY(-4px); border-color: var(--line-2); }
.strand::before { content:""; position:absolute; inset:0 auto 0 0; width:3px; background: linear-gradient(180deg, var(--gold), transparent); }
.strand.blood::before { background: linear-gradient(180deg, var(--blood), transparent); }
.strand h3 { font-size: var(--step-2); color: var(--ink); }
.strand-sub { font-family: var(--display); font-weight:600; color: var(--gold); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom: 16px; }
.strand.blood .strand-sub { color: var(--plum); }
.strand p { color: var(--ink-soft); margin: 0; }

/* ============================ BUCH-GITTER ============================ */
.book-grid { display:grid; gap: 44px 36px; grid-template-columns: repeat(auto-fill, minmax(224px, 1fr)); }
.book-card { display:flex; flex-direction:column; gap:18px; text-align:left; color: inherit; }
.cover-frame { position: relative; perspective: 1000px; }
.cover {
  position: relative; aspect-ratio: 2/3; width:100%; border-radius: var(--radius); overflow:hidden;
  border: 1px solid var(--line-2); background: var(--bg-2); box-shadow: var(--shadow);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  transform-style: preserve-3d;
}
.cover img { width:100%; height:100%; object-fit: cover; }
.cover::after { /* Glanz für Tilt */
  content:""; position:absolute; inset:0; pointer-events:none; opacity:0; transition: opacity .3s var(--ease);
  background: radial-gradient(420px circle at var(--gx,50%) var(--gy,0%), rgba(233,224,202,0.22), transparent 45%);
}
.book-card:hover .cover, .cover.tilting { box-shadow: var(--shadow-lg); border-color: var(--gold); }
.cover.tilting::after { opacity: 1; }
.book-card:hover .cover:not(.tilting) { transform: translateY(-8px); }
.book-tag {
  position:absolute; top:12px; left:12px; z-index:2;
  font-family: var(--display); font-weight:600; font-size:.6rem; letter-spacing:.14em; text-transform:uppercase;
  padding:6px 11px; border-radius:100px; background: var(--glass); backdrop-filter: blur(6px);
  border:1px solid var(--line-2); color: var(--gold-bright);
}
.book-tag.soon { color: var(--plum); border-color: rgba(176,138,160,.4); }
.book-meta .order { font-family: var(--display); font-weight:600; font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color: var(--muted-2); }
.book-meta h3 { font-size: var(--step-1); margin: 6px 0; color: var(--ink); }
.book-meta p { color: var(--muted); font-size: 1rem; margin: 0; line-height: 1.55; }
.book-card .more { margin-top:auto; font-family: var(--display); font-weight:600; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color: var(--gold); transition: gap .25s var(--ease); }
.book-card:hover .more { color: var(--gold-bright); }

/* ============================ BUCH-DETAIL ============================ */
.book-hero { padding: clamp(56px, 8vh, 84px) 0 40px; }
.book-layout { display:grid; grid-template-columns: 340px 1fr; gap: clamp(40px, 6vw, 72px); align-items: start; }
.book-cover-col { position: sticky; top: 100px; perspective: 1000px; }
.book-cover-col .cover { box-shadow: var(--shadow-lg); }
.book-cover-col .btn { width:100%; margin-top: 22px; }
.book-cover-col .buy-note { font-family: var(--serif); font-size: .86rem; color: var(--muted); text-align: center; margin: 9px 0 0; }
.book-cover-col .buy-note + .btn { margin-top: 14px; }
.facts { list-style:none; margin: 26px 0 0; padding:0; border-top:1px solid var(--line); }
.facts li { display:flex; justify-content:space-between; gap:16px; padding:12px 0; border-bottom:1px solid var(--line); font-size:.98rem; }
.facts li span:first-child { font-family: var(--display); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); align-self:center; }
.facts li span:last-child { color: var(--ink); text-align:right; }
.book-body .order { font-family: var(--display); font-weight:600; color: var(--muted-2); letter-spacing:.2em; text-transform:uppercase; font-size:.74rem; }
.book-body h1 { font-size: var(--step-3); margin: 10px 0 6px; }
.book-body .subtitle { font-style: italic; color: var(--gold); font-size: var(--step-1); margin-bottom: 26px; }
.book-body .prose p { color: var(--ink-soft); margin: 0 0 1.3em; }
.book-body .prose p.first::first-letter { font-family: var(--display); float:left; font-size:3.6rem; line-height:.78; padding: 8px 14px 0 0; color: var(--gold); }
.pull {
  margin: 40px 0; padding: 28px 34px; border-left: 3px solid var(--gold); border-radius: 0 var(--radius) var(--radius) 0;
  background: linear-gradient(90deg, rgba(200,163,92,0.08), transparent);
  font-style: italic; font-size: var(--step-2); color: var(--ink);
}
.chips { display:flex; flex-wrap:wrap; gap:10px; }
.chip { font-family: var(--display); font-weight:500; font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; border:1px solid var(--line); border-radius:100px; padding:8px 15px; color: var(--ink-soft); min-height:24px; display:inline-flex; align-items:center; }
.next-book { display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap; border-top:1px solid var(--line); margin-top:64px; padding-top:34px; }
.next-book .label { font-family: var(--display); font-weight:600; color: var(--muted); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; }

/* ============================ SEITENKOPF ============================ */
.page-head { padding: clamp(72px, 10vh, 110px) 0 30px; text-align:center; }
.page-head h1 { font-size: var(--step-3); }
.page-head p { color: var(--muted); max-width: 680px; margin: 0 auto; font-size: var(--step-1); }

/* ============================ WELT · BENTO ============================ */
.lore-grid { display:grid; grid-template-columns: repeat(6, 1fr); gap: 20px; grid-auto-flow: dense; }
.lore-card {
  position: relative; overflow: hidden; grid-column: span 2;
  border:1px solid var(--line); border-radius: var(--radius); padding: 30px 28px;
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1)); box-shadow: inset 0 1px 0 var(--hairline);
  transition: transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);
}
.lore-card:hover { transform: translateY(-4px); border-color: var(--line-2); background: linear-gradient(180deg, var(--bg-3), var(--bg-1)); }
.lore-card.bento-wide { grid-column: span 3; }
.lore-card.bento-x4 { grid-column: span 4; }
.lore-card.bento-tall { grid-row: span 2; }
.lore-card h3 { font-size: var(--step-1); color: var(--gold-bright); }
.lore-card p { color: var(--ink-soft); font-size: 1rem; margin: 0; }
.lore-card .ico { font-size: 1.7rem; margin-bottom: 12px; display:block; }

/* ============================ FOOTER ============================ */
.site-footer { border-top: 1px solid var(--line); background: var(--bg-1); padding: 60px 0 40px; margin-top: 40px; box-shadow: inset 0 1px 0 var(--hairline); }
.footer-grid { display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.footer-brand { font-family: var(--display); letter-spacing:.2em; text-transform:uppercase; color: var(--ink); font-size: 1rem; }
.footer-brand p { font-family: var(--serif); letter-spacing: normal; text-transform:none; color: var(--muted); font-size: .98rem; margin-top: 12px; max-width: 360px; }
.footer-nav { display:flex; flex-direction:column; gap:10px; }
.footer-nav a { font-family: var(--serif); font-size:1rem; color: var(--ink-soft); }
.footer-bottom { font-family: var(--serif); margin-top:16px; color: var(--muted-2); font-size:.88rem; text-align:center; }

/* ============================ REVEAL ============================ */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@keyframes fade-up { from { opacity:0; transform: translateY(22px); } to { opacity:1; transform:none; } }

/* ============================ VIEW TRANSITIONS ============================ */
@view-transition { navigation: auto; }
@media (prefers-reduced-motion: no-preference) {
  ::view-transition-old(root) { animation: vt-out .35s var(--ease) both; }
  ::view-transition-new(root) { animation: vt-in .45s var(--ease) both; }
  @keyframes vt-out { to { opacity: 0; transform: translateY(-8px) scale(.992); } }
  @keyframes vt-in  { from { opacity: 0; transform: translateY(10px) scale(.994); } }
}
/* Cover-Morph zwischen Übersicht und Buchseite */
.vt-scriptis-verbis { view-transition-name: cv-sv; }
.vt-paginae         { view-transition-name: cv-pp; }
.vt-initio          { view-transition-name: cv-in; }
.vt-bestia          { view-transition-name: cv-be; }
.vt-manes           { view-transition-name: cv-ma; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 900px) {
  .lore-grid { grid-template-columns: repeat(2, 1fr); }
  .lore-card, .lore-card.bento-wide { grid-column: span 1; }
  .lore-card.bento-tall { grid-row: span 1; }
}
@media (max-width: 860px) {
  .nav-links {
    position: fixed; inset: 70px 0 auto 0; flex-direction: column; gap:0; align-items: stretch;
    background: rgba(12,11,16,0.98); border-bottom: 1px solid var(--line);
    transform: translateY(-130%); transition: transform .3s var(--ease); padding: 8px 0;
  }
  .nav-links.open { transform: none; }
  .nav-links a { padding: 16px 28px; border-radius: 0; border-bottom: 1px solid var(--line); }
  .nav-links a::after { display:none; }
  .nav-toggle { display:block; }
  .strands { grid-template-columns: 1fr; }
  .book-layout { grid-template-columns: 1fr; gap: 36px; }
  .book-cover-col { position: static; max-width: 300px; margin: 0 auto; }
}

/* ============================ MOTION / KONTRAST ============================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
  .hero h1, .hero .lede, .hero .eyebrow, .hero-cta { animation: none; }
  ::view-transition-group(*) { animation: none !important; }
}
@media (prefers-contrast: more) {
  :root { --ink:#fff4e0; --muted:#c4baa2; --line:rgba(200,163,92,.4); --line-2:rgba(200,163,92,.6); }
}

/* ============================ FOOTER · RECHTLICHES ============================ */
.footer-legal { display:flex; gap:8px 18px; justify-content:center; flex-wrap:wrap; align-items:center; margin-top:34px; padding-top:22px; border-top:1px solid var(--line); }
.footer-legal a, .footer-legal button { font-family: var(--serif); font-size:.9rem; color: var(--muted); background:none; border:0; cursor:pointer; padding:6px 4px; min-height:24px; }
.footer-legal a:hover, .footer-legal button:hover { color: var(--gold-bright); }

/* ============================ COOKIE / EINTRITTS-SIEGEL ============================ */
.cookie {
  position: fixed; left: clamp(16px,3vw,28px); bottom: clamp(16px,3vw,28px); z-index: 2147483000;
  width: min(430px, calc(100vw - 32px));
  background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--line-2); border-radius: 12px;
  box-shadow: var(--shadow-lg), inset 0 1px 0 var(--hairline);
  padding: 28px 26px 22px; color: var(--ink);
  transform: translateY(160%); opacity: 0; transition: transform .55s var(--ease), opacity .55s var(--ease);
}
.cookie.show { transform: none; opacity: 1; }
.cookie::before { /* Wachssiegel */
  content:"❦"; position:absolute; top:-20px; left:26px; width:42px; height:42px;
  display:flex; align-items:center; justify-content:center;
  background: radial-gradient(circle at 35% 30%, #b1463a, #631c16); color:#f1d59b;
  border-radius:50%; font-size:1.15rem;
  box-shadow: 0 8px 18px -6px rgba(0,0,0,.85), inset 0 1px 2px rgba(255,255,255,.35);
}
.cookie .eyebrow { margin-bottom:.5rem; }
.cookie h3 { font-size: 1.2rem; margin: 0 0 8px; color: var(--gold-bright); }
.cookie p { font-size: .95rem; color: var(--ink-soft); margin: 0 0 18px; line-height: 1.55; }
.cookie p a { color: var(--gold-bright); text-decoration: underline; text-underline-offset: 3px; }
.cookie-actions { display:flex; gap:10px; flex-wrap:wrap; }
.cookie-actions .btn { min-height: 44px; padding: 0 18px; font-size: .72rem; flex: 1 1 140px; }

/* ============================ RECHTSSEITEN ============================ */
.legal { max-width: 760px; margin: 0 auto; padding: clamp(72px,9vh,104px) 0 90px; }
.legal h1 { font-size: var(--step-3); margin-bottom: 6px; }
.legal .eyebrow { margin-bottom: 1rem; }
.legal h2 { font-size: var(--step-1); margin: 40px 0 10px; color: var(--gold-bright); }
.legal p, .legal li { color: var(--ink-soft); }
.legal a { color: var(--gold-bright); text-decoration: underline; text-underline-offset: 3px; }
.legal ul { padding-left: 1.2em; }
.legal .muted { color: var(--muted); font-size: .92rem; }
.legal .card { border:1px solid var(--line); border-radius: var(--radius); background: var(--bg-1); padding: 22px 24px; margin: 18px 0; box-shadow: inset 0 1px 0 var(--hairline); }
