/* ═══════════════════ LOKALE FONTS — DSGVO-konform ═══════════════════
   Kein Request an Google-Server. Fonts liegen unter /assets/fonts/
   Fehlende Gewichte (300, 600) nutzen den nächstgelegenen vorhandenen Schnitt.
*/

/* Bebas Neue — Display / Headlines */
@font-face {
  font-family: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/bebas-neue-400.woff2') format('woff2');
}

/* Asap — Body / Interface */
@font-face {
  font-family: 'Asap';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/asap-400.woff2') format('woff2'); /* 300 nicht verfügbar, nutzt 400 */
}
@font-face {
  font-family: 'Asap';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/asap-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Asap';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/asap-400-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Asap';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/asap-400.woff2') format('woff2'); /* 500 nicht verfügbar, nutzt 400 */
}
@font-face {
  font-family: 'Asap';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/asap-700.woff2') format('woff2'); /* 600 nicht verfügbar, nutzt 700 */
}
@font-face {
  font-family: 'Asap';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/asap-700.woff2') format('woff2');
}

/* DM Sans — Extended Text */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/dm-sans-400.woff2') format('woff2'); /* 300 nicht verfügbar, nutzt 400 */
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/dm-sans-400.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/dm-sans-400-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/dm-sans-500.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/dm-sans-700.woff2') format('woff2');
}

/* JetBrains Mono — Code / Technical */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/jetbrains-mono-400.woff2') format('woff2'); /* 300 nicht verfügbar, nutzt 400 */
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/jetbrains-mono-400.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/jetbrains-mono-500.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/jetbrains-mono-700.woff2') format('woff2');
}

:root {
  --black: #050505;
  --near: #0A0A0A;
  --dark: #111;
  --card: #131313;
  --mid: #1A1A1A;
  --border: #1E1E1E;
  --silver: #666;
  --light: #999;
  --text: #BBB;
  --white: #E8E8E8;
  --orange: #FF6B00;
  --orange-hover: #FF8A2B;
  --orange-dim: rgba(255,107,0,0.06);
  --orange-glow: rgba(255,107,0,0.12);
  --deep-blue: #0A1628;
  --green: #00FF88;
  --red: #FF4455;
  --gold: #FFAA00;
}
/* ═══════════════════ A11Y: SKIP LINK ═══════════════════ */
.skip-link{position:absolute;top:-80px;left:8px;background:var(--orange);color:var(--black);padding:12px 24px;font-family:'JetBrains Mono';font-size:12px;letter-spacing:2px;text-transform:uppercase;z-index:9999;transition:top 0.2s;text-decoration:none;font-weight:600}
.skip-link:focus{top:8px;outline:3px solid var(--white);outline-offset:2px}
#main-content:focus{outline:none}

/* ═══════════════════ A11Y: FOCUS VISIBLE ═══════════════════ */
*:focus-visible{outline:2px solid var(--orange);outline-offset:3px;border-radius:2px}
button:focus-visible,a:focus-visible{outline-offset:4px}

/* ═══════════════════ A11Y: REDUCED MOTION ═══════════════════ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
    scroll-behavior:auto!important
  }
  .scroll-track{animation:none!important}
  .reveal{opacity:1!important;transform:none!important}
}

/* ═══════════════════ PRINT STYLES ═══════════════════ */
@media print{
  body{background:white;color:black}
  .nav,.scroll-banner,#heroCanvas,#racingCanvas,.hero::before,.hero-racing-photo,.cta-section::before,footer{display:none!important}
  .hero h1,.section-headline,.diagnostic-mockup{color:black!important}
  .impact-card,.process-card,.analogy-card{break-inside:avoid;border:1px solid #ccc!important;box-shadow:none!important;background:white!important;color:black!important}
  a{color:black;text-decoration:underline}
  *{background:transparent!important;color:black!important;box-shadow:none!important}
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--black);color:var(--white);font-family:'DM Sans',sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.7}
a{color:inherit;text-decoration:none}
::selection{background:var(--orange);color:var(--black)}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:var(--orange)}
body::after{content:'';position:fixed;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:9}

/* ═══════════════════ NAV ═══════════════════ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 48px;height:68px;display:flex;justify-content:space-between;align-items:center;background:rgba(5,5,5,0.92);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);transition:all 0.4s}
.nav.scrolled{height:54px;background:rgba(5,5,5,0.97)}
.nav-left{display:flex;align-items:center;gap:16px}
.nav-logo{font-family:'Bebas Neue';font-size:20px;letter-spacing:5px;display:flex;align-items:center;gap:10px}
.nav-logo span{color:var(--orange)}
.nav-right{display:flex;align-items:center;gap:24px}
.nav-links{display:flex;gap:24px;align-items:center;list-style:none}
.nav-links a{font-family:'Asap';font-size:13px;font-weight:500;letter-spacing:1.8px;text-transform:uppercase;color:var(--white);opacity:0.85;transition:all 0.3s}
.nav-links a:hover{color:var(--orange);opacity:1}
.nav-cta{font-family:'Asap';font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--black)!important;background:var(--orange);padding:10px 20px;transition:all 0.3s}
.nav-cta:hover{background:var(--orange-hover)}
.nav-cta:focus-visible{outline-color:var(--black);outline-offset:2px}
.nav-cta-short{display:none}
.nav-sponsor{display:flex;align-items:center;gap:12px;border-left:1px solid rgba(255,107,0,0.3);padding-left:20px;margin-left:8px}
.nav-sponsor-label{font-family:'JetBrains Mono';font-size:11px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--silver);line-height:1.4;text-align:right;white-space:nowrap}
.nav-sponsor-logo{height:40px;width:auto;opacity:0.9;transition:opacity 0.3s}
.nav-sponsor:hover .nav-sponsor-logo{opacity:1}

/* ═══════════════════ HERO ═══════════════════ */
.hero{min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:120px 48px 60px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(255,255,255,0.005) 3px,rgba(255,255,255,0.005) 6px)}
#heroCanvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;opacity:0.625}
.hero-racing-photo{position:absolute;top:0;right:0;width:80%;height:100%;z-index:2;background-size:cover;background-position:20% center;background-repeat:no-repeat;-webkit-mask-image:linear-gradient(to right,rgba(0,0,0,0) 0%,rgba(0,0,0,0.5) 100%);mask-image:linear-gradient(to right,rgba(0,0,0,0) 0%,rgba(0,0,0,0.5) 100%);pointer-events:none}
.hero-content{position:relative;z-index:5;max-width:900px}
.hero-eyebrow{font-family:'JetBrains Mono';font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--orange);margin-bottom:24px;display:flex;align-items:center;gap:16px;opacity:0;animation:fadeSlideUp .8s .3s forwards}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--orange)}
.hero h1{font-family:'Bebas Neue';font-size:clamp(52px,8vw,110px);line-height:0.92;letter-spacing:-1px;margin-bottom:32px;opacity:0;animation:fadeSlideUp .8s .5s forwards}
.hero h1 .dim{color:var(--mid)}
.hero h1 .accent{color:var(--orange)}
.hero-body{font-size:18px;font-weight:300;color:var(--text);line-height:1.7;max-width:600px;margin-bottom:48px;opacity:0;animation:fadeSlideUp .8s .7s forwards}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;position:relative;z-index:10;opacity:0;animation:fadeSlideUp .8s .9s forwards}
.btn-primary{display:inline-flex;align-items:center;gap:12px;font-family:'Asap';font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--black);background:var(--orange);padding:16px 32px;border:none;cursor:pointer;transition:all 0.3s;position:relative;z-index:10}
.btn-primary:hover{background:var(--orange-hover);gap:18px}
.btn-secondary{display:inline-flex;align-items:center;gap:12px;font-family:'Asap';font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--orange);background:transparent;padding:16px 32px;border:1px solid rgba(255,107,0,0.3);transition:all 0.3s;position:relative;z-index:10}
.btn-secondary:hover{border-color:var(--orange);background:var(--orange-dim)}
.hero-stats{position:relative;z-index:5;display:flex;gap:56px;border-top:1px solid var(--border);padding-top:32px;margin-top:60px;opacity:0;animation:fadeSlideUp .8s 1.1s forwards}
.stat-num{font-family:'Bebas Neue';font-size:56px;color:var(--orange);line-height:1}
.stat-label{font-family:'JetBrains Mono';font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--light);margin-top:8px}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════ SHARED ═══════════════════ */
.section-eyebrow{font-family:'JetBrains Mono';font-size:12px;font-weight:500;letter-spacing:5px;text-transform:uppercase;color:var(--orange);margin-bottom:24px;display:flex;align-items:center;gap:16px}
.section-eyebrow::before{content:'';width:36px;height:1px;background:var(--orange)}
.section-headline{font-family:'Bebas Neue';font-size:clamp(38px,5.2vw,76px);line-height:1;letter-spacing:1px;margin-bottom:32px}
.section-headline .accent{color:var(--orange)}
.section-body{font-size:16px;color:var(--text);line-height:1.8;max-width:650px;margin-bottom:32px}

