/* =============================================================================
 * sh-sections.css — Design-System für die neuen dunklen Flow-Sektionen (S6–S11).
 * Normaler Dokument-Flow (kein fixed Scroll-Jack), Reveals via IntersectionObserver
 * (js/sh-sections.js setzt .is-inview). Apple-artig, durchgehend schwarz.
 * ========================================================================== */

@font-face { font-family:'NHaasRg'; src:url('fonts/NHaasGroteskTXStd-55Rg.otf') format('opentype'); font-display:swap; }
@font-face { font-family:'NHaasMd'; src:url('fonts/NHaasGroteskTXStd-65Md.otf') format('opentype'); font-display:swap; }
@font-face { font-family:'NHaasIt'; src:url('fonts/NHaasGroteskTXStd-56It.otf') format('opentype'); font-display:swap; }
@font-face { font-family:'NHaasBd'; src:url('fonts/NHaasGroteskTXStd-75Bd.otf') format('opentype'); font-display:swap; }

:root {
  --sh-bg:#000;
  --sh-fg:#F2EFE8;        /* off-white */
  --sh-muted:#7d7a73;     /* gedimmt (Reveal-Grundzustand) */
  --sh-muted2:#ADADAD;
  --sh-accent:#48ACFF;        /* Akzent-Blau auf dunklem Grund */
  --sh-accent-deep:#2478C8;   /* Akzent-Blau auf hellem Grund (lesbar) */
  --sh-red:#FF5A5A;           /* Superhighlight, sparsam (Race, Strike) */
  --sh-warm:#F7C948;          /* warmes Gelb, nur fuer das Energy-Statement (Marcel) */
  --sh-green:#4DD49B;
  --sh-ease:cubic-bezier(.2,.7,.2,1);
  --sh-max:1240px;
  --sh-pad:6vw;
}

/* ---- Container / Sektion ------------------------------------------------- */
.shSection {
  position:relative; z-index:2;
  background:var(--sh-bg); color:var(--sh-fg);
  font-family:'NHaasRg', system-ui, sans-serif;
  padding:16vh var(--sh-pad);
  overflow:hidden;
}
.shWrap { max-width:var(--sh-max); margin:0 auto; }
.shWrap.narrow { max-width:880px; }

/* einzelne „Beats" einer Sektion, die nacheinander beim Scrollen erscheinen */
.shStep { min-height:72vh; display:flex; flex-direction:column; justify-content:center; }
.shStep.tall { min-height:96vh; }
/* Bruecken-Sektion (S6): nur zwei Frames — jeder steht als EIGENER voller Screen */
.shCausal .shStep { min-height:100vh; }

/* ---- Typografie ---------------------------------------------------------- */
.shKicker {
  font-family:'NHaasMd', system-ui, sans-serif;
  font-size:13px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--sh-muted2); margin-bottom:22px;
}
.shStatement {
  font-family:'NHaasMd', system-ui, sans-serif;
  font-size:clamp(30px, 4.2vw, 62px); line-height:1.08; letter-spacing:-.01em;
  color:var(--sh-muted); max-width:18ch;
}
.shStatement.wide { max-width:26ch; }
.shStatement.center { margin-left:auto; margin-right:auto; text-align:center; max-width:24ch; }
.shHead {
  font-family:'NHaasMd', system-ui, sans-serif;
  font-size:clamp(26px, 3vw, 44px); line-height:1.1; color:var(--sh-fg); margin-bottom:18px;
}
.shBody {
  font-family:'NHaasRg', system-ui, sans-serif;
  font-size:clamp(17px, 1.5vw, 22px); line-height:1.5; color:var(--sh-muted2); max-width:62ch;
}
.shBody.big { font-size:clamp(20px,1.8vw,26px); color:var(--sh-fg); }

/* Inline-Hervorhebungen */
.hl  { color:var(--sh-fg); }
.amber { color:var(--sh-accent); }
.warm  { color:var(--sh-warm); }
.green { color:var(--sh-green); }
.strike { color:var(--sh-red); text-decoration:line-through; text-decoration-thickness:2px; }
em { font-family:'NHaasMd', system-ui, sans-serif; font-style:normal; }

/* ---- Reveal (IntersectionObserver) -------------------------------------- */
.shReveal {
  opacity:0; transform:translateY(20px);
  transition:opacity .9s var(--sh-ease), transform .9s var(--sh-ease);
  transition-delay:calc(var(--d, 0) * 90ms);
  will-change:opacity, transform;
}
.shReveal.is-inview { opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce) {
  .shReveal { opacity:1; transform:none; transition:none; }
}

/* ---- Karten-Mechanik (Reuse aus frame126/127, dunkel) ------------------- */
.shCardGrid { display:grid; grid-template-columns:repeat(auto-fit, minmax(280px,1fr)); gap:18px; margin-top:48px; }
.shCard {
  background:#0c0c0d; border:1px solid #1c1c1e; border-radius:16px; padding:30px 28px;
  display:flex; flex-direction:column; gap:12px; min-height:200px;
}
.shCard .num { font-family:'NHaasMd'; font-size:13px; letter-spacing:.14em; color:var(--sh-accent); }
.shCard .ct  { font-family:'NHaasMd'; font-size:clamp(19px,1.6vw,24px); color:var(--sh-fg); line-height:1.15; }
.shCard .cb  { font-size:16px; line-height:1.45; color:var(--sh-muted2); }

/* ---- Dreigeteiltes SH-Symbol (S11): die drei Tri-Star-Roehren = drei Vertikalen.
   Auseinandergezogen im Grundzustand, fuegen sich beim Reveal zu EINEM Logo zusammen. ---- */
.shTriLogo { display:block; width:min(34vw,300px); margin:8px auto 44px; overflow:visible; }
.shTriLogo .tri { fill:var(--sh-fg); transition:transform 1.1s cubic-bezier(0.2,0.7,0.2,1), opacity .9s; opacity:0; }
.shTriLogo .tri-a { transform:translate(-16px,-9px); transition-delay:.05s; }
.shTriLogo .tri-b { transform:translate(0,17px);     transition-delay:.2s; }
.shTriLogo .tri-c { transform:translate(16px,-9px);  transition-delay:.35s; }
.shTriLogo.is-inview .tri { transform:translate(0,0); opacity:1; }

