/* ============================================================
   digitario.ch V2 — «Weissraum»
   Schweizer Plakat × generatives Feld. Kein Build-Schritt.
   ============================================================ */

/* ZENTRALES FARBSYSTEM: Markenfarbe nur hier ändern (--red + --red-tint),
   alles andere (CSS, Inline-SVGs, WebGL-Feld) zieht automatisch nach. */
:root{
  --paper:#F2EFE7; --paper2:#EAE6DB; --ink:#101013; --ink70:rgba(var(--ink-rgb),.7);
  --ink45:rgba(var(--ink-rgb),.58); --line:rgba(var(--ink-rgb),.16);
  /* AKZENTFARBE — aktuell: Petrol (Test 06/2026).
     Zurück zu Rot? Genau diese 3 Werte tauschen:
       --red:#E2080F;  --red-rgb:226,8,15;  --red-tint:rgba(226,8,15,.06); */
  --red:#0E6E6B;
  --red-rgb:14,110,107;
  --red-tint:rgba(14,110,107,.06);
  /* Semantische Tokens (Dark Mode überschreibt NUR Variablen, nie Regeln) */
  --ink-rgb:16,16,19;
  --paper-rgb:242,239,231;
  --card:#fff;          /* helle Karten-/Tabellenflächen */
  --on-accent:#fff;     /* Text/Elemente AUF der Akzentfarbe */
  --ok:#16A34A; --warn:#B5860B;
  --c-teal:#0F766E; --c-warm:#B45309; --c-blue:#1D4ED8; --c-purple:#A21CAF;
  --disp:'Anton',Impact,sans-serif; --body:'Archivo',-apple-system,sans-serif; --mono:'Space Mono',ui-monospace,monospace;
  color-scheme:light; /* UA-Widgets folgen IMMER dem Site-Theme, nie dem System */
}
*{margin:0;padding:0;box-sizing:border-box}
::selection{background:var(--red);color:var(--on-accent)}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--body);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
/* custom cursor removed – native cursor everywhere */
body.modal-open{overflow:hidden}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1340px;margin:0 auto;padding:0 clamp(18px,4vw,56px)}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em}
.disp{font-family:var(--disp);font-weight:400;text-transform:uppercase;letter-spacing:.01em}
.red{color:var(--red)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:500}
.skip-link:focus{left:0}
/* Globaler Tastatur-Fokus für interaktive Elemente ohne eigenen Fokus-Stil (A11y) */
a:focus-visible,button:focus-visible,[tabindex]:focus-visible,summary:focus-visible{outline:2px solid var(--red);outline-offset:2px;border-radius:2px}

/* ---------- Feld-Canvas (nur Desktop — auf Touch reines Papier) ---------- */
#field{position:fixed;inset:0;z-index:0;pointer-events:none}
.veil-soft{position:fixed;inset:0;z-index:1;pointer-events:none;background:radial-gradient(120% 90% at 50% 0%,transparent 55%,rgba(var(--paper-rgb),.5))}
@media(max-width:899px),(pointer:coarse){.veil-soft{display:none}} /* Feld läuft auch mobil (reduzierte Variante in field.js) */
main,header,footer,.crop{position:relative;z-index:2}

/* Schnittmarken */
.crop{position:fixed;width:18px;height:18px;z-index:40;pointer-events:none;opacity:.5}
.crop::before,.crop::after{content:"";position:absolute;background:var(--ink)}
.crop::before{width:100%;height:1px;top:50%}
.crop::after{width:1px;height:100%;left:50%}
.crop.tl{top:14px;left:14px}.crop.tr{top:14px;right:14px}.crop.bl{bottom:14px;left:14px}.crop.br{bottom:14px;right:14px}
@media(max-width:760px){.crop{display:none}}

/* ---------- Cursor ---------- */
.cur-dot,.cur-ring{display:none}
.cur-dot{width:8px;height:8px;background:var(--red)}
.cur-ring{width:38px;height:38px;border:1px solid var(--ink);transition:width .25s,height .25s,border-color .25s,background .25s}
.cur-ring.hot{width:64px;height:64px;border-color:var(--red);background:rgba(var(--red-rgb),.07)}
@media(pointer:coarse){.cur-dot,.cur-ring{display:none}}

/* ---------- Progress ---------- */
.progress{position:fixed;top:0;left:0;height:3px;z-index:100;width:0;background:var(--red)}

/* ---------- Header ---------- */
header#hdr{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .35s,box-shadow .35s}
header#hdr.scrolled{background:rgba(var(--paper-rgb),.92);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{text-decoration:none;display:flex;align-items:center;gap:10px}
.logo-img{height:46px;width:auto;display:block}
.logo-img.inv{filter:brightness(0) invert(1)}
.logo .ort{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;color:var(--ink45);text-transform:uppercase}
@media(max-width:760px){.logo .ort{display:none}.logo-img{height:40px}}
.nav-links{display:none;gap:28px;align-items:center;position:relative}
.nav-links a{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;color:var(--ink70);transition:color .2s}
.nav-links a:hover{color:var(--red)}
.lang-switch{color:var(--ink45)}
.lang-switch a{color:var(--ink45)!important}
.lang-switch a:hover{color:var(--red)!important}
.lang-switch b{color:var(--ink)}
.nav-mobile-actions{display:flex;gap:12px;align-items:center}
@media(min-width:980px){.nav-links{display:flex}.nav-mobile-actions .menu-btn{display:none}.nav-mobile-actions{display:none}}
@media(max-width:979px){.nav-links{display:none}}
.menu-btn{width:42px;height:42px;border:1px solid var(--ink);background:transparent;cursor:pointer;display:flex;flex-direction:column;gap:6px;align-items:center;justify-content:center}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink)}

/* ---------- Mobile Menu ---------- */
.mobile-menu{position:fixed;inset:0;z-index:200;background:var(--ink);color:var(--paper);display:flex;flex-direction:column;transform:translateY(-102%);transition:transform .45s cubic-bezier(.7,0,.2,1);visibility:hidden}
.mobile-menu.open{transform:none;visibility:visible}
.mobile-menu .wrap{width:100%} /* margin:0 auto der .wrap würde das Flex-Stretching aushebeln */
.mm-head{display:flex;justify-content:space-between;align-items:center;height:64px;flex-shrink:0;border-bottom:1px solid rgba(var(--paper-rgb),.15)}
.mm-close{width:42px;height:42px;border:1px solid rgba(var(--paper-rgb),.4);background:transparent;color:var(--paper);font-size:16px;cursor:pointer;flex-shrink:0}
.mm-links{flex:1;display:flex;flex-direction:column;justify-content:flex-start;gap:10px;padding-top:26px;padding-bottom:26px;overflow-y:auto}
.mm-links>a{font-family:var(--disp);font-size:clamp(26px,7vw,40px);text-transform:uppercase;color:var(--paper);text-decoration:none;line-height:1.12;opacity:0;transform:translateY(16px);transition:opacity .4s ease calc(.06s * var(--st)),transform .4s ease calc(.06s * var(--st)),color .2s}
.mobile-menu.open .mm-links>a{opacity:1;transform:none}
.mm-links>a:hover{color:var(--red)}
.mm-divider{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:rgba(var(--paper-rgb),.4);margin-top:14px;display:flex;align-items:center;gap:12px}
.mm-divider::after{content:"";flex:1;height:1px;background:rgba(var(--paper-rgb),.15)}
.mm-sub{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;margin:4px 0 8px}
.mm-sub a{font-family:var(--mono)!important;font-size:11.5px!important;letter-spacing:.08em;text-transform:uppercase;color:rgba(var(--paper-rgb),.65)!important;text-decoration:none;line-height:1.5}
.mm-sub a:hover{color:var(--red)!important}
.mm-foot{margin-top:auto;padding-top:22px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;opacity:0;transition:opacity .4s ease .3s}
.mobile-menu.open .mm-foot{opacity:1}
.mm-lang{font-family:var(--mono);font-size:13px;letter-spacing:.14em;color:rgba(var(--paper-rgb),.5)}
.mm-lang a{color:rgba(var(--paper-rgb),.5);text-decoration:none}
.mm-lang a:hover{color:var(--red)}
.mm-lang b{color:var(--paper)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;background:var(--red);color:var(--on-accent);font-family:var(--mono);font-weight:700;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;padding:16px 28px;border:none;border-radius:0;text-decoration:none;cursor:pointer;position:relative;overflow:hidden;transition:background .25s}
.btn::after{content:"";position:absolute;inset:0;background:var(--ink);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.7,0,.2,1)}
.btn:hover::after{transform:scaleX(1);transform-origin:left}
.btn span{position:relative;z-index:1}
.btn.small{padding:12px 18px;font-size:11px}
.btn[disabled]{opacity:.55;cursor:not-allowed}
.btn[disabled]::after{display:none}

/* ---------- Reveal ---------- */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.65,.2,1),transform .8s cubic-bezier(.2,.65,.2,1)}
.rv.on{opacity:1;transform:none}
.rv.d1{transition-delay:.07s}.rv.d2{transition-delay:.14s}.rv.d3{transition-delay:.21s}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1!important;transform:none!important;transition:none!important}
  .marq-in{animation:none!important}
  .schem .flow{animation:none!important}
  .mobile-menu,.mm-links>a{transition:none}
}

/* Umlaut-Punkte als akzentfarbenes Markendetail in Plakat-Headlines */
.kw{white-space:nowrap}
.um{position:relative;display:inline-block}
.um b{position:absolute;left:50%;top:-0.075em;transform:translateX(-50%);width:.46em;height:.10em;pointer-events:none}
.um b::before,.um b::after{content:"";position:absolute;top:0;width:.16em;height:.10em;background:var(--red)}
.um b::before{left:0}
.um b::after{right:0}
.um-sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap}

