/* ============================================================
   B_77 — Design-System „MONOLITH"
   Reines Schwarz/Weiß · keine Akzentfarbe · Typografie trägt alles
   Hanken Grotesk (Display/Text) · JetBrains Mono (Labels)
   ============================================================ */

:root{
  --ink:#0F0F0F;      /* Text, Flächen, starke Linien */
  --paper:#FFFFFF;    /* Hintergrund */
  --text-2:#333333;   /* Fließtext auf Weiß */
  --mute:#9A9A9A;     /* Labels, Meta, Hilfstext */
  --line:#DDDDDD;     /* feine Trennlinien innerhalb von Sektionen */
  --gutter:40px;
  --sans:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:72px;}
body{
  background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:400;
  line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--ink);color:var(--paper);}

/* ---------- Layout-Bausteine ---------- */
.wrap{padding-left:var(--gutter);padding-right:var(--gutter);}
.section{padding:clamp(64px,9vw,110px) 0;border-top:1px solid var(--ink);position:relative;}
.section--first{border-top:none;}

/* Eck-Labels: links Thema, rechts laufende Nummer */
.corners{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);margin-bottom:clamp(36px,5vw,64px);}
.corners .r{text-align:right;}

/* ---------- Typografie ---------- */
.display{font-family:var(--sans);font-weight:800;font-size:clamp(72px,20.5vw,400px);
  letter-spacing:-0.04em;line-height:0.82;white-space:nowrap;padding-left:36px;}
.h2{font-family:var(--sans);font-weight:700;font-size:clamp(28px,4vw,58px);
  letter-spacing:-0.02em;line-height:1.04;}
.manifest{font-family:var(--sans);font-weight:500;font-size:clamp(26px,4.6vw,72px);
  letter-spacing:-0.02em;line-height:1.1;text-align:justify;text-justify:inter-word;}
.body{font-family:var(--sans);font-weight:400;font-size:clamp(17px,1.7vw,21px);
  line-height:1.5;color:var(--text-2);}
.body strong{font-weight:800;color:var(--ink);}
.label{font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);}
.lead{max-width:62ch;}
p+p{margin-top:1.1em;}

/* ---------- Nav ---------- */
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;
  padding:22px var(--gutter);border-bottom:1px solid var(--ink);
  position:sticky;top:0;z-index:50;background:var(--paper);}
.nav__brand{font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--ink);white-space:nowrap;display:inline-flex;align-items:center;}
.nav__brand img{height:22px;width:auto;display:block;}

/* ---------- Magazin-Liste (Startseite) ---------- */
.mag{border-top:1px solid var(--line);}
.mag-row{display:grid;grid-template-columns:minmax(0,210px) 1fr auto;gap:28px;align-items:baseline;
  padding:clamp(20px,2.4vw,30px) var(--gutter);border-bottom:1px solid var(--line);color:var(--ink);
  transition:background .35s cubic-bezier(.2,.7,.2,1),color .35s,padding-left .35s cubic-bezier(.2,.7,.2,1);}
.mag-meta{font-family:var(--mono);font-weight:600;font-size:12px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);transition:color .35s;}
.mag-title{font-family:var(--sans);font-weight:500;font-size:clamp(17px,1.8vw,23px);
  line-height:1.3;letter-spacing:-0.01em;}
.mag-arr{justify-self:end;font-size:20px;opacity:0;transform:translateX(-8px);transition:opacity .35s,transform .35s cubic-bezier(.2,.7,.2,1);}
.mag-row:hover{background:var(--ink);color:var(--paper);padding-left:calc(var(--gutter) + 24px);}
.mag-row:hover .mag-meta{color:rgba(255,255,255,0.6);}
.mag-row:hover .mag-arr{opacity:1;transform:none;}
@media(max-width:900px){.mag-row{grid-template-columns:1fr;gap:6px;}.mag-arr{display:none;}}

