/* Kifferzeitung - Main Stylesheet (portiert aus Mockup v5) */
@import url("./fonts.css");

:root {
  /* Dark theme (default) */
  --bg: #0a0a0b;
  --bg-elevated: #131316;
  --bg-card: #18181c;
  --bg-deep: #1f1f24;
  --bg-glass: rgba(10, 10, 11, 0.75);
  --ink: #fafaf7;
  --ink-soft: #c5c5c0;
  --ink-faint: #8a8a85;
  --ink-trace: #525258;
  --rule: rgba(255, 255, 255, 0.08);
  --rule-strong: rgba(255, 255, 255, 0.18);

  --emerald: #3dd58b;
  --emerald-bright: #5cf0a6;
  --emerald-deep: #1d8b54;
  --emerald-soft: rgba(61, 213, 139, 0.18);
  --emerald-tint: rgba(61, 213, 139, 0.08);
  --emerald-glow: rgba(61, 213, 139, 0.35);

  --gold: #d4a347;
  --gold-bright: #e8be6b;
  --gold-soft: rgba(212, 163, 71, 0.15);

  --signal: #ff5a5a;
  --signal-soft: rgba(255, 90, 90, 0.15);

  --violet: #a78bfa;
  --violet-soft: rgba(167, 139, 250, 0.15);

  --c-politik: #ff5a5a;
  --c-branche: #94a3b8;
  --c-genetik: #3dd58b;
  --c-anbau:   #a3c553;
  --c-recht:   #d4a347;
  --c-wissen:  #6bb6ff;
  --c-life:    #f078b8;

  --font-display: "Bricolage Grotesque", "Geist", system-ui, sans-serif;
  --font-sans: "Geist", "Helvetica Neue", "Arial", sans-serif;
  --font-mono: "Geist Mono", "JetBrains Mono", Menlo, monospace;
  --font-serif: "Instrument Serif", Georgia, serif;

  --shadow-card: 0 1px 0 rgba(255,255,255,0.04), 0 0 0 1px rgba(255,255,255,0.04);
  --shadow-lift: 0 24px 48px -16px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.06);
  --shadow-glow: 0 0 40px var(--emerald-glow);

  --radius: 16px;
  --radius-sm: 10px;
  --radius-lg: 24px;
  --radius-pill: 999px;

  --t-fast: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
  --t-mid: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --t-slow: 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  font-feature-settings: "ss01", "ss02", "kern", "cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow-x: hidden;
}

/* Ambient glow layer */
body::before {
  content: "";
  position: fixed;
  top: -300px;
  left: 50%;
  transform: translateX(-50%);
  width: 1200px;
  height: 800px;
  background:
    radial-gradient(circle at 30% 50%, rgba(61, 213, 139, 0.12) 0%, transparent 50%),
    radial-gradient(circle at 70% 30%, rgba(167, 139, 250, 0.08) 0%, transparent 50%),
    radial-gradient(circle at 50% 80%, rgba(212, 163, 71, 0.06) 0%, transparent 50%);
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}
body::after {
  content: "";
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.025 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: overlay;
  opacity: 0.6;
}
body > * { position: relative; z-index: 2; }

a { color: inherit; text-decoration: none; transition: color var(--t-fast); }
a:hover { color: var(--emerald); }

::selection { background: var(--emerald); color: var(--bg); }

/* ============ SCROLL PROGRESS ============ */
.scroll-bar { position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 200; pointer-events: none; }
.scroll-bar__fill {
  height: 100%; width: 0;
  background: linear-gradient(90deg, var(--emerald) 0%, var(--gold-bright) 100%);
  box-shadow: 0 0 8px var(--emerald);
  transition: width 0.06s linear;
}

/* ============ TOP STRIPE ============ */
.topstripe {
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--rule);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.01em;
  position: sticky; top: 0; z-index: 100;
}
.topstripe__inner {
  max-width: 1320px; margin: 0 auto;
  padding: 0 24px;
  display: flex; align-items: center; gap: 18px;
  height: 40px;
}
.topstripe__signal {
  background: var(--signal); color: white;
  padding: 4px 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 10.5px;
  border-radius: var(--radius-pill);
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 6px;
}
.topstripe__signal::before {
  content: ""; width: 6px; height: 6px;
  background: white; border-radius: 50%;
  animation: pulse 1.5s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(255,255,255,0.6); }
  50% { opacity: 0.5; box-shadow: 0 0 0 5px rgba(255,255,255,0); }
}
.topstripe__ticker {
  flex: 1; overflow: hidden; white-space: nowrap;
  mask-image: linear-gradient(90deg, transparent, black 4%, black 96%, transparent);
}
.topstripe__ticker-inner { display: inline-flex; gap: 36px; animation: ticker 55s linear infinite; }
.topstripe__ticker-item { display: inline-flex; align-items: center; gap: 8px; opacity: 0.85; }
.topstripe__ticker-time { color: var(--ink-faint); font-variant-numeric: tabular-nums; }
.topstripe__date {
  flex-shrink: 0; color: var(--ink-faint);
  font-variant-numeric: tabular-nums;
  display: inline-flex; align-items: center; gap: 10px;
}
.topstripe__date::before {
  content: ""; width: 7px; height: 7px;
  background: var(--emerald); border-radius: 50%;
  box-shadow: 0 0 10px var(--emerald);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============ HEADER ============ */
.site-header {
  background: var(--bg-glass);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--rule);
  position: sticky; top: 0; z-index: 90;
}
.site-header__inner {
  max-width: 1320px; margin: 0 auto;
  padding: 18px 24px;
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 32px; align-items: center;
}

.wordmark {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-variation-settings: "wdth" 95, "opsz" 96;
}
.wordmark__dot {
  width: 9px; height: 9px;
  background: var(--emerald);
  border-radius: 50%;
  display: inline-block;
  margin-left: 4px;
  box-shadow: 0 0 12px var(--emerald);
  animation: pulse-soft 3s ease-in-out infinite;
}
@keyframes pulse-soft {
  0%, 100% { box-shadow: 0 0 12px var(--emerald); }
  50% { box-shadow: 0 0 20px var(--emerald); }
}

