/* Geist und Geist Mono lokal gehostet, kein Drittabruf vom Google-Fonts-CDN.
   Variable fonts, ein Datei pro Subset deckt alle Gewichte ab. */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('fonts/geist-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('fonts/geist-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400 500;
  font-display: swap;
  src: url('fonts/geist-mono-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400 500;
  font-display: swap;
  src: url('fonts/geist-mono-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root{
  --bg: #F8F6F1;
  --bg-2: #EDEAE2;
  --bg-3: #E4E0D6;
  --ink: #111210;
  --ink-2: #2A2C28;
  --ink-3: #5C5E58;
  --ink-4: #8A8C84;
  --rule: #1112101A;
  --rule-2: #11121012;
  --accent: #1F4845;
  --accent-ink: #F4EFE3;

  --sans: "Geist", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --mono: "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  --maxw: 1200px;
  --gutter: clamp(20px, 4vw, 56px);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--bg);scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
p{margin:0}
hr{border:0;border-top:1px solid var(--rule);margin:0}
::selection{background:var(--accent);color:var(--accent-ink)}
section[id]{scroll-margin-top:80px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.section{padding: clamp(72px, 10vw, 140px) 0}
.section--tight{padding: clamp(48px, 7vw, 96px) 0}
.section--dark{background:var(--ink);color:#E9E7E0}
.section--dark hr{border-top-color:#FFFFFF1A}
.section--accent{background:var(--accent);color:var(--accent-ink)}

/* TYPE: all sans, hierarchy via weight + size + tracking */
h1,h2,h3,h4{font-family:var(--sans);margin:0;line-height:1.05;text-wrap:balance;font-weight:500;letter-spacing:-0.025em}
.h-display{font-size: clamp(46px, 7vw, 96px); line-height:1.0; letter-spacing:-0.035em; font-weight:500}
.h-1{font-size: clamp(36px, 4.6vw, 60px); line-height:1.05; letter-spacing:-0.028em; font-weight:500}
.h-2{font-size: clamp(28px, 3vw, 40px); line-height:1.1; letter-spacing:-0.022em; font-weight:500}
.h-3{font-size: clamp(20px, 1.8vw, 24px); line-height:1.25; letter-spacing:-0.015em; font-weight:500}
.lead{font-size: clamp(18px, 1.4vw, 22px); line-height:1.45; color:var(--ink-2); max-width: 64ch; text-wrap:pretty; font-weight:400}
.body{font-size:17px; line-height:1.6; color:var(--ink-2); max-width: 70ch; text-wrap:pretty}
.body p + p{margin-top:1em}
.small{font-size:14px;line-height:1.5;color:var(--ink-3)}
.mono{font-family:var(--mono);font-size:12px;letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-3)}

.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);font-weight:400}

/* nav */
.nav{position:sticky;top:0;z-index:30;background:color-mix(in srgb, var(--bg) 88%, transparent);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--rule-2)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand-name{font-size:17px;font-weight:600;letter-spacing:-0.02em}
.brand-sub{font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3);margin-top:5px}
.nav-links{display:flex;gap:28px;font-size:14px;color:var(--ink-2)}
.nav-links a{padding:6px 0}
.nav-links a:hover{color:var(--accent)}
.nav-cta{font-size:14px;border:1px solid var(--ink);padding:9px 16px;border-radius:999px;transition:background .15s,color .15s;font-weight:500}
.nav-cta:hover{background:var(--ink);color:var(--bg)}
@media (max-width: 880px){ .nav-links{display:none} }

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:15px;font-weight:500;padding:14px 22px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .15s, background .15s, color .15s}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--accent);color:var(--accent-ink)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.btn .arr{transition:transform .15s}
.btn:hover .arr{transform:translateX(3px)}
.section--accent .chip{display:inline-flex;align-items:center;font-family:var(--mono);font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;padding:7px 12px;border:1px solid #FFFFFF38;border-radius:999px;color:var(--accent-ink);background:transparent}
.section--accent .btn-primary{background:var(--bg);color:var(--ink)}
.section--accent .btn-primary:hover{background:var(--accent-ink);color:var(--ink)}

/* hero */
.hero{padding-top: clamp(72px, 10vw, 140px); padding-bottom: clamp(80px, 11vw, 160px)}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom: clamp(40px, 6vw, 72px)}
.hero-meta .col{display:flex;flex-direction:column;gap:6px}
.hero-meta .label{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-3)}
.hero-meta .val{font-size:14px;color:var(--ink-2)}
.hero h1{margin-bottom: clamp(32px, 4vw, 56px)}
.hero h1 .accent{color:var(--accent)}
.hero-foot{display:grid;grid-template-columns: 1.2fr 1fr;gap: clamp(32px, 5vw, 80px); align-items:end; padding-top: clamp(40px, 5vw, 64px); border-top:1px solid var(--rule)}
.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
@media (max-width: 760px){ .hero-foot{grid-template-columns:1fr} .hero-meta{flex-wrap:wrap} }