/* ---------- Hero ---------- */
.hero{display:flex;flex-direction:column;justify-content:flex-end;padding-top:128px;padding-bottom:0} /* Manifest schliesst die Hero ab – kein doppeltes Section-Padding */
@media(min-width:900px){.hero{padding-top:150px}}
.hero .meta-row{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--ink);padding-bottom:14px;margin-bottom:26px;flex-wrap:wrap;gap:10px}
.hero .meta-row .mono{color:var(--ink70);text-transform:uppercase}
.hero .meta-row .avail{color:var(--red);font-weight:700}
.field-note{color:var(--ink45)}
@media(max-width:899px),(pointer:coarse){
  .mr-hide{display:none}
  .field-note{display:none}
  /* Ohne Feld kein Grund für Leerraum: Hero kompakt, Inhalt sofort sichtbar */
  .hero{min-height:auto;padding-top:108px}
  .hero .meta-row{margin-bottom:20px;padding-bottom:12px}
  .hero-sub{padding:24px 0 36px;gap:20px}
}
h1{font-family:var(--disp);text-transform:uppercase;font-size:clamp(46px,13.5vw,210px);line-height:.92;letter-spacing:.005em;text-wrap:balance}
/* Plakat-Hierarchie: beide Zeilen exakt auf Satzspiegelbreite (Blocksatz-Look).
   Grösse = 100cqw / gemessenes Breite-zu-Schriftgrad-Verhältnis der Zeile;
   em-Werte davor sind der Fallback für Browser ohne Container-Queries. */
.hero .wrap{container-type:inline-size;width:100%} /* width nötig: als Flex-Kind mit margin:auto würde Containment die Breite kollabieren */
.h1-top{display:block;font-size:.46em;font-size:5.5cqw;letter-spacing:.012em;white-space:nowrap}
.h1-main{display:block;font-size:.82em;font-size:11.78cqw;white-space:nowrap}
@media(max-width:759px){
  /* Mobile: Subjektzeile darf 2-zeilig werden und führt die Hierarchie an */
  .h1-top{white-space:normal;font-size:8.3cqw;line-height:1.04;margin-bottom:.12em}
  html[lang=en] .h1-top{font-size:8.3cqw}
}
/* Anton-Gedankenstrich-Ersatz: gezeichneter Balken statt Font-Glyphe */
.dsh{display:inline-block;width:.42em;height:.075em;background:currentColor;vertical-align:.18em;margin:0 .04em} /* Halbgeviert-Proportion */
/* EN-Zeilen haben andere Laufweiten */
html[lang=en] .h1-top{font-size:5.83cqw}
html[lang=en] .h1-main{font-size:11.05cqw}
h1 .outline,.outline{color:transparent;-webkit-text-stroke:2px var(--ink)}
h2 .outline{-webkit-text-stroke:1.8px var(--ink)}
.hero-sub{display:grid;gap:22px;padding:26px 0 36px;align-items:end}
@media(min-width:980px){.hero-sub{grid-template-columns:minmax(0,52ch) auto;justify-content:space-between}}
.hero-sub p{font-size:clamp(16px,1.7vw,19px);color:var(--ink70);max-width:46ch}
.hero-sub p b{color:var(--ink)}
.hero-cta{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
@media(min-width:980px){.hero-cta{flex-direction:column;align-items:flex-end;gap:12px;text-align:right}} /* CTA-Block bündig an der rechten Satzspiegelkante */
.cta-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--ink45);text-transform:uppercase}

/* ---------- Manifest-Zeile (statisch — Botschaft statt Ticker-Gimmick) ---------- */
.marq{border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:14px 0;background:var(--paper)}
.marq-in{display:flex;flex-wrap:wrap;justify-content:center;align-items:baseline;gap:6px 22px;padding:0 18px;text-align:center}
.marq-in .seg{font-family:var(--disp);font-size:clamp(17px,2.2vw,30px);text-transform:uppercase;white-space:nowrap}
.marq-in .seg em{font-style:normal;color:transparent;-webkit-text-stroke:1.1px var(--ink)}
.marq-in .x{font-style:normal;color:var(--red);font-family:var(--disp);font-size:clamp(14px,1.8vw,24px)}

/* ---------- Sections ---------- */
section{padding:clamp(64px,8vw,112px) 0;position:relative}
.sec-no{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--red);text-transform:uppercase;display:flex;align-items:center;gap:14px;margin-bottom:26px}
.sec-no::after{content:"";flex:0 0 60px;height:1px;background:var(--ink)}
h2{font-family:var(--disp);text-transform:uppercase;font-size:clamp(40px,7.2vw,108px);line-height:.95;letter-spacing:.005em;text-wrap:balance}
@media(max-width:480px){h2{font-size:clamp(28px,7.7vw,40px)}} /* lange Wörter (z. B. VERANTWORTLICHER.) müssen ohne Trennung passen */
h2 .redw,.redw{color:var(--red)}
.sec-intro{margin-top:24px;color:var(--ink70);max-width:48ch;font-size:17px}

/* ---------- Leistungen ---------- */
.posters{margin-top:60px;border-top:1px solid var(--ink)}
.poster{display:grid;grid-template-columns:1fr;gap:8px;padding:34px 0;border-bottom:1px solid var(--ink);text-decoration:none;position:relative}
@media(min-width:900px){.poster{grid-template-columns:120px 1fr 360px 60px;gap:34px;align-items:center;padding:44px 0}}
.poster .no{font-family:var(--disp);font-size:clamp(26px,3vw,42px);color:transparent;-webkit-text-stroke:1.4px var(--ink);transition:color .3s,-webkit-text-stroke-color .3s}
.poster h3{font-family:var(--disp);text-transform:uppercase;font-size:clamp(30px,4.6vw,64px);line-height:.98;transition:transform .35s cubic-bezier(.2,.65,.2,1)}
.poster p{font-size:15px;color:var(--ink70);max-width:40ch}
.poster .arr{font-family:var(--disp);font-size:34px;justify-self:end;transition:transform .35s,color .3s}
.poster:hover .arr{transform:translateX(10px);color:var(--red)}
.poster:hover h3{transform:translateX(14px)}
.poster:hover .no{color:var(--red);-webkit-text-stroke-color:var(--red)}
.poster .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.poster .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line);padding:4px 9px;color:var(--ink70)}
.poster .bar{position:absolute;left:0;top:0;bottom:0;width:0;background:rgba(var(--red-rgb),.05);transition:width .45s cubic-bezier(.2,.65,.2,1);pointer-events:none}
.poster:hover .bar{width:100%}
.poster .golabel{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink45);margin-top:8px}

/* ---------- Kennzahlen ---------- */
.numwall{display:grid;grid-template-columns:1fr 1fr;gap:1px;border:1px solid var(--ink);margin-top:60px;background:var(--ink)}
@media(min-width:900px){.numwall{grid-template-columns:repeat(4,1fr)}}
.numcell{background:var(--paper);padding:clamp(22px,3vw,40px)}
.numcell .n{font-family:var(--disp);font-size:clamp(44px,5.6vw,84px);line-height:1}
.numcell .n i{font-style:normal;color:var(--red)}
.numcell p{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink70);margin-top:10px;line-height:1.8;white-space:pre-line}

/* ---------- Agent-Schema ---------- */
.schem{margin-top:60px;border:1px solid var(--ink);background:rgba(var(--paper-rgb),.7);backdrop-filter:blur(3px);padding:clamp(20px,3.5vw,48px)}
.schem-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px;gap:10px;flex-wrap:wrap}
.schem-head .mono{color:var(--ink70);text-transform:uppercase}
.schem-head .st{color:var(--red);font-weight:700}
.schem svg{width:100%;height:auto;display:block}
.schem .legend{display:flex;gap:26px;flex-wrap:wrap;margin-top:24px;border-top:1px solid var(--line);padding-top:18px}
.schem .legend span{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink70);display:flex;align-items:center;gap:8px}
.schem .legend .sw{width:11px;height:11px;border:1.4px solid var(--ink);flex-shrink:0}
.schem .legend .sw.k{background:var(--ink)}
.schem .legend .sw.r{background:var(--red);border-color:var(--red)}
@keyframes dash{to{stroke-dashoffset:-22}}
.schem .flow{stroke-dasharray:5 6;animation:dash 1.1s linear infinite}

/* ---------- Referenzen (Dossiers) ---------- */
.refs{margin-top:60px;border-top:1px solid var(--ink);position:relative}
.ref{border-bottom:1px solid var(--ink);position:relative}
.ref-head{display:grid;gap:6px;padding:28px 0;width:100%;background:none;border:none;text-align:left;cursor:pointer;font:inherit;color:inherit;position:relative}
@media(min-width:900px){.ref-head{grid-template-columns:64px 150px 1fr 250px 50px;gap:28px;align-items:baseline;padding:34px 0}}
.ref .no{font-family:var(--mono);font-size:11px;color:var(--ink45)}
.ref .ind{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--red)}
.ref h3{font-family:var(--disp);text-transform:uppercase;font-size:clamp(22px,3vw,40px);line-height:1.02;transition:transform .3s}
.ref-head:hover h3{transform:translateX(10px)}
.ref .fact{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink70);text-transform:uppercase;line-height:1.9}
.ref .fact b{color:var(--ink);font-weight:700}
.ref .plus{font-family:var(--disp);font-size:30px;line-height:1;color:var(--ink45);justify-self:end;transition:transform .4s cubic-bezier(.2,.65,.2,1),color .3s}
.ref.open .plus{transform:rotate(45deg);color:var(--red)}
.ref-head:hover .plus{color:var(--red)}
.dossier{display:grid;grid-template-rows:0fr;transition:grid-template-rows .55s cubic-bezier(.2,.65,.2,1)}
.ref.open .dossier{grid-template-rows:1fr}
.dossier>div{overflow:hidden}
/* Inhalt zuerst — das Bild ist nur eine kleine «Briefmarke» am Dossier */
.dossier-in{display:grid;gap:24px;padding:6px 0 40px;opacity:0;transform:translateY(12px);transition:opacity .45s ease .12s,transform .45s ease .12s}
.ref.open .dossier-in{opacity:1;transform:none}
.dossier-in figure{position:relative;margin:0;order:2}
.dossier-in .blk{order:1}
/* Desktop: identisches Raster wie .ref-head — Bild in Spalte 1–2, Text exakt unter der Headline (Spalte 3) */
@media(min-width:900px){
  .dossier-in{grid-template-columns:64px 150px 1fr 250px 50px;gap:28px;align-items:start}
  .dossier-in figure{order:0;grid-column:1/3}
  .dossier-in .blk{order:0;grid-column:3/4;max-width:600px}
}
/* feste Höhe statt aspect-ratio: width/height-Attribute können nicht dazwischenfunken */
.dossier-in img{width:100%;height:160px;object-fit:cover;border:1px solid var(--ink);box-shadow:7px 7px 0 var(--red);filter:grayscale(.35) contrast(1.05)}
.dossier-in figcaption{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink45);margin-top:12px;line-height:1.7}
@media(max-width:899px){
  .dossier-in figure{max-width:220px}
  .dossier-in img{height:130px}
}
.dossier-in .blk{display:grid;gap:18px}
.dossier-in .dlbl{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.dossier-in p{font-size:15.5px;color:var(--ink70);max-width:56ch;line-height:1.7}
.dossier-in p b{color:var(--ink)}
.dossier-in .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.dossier-in .chip{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--ink);padding:7px 12px;color:var(--ink)}
.dossier-in .chip.r{background:var(--red);border-color:var(--red);color:var(--on-accent)}
.dossier-link{display:inline-block;margin-top:6px;font-family:var(--mono);font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);text-decoration:none;border-bottom:1px solid var(--red);padding-bottom:2px}
.dossier-link:hover{color:var(--ink);border-color:var(--ink)}