.nav { display: flex; gap: 0; list-style: none; padding: 0; margin: 0; }
.nav a {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14px;
  padding: 9px 14px;
  display: block;
  color: var(--ink-soft);
  border-radius: var(--radius-pill);
  transition: all var(--t-fast);
}
.nav a:hover { background: var(--bg-elevated); color: var(--ink); }
.nav a.is-active { background: var(--bg-elevated); color: var(--emerald); }

.header-actions { display: flex; align-items: center; gap: 8px; }

.menu-btn {
  display: none;
  width: 42px; height: 42px;
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  align-items: center; justify-content: center;
  cursor: pointer;
  transition: all var(--t-fast);
  padding: 0;
}
.menu-btn:hover { border-color: var(--rule-strong); }
.menu-btn__lines {
  width: 16px; height: 12px;
  position: relative;
}
.menu-btn__lines::before,
.menu-btn__lines::after {
  content: "";
  position: absolute; left: 0; right: 0;
  height: 1.5px;
  background: var(--ink);
  border-radius: 1px;
  transition: all var(--t-mid);
}
.menu-btn__lines::before { top: 2px; }
.menu-btn__lines::after { bottom: 2px; width: 70%; }
.menu-btn.is-open .menu-btn__lines::before { top: 50%; transform: translateY(-50%) rotate(45deg); }
.menu-btn.is-open .menu-btn__lines::after { bottom: 50%; transform: translateY(50%) rotate(-45deg); width: 100%; }

/* ============ MOBILE DRAWER ============ */
.drawer {
  position: fixed; inset: 0;
  z-index: 150;
  background: rgba(10, 10, 11, 0.85);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-mid);
}
.drawer.is-open { opacity: 1; pointer-events: all; }
.drawer__inner {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  padding: 88px 28px 32px;
  overflow-y: auto;
}
.drawer__brand {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: "wdth" 90, "opsz" 96;
  font-size: 22px;
  color: var(--ink);
  margin-bottom: 32px;
  letter-spacing: -0.035em;
  display: inline-flex; align-items: center; gap: 6px;
}
.drawer__nav { display: flex; flex-direction: column; gap: 4px; margin-bottom: 32px; }
.drawer__nav a {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 90;
  font-size: 2.2rem;
  letter-spacing: -0.04em;
  color: var(--ink);
  padding: 12px 0;
  border-bottom: 1px solid var(--rule);
  transition: all var(--t-fast);
  opacity: 0;
  transform: translateY(8px);
}
.drawer.is-open .drawer__nav a {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.4s ease, transform 0.4s ease, color var(--t-fast);
}
.drawer.is-open .drawer__nav a:nth-child(1) { transition-delay: 0.05s; }
.drawer.is-open .drawer__nav a:nth-child(2) { transition-delay: 0.10s; }
.drawer.is-open .drawer__nav a:nth-child(3) { transition-delay: 0.15s; }
.drawer.is-open .drawer__nav a:nth-child(4) { transition-delay: 0.20s; }
.drawer.is-open .drawer__nav a:nth-child(5) { transition-delay: 0.25s; }
.drawer.is-open .drawer__nav a:nth-child(6) { transition-delay: 0.30s; }
.drawer.is-open .drawer__nav a:nth-child(7) { transition-delay: 0.35s; }
.drawer__nav a:hover, .drawer__nav a.is-active { color: var(--emerald); }
.drawer__nav a.is-active::after {
  content: " \2022";
  color: var(--emerald);
  margin-left: 8px;
}
.drawer__actions {
  margin-top: auto;
  display: flex; flex-direction: column; gap: 10px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
}
.drawer__actions .btn { justify-content: center; padding: 14px 18px; font-size: 14.5px; }
.drawer__meta {
  display: flex; gap: 14px; flex-wrap: wrap;
  margin-top: 20px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
}
.drawer__meta a { color: var(--ink-soft); border-bottom: 1px solid var(--rule); padding-bottom: 1px; }
body.menu-locked { overflow: hidden; }

.drawer__close {
  position: absolute;
  top: 24px; right: 24px;
  width: 44px; height: 44px;
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: all var(--t-fast);
  z-index: 2;
}
.drawer__close:hover { border-color: var(--rule-strong); transform: rotate(90deg); }
.drawer__close svg { width: 18px; height: 18px; stroke: var(--ink); stroke-width: 2; fill: none; stroke-linecap: round; }
.btn {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 13.5px;
  padding: 10px 16px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--rule);
  background: var(--bg-elevated);
  color: var(--ink);
  cursor: pointer;
  transition: all var(--t-fast);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 8px;
}
.btn:hover { border-color: var(--rule-strong); transform: translateY(-1px); }
.btn--primary {
  background: var(--emerald);
  color: #08160d;
  border-color: var(--emerald);
  font-weight: 600;
}
.btn--primary:hover {
  background: var(--emerald-bright);
  border-color: var(--emerald-bright);
  color: #08160d;
  box-shadow: 0 0 24px var(--emerald-glow);
}
.btn--ghost { background: transparent; border-color: transparent; }
.btn--ghost:hover { background: var(--bg-elevated); border-color: transparent; }

/* ============ PILLS / TAGS ============ */
.live-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px 4px 9px;
  background: var(--signal-soft); color: var(--signal);
  font-family: var(--font-mono);
  font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(255, 90, 90, 0.3);
}
.live-pill::before {
  content: ""; width: 6px; height: 6px;
  background: var(--signal); border-radius: 50%;
  animation: pulse 1.5s ease-in-out infinite;
  box-shadow: 0 0 8px var(--signal);
}