/* section header */
.s-head{display:grid;grid-template-columns: 220px 1fr; gap: clamp(24px, 4vw, 64px); margin-bottom: clamp(40px, 5vw, 64px); align-items:start}
.s-head .num{font-family:var(--mono);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-3)}
.s-head h2{max-width: 22ch}
@media (max-width: 760px){ .s-head{grid-template-columns:1fr} }

/* problem */
.problem-grid{display:grid;grid-template-columns: 220px 1fr;gap: clamp(24px, 4vw, 64px); align-items:start}
@media (max-width: 760px){ .problem-grid{grid-template-columns:1fr} }

/* packages */
.pkg-grid{border-top:1px solid var(--rule)}
.pkg{display:grid;grid-template-columns: 220px 1.1fr 1fr; gap: clamp(24px, 4vw, 64px); padding: clamp(40px, 5vw, 64px) 0; border-bottom:1px solid var(--rule); align-items:start}
.pkg .meta{display:flex;flex-direction:column;gap:14px}
.pkg .num{font-family:var(--mono);font-size:11.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-3)}
.pkg .tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;padding:5px 10px;border:1px solid var(--rule);border-radius:999px;color:var(--ink-2);width:max-content}
.pkg h3{font-size: clamp(26px, 2.4vw, 34px)}
.pkg .pitch{font-size:16.5px;line-height:1.6;color:var(--ink-2);max-width:60ch;margin-top:14px}
.pkg .variants{display:flex;flex-direction:column;gap:14px;border-left:1px solid var(--rule);padding-left:24px}
.pkg .variants .v-title{font-weight:500;color:var(--ink);font-size:15px}
.pkg .variants .v-desc{color:var(--ink-3);font-size:14.5px;line-height:1.55;margin-top:2px}
@media (max-width: 960px){ .pkg{grid-template-columns:1fr} .pkg .variants{padding-left:0;border-left:0;border-top:1px solid var(--rule);padding-top:20px} }

.bul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;border-left:1px solid var(--rule);padding-left:24px}
.bul li{position:relative;padding-left:18px;font-size:15.5px;color:var(--ink-2)}
.bul li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:1px;background:var(--accent)}
@media (max-width: 960px){ .bul{padding-left:0;border-left:0;border-top:1px solid var(--rule);padding-top:20px} }