/* ═══════════════════ SCROLL BANNER ═══════════════════ */
.scroll-banner{padding:20px 0;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--near)}
.scroll-track{display:inline-flex;gap:40px;animation:marquee 35s linear infinite;white-space:nowrap;font-family:'Bebas Neue';font-size:18px;letter-spacing:5px;color:var(--text);opacity:0.6}
.scroll-banner .hl{color:var(--orange);opacity:0.45}
.scroll-track .hl{color:var(--orange)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════ RACING HERO ═══════════════════ */
.racing-hero{position:relative;min-height:90vh;min-height:90svh;display:flex;align-items:center;overflow:hidden;border-bottom:1px solid var(--border);background:linear-gradient(45deg, rgba(255,255,255,0.025) 25%, transparent 25%, transparent 75%, rgba(255,255,255,0.025) 75%) 0 0 / 8px 8px,linear-gradient(45deg, rgba(255,255,255,0.025) 25%, transparent 25%, transparent 75%, rgba(255,255,255,0.025) 75%) 4px 4px / 8px 8px,linear-gradient(135deg, rgba(0,0,0,0.35) 25%, transparent 25%, transparent 75%, rgba(0,0,0,0.35) 75%) 0 0 / 8px 8px,linear-gradient(135deg, rgba(0,0,0,0.35) 25%, transparent 25%, transparent 75%, rgba(0,0,0,0.35) 75%) 4px 4px / 8px 8px,radial-gradient(ellipse at 50% 50%, #131313 0%, var(--black) 70%, var(--black) 100%)}
.racing-hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;background:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(255,255,255,0.025) 3px,rgba(255,255,255,0.025) 5px),repeating-linear-gradient(-45deg,transparent,transparent 3px,rgba(255,255,255,0.025) 3px,rgba(255,255,255,0.025) 5px);background-size:7px 7px,7px 7px}
.racing-hero::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;background:radial-gradient(ellipse at 30% 50%,rgba(255,107,0,0.04) 0%,transparent 60%),radial-gradient(ellipse at 80% 30%,rgba(255,107,0,0.02) 0%,transparent 50%)}
#racingCanvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;opacity:0.6}
.racing-hero-content{max-width:1300px;margin:0 auto;padding:80px 48px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;width:100%;position:relative;z-index:2}
.racing-hero-text h2{font-family:'Bebas Neue';font-size:clamp(40px,5vw,80px);line-height:0.95;letter-spacing:1px;margin-bottom:24px}
.racing-hero-text h2 .accent{color:var(--orange)}
.racing-hero-body{font-size:17px;color:var(--text);line-height:1.8;margin-bottom:32px;font-weight:300}
.racing-meta{display:flex;gap:40px;margin-bottom:40px}
.racing-meta-num{font-family:'Bebas Neue';font-size:36px;color:var(--orange)}
.racing-meta-label{font-family:'JetBrains Mono';font-size:9px;letter-spacing:2px;color:var(--light);text-transform:uppercase;margin-top:4px}
.analogy-stack{display:flex;flex-direction:column;gap:3px}
.analogy-card{background:linear-gradient(135deg, rgba(255,107,0,0.025) 0%, var(--card) 50%, rgba(255,107,0,0.015) 100%);border:1px solid var(--border);padding:28px;transition:all 0.3s;position:relative;overflow:visible;box-shadow:0 0 30px rgba(255,107,0,0.08), 0 0 60px rgba(255,107,0,0.04)}
.analogy-card:hover{border-color:var(--orange);background:linear-gradient(135deg, rgba(255,107,0,0.05) 0%, var(--card) 50%, rgba(255,107,0,0.03) 100%);box-shadow:0 0 40px rgba(255,107,0,0.18), 0 0 80px rgba(255,107,0,0.08)}
.analogy-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--orange);opacity:0.4;transition:opacity 0.3s;box-shadow:0 0 12px rgba(255,107,0,0.5)}
.analogy-card::after{content:'';position:absolute;top:50%;left:50%;width:120%;height:140%;transform:translate(-50%,-50%);background:radial-gradient(ellipse at center, rgba(255,107,0,0.06) 0%, rgba(255,107,0,0.02) 40%, transparent 70%);pointer-events:none;z-index:-1;animation:telemetryPulse 4s ease-in-out infinite}
@keyframes telemetryPulse{0%,100%{opacity:0.6}50%{opacity:1}}
.analogy-card:hover::before{opacity:1}
.analogy-label{font-family:'JetBrains Mono';font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:6px}
.analogy-card h4{font-family:'Bebas Neue';font-size:20px;letter-spacing:2px;margin-bottom:6px}
.analogy-card p{font-size:13px;color:var(--light);line-height:1.6}

/* ═══════════════════ PARTNERS STRIP ═══════════════════ */
.partners-strip{display:flex;justify-content:center;align-items:center;gap:48px;padding:24px 48px;border-bottom:1px solid var(--border);background:var(--near)}
.partner-item{font-family:'JetBrains Mono';font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--light);transition:color 0.3s}
.partner-item:hover{color:var(--orange)}
.partner-sep{color:var(--border);font-size:14px}

/* ═══════════════════ FORMLINING DEF ═══════════════════ */
.FORMlining-def{padding:120px 48px;background:linear-gradient(135deg,var(--black) 0%,var(--deep-blue) 50%,var(--black) 100%);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.FORMlining-def-inner{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.def-badge{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--orange);border:1px solid rgba(255,107,0,0.3);padding:8px 16px;margin-bottom:24px}
.def-text h2{font-family:'Bebas Neue';font-size:clamp(36px,4vw,64px);line-height:1;letter-spacing:1px;margin-bottom:28px}
.def-text h2 .accent{color:var(--orange)}
.def-body{font-size:16px;color:var(--text);line-height:1.8;margin-bottom:24px}
.def-body strong{color:var(--white)}
.def-highlight{font-size:18px;color:var(--orange);font-weight:500;line-height:1.7;padding:20px 0;border-top:1px solid rgba(255,107,0,0.15);margin-top:16px}
.def-notation{display:grid;gap:16px}
.def-notation-card{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);padding:24px;transition:all 0.3s;position:relative}
.def-notation-card:hover{border-color:var(--orange)}
.def-notation-card h4{font-family:'JetBrains Mono';font-size:11px;letter-spacing:2px;color:var(--orange);margin-bottom:8px}
.def-notation-card p{font-size:13px;color:var(--light);line-height:1.6}
.ist-soll-viz{margin-top:32px;padding:40px;background:var(--card);border:1px solid var(--border)}
.ist-soll-viz svg text{font-family:'Bebas Neue',sans-serif}
.ist-soll-viz svg .mono-text{font-family:'JetBrains Mono',monospace}