/* ---------- Dunkle Sektion (z. B. Magazin) ---------- */
.section--ink{background:var(--ink);color:var(--paper);border-top-color:var(--ink);}
.section--ink .corners{color:rgba(255,255,255,0.5);}
.section--ink .h2,.section--ink .stat__num{color:var(--paper);}
.section--ink .body{color:rgba(255,255,255,0.74);}
.section--ink .body strong{color:var(--paper);}
.section--ink .label{color:rgba(255,255,255,0.5);}
.section--ink .stat{border-left-color:rgba(255,255,255,0.16);}
.section--ink .stat__lbl{color:rgba(255,255,255,0.5);}
.section--ink ::selection{background:var(--paper);color:var(--ink);}
.section--ink .mag{border-top-color:rgba(255,255,255,0.16);}
.section--ink .mag-row{color:var(--paper);border-bottom-color:rgba(255,255,255,0.16);}
.section--ink .mag-meta{color:rgba(255,255,255,0.5);}
.section--ink .mag-row:hover{background:var(--paper);color:var(--ink);}
.section--ink .mag-row:hover .mag-meta{color:rgba(0,0,0,0.55);}

/* ---------- Button (prominent) ---------- */
.btn-mono{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-weight:600;
  font-size:13px;letter-spacing:0.06em;text-transform:uppercase;padding:17px 28px;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);border-radius:1px;
  transition:background .25s ease,color .25s ease,transform .25s ease;}
.btn-mono:hover{background:var(--paper);color:var(--ink);}
.section--ink .btn-mono{background:var(--paper);color:var(--ink);border-color:var(--paper);}
.section--ink .btn-mono:hover{background:transparent;color:var(--paper);}
.nav__links{display:flex;justify-content:center;gap:34px;}
.nav__links a{font-family:var(--mono);font-weight:500;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--ink);position:relative;padding:4px 0;}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.2,.7,.2,1);}
.nav__links a:hover::after,.nav__links a.is-active::after{transform:scaleX(1);}
.nav__place{font-family:var(--mono);font-weight:500;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);text-align:right;white-space:nowrap;}
.nav__burger{display:none;justify-self:end;font-family:var(--mono);font-size:13px;
  text-transform:uppercase;letter-spacing:0.04em;background:none;border:none;color:var(--ink);
  cursor:pointer;padding:6px 0;}
.nav__mobile{display:none;}

/* ---------- Hero ---------- */
.hero{padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(56px,8vw,110px);}
.hero__word{margin:clamp(24px,4vw,48px) 0 clamp(40px,6vw,72px);}
.hero__grid{display:grid;grid-template-columns:minmax(0,0.4fr) minmax(0,1fr);gap:clamp(24px,5vw,72px);
  padding:0 var(--gutter);align-items:start;}
.hero__grid .label{padding-top:6px;}

/* ---------- Manifest ---------- */
.manifest-sec .manifest{padding:0 var(--gutter);max-width:none;}
.manifest-sec .corners{margin-bottom:clamp(40px,6vw,72px);}

/* ---------- Index-Liste (Leistungen) ---------- */
.il{border-top:1px solid var(--line);}
.il-row{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:28px;
  padding:clamp(26px,3.2vw,40px) var(--gutter);border-bottom:1px solid var(--line);
  color:var(--ink);transition:background .35s cubic-bezier(.2,.7,.2,1),
  color .35s cubic-bezier(.2,.7,.2,1),padding-left .35s cubic-bezier(.2,.7,.2,1);}
.il-idx{font-family:var(--mono);font-weight:600;font-size:14px;color:var(--mute);
  letter-spacing:0.04em;transition:color .35s;}
.il-main{min-width:0;}
.il-title{font-family:var(--sans);font-weight:700;font-size:clamp(24px,3.4vw,46px);
  letter-spacing:-0.02em;line-height:1.04;display:block;}
.il-desc{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1.5vw,18px);
  line-height:1.45;color:var(--text-2);max-width:64ch;margin-top:10px;transition:color .35s;}
.il-arr{font-family:var(--sans);font-weight:400;font-size:clamp(22px,2.4vw,32px);
  justify-self:end;transform:translateX(-8px);opacity:0;transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .35s;}
.il-row:hover{background:var(--ink);color:var(--paper);padding-left:calc(var(--gutter) + 24px);}
.il-row:hover .il-idx{color:var(--paper);}
.il-row:hover .il-desc{color:rgba(255,255,255,0.72);}
.il-row:hover .il-arr{transform:translateX(0);opacity:1;}