/* cases */
.case{padding: clamp(56px, 7vw, 96px) 0;border-bottom:1px solid var(--rule)}
.case-head{display:grid;grid-template-columns: 220px 1fr; gap: clamp(24px, 4vw, 64px); margin-bottom: clamp(28px, 3vw, 40px)}
.case-head .num{font-family:var(--mono);font-size:11.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-3)}
.case-head .meta-line{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:11.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3);margin-top:8px}
.case-head h3{font-size: clamp(30px, 3.6vw, 48px);line-height:1.05;letter-spacing:-0.028em;margin-top:14px;max-width:18ch;font-weight:500}
.case-grid{display:grid;grid-template-columns: 220px 1.05fr 1fr; gap: clamp(24px, 4vw, 64px); align-items:start}
.case-visual{aspect-ratio: 5/4; background:var(--bg-2); border:1px solid var(--rule); position:relative; overflow:hidden}
.case-visual svg{display:block;width:100%;height:100%}
.case-caption{font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3);margin-top:10px}
.case-body .pitch{font-size:17px;line-height:1.65;color:var(--ink);max-width:46ch}
.case-body .translate{margin-top:24px;padding-top:20px;border-top:1px dashed var(--rule)}
.case-body .translate .label{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.case-body .translate .text{font-size:15.5px;line-height:1.6;color:var(--ink-2);max-width:48ch}
.case-body .related{margin-top:22px;padding-top:16px;border-top:1px dashed var(--rule);font-size:14px;line-height:1.6;color:var(--ink-2);max-width:54ch}
.case-body .related strong{font-weight:500;color:var(--ink);font-family:var(--mono);font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;display:inline-block;margin-right:6px}
.case-link{display:inline-flex;align-items:center;gap:8px;margin-top:24px;border-bottom:1px solid var(--ink);padding-bottom:3px;font-size:14.5px;font-weight:500}
.case-link:hover{color:var(--accent);border-color:var(--accent)}
.case--wip{position:relative}
.case--wip .case-visual{border-style:dashed;background:transparent;background-image: repeating-linear-gradient(135deg, transparent 0 10px, color-mix(in srgb, var(--ink) 4%, transparent) 10px 11px)}
.case--wip .case-head h3{color:var(--ink-2)}
.wip-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);padding:4px 10px;border:1px solid var(--accent);border-radius:999px}
.wip-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
@media (max-width: 960px){ .case-head, .case-grid{grid-template-columns:1fr} }

/* lab */
.lab{padding-top: clamp(56px, 7vw, 96px)}
.lab .intro{display:grid;grid-template-columns:220px 1fr;gap: clamp(24px, 4vw, 64px); align-items:start; margin-bottom: clamp(40px, 5vw, 56px)}
.lab .intro .body{max-width:60ch}
@media (max-width: 760px){ .lab .intro{grid-template-columns:1fr} }