/* ═══════════════════ PROBLEM ═══════════════════ */
.problem-section{padding:140px 48px;background:var(--near);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.problem-inner{max-width:1300px;margin:0 auto}
.problem-headline{font-family:'Bebas Neue';font-size:clamp(36px,5vw,72px);line-height:1;letter-spacing:1px;margin-bottom:48px;max-width:800px}
.problem-headline .accent{color:var(--orange)}
.problem-headline .flow-word{display:inline-block;animation:flowPulse 3s ease-in-out infinite;animation-delay:var(--d,0s)}
@keyframes flowPulse{0%,100%{opacity:1;transform:translateY(0)}50%{opacity:.7;transform:translateY(-3px);color:var(--orange)}}
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:40px}
.problem-card{background:var(--card);padding:44px 36px;border:1px solid transparent;transition:all 0.4s;position:relative;overflow:hidden}
.problem-card:hover{border-color:var(--orange);background:var(--mid)}
.problem-card::before{content:'';position:absolute;top:0;left:0;right:0;height:0;background:linear-gradient(to bottom,var(--orange-glow),transparent);transition:height 0.4s}
.problem-card:hover::before{height:80px}
.problem-card h3{font-family:'Bebas Neue';font-size:20px;letter-spacing:2px;margin-bottom:10px;position:relative;z-index:2}
.problem-card p{font-size:14px;color:var(--light);line-height:1.7;position:relative;z-index:2}
.problem-icon-svg{width:80px;height:80px;margin-bottom:24px;position:relative;z-index:2}

/* ═══════════════════ IMPACT ═══════════════════ */
.impact-section{padding:100px 48px;border-bottom:1px solid var(--border)}
.impact-inner{max-width:1300px;margin:0 auto}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:40px}
.impact-card{padding:48px 32px;text-align:center;background:var(--card);border:1px solid var(--border);transition:all 0.3s}
.impact-card:hover{border-color:var(--orange)}
.impact-num{font-family:'Bebas Neue';font-size:64px;color:var(--orange);line-height:1;margin-bottom:8px}
.impact-unit{font-family:'JetBrains Mono';font-size:10px;letter-spacing:2px;color:var(--light);margin-bottom:8px}
.impact-desc{font-size:13px;color:var(--text);line-height:1.5}
.impact-bar{height:5px;background:var(--mid);margin-top:24px;border-radius:3px;overflow:hidden}
.impact-bar-fill{height:100%;background:var(--orange);border-radius:2px;width:0;transition:width 1.5s ease-out}
.impact-card.visible .impact-bar-fill{width:var(--fill)}

/* ═══════════════════ 4 SYSTEMTYPEN ═══════════════════ */
.grundtypen-section{padding:120px 48px;background:linear-gradient(135deg,var(--black) 0%,var(--deep-blue) 50%,var(--black) 100%);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.grundtypen-inner{max-width:1300px;margin:0 auto}
.grundtypen-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-top:48px}
.grundtyp-card{position:relative;overflow:hidden;padding:32px 28px;min-height:440px;display:flex;flex-direction:column;justify-content:flex-start;border:1px solid var(--border);transition:all 0.5s;cursor:default}
.grundtyp-card:hover{border-color:var(--orange)}
.grundtyp-pattern{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;opacity:0.35;transition:opacity 0.5s}
.grundtyp-card:hover .grundtyp-pattern{opacity:0.85}
.grundtyp-content{position:relative;z-index:2}
.grundtyp-card h3{font-family:'Bebas Neue';font-size:24px;letter-spacing:2px;margin-bottom:8px;min-height:60px;display:flex;align-items:flex-end}
.grundtyp-triplet{font-family:'JetBrains Mono';font-size:10px;letter-spacing:1px;color:var(--orange);margin-bottom:12px}
.grundtyp-traits{list-style:none}
.grundtyp-traits li{font-size:13px;color:var(--text);padding:4px 0;display:flex;gap:8px}
.grundtyp-traits li::before{content:'→';color:var(--orange);flex-shrink:0}
.grundtyp-badge{font-family:'JetBrains Mono';font-size:8px;letter-spacing:2px;text-transform:uppercase;padding:4px 10px;margin-bottom:16px;display:inline-block}
.badge-target{color:var(--green);border:1px solid rgba(0,255,136,0.3);background:rgba(0,255,136,0.05)}
.badge-risk{color:var(--red);border:1px solid rgba(255,68,85,0.3);background:rgba(255,68,85,0.05)}
.badge-mid{color:var(--gold);border:1px solid rgba(255,170,0,0.3);background:rgba(255,170,0,0.05)}

/* ═══════════════════ FORMLINING ═══════════════════ */
.transition-section{padding:80px 48px;background:var(--near);border-bottom:1px solid var(--border)}
.transition-inner{max-width:1100px;margin:0 auto;text-align:center}
.transition-path{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:40px;flex-wrap:wrap}
.tp-node{padding:16px 24px;border:1px solid var(--border);background:var(--card);text-align:center;min-width:140px;transition:all 0.3s}
.tp-node:hover{border-color:var(--orange)}
.tp-node-name{font-family:'Bebas Neue';font-size:18px;letter-spacing:2px}
.tp-node-triplet{font-family:'JetBrains Mono';font-size:9px;color:var(--silver);margin-top:4px}
.tp-arrow{font-family:'Bebas Neue';font-size:24px;color:var(--orange)}
.tp-target{border-color:var(--green);box-shadow:0 0 30px rgba(0,255,136,0.08)}
.tp-target .tp-node-name{color:var(--green)}

/* ═══════════════════ PROCESS / PRICING ═══════════════════ */
.process-section{padding:120px 48px;border-bottom:1px solid var(--border)}
.process-inner{max-width:1300px;margin:0 auto}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:48px}
.process-card{background:var(--card);border:1px solid var(--border);padding:40px;transition:all 0.3s;position:relative}
.process-card:hover{border-color:var(--orange)}
.process-card.featured{border-color:var(--orange);background:rgba(255,107,0,0.02)}
.process-num{font-family:'Bebas Neue';font-size:64px;color:rgba(255,107,0,0.1);position:absolute;top:16px;right:20px}
.process-name{font-family:'Bebas Neue';font-size:28px;letter-spacing:2px;margin-bottom:4px}
.process-price{font-family:'JetBrains Mono';font-size:24px;color:var(--orange);margin-bottom:4px}
.process-scope{font-family:'JetBrains Mono';font-size:9px;letter-spacing:2px;color:var(--silver);text-transform:uppercase;margin-bottom:16px}
.process-card p{font-size:14px;color:var(--text);line-height:1.7;margin-bottom:16px}
.process-features{list-style:none}
.process-features li{font-size:12px;color:var(--light);padding:4px 0;display:flex;gap:8px}
.process-features li::before{content:'✓';color:var(--orange)}

/* ═══════════════════ TESTIMONIAL ═══════════════════ */
.testimonial-section{padding:120px 48px;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
.testimonial-inner{max-width:800px;margin:0 auto;text-align:center;position:relative;z-index:2}
.testimonial-quote{font-family:'DM Sans';font-size:22px;font-style:italic;color:var(--white);line-height:1.7;margin-bottom:32px;font-weight:300}
.testimonial-author{font-family:'Bebas Neue';font-size:18px;letter-spacing:3px;color:var(--orange)}
.testimonial-role{font-family:'JetBrains Mono';font-size:10px;letter-spacing:2px;color:var(--silver);margin-top:4px}

/* ═══════════════════ PODCAST ═══════════════════ */
.podcast-section{padding:120px 48px;border-bottom:1px solid var(--border)}
.podcast-inner{max-width:1300px;margin:0 auto}
.podcast-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:48px}
.podcast-card{background:var(--card);border:1px solid var(--border);padding:36px;transition:all 0.3s;display:flex;flex-direction:column}
.podcast-card:hover{border-color:var(--orange)}
.podcast-top{display:flex;justify-content:space-between;margin-bottom:20px}
.podcast-format{font-family:'JetBrains Mono';font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--orange)}
.podcast-freq{font-family:'JetBrains Mono';font-size:9px;letter-spacing:1px;color:var(--light)}
.podcast-card h3{font-family:'Bebas Neue';font-size:28px;letter-spacing:2px;margin-bottom:12px}
.podcast-card p{font-size:13px;color:var(--light);line-height:1.7;flex-grow:1}
.podcast-tags{display:flex;gap:6px;margin-top:20px;flex-wrap:wrap}
.podcast-tag{font-family:'JetBrains Mono';font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--orange);border:1px solid rgba(255,107,0,0.2);padding:4px 10px}
.podcast-waveform{display:flex;align-items:flex-end;gap:3px;height:50px;margin:20px 0}
.podcast-waveform span{display:block;width:4px;background:var(--orange);border-radius:2px;opacity:0.5;animation:waveBar 1.5s ease-in-out infinite;animation-delay:var(--d,0s)}
@keyframes waveBar{0%,100%{height:var(--h1,10px)}50%{height:var(--h2,40px)}}