/* ---------- Person ---------- */
.person{background:var(--ink);color:var(--paper)}
.person .sec-no::after{background:var(--paper)}
.person-grid{display:grid;gap:46px}
@media(min-width:980px){.person-grid{grid-template-columns:7fr 5fr;gap:80px;align-items:center}}
.person blockquote p{font-family:var(--disp);text-transform:uppercase;font-size:clamp(30px,4.6vw,62px);line-height:1.04}
.person blockquote p .outline{-webkit-text-stroke:1.6px var(--paper)}
.person cite{display:block;margin-top:28px;font-style:normal;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(var(--paper-rgb),.5)}
.person .bio{margin-top:20px;color:rgba(var(--paper-rgb),.65);font-size:16px;max-width:46ch}
.pwrap{position:relative;max-width:430px;justify-self:center}
.pwrap img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:grayscale(1) contrast(1.12);border:1px solid rgba(var(--paper-rgb),.25)}
.pwrap::before{content:"";position:absolute;inset:0;background:var(--red);mix-blend-mode:multiply;opacity:.18}
.pwrap .tag{position:absolute;left:-12px;bottom:26px;background:var(--red);color:var(--on-accent);font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:10px 16px}

/* ---------- FAQ ---------- */
.faq-list{margin-top:60px;border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--ink)}
.faq-q{display:flex;justify-content:space-between;gap:20px;align-items:baseline;width:100%;background:none;border:none;text-align:left;cursor:pointer;font:inherit;color:inherit;padding:24px 0}
.faq-q h3{font-family:var(--disp);text-transform:uppercase;font-size:clamp(17px,2.2vw,26px);line-height:1.15;transition:color .25s}
.faq-q:hover h3{color:var(--red)}
.faq-q .plus{font-family:var(--disp);font-size:24px;color:var(--ink45);transition:transform .4s cubic-bezier(.2,.65,.2,1),color .3s;flex-shrink:0}
.faq-item.open .plus{transform:rotate(45deg);color:var(--red)}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s cubic-bezier(.2,.65,.2,1)}
.faq-item.open .faq-a{grid-template-rows:1fr}
.faq-a>div{overflow:hidden}
.faq-a p{padding:0 0 26px;color:var(--ink70);font-size:15.5px;max-width:70ch;line-height:1.7}

/* ---------- Booking-Sektion ---------- */
.book{padding-bottom:clamp(56px,7vw,96px)}
.book h2{font-size:clamp(56px,12vw,190px)}
.book .row{display:flex;flex-wrap:wrap;gap:26px;align-items:center;margin-top:40px}
.assure{display:flex;flex-wrap:wrap;margin-top:48px;border:1px solid var(--ink);background:var(--ink);gap:1px}
.assure span{flex:1 1 200px;background:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink70);padding:16px 18px;text-align:center}

/* ---------- Booking-Modal mit Slot-Picker ---------- */
.modal{position:fixed;inset:0;z-index:220;display:none;align-items:center;justify-content:center;padding:16px}
.modal.open{display:flex}
.modal .backdrop{position:absolute;inset:0;background:rgba(var(--ink-rgb),.82);backdrop-filter:blur(8px)}
.modal .box{position:relative;width:min(860px,100%);max-height:92vh;background:var(--paper);border:1px solid var(--ink);box-shadow:18px 18px 0 var(--red);display:flex;flex-direction:column;animation:up .35s cubic-bezier(.2,.7,.2,1)}
@keyframes up{from{transform:translateY(28px);opacity:0}}
.bm-head{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--ink);flex-shrink:0}
.bm-head b{font-family:var(--disp);text-transform:uppercase;font-size:19px;letter-spacing:.02em}
.bm-sub{color:var(--ink45);text-transform:uppercase;display:none}
@media(min-width:640px){.bm-sub{display:inline}}
.bm-head .x{margin-left:auto;width:40px;height:40px;border:1px solid var(--ink);background:transparent;color:var(--ink);cursor:pointer;font-size:16px;transition:all .2s;flex-shrink:0}
.bm-head .x:hover{background:var(--red);border-color:var(--red);color:var(--on-accent)}
.bm-body{padding:8px 22px 26px;overflow-y:auto}
.bm-foot{padding:11px 18px;border-top:1px solid var(--ink);flex-shrink:0;text-align:right}
.bm-foot a{font-family:var(--mono);font-size:11px;color:var(--red);text-decoration:none;font-weight:700;letter-spacing:.06em}
.bm-foot a:hover{text-decoration:underline}
.bm-alert{display:none;border:1px solid var(--red);color:var(--red);font-family:var(--mono);font-size:12px;padding:12px 14px;letter-spacing:.04em;margin-top:14px}
.bm-alert.show{display:block}
.lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:12px;margin:26px 0 14px}
.lbl::after{content:"";flex:1;height:1px;background:var(--ink)}
.days{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin}
.day{flex:0 0 auto;border:1px solid var(--ink);background:var(--card);color:var(--ink);padding:11px 16px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;cursor:pointer;transition:all .2s;text-transform:uppercase}
.day.sel{background:var(--ink);color:var(--paper)}
.day:hover:not(.sel){border-color:var(--red);color:var(--red)}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:10px;margin-top:6px}
.slot{border:1px solid var(--ink);background:var(--card);color:var(--ink);padding:12px 6px;text-align:center;font-family:var(--mono);font-size:13px;cursor:pointer;transition:all .15s}
.slot:hover{border-color:var(--red);color:var(--red)}
.slot.sel{background:var(--red);border-color:var(--red);color:var(--on-accent);font-weight:700}
.bm-empty,.bm-loading{font-family:var(--mono);font-size:12px;color:var(--ink45);padding:14px 0;letter-spacing:.08em}
#bmStep2,#bmDone{display:none}
#bmStep2.show,#bmDone.show{display:block}
.bm-summary{border:1px solid var(--ink);background:var(--card);padding:14px 16px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;margin-bottom:18px}
.bm-summary b{color:var(--red)}
#bmForm{display:grid;gap:14px;max-width:560px}
.field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink70);margin-bottom:6px}
.field input,.field textarea{width:100%;border:1px solid var(--ink);background:var(--card);color:var(--ink);padding:13px 14px;font:inherit;font-size:15px;border-radius:0;-webkit-appearance:none}
.field input:focus,.field textarea:focus{outline:2px solid var(--red);outline-offset:-1px}
.field.err input{outline:2px solid var(--red);outline-offset:-1px}
.hp{position:absolute;left:-9999px;opacity:0}
.bm-privacy{font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;color:var(--ink45);text-transform:uppercase}
.bm-done{border:1px solid var(--ink);background:var(--card);box-shadow:12px 12px 0 var(--red);padding:clamp(24px,4vw,44px);margin-top:22px}
.bm-done h3{font-size:clamp(30px,5vw,50px);line-height:1}
.bm-done p{color:var(--ink70);margin-top:12px;max-width:48ch}

/* ============================================================
   UNTERSEITEN («Weissraum»-Inhaltsseiten)
   ============================================================ */
.p-hero{padding:92px 0 40px}
@media(min-width:900px){.p-hero{padding:118px 0 52px}}
/* Keine Auto-Silbentrennung in Plakat-Headlines (hässliche Brüche wie «VERGLEICHSMA-TRIX»);
   stattdessen ausgewogener Zeilenfall + mobil leicht kleinere Stufe, damit lange Wörter ganz bleiben. */
.p-title{font-family:var(--disp);text-transform:uppercase;font-size:clamp(34px,5.8vw,84px);line-height:.98;letter-spacing:.005em;max-width:18em;text-wrap:balance}
@media(max-width:760px){.p-title{font-size:clamp(26px,8vw,40px)}}
.p-lede{margin-top:24px;font-size:clamp(17px,2vw,21px);color:var(--ink);max-width:42ch;font-weight:500}
.p-hero-grid{display:grid;gap:36px;margin-top:34px;border-top:1px solid var(--ink);padding-top:34px}
@media(min-width:980px){.p-hero-grid{grid-template-columns:minmax(0,1fr) 320px;gap:70px}}
.p-hero-body p{color:var(--ink70);font-size:16.5px;max-width:58ch}
.p-hero-body p+p{margin-top:16px}
.p-facts{display:grid;gap:0;border:1px solid var(--ink);background:var(--card);align-self:start}
.p-fact{padding:16px 18px;border-bottom:1px solid var(--line);display:grid;gap:4px}
.p-fact:last-child{border-bottom:none}
.pf-l{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--red)}
.pf-v{font-size:14.5px;line-height:1.5}

.p-sec{padding:clamp(70px,9vw,120px) 0}
.p-sec.dark{background:var(--ink);color:var(--paper)}
.p-sec.dark .sec-no::after{background:var(--paper)}
.p-h2{font-family:var(--disp);text-transform:uppercase;font-size:clamp(28px,4.4vw,58px);line-height:1;letter-spacing:.005em;max-width:22em}
.p-h2.big{font-size:clamp(34px,6vw,84px);max-width:16em}
.p-prose{margin-top:22px;max-width:62ch}
.p-prose p{color:var(--ink70);font-size:16.5px;line-height:1.75}
.p-prose p+p{margin-top:16px}
.p-prose.dark p{color:rgba(var(--paper-rgb),.65)}
.p-dark-lede{margin-top:20px;font-size:clamp(16px,1.8vw,19px);color:var(--paper);max-width:46ch}