/* ---- Stat-Karten (recycelte Zahlen aus dem Alt-Bestand, Surface dunkel) ---- */
.shStatRow { display:grid; grid-template-columns:1fr; gap:18px; margin-top:52px; }
.shStatRow.three { grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); }
.shStat { background:#0c0c0d; border:1px solid #1c1c1e; border-radius:16px; padding:34px 32px 28px; }
.shStat .sv { font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(52px,6vw,92px);
  line-height:1; color:var(--sh-fg); letter-spacing:-0.01em; }
.shStat .sv .su { font-size:.38em; color:var(--sh-accent); margin-left:8px; letter-spacing:.04em; }
.shStat .sl { font-size:clamp(15px,1.3vw,19px); line-height:1.45; color:var(--sh-muted2); margin-top:16px; max-width:44ch; }
.shStat .sq { font-family:'NHaasMd',system-ui,sans-serif; font-size:12px; letter-spacing:.1em;
  color:#5a5750; margin-top:22px; text-transform:uppercase; }

/* ---- S7 Apple-Overview-Muster (Inspo-004 + Screenshots): Augenbraue + Riesen-Titel
   + Intro zentriert; alternierende Text|Bild-Reihen; grosses Kaertchen; Schluss mit
   grosser Zahl (1:1 wie Apples "Bis zu 16 Std.") ---- */
.shApple { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(24px,2.6vw,40px); line-height:1.25; color:var(--sh-fg);
  max-width:30ch; margin:0; }
.shApple.small { font-size:clamp(19px,1.9vw,27px); max-width:44ch; }
.apHead { text-align:center; padding:8vh 0 4vh; }
.apHead .apEyebrow { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(17px,1.5vw,22px); color:var(--sh-muted2); margin:0 0 18px; }
.apHead .apTitle { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(48px,7.5vw,104px); line-height:1.02; letter-spacing:-.02em;
  color:var(--sh-fg); margin:0 0 34px; }
.apHead .apIntro { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(19px,1.9vw,27px); line-height:1.35; color:var(--sh-fg);
  max-width:56ch; margin:0 auto; }
.apRow { display:grid; grid-template-columns:1fr 1.15fr; gap:clamp(32px,5vw,80px);
  align-items:center; margin:14vh 0; }
.apRow.rev { grid-template-columns:1.15fr 1fr; }
.apRow .apImg { width:100%; height:auto; border-radius:28px; display:block;
  background:#0c0c0d; }
.apText { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(19px,1.9vw,27px); line-height:1.35; color:var(--sh-fg);
  max-width:38ch; margin:0; }
.apText .amber { color:var(--sh-accent); }
.apText.apRace { color:var(--sh-red); }
.apText .raceRed { color:var(--sh-red); }
.apCardWide { margin:14vh 0 10vh; }
.apEnd { margin-bottom:6vh; }
.apRace { margin-top:30px; }
@media (max-width:820px) { .apRow, .apRow.rev { grid-template-columns:1fr; }
  .apRow.rev .apImg { order:2; } }
.shChartCard { background:#0c0c0d; border:1px solid #1c1c1e; border-radius:28px;
  padding:clamp(24px,3vw,44px); }
.shChartCard .ccKicker { font-family:'NHaasMd',system-ui,sans-serif; font-size:12px;
  letter-spacing:.14em; text-transform:uppercase; color:#5a5750; margin-bottom:8px; }
.shChartCard .ccTitle { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(19px,1.8vw,26px); color:var(--sh-fg); margin-bottom:22px; }
.shChartCard .ccSvg { display:block; width:100%; height:auto; }
.shSplit { display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(32px,5vw,80px);
  align-items:center; }
@media (max-width:820px) { .shSplit { grid-template-columns:1fr; } }
.shBigStat { text-align:left; }
.shBigStat .bsLead { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(15px,1.3vw,19px); color:var(--sh-muted2); margin-bottom:4px; }
.shBigStat .bsNum { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(64px,7.5vw,120px); line-height:1; color:var(--sh-accent); letter-spacing:-.02em; }
.shBigStat .bsNum .bsUnit { font-size:.42em; margin-left:10px; letter-spacing:.02em; }
.shBigStat .bsCap { font-size:clamp(14px,1.2vw,17px); line-height:1.45; color:var(--sh-muted2);
  margin-top:12px; max-width:34ch; }

/* ---- Industry Giants (S9): Logo-Leiste, Alt-PNGs als weisse Silhouetten ---- */
.shGiants { background:#0c0c0d; border:1px solid #1c1c1e; border-radius:16px;
  padding:36px 34px; margin-top:52px; }
.shGiants .gTitle { font-size:clamp(16px,1.4vw,20px); line-height:1.45; color:var(--sh-muted2); max-width:56ch; }
.shGiants .gLogos { display:flex; flex-wrap:wrap; align-items:center; gap:38px 52px; margin-top:30px; }
.shGiants .gLogos img { height:26px; width:auto; filter:brightness(0) invert(1); opacity:.72; }
/* Logos mit Binnenzeichnung (z.B. TSMC-Wafer): nicht zur Silhouette fuellen, sondern invertieren */
.shGiants .gLogos img.keepArt { filter:grayscale(1) invert(1) brightness(1.35); height:34px; }

/* ---- S9 Fall-Liste / S8 Karten-Slot ------------------------------------- */
.shFallList { list-style:none; display:flex; flex-direction:column; gap:30px; }
.shFallList li { font-family:'NHaasMd', system-ui, sans-serif; font-size:clamp(22px,2.4vw,34px); color:var(--sh-fg); }
.shFallList .country { margin-right:16px; }
.shFallList .reason { display:inline; color:var(--sh-muted2); font-family:'NHaasRg', system-ui, sans-serif; font-size:clamp(16px,1.35vw,21px); }
.shMapSlot { margin-top:44px; border:1px dashed #2a2a2c; border-radius:14px; min-height:300px;
  display:flex; align-items:center; justify-content:center; color:#55524c; font-size:14px; letter-spacing:.06em; }

/* ---- Mobile ------------------------------------------------------------- */
/* ---- S11 Finale ---------------------------------------------------------- */
.shFinale { padding-bottom:0; }
.shFinaleLogo { display:block; width:clamp(220px,32vw,420px); margin:0 auto; height:auto; }
.shVerticals { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; }
.shVert { border-top:1px solid #2a2a2c; padding-top:18px; display:flex; flex-direction:column; gap:8px; }
.shVert .vi { font-family:'NHaasMd', system-ui, sans-serif; color:var(--sh-accent); font-size:13px; letter-spacing:.14em; }
.shVert .vt { font-family:'NHaasMd', system-ui, sans-serif; color:var(--sh-fg); font-size:clamp(18px,1.6vw,24px); }
.shCardGrid.four { grid-template-columns:repeat(auto-fit,minmax(232px,1fr)); }
.shFooter { max-width:var(--sh-max); margin:10vh auto 0; padding:46px 0 64px; border-top:1px solid #1c1c1e;
  display:flex; flex-direction:column; gap:14px; align-items:flex-start; }
.shFooterLogo { height:26px; width:auto; opacity:.9; }
.shFooterMeta { font-family:'NHaasMd', system-ui, sans-serif; color:var(--sh-fg); font-size:15px; letter-spacing:.04em; }
.shFooterLinks { font-size:14px; color:var(--sh-muted2); }
.shFooterLinks a { color:var(--sh-muted2); text-decoration:none; }
.shFooterLinks a:hover { color:var(--sh-fg); }

/* ---- Mobile ------------------------------------------------------------- */
@media (max-width:820px) {
  .shSection { padding:12vh 7vw; }
  .shStep { min-height:64vh; }
  .shStatement { font-size:clamp(26px,7vw,40px); max-width:none; }
  .shVerticals { grid-template-columns:1fr; }
}

/* ---- ORBIT & LOGO — eine sticky Sequenz (Beat C..S5), scoped #sec5 --------- */
/* #sec5 wird hochgezogen, sodass es am ENDE der Kaskade andockt (dort haelt der Chip).
   So kann der schwarze Kaskaden-Layer ausblenden und den dahinter auf den Chip
   ausgerichteten Satelliten aufdecken (= in-place Crossfade Chip -> Satellit). */
/* #sec5 dockt FRUEH an (~vh 1480, noch waehrend der Satellit im Kaskaden-Layer fliegt):
   der Layer wird dort transparent und die Sektion (Sterne, Erde) ist die Kulisse HINTER
   dem fliegenden Satelliten — eine durchgehende Szene, keine Ueberblendung. */
#sec5 { margin-top:-255vh; position:relative; z-index:2; }
#sec5 #scroll { height:700vh; position:relative; }
#sec5 #stage { position:sticky; top:0; height:100vh; width:100%; overflow:hidden;
  background:radial-gradient(ellipse at 50% 36%, #060a12 0%, #000 78%); }

/* Arbeitsmodus: GLOBALER Scroll-Zähler ab Seitenanfang (vh) — fixed, immer sichtbar,
   ueber allen Layern (Kaskade z5, secondaryBar z50). Fuer punktgenaue Regie-Ansagen. */
#globalScrollHUD { position:fixed; right:14px; bottom:14px; z-index:99999; pointer-events:none;
  font-family:'SF Mono',ui-monospace,monospace; font-size:15px; font-weight:600; letter-spacing:.03em;
  color:#ffce9a; background:rgba(10,10,12,.82); border:1px solid rgba(255,205,140,.45);
  border-radius:7px; padding:5px 11px; box-shadow:0 2px 12px rgba(0,0,0,.5); }

/* Sterne+Logo ganz hinten, Netz darüber (Himmel) — beide hinter der Erde */
#sec5 #stage #c        { position:absolute; inset:0; width:100%; height:100%; display:block; z-index:1; }
#sec5 #stage #orbitNet { position:absolute; inset:0; width:100%; height:100%; display:block; z-index:2; pointer-events:none; }

/* Erde SEHR tief angesetzt (2026-07: nochmals ~45% weiter unten als zuvor, deutlich mehr
   Sternenhimmel). Maske blendet den schwarzen Weltraum oberhalb des Limbs in den
   Sternenhimmel, die blaue Atmosphären-Glow-Linie bleibt sichtbar. */
#sec5 #orbitEarth, #sec5 #orbitEarthNet {
  position:absolute; left:50%; bottom:-88vh; transform:translateX(-50%);
  width:150vw; max-width:none; height:auto; z-index:3; pointer-events:none; opacity:0;
  -webkit-mask-image:linear-gradient(to bottom, transparent 0%, transparent 6%, #000 12%, #000 100%);
          mask-image:linear-gradient(to bottom, transparent 0%, transparent 6%, #000 12%, #000 100%); }
#sec5 #orbitEarthNet { z-index:4; }

/* Satelliten-ANSCHNITT oben rechts: nahtlose DOM-Fortsetzung des WebGL-Flugs. Pose
   (Position/Groesse/Rotation) setzt js/sh-orbit.js exakt aus der WebGL-Endkonfiguration —
   beim Ausblenden des Kaskaden-Layers liegen beide deckungsgleich uebereinander. */
#sec5 #orbitSat {
  position:absolute; left:0; top:0; height:auto; max-width:none;
  z-index:6; pointer-events:none; display:none; opacity:0;
  transform-origin:50% 50%; will-change:transform,opacity; }

/* Beat-Texte */
#sec5 .obText { position:absolute; left:50%; transform:translateX(-50%);
  text-align:center; width:min(92vw,900px); z-index:7; opacity:0; pointer-events:none; }
#sec5 .obTop  { top:72%; }
/* Hero: liegt HINTER der Erde (z2 < Erde z3), vor Sternen/Netz — der Text faehrt von unten
   hinter dem Planeten hervor und steht dann in der BILDMITTE. */
#sec5 .obHero { top:40%; z-index:2; }
/* Close-up-Text unten RECHTS (Chips & Satelliten) */
#sec5 .obRight { right:6vw; bottom:9vh; top:auto; left:auto; transform:none; text-align:right;
  width:min(80vw,620px); }
/* Netz-Text unten LINKS (nach dem Netzaufbau) */
#sec5 .obLeft { left:6vw; bottom:10vh; top:auto; transform:none; text-align:left;
  width:min(80vw,620px); }
#sec5 .obLeft .big { font-size:clamp(28px,4vw,56px); }
/* "Engines of intelligence" OBEN RECHTS (nach der Erd-Abfahrt); faehrt beim
   Weiterscrollen nach oben aus dem Bild (js/sh-orbit.js Sonderfall) */
#sec5 .obTopRight { right:6vw; top:12vh; left:auto; bottom:auto; transform:none;
  text-align:right; width:min(80vw,620px); }
#sec5 .obTopRight .big { font-size:clamp(28px,4vw,56px); }
#sec5 .obRight .big { font-size:clamp(28px,4vw,56px); }
#sec5 .obText .big { font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(30px,4.4vw,64px); color:var(--sh-fg); line-height:1.08; }
#sec5 .obText .big.amber { color:var(--sh-accent); }
#sec5 .obText .sub { font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(17px,1.8vw,26px); color:var(--sh-muted2); margin-top:14px; line-height:1.4; }

/* ---- S8 SUPPLY + GEOPOLITIK: Marcels Welt-Karte als Sticky-Scroll-Sequenz ----------
   Links Kicker/Headline + wechselnder Step-Text, rechts die Karte (faehrt von unten
   rein); der Scroll skippt die Karten-Steps durch. Treiber: js/sh-supply.js */
#sec8 { background:#000; position:relative; z-index:2; }
#sec8 #supplyScroll { height:790vh; position:relative; }
#sec8 #supplyStage { position:sticky; top:0; height:100vh; overflow:hidden; background:#000;
  display:grid; grid-template-columns:0.85fr 1.35fr; gap:4vw; align-items:center;
  padding:0 5vw; font-family:'NHaasRg',system-ui,sans-serif; color:var(--sh-fg); }
#sec8 .spKicker { font-family:'NHaasMd',system-ui,sans-serif; font-size:13px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--sh-muted2); margin-bottom:20px; }
#sec8 .spHead { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(30px,3.4vw,52px); line-height:1.08; color:var(--sh-fg);
  margin-bottom:34px; transition:opacity .5s; }
#sec8 .spHead.dim { opacity:.25; }
#sec8 .spTexts { position:relative; min-height:11em; }
#sec8 .spStep { position:absolute; inset:0 0 auto 0; margin:0;
  font-size:clamp(16px,1.4vw,21px); line-height:1.55; color:var(--sh-muted2); max-width:46ch;
  opacity:0; transform:translateY(14px);
  transition:opacity .4s var(--sh-ease), transform .4s var(--sh-ease); }