/* ═══════════════════ DIAGNOSTIC TEASER ═══════════════════ */
.diagnostic-section{padding:120px 48px;background:linear-gradient(135deg,var(--black) 0%,#0A0F1A 50%,var(--black) 100%);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.diagnostic-inner{max-width:900px;margin:0 auto;text-align:center}
.diagnostic-mockup{background:var(--card);border:1px solid var(--border);padding:48px;margin-top:48px;text-align:left;position:relative;min-height:420px}
.diagnostic-progress{height:4px;background:var(--mid);margin-bottom:32px;border-radius:2px;overflow:hidden}
.diagnostic-progress-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--orange-hover));width:0;border-radius:2px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.diagnostic-q{font-family:'DM Sans';font-size:20px;font-weight:400;color:var(--white);margin-bottom:28px;line-height:1.5}
.diagnostic-options{display:flex;flex-direction:column;gap:8px}
.diagnostic-opt{padding:18px 22px;border:1px solid var(--border);background:var(--mid);font-size:14px;color:var(--text);cursor:pointer;transition:all .25s;display:flex;gap:14px;align-items:center;line-height:1.5}
.diagnostic-opt:hover{border-color:rgba(255,107,0,.5);color:var(--white);background:#1C1C1C}
.diagnostic-opt.selected{border-color:var(--orange);background:var(--orange-dim);color:var(--white)}
.diagnostic-opt::before{content:'';width:12px;height:12px;border:1px solid var(--silver);border-radius:50%;flex-shrink:0;transition:all .25s}
.diagnostic-opt:hover::before{border-color:var(--orange)}
.diagnostic-opt.selected::before{border-color:var(--orange);background:var(--orange);box-shadow:inset 0 0 0 2px var(--card)}
#diagBack{transition:color .3s;background:transparent;border:none;cursor:pointer;min-height:44px;padding:8px 4px;display:inline-flex;align-items:center}
#diagBack:hover{color:var(--orange)}
#diagNext:disabled{pointer-events:none}
#diagResult{animation:fadeSlideUp .6s ease-out forwards}

/* ═══════════════════ BLOG / SHIFT.PAPER ═══════════════════ */
.blog-section{padding:120px 48px;background:var(--near);border-bottom:1px solid var(--border)}
.blog-inner{max-width:1300px;margin:0 auto}
.blog-grid{display:grid;grid-template-columns:2fr 1fr;gap:3px;margin-top:48px}
.blog-feature{background:var(--card);border:1px solid var(--border);padding:48px;transition:all 0.3s}
.blog-feature:hover{border-color:var(--orange)}
.blog-feature-tag{font-family:'JetBrains Mono';font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:16px}
.blog-feature h3{font-family:'Bebas Neue';font-size:36px;letter-spacing:2px;margin-bottom:16px}
.blog-feature p{font-size:15px;color:var(--text);line-height:1.8}
.blog-sidebar{display:flex;flex-direction:column;gap:3px}
.blog-mini{background:var(--card);border:1px solid var(--border);padding:28px;transition:all 0.3s}
.blog-mini:hover{border-color:var(--orange)}
.blog-mini-tag{font-family:'JetBrains Mono';font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--silver);margin-bottom:8px}
.blog-mini h4{font-family:'Bebas Neue';font-size:18px;letter-spacing:1px;margin-bottom:6px}
.blog-mini p{font-size:12px;color:var(--light);line-height:1.6}

/* ═══════════════════ CTA ═══════════════════ */
.cta-section{padding:160px 48px;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,0,0.06) 0%,transparent 50%);top:50%;left:50%;transform:translate(-50%,-50%)}
.cta-inner{position:relative;z-index:2}
.cta-headline{font-family:'Bebas Neue';font-size:clamp(48px,6vw,96px);line-height:1;letter-spacing:2px;margin-bottom:24px}
.cta-headline .accent{color:var(--orange)}
.cta-headline .dim{color:var(--mid)}
.cta-body{font-size:18px;color:var(--silver);max-width:600px;margin:0 auto 48px;line-height:1.7}

/* ═══════════════════ FOOTER ═══════════════════ */
footer{padding:80px 48px 48px;background:var(--near);border-top:1px solid var(--border)}
.footer-inner{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-brand{font-family:'Bebas Neue';font-size:24px;letter-spacing:4px;margin-bottom:12px}
.footer-brand span{color:var(--orange)}
.footer-desc{font-size:13px;color:var(--silver);line-height:1.6;max-width:300px}
.footer-col h4{font-family:'JetBrains Mono';font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:16px}
.footer-col a{display:block;font-size:13px;color:var(--light);padding:8px 0;transition:color 0.3s}
.footer-col a:hover{color:var(--orange)}
.footer-bottom{max-width:1300px;margin:48px auto 0;padding-top:32px;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:18px;font-family:'JetBrains Mono';font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--silver);text-align:center}