/* ---------- Plakat (schwarze Kontrast-Sektion) ---------- */
.plakat{background:var(--ink);color:var(--paper);border-top:1px solid var(--ink);
  padding:clamp(72px,11vw,150px) 0;}
.plakat .corners{color:rgba(255,255,255,0.55);}
.plakat .display{color:var(--paper);margin:clamp(28px,4vw,56px) 0;
  font-size:clamp(48px,9vw,150px);line-height:0.9;white-space:normal;}
.plakat__sub{padding:0 var(--gutter);max-width:60ch;font-family:var(--sans);font-weight:400;
  font-size:clamp(17px,1.8vw,22px);line-height:1.5;color:rgba(255,255,255,0.74);}
.plakat ::selection{background:var(--paper);color:var(--ink);}

/* ---------- Zahlen ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);}
.stat{padding:clamp(28px,3.5vw,48px) clamp(20px,2.4vw,40px);border-left:1px solid var(--line);}
.stat:first-child{border-left:none;}
.stat__num{font-family:var(--sans);font-weight:800;font-size:clamp(64px,9vw,148px);
  letter-spacing:-0.04em;line-height:0.9;}
.stat__lbl{font-family:var(--mono);font-weight:600;font-size:12px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);margin:18px 0 8px;}
.stat__txt{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1.5vw,18px);
  line-height:1.45;color:var(--text-2);max-width:30ch;}

/* ---------- KI ---------- */
.ki-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,5vw,80px);
  padding:0 var(--gutter);align-items:start;}
.ki-grid .body{max-width:54ch;}

/* ---------- Kontakt ---------- */
.kontakt .display{margin:clamp(24px,4vw,48px) 0 clamp(40px,6vw,72px);}
.kontakt__links{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,80px);padding:0 var(--gutter);}
.kontakt__item .label{margin-bottom:8px;}
.kontakt__item a,.kontakt__item span{font-family:var(--sans);font-weight:700;
  font-size:clamp(20px,2.2vw,30px);letter-spacing:-0.01em;color:var(--ink);
  display:inline-block;position:relative;}
.kontakt__item a::after{content:"";position:absolute;left:0;bottom:2px;width:100%;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.2,.7,.2,1);}
.kontakt__item a:hover::after{transform:scaleX(1);}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--ink);padding:32px var(--gutter);
  display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:16px;
  font-family:var(--mono);font-weight:500;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);}
.footer a:hover{color:var(--ink);}
.footer__r{text-align:right;}

/* ---------- Unterseiten-Kopf ---------- */
.page-head{padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(40px,6vw,72px);}
/* Unterseiten-Titel: Typo wie der Startseiten-Hero (Versalien, schwer, eng, gross),
   im Seitenrand, zweizeilig umbrechend/trennend, mit Luft zum Lead */
.page-head .display{margin-top:clamp(24px,4vw,48px);text-transform:uppercase;font-weight:800;
  letter-spacing:-0.04em;line-height:0.82;font-size:clamp(46px,10vw,176px);
  padding:0 var(--gutter);white-space:normal;overflow-wrap:break-word;hyphens:auto;-webkit-hyphens:auto;}
.page-head .hero__grid{margin-top:clamp(44px,6vw,80px);}
.prose{padding:0 var(--gutter);max-width:72ch;}
.prose h2{font-family:var(--sans);font-weight:700;font-size:clamp(22px,2.4vw,32px);
  letter-spacing:-0.01em;margin:1.6em 0 0.5em;}
.prose p{font-family:var(--sans);font-weight:400;font-size:clamp(17px,1.7vw,21px);
  line-height:1.55;color:var(--text-2);}
.prose p strong{font-weight:800;color:var(--ink);}
.prose .first{font-size:clamp(20px,2vw,26px);color:var(--ink);font-weight:500;line-height:1.4;}