/* about */
.about-grid{display:grid;grid-template-columns: 1fr 1.4fr; gap: clamp(40px, 6vw, 96px); align-items:start}
.portrait{aspect-ratio: 4/5;background:var(--bg-2);border:1px solid var(--rule);position:relative;overflow:hidden;margin:0}
.portrait svg{position:absolute;inset:0;width:100%;height:100%}
.portrait--photo{aspect-ratio: 3/4}
.portrait--photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 40%;display:block;filter:grayscale(0.05) contrast(1.02)}
.about-grid h2{margin-bottom:32px;max-width:18ch}
.about-grid .body{font-size:17px;line-height:1.7;max-width:60ch}
.about-roles{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);margin-top:40px;border:1px solid var(--rule)}
.about-roles .cell{background:var(--bg);padding:18px 20px}
.about-roles .role{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.about-roles .org{font-size:15.5px;color:var(--ink);font-weight:500}
.about-roles .since{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:2px}
@media (max-width: 880px){ .about-grid{grid-template-columns:1fr} .about-roles{grid-template-columns:1fr} }

/* tech stack (dark) */
.section--dark .stack-row{border-bottom:1px solid #FFFFFF1A}
.stack-row{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:24px 0;align-items:baseline}
.stack-row .label{font-family:var(--mono);font-size:11.5px;letter-spacing:0.12em;text-transform:uppercase;color:#9C9D97}
.stack-row .items{font-size:22px;color:#E9E7E0;line-height:1.4;letter-spacing:-0.018em;font-weight:400}
@media (max-width: 760px){ .stack-row{grid-template-columns:1fr;gap:6px} }

/* start */
.start-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.start-card{padding: clamp(28px,3vw,40px) clamp(24px,2.5vw,32px);border-right:1px solid var(--rule);display:flex;flex-direction:column;gap:14px;min-height:340px;position:relative}
.start-card:last-child{border-right:0}
.start-card .num{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-3)}
.start-card .price{font-family:var(--mono);font-size:11.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-2);margin-top:auto}
.start-card h3{font-size:26px;line-height:1.15;margin-top:4px;font-weight:500}
.start-card .desc{font-size:15.5px;line-height:1.6;color:var(--ink-2)}
.start-card.featured{background:var(--ink);color:var(--bg)}
.start-card.featured .num,.start-card.featured .price,.start-card.featured .desc{color:#C9C7C0}
.start-card.featured h3{color:var(--bg)}
@media (max-width: 880px){ .start-grid{grid-template-columns:1fr} .start-card{border-right:0;border-bottom:1px solid var(--rule);min-height:auto} .start-card:last-child{border-bottom:0} }

/* form */
.form-wrap{margin-top: clamp(56px,6vw,80px); display:grid;grid-template-columns:220px 1fr;gap: clamp(24px,4vw,64px)}
.form-wrap h3{font-size:32px;margin-bottom:8px;font-weight:500;letter-spacing:-0.025em}
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px;max-width:720px;margin-top:24px}
.form .full{grid-column:1/-1}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:15px;color:var(--ink);background:transparent;border:0;border-bottom:1px solid var(--rule);padding:8px 0;outline:none;font-family:var(--sans);border-radius:0}
.field textarea{min-height:90px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-bottom-color:var(--accent)}
.form .submit-row{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:14px}
.form .legal{font-size:12px;color:var(--ink-3);max-width:50ch;line-height:1.5}
@media (max-width: 760px){ .form{grid-template-columns:1fr} .form-wrap{grid-template-columns:1fr} }

/* speaking */
.speak-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.speak-card{padding:28px;border:1px solid var(--rule);background:var(--bg);display:flex;flex-direction:column}
.speak-card .label{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.speak-card h4{font-size:22px;margin-bottom:12px;line-height:1.2;font-weight:500;letter-spacing:-0.02em}
.speak-card .text{font-size:15px;color:var(--ink-2);line-height:1.6;max-width:46ch}
.speak-card .meta-row{margin-top:18px;padding-top:14px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:11.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3);display:flex;gap:16px;flex-wrap:wrap}
@media (max-width: 760px){ .speak-grid{grid-template-columns:1fr} }

/* publikationen */
.pub-grid{display:grid;grid-template-columns: 220px 1fr; gap: clamp(24px, 4vw, 64px); align-items:start}
.pub-body{display:flex;flex-direction:column;gap:40px}
.pub-lead{font-size:clamp(19px,1.6vw,23px);line-height:1.45;color:var(--ink);max-width:48ch;letter-spacing:-0.01em;font-weight:400;text-wrap:pretty}
.pub-lead em{font-style:normal;color:var(--accent)}
.pub-covers{display:flex;gap:22px;flex-wrap:wrap;align-items:flex-end}
.pub-cover{height:200px;display:block;border:1px solid #11121022;box-shadow:1px 1px 0 0 #1112100A, 6px 6px 0 0 var(--bg-3);position:relative;overflow:hidden;background:var(--bg-2);line-height:0}
.pub-cover img{display:block;height:100%;width:auto;filter:grayscale(1) contrast(0.96);opacity:0.92}
.pub-cover figcaption{position:absolute;left:-9999px}
.pub-cover--alt{box-shadow:1px 1px 0 0 #1112100A, 6px 6px 0 0 var(--bg-2)}
.pub-bylines{display:flex;flex-direction:column;gap:14px;padding-top:28px;border-top:1px solid var(--rule)}
.pub-bylines .label{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3)}
.pub-mags{display:flex;align-items:baseline;gap:14px 22px;flex-wrap:wrap;font-size:clamp(20px,2vw,28px);letter-spacing:-0.022em;font-weight:500;color:var(--ink)}
.pub-mags .sep{color:var(--ink-4);font-weight:400;font-size:0.7em;transform:translateY(-0.15em);display:inline-block}
.pub-meta-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding-top:24px;border-top:1px solid var(--rule)}
.pub-meta-row .meta-cell .label{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px;display:block}
.pub-meta-row .meta-cell .text{font-size:15px;line-height:1.55;color:var(--ink-2);max-width:42ch}
@media (max-width: 880px){ .pub-grid{grid-template-columns:1fr} .pub-meta-row{grid-template-columns:1fr} .pub-cover{height:170px} }

/* svc-cards: konsolidierte Speaking/Veröffentlichungen/Community
   6-Spalten-Basis: kurze Karten 1/3 (span 2), Wide-Karten 1/2 (span 3) */
.svc-cards{display:grid;grid-template-columns:repeat(6, minmax(0,1fr));gap:20px;margin-top:48px}
.svc-card{grid-column:span 2;padding:24px;border:1px solid var(--rule);background:var(--bg);display:flex;flex-direction:column;min-height:340px}
.svc-card--wide{grid-column:span 3;padding:28px}
.svc-card .label{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.svc-card h4{font-size:21px;margin-bottom:12px;line-height:1.2;font-weight:500;letter-spacing:-0.02em}
.svc-card .text{font-size:14.5px;color:var(--ink-2);line-height:1.55;flex:1}
.svc-card .meta-row{margin-top:18px;padding-top:14px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3);display:flex;gap:14px;flex-wrap:wrap}
.svc-card .case-link{margin-top:18px;display:inline-block}
.svc-covers{display:flex;gap:10px;margin-top:20px;align-items:flex-end;justify-content:flex-start}
.svc-cover{width:74px;display:block;border:1px solid #11121022;box-shadow:1px 1px 0 0 #1112100A, 4px 4px 0 0 var(--bg-3);overflow:hidden;background:var(--bg-2);line-height:0;flex:0 0 auto;margin:0}
.svc-cover img{display:block;width:100%;height:auto;filter:grayscale(1) contrast(0.96);opacity:0.92}
.svc-cover figcaption{position:absolute;left:-9999px}
.svc-mags{display:flex;flex-direction:column;gap:6px;margin-top:14px;font-size:13.5px;color:var(--ink);letter-spacing:-0.01em}
.svc-mags .grp-label{font-family:var(--mono);font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:2px;font-weight:400}
.svc-card .list-mono{list-style:none;padding:0;margin:14px 0 0 0;font-family:var(--mono);font-size:12.5px;line-height:1.5;color:var(--ink-2)}
.svc-card .list-mono li{padding:9px 0;border-top:1px solid var(--rule)}
.svc-card .list-mono li:first-child{border-top:0;padding-top:4px}
.svc-card .list-mono .l-title{display:block;color:var(--ink);letter-spacing:-0.005em;font-size:13.5px;margin-bottom:3px}
.svc-card .list-mono .l-meta{display:block;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--ink-3)}
.svc-card .list-mono a{color:inherit;border-bottom:1px solid var(--rule)}
.svc-card .list-mono a:hover{color:var(--accent);border-color:var(--accent)}
.svc-card .list-note{margin-top:14px;padding-top:12px;border-top:1px solid var(--rule);font-size:12.5px;line-height:1.5;color:var(--ink-3);font-style:italic;max-width:55ch}
.svc-card .list-note + .list-foot{margin-top:10px;padding-top:10px;border-top:1px dashed var(--rule)}
.svc-card .list-foot{margin-top:14px;padding-top:12px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3)}
@media (max-width: 1100px){ .svc-cards{grid-template-columns:repeat(2, minmax(0,1fr))} .svc-card,.svc-card--wide{grid-column:span 1} }
@media (max-width: 580px){ .svc-cards{grid-template-columns:1fr} .svc-card{min-height:0} }