/* ═══════════════════ REVEAL ═══════════════════ */
.reveal{opacity:0;transform:translateY(25px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════ RESPONSIVE ═══════════════════ */
@media(max-width:1440px){.nav-sponsor-label{display:none}.nav-cta-full{display:none}.nav-cta-short{display:inline}}
@media(max-width:1280px){.nav-sponsor-logo{height:34px}}
@media(max-width:1200px){.nav-sponsor{display:none}}
@media(max-width:980px){.nav-sponsor-logo{height:28px}}
@media(max-width:960px){.nav-links{display:none}.nav-mobile-toggle{display:flex}}
@media(max-width:1024px){.racing-hero-content,.FORMlining-def-inner{grid-template-columns:1fr;gap:48px}.grundtypen-grid,.impact-grid,.process-grid,.podcast-grid{grid-template-columns:1fr 1fr}.problem-grid{grid-template-columns:1fr 1fr}.footer-inner{grid-template-columns:1fr 1fr}.hero-stats{flex-wrap:wrap;gap:32px}.blog-grid,.leistungen-section [style*="grid-template-columns:repeat(4"]{grid-template-columns:1fr 1fr!important}.leistungen-section [style*="grid-template-columns:repeat(3"]{grid-template-columns:1fr 1fr!important}}
@media(max-width:768px){.diagnostic-section{padding:80px 24px}.diagnostic-mockup{padding:28px 22px}.diagnostic-q{font-size:17px}.diagnostic-opt{padding:14px 16px;font-size:13px}#diagResultType{font-size:36px!important}}
@media(max-width:768px){.nav{padding:0 24px}.nav-links{display:none}.nav-sponsor{display:none}.hero,.racing-hero-content,.FORMlining-def-inner{padding-left:24px;padding-right:24px}.grundtypen-grid,.impact-grid,.problem-grid,.process-grid,.podcast-grid{grid-template-columns:1fr}.hero-stats{flex-direction:column;gap:20px}.transition-path{flex-direction:column}.footer-inner{grid-template-columns:1fr}.partners-strip{flex-wrap:wrap;gap:16px}}

/* ═════════════ ARTICLE MODAL ═════════════ */
.article-modal-backdrop{
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:rgba(5,5,5,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  z-index:1000;
  display:none;
  align-items:flex-start;
  justify-content:center;
  overflow-y:auto;
  padding:60px 24px;
  opacity:0;
  transition:opacity 0.3s ease
}
.article-modal-backdrop.active{display:flex;opacity:1}
.article-modal{
  background:var(--card);
  border:1px solid var(--border);
  max-width:880px;
  width:100%;
  position:relative;
  margin:auto;
  box-shadow:0 0 80px rgba(255,107,0,0.08), 0 0 160px rgba(255,107,0,0.04)
}
.article-modal::before{
  content:'';position:absolute;top:0;left:0;width:4px;height:100%;
  background:linear-gradient(180deg,var(--orange) 0%,transparent 100%);
  opacity:0.8
}
.article-modal-close{
  position:absolute;top:20px;right:20px;
  width:44px;height:44px;
  background:transparent;
  border:1px solid var(--border);
  color:var(--silver);
  font-family:'JetBrains Mono';font-size:18px;
  cursor:pointer;
  transition:all 0.2s;
  display:flex;align-items:center;justify-content:center;
  z-index:10
}
.article-modal-close:hover{
  border-color:var(--orange);
  color:var(--orange);
  background:rgba(255,107,0,0.05)
}
.article-modal-inner{padding:64px 64px 80px 64px}
.article-modal-meta{
  font-family:'JetBrains Mono';font-size:9px;letter-spacing:3px;
  text-transform:uppercase;color:var(--orange);
  margin-bottom:24px;
  display:flex;align-items:center;gap:16px
}
.article-modal-meta::before{
  content:'';width:30px;height:1px;background:var(--orange);display:inline-block
}
.article-modal-title{
  font-family:'Bebas Neue';
  font-size:42px;
  letter-spacing:1.5px;
  line-height:1.05;
  margin-bottom:16px;
  color:var(--white)
}
.article-modal-title .accent{color:var(--orange)}
.article-modal-author{
  font-family:'JetBrains Mono';font-size:11px;letter-spacing:2px;
  color:var(--silver);
  text-transform:uppercase;
  margin-bottom:40px;
  padding-bottom:32px;
  border-bottom:1px solid var(--border)
}
.article-modal-body{
  font-family:'Asap',-apple-system,sans-serif;
  font-size:16px;
  line-height:1.75;
  color:var(--text)
}
.article-modal-body p{margin:0 0 22px 0}
.article-modal-body h3{
  font-family:'Bebas Neue';
  font-size:20px;letter-spacing:2px;
  color:var(--white);
  margin:40px 0 16px 0;
  text-transform:uppercase
}
.article-modal-body ul{
  margin:0 0 22px 0;
  padding-left:0;
  list-style:none
}
.article-modal-body ul li{
  position:relative;
  padding:6px 0 6px 24px;
  font-size:15px
}
.article-modal-body ul li::before{
  content:'›';
  position:absolute;left:0;top:6px;
  color:var(--orange);
  font-family:'JetBrains Mono';
  font-weight:bold
}
.article-modal-body strong{color:var(--white);font-weight:600}
.article-modal-body em{color:var(--text);font-style:italic}
.article-modal-body blockquote{
  border-left:3px solid var(--orange);
  padding:16px 0 16px 24px;
  margin:28px 0;
  font-family:'Bebas Neue';font-size:24px;letter-spacing:1.5px;
  color:var(--white);
  background:rgba(255,107,0,0.04);
  line-height:1.3
}
.article-modal-body sup{
  color:var(--orange);
  font-size:10px;
  font-family:'JetBrains Mono'
}
.article-modal-body .article-sources{
  margin-top:48px;padding-top:24px;
  border-top:1px solid var(--border);
  font-size:13px;color:var(--silver);
  line-height:1.7
}
body.modal-open{overflow:hidden}

@media(max-width:768px){
  .article-modal-backdrop{padding:0}
  .article-modal{max-width:100%}
  .article-modal-inner{padding:80px 28px 60px 28px}
  .article-modal-title{font-size:30px}
  .article-modal-body{font-size:15px}
  .article-modal-close{top:16px;right:16px}
}


.impact-source{
  margin-top:48px;
  text-align:center;
  padding-top:32px;
  border-top:1px solid var(--border)
}
.impact-source-link{
  display:inline-block;
  font-family:'JetBrains Mono';
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--orange);
  text-decoration:none;
  padding:8px 0;
  transition:opacity 0.3s;
  cursor:pointer;
  opacity:0.9
}
.impact-source-link:hover{opacity:1;text-decoration:underline}
.impact-source-refs{
  margin-top:14px;
  font-family:'JetBrains Mono';
  font-size:10px;
  letter-spacing:1.5px;
  text-transform:lowercase;
  color:var(--orange);
  opacity:0.5
}


/* ═══════════════════ DIAGNOSTIC RESULT ═══════════════════ */
#diagResult{
  animation:fadeSlideUp .6s ease-out forwards;
  text-align:left
}

/* ─────────── REVEAL SEQUENCE: gestaffelte Animation der Result-Elemente ─────────── */
/* Alle Elemente starten unsichtbar */
.diag-science-card .diag-result-eyebrow,
.diag-science-card .diag-result-type,
.diag-science-card .diag-result-headline,
.diag-science-card .diag-science-divider,
.diag-science-card .diag-result-core,
.diag-science-card .diag-result-traits-label,
.diag-science-card .diag-result-traits li,
.diag-result-transition,
.savings-module{
  opacity:0;
  animation-fill-mode:forwards
}

/* Eyebrow: 0ms — sanft fade-in */
.diag-science-card .diag-result-eyebrow{
  animation:revealFadeUp 0.5s ease-out 0.1s forwards
}

/* Systemtyp-Name: 200ms — scale + glow-explosion */
.diag-science-card .diag-result-type{
  animation:revealTypeBurst 0.7s cubic-bezier(0.34,1.56,0.64,1) 0.3s forwards
}

/* Headline: 400ms — fade up */
.diag-science-card .diag-result-headline{
  animation:revealFadeUp 0.6s ease-out 0.6s forwards
}

/* Divider 1 (zwischen Header + Core): 600ms — zeichnet sich von Mitte aus */
.diag-science-card .diag-science-divider:nth-of-type(1),
.diag-science-card .diag-science-divider{
  animation:revealDividerDraw 0.8s ease-out 0.9s forwards;
  transform-origin:center
}

/* Core-Text: 900ms — fade up */
.diag-science-card .diag-result-core{
  animation:revealFadeUp 0.6s ease-out 1.1s forwards
}

/* Traits-Label: 1200ms */
.diag-science-card .diag-result-traits-label{
  animation:revealFadeUp 0.5s ease-out 1.4s forwards
}

/* Traits-Items: 1400ms+, stagger 80ms je Item */
.diag-science-card .diag-result-traits li{
  animation:revealFadeInLeft 0.5s ease-out forwards
}
.diag-science-card .diag-result-traits li:nth-child(1){animation-delay:1.6s}
.diag-science-card .diag-result-traits li:nth-child(2){animation-delay:1.68s}
.diag-science-card .diag-result-traits li:nth-child(3){animation-delay:1.76s}
.diag-science-card .diag-result-traits li:nth-child(4){animation-delay:1.84s}
.diag-science-card .diag-result-traits li:nth-child(5){animation-delay:1.92s}

/* Transition-Hint: 2200ms */
.diag-result-transition{
  animation:revealFadeUp 0.6s ease-out 2.2s forwards
}

/* Savings-Module: 2500ms — slide-up mit elastischem Bounce */
.savings-module{
  animation:revealSlideUpBounce 0.8s cubic-bezier(0.34,1.56,0.64,1) 2.5s forwards
}

/* Keyframes */
@keyframes revealFadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes revealFadeInLeft{
  from{opacity:0;transform:translateX(-20px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes revealTypeBurst{
  0%{
    opacity:0;
    transform:scale(0.6);
    filter:blur(8px);
    text-shadow:0 0 0 rgba(255,107,0,0)
  }
  60%{
    opacity:1;
    transform:scale(1.05);
    filter:blur(0);
    text-shadow:
      0 0 60px rgba(255,107,0,0.5),
      0 0 120px rgba(0,180,255,0.3)
  }
  100%{
    opacity:1;
    transform:scale(1);
    filter:blur(0);
    text-shadow:
      0 0 30px rgba(255,107,0,0.2),
      0 0 60px rgba(0,180,255,0.1)
  }
}
@keyframes revealDividerDraw{
  from{
    opacity:0;
    transform:scaleX(0)
  }
  to{
    opacity:1;
    transform:scaleX(1)
  }
}
@keyframes revealSlideUpBounce{
  from{
    opacity:0;
    transform:translateY(40px) scale(0.96)
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1)
  }
}

/* Reduced motion: alle Reveal-Animationen instant */
@media (prefers-reduced-motion: reduce){
  .diag-science-card .diag-result-eyebrow,
  .diag-science-card .diag-result-type,
  .diag-science-card .diag-result-headline,
  .diag-science-card .diag-science-divider,
  .diag-science-card .diag-result-core,
  .diag-science-card .diag-result-traits-label,
  .diag-science-card .diag-result-traits li,
  .diag-result-transition,
  .savings-module{
    animation:none;
    opacity:1;
    transform:none
  }
  .diag-science-glow,
  .diag-result-transition-arrow{
    animation:none !important
  }
}

/* ─────────── SCIENCE CARD: ein zusammenhängender Wissenschafts-Block ─────────── */
.diag-science-card{
  position:relative;
  background:linear-gradient(135deg,#050B14 0%,#0A1628 50%,#050B14 100%);
  border:1px solid rgba(0,180,255,0.2);
  border-radius:0;
  padding:0;
  margin-bottom:48px;
  overflow:hidden;
  box-shadow:
    inset 0 1px 0 rgba(0,200,255,0.1),
    0 0 60px rgba(0,150,255,0.05),
    0 20px 50px rgba(0,0,0,0.4)
}
.diag-science-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 600px 300px at 20% 20%,rgba(0,150,255,0.08) 0%,transparent 60%),
    radial-gradient(ellipse 500px 400px at 80% 80%,rgba(255,107,0,0.04) 0%,transparent 55%);
  pointer-events:none;
  z-index:0
}
.diag-science-glow{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(circle 2px at 12% 30%,rgba(0,200,255,0.4) 0%,transparent 100%),
    radial-gradient(circle 2px at 88% 70%,rgba(0,200,255,0.4) 0%,transparent 100%),
    radial-gradient(circle 1.5px at 70% 20%,rgba(255,107,0,0.5) 0%,transparent 100%),
    radial-gradient(circle 1.5px at 30% 85%,rgba(255,107,0,0.5) 0%,transparent 100%),
    radial-gradient(circle 1px at 50% 50%,rgba(0,180,255,0.3) 0%,transparent 100%);
  animation:scienceGlow 8s ease-in-out infinite
}
@keyframes scienceGlow{
  0%,100%{opacity:0.6}
  50%{opacity:1}
}
.diag-science-card > *{position:relative;z-index:1}

.diag-science-divider{
  height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,107,0,0.25) 20%,
    rgba(0,180,255,0.4) 50%,
    rgba(255,107,0,0.25) 80%,
    transparent 100%);
  margin:0 32px;
  border:none
}

/* ─── HEADER innerhalb der Science-Card ─── */
.diag-result-header{
  text-align:center;
  padding:48px 32px 36px
}
.diag-result-eyebrow{
  font-family:'JetBrains Mono';
  font-size:10px;
  letter-spacing:5px;
  color:var(--orange);
  margin-bottom:20px;
  display:inline-flex;
  align-items:center;
  gap:14px;
  text-transform:uppercase
}
.diag-result-eyebrow::before,
.diag-result-eyebrow::after{
  content:'';
  display:inline-block;
  width:28px;
  height:1px;
  background:var(--orange)
}
.diag-result-type{
  font-family:'Bebas Neue';
  font-size:clamp(44px,7vw,76px);
  line-height:1;
  letter-spacing:3px;
  margin-bottom:18px;
  text-shadow:
    0 0 30px rgba(255,107,0,0.2),
    0 0 60px rgba(0,180,255,0.1)
}
.diag-result-headline{
  font-family:'DM Sans';
  font-size:17px;
  color:var(--white);
  font-weight:300;
  line-height:1.5;
  max-width:560px;
  margin:0 auto;
  font-style:italic;
  opacity:0.92
}

/* ─── CORE TEXT innerhalb der Science-Card ─── */
.diag-result-core{
  padding:32px 40px
}
.diag-result-core p{
  font-size:15px;
  color:var(--text);
  line-height:1.85;
  margin:0;
  max-width:680px;
  margin-left:auto;
  margin-right:auto
}

/* ─── TRAITS innerhalb der Science-Card ─── */
.diag-result-traits{
  padding:32px 40px 48px
}
.diag-result-traits-label{
  font-family:'JetBrains Mono';
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:20px;
  display:flex;
  align-items:center;
  gap:14px
}
.diag-result-traits-label::before{
  content:'';
  width:28px;
  height:1px;
  background:var(--orange)
}
.diag-result-traits ul{
  list-style:none;
  padding:0;
  margin:0
}
.diag-result-traits li{
  position:relative;
  padding:10px 0 10px 24px;
  font-size:14px;
  color:var(--text);
  line-height:1.6
}
.diag-result-traits li::before{
  content:'→';
  position:absolute;
  left:0;
  top:10px;
  color:var(--orange);
  font-weight:bold
}

/* ═══════════════════ TRANSITION HINT (zw. Result → Savings) ═══════════════════ */
.diag-result-transition{
  text-align:center;
  padding:32px 0 24px;
  margin-bottom:24px
}
.diag-result-transition-lead{
  font-family:'Bebas Neue';
  font-size:clamp(20px,2.8vw,28px);
  letter-spacing:1.5px;
  color:var(--white);
  margin:0 0 16px 0;
  line-height:1.2
}
.diag-result-transition-arrow{
  font-family:'JetBrains Mono';
  font-size:24px;
  color:var(--orange);
  line-height:1;
  animation:transitionPulse 2s ease-in-out infinite;
  opacity:0.7
}
@keyframes transitionPulse{
  0%,100%{transform:translateY(0);opacity:0.6}
  50%{transform:translateY(6px);opacity:1}
}

/* ═══════════════════ CTA SECTION ═══════════════════ */
.diag-result-cta{
  text-align:center;
  padding:36px 0 40px;
  margin-bottom:48px
}
.diag-result-cta-lead{
  font-size:16px;
  color:var(--white);
  margin-bottom:24px;
  font-weight:300;
  line-height:1.5;
  max-width:520px;
  margin-left:auto;
  margin-right:auto
}
.diag-cta-btn{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  font-size:11px!important;
  padding:18px 32px!important;
  letter-spacing:1.8px
}
.diag-result-restart{
  text-align:center;
  padding:24px 0 0
}

/* ═══════════════════ SAVINGS MODULE (eigenständige Card) ═══════════════════ */
.savings-module{
  position:relative;
  background:#0A0A0A;
  border:2px solid rgba(255,107,0,0.4);
  padding:56px 40px 48px;
  margin-bottom:32px;
  box-shadow:
    inset 0 1px 0 rgba(255,107,0,0.15),
    0 0 40px rgba(255,107,0,0.06),
    0 20px 50px rgba(0,0,0,0.5)
}
/* Vier Ecken-Akzente */
.savings-module::before,
.savings-module::after{
  content:'';
  position:absolute;
  width:24px;height:24px;
  pointer-events:none;
  z-index:2
}
.savings-module::before{
  top:-2px;left:-2px;
  border-top:3px solid var(--orange);
  border-left:3px solid var(--orange)
}
.savings-module::after{
  bottom:-2px;right:-2px;
  border-bottom:3px solid var(--orange);
  border-right:3px solid var(--orange)
}
.savings-module-marker{
  position:absolute;
  top:-11px;
  left:32px;
  background:#0A0A0A;
  padding:0 14px;
  font-family:'JetBrains Mono';
  font-size:10px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--orange);
  font-weight:600;
  z-index:3;
  line-height:22px
}
.savings-module-hero{margin-bottom:36px}
.savings-h1{
  font-family:'Bebas Neue';
  font-size:clamp(30px,4.8vw,46px);
  line-height:1;
  letter-spacing:-0.5px;
  margin:0 0 14px 0;
  color:var(--white)
}
.savings-h1 .savings-accent{color:var(--orange)}
.savings-subtitle{
  font-size:14px;
  color:var(--text);
  font-weight:300;
  margin:0;
  line-height:1.6;
  max-width:560px
}
.savings-progress-bar{
  height:4px;
  background:var(--mid);
  border-radius:2px;
  overflow:hidden;
  margin:0 0 32px 0
}
.savings-progress-fill{
  height:100%;
  border-radius:2px;
  background:linear-gradient(90deg,var(--orange),#FFAA00);
  transition:width 0.8s ease-out;
  width:30%
}

/* ─── INPUT-GROUPS: jeder Slider in eigener kleiner Card ─── */
.savings-input-group{
  background:var(--mid);
  border:1px solid rgba(255,255,255,0.06);
  padding:18px 22px;
  margin-bottom:12px;
  transition:border-color 0.3s
}
.savings-input-group:hover{
  border-color:rgba(255,107,0,0.3)
}
.savings-input-label{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:12px;
  gap:16px
}
.savings-input-label label{
  font-family:'Asap';
  font-size:13px;
  font-weight:500;
  color:var(--white);
  flex:1
}
.savings-val{
  font-family:'JetBrains Mono';
  font-size:18px;
  color:var(--orange);
  font-weight:700;
  white-space:nowrap
}
.savings-slider{
  width:100%;
  -webkit-appearance:none;
  appearance:none;
  height:4px;
  background:#222;
  outline:none;
  border-radius:2px;
  cursor:pointer
}
.savings-slider::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:20px;
  height:20px;
  background:var(--orange);
  border-radius:0;
  cursor:grab;
  border:2px solid #0A0A0A;
  transition:background 0.2s,transform 0.2s
}
.savings-slider::-webkit-slider-thumb:hover{
  background:var(--orange-hover);
  transform:scale(1.2)
}
.savings-slider::-webkit-slider-thumb:active{cursor:grabbing}
.savings-slider::-moz-range-thumb{
  width:20px;
  height:20px;
  background:var(--orange);
  border:2px solid #0A0A0A;
  border-radius:0;
  cursor:grab
}