.tag {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px 3px;
  border-radius: var(--radius-pill);
  display: inline-block;
  background: var(--bg-elevated);
  color: var(--ink-soft);
  border: 1px solid var(--rule);
}
.tag--politik  { background: rgba(255,90,90,0.12); color: var(--c-politik); border-color: rgba(255,90,90,0.25); }
.tag--branche  { background: rgba(148,163,184,0.12); color: var(--c-branche); border-color: rgba(148,163,184,0.25); }
.tag--genetik  { background: var(--emerald-tint); color: var(--emerald); border-color: rgba(61,213,139,0.3); }
.tag--anbau    { background: rgba(163,197,83,0.12); color: var(--c-anbau); border-color: rgba(163,197,83,0.3); }
.tag--recht    { background: var(--gold-soft); color: var(--gold-bright); border-color: rgba(212,163,71,0.3); }
.tag--wissen   { background: rgba(107,182,255,0.12); color: var(--c-wissen); border-color: rgba(107,182,255,0.3); }
.tag--life     { background: rgba(240,120,184,0.12); color: var(--c-life); border-color: rgba(240,120,184,0.3); }
.tag--breaking { background: var(--signal); color: white; border-color: var(--signal); }

.ki-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px 3px 7px;
  background: var(--emerald-tint);
  color: var(--emerald);
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(61,213,139,0.25);
  line-height: 1;
}
.ki-badge::before {
  content: ""; width: 5px; height: 5px;
  background: var(--emerald); border-radius: 50%;
  box-shadow: 0 0 6px var(--emerald);
}

.time-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono);
  font-size: 10.5px; color: var(--ink-faint);
  padding: 3px 9px;
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  font-variant-numeric: tabular-nums;
}

/* ============ TYPOGRAFIE ============ */
.headline {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 90, "opsz" 96;
  line-height: 0.98;
  letter-spacing: -0.035em;
  color: var(--ink);
  margin: 0;
  text-wrap: balance;
}
.headline em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.015em;
  color: var(--emerald);
}
.headline a { color: inherit; transition: color var(--t-fast); }
.headline a:hover { color: var(--emerald); }

.h-hero  { font-size: clamp(2.8rem, 6.5vw, 5.6rem); font-weight: 700; font-variation-settings: "wdth" 85, "opsz" 96; line-height: 0.95; letter-spacing: -0.045em; }
.h-xl    { font-size: clamp(2rem, 3.4vw, 2.8rem); font-weight: 600; }
.h-l     { font-size: 1.6rem; line-height: 1.02; }
.h-m     { font-size: 1.25rem; line-height: 1.1; }
.h-s     { font-size: 1.1rem; line-height: 1.15; }

.dek {
  font-family: var(--font-sans);
  font-size: 1.1rem;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
  text-wrap: pretty;
  letter-spacing: -0.005em;
  font-weight: 400;
}
.snippet { font-size: 0.93rem; line-height: 1.5; color: var(--ink-soft); margin: 0; }

.byline {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-faint);
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap;
  letter-spacing: -0.005em;
}
.byline__sep { color: var(--ink-trace); }
.byline a { color: var(--ink-soft); border-bottom: 1px solid var(--rule); padding-bottom: 1px; transition: all var(--t-fast); }
.byline a:hover { color: var(--emerald); border-color: var(--emerald); }

/* ============ MEDIA ============ */
.media {
  background: var(--bg-card);
  overflow: hidden;
  position: relative;
  border-radius: var(--radius);
  margin-bottom: 20px;
  border: 1px solid var(--rule);
}
.media--hero { aspect-ratio: 16/9; }
.media--mxn { aspect-ratio: 4/3; }
.media--wide { aspect-ratio: 21/9; }
.media--tall { aspect-ratio: 3/4; }
.media--sq  { aspect-ratio: 1/1; }
.media--xl  { aspect-ratio: 5/4; }