#sec8 .spStep b { font-family:'NHaasMd',system-ui,sans-serif; font-weight:normal; color:var(--sh-fg); }
#sec8 .spStep.on { opacity:1; transform:none; }
/* Ausblenden INSTANT (Einblenden bleibt weich): beim schnellen Daumen-Scrollen standen
   sonst zwei Steps halb-transparent uebereinander (iPhone-Video 2026-07-03). */
#sec8 .spStep:not(.on) { opacity:0; transition:none; }
#sec8 .spFinal { position:absolute; left:50%; top:50%; margin:0; z-index:5;
  font-family:'NHaasMd',system-ui,sans-serif; text-align:center;
  font-size:clamp(28px,3vw,48px); line-height:1.18; color:var(--sh-fg); max-width:22ch;
  opacity:0; transform:translate(-50%,-50%) translateY(16px);
  transition:opacity .6s var(--sh-ease), transform .6s var(--sh-ease); }
#sec8 .spFinal.on { opacity:1; transform:translate(-50%,-50%); }
#sec8 .spRight { will-change:transform; transition:opacity .6s var(--sh-ease); }
#sec8 #supplyMapHost svg { width:100%; height:auto; display:block; }
#sec8 #supplyMapHost svg path.c { fill:#1b1b1e; stroke:#0a0a0b; stroke-width:.3;
  transition:fill .8s cubic-bezier(.2,.7,.2,1); }