/* ─── RESULT-BOX (das große Ergebnis) ─── */
.savings-result-box{
  background:#050505;
  border:1px solid rgba(255,107,0,0.25);
  padding:36px 32px;
  margin-top:32px;
  position:relative;
  overflow:hidden
}
.savings-result-box::before{
  content:'';
  position:absolute;
  top:0;left:0;
  width:80px;height:2px;
  background:linear-gradient(90deg,var(--orange),transparent)
}
.savings-result-label{
  font-family:'JetBrains Mono';
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:8px
}
.savings-result-main{
  font-family:'Bebas Neue';
  font-size:clamp(44px,8vw,72px);
  line-height:0.95;
  color:var(--orange);
  margin-bottom:6px;
  transition:all 0.3s
}
.savings-result-sub{
  font-family:'JetBrains Mono';
  font-size:11px;
  color:var(--silver);
  letter-spacing:1px;
  margin-bottom:28px;
  line-height:1.5
}
.savings-breakdown{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  margin-top:24px
}
.savings-bd-item{
  background:#0F0F0F;
  border:1px solid rgba(255,255,255,0.08);
  padding:24px 16px;
  text-align:center;
  transition:border-color 0.3s
}
.savings-bd-item:hover{border-color:rgba(255,107,0,0.4)}
.savings-bd-num{
  font-family:'Bebas Neue';
  font-size:30px;
  color:var(--white);
  line-height:1;
  margin-bottom:6px;
  transition:all 0.3s
}
.savings-bd-label{
  font-family:'JetBrains Mono';
  font-size:9px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--silver);
  line-height:1.3
}
.savings-bd-save{
  border-color:rgba(0,255,136,0.4);
  background:rgba(0,255,136,0.04)
}
.savings-bd-save .savings-bd-num{color:var(--green)}
.savings-bd-save:hover{border-color:var(--green)}
.savings-source{
  font-family:'JetBrains Mono';
  font-size:9px;
  color:var(--silver);
  text-align:center;
  padding:20px 0 0 0;
  letter-spacing:1px;
  border-top:1px solid rgba(255,255,255,0.06);
  margin-top:32px;
  line-height:1.5
}