/* Magazinsatz: mehrspaltiger Fliesstext füllt die Seitenbreite (gegen rechten Leerraum) */
@media(min-width:1000px){
  .p-prose.cols{max-width:none;columns:2;column-gap:72px;column-rule:1px solid var(--line)}
  .p-prose.cols p{break-inside:avoid;max-width:none}
  .p-subs.two{display:grid;grid-template-columns:1fr 1fr;gap:0 72px;align-items:start}
  .p-subs.two .p-sub{max-width:none}
}
.p-sub{margin-top:48px;border-top:1px solid var(--line);padding-top:34px;max-width:760px}
.p-sub h3{font-family:var(--disp);text-transform:uppercase;font-size:clamp(19px,2.4vw,28px);margin-bottom:14px}
.p-sub p{color:var(--ink70);font-size:16px;line-height:1.75}
.p-sub p+p{margin-top:14px}

.checklist{list-style:none;margin-top:20px;display:grid;gap:11px}
.checklist li{position:relative;padding-left:26px;font-size:15.5px;color:var(--ink70);line-height:1.6}
.checklist li::before{content:"";position:absolute;left:0;top:.5em;width:10px;height:10px;background:var(--red)}
.checklist.small li{font-size:14px;padding-left:22px}
.checklist.small li::before{width:8px;height:8px}

.p-cards{display:grid;gap:18px;margin-top:46px}
@media(min-width:900px){.p-cards{grid-template-columns:repeat(3,1fr)}}
.p-card{border:1px solid var(--ink);background:var(--card);padding:28px;display:flex;flex-direction:column;gap:12px}
.p-card h3{font-family:var(--disp);text-transform:uppercase;font-size:21px;line-height:1.1}
.p-card p{font-size:14.5px;color:var(--ink70);line-height:1.65}
.p-card .caveat{margin-top:auto;border-top:1px dashed var(--line);padding-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink70)}
.p-card .caveat b{color:var(--red);font-weight:700}

.p-split{display:grid;gap:40px;margin-top:10px}
@media(min-width:980px){.p-split{grid-template-columns:minmax(0,1fr) 340px;gap:80px;align-items:start}}
.p-split-list{border:1px solid rgba(var(--paper-rgb),.3);padding:24px}
.monolist{list-style:none;display:grid;gap:12px;margin-top:14px}
.monolist li{font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:rgba(var(--paper-rgb),.8);padding-left:20px;position:relative;line-height:1.6}
.monolist li::before{content:"→";position:absolute;left:0;color:var(--red)}

.p-imgright{display:grid;gap:36px}
@media(min-width:980px){.p-imgright{grid-template-columns:minmax(0,1fr) 240px;gap:70px;align-items:start}}
.p-stamp{margin:0;max-width:240px}
.p-stamp img{width:100%;height:170px;object-fit:cover;border:1px solid var(--ink);box-shadow:7px 7px 0 var(--red);filter:grayscale(.35) contrast(1.05)}
.p-stamp figcaption{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink45);margin-top:12px}

.phases{margin-top:48px;border:1px solid var(--ink);background:rgba(var(--paper-rgb),.7);padding:clamp(18px,3vw,34px)}
.ph-title{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink70);margin-bottom:22px}
.ph-row{display:grid;gap:14px}
@media(min-width:900px){.ph-row{grid-template-columns:repeat(5,1fr)}}
.ph-step{border:1px solid var(--line);background:var(--card);padding:16px;display:grid;gap:6px;align-content:start;position:relative}
.ph-no{font-family:var(--disp);font-size:20px;color:transparent;-webkit-text-stroke:1.2px var(--ink)}
.ph-step b{font-size:14.5px;line-height:1.3}
.ph-step p{font-size:12.5px;color:var(--ink70);line-height:1.55}
.ph-role{font-family:var(--mono);font-size:9px;letter-spacing:.14em;margin-top:6px;color:var(--ink45)}
.ph-role.r{color:var(--red)}

.layers{margin-top:48px;border:1px solid var(--ink);background:rgba(var(--paper-rgb),.7);padding:clamp(18px,3vw,34px);max-width:720px}
.layer{display:flex;justify-content:space-between;gap:14px;align-items:baseline;border:1px solid var(--ink);background:var(--card);padding:14px 18px;font-size:15px}
.layer+.layer{margin-top:10px}
.layer.active{border-color:var(--red);border-width:2px}
.layer.active span:first-child{font-weight:600}
.layer .owner{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink45)}
.layer.active .owner{color:var(--red)}
.layer-break{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);padding:8px 4px}

.p-cta{padding-bottom:clamp(90px,11vw,150px)}

/* Metriken (image-overlay) */
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:1px;border:1px solid var(--ink);background:var(--ink);margin-top:30px;max-width:560px}
.metric{background:var(--card);padding:16px 18px;display:grid;gap:4px}

/* Staggered rows */
.stagger{margin-top:50px;border-top:1px solid var(--ink)}
.stag-row{display:grid;gap:10px;padding:28px 0;border-bottom:1px solid var(--ink)}
@media(min-width:900px){.stag-row{grid-template-columns:140px minmax(0,560px) 200px;gap:36px;align-items:start}}
.stag-no{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--red)}
.stag-row h3{font-family:var(--disp);text-transform:uppercase;font-size:clamp(18px,2.2vw,24px);margin-bottom:8px}
.stag-row p{font-size:15px;color:var(--ink70);line-height:1.65}
.stag-img{margin:0;max-width:200px}
.stag-img img{width:100%;height:110px;object-fit:cover;border:1px solid var(--ink);box-shadow:5px 5px 0 var(--red);filter:grayscale(.35)}
@media(max-width:899px){.stag-img{display:none}}

/* Related */
.related{padding-top:0}
.rel-grid{display:grid;gap:18px;margin-top:40px}
@media(min-width:900px){.rel-grid{grid-template-columns:repeat(3,1fr)}}
.rel-card{border:1px solid var(--ink);background:var(--card);padding:26px;text-decoration:none;display:flex;flex-direction:column;gap:10px;transition:transform .25s,box-shadow .25s;position:relative}
.rel-card:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--red)}
.rel-card h3{font-family:var(--disp);text-transform:uppercase;font-size:19px;line-height:1.15}
.rel-card p{font-size:13.5px;color:var(--ink70);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.rel-card .rel-go{margin-top:auto;font-family:var(--disp);font-size:22px;color:var(--red)}

/* Legal */
.legal-grid{display:grid;gap:18px}
@media(min-width:760px){.legal-grid{grid-template-columns:1fr 1fr}}
.legal-card{border:1px solid var(--ink);background:var(--card);padding:26px}
.legal-card h2{font-family:var(--disp);text-transform:uppercase;font-size:19px;margin-bottom:12px}
.legal-card p{font-size:15px;color:var(--ink70);line-height:1.7}
.legal-note{margin-top:26px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink45)}
.legal-prose{max-width:760px}
.legal-prose h2{font-family:var(--disp);text-transform:uppercase;font-size:clamp(19px,2.4vw,26px);margin:38px 0 14px;border-top:1px solid var(--ink);padding-top:26px}
.legal-prose h2:first-child{margin-top:0;border-top:none;padding-top:0}
.legal-prose p{font-size:15.5px;color:var(--ink70);line-height:1.75;margin-bottom:14px;overflow-wrap:anywhere}

/* Footer-Linkzeile */
.foot-links{display:flex;flex-wrap:wrap;gap:10px 22px;padding:22px 0;border-bottom:1px solid var(--line);margin-bottom:22px}
.foot-links a{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink70);text-decoration:none}
.foot-links a:hover{color:var(--red)}

/* Nav-Dropdown */
.nav-dd{position:relative}
.nav-dd>button{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;background:none;border:none;color:var(--ink70);cursor:pointer;padding:24px 0;display:inline-flex;gap:7px;align-items:center;transition:color .2s}
.nav-dd>button:hover,.nav-dd>button[aria-expanded="true"]{color:var(--red)}
.nav-dd>button::after{content:"+";font-family:var(--disp);font-size:13px}
.nav-dd-menu{position:absolute;top:100%;left:-18px;min-width:280px;background:var(--paper);border:1px solid var(--ink);box-shadow:8px 8px 0 var(--red);display:none;z-index:70}
.nav-dd.open .nav-dd-menu{display:block}
.nav-dd-menu a{display:block;padding:14px 18px;border-bottom:1px solid var(--line);text-decoration:none;font-family:var(--body)!important;font-size:14px!important;letter-spacing:0!important;text-transform:none!important;color:var(--ink)!important;transition:background .15s,color .15s}
.nav-dd-menu a:last-child{border-bottom:none}
.nav-dd-menu a:hover{background:var(--ink);color:var(--paper)!important}
.nav-dd-menu a b{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:3px}
.nav-dd-divider{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink45);padding:12px 18px 6px;border-bottom:1px solid var(--line)}
.nav-dd-menu a.dd-small{padding:10px 18px;font-size:13px!important}
.nav-links a.active{color:var(--red)}
.mm-sub{display:grid;gap:10px;margin:4px 0 10px;padding-left:2px}
.mm-sub a{font-family:var(--mono)!important;font-size:13px!important;letter-spacing:.1em;text-transform:uppercase;color:rgba(var(--paper-rgb),.6)!important;text-decoration:none}
.mm-sub a:hover{color:var(--red)!important}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--ink);padding:34px 0 110px;background:var(--paper)}
.foot{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink70)}
footer a{text-decoration:none}
footer a:hover{color:var(--red)}