.media-bg-1 {
  background:
    radial-gradient(circle at 25% 30%, var(--emerald-glow), transparent 55%),
    radial-gradient(circle at 75% 65%, rgba(212,163,71,0.4), transparent 60%),
    linear-gradient(135deg, #0a1f12, #1a3a26 60%, #0f2a1a);
}
.media-bg-2 {
  background:
    radial-gradient(circle at 60% 40%, rgba(255,90,90,0.4), transparent 55%),
    linear-gradient(160deg, #1a1010, #2a1818);
}
.media-bg-3 {
  background:
    radial-gradient(ellipse at 30% 70%, rgba(212,163,71,0.55), transparent 60%),
    linear-gradient(180deg, #1c1813, #2e2620);
}
.media-bg-4 {
  background:
    radial-gradient(circle at 50% 50%, var(--emerald-glow), transparent 55%),
    linear-gradient(45deg, #0a1810, #1a3025);
}
.media-bg-5 {
  background:
    radial-gradient(circle at 70% 30%, rgba(61,213,139,0.4), transparent 60%),
    radial-gradient(circle at 20% 70%, rgba(212,163,71,0.35), transparent 55%),
    linear-gradient(180deg, #1f3a28, #0d2818);
}
.media-bg-6 {
  background:
    radial-gradient(circle at 20% 30%, rgba(167,139,250,0.45), transparent 55%),
    linear-gradient(160deg, #181820, #2a2535);
}
.media-bg-7 {
  background:
    radial-gradient(circle at 80% 80%, rgba(107,182,255,0.45), transparent 50%),
    linear-gradient(160deg, #0f2030, #1a2f3a);
}
.media-bg-8 {
  background:
    radial-gradient(circle at 30% 30%, rgba(255,90,90,0.45), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(212,163,71,0.4), transparent 50%),
    linear-gradient(45deg, #1a1010, #2a1818);
}
.media-bg-mesh {
  background:
    radial-gradient(circle at 20% 20%, rgba(61,213,139,0.6) 0%, transparent 40%),
    radial-gradient(circle at 80% 30%, rgba(167,139,250,0.4) 0%, transparent 40%),
    radial-gradient(circle at 50% 80%, rgba(212,163,71,0.45) 0%, transparent 40%),
    linear-gradient(135deg, #0a1f12, #0d1318 60%);
}

.media__caption {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 14px 18px;
  background: linear-gradient(transparent, rgba(0,0,0,0.7));
  color: rgba(255,255,255,0.95);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.01em;
  line-height: 1.3;
}
.media__overlay {
  position: absolute; top: 14px; left: 14px;
  display: flex; gap: 6px; align-items: center;
}
.media__overlay .tag {
  background: rgba(10, 10, 11, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-color: rgba(255,255,255,0.15);
  color: var(--ink);
}

/* ============ LAYOUT ============ */
.wrap { max-width: 1320px; margin: 0 auto; padding: 0 24px; }

/* ============ HERO ============ */
.hero { padding: 56px 0 64px; }
.hero__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 56px;
  align-items: start;
}
.hero__lead .h-hero { margin: 18px 0 20px; }
.hero__lead .dek { margin: 20px 0; max-width: 56ch; font-size: 1.18rem; line-height: 1.55; }
.hero__lead .byline { margin-top: 22px; padding-top: 22px; border-top: 1px solid var(--rule); }
.hero__lead-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 4px; }

.hero__side { display: flex; flex-direction: column; gap: 24px; padding-left: 36px; border-left: 1px solid var(--rule); }
.hero__side-item { padding-bottom: 24px; border-bottom: 1px solid var(--rule); transition: opacity var(--t-mid); }
.hero__side-item:last-child { border-bottom: 0; padding-bottom: 0; }
.hero__side-item .tag { margin-bottom: 12px; }
.hero__side-item .h-l, .hero__side-item .h-m { margin-bottom: 8px; }
.hero__side-item .byline { margin-top: 10px; font-size: 11px; }

/* ============ SECTIONS ============ */
.section { padding: 72px 0; border-top: 1px solid var(--rule); }
.section--flush { border-top: 0; padding-top: 0; }
.section-head {
  display: flex; align-items: end; justify-content: space-between;
  margin-bottom: 36px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--rule);
  gap: 16px; flex-wrap: wrap;
}
.section-head__left { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.section-head__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 85, "opsz" 96;
  font-size: 2.6rem;
  line-height: 0.95;
  letter-spacing: -0.045em;
  margin: 0;
  color: var(--ink);
}
.section-head__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--emerald);
}
.section-head__count {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-faint);
  background: var(--bg-elevated);
  padding: 5px 11px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--rule);
  display: inline-flex; align-items: center; gap: 7px;
  align-self: center;
}
.section-head__count::before {
  content: ""; width: 6px; height: 6px;
  background: var(--emerald);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--emerald);
}
.section-head__more {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-soft);
  border-bottom: 1px solid var(--rule);
  padding-bottom: 3px;
  transition: all var(--t-fast);
}
.section-head__more:hover { color: var(--emerald); border-color: var(--emerald); }

.section-head__filters { display: flex; gap: 6px; }
.section-head__filters .chip {
  font-family: var(--font-sans);
  font-size: 12.5px;
  padding: 7px 13px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--rule);
  color: var(--ink-soft);
  background: transparent;
  cursor: pointer;
  transition: all var(--t-fast);
}
.section-head__filters .chip.is-active {
  background: var(--ink); color: var(--bg); border-color: var(--ink);
}
.section-head__filters .chip:hover:not(.is-active) { background: var(--bg-elevated); }

/* ============ REDAKTIONS-LIVE-STRIP ============ */
.live-strip {
  background: linear-gradient(135deg, var(--bg-elevated), var(--bg-card));
  border: 1px solid var(--rule);
  border-radius: var(--radius-lg);
  padding: 28px 36px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 36px;
  position: relative;
  overflow: hidden;
}
.live-strip::before {
  content: "";
  position: absolute; top: -50%; left: -10%;
  width: 60%; height: 200%;
  background: radial-gradient(circle, var(--emerald-glow), transparent 60%);
  filter: blur(60px);
  pointer-events: none;
}
.live-strip__title { display: flex; flex-direction: column; gap: 6px; position: relative; }
.live-strip__title strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 90, "opsz" 96;
  font-size: 1.7rem;
  color: var(--ink);
  letter-spacing: -0.035em;
  display: flex; align-items: center; gap: 12px;
}
.live-strip__title strong em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--emerald);
  letter-spacing: -0.015em;
}
.live-strip__title small {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.02em;
  display: flex; align-items: center; gap: 6px;
}
.live-strip__title small::before {
  content: ""; width: 6px; height: 6px;
  background: var(--emerald); border-radius: 50%;
  box-shadow: 0 0 8px var(--emerald);
  animation: pulse 2s ease-in-out infinite;
}
.live-strip__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  padding-left: 36px;
  border-left: 1px solid var(--rule);
  position: relative;
}
.live-strip__stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  min-height: 70px;
}
.live-strip__stat strong {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: "wdth" 85, "opsz" 96;
  font-size: 2.4rem;
  color: var(--ink);
  display: block;
  line-height: 1;
  letter-spacing: -0.045em;
  font-feature-settings: "tnum";
  margin-bottom: 8px;
}
.live-strip__stat strong em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--emerald);
}
.live-strip__stat strong sup { font-size: 0.5em; vertical-align: top; opacity: 0.7; }
.live-strip__stat small {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: block;
  line-height: 1.35;
  text-wrap: balance;
}

/* ============ BENTO GRID ============ */
.bento {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(180px, auto);
  gap: 20px;
}
.bento__item {
  display: flex; flex-direction: column; gap: 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 22px;
  transition: all var(--t-mid);
  position: relative;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
}
.bento__item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lift);
  border-color: var(--rule-strong);
}
.bento__item .tag { align-self: flex-start; }
.bento__item .byline { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--rule); }

.bento__item--feature {
  grid-column: span 2; grid-row: span 2;
  padding: 0;
  background: var(--bg-card);
  position: relative;
  overflow: hidden;
}
.bento__item--feature .bento__media {
  aspect-ratio: 16/10;
  margin: 0;
  border-radius: 0;
  border: 0;
  border-bottom: 1px solid var(--rule);
}
.bento__item--feature .bento__body { padding: 28px; display: flex; flex-direction: column; gap: 14px; flex: 1; }
.bento__item--feature:hover { transform: translateY(-4px); }