@media(max-width:640px){
  .savings-module{padding:32px 20px;margin:48px -16px 24px -16px}
  .savings-breakdown{grid-template-columns:1fr}
  .savings-result-box{padding:32px 24px}
  .diag-cta-btn{font-size:10px!important;padding:14px 18px!important;letter-spacing:1.2px;text-align:center}
  .diag-result-traits{padding:18px 20px}
}



/* Heading-Hierarchie A11Y: Card-Titel als h4 — übernehmen das Styling der ehemaligen h3 */
.problem-card h4{
  font-family:'Bebas Neue';
  font-size:22px;
  letter-spacing:2px;
  color:var(--white);
  margin:20px 0 12px 0;
  line-height:1.1
}
.impact-card h4{
  font-family:'Bebas Neue';
  font-size:20px;
  letter-spacing:1.5px;
  color:var(--white);
  margin:0 0 16px 0;
  line-height:1.2
}
/* ═══════════════════ GLOBAL REDUCED-MOTION OVERRIDE ═══════════════════ */
/* Respektiert User-Präferenz für reduzierte Bewegung — A11Y, WCAG 2.1 AA 2.3.3 */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important
  }
  /* Bestimmte Animationen komplett aus */
  .diag-science-glow,
  .diag-result-transition-arrow,
  .savings-progress-fill,
  #heroCanvas,
  #racingCanvas,
  .scroll-track{
    animation:none !important;
    transition:none !important
  }
  /* Reveal-Animationen instant zum Endzustand */
  .diag-science-card .diag-result-eyebrow,
  .diag-science-card .diag-result-type,
  .diag-science-card .diag-result-headline,
  .diag-science-card .diag-science-divider,
  .diag-science-card .diag-result-core,
  .diag-science-card .diag-result-traits-label,
  .diag-science-card .diag-result-traits li,
  .diag-result-transition,
  .savings-module{
    opacity:1 !important;
    transform:none !important
  }
}


/* ═══════════════════ REFACTORED: Ehemals Inline-Styles ═══════════════════ */

/* Navigation */
.nav-logo img { height: 36px; width: auto; }

/* Hero */
.hero-racing-photo { background-image: url('../images/hero-porsche-racing.jpg'); }

/* Transition Path */
.transition-path { gap: 12px; }

/* Transition Node */
.tp-node-name { color: var(--white); }

/* Process Cards */
.process-card { position: relative; }
.process-icon-wrap { margin-bottom: 20px; }

/* IST/SOLL Visualisierung */
.ist-soll-viz {
  grid-column: 1 / -1;
  margin-top: 48px;
  padding: 48px;
  width: 100%;
}

/* Sections — Padding & Hintergrund */
.leistungen-section {
  padding: 140px 48px;
  background: var(--black);
  border-bottom: 1px solid var(--border);
}
.blog-section {
  padding: 120px 48px;
  background: var(--near);
  border-bottom: 1px solid var(--border);
}

