/* ============================================================
   fdhz.de  —  brutalist street / akte / blaulicht
   ============================================================ */

:root{
  --bg:        #0b0b0c;
  --bg-2:      #111114;
  --ink:       #ededea;
  --ink-dim:   #8a8a85;
  --paper:     #e7e4db;
  --paper-ink: #1a1a1a;
  --red:       #ff1f1f;
  --red-deep:  #b51212;
  --blue:      #1f7bff;
  --yellow:    #f5d400;
  --line:      #1f1f22;

  --display: "Archivo Black", "Bebas Neue", Impact, system-ui, sans-serif;
  --type:    "Special Elite", ui-monospace, monospace;
  --mono:    "JetBrains Mono", ui-monospace, monospace;
  --sans:    "Bebas Neue", "Archivo Black", system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;min-width:0}
html,body{
  background:var(--bg);color:var(--ink);font-family:var(--type);line-height:1.55;
  overflow-x:clip;           /* clip statt hidden: erlaubt position:sticky in Childs */
  -webkit-text-size-adjust:100%;
}
html{scroll-behavior:smooth}
body{width:100%;max-width:100vw}
a,button{color:inherit;text-decoration:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
button{font:inherit}
img{max-width:100%;display:block}

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

/* ----- Background Atmosphäre ------------------------------- */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(31,123,255,.10), transparent 60%),
    radial-gradient(900px 700px at -10% 110%, rgba(255,31,31,.10), transparent 55%),
    repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0 1px, transparent 1px 3px);
  pointer-events:none;
  z-index:-2;
}
body::after{
  /* Beton‑Textur via SVG */
  content:"";
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.18;
  mix-blend-mode:overlay;
  pointer-events:none;
  z-index:-1;
}

/* ----- Grain Overlay (animiertes Rauschen) ----------------- */
.grain{
  position:fixed;inset:-50%;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' seed='7'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/></svg>");
  opacity:.08;
  pointer-events:none;
  z-index:40;
  animation:grain 1.6s steps(6) infinite;
}
@keyframes grain{
  0%  {transform:translate(0,0)}
  20% {transform:translate(-2%,1%)}
  40% {transform:translate(1%,-2%)}
  60% {transform:translate(-1%,2%)}
  80% {transform:translate(2%,1%)}
  100%{transform:translate(0,0)}
}

/* ----- Blaulicht Strobe ------------------------------------ */
.strobe{position:fixed;inset:0;pointer-events:none;z-index:1;mix-blend-mode:screen}
.strobe span{
  position:absolute;top:-40%;width:140vmax;height:140vmax;border-radius:50%;
  filter:blur(90px);opacity:0;
}
.strobe-blue{left:-40%;background:radial-gradient(circle,var(--blue),transparent 55%);animation:blue 4.5s infinite}
.strobe-red {right:-40%;background:radial-gradient(circle,var(--red),transparent 55%);animation:red  4.5s infinite}
@keyframes blue{
  0%,39%  {opacity:0}
  40%,49% {opacity:.25}
  50%,100%{opacity:0}
}
@keyframes red{
  0%,89%  {opacity:0}
  90%,99% {opacity:.25}
  100%    {opacity:0}
}

/* ----- Absperrband ----------------------------------------- */
.tape{
  position:fixed;left:-5%;right:-5%;
  background:var(--yellow);
  color:#000;
  font-family:var(--display);
  font-size:14px;letter-spacing:.12em;
  padding:10px 0;
  white-space:nowrap;overflow:hidden;
  z-index:30;
  border-top:2px solid #000;border-bottom:2px solid #000;
  transform:rotate(-2deg);
  max-width:110vw;                   /* niemals breiter als Viewport + etwas */
}
.tape-top{top:20px}
.tape span{display:inline-block;padding-right:40px;animation:slide 24s linear infinite}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ----- NAV ------------------------------------------------- */
.nav{
  position:relative;z-index:5;
  display:flex;justify-content:space-between;align-items:center;
  padding:72px 40px 0;
}
.brand{display:flex;align-items:baseline;gap:10px;font-family:var(--mono);font-size:13px}
.brand-mark{
  background:var(--red);color:#fff;padding:4px 8px;font-weight:700;letter-spacing:.1em;
  box-shadow:3px 3px 0 #000;
  /* Button-Reset */
  border:none;font-family:inherit;font-size:inherit;
  cursor:pointer;user-select:none;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  transition:transform .08s ease;
}
.brand-mark:hover,.brand-mark:focus-visible{outline:none;filter:brightness(1.1)}
.brand-mark:active{transform:translate(1px,1px)}
.brand-mark.tap-pulse{transform:scale(1.18)}
.brand-sep{color:var(--ink-dim)}
.brand-name{font-family:var(--display);letter-spacing:.05em;text-transform:uppercase}