.bento__item--accent {
  background: linear-gradient(135deg, var(--emerald-tint), var(--bg-elevated) 60%);
  border-color: rgba(61,213,139,0.25);
}
.bento__item--accent::before {
  content: ""; position: absolute; top: 0; right: 0;
  width: 140px; height: 140px;
  background: radial-gradient(circle, var(--emerald-glow), transparent 70%);
  filter: blur(20px);
}
.bento__item--gold {
  background: linear-gradient(135deg, var(--gold-soft), var(--bg-elevated) 60%);
  border-color: rgba(212,163,71,0.25);
}
.bento__item--violet {
  background: linear-gradient(135deg, var(--violet-soft), var(--bg-elevated) 60%);
  border-color: rgba(167,139,250,0.25);
}

.bento__media {
  aspect-ratio: 4/3;
  border-radius: var(--radius-sm);
  position: relative; overflow: hidden;
  border: 1px solid var(--rule);
}

/* ============ CARDS ============ */
.card { display: flex; flex-direction: column; gap: 12px; text-decoration: none; color: inherit; transition: all var(--t-mid); }
.card:hover .headline { color: var(--emerald); }
.card:hover .media { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.card .tag { align-self: flex-start; }
.card .media { margin: 0; transition: all var(--t-mid); }
.card .byline { margin-top: 4px; }
.card .snippet { margin: 4px 0 0; }

.card-row-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.card-row-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }

/* ============ SPLIT ============ */
.split { display: grid; grid-template-columns: 1fr 340px; gap: 56px; }
.split__main { display: flex; flex-direction: column; gap: 48px; }
.split__side { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 120px; align-self: start; }

/* ============ WIDGETS ============ */
.widget {
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
}
.widget__label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin: 0 0 14px;
  display: flex; align-items: center; gap: 8px;
}
.widget__label::after { content: ""; flex: 1; height: 1px; background: var(--rule); }

/* === STAT WIDGET === */
.stat-widget {
  background: linear-gradient(135deg, var(--emerald-tint), var(--bg-elevated) 70%);
  border-color: rgba(61,213,139,0.25);
}
.stat-widget::before {
  content: ""; position: absolute; top: -50px; right: -50px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, var(--emerald-glow), transparent 65%);
  filter: blur(30px);
  pointer-events: none;
}
.stat-widget__big {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: "wdth" 80, "opsz" 96;
  font-size: 5rem;
  line-height: 0.9;
  letter-spacing: -0.06em;
  color: var(--ink);
  margin: 0;
  font-feature-settings: "tnum";
  position: relative;
}
.stat-widget__big em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--emerald);
}
.stat-widget__big sup {
  font-size: 1.5rem;
  vertical-align: top;
  margin-left: 4px;
  position: relative;
  top: 0.4em;
  color: var(--ink-soft);
  font-weight: 500;
  font-variation-settings: "wdth" 100, "opsz" 36;
}
.stat-widget__caption {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  color: var(--ink-soft);
  margin: 10px 0 14px;
  line-height: 1.45;
  position: relative;
}
.stat-widget__delta {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 600;
  color: var(--emerald);
  background: var(--emerald-tint);
  padding: 5px 10px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(61,213,139,0.3);
  position: relative;
}
.stat-widget__source {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
  margin-top: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  position: relative;
}