/* section divider */
.section-sep{padding:0}
.section-sep-line{height:1px;background:var(--rule)}

/* standpunkte (dark) */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.post{padding:32px;border:1px solid #FFFFFF22;background:#1B1C1A;display:flex;flex-direction:column;gap:14px;min-height:280px}
.post .date{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:#9C9D97}
.post h4{font-size:24px;line-height:1.2;color:#F4EFE3;font-weight:500;letter-spacing:-0.022em}
.post .text{font-size:15px;line-height:1.6;color:#C9C7C0}
.post .link{margin-top:auto;font-family:var(--mono);font-size:11.5px;letter-spacing:0.08em;text-transform:uppercase;color:#9CC1BC;padding-top:18px;border-top:1px solid #FFFFFF1A}
.post .link:hover{color:#F4EFE3}
@media (max-width: 1100px){ .posts{grid-template-columns:repeat(2,1fr)} }
@media (max-width: 720px){ .posts{grid-template-columns:1fr} }

/* footer */
.footer{padding: clamp(64px,8vw,120px) 0 48px;background:var(--ink);color:#C9C7C0}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:64px}
.footer-top h4{font-size:34px;color:#F4EFE3;line-height:1.1;max-width:14ch;font-weight:500;letter-spacing:-0.025em}
.footer-top .col{display:flex;flex-direction:column;gap:10px}
.footer-top .col .h{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:#9C9D97;margin-bottom:6px}
.footer-top .col a{color:#C9C7C0;font-size:14.5px}
.footer-top .col a:hover{color:#F4EFE3}
.footer-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:#7A7C76;border-top:1px solid #FFFFFF22;padding-top:24px}
@media (max-width: 880px){ .footer-top{grid-template-columns:1fr 1fr} }
@media (max-width: 560px){ .footer-top{grid-template-columns:1fr} }

.viz-bg{fill:var(--bg-2)}
.stripe{background-image: repeating-linear-gradient(135deg, transparent 0 14px, color-mix(in srgb, var(--ink) 4%, transparent) 14px 15px)}

/* trust bar — quiet inline framework row, no section header */
.trust-bar{padding: clamp(28px, 3.5vw, 44px) 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.trust-bar .trust-inner{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.trust-bar .trust-note{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-4);font-weight:400}
.trust-bar .trust-list{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px 0;font-size:14.5px;color:var(--ink-2);letter-spacing:-0.005em}
.trust-bar .trust-list span{padding:0 18px;border-right:1px solid var(--rule);line-height:1.2;white-space:nowrap}
.trust-bar .trust-list span:last-child{border-right:0}
@media (max-width: 640px){
  .trust-bar .trust-list span{padding:0 12px;font-size:13.5px}
}

/* ============================================================ */
/* Visitenkarten-Variante (visitenkarte.html)                   */
/* ============================================================ */

/* Cases als kompaktes 3er-Grid statt einzelner Case-Blöcke */
.vk-cases-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:24px}
.case-card{padding:32px;border:1px solid var(--rule);background:var(--bg);display:flex;flex-direction:column;gap:14px;min-height:340px}
.case-card .meta-line{display:flex;gap:16px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3)}
.case-card h3{font-size:24px;line-height:1.18;letter-spacing:-0.022em;margin-top:4px;font-weight:500;max-width:22ch}
.case-card .pitch{font-size:15px;line-height:1.6;color:var(--ink-2);margin-top:4px}
.case-card .case-link{margin-top:auto;background:none;border:0;border-bottom:1px solid var(--ink);border-radius:0;padding:0 0 3px;cursor:pointer;font-family:inherit;font-size:14.5px;font-weight:500;color:var(--ink);align-self:flex-start;display:inline-flex;align-items:center;gap:8px}
.case-card .case-link:hover{color:var(--accent);border-color:var(--accent)}
.case-card .case-link .arr{transition:transform .15s}
.case-card .case-link:hover .arr{transform:translateX(3px)}
@media (max-width: 720px){ .vk-cases-grid{grid-template-columns:1fr} .case-card{min-height:0} }

/* Modal-Dialog für Case-Details */
.case-modal{padding:0;border:0;background:var(--bg);color:var(--ink);max-width:min(820px, 92vw);width:100%;max-height:90vh;overflow:auto;border-radius:0;box-shadow:0 30px 80px rgba(17,18,16,0.35)}
.case-modal::backdrop{background:rgba(17,18,16,0.55);backdrop-filter:blur(4px)}
.case-modal-close{position:absolute;top:14px;right:18px;background:none;border:0;font-size:32px;line-height:1;color:var(--ink-3);cursor:pointer;padding:6px 10px;font-family:var(--sans);z-index:2}
.case-modal-close:hover{color:var(--ink)}
.case-modal-body{padding: clamp(32px, 5vw, 56px) clamp(28px, 5vw, 56px)}
.case-modal-body .meta-line{display:flex;gap:16px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:18px}
.case-modal-body h3{font-size: clamp(26px, 3.2vw, 38px);line-height:1.1;letter-spacing:-0.025em;margin-bottom:24px;font-weight:500;max-width:24ch}
.case-modal-visual{aspect-ratio:5/4;background:var(--bg-2);border:1px solid var(--rule);overflow:hidden;margin-bottom:28px}
.case-modal-visual svg{display:block;width:100%;height:100%}
.case-modal-visual img{display:block;width:100%;height:100%;object-fit:contain;background:#111210}
.case-modal-visual--wide{aspect-ratio:16/10}
.case-modal-visual--tall{aspect-ratio:2/3;max-width:520px;margin-left:auto;margin-right:auto}
.case-modal-body .pitch{font-size:16.5px;line-height:1.65;color:var(--ink);max-width:60ch}
.case-modal-body .related{margin-top:22px;padding-top:16px;border-top:1px dashed var(--rule);font-size:14px;line-height:1.6;color:var(--ink-2);max-width:60ch}
.case-modal-body .related strong{font-weight:500;color:var(--ink);font-family:var(--mono);font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;display:inline-block;margin-right:6px}

/* Legal modals (Impressum, Datenschutz) */
.legal-modal h3{font-size: clamp(24px, 2.6vw, 30px);margin-bottom:14px}
.legal-modal-body{font-size:14.5px;line-height:1.6;color:var(--ink-2)}
.legal-modal-body .legal-intro{font-family:var(--mono);font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:32px;padding-bottom:14px;border-bottom:1px solid var(--rule)}
.legal-modal-body .legal-h{font-size:13.5px;font-weight:500;color:var(--ink);letter-spacing:0.04em;text-transform:uppercase;font-family:var(--mono);margin-top:28px;margin-bottom:10px;padding-top:14px;border-top:1px dashed var(--rule)}
.legal-modal-body .legal-h:first-of-type{padding-top:0;border-top:0;margin-top:0}
.legal-modal-body p{max-width:68ch;margin-bottom:10px}
.legal-modal-body a{color:var(--accent);border-bottom:1px solid color-mix(in srgb, var(--accent) 40%, transparent)}
.legal-modal-body a:hover{border-color:var(--accent)}
.legal-modal-body .legal-list{margin:6px 0 12px 0;padding-left:20px;max-width:68ch}
.legal-modal-body .legal-list li{margin-bottom:4px}
.legal-modal-body .legal-note{font-size:13px;color:var(--ink-3);font-style:italic;margin-top:-2px;margin-bottom:16px;max-width:68ch}

/* About ohne Portrait, einspaltig */
.vk-about{max-width:760px}
.vk-about .body{font-size:17px;line-height:1.7}
.vk-about .body p + p{margin-top:1em}
.vk-about .about-roles{margin-top:48px}

/* About split-Layout: Portrait links, Body + Rollen rechts (wie index.html .about-grid) */
.vk-about--split{max-width:none;display:grid;grid-template-columns:1fr 1.4fr;gap: clamp(40px,6vw,96px);align-items:start}
.vk-about--split .body{max-width:60ch}
@media (max-width: 880px){
  .vk-about--split{grid-template-columns:1fr}
  .vk-about--split .portrait{max-width:320px}
  .vk-about--split .about-roles{grid-template-columns:1fr}
}

/* Kontakt-Block schmal */
.vk-contact{display:grid;grid-template-columns:220px 1fr;gap: clamp(24px,4vw,64px); align-items:start}
@media (max-width: 760px){ .vk-contact{grid-template-columns:1fr} }