.nav-links{display:flex;gap:22px;font-family:var(--mono);font-size:12.5px}
.nav-links a{
  color:var(--ink-dim);
  padding-bottom:4px;border-bottom:1px solid transparent;transition:.2s;
  text-transform:lowercase;letter-spacing:.04em;
}
.nav-links a:hover{color:var(--red);border-color:var(--red)}

/* ----- HERO ------------------------------------------------ */
.hero{
  min-height:100vh;
  min-height:100svh;           /* iOS: stabile Höhe ohne URL-Leisten-Spring */
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:80px 40px 40px;position:relative;
}
.hero-meta{
  font-family:var(--mono);font-size:12px;color:var(--ink-dim);
  margin-bottom:28px;letter-spacing:.08em;
}
.hero-meta .blink{color:var(--red);animation:blink 1s infinite}
@keyframes blink{50%{opacity:0}}

.title{
  font-family:var(--display);
  font-size:clamp(72px, 22vw, 360px);
  line-height:.82;
  letter-spacing:-.03em;
  margin-left:-.04em;
  position:relative;
  display:flex;flex-wrap:wrap;
  max-width:100%;
  word-break:break-all;        /* notfalls F D \n H Z auf schmalen screens */
}
.title span{
  display:inline-block;
  position:relative;
  color:var(--ink);
  text-shadow:
    6px 0 var(--red),
    -6px 0 var(--blue);
  animation:jitter 7s infinite;
}
.title span:nth-child(2){animation-delay:.3s}
.title span:nth-child(3){animation-delay:.6s}
.title span:nth-child(4){animation-delay:.9s}
@keyframes jitter{
  0%,92%,100%{transform:translate(0,0)}
  93%{transform:translate(-3px,2px) skewX(-3deg)}
  95%{transform:translate(4px,-1px) skewX(2deg)}
  97%{transform:translate(-2px,1px)}
}

.hero-sub{
  margin-top:28px;max-width:820px;width:100%;
  font-family:var(--type);font-size:clamp(16px,1.6vw,22px);
  color:var(--ink-dim);
  overflow-wrap:break-word;
}
.hero-sub .strike{display:block;text-decoration:line-through;text-decoration-color:var(--red);text-decoration-thickness:3px}
.hero-sub .truth{
  display:inline-block;margin-top:10px;
  font-family:var(--display);
  color:var(--ink);font-size:clamp(20px,2.2vw,32px);
  letter-spacing:.02em;text-transform:uppercase;
  background:linear-gradient(180deg,transparent 60%, var(--red) 60% 92%, transparent 92%);
  padding:0 6px;
  max-width:100%;
}

.hero-scroll{
  position:absolute;bottom:32px;left:40px;
  font-family:var(--mono);font-size:11px;color:var(--ink-dim);letter-spacing:.3em;
  animation:drift 2.4s ease-in-out infinite;
}
@keyframes drift{50%{transform:translateY(6px)}}

/* ----- SECTIONS generisch ---------------------------------- */
.section{
  padding:140px 40px;position:relative;z-index:2;
  border-top:1px solid var(--line);
  max-width:100vw;overflow-x:clip;             /* kein horizontaler Scroll durch schräge Boxen */
}
.section-head{display:flex;align-items:baseline;gap:22px;margin-bottom:56px;flex-wrap:wrap;max-width:100%}
.section-num{
  font-family:var(--mono);color:var(--red);font-size:13px;letter-spacing:.24em;
  border-left:3px solid var(--red);padding-left:12px;
}
.section h2{
  font-family:var(--display);
  font-size:clamp(36px,6vw,84px);
  line-height:.95;letter-spacing:-.01em;
  text-transform:uppercase;
  overflow-wrap:break-word;
  word-break:break-word;
  max-width:100%;
  hyphens:auto;
}