/* ---------- Daten-Tabellen (spec-table, matrix, feature-comparison) ---------- */
.tbl-scroll{margin-top:44px;border:1px solid var(--ink);background:var(--card);overflow-x:auto;-webkit-overflow-scrolling:touch}
.spec-tbl{width:100%;border-collapse:collapse;font-size:12.5px;min-width:880px}
.spec-tbl th{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;text-align:left;padding:12px 14px;background:var(--ink);color:var(--paper);white-space:nowrap;position:sticky;top:0}
.spec-tbl td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:top;line-height:1.5}
.spec-tbl tr:last-child td{border-bottom:none}
.spec-tbl .cat-row td{background:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:700;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.cat-dot{display:inline-block;width:9px;height:9px;margin-right:9px;background:var(--ink45);vertical-align:baseline}
.spec-tbl .tool b{display:block;font-weight:600;font-size:13px;white-space:nowrap}
.spec-tbl .tool span{display:block;font-family:var(--mono);font-size:9.5px;color:var(--ink45);letter-spacing:.04em}
/* EINE Farbregel in der Tabelle: Farbe = Bewertung.
   Grün = positiv · Orange = Einschränkung · Rot = kritisch. Alles andere neutral. */
.c-teal{color:var(--c-teal)}.cat-dot.c-teal{background:var(--c-teal)}
.c-warm{color:var(--c-warm)}.cat-dot.c-warm{background:var(--c-warm)}
.c-red{color:var(--red)}.cat-dot.c-red{background:var(--red)}
.c-primary{color:var(--c-teal);font-weight:700}.cat-dot.c-primary{background:var(--c-teal)}
.spec-tbl .c-blue,.spec-tbl .c-purple{color:var(--ink70)}
.spec-cards .c-blue,.spec-cards .c-purple{color:var(--ink70)}
.spec-tbl .cat-dot,.spec-cards .cat-dot{background:var(--ink)} /* Kategorie-Marker neutral */
/* Matrix behält kategoriale Farben — dort erklärt die Legende sie. Violett klar von Blau getrennt. */
.mx-legend .c-blue,.mx-chip.c-blue{color:var(--c-blue)}.mx-legend i.c-blue{background:var(--c-blue)}
.mx-legend .c-teal,.mx-chip.c-teal{color:var(--c-teal)}.mx-legend i.c-teal{background:var(--c-teal)}
.mx-legend .c-warm,.mx-chip.c-warm{color:var(--c-warm)}.mx-legend i.c-warm{background:var(--c-warm)}
.mx-legend .c-purple,.mx-chip.c-purple{color:var(--c-purple)}.mx-legend i.c-purple{background:var(--c-purple)}
.tbl-note{margin-top:14px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink45)}
.mx-notes{list-style:none;margin:24px 0 4px;padding:0;display:grid;gap:9px}
.mx-notes li{font-size:13px;line-height:1.55;color:var(--ink70)}
.mx-notes .mx-note-i{display:inline-block;min-width:1.1em;margin-right:6px;font-weight:700}
.mx-notes strong{color:var(--ink);font-weight:600}
.tbl-disclaimer{font-style:italic;opacity:.8}
.fc-tbl{min-width:680px}
/* Matrix-Visual */
.matrix{margin-top:48px}
.mx-sub{font-size:13.5px;color:var(--ink70);margin:-12px 0 16px;max-width:60ch}
.mx-legend{display:flex;flex-wrap:wrap;gap:10px 22px;margin-bottom:16px}
.mx-legend span{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink70);display:flex;align-items:center;gap:7px}
.mx-legend i{font-style:normal}
.mx-tbl{min-width:920px}
.mx-tbl td{vertical-align:top}
.mx-chip{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.02em;border:1px solid currentColor;padding:3px 8px;margin:2px 3px 2px 0;white-space:nowrap}

/* Glossar-Begriffe (gepunktet, erklärbar) */
.gl{background:none;border:none;padding:0;font:inherit;color:inherit;cursor:help;border-bottom:1px dotted currentColor;letter-spacing:inherit;text-transform:inherit}
.gl:hover,.gl:focus-visible{color:var(--red);border-bottom-style:solid;outline:none}
.gl-tip{position:fixed;z-index:280;max-width:340px;background:var(--ink);color:var(--paper);padding:14px 16px;font-size:13px;line-height:1.6;box-shadow:8px 8px 0 var(--red);opacity:0;pointer-events:none;transition:opacity .15s}
.gl-tip.on{opacity:1}
.gl-tip b{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.gl-sheet{position:fixed;left:0;right:0;bottom:0;z-index:280;background:var(--paper);border-top:2px solid var(--ink);box-shadow:0 -10px 40px rgba(var(--ink-rgb),.25);padding:22px 20px calc(26px + env(safe-area-inset-bottom));transform:translateY(105%);transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.gl-sheet.on{transform:none}
.gl-sheet b{display:block;font-family:var(--disp);text-transform:uppercase;font-size:18px;margin-bottom:8px}
.gl-sheet b i{font-style:normal;color:var(--red)}
.gl-sheet p{font-size:14.5px;line-height:1.65;color:var(--ink70);max-width:60ch}
.gl-sheet .x{position:absolute;top:14px;right:14px;width:36px;height:36px;border:1px solid var(--ink);background:none;font-size:14px;cursor:pointer}
.gl-backdrop{position:fixed;inset:0;z-index:270;background:rgba(var(--ink-rgb),.4);opacity:0;pointer-events:none;transition:opacity .25s}
.gl-backdrop.on{opacity:1;pointer-events:auto}
/* Glossar-Block (SEO) — zugeklappt per Default, Inhalt bleibt crawlbar im DOM */
.glossary{padding-top:0}
.gl-acc{margin-top:32px;border:1px solid var(--ink);background:var(--card)}
.gl-acc summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 22px}
.gl-acc summary::-webkit-details-marker{display:none}
.gl-acc summary span:first-child{font-family:var(--disp);text-transform:uppercase;font-size:clamp(17px,2vw,22px)}
.gl-acc summary i{font-style:normal;color:var(--red)}
.gl-acc summary .plus{font-family:var(--disp);font-size:26px;color:var(--ink45);transition:transform .35s cubic-bezier(.2,.65,.2,1)}
.gl-acc summary:hover .plus{color:var(--red)}
.gl-acc[open] summary{border-bottom:1px solid var(--ink)}
.gl-acc[open] summary .plus{transform:rotate(45deg);color:var(--red)}
.gl-intro{padding:18px 22px 0;font-size:14px;color:var(--ink70)}
.gl-list{margin:16px;display:grid;gap:1px;padding:1px}
@media(min-width:900px){.gl-list{grid-template-columns:1fr 1fr}}
/* Linien via Outline — keine schwarze Restfläche bei ungerader Anzahl */
.gl-item{background:var(--card);outline:1px solid var(--ink);padding:18px 20px;scroll-margin-top:110px}
.gl-item dt{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--red);margin-bottom:6px}
.gl-item dd{font-size:13.5px;color:var(--ink70);line-height:1.65}
.gl-item.flash{animation:glflash 1.6s ease}
@keyframes glflash{0%,40%{background:rgba(var(--red-rgb),.12)}100%{background:var(--card)}}

/* Filter-Kopf mit Zähler */
.scen-head{display:flex;align-items:center;gap:10px;margin-top:36px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink70)}
.scen-head svg{color:var(--red);flex-shrink:0}
.scen-head b{margin-left:auto;color:var(--ink);font-weight:700;white-space:nowrap}
.scen-head b span{color:var(--red)}
.fl-short{display:none}

/* Szenario-Presets */
.scen{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.scen-chip{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--ink);background:var(--card);color:var(--ink);padding:11px 16px;cursor:pointer;transition:all .2s;white-space:nowrap}
.scen-chip:hover{border-color:var(--red);color:var(--red)}
.scen-chip.active{background:var(--ink);color:var(--paper)}
.scen-fazit{margin-top:14px;border:1px solid var(--ink);border-left:4px solid var(--red);background:var(--card);padding:16px 18px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.scen-fazit[hidden]{display:none!important} /* display:flex darf das hidden-Attribut nie überschreiben */
.scen-fazit p{font-size:14.5px;line-height:1.6;max-width:62ch}
.scen-hide{display:none!important}

/* Mobile: eine wischbare Chip-Zeile statt gestapelter Blöcke */
@media(max-width:899px){
  .fl-long{display:none}
  .fl-short{display:inline}
  .scen-head{margin-top:26px;font-size:9.5px;gap:8px}
  .scen{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:10px -18px 0;padding:2px 18px 6px;mask-image:linear-gradient(90deg,#000 90%,transparent);-webkit-mask-image:linear-gradient(90deg,#000 90%,transparent)}
  .scen::-webkit-scrollbar{display:none}
  .scen-chip{flex:0 0 auto;padding:9px 13px;font-size:10px}
  .scen-fazit{padding:12px 14px;gap:10px;margin-top:12px}
  .scen-fazit p{font-size:12.5px;line-height:1.55}
  .scen-fazit .btn{padding:10px 14px;font-size:10px}
  .tbl-meta{margin-top:16px;margin-bottom:-26px;gap:6px 14px}
  .as-of{font-size:8.5px;letter-spacing:.06em}
  .tbl-meta .legend{font-size:8px;gap:5px 9px;letter-spacing:.06em}
  .tbl-meta .legend i{width:8px;height:8px;margin-right:-5px}
}
/* Tabellen-Meta: Stand, Legende, Wisch-Hinweis */
.tbl-meta{display:flex;flex-wrap:wrap;gap:12px 26px;align-items:center;margin-top:20px;margin-bottom:-30px}
.as-of{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);font-weight:700}
.tbl-meta .legend{display:flex;gap:7px 14px;align-items:center;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink70);flex-wrap:wrap}
.tbl-meta .legend i{font-style:normal;margin-right:-8px}
.swipe-hint{display:none;font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink45);margin-left:auto}
@media(min-width:900px) and (max-width:1120px){.swipe-hint{display:inline}}
/* Sticky erste Spalte + Hover + Scroll-Kante */
.spec-tbl.has-sticky .tool, .spec-tbl.has-sticky th:first-child{position:sticky;left:0;background:var(--card);z-index:2;box-shadow:1px 0 0 var(--line)}
.spec-tbl.has-sticky th:first-child{background:var(--ink);z-index:3}
.spec-tbl.has-sticky .cat-row td{position:sticky;left:0}
.spec-tbl tbody tr:not(.cat-row):hover td{background:rgba(var(--red-rgb),.04)}
.spec-tbl tbody tr:not(.cat-row):hover .tool{background:rgba(var(--red-rgb),.08)}
.tbl-scroll{position:relative}
/* Mobile: Tabelle aus, Karten an */
.spec-cards{display:none}
@media(max-width:899px){
  #vergleich .tbl-scroll{display:none}
  .spec-cards{display:block;margin-top:40px}
  .swipe-hint{display:none}
}
.sc-cat{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;border-top:1px solid var(--ink);padding:16px 0 10px;margin-top:10px}
.sc-card{border:1px solid var(--ink);background:var(--card);padding:16px;margin-bottom:12px}
.sc-head{display:flex;justify-content:space-between;gap:12px;align-items:baseline;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:10px}
.sc-head b{font-size:15px;display:block}
.sc-head span{font-family:var(--mono);font-size:9.5px;color:var(--ink45);letter-spacing:.04em}
.sc-type{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;border:1px solid currentColor;padding:3px 8px;white-space:nowrap}
.sc-card dl{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
.sc-card dt{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink45)}
.sc-card dd{font-size:12.5px;font-family:var(--mono);margin-top:2px}
/* Matrix-Aufwertung */
.mx-empty{color:var(--ink45);opacity:.4}
a.mx-chip{text-decoration:none;transition:all .15s}
a.mx-chip:hover{background:var(--ink);color:var(--paper)!important;border-color:var(--ink)}
.mx-annotation{margin-top:16px;font-size:14px;font-weight:600;color:var(--red);border-left:3px solid var(--red);padding-left:14px;max-width:70ch;line-height:1.6}
.mx-takeaway{margin-top:20px;border:1px solid var(--ink);background:var(--card);box-shadow:7px 7px 0 var(--red);padding:20px 22px;display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.mx-takeaway p{font-size:14.5px;line-height:1.65;max-width:62ch}

/* ---------- Produkt-Pakete (pricing-cards) ---------- */
.price-grid{display:grid;gap:18px;margin-top:50px;align-items:stretch}
@media(min-width:980px){.price-grid{grid-template-columns:repeat(3,1fr)}}
.price-card{position:relative;border:1px solid var(--ink);background:var(--card);padding:30px 26px;display:flex;flex-direction:column;gap:14px}
.price-card.rec{border-width:2px;border-color:var(--red);box-shadow:10px 10px 0 var(--red)}
.rec-badge{position:absolute;top:-13px;left:22px;background:var(--red);color:var(--on-accent);font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:6px 14px}
.price-card h3{font-family:var(--disp);text-transform:uppercase;font-size:24px;line-height:1.05}
.price-line{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;border-bottom:1px solid var(--ink);padding-bottom:14px}
.price-line .price{font-family:var(--disp);font-size:clamp(26px,2.6vw,34px);color:var(--red)}
.price-line .duration{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink45)}
.price-desc{font-size:14px;color:var(--ink70);line-height:1.65}
.price-note{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink45);border-top:1px dashed var(--line);padding-top:12px;line-height:1.7}
.price-ctas{margin-top:auto;display:grid;gap:12px;text-align:center}
.price-written{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink70);text-decoration:underline;text-underline-offset:3px}
.price-written:hover{color:var(--red)}