/* Labels — JetBrains Mono */
.label-mono {
  font-family: 'JetBrains Mono';
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 24px;
}
.label-mono-flex {
  display: flex;
  align-items: center;
  gap: 12px;
}
.label-mono-flex .label-line {
  width: 30px;
  height: 1px;
  background: var(--orange);
  flex-shrink: 0;
}
.label-mono-sm {
  font-family: 'JetBrains Mono';
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 14px;
}
.label-mono-diag {
  font-family: 'JetBrains Mono';
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--orange);
  margin-bottom: 20px;
}
.label-mono-nav {
  font-family: 'JetBrains Mono';
  font-size: 9px;
  color: var(--silver);
  letter-spacing: 1px;
  cursor: pointer;
  user-select: none;
}

/* Grundtyp-Card Farbvarianten */
.grundtyp-card--green  { background: linear-gradient(180deg, rgba(0,255,136,0.03), var(--card)); }
.grundtyp-card--gold   { background: linear-gradient(180deg, rgba(255,170,0,0.03), var(--card)); }
.grundtyp-card--orange { background: linear-gradient(180deg, rgba(255,107,0,0.03), var(--card)); }
.grundtyp-card--silver { background: linear-gradient(180deg, rgba(138,138,138,0.03), var(--card)); }

/* Grundtyp-Badge Farbvarianten */
.grundtyp-badge--green  { color: var(--green);  border: 1px solid rgba(0,255,136,0.3);   background: rgba(0,255,136,0.05); }
.grundtyp-badge--gold   { color: var(--gold);   border: 1px solid rgba(255,170,0,0.3);   background: rgba(255,170,0,0.05); }
.grundtyp-badge--orange { color: var(--orange); border: 1px solid rgba(255,107,0,0.3);   background: rgba(255,107,0,0.05); }
.grundtyp-badge--silver { color: var(--light);  border: 1px solid rgba(153,153,153,0.3); background: rgba(153,153,153,0.05); }

/* Blog-Karten */
.blog-card-link {
  background: var(--card);
  border: 1px solid var(--border);
  padding: 32px;
  transition: all 0.3s;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
}
.blog-card-tag {
  font-family: 'JetBrains Mono';
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 14px;
}
.blog-card-body { font-size: 13px; color: var(--silver); line-height: 1.6; flex-grow: 1; }
.blog-card-meta {
  font-family: 'JetBrains Mono';
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--orange);
  margin-top: 20px;
}

/* Blog-Karten Überschriften */
.heading-blog {
  font-family: 'Bebas Neue';
  font-size: 22px;
  letter-spacing: 1px;
  margin-bottom: 12px;
  line-height: 1.1;
}

/* Leistungen Layout */
.leistungen-inner   { max-width: 1300px; margin: 0 auto; }
.leistungen-grid-3  { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 48px; }
.leistungen-grid-4  { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; margin-top: 32px; }
.leistungen-process-wrap { margin-top: 64px; }
.service-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-top: 56px; }

/* Service-Cards (Leistungen) */
.service-card {
  background: rgba(255,107,0,0.03);
  border: 1px solid rgba(255,107,0,0.15);
  padding: 32px;
  transition: all 0.3s;
}
.service-num {
  font-family: 'Bebas Neue';
  font-size: 56px;
  color: rgba(255,107,0,0.12);
  line-height: 1;
  margin-bottom: 12px;
}
.leistungen-item-title {
  font-family: 'Bebas Neue';
  font-size: 20px;
  letter-spacing: 2px;
  margin-bottom: 8px;
  color: var(--orange);
}
.leistungen-item-desc { font-size: 13px; color: var(--silver); line-height: 1.6; }

/* Section-Modifier */
.section-eyebrow--center { justify-content: center; }
.section-headline--center { text-align: center; }
.section-body--center { text-align: center; margin: 0 auto; }

/* Text-Varianten */
.text-highlight { color: var(--orange); font-weight: 500; font-size: 17px; margin-bottom: 32px; }
.text-transition-note {
  color: var(--light);
  font-size: 14px;
  max-width: 650px;
  margin: 32px auto 0;
  text-align: center;
  line-height: 1.7;
}
.text-body-small { font-size: 13px; color: var(--text); line-height: 1.7; }
.text-secondary   { font-size: 13px; color: var(--silver); line-height: 1.6; }
.text-accent-inline { color: var(--green); }

/* IST-SOLL Highlight-Box */
.highlight-box-green {
  margin-top: 24px;
  padding: 24px;
  background: rgba(0,255,136,0.02);
  border: 1px solid rgba(0,255,136,0.1);
}

/* SVG */
.svg-block { display: block; }

/* Diagnostik-Steuerung */
.diag-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 24px;
}

/* Button-Varianten */
.btn-primary--sm { padding: 12px 24px; font-size: 11px; }

/* Hilfsklassen */
.hidden { display: none; }
.flex-center-wrap { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

.font-bebas { font-family: 'Bebas Neue'; }

.blog-card-tag--spaced { margin-bottom: 16px; }

/* ═══════════════════ IST-SOLL MOBILE ALT ═══════════════════ */
.ist-soll-mobile-alt{display:none;padding:24px;background:var(--card);border:1px solid var(--border);margin-top:24px}
.ist-soll-mobile-alt p{font-size:14px;color:var(--text);line-height:1.7;margin:0}

/* ═══════════════════ MOBILE NAV ═══════════════════ */
.nav-mobile-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;padding:8px;background:transparent;border:1px solid rgba(255,107,0,0.3);cursor:pointer;flex-shrink:0}
.nav-mobile-bar{display:block;width:22px;height:2px;background:var(--white);border-radius:1px;transition:transform 0.3s,opacity 0.3s}
.nav-mobile-toggle[aria-expanded="true"] .nav-mobile-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-mobile-toggle[aria-expanded="true"] .nav-mobile-bar:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-mobile-toggle[aria-expanded="true"] .nav-mobile-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav-drawer{position:fixed;top:68px;left:0;width:100vw;bottom:0;background:rgba(5,5,5,0.99);z-index:999;overflow-y:auto;transform:translateX(-100%);transition:transform 0.3s ease;visibility:hidden}
.mobile-nav-drawer.open{transform:translateX(0);visibility:visible}
.mobile-nav-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,0.6);z-index:998;opacity:0;visibility:hidden;transition:opacity 0.3s}
.mobile-nav-overlay.active{opacity:1;visibility:visible}
.mobile-nav-inner{padding:32px 24px 60px}
.mobile-nav-links{list-style:none;margin:0;padding:0}
.mobile-nav-links li{border-bottom:1px solid var(--border)}
.mobile-nav-links a{display:block;padding:20px 0;font-family:'Bebas Neue';font-size:30px;letter-spacing:3px;color:var(--white);transition:color 0.3s}
.mobile-nav-links a:hover,.mobile-nav-links a:focus-visible{color:var(--orange)}
.mobile-nav-cta{color:var(--orange)!important}
.mobile-nav-sponsor{margin-top:40px;padding-top:32px;border-top:1px solid var(--border);display:flex;align-items:center;gap:16px}
.mobile-nav-sponsor-label{font-family:'JetBrains Mono';font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--light);line-height:1.4}

/* ═══════════════════ RESPONSIVE ERGÄNZUNGEN ═══════════════════ */
@media(max-width:768px){
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none}
  .grundtyp-card{min-height:280px}
  .ist-soll-viz{display:none}
  .ist-soll-mobile-alt{display:block}
  .stat-label,.podcast-freq,.racing-meta-label,.impact-unit,.nav-sponsor-label{font-size:11px}
  .savings-slider::-webkit-slider-thumb{width:24px;height:24px}
  .savings-slider::-moz-range-thumb{width:24px;height:24px}
  .leistungen-grid-3{grid-template-columns:1fr}
  .leistungen-grid-4{grid-template-columns:1fr}
  .leistungen-grid-3 .process-card,.leistungen-grid-4 .service-card{min-width:0}
  .blog-grid{grid-template-columns:1fr}
  .service-grid{grid-template-columns:1fr}
  .service-grid .blog-card-link{min-width:0}
}
@media(max-width:960px){.nav-mobile-toggle{display:flex}}