#sec8 #supplyMapHost .arrowlabel { font-size:9px; fill:#c9c6bf; }
@media (max-width:900px) { #sec8 #supplyStage { grid-template-columns:1fr; align-content:center; } }

/* ---- S10 USA-Kaertchen (Alt-Bestand 1:1): heller Legacy-Block im Original-Look ---- */
/* S10 = nur noch der weisse USA-Block: nach dem Supply-Schluss etwas Schwarzraum
   (padding-top der Sektion), dann der Wechsel ins Weisse. */
.shToWhite { padding-bottom:0; }
/* Original-Hintergrund der Ausgangsseite (#F8F8F8 = .bg_light): weisse Karten heben
   sich sonst nicht ab ("fehlende Kaertchen-Hintergruende"). Frames full-bleed wie im
   Original — sie zentrieren sich selbst (megaCard max 1200px). */
.shUsaLegacy { background:#F8F8F8; margin:14vh calc(-1 * var(--sh-pad)) 0;
  padding:0 0 12vh; }
.shUsaLegacy .container { margin-left:auto; margin-right:auto; }
/* Titel bricht frueher um -> keine Kollision mit dem "United States"-Label rechts */
.shUsaLegacy .textGroup109 { max-width:15ch; padding-left:20px; }
/* Platzhalter-Kreise des Prototyps ausblenden (finale Icons folgen von Marcel) */
.shUsaLegacy img[src*="placeholder"] { display:none; }
/* Mehr Luft: die ersten Kaertchen sassen direkt an der Hero-Kante (Legacy-CSS hat kein
   margin-top auf #frame114), und der Rhythmus zwischen den Karten war zu eng. */
.shUsaLegacy #frame114 { margin-top:14vh; }
.shUsaLegacy #frame114, .shUsaLegacy #frame115, .shUsaLegacy #frame116 { margin-bottom:60px; }
.shUsaLegacy #frame126 { margin-top:60px; }

/* Apple-Hero-Moment (macOS-Screenshot-Muster): Kicker + Riesentitel + Intro auf
   Glas-Pill-Hintergrund. Baut die Bruecke US-Fakten -> Standard-Helium-Plattform.
   FULLSCREEN wie #frame109 (Marcel 2026-07-02: "genauso anfangen wie bei 4800") —
   randlos, kein Card-Rahmen, KEIN Schwarz — helle, leuchtende Pills wie im
   Original-Screenshot, dunkler Text statt weiss. */
.shHero2 { position:relative; overflow:hidden;
  height:100vh; display:flex; align-items:center; justify-content:center;
  margin:0; width:100%; background:#ebf4fd; }
.shHero2 .heroPills { position:absolute; inset:-6% -1%; display:flex; gap:14px;
  pointer-events:none; }
.shHero2 .pill { flex:1; border-radius:999px; }
.shHero2 .pill:nth-child(odd)  { background:linear-gradient(175deg,#f2f9ff 0%,#9ecdf5 48%,#5aa2dd 100%);
  transform:translateY(-4%); }
.shHero2 .pill:nth-child(even) { background:linear-gradient(175deg,#e8f3fe 0%,#7db8ea 55%,#2f7fc4 100%);
  transform:translateY(4%); }
.shHero2 .pill:nth-child(4n)   { background:linear-gradient(175deg,#ffffff 0%,#aed6f7 40%,#5ba7e2 100%); }
.shHero2 .heroContent { position:relative; z-index:2; }
.shHero2 .heroLogoVert { display:block; width:min(220px,32vw); margin:0 auto 30px; }

.shHero2 .heroTitle { color:#1d1d1f; text-shadow:none; }
.shHero2 .heroIntro { color:#4a4642; text-shadow:none; }
/* Geteilte Apple-Hero-Typografie (macOS-Screenshot-Muster): Kicker + Riesentitel +
   Intro, zentriert — genutzt von .shHero2 (Pill-BG, hell) UND #frame109 (Foto-BG, dunkel). */
.hero1Content, .shHero2 .heroContent { text-align:center; color:var(--sh-fg); padding:0 7vw; }
.heroIcon { display:block; height:38px; width:auto; margin:0 auto 20px; fill:#fff; opacity:.95; }
.heroEyebrow { font-family:'NHaasMd',system-ui,sans-serif; display:flex; align-items:center;
  justify-content:center; gap:9px;
  font-size:clamp(15px,1.4vw,19px); color:#e9c9a0; margin:0 0 16px; }
.heroEyebrow .heroFlag { height:.95em; width:auto; border-radius:2px; }
.heroTitle { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(38px,5.6vw,78px); line-height:1.05; letter-spacing:-.015em;
  color:#fff; margin:0 0 28px; }
.heroIntro { font-family:'NHaasRg',system-ui,sans-serif;
  font-size:clamp(17px,1.6vw,23px); line-height:1.5; color:#f0e6d8;
  max-width:58ch; margin:0 auto; }
@media (max-width:820px) { .shHero2 .pill:nth-child(n+5) { display:none; } }

/* #frame109: Foto-Variante des Hero-Musters — Bergbild bleibt, Text jetzt zentriert
   im Apple-Stil statt oben-links/rechts verteilt (Marcel 2026-07-02). */
.shUsaLegacy #frame109 { position:relative; display:flex; align-items:center;
  justify-content:center; overflow:hidden; }
.shUsaLegacy .hero1Overlay { position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.58) 0%, rgba(0,0,0,.18) 30%,
    rgba(0,0,0,.08) 52%, rgba(0,0,0,.4) 100%); }
.shUsaLegacy .hero1Content { position:relative; z-index:2; max-width:900px; }

/* Platzhalter-Statement (weisse Sektion -> eigene helle Typografie) */
.whStatement { text-align:center; font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(28px,3.6vw,50px); line-height:1.2; color:#1d1d1f;
  margin:10vh auto; max-width:24ch; }
.whStatement .whAccent { color:var(--sh-accent-deep); }

/* Feature-Carousel (Apple-Muster): horizontale Scroll-Reihe, gerundete Bild-Karte
   oben, Fliesstext darunter, Prev/Next-Pfeile unten rechts. */
.shCarousel { max-width:1400px; margin:10vh auto 4vh; padding:0 20px; position:relative; }
.shCarousel .scTrack { display:flex; gap:26px; overflow-x:auto; scroll-snap-type:x proximity;
  scroll-behavior:smooth; padding-bottom:4px; -ms-overflow-style:none; scrollbar-width:none; }
.shCarousel .scTrack::-webkit-scrollbar { display:none; }
.shCarousel .scCard { flex:0 0 auto; width:min(430px,78vw); scroll-snap-align:start; }
.shCarousel .scImgWrap { background:#f2f2f4; border-radius:28px; overflow:hidden;
  aspect-ratio:4/3; margin-bottom:22px; }
.shCarousel .scImgWrap img { width:100%; height:100%; object-fit:cover; display:block; }
.shCarousel .scImgWrap.seal { display:flex; align-items:center; justify-content:center; background:#fff; }
.shCarousel .scImgWrap.seal img { width:52%; height:auto; object-fit:contain; }
.shCarousel .scText { font-family:'NHaasRg',system-ui,sans-serif;
  font-size:clamp(16px,1.4vw,19px); line-height:1.5; color:#3a3a3c; max-width:40ch; margin:0; }
.shCarousel .scText b { font-family:'NHaasMd',system-ui,sans-serif; font-weight:normal; color:#1d1d1f; }
.shCarousel .scNav { display:flex; justify-content:flex-end; gap:12px; margin-top:22px; }
.shCarousel .scBtn { display:flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:50%; border:1px solid #dcdcde; background:#fff;
  color:#1d1d1f; cursor:pointer; transition:background .2s, border-color .2s; }
.shCarousel .scBtn:hover { background:#f2f2f4; }
.shCarousel .scBtn:disabled { opacity:.35; cursor:default; }
.shCarousel .scBtn:disabled:hover { background:#fff; }

/* ---- HELLER SEITENSCHLUSS (ersetzt das dunkle sec11-Finale; Marcel 2026-07-02:
   "Schwarz, das kommt nicht mehr"). Reihenfolge: Carousel -> Control-Statement ->
   drei Vertikale -> "Who controls helium" -> Umwelt/Werte -> Ausklang -> Fussnoten
   -> Footer. ---------------------------------------------------------------- */

/* Grosser linksbuendiger Sektionstitel im Apple-Stil ("Das MacBook Neo und die Umwelt.") */
.whTitle { font-family:'NHaasMd',system-ui,sans-serif; font-weight:normal;
  font-size:clamp(30px,4vw,56px); line-height:1.1; color:#1d1d1f;
  max-width:1400px; margin:16vh auto 0; padding:0 20px; }

.whStatement.tight { margin:3vh auto 7vh; }
.whKicker { text-align:center; font-family:'NHaasMd',system-ui,sans-serif;
  font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:#86868b;
  margin:18vh auto 0; }

/* Drei Vertikale (hell portiert aus dem alten Finale). Marcels Grafik bekommt
   hier spaeter ihren Platz. */
.whVerticals { max-width:1200px; margin:0 auto; padding:0 20px; }
.wvGrid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.wvGraphic { display:block; width:min(620px,76vw); margin:0 auto 8vh; }
.wvItem { background:#fff; border-radius:24px; padding:30px 28px 36px;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
  display:flex; flex-direction:column; gap:10px; }
.wvBody { margin:2px 0 0; font-family:'NHaasRg',system-ui,sans-serif;
  font-size:15px; line-height:1.5; color:#6e6e73; }
.wvNum { font-family:'NHaasMd',system-ui,sans-serif; font-size:13px;
  letter-spacing:.14em; color:var(--sh-accent-deep); }
.wvName { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(18px,1.8vw,24px); color:#1d1d1f; }

/* Umwelt-/Werte-Karten (Apple-Umwelt-Muster: weisse Karten mit farbigen Statements) */
.whEnviro { max-width:1400px; margin:0 auto; padding:0 20px; }
.whEnviro .whTitle { padding:0; margin:16vh 0 6vh; }
.weGrid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.weCard { background:#fff; border-radius:24px; padding:34px 30px 46px;
  box-shadow:0 1px 0 rgba(0,0,0,.03); }
.weCard p { margin:0; font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(19px,1.7vw,25px); line-height:1.3; color:#1d1d1f; }
.weAccent { color:var(--sh-accent-deep); }

/* Ausklang Schweiz (Zuerichsee-Foto folgt) */
.whOutro { text-align:center; margin:30vh auto 26vh; padding:0 20px; }
.woLine + .woLine { margin-top:9vh; }
.woLine .whAccent { color:var(--sh-accent-deep); }
.woLine { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(26px,3.2vw,46px); line-height:1.18; color:#1d1d1f;
  max-width:22ch; margin:0 auto; }

/* Fussnoten (Apple-Disclaimer: klein, grau, nummeriert) */
.whDisclaimer { max-width:980px; margin:0 auto; padding:6vh 20px 4vh;
  border-top:1px solid #d2d2d7; }
.whDisclaimer ol { margin:0; padding-left:18px; }
.whDisclaimer li { font-family:'NHaasRg',system-ui,sans-serif; font-size:12px;
  line-height:1.65; color:#86868b; margin-bottom:8px; }

/* Important Notice (Website-Fassung des Strategy-Paper-Disclaimers) */
.wfNotice { max-width:980px; margin:0 auto; padding:2vh 20px 6vh; }
.wfNotice h5 { font-family:'NHaasMd',system-ui,sans-serif; font-size:13px;
  letter-spacing:.02em; color:#515154; margin:0 0 14px; }
.wfNotice p { font-family:'NHaasRg',system-ui,sans-serif; font-size:12px;
  line-height:1.65; color:#86868b; margin:0 0 12px; }

/* Footer: dezent, drei Spalten (Firma+Adresse / Links / Copyright), Trennstrich oben */
.whFooter { padding:7vh 0 9vh; margin:0 20px; border-top:1px solid #d2d2d7; }
.whFooter .wfCols { max-width:1240px; margin:0 auto; padding:0 20px;
  display:flex; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.whFooter .wfCol { font-family:'NHaasRg',system-ui,sans-serif; font-size:13px;
  line-height:1.7; color:#86868b; }
.whFooter .wfName { font-family:'NHaasMd',system-ui,sans-serif; color:#515154; }
.whFooter .wfNav { display:flex; gap:26px; }
.whFooter .wfNav a { color:#515154; text-decoration:none; }
.whFooter .wfNav a:hover { text-decoration:underline; }
.whFooter .wfCopy { text-align:right; }

@media (max-width: 860px) {
  .wvGrid, .weGrid { grid-template-columns:1fr; }
}

/* ---- S10 USA-KARTE (ruhig — Karte statt Animation) ---- */
/* Weltkarte: Alt-Bestand-SVG als reiner Grauton-Untergrund (brightness 0 -> Silhouette,
   invert hebt sie auf dunkles Grau). Marker liegen als absolute Punkte darueber. */
.shSupplyMap { position:relative; width:min(92vw,1100px); margin:56px auto 0; }
.shSupplyMap .smBase { display:block; width:100%; height:auto;
  filter:brightness(0) invert(0.30); opacity:.9; }
.smDot { position:absolute; width:10px; height:10px; margin:-5px 0 0 -5px; border-radius:50%;
  background:#8a877f; opacity:0; pointer-events:none; }
.smDot.explore { box-shadow:0 0 10px rgba(173,173,173,.4); }
.smDot.region { background:#48ACFF; box-shadow:0 0 0 rgba(72,172,255,0); transition:box-shadow .6s; }
.smDot.region.lit { box-shadow:0 0 18px rgba(72,172,255,.85), 0 0 44px rgba(72,172,255,.35); }
.smDot.region .smLbl { position:absolute; left:15px; top:-5px; white-space:nowrap;
  font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(12px,1.1vw,15px);
  color:var(--sh-fg); opacity:0; transition:opacity .6s; }
.smDot.region.lit .smLbl { opacity:1; }

/* USA-Karte (Prototyp-PNG, alpha): Gasfelder + gruener Helium-Belt, Amber-Ring als Marker */
.shUsaMap { position:relative; width:min(88vw,980px); margin:0 auto; }
.shUsaMap .umBase { display:block; width:100%; height:auto; opacity:.92; }
.umBelt { position:absolute; width:0; height:0; }
.umBelt::before { content:''; position:absolute; left:-48px; top:-48px; width:96px; height:96px;
  border:1.5px solid var(--sh-accent-deep); border-radius:50%;
  box-shadow:0 0 26px rgba(217,122,44,.35), inset 0 0 18px rgba(217,122,44,.15);
  animation:umPulse 3.4s ease-in-out infinite; }
.umBelt .umLbl { position:absolute; left:64px; top:-9px; white-space:nowrap;
  font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(13px,1.2vw,16px); color:var(--sh-accent-deep); }
@keyframes umPulse { 0%,100% { transform:scale(1); opacity:.95; } 50% { transform:scale(1.07); opacity:.6; } }
.umCaption { text-align:center; margin:26px auto 0; max-width:56ch; }

/* ---- S6b PAPERCUT + ZWIEBEL — eine sticky Fotosequenz (Technik B, js/sh-onion.js) ---- */
#sec6b { background:#000; }
#sec6b #onionScroll { height:330vh; position:relative; }
#sec6b #onionStage { position:sticky; top:0; height:100vh; width:100%; overflow:hidden; background:#000; }

/* zentrierter „Produktfoto"-Frame: alle Ebenen exakt gleich positioniert, Bild-BGs sind
   reines Schwarz → object-fit:contain verschmilzt nahtlos mit der Seite (kein sichtbarer Rahmen) */
#sec6b #onionImgs { position:absolute; left:50%; top:50%; width:min(88vw,1400px); aspect-ratio:4/3;
  transform:translate(-50%,-50%); z-index:2; }
#sec6b .oiLayer { position:absolute; inset:0; width:100%; height:100%; object-fit:contain;
  opacity:0; will-change:opacity,transform; }
#sec6b #onionLines { position:absolute; inset:0; width:100%; height:100%; z-index:3; pointer-events:none; }

#sec6b .obText { position:absolute; left:50%; transform:translateX(-50%); text-align:center;
  width:min(92vw,780px); z-index:5; opacity:0; pointer-events:none; }
#sec6b .obText .big { font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(26px,3.6vw,52px); color:var(--sh-fg); line-height:1.12; }
#sec6b .obText .big.warm { color:var(--sh-warm); }
#sec6b .obText .sub { font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(16px,1.6vw,22px); color:var(--sh-muted2); margin-top:12px; line-height:1.4; }
/* Beat-Texte OBEN ueber dem grossen Bild (Marcel 2026-07) */
#sec6b .onEnergy { top:6%; }
#sec6b .onCaption { top:7%; }

/* Navigationssystem 1:1 nach dem Apple-Product-Viewer (Inspo-002.mov):
   Pill-Liste links bleibt sichtbar; Klick expandiert die Pille an Ort und Stelle zu einer
   GRAUEN Karte ("Titel. Beschreibung"), die anderen ruecken nach. Chevron-Paddle links,
   x oben rechts. Grauflaechen bewusst einen Tick heller (Marcel 2026-07). */
#sec6d { padding:16vh 0 0; }
#sec6d .onHeadline { padding:0 6vw; max-width:1240px; margin:0 auto 8vh; }
#sec6d .chipStage { position:relative; width:100%; height:100vh; overflow:hidden; background:#000; }
#sec6d .chipStage > img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
#sec6d #oiChip { z-index:0; }
#sec6d #onionNav { position:absolute; left:4.5vw; top:50%; transform:translateY(-50%);
  display:flex; flex-direction:column; align-items:flex-start; gap:26px; z-index:6;
  opacity:0; pointer-events:none; transition:opacity .35s; }
/* Headline linksbuendig ueber den Pills (kein Titel) */
#sec6d .onHeadline { font-family:'NHaasMd',system-ui,sans-serif;
  font-size:clamp(22px,2.2vw,34px); line-height:1.2; color:var(--sh-fg);
  max-width:24ch; }
#sec6d .onHeadline .hlSub { color:var(--sh-muted2); }
#sec6b .onNavRow { display:flex; align-items:center; gap:18px; }
#sec6b .onPaddle { display:flex; flex-direction:column; gap:16px; }
#sec6d .onPad, #sec6d #onClose { display:flex; align-items:center; justify-content:center;
  width:52px; height:52px; border:0; border-radius:50%; cursor:pointer; flex:0 0 auto;
  background:rgba(60,60,68,.9); color:var(--sh-fg); transition:background .3s, opacity .3s; }
#sec6d .onPad:hover, #sec6d #onClose:hover { background:rgba(84,84,94,.95); }
#sec6d .onPad:disabled { opacity:.3; cursor:default; }
#sec6d #onionList { display:flex; flex-direction:column; gap:12px; width:min(320px,42vw); }
#sec6d .opItem { position:relative; }
/* Kapsel (zu): 56px, radius 28, KEIN Rahmen, hellgraues Glas, Plus 24px */
#sec6d .opPill { display:flex; align-items:center; width:100%; height:56px; border:0;
  background:rgba(60,60,68,.9); color:var(--sh-fg);
  border-radius:28px; padding:0 26px 0 14px; gap:10px;
  font-family:'NHaasMd',system-ui,sans-serif; font-size:17px; line-height:25px; text-align:left;
  cursor:pointer; transition:background .3s; }
#sec6d .opPill:hover { background:rgba(84,84,94,.95); }
#sec6d .opPill .opPlus { width:24px; height:24px; color:var(--sh-fg); opacity:.9; flex:0 0 auto; }
#sec6d .opItem.open .opPill { display:none; }
/* Karte (offen): expandiert an Ort und Stelle, gleiches Grau, Titel fett inline */
#sec6d .opCard { display:grid; grid-template-rows:0fr;
  background:rgba(66,66,74,.94); border-radius:24px;
  opacity:0; transition:grid-template-rows .42s cubic-bezier(0.2,0.7,0.2,1), opacity .3s; }
#sec6d .opItem.open .opCard { grid-template-rows:1fr; opacity:1; }
#sec6d .opCard > .opCardInner { overflow:hidden; }
#sec6d .opCard p { margin:0; padding:22px 24px 24px;
  font-family:'NHaasRg',system-ui,sans-serif; font-size:17px; line-height:25px; color:var(--sh-fg); }
#sec6d .opCard p .opCardTitle { font-family:'NHaasMd',system-ui,sans-serif; color:var(--sh-fg); }
#sec6d .opCard p .opCardBody { color:#d4d2cc; }
#sec6d #onClose { position:absolute; right:4vw; top:7vh; z-index:7;
  opacity:0; pointer-events:none; }
#sec6d #onClose.show { opacity:1; pointer-events:auto; }
/* Per-Punkt-Bild: liegt ueber dem Chip, crossfadet ein */
#sec6d #oiStepImg { z-index:1; opacity:0; transition:opacity .5s; }
#sec6d #onionNav { opacity:1; }
#sec6b .onHero { top:clamp(120px, 16vh, 210px); }
/* Onion-Schlusstext: unten LINKS unterm Bild, linksbuendig */
#sec6b .onOutro { left:5vw; bottom:7vh; top:auto; transform:none; text-align:left;
  width:min(86vw,640px); }
#sec6b .onOutro .big { font-size:clamp(26px,3vw,44px); }
#sec6b .onKicker { font-family:'NHaasIt',serif; font-size:clamp(17px,1.7vw,23px); color:var(--sh-accent-deep); margin-top:14px; }

/* sechs Prozess-Marker: links 3 / rechts 3, mit Linien zum Chip (Canvas) verbunden */
#sec6b #onionLabels { position:absolute; inset:0; z-index:4; pointer-events:none; }
#sec6b .onLabel { position:absolute; opacity:0; transform:translateY(8px); transition:none;
  font-family:'NHaasMd',system-ui,sans-serif; font-size:clamp(13px,1.15vw,16px); color:var(--sh-fg);
  display:flex; align-items:center; gap:10px; width:max-content; max-width:34vw; }
#sec6b .onDot { width:7px; height:7px; border-radius:50%; background:var(--sh-accent-deep); flex:none;
  box-shadow:0 0 10px 2px rgba(217,122,44,.7); }
#sec6b .onL1, #sec6b .onL2, #sec6b .onL3 { left:6vw; text-align:left; }
#sec6b .onR1, #sec6b .onR2, #sec6b .onR3 { right:6vw; text-align:right; flex-direction:row-reverse; }
#sec6b .onL1 { top:30%; } #sec6b .onL2 { top:46%; } #sec6b .onL3 { top:62%; }
#sec6b .onR1 { top:30%; } #sec6b .onR2 { top:46%; } #sec6b .onR3 { top:62%; }

/* Figure-7-Kärtchen (illustrativ, Platzhalter-Datenwerte bis echte Zahlen vorliegen) */
#sec6b .onFigureCard { position:absolute; left:50%; bottom:4vh; transform:translateX(-50%);
  width:min(90vw,500px); max-height:78vh; overflow:hidden; background:rgba(10,10,11,.86); border:1px solid #232325; border-radius:16px;
  padding:16px 24px; z-index:6; opacity:0; backdrop-filter:blur(6px); }
#sec6b .onFigureKicker { font-family:'NHaasMd',system-ui,sans-serif; font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--sh-accent-deep); margin-bottom:10px; }
#sec6b .onFigureBar { display:grid; grid-template-columns:1fr; gap:4px; margin-bottom:7px; }
#sec6b .onFigureBar span { font-family:'NHaasRg',system-ui,sans-serif; font-size:12.5px; color:var(--sh-muted2); }
#sec6b .onFigureBar i { display:block; height:6px; border-radius:3px; background:linear-gradient(90deg,#D97A2C,#f0a35c);
  width:var(--w); }
#sec6b .onFigureNote { font-family:'NHaasIt',serif; font-size:11.5px; color:#6b6963; margin-top:8px; }

@media (max-width:820px) {
  #sec6b .onL1,#sec6b .onL2,#sec6b .onL3,#sec6b .onR1,#sec6b .onR2,#sec6b .onR3 { max-width:40vw; font-size:11px; }
}

/* ---- MOBIL (<=700px): Kaskade -> Onion (Marcels Auftrag: Bereich 1000-3200) -------- */
#cascadeSpace { display:none; background:#000; }
/* Mobile-Marker der Legacy-Engine (siehe index.html): nur unter 700px "sichtbar" */
.footerSeparator { display:none; position:absolute; width:1px; height:1px; opacity:0;
  pointer-events:none; }
@media (max-width:700px) {
  .footerSeparator { display:block; }
  #cascadeSpace { display:block; height:590vh; }
  /* Erde: hoehenbasiert (breitenbasiert laege sie unterm Viewport); 140vh, damit nach
     dem Absinken (EARTH_DROP 32vh) noch ein Limb-Streifen sichtbar bleibt (iPhone-Video). */
  #sec5 #orbitEarth, #sec5 #orbitEarthNet { width:auto; height:140vh; }
  /* Sternenfeld-Kante am Sektionsende weich ausblenden (nur die Canvases, nicht die Erde) */
  #sec5 #stage canvas { -webkit-mask-image:linear-gradient(to bottom,#000 88%,transparent 100%);
          mask-image:linear-gradient(to bottom,#000 88%,transparent 100%); }
  /* Rhythmus: dunkle Flow-Sektionen straffen (iPhone: "passiert nichts beim Scrollen") */
  .shSection { padding:10vh var(--sh-pad); }
  .shStep { min-height:52vh; }
  .shStep.tall { min-height:70vh; }
  .shCausal .shStep { min-height:78vh; }
  /* Onion: Datacenter braucht auf dem Telefon Praesenz */
  #sec6b #onionImgs { width:135vw; max-width:none; }
  /* Titel-Umbrueche: feste <br> aufheben, Groessen fuers Telefon */
  .apHead .apTitle { font-size:clamp(34px,10.5vw,48px); }
  .apHead .apTitle br { display:none; }
  .shHero2 .heroTitle { font-size:clamp(32px,9.5vw,46px); }
}