/* === WETTER === */
.weather-widget {
  background: linear-gradient(180deg, var(--emerald-tint), var(--bg-elevated) 80%);
  border-color: rgba(61,213,139,0.25);
}
.weather-widget__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.weather-widget__icon { font-size: 2.6rem; line-height: 1; filter: drop-shadow(0 0 12px var(--emerald-glow)); }
.weather-widget__status {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 90;
  font-size: 1.65rem;
  line-height: 1.05;
  color: var(--ink);
  margin: 0;
  letter-spacing: -0.035em;
}
.weather-widget__status em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--emerald);
}
.weather-widget__sub {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
  margin: 6px 0 0;
  line-height: 1.5;
  letter-spacing: -0.005em;
}
.weather-widget__stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 10px; margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
}
.weather-widget__stat strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 85;
  font-size: 1.35rem;
  display: block;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 4px;
  letter-spacing: -0.035em;
}
.weather-widget__stat small {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* === NEWSLETTER === */
.newsletter-widget {
  background: linear-gradient(135deg, var(--bg-card), var(--bg-deep));
  border: 1px solid var(--rule-strong);
  position: relative;
}
.newsletter-widget::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 100% 0%, var(--emerald-glow), transparent 50%);
  filter: blur(40px);
  pointer-events: none;
}
.newsletter-widget h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 90;
  font-size: 1.7rem;
  line-height: 1.02;
  margin: 0 0 10px;
  letter-spacing: -0.035em;
  position: relative;
}
.newsletter-widget h3 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--emerald);
}
.newsletter-widget p { font-size: 0.94rem; color: var(--ink-soft); margin: 0 0 16px; line-height: 1.5; position: relative; }
.newsletter-widget__form { display: flex; flex-direction: column; gap: 12px; position: relative; }
.newsletter-widget__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: stretch;
}
.newsletter-widget__form input[type="email"] {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--rule);
  color: var(--ink);
  padding: 11px 14px;
  font-family: var(--font-sans);
  font-size: 13.5px;
  border-radius: var(--radius-pill);
  transition: all var(--t-fast);
  min-width: 0;
}
.newsletter-widget__form input::placeholder { color: var(--ink-trace); }
.newsletter-widget__form input:focus { outline: none; border-color: var(--emerald); box-shadow: 0 0 0 3px var(--emerald-soft); }
.newsletter-widget__form button {
  background: var(--emerald);
  color: #08160d;
  border: 0;
  padding: 11px 18px;
  font-family: var(--font-sans);
  font-size: 13.5px;
  font-weight: 600;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: all var(--t-fast);
  white-space: nowrap;
}
.newsletter-widget__form button:hover:not(:disabled) {
  background: var(--emerald-bright);
  box-shadow: 0 0 20px var(--emerald-glow);
}
.newsletter-widget__form button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  filter: grayscale(40%);
}
.newsletter-widget__consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.5;
  cursor: pointer;
}
.newsletter-widget__consent input[type="checkbox"] {
  margin-top: 3px;
  accent-color: var(--emerald);
  flex-shrink: 0;
  width: 15px; height: 15px;
}
.newsletter-widget__consent a { color: var(--emerald); border-bottom: 1px solid var(--emerald-deep); }
.newsletter-widget__legal {
  margin-top: 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
  line-height: 1.5;
  position: relative;
}
.newsletter-widget__legal a { color: var(--ink-soft); border-bottom: 1px solid var(--rule); padding-bottom: 1px; }
.newsletter-widget__readers {
  display: flex; align-items: center; gap: 10px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
  position: relative;
}
.avatar-stack { display: flex; }
.avatar-stack span {
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 2px solid var(--bg-card);
  margin-left: -6px;
}
.avatar-stack span:first-child { margin-left: 0; }
.avatar-stack span:nth-child(1) { background: linear-gradient(135deg, #3dd58b, #1d8b54); }
.avatar-stack span:nth-child(2) { background: linear-gradient(135deg, #d4a347, #b8862f); }
.avatar-stack span:nth-child(3) { background: linear-gradient(135deg, #6bb6ff, #36577a); }
.avatar-stack span:nth-child(4) { background: linear-gradient(135deg, #f078b8, #a0407a); }

/* === TRENDING with Sparklines === */
.trending-widget ol {
  list-style: none; padding: 0; margin: 0;
  counter-reset: trending;
  display: flex; flex-direction: column; gap: 16px;
}
.trending-widget li {
  counter-increment: trending;
  display: grid;
  grid-template-columns: 24px 1fr 54px;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--rule);
  align-items: start;
}
.trending-widget li:last-child { border-bottom: 0; padding-bottom: 0; }
.trending-widget li::before {
  content: counter(trending, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--emerald);
  font-weight: 600;
  line-height: 1.4;
  padding-top: 2px;
}
.trending-widget a {
  font-family: var(--font-display);
  font-weight: 500;
  font-variation-settings: "wdth" 95;
  font-size: 1.02rem;
  line-height: 1.15;
  color: var(--ink);
  letter-spacing: -0.02em;
  display: block;
}
.trending-widget a:hover { color: var(--emerald); }
.trending-widget small {
  display: block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--ink-faint);
  margin-top: 5px;
  letter-spacing: 0.02em;
}
.sparkline { width: 54px; height: 26px; align-self: center; }
.sparkline path { fill: none; stroke-width: 1.5; }
.sparkline--up path { stroke: var(--emerald); filter: drop-shadow(0 0 4px var(--emerald-glow)); }
.sparkline--down path { stroke: var(--signal); }
.sparkline--flat path { stroke: var(--ink-faint); }

/* === KI WIDGET === */
.ki-widget {
  background: linear-gradient(135deg, var(--emerald-tint), var(--bg-card) 70%);
  border-color: rgba(61,213,139,0.25);
  position: relative;
  overflow: hidden;
}
.ki-widget::before {
  content: ""; position: absolute; bottom: -40px; right: -40px;
  width: 160px; height: 160px;
  background: radial-gradient(circle, var(--emerald-glow), transparent 70%);
  filter: blur(20px);
}
.ki-widget__head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; position: relative; }
.ki-widget__head strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 90;
  font-size: 1.5rem;
  color: var(--ink);
  letter-spacing: -0.035em;
  line-height: 1;
}
.ki-widget__head strong em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--emerald);
}
.ki-widget p { margin: 0; font-size: 0.93rem; color: var(--ink-soft); line-height: 1.5; position: relative; }
.ki-widget a { color: var(--emerald); border-bottom: 1px solid var(--emerald); padding-bottom: 1px; font-weight: 500; }
.ki-widget__stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 10px; margin-top: 16px; padding-top: 16px;
  border-top: 1px solid var(--rule);
  position: relative;
}
.ki-widget__stat strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 85;
  font-size: 1.45rem;
  color: var(--ink);
  display: block;
  line-height: 1;
  letter-spacing: -0.035em;
}
.ki-widget__stat small {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 4px;
  display: block;
}

/* ============ AD SLOT ============ */
.ad-slot {
  background: var(--bg-elevated);
  border: 1px solid rgba(212,163,71,0.3);
  border-radius: var(--radius);
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
}
.ad-slot::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 100% 50%, var(--gold-soft), transparent 60%);
  pointer-events: none;
}
.ad-slot__tag {
  position: absolute;
  top: -10px; left: 24px;
  background: var(--gold);
  color: #1a1310;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: var(--radius-pill);
  font-weight: 700;
}
.ad-slot h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 95;
  font-size: 1.5rem;
  letter-spacing: -0.035em;
  margin: 0 0 8px;
  line-height: 1.05;
  position: relative;
}
.ad-slot h3 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--gold-bright);
}
.ad-slot p { margin: 0 0 14px; font-size: 0.95rem; color: var(--ink-soft); line-height: 1.5; position: relative; }
.ad-slot__cta {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--gold-bright);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 2px;
  position: relative;
}
.ad-slot__cta:hover { color: var(--gold); }
.ad-slot__price {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: "wdth" 75;
  font-size: 5rem;
  line-height: 0.95;
  letter-spacing: -0.07em;
  color: var(--gold-bright);
  position: relative;
}
.ad-slot__price em { font-family: var(--font-serif); font-style: italic; font-weight: 400; }