/* ---------- Kontakt ---------- */
.contact-grid{display:grid;gap:40px}
@media(min-width:980px){.contact-grid{grid-template-columns:minmax(0,620px) 320px;gap:80px;align-items:start}}
#contact-form{display:grid;gap:16px;max-width:620px}
.form-2col{display:grid;gap:16px}
@media(min-width:640px){.form-2col{grid-template-columns:1fr 1fr}}
.ferr{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--red);margin-top:6px;text-transform:uppercase}
.contact-aside{display:grid;gap:24px}
.contact-aside .pf-v a{text-decoration:none;color:var(--ink)}
.contact-aside .pf-v a:hover{color:var(--red)}
.contact-booking{border:1px solid var(--ink);background:var(--card);padding:22px}

/* ---------- Cookie-Banner ---------- */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:150;padding:14px;display:flex;justify-content:center;opacity:0;transform:translateY(16px);transition:opacity .4s,transform .4s;pointer-events:none}
.cookie-banner.on{opacity:1;transform:none;pointer-events:auto}
.cb-box{max-width:560px;background:var(--paper);border:1px solid var(--ink);box-shadow:8px 8px 0 var(--red);padding:20px 22px}
.cb-box b{font-family:var(--disp);text-transform:uppercase;font-size:16px;letter-spacing:.02em}
.cb-box p{font-size:13px;color:var(--ink70);line-height:1.6;margin:8px 0 14px}
.cb-box p a{color:var(--red)}
.cb-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.cb-decline{background:none;border:none;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink70);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.cb-decline:hover{color:var(--red)}
/* Opt-out-Box (Datenschutzseite) */
.optout{border:1px solid var(--ink);background:var(--card);padding:24px;max-width:760px;margin-top:40px}
.optout h2{font-family:var(--disp);text-transform:uppercase;font-size:20px;margin-bottom:10px}
.optout p{font-size:14.5px;color:var(--ink70);line-height:1.7;margin-bottom:14px}
.optout .status{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:14px}
.optout .row{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- Sticky CTA (mobil) ---------- */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:90;background:var(--ink);padding:12px 18px calc(12px + env(safe-area-inset-bottom));display:flex;justify-content:space-between;align-items:center;transform:translateY(110%);transition:transform .4s}
.sticky-cta.show{transform:none}
.sticky-cta span{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:rgba(var(--paper-rgb),.7);text-transform:uppercase}
@media(min-width:900px){.sticky-cta{display:none}}

/* ===================================================================
   V2.1 (06/2026) — Rote Konversions-Leiste + Konturlinien-Hero
   Nur additive Überschreibungen; Basis-System unverändert darüber.
   =================================================================== */
:root{--colw:clamp(64px,6.5vw,100px)}
body{padding-right:var(--colw)}
header#hdr{right:var(--colw)}

/* Cookie-Banner endet vor der Leiste (sonst verdeckt er den Buchungs-Button) */
.cookie-banner{right:var(--colw)}

/* Rote Leiste */
.colbar{position:fixed;top:0;right:0;bottom:0;width:var(--colw);background:var(--red);z-index:80;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:24px 0 20px}
.cb-brand{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--mono);font-weight:700;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--on-accent);white-space:nowrap}
.cb-prog{flex:1;width:1px;background:rgba(255,255,255,.25);margin:18px 0;position:relative}
.cb-prog b{position:absolute;top:0;left:-.5px;width:2px;height:0;background:var(--card)}
.cb-btn{display:flex;flex-direction:column;align-items:center;gap:10px;background:none;border:0;cursor:pointer;padding:0}
.cb-btn .bx{width:clamp(46px,4.6vw,60px);height:clamp(46px,4.6vw,60px);background:var(--card);color:var(--red);display:grid;place-items:center;transition:transform .25s,box-shadow .25s}
.cb-btn:hover .bx{transform:translate(-2px,-2px);box-shadow:3px 3px 0 rgba(0,0,0,.25)}
.cb-btn .bx svg{width:45%;height:45%}
.cb-btn em{writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--mono);font-style:normal;font-weight:700;font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--on-accent)}