/* ---------- Figur / Bild (gerahmt, Monolith) ---------- */
.figure{margin:0;padding:0 var(--gutter);}
.figure__img{width:100%;height:auto;display:block;border:1px solid var(--line);}
.figure__cap{margin-top:14px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-family:var(--mono);font-size:12px;letter-spacing:0.04em;text-transform:uppercase;color:var(--mute);}
.figure__cap span:last-child{text-align:right;}

/* ---------- Hero (Startseite, Monolith — invertierte Sektion 00) ---------- */
.hb{position:relative;min-height:100vh;overflow:hidden;background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;padding:clamp(124px,17vh,196px) 0 clamp(28px,4vh,44px);}
.hb__top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:0 var(--gutter);
  font-family:var(--mono);font-size:clamp(11px,1vw,13px);letter-spacing:0.08em;text-transform:uppercase;color:var(--mute);}
.hb__top .r{color:#f2f2f2;}
.hb__title{margin:clamp(44px,8vh,108px) 0 0;padding:0 var(--gutter);font-weight:800;text-transform:uppercase;
  letter-spacing:-0.04em;line-height:0.84;font-size:clamp(56px,15vw,240px);color:var(--paper);}
.hb__title .l{display:block;overflow:hidden;padding:.06em 0;margin:-.06em 0;}
.hb__title .l i{display:block;font-style:normal;white-space:nowrap;transform:translateY(115%);
  will-change:transform;animation:poLineUp 1.2s cubic-bezier(.16,1,.3,1) both;}
.hb__title .l:nth-child(1) i{animation-delay:.30s;}
.hb__title .l:nth-child(2) i{animation-delay:.44s;}
.hb__lead{max-width:48ch;padding:0 var(--gutter);margin:clamp(72px,16vh,220px) 0 clamp(58px,8vh,104px);
  font-family:var(--sans);font-weight:400;font-size:clamp(17px,1.7vw,22px);line-height:1.5;color:#cfcfcf;}
.hb__lead strong{color:var(--paper);font-weight:700;}
.hb__foot{display:flex;justify-content:space-between;align-items:center;gap:20px;
  border-top:1px solid rgba(255,255,255,0.16);
  margin:auto var(--gutter) 0;padding-top:20px;
  font-family:var(--mono);font-size:clamp(10px,0.9vw,12px);letter-spacing:0.08em;text-transform:uppercase;color:var(--mute);}
.hb__sig{display:inline-flex;align-items:center;gap:12px;color:#f2f2f2;}
.hb__foot img{height:22px;width:auto;display:block;}

/* ---------- Hero-Poster (Startseite) ---------- */
.hero-poster{position:relative;min-height:100vh;background:#0A0A0A;color:#F2F2F2;
  font-family:var(--sans);display:flex;flex-direction:column;overflow:hidden;}
.hero-poster a{color:inherit;}
.hero-poster ::selection{background:#fff;color:#0A0A0A;}
/* Eine Nav: über dem Poster transparent + weiß, ab dem hellen Bereich solide weiß */
.nav--floating{position:fixed;top:0;left:0;right:0;background:transparent;
  border-bottom-color:rgba(255,255,255,0.16);transition:background .3s ease,border-color .3s ease;}
.nav--floating .nav__brand img{transition:filter .3s ease;}
.nav--floating:not(.is-solid) .nav__brand img{filter:invert(1);}
.nav--floating:not(.is-solid) .nav__links a{color:#F2F2F2;}
.nav--floating:not(.is-solid) .nav__links a::after{background:#F2F2F2;}
.nav--floating:not(.is-solid) .nav__place{color:#9a9a9a;}
.nav--floating:not(.is-solid) .nav__burger{color:#F2F2F2;border-color:rgba(255,255,255,0.4);}
.nav--floating:not(.is-solid) .nav__mobile a{color:#F2F2F2;border-top-color:rgba(255,255,255,0.16);}
/* Offenes Mobil-Menü über dem Hero: deckender dunkler Hintergrund, damit nichts durchscheint */
.nav--floating.nav--menu-open:not(.is-solid){background:var(--ink);}
.nav--floating.is-solid{background:var(--paper);border-bottom-color:var(--ink);}
/* Edle Choreografie: maskiertes Zeilen-Reveal des Titels, sanfte gestaffelte
   Einblendungen (expo-out), lebendiger Dunst (Driften) + Glow (Pulsieren). */
@keyframes poFade{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes poLineUp{from{transform:translateY(115%);}to{transform:translateY(0);}}
@keyframes poSmokeIn{from{opacity:0;}to{opacity:1;}}
@keyframes poDrift{0%,100%{transform:translate3d(0,0,0) scale(1);}50%{transform:translate3d(-1%,-1.6%,0) scale(1.045);}}
@keyframes poGlowPulse{0%,100%{opacity:1;}50%{opacity:.66;}}
.hero-poster .po-title{line-height:0.82;}
.hero-poster .po-line{display:block;overflow:hidden;padding:0.06em 0;margin:-0.06em 0;}
.hero-poster .po-line-in{display:block;transform:translateY(115%);will-change:transform;
  animation:poLineUp 1.2s cubic-bezier(.16,1,.3,1) both;}
.hero-poster .po-line:nth-child(1) .po-line-in{animation-delay:.36s;}
.hero-poster .po-line:nth-child(2) .po-line-in{animation-delay:.52s;}
.hero-poster .pf2{animation:poFade 1.1s cubic-bezier(.16,1,.3,1) .28s both;}
.hero-poster .pf1{animation:poFade 1.2s cubic-bezier(.16,1,.3,1) .92s both;}
.hero-poster .pcredit{animation:poFade 1.2s cubic-bezier(.16,1,.3,1) 1.08s both;}
.hero-poster .po-smoke{opacity:0;animation:poSmokeIn 1.8s ease .1s both, poDrift 28s ease-in-out 1.9s infinite;}
.hero-poster .po-glow{opacity:0;animation:poSmokeIn 2.2s ease .2s both, poGlowPulse 10s ease-in-out 2.4s infinite;}
@media(max-width:760px){
  .hero-poster .po-names{font-size:15px!important;}
  .hero-poster .po-title{font-size:27vw!important;}
  .hero-poster .po-wrap{padding:88px 24px 0!important;}
  .hero-poster .hp-links{display:none!important;}
}
@media(prefers-reduced-motion:reduce){
  .hero-poster .pf1,.hero-poster .pf2,.hero-poster .pcredit,
  .hero-poster .po-line-in,.hero-poster .po-smoke,.hero-poster .po-glow,
  .hb__title .l i{
    animation:none!important;opacity:1!important;transform:none!important;}
}

/* ---------- Scroll-Reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s ease,transform 1s ease;}
.reveal.in{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  :root{--gutter:24px;}
  .nav{grid-template-columns:1fr auto;}
  .nav__links,.nav__place{display:none;}
  .nav__burger{display:inline-block;}
  .nav__mobile{grid-column:1 / -1;flex-direction:column;gap:2px;padding-top:14px;}
  .nav__mobile.is-open{display:flex;}
  .nav__mobile a{font-family:var(--mono);font-size:14px;text-transform:uppercase;
    letter-spacing:0.04em;padding:14px 0;border-top:1px solid var(--line);}
  .hero__grid,.ki-grid{grid-template-columns:1fr;}
  .stats{grid-template-columns:1fr;}
  .stat{border-left:none;border-top:1px solid var(--line);}
  .stat:first-child{border-top:none;}
  .il-row{grid-template-columns:40px 1fr;gap:14px 16px;}
  .il-arr{display:none;}
  .il-row:hover{padding-left:calc(var(--gutter) + 14px);}
  .display{font-size:clamp(64px,22vw,150px);padding-left:0;white-space:normal;}
  .manifest{text-align:left;}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto;}
  .reveal{opacity:1 !important;transform:none !important;transition:none !important;}
  .il-row,.il-arr{transition:none !important;}
}

/* ============================================================
   VERTRIEBS-CHECK (Quiz) — Monolith
   Reines Schwarz/Weiß · eckig (radius ≤2px) · 1px-Linien
   Ausgewählte Option = invertiert · Balken: schwarz auf #DDDDDD
   ============================================================ */

/* Intro: Feature-Spalten (wie .stat, aber 1px-Oberkante) */
.check-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin:clamp(40px,6vw,64px) 0 clamp(36px,5vw,48px);border-top:1px solid var(--line);}
.check-feat{border-left:1px solid var(--line);padding:24px clamp(18px,2vw,28px) 4px;}
.check-feat:first-child{border-left:none;}
.check-feat .l{font-family:var(--mono);font-weight:600;font-size:12px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);margin-bottom:10px;}
.check-feat .t{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1.5vw,17px);
  line-height:1.5;color:var(--text-2);max-width:34ch;}

/* Phasen-Umschaltung */
.check-phase{display:none;}
.check-phase.active{display:block;}

/* Buttons (CTA + Outline), eckig, S/W */
.check-phase .btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);
  font-weight:600;font-size:13px;letter-spacing:0.04em;text-transform:uppercase;
  border:1px solid var(--ink);border-radius:2px;padding:16px 26px;cursor:pointer;
  background:var(--ink);color:var(--paper);transition:background .25s,color .25s;}
.check-phase .btn--primary{background:var(--ink);color:var(--paper);}
.check-phase .btn--primary:hover{background:var(--paper);color:var(--ink);}
.check-phase .btn--outline{background:var(--paper);color:var(--ink);}
.check-phase .btn--outline:hover{background:var(--ink);color:var(--paper);}
.check-phase .btn--lg{padding:18px 30px;font-size:13px;}
.check-phase .btn .arr{font-family:var(--sans);}

/* Quiz-Kopf: Dimension + Fragenzähler (Mono-Labels) */
.q-top{display:flex;justify-content:space-between;align-items:center;gap:16px;
  margin-bottom:14px;font-family:var(--mono);font-weight:600;font-size:13px;
  letter-spacing:0.04em;text-transform:uppercase;color:var(--mute);}
.q-top .dim{color:var(--ink);}

/* Fortschritts-Balken: schwarz auf hellgrau */
.q-bar{height:4px;background:var(--line);border-radius:2px;overflow:hidden;
  margin-bottom:clamp(40px,6vw,60px);}
.q-bar i{display:block;height:100%;background:var(--ink);transition:width .3s ease;}

/* Frage */
.q-text{font-family:var(--sans);font-weight:800;font-size:clamp(28px,3.6vw,52px);
  line-height:1.12;letter-spacing:-0.025em;margin:0 0 clamp(36px,5vw,50px);
  max-width:18ch;color:var(--ink);}

/* Antwort-Optionen */
.q-opts{display:flex;flex-direction:column;gap:10px;max-width:720px;}
.q-opt{display:flex;align-items:center;gap:18px;width:100%;text-align:left;
  padding:18px 22px;background:var(--paper);color:var(--ink);
  border:1px solid var(--ink);border-radius:2px;cursor:pointer;
  font-family:var(--sans);font-size:17px;font-weight:600;letter-spacing:-0.01em;
  transition:background .15s,color .15s;}
.q-opt:hover{background:var(--ink);color:var(--paper);}
.q-opt.sel{background:var(--ink);color:var(--paper);}      /* gewählt = invertiert */
.q-opt .on{font-family:var(--mono);font-weight:600;font-size:13px;color:var(--mute);
  min-width:22px;transition:color .15s;}
.q-opt:hover .on,.q-opt.sel .on{color:var(--paper);}

/* Aktionen unter dem Quiz */
.q-actions{display:flex;align-items:center;gap:24px;margin-top:clamp(36px,5vw,44px);}
.q-back,.q-cancel{background:none;border:none;cursor:pointer;font-family:var(--mono);
  letter-spacing:0.04em;text-transform:uppercase;}
.q-back{font-size:13px;font-weight:600;color:var(--ink);}
.q-back:hover{text-decoration:underline;}
.q-cancel{font-size:12px;font-weight:500;color:var(--mute);text-decoration:underline;}
.q-cancel:hover{color:var(--ink);}

/* Ergebnis: Score-Kopf */
.score-head{display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,4vw,48px);
  align-items:center;background:var(--paper);color:var(--ink);
  border:1px solid var(--ink);border-radius:2px;padding:clamp(32px,4vw,48px);
  margin-bottom:24px;}
.score-head .big{font-family:var(--sans);font-weight:800;font-size:clamp(80px,11vw,150px);
  letter-spacing:-0.04em;line-height:0.9;color:var(--ink);text-align:center;}
.score-head .u{font-family:var(--mono);font-weight:600;font-size:12px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);margin-top:6px;text-align:center;}
.score-head h2{font-family:var(--sans);font-weight:700;font-size:clamp(28px,3.2vw,48px);
  letter-spacing:-0.02em;line-height:1.04;margin:0 0 14px;color:var(--ink);}
.score-head .desc{font-family:var(--sans);font-weight:400;font-size:clamp(16px,1.6vw,18px);
  line-height:1.55;color:var(--text-2);margin:0;max-width:560px;}

/* Ergebnis: Dimensionen */
.dims{background:var(--paper);border:1px solid var(--ink);border-radius:2px;
  padding:clamp(28px,4vw,44px);margin-bottom:24px;}
.dimrow{margin-bottom:24px;}
.dimrow:last-child{margin-bottom:0;}
.dimrow .top{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:10px;}
.dimrow .name{font-family:var(--sans);font-weight:700;font-size:clamp(16px,1.7vw,19px);
  letter-spacing:-0.01em;color:var(--ink);}
.dimrow .val{font-family:var(--mono);font-weight:600;font-size:14px;color:var(--ink);white-space:nowrap;}
.dimrow .track{height:8px;background:var(--line);border-radius:2px;overflow:hidden;}
.dimrow .track i{display:block;height:100%;background:var(--ink);}
/* Schwache Dimension (<60): über Mono-Hinweis markiert, nicht über Farbe */
.dimrow.weak .val::after{content:" · Hebel";color:var(--mute);}

/* Ergebnis: Empfehlungen */
.recs{margin-bottom:clamp(32px,5vw,40px);}
.rec{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  padding:28px 0;border-top:1px solid var(--line);}
.rec h3{font-family:var(--sans);font-weight:700;font-size:clamp(20px,2.2vw,24px);
  letter-spacing:-0.01em;margin:0 0 8px;color:var(--ink);}
.rec p{font-family:var(--sans);font-weight:400;font-size:clamp(15px,1.5vw,16px);
  line-height:1.55;color:var(--text-2);margin:0;}
.rec a{font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--ink);white-space:nowrap;
  border-bottom:1px solid var(--ink);padding-bottom:4px;}
.rec a:hover{color:var(--mute);border-color:var(--mute);}

/* Ergebnis: Aktionsleiste */
.result-actions{display:flex;flex-wrap:wrap;gap:16px;align-items:center;
  border-top:1px solid var(--line);padding-top:36px;}

/* Quiz-Breadcrumb + Eyebrow (Mono, S/W) */
.check-breadcrumb{display:flex;align-items:center;gap:12px;font-family:var(--mono);
  font-weight:600;font-size:12.5px;letter-spacing:0.04em;text-transform:uppercase;
  color:var(--mute);margin-bottom:clamp(28px,4vw,40px);flex-wrap:wrap;}
.check-breadcrumb a{color:var(--mute);}
.check-breadcrumb a:hover{color:var(--ink);}
.check-breadcrumb .cur{color:var(--ink);}
.check-kicker{font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--mute);margin:0 0 24px;}

/* Quiz-Responsive */
@media(max-width:900px){
  .check-feats{grid-template-columns:1fr;}
  .check-feat{border-left:none;border-top:1px solid var(--line);padding-top:20px;}
  .check-feat:first-child{border-top:none;}
  .score-head{grid-template-columns:1fr;text-align:center;}
  .score-head .desc{margin:0 auto;}
  .rec{grid-template-columns:1fr;gap:14px;}
  .q-text{max-width:none;}
}

/* Druck (PDF-Report): Navigation, Footer, Steuer-Buttons ausblenden */
@media print{
  .nav,.footer,.b77-noprint{display:none !important;}
  body{background:#fff;color:#000;}
  .check-phase{display:none !important;}
  #phase-result.active{display:block !important;}
  .section{border-top:none;}
}