/* ============ FEATURE STRIP ============ */
.feature-strip {
  background: var(--bg-card);
  color: var(--ink);
  border-radius: var(--radius-lg);
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--rule);
}
.feature-strip__mesh {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(61,213,139,0.45) 0%, transparent 45%),
    radial-gradient(circle at 80% 30%, rgba(167,139,250,0.35) 0%, transparent 45%),
    radial-gradient(circle at 50% 80%, rgba(212,163,71,0.4) 0%, transparent 45%),
    radial-gradient(circle at 90% 90%, rgba(255,90,90,0.25) 0%, transparent 35%);
  filter: blur(60px);
  pointer-events: none;
  animation: mesh-shift 20s ease-in-out infinite;
}
@keyframes mesh-shift {
  0%, 100% { transform: scale(1) rotate(0deg); }
  50% { transform: scale(1.15) rotate(8deg); }
}
.feature-strip__inner { padding: 64px 64px 64px 64px; position: relative; z-index: 2; }
.feature-strip__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 20px;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px;
  background: rgba(0,0,0,0.4);
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  backdrop-filter: blur(12px);
}
.feature-strip__label::before {
  content: ""; width: 6px; height: 6px;
  background: var(--gold-bright); border-radius: 50%;
  box-shadow: 0 0 10px var(--gold-bright);
}
.feature-strip h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-variation-settings: "wdth" 85, "opsz" 96;
  font-size: clamp(2.4rem, 4.2vw, 3.4rem);
  letter-spacing: -0.045em;
  line-height: 1;
  margin: 0 0 20px;
  color: var(--ink);
  text-wrap: balance;
}
.feature-strip h2 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--emerald);
  letter-spacing: -0.02em;
}
.feature-strip p {
  font-family: var(--font-sans);
  font-size: 1.1rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 28px;
  max-width: 44ch;
}
.feature-strip__media {
  position: relative; z-index: 2;
  background:
    radial-gradient(circle at 30% 40%, rgba(212,163,71,0.5), transparent 50%),
    radial-gradient(circle at 70% 60%, rgba(45,213,139,0.5), transparent 50%),
    linear-gradient(135deg, #0a1f12, #0d1318 70%);
  min-height: 440px;
  border-left: 1px solid var(--rule);
}
.feature-strip__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--emerald);
  color: #08160d;
  padding: 14px 22px;
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 14.5px;
  transition: all var(--t-mid);
}
.feature-strip__cta:hover {
  background: var(--emerald-bright);
  color: #08160d;
  transform: translateY(-2px);
  box-shadow: 0 0 32px var(--emerald-glow);
}
.feature-strip__cta::after { content: "\2192"; transition: transform var(--t-fast); }
.feature-strip__cta:hover::after { transform: translateX(4px); }
.feature-strip__meta {
  position: absolute; bottom: 28px; left: 64px;
  display: flex; align-items: center; gap: 16px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-faint);
  z-index: 2;
}
.feature-strip__meta strong { color: var(--ink); font-weight: 500; }

/* ============ FOOTER ============ */
.site-footer {
  background: var(--bg-elevated);
  border-top: 1px solid var(--rule);
  padding: 80px 0 40px;
  margin-top: 96px;
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: ""; position: absolute; top: -100px; left: 50%;
  transform: translateX(-50%);
  width: 1200px; height: 400px;
  background: radial-gradient(circle, var(--emerald-glow), transparent 60%);
  filter: blur(80px);
  pointer-events: none;
}
.site-footer__inner { max-width: 1320px; margin: 0 auto; padding: 0 24px; position: relative; }
.site-footer__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 40px; border-bottom: 1px solid var(--rule); margin-bottom: 28px; }
.site-footer__brand h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-variation-settings: "wdth" 95, "opsz" 96;
  font-size: 2.2rem;
  margin: 0 0 12px;
  letter-spacing: -0.04em;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 4px;
}
.site-footer__brand p {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0 0 18px;
  max-width: 38ch;
  line-height: 1.6;
}
.site-footer__brand-meta {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--ink-faint); letter-spacing: 0.04em;
  display: flex; gap: 14px; flex-wrap: wrap;
}
.site-footer__col h4 { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-faint); margin: 0 0 16px; font-weight: 500; }
.site-footer__col ul { list-style: none; padding: 0; margin: 0; }
.site-footer__col li { font-size: 14px; margin-bottom: 10px; color: var(--ink-soft); }
.site-footer__col a:hover { color: var(--emerald); }
.site-footer__bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; font-family: var(--font-mono); font-size: 11px; color: var(--ink-faint); letter-spacing: 0.02em; }
.site-footer__bottom-meta { display: flex; gap: 20px; flex-wrap: wrap; align-items: center; }
.site-footer__theme-toggle {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 13px;
  background: var(--bg-card);
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: all var(--t-fast);
}
.site-footer__theme-toggle:hover { border-color: var(--rule-strong); }

/* ============ RESPONSIVE ============ */
@media (max-width: 1100px) {
  .hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .hero__side { padding-left: 0; border-left: 0; border-top: 1px solid var(--rule); padding-top: 32px; }
  .card-row-3, .card-row-4 { grid-template-columns: repeat(2, 1fr); }
  .split { grid-template-columns: 1fr; }
  .split__side { position: static; }
  .site-footer__top { grid-template-columns: 1fr 1fr 1fr; }
  .feature-strip { grid-template-columns: 1fr; }
  .feature-strip__media { min-height: 280px; border-left: 0; border-top: 1px solid var(--rule); }
  .feature-strip__meta { position: static; padding: 0 64px 40px; }
  .site-header__inner { grid-template-columns: auto auto; gap: 16px; }
  .nav { display: none; }
  .bento { grid-template-columns: repeat(2, 1fr); }
  .bento__item--feature { grid-column: span 2; grid-row: auto; }
  .live-strip { grid-template-columns: 1fr; gap: 20px; }
  .live-strip__stats { padding-left: 0; border-left: 0; padding-top: 20px; border-top: 1px solid var(--rule); }
}