/* Hero Startseite: zentriert auf Linien-Bühne */
.hero{min-height:100svh;align-items:center;justify-content:center;text-align:center;padding-top:108px;overflow:hidden} /* clippt das Hero-Veil */
.hero .lines{position:absolute;inset:0;z-index:0;pointer-events:none;width:100%;height:100%}
.hero-in{position:relative;z-index:1}
.hero-in::before{content:"";position:absolute;inset:-24px -60px;background:radial-gradient(ellipse 58% 52% at 50% 46%,var(--paper) 30%,rgba(var(--paper-rgb),.85) 56%,rgba(var(--paper-rgb),0) 76%);z-index:-1}
.hero-meta{color:var(--red);font-weight:700;letter-spacing:.2em;text-transform:uppercase}
.hero h1{margin:18px 0 4px}
.h1-a{display:block;font-size:clamp(27px,4.7vw,66px);letter-spacing:.012em}
.h1-b{display:block;font-size:clamp(38px,8.3vw,120px)}
.hero-chips{display:flex;gap:10px;justify-content:center;margin:28px 0 24px;flex-wrap:wrap}
.hero-chips .chip{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;border:1px solid rgba(var(--ink-rgb),.35);padding:10px 18px;background:rgba(var(--paper-rgb),.78);color:var(--ink);text-decoration:none;display:inline-flex;align-items:center;transition:border-color .2s,transform .2s,box-shadow .2s}
.hero-chips .chip .ca{font-style:normal;font-weight:700;color:var(--red);max-width:0;overflow:hidden;transition:max-width .25s ease,margin-left .25s ease}
.hero-chips .chip:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:3px 3px 0 var(--red)}
.hero-chips .chip:hover .ca{max-width:1.2em;margin-left:8px}
.hero-chips .chip i{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ink);margin-right:9px;vertical-align:1px}
.hero-chips .chip.r i{background:var(--red)}
.hero-sub2{max-width:56ch;margin:0 auto;font-size:clamp(16px,1.5vw,19px);color:var(--ink70)}
.hero-sub2 b{color:var(--ink)}
.hero-cta2{margin-top:32px}
.hero-cta2 .cta-meta{display:block;margin-top:14px}
.cue{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink45);z-index:1}
.cue::after{content:"";display:block;width:1px;height:32px;background:var(--ink45);margin:8px auto 0;animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* Inhaltsbilder (Hero-Seite, Copy-Sektion, Subsektion) */
.p-hero-side{display:grid;gap:18px;align-self:start}
.p-hero-img,.p-figure{margin:0;border:1px solid var(--ink);box-shadow:8px 8px 0 var(--red);background:var(--card)}
.p-hero-img img,.p-figure img,.sub-img img{display:block;width:100%;height:auto}
.p-figure{margin-top:34px;max-width:640px}
.sub-img{margin:0 0 16px;border:1px solid var(--line)}

/* Unterseiten-Hero: dezente Linien */
.p-hero{position:relative;overflow:hidden}
.p-hero .lines{position:absolute;inset:0;z-index:0;pointer-events:none;width:100%;height:100%}
.p-hero .wrap{position:relative;z-index:1}

/* Mobile: Headline als echtes Plakat — Zeilen auf Satzspiegelbreite gefittet
   (cqw über die bestehende container-type auf .hero .wrap) */
@media(max-width:760px){
  .hero-in{padding-left:9px;padding-right:9px}
  .h1-a{font-size:8.45cqw;line-height:1.02;text-wrap:balance}
  /* «KI-ZEITALTER.» allein und gross; «im» als kleine rote Brücke */
  .h1-b{font-size:13.9cqw;white-space:nowrap;margin-top:.02em}
  .h1-im{display:block;font-size:.32em;letter-spacing:.34em;color:var(--red);line-height:1.5}
  html[lang=en] .h1-b{font-size:12.3cqw}
  .hero h1{margin:16px 0 2px}
  .hero-chips{gap:6px;margin:22px 0 20px}
  .hero-chips .chip{padding:8px 12px;font-size:10px;letter-spacing:.12em}
  .hero-chips .chip i{width:6px;height:6px;margin-right:7px}
  .hero-sub2{font-size:16px;max-width:34ch}
}

/* Mobile: Leiste wird Bottom-Bar */
@media(max-width:760px){
  body{padding-right:0;padding-bottom:62px}
  header#hdr{right:0}
  .colbar{top:auto;left:0;right:0;bottom:0;width:auto;height:62px;flex-direction:row;padding:0 16px;justify-content:space-between;transform:translateY(100%);transition:transform .35s ease}
  body.scrolled-hero .colbar{transform:none}
  .cb-brand{writing-mode:horizontal-tb;transform:none;font-size:8.5px;letter-spacing:.1em;white-space:normal;line-height:1.6;max-width:56%}
  .cb-prog{display:none}
  .cb-btn{flex-direction:row;gap:9px;background:var(--card);padding:9px 14px}
  .cb-btn .bx{width:auto;height:auto;background:none}
  .cb-btn .bx svg{width:14px;height:14px;display:block}
  .cb-btn:hover .bx{transform:none;box-shadow:none}
  .cb-btn em{writing-mode:horizontal-tb;transform:none;color:var(--red);font-size:10px}
  .cookie-banner{bottom:62px}
  /* Bottom-CTA-Leiste erst nach Cookie-Entscheidung zeigen — kein Overlap im ersten Viewport */
  body.consent-open{padding-bottom:0}
  body.consent-open .colbar{display:none}
  body.consent-open .cookie-banner{bottom:0}
}

/* ===================================================================
   DARK MODE (automatisch via Systemeinstellung; kein Toggle nötig)
   Pflege-Regel: Dark Mode überschreibt AUSSCHLIESSLICH die Tokens
   unten + Logo-Invertierung. Niemals einzelne Komponenten-Regeln
   duplizieren — neue Farben immer erst als Token in :root anlegen.
   =================================================================== */
/* Aktivierung: html[data-theme="dark"] — gesetzt vom Pre-Paint-Skript
   (gespeicherte Wahl oder Systemeinstellung) bzw. vom Switch in der Navigation. */
html[data-theme="dark"]{
  color-scheme:dark;
    --paper:#161511;        /* warmes Schwarz statt Papier */
    --paper-rgb:22,21,17;
    --paper2:#1D1C17;
    --ink:#ECE9E0;          /* Papierton als Schriftfarbe */
    --ink-rgb:236,233,224;
    --card:#1E1D18;         /* Kartenflächen leicht über Grund */
    --on-accent:#12110D;    /* dunkle Schrift auf hellem Akzent */
    --red:#2FB8AF;          /* Petrol aufgehellt (Text-Kontrast) */
    --red-rgb:47,184,175;
    --red-tint:rgba(47,184,175,.09);
    --ok:#4ADE80; --warn:#E3B341;
    --c-teal:#2EB8AC; --c-warm:#E8945A; --c-blue:#7C9EFF; --c-purple:#D9A0E8;
  }
html[data-theme="dark"] .logo-img{filter:brightness(0) invert(1)}  /* dunkles Logo → hell */
html[data-theme="dark"] .mobile-menu .logo-img.inv{filter:none}    /* Menü-Grund ist jetzt hell */
html[data-theme="dark"] img{filter:brightness(.9)}                 /* Fotos leicht dämpfen */

/* Theme-Switch (Sonne ↔ Mond) */
.theme-btn{width:38px;height:38px;border:1px solid var(--line);background:none;color:var(--ink70);display:grid;place-items:center;cursor:pointer;padding:0;transition:color .2s,border-color .2s}
.theme-btn:hover{color:var(--red);border-color:var(--ink)}
.theme-btn svg{width:19px;height:19px;overflow:visible}
.theme-btn .tc{transition:r .45s cubic-bezier(.2,.7,.2,1)}
.theme-btn .tm{transition:cx .45s cubic-bezier(.2,.7,.2,1),cy .45s cubic-bezier(.2,.7,.2,1)}
.theme-btn .tr{transform-origin:12px 12px;transition:opacity .3s,transform .45s cubic-bezier(.2,.7,.2,1)}
html[data-theme="dark"] .theme-btn .tc{r:8px}
html[data-theme="dark"] .theme-btn .tm{cx:17px;cy:7px}
html[data-theme="dark"] .theme-btn .tr{opacity:0;transform:rotate(60deg) scale(.5)}
/* Sichtbarkeit: Desktop → Footer, Mobile → Menü. Nie beide gleichzeitig. */
.foot .theme-btn{display:inline-grid;width:30px;height:30px;vertical-align:middle;margin-left:2px}
.foot .theme-btn svg{width:15px;height:15px}
@media(max-width:760px){.foot .theme-btn{display:none}}
.mobile-menu .theme-btn{color:rgba(var(--paper-rgb),.85);border-color:rgba(var(--paper-rgb),.35)}
.mobile-menu .theme-btn:hover{color:var(--red);border-color:rgba(var(--paper-rgb),.85)}

/* Mega-Menü «Leistungen»: breit statt lang, Hub-Spalten (V2.1) */
.nav-dd-menu.mega{left:auto;right:0;width:min(740px,calc(100vw - var(--colw) - 2*clamp(18px,4vw,56px)));padding:0;display:none;grid-template-columns:repeat(3,1fr)}
.nav-dd.open .nav-dd-menu.mega{display:grid}
.mg-col{padding:18px 18px 16px;border-right:1px solid var(--line)}
.mg-col:last-child{border-right:0}
.nav-dd-menu.mega a{border-bottom:0;background:none!important;padding:0}
/* Alte Dropdown-Hover-Regel (Paper auf Ink) neutralisieren — hier gilt: Hover = Akzent */
.nav-dd-menu.mega a:hover{color:var(--red)!important;background:none!important}
.nav-dd-menu.mega a.mg-hub:hover b{color:var(--red)}
.mg-hub{display:block;color:var(--ink)!important;font-size:14.5px!important;font-weight:700;padding-bottom:10px!important;border-bottom:1px solid var(--ink)!important;margin-bottom:10px}
.mg-hub b{display:block;font:700 9.5px var(--mono);letter-spacing:.18em;color:var(--red);text-transform:uppercase;margin-bottom:6px}
.mg-link{display:block;padding:7px 0!important;font-size:13.5px!important;color:var(--ink70)!important;line-height:1.35}
.mg-link:hover,.mg-hub:hover{color:var(--red)!important}
.mg-more{display:inline-block;margin-top:10px;font-family:var(--mono)!important;font-weight:700;font-size:10.5px!important;letter-spacing:.1em!important;text-transform:uppercase!important;color:var(--red)!important}
.mg-more:hover{text-decoration:underline}

/* Mobile-Menü: gleiche Hub-Gruppierung wie das Mega-Menü (V2.1) */
.mm-group{margin:6px 0 14px;opacity:0;transform:translateY(16px);transition:opacity .4s ease calc(.06s * var(--st)),transform .4s ease calc(.06s * var(--st))}
.mobile-menu.open .mm-group{opacity:1;transform:none}
.mm-kicker{display:block;font:700 9.5px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.mm-hub-link{font-family:var(--disp);font-size:clamp(24px,6.4vw,36px);text-transform:uppercase;color:var(--paper);text-decoration:none;line-height:1.1;display:inline-block}
.mm-hub-link:active,.mm-hub-link:hover{color:var(--red)}
.mm-sub.grouped{margin:10px 0 0;display:grid;gap:9px;padding-left:2px}
.mm-sub.grouped a{font-family:var(--mono)!important;font-size:11.5px!important;letter-spacing:.08em;text-transform:uppercase;color:rgba(var(--paper-rgb),.65)!important;text-decoration:none;line-height:1.45}
.mm-more2{color:var(--red)!important;font-weight:700}

/* ===== Tools-Matrix-Teaser auf der Startseite (V2.1) ===== */
.tools-teaser{padding-top:0}
.tt-box{background:var(--ink);color:var(--paper);padding:clamp(28px,4vw,52px);display:grid;gap:34px;box-shadow:10px 10px 0 var(--red)}
@media(min-width:920px){.tt-box{grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);align-items:center}}
.tt-label{color:var(--red);font-weight:700;letter-spacing:.2em;text-transform:uppercase}
.tt-title{font-family:var(--disp);font-weight:400;text-transform:uppercase;font-size:clamp(26px,3.6vw,52px);line-height:1;margin:14px 0 0;color:var(--paper)}
.tt-intro{margin:16px 0 24px;color:rgba(var(--paper-rgb),.75);max-width:52ch;font-size:15.5px;line-height:1.6}
.tt-facts{display:grid;gap:0;border:1px solid rgba(var(--paper-rgb),.25)}
.tt-fact{display:flex;align-items:baseline;gap:14px;padding:14px 18px;border-bottom:1px solid rgba(var(--paper-rgb),.25)}
.tt-fact:last-child{border-bottom:0}
.tt-fact b{font-family:var(--disp);font-weight:400;font-size:clamp(22px,2.4vw,34px);color:var(--red);min-width:2.6em}
.tt-fact span{font:10.5px var(--mono);letter-spacing:.14em;text-transform:uppercase;color:rgba(var(--paper-rgb),.7);line-height:1.6}

/* PDF-Button bei der Matrix */
.print-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-weight:700;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--ink);background:var(--card);color:var(--ink);padding:9px 14px;cursor:pointer;transition:all .2s;margin-left:auto}
.print-btn:hover{border-color:var(--red);color:var(--red)}
.tbl-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.print-head{display:none}

