/* ════════════════════════════════════════════════════════════
   Real Pension · CGRE × VIPE — Vertrieb & Maßnahmen
   Interaktives Pitch-Deck. Engine nach vipe.solutions.
   Design-Sprache angelehnt an real-pension.vipe.solutions:
   Navy #0d1b2a · Gold #b89b6a · Sand/Paper · Fraunces + Hanken Grotesk.
   ════════════════════════════════════════════════════════════ */

:root{
  /* Real Pension — Navy / Gold / Sand */
  --navy:#0d1b2a; --navy-mid:#152236; --navy-light:#1e3050;
  --green-1:#0d1b2a; --green-2:#152236; --green-3:#1e3050;        /* dark gradient (navy) */
  --emerald:#1e3050; --emerald-br:#2a4a7a; --emerald-deep:#0d1b2a; /* "active/structure" */
  --gold:#9c8252; --gold-br:#b89b6a; --gold-light:#c9b084; --champagne:#c9b084;
  --sage:#93a6bd; --sage-soft:#c3d0e0;
  --paper:#fcfbf8; --paper-2:#f5f1ea; --paper-3:#ebe5db;
  --ink:#0d1b2a; --ink-2:#46586a; --ink-3:#6c7d8c;
  --line:#e6dfd2;
  --glow:#c9b084;

  --font-serif:"Fraunces","Georgia",serif;
  --font-sans:"Hanken Grotesk","Helvetica Neue",system-ui,sans-serif;
  --font-mono:"JetBrains Mono","SF Mono",ui-monospace,monospace;

  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-in:cubic-bezier(.64,0,.78,0);
  --ease-spring:cubic-bezier(.34,1.4,.64,1);

  --pad-x:clamp(26px,6vw,118px);
  --pad-y:clamp(90px,11vh,114px);

  --shadow-card:0 1px 2px rgba(13,27,42,.05),0 16px 40px -16px rgba(13,27,42,.18);
  --shadow-pop:0 2px 6px rgba(13,27,42,.08),0 28px 64px -24px rgba(13,27,42,.3);
  --shadow-lg:0 2px 8px rgba(13,27,42,.07),0 44px 90px -36px rgba(13,27,42,.36);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-sans);
  font-size:clamp(15px,1.12vw,19px);line-height:1.55;
  color:var(--ink);background:var(--navy);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow:hidden;transition:background-color .7s ease;
}
body[data-theme="dark"]{background:#0b1622}
body[data-theme="emerald"]{background:#0f1d2e}
body[data-theme="light"]{background:var(--paper-2)}
body.cursor-idle,body.cursor-idle *{cursor:none!important}
body.demo-full{overflow:hidden}
img{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}
:where(button,a,[tabindex]):focus-visible{outline:2px solid color-mix(in oklab,currentColor 70%,transparent);outline-offset:3px;border-radius:6px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* inline-icon system (one stroke width, currentColor) */
.ico{width:1em;height:1em;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;vertical-align:-.14em}

/* ───────────────── chrome ───────────────── */
.chrome{position:fixed;inset:0;z-index:60;pointer-events:none;color:var(--ink);transition:opacity .4s ease}
body[data-theme="dark"] .chrome,body[data-theme="emerald"] .chrome{color:#eaf0f6}
.svg-defs{position:absolute;width:0;height:0;overflow:hidden}

.progress{position:absolute;top:0;left:0;right:0;height:3px;background:color-mix(in oklab,currentColor 14%,transparent)}
.progress span{display:block;height:100%;width:0;background:var(--gold-br);transition:width .6s var(--ease-out)}
body[data-theme="light"] .progress span{background:var(--gold)}

/* CGRE logo (transparent navy PNG; whitened on dark themes) */
.cgre-mark{display:inline-flex;align-items:center}
.cgre-mark img{display:none;width:auto}
.cgre-mark .cgre-word{display:inline-block;font-family:var(--font-sans);font-weight:800;letter-spacing:.13em}
.cgre-mark.has-logo img{display:block}
.cgre-mark.has-logo .cgre-word{display:none}
body[data-theme="dark"] .cgre-mark img,body[data-theme="emerald"] .cgre-mark img{filter:brightness(0) invert(1)}

.brand{position:absolute;top:clamp(15px,2.8vh,28px);left:var(--pad-x);pointer-events:auto;color:inherit;display:flex;align-items:center;transition:opacity .3s ease,transform .15s ease}
.brand .cgre-mark img{height:clamp(22px,2.3vw,30px)}
.brand .cgre-mark .cgre-word{font-size:clamp(20px,2.1vw,30px)}
.brand:hover{opacity:.7}.brand:active{transform:scale(.97)}

.credit{position:absolute;bottom:clamp(15px,2.7vh,26px);left:var(--pad-x);display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.74;transition:opacity .5s ease}
.credit .c-logos{display:inline-flex;align-items:center;gap:10px}
.credit .pl-tpa{width:23px;height:23px;fill:currentColor}
.credit .cgre-mark img{height:15px}
.credit .cgre-mark .cgre-word{font-size:13px}
.credit .c-amp{opacity:.5}
body.chrome-min .credit{opacity:0}
body.ui-idle .hud,body.ui-idle .credit,body.ui-idle .keys-hint{opacity:0;pointer-events:none}
.hud,.keys-hint{transition:opacity .5s ease}

.hud{position:absolute;bottom:calc(clamp(13px,2.5vh,24px) + env(safe-area-inset-bottom,0px));right:var(--pad-x);display:flex;align-items:center;gap:2px;pointer-events:auto;padding:4px;border-radius:999px;background:color-mix(in oklab,currentColor 8%,transparent);backdrop-filter:blur(12px)}
.hud button{display:grid;place-items:center;width:40px;height:40px;border-radius:999px;opacity:.75;transition:opacity .2s,background-color .2s,transform .15s ease}
.hud button:hover{opacity:1;background:color-mix(in oklab,currentColor 12%,transparent)}
.hud button:active{transform:scale(.95)}
.hud button svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.hud-sep{width:1px;height:18px;margin:0 6px;background:currentColor;opacity:.2}
.counter{font-family:var(--font-mono);font-size:11.5px;font-variant-numeric:tabular-nums;letter-spacing:.08em;opacity:.82;min-width:66px;text-align:center}

.keys-hint{position:absolute;bottom:clamp(20px,3.2vh,32px);left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;opacity:0;transition:opacity .8s ease;white-space:nowrap;text-transform:uppercase}
.keys-hint.show{opacity:.5}
.keys-hint kbd{font:inherit;display:inline-block;padding:1px 5px;margin:0 1px;border:1px solid color-mix(in oklab,currentColor 35%,transparent);border-radius:5px}

/* edge tap-zones */
.tapzone{position:fixed;top:0;bottom:0;width:13%;max-width:150px;z-index:40;background:none;cursor:pointer;opacity:0}
.tz-left{left:0}.tz-right{right:0}
body.demo-full .tapzone{display:none}

/* ───────────────── agenda overlay ───────────────── */
.agenda{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:color-mix(in oklab,var(--navy) 92%,transparent);backdrop-filter:blur(22px);opacity:0;transition:opacity .35s ease;color:#eaf0f6}
.agenda[hidden]{display:none}
.agenda:not(.open){pointer-events:none}
.agenda.open{opacity:1}
.agenda-inner{width:min(940px,90vw);max-height:86vh;overflow-y:auto;padding:10px}
.agenda .kicker{color:var(--gold-light);margin-bottom:24px}
.agenda-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;counter-reset:ag}
.agenda-grid li{counter-increment:ag}
.agenda-grid button{position:relative;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;width:100%;height:104px;text-align:left;padding:16px;border-radius:16px;background:rgba(255,255,255,.05);box-shadow:inset 0 0 0 1px rgba(255,255,255,.09);font-size:clamp(14px,1.2vw,17px);font-weight:600;opacity:.82;transition:opacity .2s,background-color .25s,transform .25s var(--ease-out)}
.agenda-grid button::before{content:counter(ag,decimal-leading-zero);position:absolute;top:14px;left:16px;font-family:var(--font-mono);font-size:12px;color:var(--gold-light);opacity:.85}
.agenda-grid button:hover{opacity:1;background:rgba(201,176,132,.16);transform:translateY(-3px)}
.agenda-grid li.current button{opacity:1;background:rgba(201,176,132,.2);box-shadow:inset 0 0 0 1px var(--gold-light)}

/* ───────────────── deck & slides ───────────────── */
.deck{position:fixed;inset:0}
.slide{position:absolute;inset:0;visibility:hidden;opacity:0;transform:translateX(calc(var(--dir,1)*5vw));transition:opacity .6s ease,transform .78s var(--ease-out),visibility 0s linear .82s}
.slide.is-active{visibility:visible;opacity:1;transform:none;z-index:2;transition:opacity .55s ease .12s,transform .82s var(--ease-out) .12s}
.slide.is-leaving{visibility:visible;z-index:1;opacity:0;transform:translateX(calc(var(--dir,1)*-4vw)) scale(.992)}
.wrap{position:relative;z-index:3;width:min(1580px,100%);height:100%;margin-inline:auto;padding:var(--pad-y) var(--pad-x);display:flex;flex-direction:column;justify-content:center}

/* themes */
.slide[data-theme="dark"]{background:linear-gradient(158deg,#1b2c44 0%,#11202f 55%,#0b1622 100%);color:#eaf0f6}
.slide[data-theme="emerald"]{background:linear-gradient(157deg,#243a5e 0%,#16273f 54%,#0f1d2e 100%);color:#eef3f9}
.slide[data-theme="light"]{background:linear-gradient(162deg,#fcfbf8 0%,#f5f1ea 56%,#ece4d4 100%);color:var(--ink)}

/* premium mesh accent */
.mesh{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.mesh::before,.mesh::after{content:"";position:absolute;border-radius:50%;filter:blur(64px);opacity:.55}
.slide[data-theme="dark"] .mesh::before,.slide[data-theme="emerald"] .mesh::before{width:46%;aspect-ratio:1;right:-7%;top:-13%;background:radial-gradient(circle,rgba(184,155,106,.22),transparent 70%)}
.slide[data-theme="dark"] .mesh::after,.slide[data-theme="emerald"] .mesh::after{width:42%;aspect-ratio:1;left:-9%;bottom:-15%;background:radial-gradient(circle,rgba(67,103,160,.28),transparent 70%)}
.slide[data-theme="light"] .mesh::before{width:42%;aspect-ratio:1;right:-7%;top:-12%;background:radial-gradient(circle,rgba(30,48,80,.10),transparent 70%)}
.slide[data-theme="light"] .mesh::after{width:38%;aspect-ratio:1;left:-9%;bottom:-15%;background:radial-gradient(circle,rgba(184,155,106,.16),transparent 70%)}

/* ───────────────── typography ───────────────── */
.kicker{display:flex;align-items:center;gap:11px;font-family:var(--font-mono);font-size:clamp(10px,.78vw,13px);letter-spacing:.22em;text-transform:uppercase;margin-bottom:clamp(16px,3vh,32px);color:color-mix(in oklab,currentColor 74%,transparent)}
.kicker::before{content:"";flex:0 0 auto;width:8px;height:8px;border-radius:2px;background:var(--gold-br);transform:rotate(45deg)}
.display{font-family:var(--font-serif);font-size:clamp(50px,8.6vw,142px);font-weight:400;line-height:1.0;letter-spacing:-.02em;text-wrap:balance}
.headline{font-family:var(--font-serif);font-size:clamp(31px,4.6vw,74px);font-weight:400;line-height:1.05;letter-spacing:-.016em;text-wrap:balance;margin-bottom:clamp(16px,3vh,32px);max-width:24ch}
.lede{font-size:clamp(16px,1.6vw,27px);font-weight:400;color:color-mix(in oklab,currentColor 82%,transparent);line-height:1.42}
.measure{max-width:54ch}
.accent{color:var(--gold-br)}
.slide[data-theme="light"] .accent{color:var(--gold)}
.display .line,.split-lines .line{display:block}

/* enter animations */
[data-a]{opacity:0;translate:0 26px;filter:blur(6px);transition:opacity .76s var(--ease-out),translate .76s var(--ease-out),filter .76s var(--ease-out);transition-delay:var(--d,0s)}
.slide.is-active [data-a].in{opacity:1;translate:0 0;filter:blur(0)}
.split-chars .w{display:inline-block;white-space:nowrap}
.split-chars .c{display:inline-block;opacity:0;translate:0 16px;filter:blur(12px);transition:opacity .9s var(--ease-out),translate .9s var(--ease-out),filter .9s var(--ease-out)}
.slide.is-active .split-chars .c{opacity:1;translate:0 0;filter:blur(0)}

/* ───────────────── generic components ───────────────── */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.6vw,26px)}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.2vw,20px)}
@media(max-width:900px){.grid4{grid-template-columns:1fr 1fr}}
@media(max-width:820px){.grid3{grid-template-columns:1fr}}
@media(max-width:560px){.grid4{grid-template-columns:1fr}}

.os-card{position:relative;padding:clamp(18px,2.2vh,30px) clamp(16px,1.6vw,26px);border-radius:16px;background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12),0 18px 44px -20px rgba(6,14,28,.5)}
.slide[data-theme="light"] .os-card{background:#fff;box-shadow:inset 0 0 0 1px var(--line),var(--shadow-card)}
.os-card .o-ico{display:grid;place-items:center;width:clamp(40px,3.2vw,50px);height:clamp(40px,3.2vw,50px);border-radius:50%;margin-bottom:16px;font-size:clamp(19px,1.6vw,24px);color:var(--gold-light);background:var(--navy)}
.os-card .c-num{font-family:var(--font-mono);font-size:clamp(13px,1.1vw,16px);font-weight:500;color:var(--gold-br);letter-spacing:.06em}
.slide[data-theme="light"] .os-card .c-num{color:var(--gold)}
.os-card .c-date{float:right;font-family:var(--font-mono);font-size:clamp(10px,.84vw,12px);letter-spacing:.04em;opacity:.6;margin-top:2px}
.os-card h3{font-family:var(--font-serif);font-weight:500;font-size:clamp(17px,1.5vw,23px);letter-spacing:-.01em;margin:9px 0 9px;line-height:1.12}
.os-card p{font-size:clamp(12.5px,1vw,15.5px);line-height:1.5;color:color-mix(in oklab,currentColor 80%,transparent);text-wrap:pretty}
.os-card .c-tag{display:inline-block;margin-top:14px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;opacity:.7}

.ticks{list-style:none;max-width:48ch}
.ticks li{position:relative;padding-left:38px;font-size:clamp(15px,1.3vw,21px);line-height:1.34;color:color-mix(in oklab,currentColor 90%,transparent)}
.ticks li+li{margin-top:clamp(12px,2vh,20px)}
.ticks li b{font-weight:700}
.ticks li .ts{display:block;font-size:.72em;opacity:.74;margin-top:3px;line-height:1.35;font-weight:400}
.ticks li>.ico{position:absolute;left:0;top:.04em;width:23px;height:23px;color:var(--gold-br);stroke-width:1.7}
.slide[data-theme="light"] .ticks li>.ico{color:var(--gold)}
.ticks.warn li>.ico{color:var(--gold-br)}

.leitsatz{font-family:var(--font-serif);font-size:clamp(22px,2.7vw,42px);font-weight:400;line-height:1.16;letter-spacing:-.014em;max-width:24ch;margin-bottom:clamp(14px,2.4vh,28px)}

.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:clamp(14px,2.4vh,24px)}
.chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:clamp(11px,.92vw,13.5px);letter-spacing:.02em;padding:.55em 1em;border-radius:999px;background:color-mix(in oklab,currentColor 8%,transparent);box-shadow:inset 0 0 0 1px color-mix(in oklab,currentColor 14%,transparent)}
.chip .ico{width:15px;height:15px;color:var(--gold-br)}
.slide[data-theme="light"] .chip .ico{color:var(--gold)}
.chip b{color:var(--gold-br);font-weight:500}
.slide[data-theme="light"] .chip b{color:var(--gold)}

/* ── 01 · title hero — full-height image feathered into the navy ── */
.s-title .wrap{justify-content:center;align-items:flex-start}
.s-title .title-head{position:relative;z-index:3;max-width:min(62%,680px)}
.s-title .sub{margin-top:clamp(14px,2.4vh,26px);max-width:30ch}
.hero-figure{position:absolute;top:0;bottom:0;right:0;width:min(48%,660px);margin:0;z-index:1;overflow:hidden}
.hf-zoom{position:absolute;inset:0;z-index:1;transform-origin:55% -12%;will-change:transform;animation:sway 6.5s ease-in-out infinite}
.hero-figure img{width:100%;height:100%;object-fit:cover;object-position:58% 46%;display:block;transform:scale(1.1) translate(var(--px,0px),var(--py,0px));transition:transform .4s var(--ease-out)}
/* feather the inner (left) edge + soft top/bottom so the collage melts into the background */
.hero-figure::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(90deg,#0b1622 0%,rgba(11,22,34,.66) 12%,rgba(11,22,34,.14) 33%,transparent 52%),linear-gradient(0deg,rgba(11,22,34,.55),transparent 24%),linear-gradient(180deg,rgba(11,22,34,.5),transparent 20%)}
@keyframes sway{0%,100%{transform:rotate(-0.6deg)}50%{transform:rotate(0.6deg)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(max-width:920px){.hero-figure{width:74%;opacity:.26}.s-title .title-head{max-width:100%}}

/* abstract node accent (kept subtle behind text on mobile fallback) */
.hero-art{display:none}

/* ── interactive layers (Was VIPE leistet) ── */
.layers{display:flex;flex-direction:column;gap:10px;margin-top:clamp(8px,1.8vh,18px)}
.layer{position:relative;display:grid;grid-template-columns:auto minmax(178px,2fr) 5fr;gap:clamp(13px,1.6vw,30px);align-items:center;padding:clamp(12px,1.7vh,20px) clamp(15px,1.5vw,26px);border-radius:15px;cursor:pointer;background:#fff;box-shadow:inset 0 0 0 1px var(--line),var(--shadow-card);transition:background-color .35s,box-shadow .35s,transform .35s var(--ease-out)}
.slide[data-theme="dark"] .layer,.slide[data-theme="emerald"] .layer{background:rgba(255,255,255,.05);box-shadow:inset 0 0 0 1px rgba(255,255,255,.10)}
.layer:hover{transform:translateX(6px)}
.layer .l-ico{display:grid;place-items:center;width:clamp(36px,2.9vw,46px);height:clamp(36px,2.9vw,46px);border-radius:50%;font-size:clamp(18px,1.5vw,23px);color:var(--gold-light);background:var(--navy);transition:transform .35s}
.layer.active{background:linear-gradient(118deg,var(--navy-light),var(--navy));color:#fff;box-shadow:0 20px 48px -20px rgba(13,27,42,.7)}
.layer.active .l-ico{background:rgba(255,255,255,.12);color:var(--gold-light)}
.layer .l-name{font-family:var(--font-serif);font-weight:500;font-size:clamp(16px,1.4vw,23px);letter-spacing:-.01em;line-height:1.1}
.layer .l-sub{display:block;margin-top:3px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;opacity:.66}
.layer .l-items{display:flex;flex-wrap:wrap;gap:7px}
.layer .l-items span{font-size:clamp(12px,.96vw,15px);font-weight:500;padding:.38em .85em;border-radius:999px;background:color-mix(in oklab,currentColor 9%,transparent);transition:opacity .3s}
.layer:not(.active) .l-items span{opacity:.62}
.layer .l-num{position:absolute;top:9px;right:15px;font-family:var(--font-mono);font-size:11px;opacity:.45}
@media(max-width:760px){.layer{grid-template-columns:auto 1fr}.layer .l-items{grid-column:1 / -1}}

/* ── s-build · Funnel, aufeinander aufbauend ── */
.s-build .wrap{justify-content:center}
.build{margin-top:clamp(8px,1.8vh,18px)}
.build-track{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(8px,.9vw,16px);align-items:stretch}
@media(max-width:860px){.build-track{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.build-track{grid-template-columns:1fr}}
.phase{position:relative;display:flex;flex-direction:column;border-radius:15px;padding:clamp(14px,1.8vh,22px) clamp(13px,1.1vw,20px);background:#fff;box-shadow:inset 0 0 0 1px var(--line),0 12px 30px -18px rgba(13,27,42,.4);transition:transform .4s var(--ease-out),box-shadow .4s,background-color .4s}
.slide[data-theme="dark"] .phase,.slide[data-theme="emerald"] .phase{background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);color:#eef3f9}
.phase .ph-top{display:flex;align-items:center;gap:10px;margin-bottom:11px}
.phase .ph-ico{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;font-size:21px;color:var(--gold-light);background:var(--navy);flex:0 0 auto}
.phase .ph-num{font-family:var(--font-mono);font-size:11px;color:var(--gold);letter-spacing:.06em}
.phase h3{font-family:var(--font-serif);font-weight:500;font-size:clamp(16px,1.3vw,21px);letter-spacing:-.01em;line-height:1.1;margin-top:1px}
.phase .ph-tag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;opacity:.58;margin-bottom:12px}
.phase ul{list-style:none;display:flex;flex-direction:column;gap:7px;flex:1}
.phase ul li{position:relative;padding-left:16px;font-size:clamp(11.5px,.92vw,14px);line-height:1.32;color:color-mix(in oklab,currentColor 82%,transparent)}
.phase ul li::before{content:"";position:absolute;left:0;top:.5em;width:6px;height:6px;border-radius:1px;background:var(--gold-br);transform:rotate(45deg)}
.phase .ph-stack{display:flex;gap:3px;margin-top:13px}
.phase .ph-stack i{height:4px;flex:1;border-radius:2px;background:color-mix(in oklab,currentColor 14%,transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-out)}
.phase .ph-stack i.on{background:var(--gold-br)}
.build.lit .phase .ph-stack i.on{transform:scaleX(1)}
.build .phase .ph-stack i:nth-child(1){transition-delay:.1s}
.build .phase .ph-stack i:nth-child(2){transition-delay:.18s}
.build .phase .ph-stack i:nth-child(3){transition-delay:.26s}
.build .phase .ph-stack i:nth-child(4){transition-delay:.34s}
.phase .ph-out{margin-top:13px;padding-top:11px;border-top:1px dashed color-mix(in oklab,currentColor 22%,transparent);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.03em;text-transform:uppercase;display:flex;align-items:center;gap:7px;color:var(--gold)}
.phase .ph-out .ico{width:14px;height:14px}
.phase:hover,.phase.hot{transform:translateY(-6px);box-shadow:0 20px 40px -18px rgba(13,27,42,.5),inset 0 0 0 1.5px var(--gold-br)}
.phase.is-end{background:linear-gradient(150deg,var(--navy-light),var(--navy));color:#fff;box-shadow:0 18px 40px -16px rgba(13,27,42,.7)}
.phase.is-end .ph-ico{background:rgba(255,255,255,.14)}
.phase.is-end .ph-num,.phase.is-end .ph-out{color:var(--gold-light);opacity:.95}
.phase.is-end ul li::before{background:var(--gold-light)}
.build-conn{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(8px,.9vw,16px);margin-top:10px}
@media(max-width:860px){.build-conn{display:none}}
.bc-cell{position:relative;height:24px}
.bc-cell .bc-line{position:absolute;left:50%;right:-50%;top:50%;height:2px;background:linear-gradient(90deg,var(--gold-br),var(--gold-light));transform:scaleX(0);transform-origin:left;transition:transform .55s var(--ease-out)}
.bc-cell:last-child .bc-line{display:none}
.build.lit .bc-cell .bc-line{transform:scaleX(1)}
.build.lit .bc-cell:nth-child(1) .bc-line{transition-delay:.2s}
.build.lit .bc-cell:nth-child(2) .bc-line{transition-delay:.5s}
.build.lit .bc-cell:nth-child(3) .bc-line{transition-delay:.8s}

/* data-standard thread (navy band) */
.thread{margin-top:clamp(12px,2.2vh,22px);border-radius:14px;padding:clamp(13px,1.8vh,20px) clamp(18px,1.8vw,30px);background:linear-gradient(118deg,var(--navy-light),var(--navy));color:#eef3f9;display:flex;align-items:center;gap:14px;box-shadow:0 20px 44px -22px rgba(13,27,42,.7)}
.thread .th-ico{flex:0 0 auto;display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:rgba(201,176,132,.16);color:var(--gold-light);font-size:21px}
.thread b{font-family:var(--font-sans);font-weight:800;letter-spacing:.05em;text-transform:uppercase;font-size:clamp(12px,1vw,15px)}
.thread span{display:block;margin-top:3px;font-size:clamp(12px,.98vw,15px);opacity:.86}

/* ── financing fan-out (s-ai) ── */
.fan{display:grid;grid-template-columns:minmax(220px,1fr) 2.15fr;gap:clamp(20px,3vw,58px);align-items:center;margin-top:clamp(8px,1.6vh,16px)}
@media(max-width:860px){.fan{grid-template-columns:1fr}}
.fan-in{position:relative}
.fan-in .fi-cap{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;opacity:.6;margin-bottom:9px}
.brief-card{border-radius:16px;padding:20px;background:rgba(255,255,255,.07);box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
.slide[data-theme="light"] .brief-card{background:#fff;box-shadow:inset 0 0 0 1px var(--line),var(--shadow-card)}
.brief-card .bk{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.66}
.brief-card .bl{display:flex;align-items:center;gap:10px;margin-top:11px;font-size:clamp(12.5px,1.02vw,15.5px)}
.brief-card .bl .ico{width:17px;height:17px;color:var(--gold-br);flex:0 0 auto}
.run-btn{margin-top:16px;display:inline-flex;align-items:center;gap:10px;pointer-events:auto;padding:.74em 1.4em;border-radius:999px;background:var(--gold);color:var(--navy);font-family:var(--font-sans);font-weight:700;font-size:13.5px;letter-spacing:.01em;box-shadow:0 14px 30px -12px rgba(184,155,106,.7);transition:transform .2s,box-shadow .2s,background-color .2s}
.run-btn:hover{transform:translateY(-2px);background:var(--gold-light)}.run-btn:active{transform:translateY(0) scale(.98)}
.run-btn .ico{width:16px;height:16px}
.fan-flow{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;opacity:.55;margin:10px 0 0}
.fan-out{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
@media(max-width:560px){.fan-out{grid-template-columns:1fr}}
.out-card{border-radius:15px;overflow:hidden;background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);opacity:0;transform:translateY(18px) scale(.96);filter:blur(6px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out),filter .6s var(--ease-out);transition-delay:var(--d,0s)}
.slide[data-theme="light"] .out-card{background:#fff;box-shadow:inset 0 0 0 1px var(--line),var(--shadow-card)}
.fan.run .out-card{opacity:1;transform:none;filter:blur(0)}
.out-card .oc-bar{height:5px;background:linear-gradient(90deg,var(--navy),var(--gold-br))}
.out-card .oc-body{padding:14px 15px 16px}
.out-card .oc-k{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-br);opacity:.95}
.slide[data-theme="light"] .out-card .oc-k{color:var(--gold)}
.out-card h4{font-family:var(--font-serif);font-weight:500;font-size:clamp(15px,1.2vw,19px);margin:6px 0 9px;letter-spacing:-.01em}
.dotpulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold-br);opacity:.4}
.fan.run .oc-k .dotpulse{animation:blink 1.3s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.gen-check{display:flex;flex-direction:column;gap:8px}
.gen-check .gc{display:flex;align-items:center;gap:9px;font-size:12.5px;opacity:0;transform:translateX(-6px);transition:opacity .4s var(--ease-out),transform .4s var(--ease-out)}
.gen-check .gc .ico{width:15px;height:15px;color:#4f8a6a;flex:0 0 auto}
.slide[data-theme="light"] .gen-check .gc .ico{color:#3f7d57}
.fan.run .oc-check .gc{opacity:1;transform:none}
.fan.run .oc-check .gc:nth-child(1){transition-delay:.30s}
.fan.run .oc-check .gc:nth-child(2){transition-delay:.44s}
.fan.run .oc-check .gc:nth-child(3){transition-delay:.58s}
.fan.run .oc-check .gc:nth-child(4){transition-delay:.72s}
.gen-bank{display:flex;flex-direction:column;gap:9px}
.gen-bank .br{display:flex;align-items:center;gap:9px;font-size:12px}
.gen-bank .br .bn{flex:1;font-family:var(--font-mono);letter-spacing:.02em;opacity:.82}
.gen-bank .br .amp{width:11px;height:11px;border-radius:50%;background:color-mix(in oklab,currentColor 18%,transparent);transition:background-color .4s;opacity:0}
.fan.run .oc-bank .br .amp{opacity:1}
.gen-bank .br .amp.g{background:#4f8a6a}.gen-bank .br .amp.y{background:#c9a24a}.gen-bank .br .amp.r{background:#bf6a52}
.gen-bank .br .cond{font-family:var(--font-mono);font-size:10px;opacity:.6;white-space:nowrap}
.fan.run .oc-bank .br:nth-child(1) .amp{transition-delay:.34s}
.fan.run .oc-bank .br:nth-child(2) .amp{transition-delay:.5s}
.fan.run .oc-bank .br:nth-child(3) .amp{transition-delay:.66s}
.gen-doc{display:flex;flex-direction:column;gap:8px;padding-top:2px}
.gen-doc .g-h{height:11px;width:72%;border-radius:3px;background:linear-gradient(90deg,var(--navy),var(--gold-br));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-out)}
.gen-doc .g-line{height:7px;border-radius:3px;background:color-mix(in oklab,currentColor 16%,transparent);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease-out)}
.gen-doc .g-line.s{width:54%}
.fan.run .oc-doc .g-h{transform:scaleX(1);transition-delay:.1s}
.fan.run .oc-doc .g-line{transform:scaleX(1)}
.fan.run .oc-doc .l1{transition-delay:.34s}.fan.run .oc-doc .l2{transition-delay:.5s}
.fan.run .oc-doc .l3{transition-delay:.66s}.fan.run .oc-doc .l4{transition-delay:.82s}
.fan-note{grid-column:1 / -1;margin-top:12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;opacity:.62;display:flex;align-items:center;gap:9px}
.fan-note::before{content:"";width:7px;height:7px;border-radius:50%;background:#4f8a6a;animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(79,138,106,.5)}70%{box-shadow:0 0 0 9px rgba(79,138,106,0)}100%{box-shadow:0 0 0 0 rgba(79,138,106,0)}}

/* ── slide 2 · image figure (analytics, harmonised) ── */
.split-media{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(26px,4vw,72px);align-items:center}
@media(max-width:900px){.split-media{grid-template-columns:1fr}.split-media .fig-card{display:none}}
.fig-card{position:relative;border-radius:14px;overflow:hidden;will-change:transform;min-height:clamp(220px,30vh,340px)}
.fig-card img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.07) translate(var(--px,0),var(--py,0));transition:transform .35s var(--ease-out);filter:grayscale(.55) contrast(1.05) brightness(1.05)}
.fig-card::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(150deg,rgba(30,48,80,.4),rgba(184,155,106,.16));mix-blend-mode:multiply}
/* feather inner edges into the slide background + bottom scrim for the caption */
.fig-card::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(90deg,#16273f 0%,rgba(22,39,63,.5) 9%,transparent 26%),linear-gradient(0deg,rgba(13,24,40,.92) 0%,rgba(13,24,40,.22) 27%,transparent 42%),linear-gradient(180deg,rgba(22,39,63,.42),transparent 16%)}
.fig-cap{position:absolute;left:18px;right:18px;bottom:15px;z-index:3;font-family:var(--font-mono);font-size:clamp(11px,.98vw,13.5px);font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-light);text-shadow:0 1px 10px rgba(0,0,0,.7)}

/* ── slide 5 · Engpass-Visualisierung ── */
.engpass{display:grid;grid-template-columns:1fr .9fr;gap:clamp(24px,3.6vw,64px);align-items:center}
@media(max-width:920px){.engpass{grid-template-columns:1fr}}
.ev{position:relative;border-radius:18px;padding:clamp(18px,2.4vh,30px);background:linear-gradient(155deg,#22365a,#11202f);color:#eef3f9;box-shadow:var(--shadow-lg);overflow:hidden}
.ev-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ev-head .ev-clock{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--gold-light)}
.ev-head .ev-clock .ico{width:18px;height:18px}
.ev-count{font-family:var(--font-serif);font-size:clamp(28px,3.4vw,46px);line-height:1;color:var(--gold-light)}
.ev-count span{font-size:.42em;font-family:var(--font-mono);letter-spacing:.04em;opacity:.7;display:block;text-transform:uppercase;margin-top:4px}
.ev-srcs{display:flex;gap:7px;margin-bottom:13px;flex-wrap:wrap}
.ev-srcs span{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;padding:.32em .7em;border-radius:999px;opacity:.92}
.ev-srcs .s1{background:rgba(201,176,132,.2);color:var(--gold-light)}
.ev-srcs .s2{background:rgba(120,150,200,.22);color:#bcd0ee}
.ev-srcs .s3{background:rgba(180,140,150,.22);color:#e3c2c8}
.ev-docs{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
@media(max-width:520px){.ev-docs{grid-template-columns:repeat(5,1fr)}}
.ev-doc{aspect-ratio:3/4;border-radius:4px;background:rgba(255,255,255,.08);box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);position:relative}
.ev-doc::before{content:"";position:absolute;left:14%;right:14%;top:22%;height:2px;background:rgba(255,255,255,.22);box-shadow:0 4px 0 rgba(255,255,255,.16),0 8px 0 rgba(255,255,255,.12)}
.ev-doc.t1{background:rgba(201,176,132,.16)}.ev-doc.t2{background:rgba(120,150,200,.16)}.ev-doc.t3{background:rgba(180,140,150,.16)}
.ev-doc.miss{box-shadow:inset 0 0 0 1.5px var(--gold-light)}
.ev-stamp{position:absolute;right:clamp(14px,2vw,26px);bottom:clamp(14px,2vh,24px);font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#0d1b2a;background:var(--gold-light);padding:.45em .9em;border-radius:8px;transform:rotate(-4deg);box-shadow:0 8px 20px -8px rgba(0,0,0,.5)}

/* ── slide 7 · live demo browser ── */
.demo-wrap{margin-top:clamp(8px,1.6vh,16px)}
.browser{display:flex;flex-direction:column;border-radius:14px;overflow:hidden;background:var(--navy);box-shadow:var(--shadow-lg);height:clamp(240px,38vh,420px)}
/* process slide: top-aligned + compact so kicker always clears the logo */
.s-process .wrap{justify-content:flex-start}
.s-process .headline{font-size:clamp(28px,3.7vw,56px);margin-bottom:clamp(10px,1.8vh,18px)!important}
.s-process .grid4{gap:clamp(10px,1vw,16px)}
.s-process .os-card{padding:clamp(13px,1.6vh,20px) clamp(13px,1.2vw,19px)}
.s-process .os-card p{font-size:clamp(12px,.95vw,14.5px)}
.browser-bar{display:flex;align-items:center;gap:12px;padding:9px 13px;background:#11202f;border-bottom:1px solid rgba(255,255,255,.08)}
.browser-bar .dots{display:flex;gap:6px}
.browser-bar .dots i{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.18)}
.browser-bar .url{flex:1;font-family:var(--font-mono);font-size:11.5px;letter-spacing:.02em;color:#bcd0ee;opacity:.8;text-align:center}
.bb-btn{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.7);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;padding:5px 9px;border-radius:8px;pointer-events:auto;transition:color .2s,background-color .2s,transform .15s}
.bb-btn:hover{color:#fff;background:rgba(255,255,255,.09)}.bb-btn:active{transform:scale(.96)}
.bb-btn svg{width:14px;height:14px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.browser.is-full #demo-fs .ic-expand{display:none}
.browser:not(.is-full) #demo-fs .ic-compress{display:none}
.browser.is-full{position:fixed;inset:24px;z-index:90;height:auto}
.browser-body{position:relative;flex:1;min-height:0}
.browser-body iframe{width:100%;height:100%;border:0;background:#fff;display:block}
.demo-cover{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:linear-gradient(155deg,#22365a,#0d1b2a);color:#eef3f9;pointer-events:auto;transition:opacity .5s ease,visibility .5s}
.demo-cover.hidden{opacity:0;visibility:hidden;pointer-events:none}
.demo-play{display:grid;place-items:center;width:66px;height:66px;border-radius:50%;background:var(--gold);color:var(--navy);box-shadow:0 16px 40px -14px rgba(184,155,106,.8);transition:scale .25s var(--ease-out)}
.demo-cover:hover .demo-play{scale:1.08}.demo-cover:active .demo-play{scale:.96}
.demo-play svg{width:26px;height:26px;fill:currentColor;margin-left:3px}
.demo-label{font-family:var(--font-serif);font-size:clamp(19px,1.8vw,27px);letter-spacing:-.01em}
.demo-sub{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;opacity:.6}

/* ── KPI tiles + transform ── */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,32px);margin-top:clamp(10px,2vh,24px)}
@media(max-width:820px){.kpis{grid-template-columns:1fr}}
.kpi{border-radius:18px;padding:clamp(22px,3vh,38px) clamp(20px,2vw,32px);background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.slide[data-theme="light"] .kpi{background:#fff;box-shadow:inset 0 0 0 1px var(--line),var(--shadow-card)}
.kpi .k-num{font-family:var(--font-serif);font-size:clamp(46px,6.4vw,102px);line-height:.92;letter-spacing:-.02em;color:var(--gold)}
.kpi h3{font-family:var(--font-serif);font-weight:500;font-size:clamp(16px,1.3vw,21px);letter-spacing:-.01em;margin:14px 0 8px}
.kpi p{font-size:clamp(12.5px,1vw,15.5px);line-height:1.45;color:color-mix(in oklab,currentColor 80%,transparent)}
/* transform KPI: Wochen → Tage */
.kx{display:flex;flex-direction:column;gap:10px;margin:4px 0 2px}
.kx-row{display:flex;align-items:center;gap:11px}
.kx-row .kl{flex:0 0 58px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;opacity:.7}
.kx-bar{height:14px;border-radius:7px;background:color-mix(in oklab,currentColor 12%,transparent);position:relative;flex:1;overflow:hidden}
.kx-bar i{position:absolute;left:0;top:0;bottom:0;border-radius:7px;transform:scaleX(0);transform-origin:left;transition:transform .9s var(--ease-out)}
.kx-row.was .kx-bar i{background:color-mix(in oklab,var(--ink-2) 60%,transparent);width:100%}
.slide[data-theme="light"] .kx-row.was .kx-bar i{background:#9aa7b6}
.kx-row.now .kx-bar i{background:var(--gold);width:26%}
.kv{flex:0 0 auto;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;opacity:.78}
.kx-row.now .kv{color:var(--gold);opacity:1;font-weight:500}
.kpi.kpi-x.lit .kx-row.was .kx-bar i{transform:scaleX(1);transition-delay:.2s}
.kpi.kpi-x.lit .kx-row.now .kx-bar i{transform:scaleX(1);transition-delay:.5s}
.kx-cap{margin-top:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.02em;opacity:.7}

/* ── closing ── */
.s-closing .wrap{justify-content:center}
.s-closing.has-fig .wrap{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(26px,4vw,68px);align-items:center}
.s-closing.has-fig .display{font-size:clamp(38px,5vw,84px)}
.close-main{min-width:0}
@media(max-width:920px){.s-closing.has-fig .wrap{grid-template-columns:1fr}.close-fig{display:none}}
.close-fig{position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg);background:#f4efe6;will-change:transform;animation:floaty 7s ease-in-out infinite}
.close-fig img{width:100%;height:auto;display:block;transform:scale(1.03) translate(var(--px,0),var(--py,0));transition:transform .35s var(--ease-out)}
.close-fig::after{content:"";position:absolute;inset:0;border-radius:16px;box-shadow:inset 0 0 0 1px rgba(201,176,132,.5);pointer-events:none}
.close-lockup{display:flex;align-items:center;gap:16px;margin-top:clamp(20px,4vh,40px);flex-wrap:wrap}
.close-lockup .cl-word{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.66}
.close-lockup .cl-logo{display:inline-flex;align-items:center;gap:10px}
.close-lockup .cl-logo .pl-tpa{width:28px;height:28px;fill:currentColor}
.close-lockup .cgre-mark img{height:26px}
.close-lockup .cgre-mark .cgre-word{font-size:22px}
.close-lockup .cl-amp{opacity:.5}
.close-contact{margin-top:clamp(22px,4vh,48px);display:grid;grid-template-columns:auto auto;gap:6px 34px;justify-content:start;font-family:var(--font-mono);font-size:clamp(11.5px,.95vw,14px);letter-spacing:.02em;line-height:1.7;opacity:.86}
.close-contact .cc-h{font-weight:500;color:var(--gold-light);text-transform:uppercase;letter-spacing:.1em;font-size:11px}
.close-contact a{color:var(--sage-soft)}
.disc{margin-top:22px;max-width:84ch;font-size:10px;line-height:1.5;opacity:.45}

@media(max-width:680px){
  .layer{grid-template-columns:auto 1fr}
  .close-contact{grid-template-columns:1fr;gap:4px 0}
  .close-contact .cc-h{margin-top:10px}
  .engpass,.split-media{gap:20px}
}

/* ───────────────── reduced motion ───────────────── */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01s!important;animation:none!important;scroll-behavior:auto!important}
  .slide{transform:none!important}
  [data-a]{opacity:1!important;translate:none!important;filter:none!important}
  .split-chars .c{opacity:1!important;translate:none!important;filter:none!important}
  .build.lit .bc-cell .bc-line,.phase .ph-stack i.on{transform:scaleX(1)!important}
  .hero-figure{animation:none!important}
  .kpi.kpi-x.lit .kx-bar i{transform:scaleX(1)!important}
  .fan.run .out-card,.fan.run .oc-check .gc{opacity:1!important;transform:none!important;filter:none!important}
}