@media (max-width: 600px) {
  .topstripe__date { display: none; }
  .h-hero { font-size: 2.6rem; }
  .card-row-3, .card-row-4 { grid-template-columns: 1fr; }
  .site-footer__top { grid-template-columns: 1fr 1fr; }
  .section-head__title { font-size: 1.9rem; }
  .feature-strip__inner { padding: 36px 28px 0; }
  .feature-strip__meta { padding: 16px 28px 28px; flex-wrap: wrap; }
  .feature-strip__media { min-height: 220px; }
  .wordmark { font-size: 24px; }
  .header-actions .btn--ghost { display: none; }
  .menu-btn { display: inline-flex; }
  .bento { grid-template-columns: 1fr; }
  .bento__item--feature { grid-column: auto; }
  .live-strip__stats { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .stat-widget__big { font-size: 4rem; }
  .feature-strip h2 { font-size: 2.2rem; }
}


/* ============ EMPTY-STATE ============ */
.empty-state {
  background: linear-gradient(135deg, var(--bg-elevated), var(--bg-card));
  border: 1px dashed var(--rule);
  border-radius: var(--radius-lg);
  padding: 56px 40px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}
.empty-state .headline {
  margin: 0;
  letter-spacing: -0.02em;
}
.empty-state p {
  color: var(--ink-soft);
  max-width: 60ch;
  font-size: 1.02rem;
  line-height: 1.6;
  margin: 0;
}
.empty-state--inline {
  padding: 36px 28px;
  text-align: left;
  align-items: flex-start;
  margin-bottom: 32px;
}

/* ============ LIVE-STRIP MOBILE FIX ============ */
@media (max-width: 768px) {
  .live-strip {
    padding: 24px 22px;
    text-align: left;
  }
  .live-strip > .btn {
    justify-self: start;
  }
  .live-strip__title strong {
    font-size: 1.45rem;
    text-wrap: balance;
  }
}

/* ============ GHOST-SPECIFIC ============ */

.wrap--narrow { max-width: 760px; }

/* Ghost-rendered Markdown-Content im Artikel */
.gh-content {
  font-family: var(--font-sans);
  font-size: 1.13rem;
  line-height: 1.65;
  color: var(--ink);
  max-width: 70ch;
  margin: 32px auto;
}
.gh-content p { margin: 0 0 1.2em; }
.gh-content a {
  color: var(--emerald);
  border-bottom: 1px solid rgba(61,213,139,0.35);
  padding-bottom: 1px;
  transition: all var(--t-fast);
}
.gh-content a:hover { color: var(--emerald-bright); border-color: var(--emerald-bright); }
.gh-content h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.95rem;
  letter-spacing: -0.035em;
  margin: 2.2em 0 0.6em;
  line-height: 1.1;
}
.gh-content h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.45rem;
  letter-spacing: -0.025em;
  margin: 1.8em 0 0.5em;
  line-height: 1.15;
}
.gh-content h4 { font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; margin: 1.6em 0 0.4em; letter-spacing: -0.02em; }
.gh-content blockquote {
  border-left: 3px solid var(--emerald);
  padding: 6px 0 6px 20px;
  margin: 1.4em 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.3rem;
  line-height: 1.4;
  color: var(--ink);
}
.gh-content ul, .gh-content ol { padding-left: 1.4em; margin: 0 0 1.2em; }
.gh-content li { margin-bottom: 0.4em; }
.gh-content img, .gh-content figure { max-width: 100%; height: auto; border-radius: var(--radius-sm); margin: 1.4em 0; }
.gh-content figcaption {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--ink-faint);
  margin-top: 6px;
  text-align: center;
}
.gh-content hr { border: 0; border-top: 1px solid var(--rule); margin: 2em 0; }
.gh-content code {
  background: var(--bg-elevated);
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 0.92em;
  color: var(--emerald);
}
.gh-content pre {
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 0.9rem;
  line-height: 1.5;
  margin: 1.4em 0;
}
.gh-content pre code { background: transparent; padding: 0; color: var(--ink); }

/* Ghost-Editor Card-Width: wide und full breechen aus .gh-content's 70ch-Container aus */
.gh-content .kg-width-wide,
.kg-width-wide {
  position: relative;
  width: min(100vw, 1100px);
  max-width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);
}
.gh-content .kg-width-full,
.kg-width-full {
  position: relative;
  width: 100vw;
  max-width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);
}
.kg-width-wide img,
.kg-width-full img { width: 100%; height: auto; display: block; }

/* Single-Post-Header */
.post--single { padding: 56px 0 24px; }
.post__head { max-width: 70ch; margin: 0 auto 24px; text-align: left; }
.post__head .tag, .post__head .post__tags { margin-bottom: 18px; display: flex; gap: 6px; flex-wrap: wrap; }
.post__head .h-hero { margin: 0 0 18px; }
.post__head .dek { margin: 0 0 20px; }
.post__head .byline { padding-bottom: 18px; border-bottom: 1px solid var(--rule); }
.post__cover { max-width: 1100px; margin: 32px auto; }

/* Quellen-Box am Post-Ende */
.post-sources {
  max-width: 70ch;
  margin: 56px auto 32px;
  padding: 24px 28px;
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  position: relative;
}
.post-sources h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.25rem;
  letter-spacing: -0.025em;
  margin: 0 0 14px;
  line-height: 1.1;
  display: flex; align-items: center; gap: 10px;
}
.post-sources h2::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--emerald);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--emerald);
}
.post-sources__body {
  font-family: var(--font-mono);
  font-size: 0.86rem;
  line-height: 1.6;
  color: var(--ink-soft);
}
.post-sources__body ul, .post-sources__body ol { padding-left: 1.2em; margin: 0; }
.post-sources__body li { margin-bottom: 0.5em; }
.post-sources__body a { color: var(--emerald); border-bottom: 1px solid rgba(61,213,139,0.3); }

/* KI-Disclaimer am Artikelende */
.ki-disclaimer {
  max-width: 70ch;
  margin: 24px auto 0;
  padding: 16px 20px;
  background: var(--emerald-tint);
  border: 1px solid rgba(61,213,139,0.2);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--ink-soft);
  line-height: 1.55;
}
.ki-disclaimer a { color: var(--emerald); border-bottom: 1px solid var(--emerald); padding-bottom: 1px; }

/* Pagination */
.pagination {
  display: flex; justify-content: center; gap: 12px;
  margin-top: 48px;
  font-family: var(--font-mono);
  font-size: 13px;
}
.pagination a {
  padding: 10px 16px;
  border: 1px solid var(--rule);
  border-radius: var(--radius-pill);
  color: var(--ink-soft);
}
.pagination a:hover { border-color: var(--rule-strong); color: var(--ink); }
.pagination .pagination__current {
  background: var(--bg-elevated);
  color: var(--ink-faint);
  padding: 10px 16px;
}

/* Page (statisch) */
.page { padding: 48px 0; }
.page__head { max-width: 70ch; margin: 0 auto 24px; }