/* ===== Print: nur die Matrix, gebrandet, helle Farben ===== */
@media print{
  html{--paper:#fff;--paper-rgb:255,255,255;--paper2:#f4f2ec;--ink:#141414;--ink-rgb:20,20,20;--card:#fff;--on-accent:#fff;
       --red:#0E6E6B;--red-rgb:14,110,107;--red-tint:rgba(14,110,107,.06);color-scheme:light}
  body{padding:0!important}
  body.print-matrix header#hdr,body.print-matrix .colbar,body.print-matrix footer,body.print-matrix .cookie-banner,
  body.print-matrix .progress,body.print-matrix .crop,body.print-matrix .cur-dot,body.print-matrix .cur-ring,
  body.print-matrix canvas{display:none!important}
  body.print-matrix main>*:not(.spec-sec),body.print-matrix .p-hero{display:none!important}
  body.print-matrix .spec-sec .scen-head,body.print-matrix .spec-sec .scen,body.print-matrix .scen-fazit,
  body.print-matrix .print-btn,body.print-matrix .spec-cards,body.print-matrix .sec-no,body.print-matrix .swipe-hint{display:none!important}
  body.print-matrix .print-head{display:flex!important;align-items:center;gap:18px;justify-content:space-between;border-bottom:2px solid var(--ink);padding-bottom:12px;margin-bottom:16px}
  body.print-matrix .print-head .ph-mid b{display:block;font-family:var(--disp);text-transform:uppercase;font-size:15px}
  body.print-matrix .print-head .ph-mid span{font:9px var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--red)}
  body.print-matrix .print-head .ph-right{font:9px var(--mono);letter-spacing:.08em;text-transform:uppercase}
  body.print-matrix .rv{opacity:1!important;transform:none!important} /* Reveal-Animation darf im Druck nichts verstecken */
  body.print-matrix .spec-sec{padding:0}
  body.print-matrix .p-h2{font-size:22px}
  body.print-matrix .tbl-scroll{overflow:visible;border:1px solid var(--ink)}
  body.print-matrix .spec-tbl{font-size:8.5px;min-width:0;width:100%}
  body.print-matrix .spec-tbl th{position:static;padding:6px 8px}
  body.print-matrix .spec-tbl td{padding:6px 8px}
  body.print-matrix .spec-tbl tr{break-inside:avoid}
  body.print-matrix .gl{text-decoration:none;border-bottom:0}
}


/* Querverweis zwischen den Matrix-Seiten (V2.1) */
.matrix-x{margin-top:26px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;border:1px solid var(--ink);border-left:4px solid var(--red);background:var(--card);padding:16px 18px;text-decoration:none;color:var(--ink);transition:transform .2s,box-shadow .2s}
.matrix-x:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--red)}
.matrix-x .mx-q{font-size:14.5px}
.matrix-x .mx-l{font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);white-space:nowrap}


/* Filter-Gruppen-Trenner (Medium | Kriterien) */
.scen-sep{width:1px;align-self:stretch;background:var(--ink45);opacity:.5;margin:0 8px;flex:0 0 auto}

/* Hersteller-Links in den Matrizen (V2.1) */
.tool a,.sc-head a{color:inherit;text-decoration:none;border-bottom:1px solid var(--line);transition:color .15s,border-color .15s}
.tool a:hover,.sc-head a:hover{color:var(--red);border-color:var(--red)}
.tool a::after,.sc-head a::after{content:"\2197";font-size:.72em;margin-left:4px;color:var(--ink45)}
.tool a:hover::after{color:var(--red)}
@media print{.tool a{border-bottom:0}.tool a::after{content:""}}

/* Verlassen-Dialog für externe Links (V2.1) */
.ext-box{width:min(560px,100%)}
.ext-text{font-size:15px;color:var(--ink70);margin:14px 0 10px}
.ext-url{display:block;border:1px solid var(--ink);border-left:4px solid var(--red);background:var(--card);padding:12px 14px;font-size:12px;word-break:break-all;color:var(--ink)}
.ext-actions{display:flex;gap:14px;align-items:center;margin:20px 0 8px;flex-wrap:wrap}
.ext-stay{background:none;border:1px solid var(--ink);color:var(--ink);font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:15px 22px;cursor:pointer;transition:all .2s}
.ext-stay:hover{border-color:var(--red);color:var(--red)}


/* ===== Header-Sprachschalter (Globe) + Mega-Overflow-Fix · nav-pass 2026-06-25 ===== */
.mega-dd{position:static}                       /* Mega-Menü an .nav-links (Inhaltsrand) verankern */
.lang-dd>button.globe-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 8px;min-height:40px;background:none;border:none;cursor:pointer;color:var(--ink70);transition:color .2s}
.lang-dd>button.globe-btn::after{content:none}  /* kein "+" wie beim Mega-Button */
.lang-dd>button.globe-btn:hover,.lang-dd>button.globe-btn[aria-expanded="true"]{color:var(--red)}
.globe-btn svg{width:19px;height:19px;display:block}
.globe-btn .globe-code{font-family:var(--mono);font-weight:700;font-size:11.5px;letter-spacing:.08em;line-height:1}
.nav-dd-menu.lang-menu{left:auto;right:0;min-width:0;width:auto;padding:14px}
.lang-menu .lang-cap{display:block;font:700 9px var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:9px}
.lang-menu .seg{display:flex;border:1px solid var(--ink)}
.lang-menu .seg-opt{display:flex!important;align-items:center;justify-content:center;min-width:54px;min-height:42px;padding:0 16px!important;border:0!important;border-right:1px solid var(--ink)!important;font:700 12.5px var(--mono)!important;letter-spacing:.12em!important;text-transform:uppercase!important;color:var(--ink)!important;background:none!important;transition:background .15s,color .15s}
.lang-menu .seg-opt:last-child{border-right:0!important}
.lang-menu .seg-opt:hover{background:var(--paper2)!important;color:var(--ink)!important}
.lang-menu .seg-opt.active{background:var(--red)!important;color:var(--on-accent)!important}

/* ---------- Rollen-Strip (Startseite · V2.2) ---------- */
.roles{margin-top:clamp(48px,6vw,86px)}
.roles-head{margin-bottom:clamp(20px,3vw,34px)}
.roles-title{font-family:var(--disp);font-weight:400;font-size:clamp(26px,3.6vw,46px);line-height:1;text-transform:uppercase;letter-spacing:.01em;margin:0 0 10px}
.roles-intro{color:var(--ink70);max-width:56ch;margin:0;font-size:16px}
.roles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(208px,1fr));gap:clamp(12px,1.4vw,18px)}
.role-card{position:relative;display:flex;flex-direction:column;gap:9px;padding:22px 20px 50px;background:var(--paper);border:1px solid var(--ink);box-shadow:4px 4px 0 var(--ink);text-decoration:none;color:var(--ink);transition:transform .18s cubic-bezier(.2,.65,.2,1),box-shadow .18s ease}
.role-card:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--red)}
.role-no{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--ink45)}
.role-card h4{font-family:var(--disp);font-weight:400;font-size:clamp(19px,1.5vw,23px);line-height:1.04;text-transform:uppercase;letter-spacing:.01em;margin:0}
.role-card p{font-size:13.5px;line-height:1.5;color:var(--ink70);margin:0}
.role-go{position:absolute;left:20px;bottom:18px;font-size:18px;color:var(--red);transition:transform .18s ease}
.role-card:hover .role-go{transform:translateX(6px)}
@media(max-width:900px){.roles-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.roles-grid{grid-template-columns:1fr}}

/* ---------- Footer-Verzeichnis (gruppiert · V2.2) ---------- */
.foot-dir{display:grid;grid-template-columns:repeat(auto-fit,minmax(178px,1fr));gap:clamp(20px,3vw,38px) clamp(16px,2.4vw,30px);padding:clamp(26px,3.5vw,44px) 0}
.fd-col{display:flex;flex-direction:column;gap:8px;min-width:0}
.fd-h{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin:0 0 5px}
.foot-dir a{font-size:13px;line-height:1.4;color:var(--ink70);text-decoration:none;transition:color .15s ease}
.foot-dir a:hover{color:var(--ink)}

/* ===== MVP-Band · Conversion-Anreisser Startseite (V2.2) =====
   Fester Petrol-Sticker (#0E6E6B) + cremefarbene Preis-Karte in BEIDEN Themes,
   damit der Block themenunabhaengig immer gleich auffaellt und lesbar bleibt.
   Kein Rot: #0E6E6B ist der Petrol-Markenakzent. */
.mvp-band{margin:clamp(56px,9vw,116px) 0}
.mvp-wrap{position:relative;background:#0E6E6B;color:#fff;padding:clamp(30px,4.6vw,62px);box-shadow:14px 14px 0 var(--ink);overflow:hidden}
.mvp-wrap::after{content:"MVP";position:absolute;right:-1.5vw;bottom:-4vw;font-family:var(--disp);font-size:clamp(140px,21vw,320px);line-height:.8;color:rgba(255,255,255,.07);letter-spacing:-.02em;pointer-events:none;user-select:none}
.mvp-grid{position:relative;z-index:1;display:grid;gap:30px}
@media(min-width:900px){.mvp-grid{grid-template-columns:minmax(0,1.5fr) minmax(0,.9fr);align-items:center;gap:clamp(32px,5vw,68px)}}
.mvp-eyebrow{font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.82);margin:0}
.mvp-title{font-family:var(--disp)!important;font-weight:400;text-transform:uppercase;font-size:clamp(34px,5.3vw,68px);line-height:.95;margin:14px 0 0;color:#fff!important}
.mvp-intro{margin:18px 0 28px;max-width:48ch;font-size:16px;line-height:1.62;color:rgba(255,255,255,.9)}
.mvp-cta{display:inline-flex;align-items:center;gap:12px;background:#F2EFE7;color:#101013;font-family:var(--mono);font-weight:700;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;padding:16px 28px;text-decoration:none;transition:transform .2s,box-shadow .2s}
.mvp-cta:hover{transform:translateY(-2px);box-shadow:0 9px 0 rgba(0,0,0,.22)}
.mvp-offer{background:#F2EFE7;color:#101013;padding:clamp(22px,3vw,32px);box-shadow:8px 8px 0 rgba(0,0,0,.18)}
.mvp-offer-kicker{font-family:var(--mono);font-weight:700;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#0E6E6B;margin:0}
.mvp-price{font-family:var(--disp);font-weight:400;font-size:clamp(40px,5.6vw,62px);line-height:.92;color:#0E6E6B;margin:8px 0 0}
.mvp-price small{display:block;font:700 12px var(--mono);letter-spacing:.14em;text-transform:uppercase;color:rgba(16,16,19,.5);margin-bottom:3px}
.mvp-offer-note{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(16,16,19,.66);margin:14px 0 0;line-height:1.6}
@media(prefers-reduced-motion:reduce){.mvp-cta{transition:none}}
/* Preis-Hinweis im Mega-/Mobile-Menue hinter dem MVP-Eintrag */
.mg-hint{margin-left:8px;font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;color:var(--red);text-transform:uppercase;opacity:.9;white-space:nowrap}
.mm-sub .mg-hint{font-size:10px}