/* ----- § 01 Bedeutung -------------------------------------- */
.bedeutung{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:60px;
}
.bedeutung .section-head{grid-column:1/-1}

.decode{
  grid-column:1;
  font-family:var(--display);
  font-size:clamp(40px,6vw,88px);
  line-height:1;
}
.decode-row{
  display:flex;align-items:baseline;gap:24px;
  padding:18px 0;border-bottom:1px dashed #2a2a2e;
}
.decode-row .letter{color:var(--red);min-width:1.2em}
.decode-row .dash{color:var(--ink-dim);font-family:var(--mono);font-size:.4em;transform:translateY(-.4em)}
.decode-row .word{letter-spacing:-.01em}

.lead{
  grid-column:1;
  margin-top:30px;max-width:640px;
  font-size:17px;color:#cfcfc9;
}
.lead b{color:var(--red)}

.akte{
  grid-column:2;
  position:relative;
  background:
    repeating-linear-gradient(92deg, rgba(0,0,0,.02) 0 2px, transparent 2px 9px),
    linear-gradient(180deg,#efece1,#e3dfd0);
  color:var(--paper-ink);
  padding:36px 32px 32px;
  box-shadow:14px 14px 0 #000, 14px 14px 0 1px var(--red);
  transform:rotate(1.2deg);
  align-self:start;
  margin-top:8px;
  isolation:isolate;
}
.akte > *{color:var(--paper-ink)}
.akte b{color:#000}
.akte-stamp{
  position:absolute;top:-18px;right:20px;
  font-family:var(--display);color:var(--red-deep);
  border:3px solid var(--red-deep);padding:6px 14px;
  letter-spacing:.2em;font-size:14px;
  transform:rotate(-6deg);background:#f7f4ea;
  box-shadow:inset 0 0 0 1px #fff;
}
.akte h3{font-family:var(--display);font-size:26px;margin-bottom:14px;text-transform:uppercase}
.akte ul{list-style:none}
.akte li{
  padding:10px 0;border-top:1px solid #c7c2b5;
  font-family:var(--type);font-size:15px;
}
.akte li:first-child{border-top:none}
.akte b{color:#000}
.akte u{text-decoration:underline wavy var(--red-deep)}

/* ----- § 02 Timeline --------------------------------------- */
.timeline{
  list-style:none;
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  border-left:2px solid var(--red);
  margin-left:12px;
}
.timeline li{
  position:relative;padding:32px 0 40px 36px;
}
.timeline li::before{
  content:"";position:absolute;left:-9px;top:38px;
  width:16px;height:16px;border-radius:50%;
  background:var(--bg);border:3px solid var(--red);
}
.timeline li.now::before{background:var(--red);box-shadow:0 0 0 6px rgba(255,31,31,.18)}
.timeline li.highlight{
  background:linear-gradient(90deg, rgba(255,31,31,.06), transparent 80%);
  padding-left:40px;margin-left:-4px;border-radius:0 6px 6px 0;
}
.timeline li.highlight::before{background:var(--red);box-shadow:0 0 0 4px rgba(255,31,31,.25)}
.timeline li.highlight h4{color:#fff}
.t-year{
  font-family:var(--mono);font-size:12px;color:var(--red);letter-spacing:.2em;
}
.timeline h4{
  font-family:var(--display);text-transform:uppercase;
  font-size:clamp(22px,2.6vw,34px);margin:6px 0 10px;
  letter-spacing:-.005em;
}
.timeline p{max-width:760px;color:#cfcfc9;font-size:16px}

/* ----- § 03 Zitate ----------------------------------------- */
.quote-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:24px;
}
.quote{
  position:relative;padding:34px 30px;
  background:var(--bg-2);
  border:1px solid var(--line);
  box-shadow:6px 6px 0 #000;
}
.quote::before{
  /* Einschussloch */
  content:"";position:absolute;top:-14px;left:-14px;
  width:44px;height:44px;border-radius:50%;
  background:radial-gradient(circle at 38% 35%, #111 0 40%, #000 60%, transparent 70%);
  box-shadow:0 0 0 2px #1a1a1a, 6px 6px 14px rgba(0,0,0,.6);
}
.quote blockquote{
  font-family:var(--display);
  font-size:clamp(22px,2.4vw,32px);
  line-height:1.18;letter-spacing:-.005em;
  text-transform:uppercase;
  color:var(--ink);
}
.quote figcaption{
  margin-top:20px;display:flex;justify-content:space-between;gap:14px;
  font-family:var(--mono);font-size:12px;color:var(--ink-dim);
  border-top:1px dashed #2a2a2e;padding-top:14px;
  letter-spacing:.05em;
}
.quote .who{color:var(--red);font-weight:700}

.q-keemo {
  grid-column:span 7;transform:rotate(-.4deg);
  position:relative;overflow:hidden;
  background:
    radial-gradient(600px 200px at 90% 110%, rgba(255,31,31,.18), transparent 70%),
    linear-gradient(180deg,#131314,#0d0d0e);
}
.q-keemo .rotate-btn{
  position:absolute;top:14px;right:14px;z-index:2;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  color:var(--ink-dim);background:transparent;
  border:1px solid var(--line);padding:6px 10px;border-radius:999px;
  cursor:pointer;transition:.2s;text-transform:uppercase;
}
.q-keemo .rotate-btn:hover,
.q-keemo .rotate-btn:focus-visible{
  color:var(--red);border-color:var(--red);outline:none;
  transform:rotate(-20deg);
}
.q-keemo blockquote{transition:opacity .25s ease}
.q-keemo.swap blockquote{opacity:0}
.q-keemo .tag{
  position:absolute;bottom:-18px;right:-8px;
  font-family:var(--display);font-size:clamp(60px,10vw,120px);
  color:rgba(255,31,31,.06);
  letter-spacing:-.04em;line-height:.8;pointer-events:none;z-index:0;
  text-transform:uppercase;
}
.q-onkelz{grid-column:span 5;transform:rotate(.6deg);background:linear-gradient(180deg,#14100f,#0e0c0b)}
.q-nwa   {grid-column:span 5;transform:rotate(.3deg);background:linear-gradient(180deg,#0c1218,#0a0c10)}

/* BVerfG — Papier-Karte, bewusst ruhig & seriös, gut lesbar */
.q-bvg{
  grid-column:span 7;transform:rotate(-.3deg);
  background:
    /* leichte Papier-Maserung, NICHT das harte Global-Noise */
    repeating-linear-gradient(92deg, rgba(0,0,0,.018) 0 2px, transparent 2px 9px),
    linear-gradient(180deg,#efece1,#e3dfd0);
  color:var(--paper-ink);
  isolation:isolate;                 /* schneidet globales Blend-Noise vom Inhalt ab */
  border:1px solid #c8c2b0;
  box-shadow:
    6px 6px 0 #000,
    inset 0 0 0 1px rgba(255,255,255,.5);
}
/* Spezifisch genug, um globale .quote blockquote Farbe zu schlagen */
.q-bvg blockquote,
.q-bvg blockquote *{
  color:#111 !important;
  text-shadow:none;
  font-family:var(--type);
  text-transform:none;
  font-size:clamp(17px,1.7vw,22px);
  line-height:1.55;
  letter-spacing:0;
  font-weight:400;
}
.q-bvg figcaption{color:#4a4a42;border-color:#b8b2a1}
.q-bvg figcaption .who{color:var(--red-deep)}
.q-bvg figcaption .what{color:#5e5e54}
.q-bvg::before{                        /* kein Einschussloch auf der Akte */
  display:none;
}

/* ----- § 04 Ticker ----------------------------------------- */
.ticker{padding-bottom:100px}
.readout{
  max-width:720px;
  border:1px solid var(--line);
  background:var(--bg-2);
  font-family:var(--mono);
}
.readout-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 18px;border-top:1px solid var(--line);
  font-size:13px;
}
.readout-row:first-child{border-top:none}
.readout-row span{color:var(--ink-dim);letter-spacing:.2em;text-transform:uppercase}
.readout-row b{color:var(--ink);font-size:15px}
.readout-row .ok{color:#7fff9a}

.marquee{
  margin-top:60px;overflow:hidden;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-2);
  padding:18px 0;
}
.marquee-inner{
  display:flex;gap:40px;width:max-content;
  animation:slide 40s linear infinite;
  font-family:var(--display);font-size:26px;letter-spacing:.2em;color:var(--red);
  text-transform:uppercase;
}

/* ----- FOOTER ---------------------------------------------- */
.foot{
  padding:80px 40px 40px;
  border-top:2px solid var(--red);
  background:linear-gradient(180deg,#0a0a0b,#050506);
}
.foot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1200px}
.foot h5{
  font-family:var(--display);text-transform:uppercase;font-size:18px;
  letter-spacing:.04em;margin-bottom:14px;color:var(--red);
}
.foot p,.foot li{font-size:14px;color:#a7a7a1;line-height:1.65}
.foot .links{list-style:none}
.foot .links li{padding:4px 0}
.foot .mono{font-family:var(--mono);font-size:12.5px;color:#8a8a85}

.foot-bottom{
  margin-top:40px;padding-top:24px;border-top:1px solid #1a1a1a;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:11.5px;color:#5e5e58;letter-spacing:.1em;
}
.foot-bottom .tiny{opacity:.7}

/* ----- Konami Overlay -------------------------------------- */
.konami{
  position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 50%, rgba(31,123,255,.35), rgba(0,0,0,.96));
  opacity:0;pointer-events:none;transition:opacity .25s;
  touch-action:manipulation;cursor:pointer;
}
.konami.on{pointer-events:auto}
.konami.on{opacity:1}
.konami-inner{text-align:center;animation:pulse 1s infinite alternate}
.konami h2{font-family:var(--display);font-size:clamp(120px,22vw,340px);color:#fff;letter-spacing:-.02em;line-height:.9}
.konami p{font-family:var(--mono);letter-spacing:.3em;color:var(--yellow);text-transform:uppercase;margin-top:10px}
@keyframes pulse{to{transform:scale(1.03)}}

/* ----- Responsive ------------------------------------------ */

/* Tablet / kleineres Desktop */
@media (max-width: 900px){
  .nav{padding:72px 22px 0;flex-direction:column;align-items:flex-start;gap:16px}
  .nav-links{flex-wrap:wrap;gap:14px 18px}
  .hero{padding:80px 22px 40px}
  .hero-scroll{left:22px}
  .section{padding:100px 22px}

  .bedeutung{grid-template-columns:1fr;gap:40px}
  .akte{grid-column:1;margin-top:20px}

  .quote-grid{grid-template-columns:1fr}
  .q-keemo,.q-onkelz,.q-nwa,.q-bvg{grid-column:1}

  .foot-grid{grid-template-columns:1fr;gap:30px}
  .foot-bottom{flex-direction:column;gap:10px;align-items:flex-start}
}

/* Smartphones ~ bis 600px */
@media (max-width: 600px){
  /* Atmosphäre zurückdrehen, damit mobile nicht flackert und CPU hochdreht */
  .grain{opacity:.05;animation-duration:2.4s}
  .strobe span{filter:blur(60px)}

  /* Absperrband kleiner + mehr Platz zur Nav */
  .tape{font-size:11px;padding:7px 0;transform:rotate(-1.4deg)}
  .tape-top{top:10px}

  /* NAV kompakter */
  .nav{padding:54px 18px 0;gap:12px}
  .brand{font-size:12px;gap:8px;flex-wrap:wrap}
  .brand-mark{padding:3px 7px}
  .nav-links{gap:10px 14px;font-size:11.5px}
  .nav-links a{padding-bottom:2px}

  /* HERO */
  .hero{padding:46px 18px 60px;min-height:88svh}
  .hero-meta{font-size:11px;margin-bottom:18px;word-break:break-word}

  .title{
    font-size:clamp(64px, 26vw, 140px);
    letter-spacing:-.02em;
    gap:0;
  }
  .title span{
    text-shadow:3px 0 var(--red),-3px 0 var(--blue); /* dünner, damit kein overflow */
  }

  .hero-sub{margin-top:20px;font-size:15px}
  .hero-sub .strike{text-decoration-thickness:2px;font-size:14px}
  .hero-sub .truth{
    font-size:20px;margin-top:8px;line-height:1.15;
    padding:2px 5px;white-space:normal;
  }

  .hero-scroll{bottom:20px;left:18px;font-size:10px;letter-spacing:.25em}

  /* Sections */
  .section{padding:72px 18px}
  .section-head{gap:14px;margin-bottom:36px}
  .section-num{font-size:11px;letter-spacing:.18em;padding-left:10px}
  .section h2{font-size:clamp(30px,9vw,48px);line-height:.98}

  /* § 01 Bedeutung */
  .decode{font-size:clamp(36px,11vw,60px)}
  .decode-row{gap:16px;padding:12px 0}
  .decode-row .dash{font-size:.45em}

  .lead{font-size:15.5px;margin-top:22px;line-height:1.55}

  .akte{
    padding:26px 20px 22px;
    transform:rotate(.6deg);
    box-shadow:8px 8px 0 #000, 8px 8px 0 1px var(--red);
    margin-right:6px;                    /* Schatten bleibt im Viewport */
  }
  .akte-stamp{font-size:12px;padding:4px 10px;top:-14px;right:14px}
  .akte h3{font-size:22px}
  .akte li{font-size:14px;padding:9px 0;line-height:1.5}

  /* § 02 Timeline */
  .timeline{margin-left:6px}
  .timeline li{padding:22px 0 28px 24px}
  .timeline li::before{left:-8px;top:28px;width:12px;height:12px;border-width:2px}
  .timeline h4{font-size:clamp(19px,5.2vw,24px);margin:4px 0 8px;line-height:1.1}
  .timeline p{font-size:14.5px;line-height:1.55}
  .t-year{font-size:11px;letter-spacing:.18em}

  /* § 03 Zitate */
  .quote{padding:28px 22px;box-shadow:4px 4px 0 #000;transform:none !important}
  .quote::before{
    width:32px;height:32px;top:-10px;left:-6px;     /* Einschussloch bleibt im Viewport */
  }
  .quote blockquote{font-size:clamp(19px,5vw,24px);line-height:1.22}
  .quote figcaption{
    flex-direction:column;gap:4px;
    font-size:11px;padding-top:10px;margin-top:14px;
  }
  .q-bvg blockquote,.q-bvg blockquote *{font-size:15.5px !important;line-height:1.5}
  .q-keemo{padding-top:54px}                       /* Platz für Rotate-Button */
  .q-keemo .rotate-btn{font-size:9.5px;padding:5px 8px;top:12px;right:12px}
  .q-keemo .tag{font-size:80px;bottom:-14px}

  /* § 04 Ticker */
  .readout-row{
    flex-direction:column;align-items:flex-start;gap:4px;
    padding:12px 14px;font-size:12px;
  }
  .readout-row span{font-size:10.5px}
  .readout-row b{font-size:14px;word-break:break-all}

  .marquee{margin-top:36px;padding:12px 0}
  .marquee-inner{font-size:18px;gap:24px}

  /* FOOTER */
  .foot{padding:60px 18px 30px}
  .foot-grid{gap:26px}
  .foot h5{font-size:16px;margin-bottom:10px}
  .foot p,.foot li{font-size:13.5px;line-height:1.6}
  .foot .mono{font-size:11.5px}
  .foot-bottom{font-size:10.5px;letter-spacing:.06em}

  /* Konami Overlay */
  .konami h2{font-size:clamp(90px,30vw,160px)}
  .konami p{font-size:12px;letter-spacing:.2em}
}

/* Sehr schmale Geräte (iPhone SE, Galaxy Fold zu) */
@media (max-width: 380px){
  .tape{font-size:10px;letter-spacing:.08em}
  .nav{padding:48px 14px 0}
  .hero{padding:38px 14px 50px}
  .section{padding:60px 14px}
  .foot{padding:50px 14px 28px}

  .title{font-size:clamp(54px, 27vw, 100px)}
  .hero-sub .truth{font-size:18px}

  .decode{font-size:44px}
  .decode-row{gap:12px}

  .akte{padding:22px 16px 18px;box-shadow:5px 5px 0 #000, 5px 5px 0 1px var(--red)}
  .akte h3{font-size:19px}

  .marquee-inner{font-size:15px;letter-spacing:.15em}
}

/* Landscape auf kleinen Handys: Hero nicht auf volle Höhe zwingen */
@media (max-height: 480px) and (orientation: landscape){
  .hero{min-height:auto;padding-top:100px;padding-bottom:60px}
  .title{font-size:clamp(56px,14vw,120px)}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}
