/* =========================================================================
   3dkad.de – Visual System
   Swiss grid · architectural precision · monochrome + copper accent
   Type: Clash Display (display) · General Sans (body) · IBM Plex Mono (labels)
   ========================================================================= */

:root{
  /* Brand ink + neutrals (from "All About The Logo") */
  --ink:#231F20;
  --ink-90:#2c2826;
  --ink-80:#3a3633;
  --ink-60:#5b554f;
  --gray:#6d6d6d;
  --gray-40:#b6b2ab;
  --paper:#ffffff;
  --paper-2:#f1f2f2;      /* brand secondary light */
  --paper-3:#f7f6f3;      /* warm off-white */

  /* Accent – warm gold */
  --accent:#f9c85d;
  --accent-deep:#e3a83a;
  --accent-soft:rgba(249,200,93,.14);
  --accent-ink:#231F20;   /* readable text on the accent fill */
  --accent-text:#8a6a12;  /* deeper gold for accent TEXT on light backgrounds (WCAG AA) */

  /* Lines */
  --line:#e4e2dd;
  --line-strong:#d6d3cc;
  --line-dark:rgba(255,255,255,.13);

  /* Layout */
  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
  --col-gap:24px;

  /* Type */
  --font-display:"Switzer","General Sans",system-ui,sans-serif;
  --font-body:"Switzer","General Sans",system-ui,sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,Menlo,monospace;

  /* Motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --reveal-y:34px;
  --reveal-dur:.9s;
}


*{box-sizing:border-box;margin:0;padding:0}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto} }

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- Layout primitives ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.section{ position:relative; padding-block:clamp(72px,9vw,140px); }
.section--tight{ padding-block:clamp(48px,6vw,88px); }

.grid12{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:var(--col-gap);
}

/* faint vertical grid lines motif */
.gridlines{ position:absolute; inset:0; pointer-events:none; z-index:0; }
.gridlines .wrap{ height:100%; }
.gridlines-inner{
  height:100%;
  display:grid;
  grid-template-columns:repeat(4,1fr);
}
.gridlines-inner span{ border-right:1px solid var(--line); }
.gridlines-inner span:first-child{ border-left:1px solid var(--line); }
.dark .gridlines-inner span,
.dark .gridlines-inner span:first-child{ border-color:var(--line-dark); }
@media(max-width:760px){ .gridlines{display:none} }

/* ---------- Sections themes ---------- */
.dark{ background:var(--ink); color:var(--paper-2); }
.dark .muted{ color:var(--gray-40); }
.alt{ background:var(--paper-2); }
.warm{ background:var(--paper-3); }

/* ---------- Type ---------- */
.eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-weight:500;
}
.eyebrow::before{
  content:"";
  width:26px;height:1px;background:var(--accent);
  display:inline-block;
}
.eyebrow .num{ color:var(--gray); }
.dark .eyebrow .num{ color:var(--gray-40); }

h1,h2,h3{ font-family:var(--font-display); font-weight:600; line-height:1.02; letter-spacing:-.018em; }
.display{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2.6rem,6.4vw,5.4rem);
  line-height:.98;
  letter-spacing:-.026em;
}
h2.title{ font-size:clamp(2rem,3.6vw,3.3rem); letter-spacing:-.022em; }
h3{ font-size:clamp(1.25rem,1.7vw,1.55rem); font-weight:600; letter-spacing:-.012em; }

.lead{ font-size:clamp(1.05rem,1.35vw,1.32rem); line-height:1.5; color:var(--ink-80); max-width:46ch; }
.dark .lead{ color:var(--paper-2); }
.muted{ color:var(--ink-60); }
.cap{ font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--gray); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-mono); font-size:13px; letter-spacing:.08em; text-transform:uppercase;
  padding:16px 26px; border:1px solid var(--ink); background:var(--ink); color:var(--paper);
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease);
}
.btn .arrow{ transition:transform .4s var(--ease); }
.btn:hover{ background:var(--accent); border-color:var(--accent); color:var(--accent-ink); }
.btn:hover .arrow{ transform:translateX(5px); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.dark .btn{ background:var(--paper); color:var(--ink); border-color:var(--paper); }
.dark .btn:hover{ background:var(--accent); border-color:var(--accent); color:var(--accent-ink); }
.dark .btn--ghost{ background:transparent; color:var(--paper); border-color:rgba(255,255,255,.4); }
.dark .btn--ghost:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* Hero ghost button sits on the dark hero image (overlay layout, ≥641px):
   give it light text + a clearly visible border. On mobile (≤640px) the hero
   renders on paper, so the default dark-ink ghost stays. */
@media(min-width:641px){
  .hero .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.6); }
  .hero .btn--ghost:hover{ background:#fff; color:var(--ink); border-color:#fff; }
}

.textlink{
  font-family:var(--font-mono); font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:9px; color:var(--ink);
  border-bottom:1px solid var(--line-strong); padding-bottom:4px;
  transition:color .3s var(--ease), border-color .3s var(--ease);
}
.textlink .arrow{ transition:transform .35s var(--ease); }
.textlink:hover{ color:var(--accent); border-color:var(--accent); }
.textlink:hover .arrow{ transform:translateX(4px); }
.dark .textlink{ color:var(--paper-2); border-color:var(--line-dark); }
.dark .textlink:hover{ color:#fff; border-color:var(--accent); }

/* =========================================================================
   HEADER
   ========================================================================= */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  padding-block:13px;
}
.site-header.on-dark .logo img{ content:url("3dkad_logo_light.png"); }
.site-header.scrolled.on-dark .logo img{ content:url("3dkad_logo_dark.png"); }
.logo img{ height:30px; width:auto; transition:opacity .3s; }
.site-header.scrolled .logo img{ height:27px; }

.nav{ display:flex; align-items:center; gap:34px; }
.nav-links{ display:flex; gap:34px; align-items:center; }
.nav a{
  font-family:var(--font-body); font-size:15px; font-weight:500; letter-spacing:0; color:var(--ink-80);
  position:relative; transition:color .3s var(--ease);
}
.on-dark:not(.scrolled) .nav a{ color:rgba(255,255,255,.78); }
.on-dark:not(.scrolled) .nav .lang button{ color:rgba(255,255,255,.78); }
.nav a::after{
  content:""; position:absolute; left:0; bottom:-6px; width:0; height:1px; background:var(--accent);
  transition:width .35s var(--ease);
}
.nav a:hover{ color:var(--accent); }
.nav a:hover::after{ width:100%; }

.nav .lang{ display:flex; align-items:center; gap:7px; font-family:var(--font-body); font-size:13px; font-weight:500; }
.nav .lang button{ background:none;border:none; color:var(--ink-60); letter-spacing:.02em; padding:2px; transition:color .25s; }
.nav .lang button.active{ color:var(--accent); }
.nav .lang span{ color:var(--gray-40); }

.nav .nav-cta{
  border:1px solid var(--ink); padding:10px 20px; color:var(--ink); font-size:14px; letter-spacing:.01em;
}
.on-dark:not(.scrolled) .nav .nav-cta{ border-color:rgba(255,255,255,.4); color:#fff; }
.nav .nav-cta::after{ display:none; }
.nav .nav-cta:hover{ background:var(--accent); border-color:var(--accent); color:var(--accent-ink); }

.burger{ display:none; }

@media(max-width:880px){
  .nav .nav-links,.nav .nav-cta{ display:none; }
  .burger{
    display:flex; flex-direction:column; gap:5px; background:none; border:none; padding:6px;
  }
  .burger span{ width:26px; height:2px; background:var(--ink); display:block; transition:.3s; }
  .on-dark:not(.scrolled) .burger span{ background:#fff; }
}

/* =========================================================================
   01 · HERO
   ========================================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  background:var(--ink); color:var(--paper); overflow:hidden;
  padding-bottom:clamp(48px,7vw,90px);
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media .frame{
  position:absolute; inset:0; opacity:0; transform:scale(1.08);
  transition:opacity 1.8s var(--ease);
}
.hero-media .frame.active{ opacity:1; animation:kenburns 9s ease-out forwards; }
@keyframes kenburns{ from{transform:scale(1.08)} to{transform:scale(1.0)} }
.hero-media image-slot, .hero-media img{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(35,31,32,.62) 0%,rgba(35,31,32,.30) 35%,rgba(35,31,32,.74) 100%);
  z-index:2;
}
.hero-grid{ z-index:3; }
.hero-grid .gridlines-inner span{ border-color:rgba(255,255,255,.08); }

/* cursor-raster – grid halo that follows the pointer, in the dark grid zones (Hero + #architekt). */
.cursor-raster{
  position:absolute; inset:0; z-index:0;
  pointer-events:none; opacity:0;
  transition:opacity .45s ease;
  --mx:50%; --my:50%;
  --raster-gap:24px;
  --raster-line:rgba(249,200,93,.22);
  background-image:
    repeating-linear-gradient(to right,  var(--raster-line) 0 1px, transparent 1px var(--raster-gap)),
    repeating-linear-gradient(to bottom, var(--raster-line) 0 1px, transparent 1px var(--raster-gap));
  -webkit-mask:radial-gradient(circle clamp(95px,12vw,165px) at var(--mx) var(--my), #000 0%, transparent 70%);
          mask:radial-gradient(circle clamp(95px,12vw,165px) at var(--mx) var(--my), #000 0%, transparent 70%);
}
.hero .cursor-raster{ z-index:3; }                /* over the hero overlay (::after z2), under the text (z4) */
@media(max-width:760px){ .cursor-raster{ display:none; } }

.hero-inner{ position:relative; z-index:4; width:100%; }
.hero-eyebrow{ color:#fff; margin-bottom:26px; }
.hero-eyebrow::before{ background:var(--accent); }
.hero h1{
  color:#fff; max-width:24ch;
  font-size:clamp(2.9rem,7.4vw,5.5rem);
  hyphens:none; -webkit-hyphens:none;
}
@media(max-width:600px){
  .hero h1{ font-size:clamp(1.8rem,7.6vw,2.6rem); max-width:100%; overflow-wrap:break-word; hyphens:manual; -webkit-hyphens:manual; }
  .hero .sub{ font-size:1rem; }
}
.hero h1 .accent{ color:var(--accent); }
.hero .sub{
  margin-top:28px; max-width:62ch; color:rgba(255,255,255,.84);
  font-size:clamp(1.02rem,1.3vw,1.28rem); line-height:1.55;
}
.hero .cta-row{ display:flex; gap:16px; flex-wrap:wrap; margin-top:40px; align-items:center; }

.hero-foot{
  position:absolute; bottom:0; left:0; right:0; z-index:4;
  border-top:1px solid rgba(255,255,255,.14);
  display:none;
}
.scroll-hint{
  position:absolute; right:var(--gutter); bottom:clamp(48px,7vw,90px); z-index:4;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.6); writing-mode:vertical-rl; display:flex; align-items:center; gap:14px;
}
.scroll-hint::after{ content:""; width:1px; height:46px; background:rgba(255,255,255,.4); animation:scrollpulse 2s var(--ease) infinite; }
@keyframes scrollpulse{ 0%,100%{opacity:.3;transform:scaleY(.6)} 50%{opacity:1;transform:scaleY(1)} }
@media(max-width:760px){ .scroll-hint{display:none} }

/* hero rotating dots */
.hero-dots{ display:flex; gap:10px; margin-top:38px; flex-wrap:wrap; max-width:100%; }
.hero-dots button{ width:34px;height:3px;background:rgba(255,255,255,.25);border:none;padding:0;transition:background .4s; }
.hero-dots button.active{ background:var(--accent); }
@media(max-width:560px){
  .hero-dots{ gap:7px; flex-wrap:nowrap; }
  .hero-dots button{ flex:1 1 0; width:auto; min-width:0; height:3px; }
}

/* MOBILE HERO – gestapelt; Render im echten 16:9 ohne Crop (ersetzt frühere 100svh/cover-Lösung).
   Box = Bildverhältnis → randlos, keine Balken. Text + Lead unter das Bild, auf Papier. */
@media(max-width:640px){
  .hero{ min-height:auto; display:block; background:var(--paper); color:var(--ink); padding-bottom:0; }
  .hero-media{ position:relative; inset:auto; aspect-ratio:16/9; width:100%; z-index:0; }
  .hero-media .frame{ position:absolute; inset:0; transform:none; }
  .hero-media .frame.active{ animation:none; }            /* Ken-Burns aus */
  .hero-media image-slot, .hero-media img{ width:100%; height:100%; object-fit:cover; }
  .hero-media::after{ display:none; }                     /* kein Text über dem Bild → kein Verlauf */
  .hero-inner{ position:static; z-index:auto; padding:24px 20px; }
  .hero-eyebrow{ color:var(--ink); margin-bottom:18px; }
  .hero h1{ color:var(--ink); }
  .hero .sub{ color:rgba(35,31,32,.74); }
  .hero-dots button{ background:rgba(35,31,32,.18); }
  .hero-dots button.active{ background:var(--accent); }
}

/* =========================================================================
   02 · TRUST BAR
   ========================================================================= */
.trust{ padding-block:clamp(40px,5vw,64px); border-bottom:1px solid var(--line); }
.trust-head{ font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--gray); text-align:center; margin-bottom:34px; }
.logos{
  display:grid; grid-template-columns:repeat(5,1fr); gap:30px 24px; align-items:center; justify-items:center;
}
.logos .client{
  display:flex; align-items:center; justify-content:center;
  opacity:.66; transition:opacity .35s var(--ease); padding-block:6px;
}
.logos .client img{ display:block; width:auto; height:auto; object-fit:contain; }
.logos .client:hover{ opacity:1; }
@media(max-width:900px){ .logos{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:520px){ .logos{ grid-template-columns:repeat(2,1fr); } }

/* =========================================================================
   Section header block (shared)
   ========================================================================= */
.sec-head{ margin-bottom:clamp(40px,5vw,68px); }
.sec-head .title{ margin-top:20px; max-width:20ch; }
.sec-head.split{ display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:end; }
.sec-head.split .lead{ padding-bottom:8px; }
@media(max-width:860px){ .sec-head.split{ grid-template-columns:1fr; gap:18px; } }

/* =========================================================================
   03 · LEISTUNGEN
   ========================================================================= */
.leistungen-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.leistung{
  background:var(--paper); padding:clamp(28px,3vw,48px); position:relative;
  display:flex; flex-direction:column; min-height:300px;
  transition:background .4s var(--ease);
}
.alt .leistung{ background:var(--paper-2); }
.leistung:hover{ background:var(--paper-3); }
.leistung .l-num{ font-family:var(--font-mono); font-size:12px; color:var(--gray); letter-spacing:.1em; }
.leistung h3{ margin-top:auto; padding-top:60px; }
.leistung .l-desc{ margin-top:14px; color:var(--ink-60); font-size:1rem; max-width:38ch; }
.leistung .l-price{ margin-top:22px; font-family:var(--font-mono); font-size:13px; letter-spacing:.04em; color:var(--accent); }
.leistung .l-mark{
  position:absolute; top:clamp(28px,3vw,48px); right:clamp(28px,3vw,48px);
  width:40px;height:40px; border:1px solid var(--line-strong); border-radius:50%;
  display:flex;align-items:center;justify-content:center; color:var(--ink-60);
  transition:transform .45s var(--ease), border-color .4s, color .4s;
}
.leistung:hover .l-mark{ transform:rotate(45deg); border-color:var(--accent); color:var(--accent); }
@media(max-width:760px){ .leistungen-grid{ grid-template-columns:1fr; } .leistung{ min-height:auto; } .leistung h3{ padding-top:34px; } }

.preis-note{ margin-top:26px; font-family:var(--font-mono); font-size:12.5px; color:var(--gray); letter-spacing:.02em; }

/* =========================================================================
   04 · WARUM EIN ARCHITEKT (dark, portrait split)
   ========================================================================= */
.warum-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(40px,5vw,80px); align-items:center; }
@media(max-width:900px){ .warum-grid{ grid-template-columns:1fr; gap:40px; } }
.portrait-wrap{ position:relative; }
.portrait-wrap image-slot, .portrait-wrap .portrait-img{ width:100%; aspect-ratio:4/5; display:block; }
.portrait-wrap .portrait-img{ object-fit:cover; object-position:50% 18%; }
.portrait-tag{
  position:absolute; left:0; bottom:-1px; background:var(--accent); color:var(--accent-ink);
  font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  padding:11px 18px;
}
.warum-points{ margin-top:38px; display:grid; gap:0; border-top:1px solid var(--line-dark); }
.warum-point{ padding:26px 0; border-bottom:1px solid var(--line-dark); display:grid; grid-template-columns:auto 1fr; gap:26px; align-items:start; }
.warum-point .wp-num{ font-family:var(--font-mono); font-size:12px; color:var(--accent); letter-spacing:.1em; padding-top:5px; }
.warum-point .wp-body strong{ display:block; font-family:var(--font-display); font-weight:600; font-size:1.18rem; color:#fff; margin-bottom:7px; letter-spacing:-.01em; }
.warum-point .wp-body p{ color:var(--gray-40); font-size:1rem; line-height:1.5; max-width:54ch; }

/* =========================================================================
   05 · FEATURED PROJEKTE
   ========================================================================= */
/* Lead project (large) */
.feat-lead{ display:grid; grid-template-columns:1.55fr 1fr; border:1px solid var(--line); margin-bottom:var(--col-gap); background:var(--ink); overflow:hidden; }
.feat-lead-img{ position:relative; overflow:hidden; aspect-ratio:16/10; }
.feat-lead-img img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.2s var(--ease); }
.feat-lead:hover .feat-lead-img img{ transform:scale(1.05); }
.feat-lead-body{ padding:clamp(28px,3.4vw,56px); display:flex; flex-direction:column; justify-content:center; color:#fff; }
.feat-lead-body .eyebrow{ color:var(--accent); }
.feat-lead-body h3{ font-size:clamp(2rem,3.4vw,3rem); color:#fff; margin:18px 0 12px; letter-spacing:-.02em; }
.feat-lead-body .feat-sub{ color:var(--accent); }
.feat-lead-body p{ color:var(--gray-40); margin:16px 0 28px; max-width:42ch; font-size:1.02rem; }
@media(max-width:860px){ .feat-lead{ grid-template-columns:1fr; } }

.feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--col-gap) calc(var(--col-gap) + 4px); }
@media(max-width:900px){ .feat-grid{ grid-template-columns:1fr 1fr; gap:32px; } }
@media(max-width:560px){ .feat-grid{ grid-template-columns:1fr; gap:36px; } }
.feat .feat-sub{ font-family:var(--font-mono); font-size:12px; letter-spacing:.05em; color:var(--accent); text-transform:uppercase; margin-top:7px; }
.feat .feat-img{ aspect-ratio:3/2; }
.feat .feat-img{ position:relative; overflow:hidden; aspect-ratio:4/3; }
.feat .feat-img img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1s var(--ease); }
.feat:hover .feat-img img{ transform:scale(1.05); }
.feat-meta{ display:flex; justify-content:space-between; align-items:baseline; margin-top:16px; gap:16px; }
.feat-meta h3{ font-size:1.35rem; }
.feat-meta .yr{ font-family:var(--font-mono); font-size:12px; color:var(--gray); letter-spacing:.06em; white-space:nowrap; }
.feat .feat-sub{ font-family:var(--font-mono); font-size:12px; letter-spacing:.05em; color:var(--accent); text-transform:uppercase; margin-top:8px; }
.feat .feat-ctx{ color:var(--ink-60); font-size:.98rem; margin-top:12px; max-width:40ch; }
.feat .feat-go{ margin-top:16px; }

/* ===== 04 Projekte – Modernes asymmetrisches Mosaik ===== */

#projekte{ overflow-x:clip; }

.pj-mosaic{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:clamp(94px,9.4vw,132px);
  gap:var(--col-gap);
  grid-template-areas:
    "a10 a10 a10 gab gab gab"
    "a10 a10 a10 gab gab gab"
    "a10 a10 a10 t25 t25 f18"
    "alt alt gar gar gar gar"
    "alt alt gar gar gar gar"
    "alt alt wq  wq  gui gui"
    "lof lof lof loe loe loe"
    "lof lof lof loe loe loe"
    "aub aub steg loe loe loe";
}

/* Kachel = reine Bildfläche, Text als Overlay */
.pj-tile{ position:relative; margin:0; cursor:pointer; min-width:0; }
.pj-tile{ text-decoration:none; color:inherit; display:block; }
.pj-tile:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; }
.pj-tile .feat-img{
  position:relative; overflow:hidden; border-radius:5px;
  height:100%; aspect-ratio:auto;
}
.pj-tile .feat-img img{ width:100%; height:100%; object-fit:cover; display:block;
  transition:transform 1s var(--ease); }
.pj-tile:hover .feat-img img{ transform:scale(1.04); }

/* Verlaufs-Scrim unten, damit heller Text auf jedem Bild sitzt */
.pj-tile .feat-img::before{
  content:""; position:absolute; inset:auto 0 0 0; height:62%; z-index:1;
  pointer-events:none;
  background:linear-gradient(to top, rgba(15,13,13,.82), rgba(15,13,13,0));
}

/* .feat-meta + .feat-sub als Overlay */
.pj-tile .feat-meta,
.pj-tile .feat-sub{ position:absolute; left:clamp(16px,1.4vw,22px); right:clamp(16px,1.4vw,22px); z-index:2; color:#fff; }
.pj-tile .feat-meta{ bottom:42px; display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; }
.pj-tile .feat-meta h3{
  margin:0; font-family:var(--font-display); font-weight:600;
  font-size:clamp(1.05rem,1.7vw,1.5rem); color:#fff; letter-spacing:-.01em; line-height:1.1; }
.pj-tile .feat-meta .yr{ font-family:var(--font-mono); font-size:12px;
  color:rgba(255,255,255,.70); }
.pj-tile .feat-sub{
  bottom:20px; font-family:var(--font-mono); font-size:11.5px;
  letter-spacing:.13em; text-transform:uppercase; color:rgba(255,255,255,.82);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pj-tile .feat-sub::before{   /* Akzent-Haarlinie über der Sub-Zeile */
  content:""; position:absolute; top:-9px; left:0; width:30px; height:2px;
  background:var(--accent); }

/* Größere Feature-Kacheln dürfen größere Headline tragen */
.pj-tile[style*="a10"] .feat-meta h3,
.pj-tile[style*="loe"] .feat-meta h3{ font-size:clamp(1.4rem,2.4vw,2.1rem); }

/* Badge (▦ N Bilder) über dem Scrim halten */
.pj-tile .feat-badge{ z-index:3; }

/* ---- Projekt-Filter ---- */
.pj-filters{ display:flex; flex-wrap:wrap; gap:10px; margin:0 0 30px; }
.pj-filters button{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  padding:9px 16px; border:1px solid rgba(35,31,32,.18); border-radius:999px;
  background:transparent; color:var(--gray); cursor:pointer;
  transition:color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.pj-filters button:hover{ border-color:var(--ink); color:var(--ink); }
.pj-filters button.active{ background:var(--ink); border-color:var(--ink); color:#fff; }

/* Gefilterte Ansicht: Mosaik -> gleichmäßiges Raster, keine Lücken */
.pj-mosaic.is-filtered{ grid-template-areas:none; grid-template-columns:repeat(3,1fr); grid-auto-rows:auto; }
.pj-mosaic.is-filtered .pj-tile{ grid-area:auto !important; animation:pjFade .45s var(--ease) both; }
.pj-mosaic.is-filtered .pj-tile .feat-img{ height:auto; aspect-ratio:4/3; }
.pj-mosaic.is-filtered .pj-tile[style*="a10"] .feat-meta h3,
.pj-mosaic.is-filtered .pj-tile[style*="loe"] .feat-meta h3{ font-size:clamp(1.05rem,1.7vw,1.5rem); }
.pj-tile.is-hidden{ display:none !important; }
@keyframes pjFade{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }
@media(max-width:1000px){ .pj-mosaic.is-filtered{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:620px){ .pj-mosaic.is-filtered{ grid-template-columns:1fr; } }

/* ---- Tablet ---- */
@media(max-width:1000px){
  .pj-mosaic{
    grid-auto-rows:clamp(120px,17vw,170px);
    grid-template-areas:
      "a10 a10 a10 gab gab gab"
      "a10 a10 a10 t25 t25 f18"
      "alt alt gar gar gar gar"
      "alt alt wq  wq  gui gui"
      "lof lof lof loe loe loe"
      "aub aub steg loe loe loe";
  }
}

/* ---- Mobile: gestapelt ---- */
@media(max-width:620px){
  .pj-mosaic{ grid-template-columns:1fr; grid-template-areas:none; grid-auto-rows:auto; }
  .pj-tile{ grid-area:auto !important; }
  .pj-tile .feat-img{ height:clamp(230px,62vw,340px); }
}

/* =========================================================================
   05 · SHOWCASE – horizontal pinned strip (GSAP ScrollTrigger)
   ========================================================================= */
.showcase{ background:var(--ink); color:var(--paper-2); position:relative; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.showcase::-webkit-scrollbar{ display:none; }
.showcase.is-pinned{ overflow:hidden; height:100vh; }
.showcase-track{ display:flex; height:78vh; width:max-content; }
.showcase.is-pinned .showcase-track{ height:100vh; align-items:stretch; }

.s-panel{ flex:0 0 86vw; position:relative; height:100%; border-right:1px solid var(--line-dark); }
.s-intro{ flex:0 0 84vw; display:flex; flex-direction:column; justify-content:center; padding:0 clamp(24px,6vw,90px); }
@media(min-width:901px){ .s-panel{ flex-basis:46vw; } .s-intro{ flex-basis:40vw; } }

.s-intro .eyebrow{ color:#fff; }
.s-intro h2{ color:#fff; font-size:clamp(2rem,3.4vw,3.3rem); margin:20px 0 18px; letter-spacing:-.02em; max-width:14ch; }
.s-intro .lead{ color:var(--gray-40); max-width:40ch; }
.s-hint{ margin-top:34px; font-family:var(--font-mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); display:flex; align-items:center; gap:12px; }
.s-hint .line{ width:46px; height:1px; background:var(--accent); display:inline-block; }

.s-panel .s-img{ position:absolute; inset:0; overflow:hidden; }
.s-panel .s-img img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.2s var(--ease); }
.s-panel:hover .s-img img{ transform:scale(1.04); }
.s-panel .s-grad{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(35,31,32,.05) 40%,rgba(35,31,32,.78) 100%); }
.s-panel .s-meta{ position:absolute; left:0; right:0; bottom:0; padding:clamp(24px,3vw,44px); display:flex; align-items:flex-end; justify-content:space-between; gap:20px; }
.s-panel .s-num{ position:absolute; top:clamp(20px,2.4vw,36px); left:clamp(20px,2.4vw,36px); font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; color:rgba(255,255,255,.7); }
.s-panel .s-meta h3{ color:#fff; font-size:clamp(1.6rem,2.4vw,2.4rem); letter-spacing:-.015em; }
.s-panel .s-meta .s-sub{ font-family:var(--font-mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); margin-top:8px; }
.s-panel .s-meta .yr{ font-family:var(--font-mono); font-size:12px; color:rgba(255,255,255,.6); white-space:nowrap; }

/* =========================================================================
   06 · PORTFOLIO GRID (filterable)
   ========================================================================= */
.filters{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:34px; }
.filters button{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  padding:9px 16px; border:1px solid var(--line-strong); background:transparent; color:var(--ink-60);
  transition:.3s var(--ease);
}
.filters button:hover{ border-color:var(--ink); color:var(--ink); }
.filters button.active{ background:var(--ink); border-color:var(--ink); color:#fff; }

.pf-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
@media(max-width:1024px){ .pf-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:640px){ .pf-grid{ grid-template-columns:repeat(2,1fr); } }

/* =========================================================================
   07 · PROZESS
   ========================================================================= */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line); }
.step{ padding:34px 28px 36px 0; border-right:1px solid var(--line); position:relative; }
.step:last-child{ border-right:none; padding-right:0; }
.step .s-num{ font-family:var(--font-mono); font-size:13px; color:var(--accent); letter-spacing:.08em; }
.step h3{ font-size:1.2rem; margin-top:22px; }
.step p{ color:var(--ink-60); font-size:.97rem; margin-top:12px; max-width:30ch; }
.step::before{ content:""; position:absolute; top:-1px; left:0; width:34px; height:2px; background:var(--accent); }
.step:last-child::before{ width:34px; }
@media(max-width:860px){ .steps{ grid-template-columns:1fr 1fr; } .step{ padding:28px 24px 28px 0; } .step:nth-child(2n){ border-right:none; padding-right:0; } }
@media(max-width:520px){ .steps{ grid-template-columns:1fr; } .step{ border-right:none; padding-right:0; border-bottom:1px solid var(--line); } .step:last-child{border-bottom:none} }

/* =========================================================================
   08 · TESTIMONIALS
   ========================================================================= */
.tgroup-label{ font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin:0 0 22px; display:flex; align-items:center; gap:12px; }
.tgroup-label::before{ content:""; width:22px;height:1px;background:var(--accent); }
.tgroup-label:not(:first-of-type){ margin-top:56px; }
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.quote{ background:var(--paper-2); padding:clamp(26px,2.6vw,40px); display:flex; flex-direction:column; }
.alt .quote{ background:var(--paper); }
.quote blockquote{ font-family:var(--font-display); font-weight:500; font-size:1.18rem; line-height:1.34; letter-spacing:-.01em; color:var(--ink); }
.quote .q-mark{ font-family:var(--font-display); font-size:3rem; line-height:.5; color:var(--accent); height:24px; }
.quote .q-by{ margin-top:auto; padding-top:26px; }
.quote .q-by .name{ font-weight:600; font-size:.98rem; }
.quote .q-by .role{ font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--gray); text-transform:uppercase; margin-top:4px; }
.quote.pending blockquote{ color:var(--gray-40); }
.quote .q-pending{ font-family:var(--font-mono); font-size:10px; letter-spacing:.1em; color:var(--gray-40); border:1px solid var(--line-strong); padding:3px 8px; align-self:flex-start; text-transform:uppercase; }
@media(max-width:860px){ .quotes{ grid-template-columns:1fr; } }

/* =========================================================================
   09 · FAQ
   ========================================================================= */
.faq-list{ border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{
  width:100%; background:none; border:none; text-align:left;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:28px 0; font-family:var(--font-display); font-weight:600; font-size:clamp(1.1rem,1.7vw,1.5rem);
  color:var(--ink); letter-spacing:-.012em;
}
.faq-q .ic{ flex:none; width:30px;height:30px; position:relative; }
.faq-q .ic::before,.faq-q .ic::after{ content:""; position:absolute; background:var(--accent); transition:transform .4s var(--ease); }
.faq-q .ic::before{ left:0; top:50%; width:100%; height:2px; transform:translateY(-50%); }
.faq-q .ic::after{ left:50%; top:0; width:2px; height:100%; transform:translateX(-50%); }
.faq-item.open .faq-q .ic::after{ transform:translateX(-50%) scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
.faq-a p{ padding:0 0 30px; color:var(--ink-60); max-width:70ch; font-size:1.04rem; line-height:1.6; }

/* =========================================================================
   10 · ANFRAGE (dark)
   ========================================================================= */
.anfrage-grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(40px,5vw,80px); align-items:start; }
@media(max-width:900px){ .anfrage-grid{ grid-template-columns:1fr; gap:48px; } }
.form-field{ margin-bottom:22px; }
.form-field label{ display:block; font-family:var(--font-mono); font-size:11.5px; letter-spacing:.07em; text-transform:uppercase; color:rgba(255,255,255,.74); margin-bottom:10px; }
.form-field input,.form-field select,.form-field textarea{
  width:100%; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.2); border-radius:2px;
  color:#fff; font-family:var(--font-body); font-size:1.02rem; padding:14px 16px; transition:border-color .25s var(--ease), background .25s var(--ease);
  cursor:default;
}
.form-field input::placeholder,.form-field textarea::placeholder{ color:rgba(255,255,255,.42); }
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{ outline:none; border-color:var(--accent); background:rgba(255,255,255,.09); }
.form-field select{ color:#fff; }
.form-field select option{ color:#111; }
.form-field textarea{ resize:vertical; min-height:120px; line-height:1.5; }
.form-field.invalid input,.form-field.invalid textarea,.form-field.invalid select{ border-color:#d9694f; background:rgba(217,105,79,.08); }
.form-field .err{ display:none; color:#e08a73; font-family:var(--font-mono); font-size:11px; margin-top:7px; letter-spacing:.03em; }
.form-field.invalid .err{ display:block; }
.hp-field{ position:absolute !important; left:-9999px; width:1px; height:1px; opacity:0; overflow:hidden; pointer-events:none; }
.form-noscript{ margin-top:20px; font-size:.95rem; color:rgba(255,255,255,.8); }
.form-noscript a{ color:var(--accent); border-bottom:1px solid var(--accent); }
.form-2col{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media(max-width:560px){ .form-2col{ grid-template-columns:1fr; gap:0; } }
.optional-label{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin:36px 0 22px; }
.gdpr{ display:flex; gap:13px; align-items:flex-start; margin:6px 0 28px; }
.gdpr input{ width:18px;height:18px;flex:none; margin-top:3px; accent-color:var(--accent); }
.gdpr label{ font-family:var(--font-body); font-size:.9rem; color:rgba(255,255,255,.74); letter-spacing:0; text-transform:none; line-height:1.5; }
.gdpr.invalid label{ color:#e08a73; }
.form-success{ display:none; padding:40px 0; }
.form-success.show{ display:block; }
.form-success .check{ width:54px;height:54px;border:2px solid var(--accent); border-radius:50%; display:flex;align-items:center;justify-content:center; color:var(--accent); font-size:1.5rem; margin-bottom:24px; }
.form-success h3{ color:#fff; font-size:1.6rem; }
.form-success p{ color:var(--gray-40); margin-top:12px; max-width:44ch; }

.contact-side{ border-left:1px solid var(--line-dark); padding-left:clamp(24px,3vw,48px); }
@media(max-width:900px){ .contact-side{ border-left:none; padding-left:0; border-top:1px solid var(--line-dark); padding-top:40px; } }
.contact-side .portrait-mini{ width:84px;height:84px; border-radius:50%; overflow:hidden; margin-bottom:22px; }
.contact-side .portrait-mini image-slot, .contact-side .portrait-mini img{ width:100%;height:100%; object-fit:cover; object-position:50% 16%; display:block; }
.contact-side .ci{ margin-bottom:26px; }
.contact-side .ci .k{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--gray-40); margin-bottom:8px; }
.contact-side .ci a{ font-family:var(--font-display); font-weight:500; font-size:1.16rem; color:#fff; letter-spacing:-.01em; transition:color .3s; }
.contact-side .ci a:hover{ color:var(--accent); }
.assurances{ margin-top:30px; display:grid; gap:14px; }
.assurances li{ list-style:none; display:flex; gap:12px; align-items:center; color:var(--gray-40); font-size:.95rem; }
.assurances li .tick{ color:var(--accent); font-family:var(--font-mono); }

/* =========================================================================
   11 · FOOTER
   ========================================================================= */
.site-footer{ background:#1a1718; color:var(--gray-40); padding-block:clamp(56px,6vw,90px) 36px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:54px; border-bottom:1px solid var(--line-dark); }
@media(max-width:860px){ .footer-top{ grid-template-columns:1fr 1fr; gap:36px; } }
@media(max-width:520px){ .footer-top{ grid-template-columns:1fr; } }
.footer-brand img{ height:34px; width:auto; max-width:60vw; object-fit:contain; margin-bottom:22px; }
.footer-brand p{ font-size:.95rem; max-width:34ch; line-height:1.5; }
.footer-col h4{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray); margin-bottom:18px; font-weight:500; }
.footer-col a{ display:block; font-size:.96rem; color:var(--gray-40); padding:6px 0; transition:color .3s; }
.footer-col .foot-addr{ display:block; font-size:.96rem; color:var(--gray-40); padding:6px 0; line-height:1.5; }
.footer-col a:hover{ color:#fff; }
.foot-social{ display:flex; gap:14px; }
.foot-social a{ display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; padding:0; color:var(--gray-40); border:1px solid var(--line-dark); border-radius:50%; transition:color .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease); }
.foot-social a:hover{ color:var(--accent-ink); background:var(--accent); border-color:var(--accent); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding-top:30px; flex-wrap:wrap; }
.footer-bottom .legal{ font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--gray); }
.footer-bottom .legal a:hover{ color:#fff; }

/* =========================================================================
   Scroll reveal
   ========================================================================= */
.reveal{ opacity:0; transform:translateY(var(--reveal-y)); transition:opacity var(--reveal-dur) var(--ease), transform var(--reveal-dur) var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; }

/* =========================================================================
   image-slot default empty-state styling
   ========================================================================= */
image-slot{
  --is-bg:#2a2624;
  background:var(--is-bg);
}
image-slot::part(placeholder){ font-family:var(--font-mono); }

/* mobile menu overlay */
.mobile-menu{
  position:fixed; inset:0; z-index:60; background:var(--ink); color:#fff;
  display:flex; flex-direction:column; justify-content:center; padding:var(--gutter);
  transform:translateY(-100%); transition:transform .5s var(--ease); gap:6px;
}
.mobile-menu.open{ transform:none; }
.mobile-menu a{ font-family:var(--font-display); font-weight:600; font-size:2rem; padding:10px 0; border-bottom:1px solid var(--line-dark); }
.mobile-menu .mm-close{ position:absolute; top:22px; right:var(--gutter); background:none;border:none;color:#fff;font-size:2rem; }
.mobile-menu .mm-foot{ margin-top:34px; font-family:var(--font-mono); font-size:13px; color:var(--gray-40); }

/* =========================================================================
   PROJEKT-GALERIE (Lightbox)
   ========================================================================= */
/* affordance on the featured project cards */
.feat[data-project]{ cursor:pointer; }
.feat[data-project] .feat-img::after{
  content:""; position:absolute; inset:0; background:rgba(35,31,32,.32);
  opacity:0; transition:opacity .4s var(--ease); pointer-events:none;
}
.feat[data-project]:hover .feat-img::after,
.feat[data-project]:focus-visible .feat-img::after{ opacity:1; }
.feat[data-project]:focus-visible{ outline:2px solid var(--accent); outline-offset:4px; }
.feat-badge{
  position:absolute; left:14px; bottom:14px; z-index:2;
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:#fff; background:rgba(35,31,32,.62); backdrop-filter:blur(4px);
  padding:8px 13px; border:1px solid rgba(255,255,255,.18);
  opacity:0; transform:translateY(8px); transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.feat[data-project]:hover .feat-badge,
.feat[data-project]:focus-visible .feat-badge{ opacity:1; transform:none; }
.feat-badge .fb-ic{ font-size:13px; line-height:1; }


/* =========================================================================
   LEISTUNG-BEISPIEL (Modal)
   ========================================================================= */
.leistung[data-service]{ cursor:pointer; }
.leistung[data-service]:focus-visible{ outline:2px solid var(--accent); outline-offset:4px; }

.lmodal{ position:fixed; inset:0; z-index:200; }
.lmodal[hidden]{ display:none; }
.lmodal-backdrop{ position:absolute; inset:0; background:rgba(18,16,16,.96); backdrop-filter:blur(6px); }
.lmodal-panel{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(.98);
  width:min(960px, calc(100vw - 40px)); max-height:calc(100vh - 60px);
  background:var(--ink); border:1px solid var(--line-dark); overflow:hidden;
  display:grid; grid-template-columns:1.08fr .92fr;
  opacity:0; transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.lmodal.open .lmodal-panel{ opacity:1; transform:translate(-50%,-50%); }
.lmodal-close{
  position:absolute; top:14px; right:14px; z-index:3; width:44px; height:44px;
  background:rgba(35,31,32,.55); border:1px solid rgba(255,255,255,.22); color:#fff; font-size:24px;
  line-height:1; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px);
  transition:background .3s var(--ease), border-color .3s var(--ease);
}
.lmodal-close:hover{ background:var(--accent); border-color:var(--accent); }

.lmodal-media{ position:relative; display:block; overflow:hidden; min-height:340px; background:#000; }
.lmodal-media .lm-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.lmodal-media iframe.lm-video{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; z-index:2; }
.lmodal-media[data-video] .lm-img, .lmodal-media[data-video] .lm-launch{ display:none; }
.lmodal-media[data-launch="true"]{ cursor:pointer; }
.lmodal-media[data-launch="true"]:hover .lm-img{ transform:scale(1.04); }
.lm-launch{
  position:absolute; inset:0; display:none; align-items:center; justify-content:center;
  background:rgba(35,31,32,.28); transition:background .3s var(--ease);
}
.lmodal-media[data-launch="true"] .lm-launch{ display:flex; }
.lmodal-media[data-launch="true"]:hover .lm-launch{ background:rgba(35,31,32,.42); }
.lm-launch-ic{
  width:72px; height:72px; border:1.5px solid rgba(255,255,255,.85); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#fff;
  font-family:var(--font-mono); font-size:13px; letter-spacing:.08em;
  transition:background .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
}
.lmodal-media[data-launch="true"]:hover .lm-launch-ic{ background:var(--accent); border-color:var(--accent); transform:scale(1.06); }

.lmodal-body{ padding:clamp(26px,3vw,42px); display:flex; flex-direction:column; justify-content:center; color:#fff; }
.lmodal-body .lm-num{ color:var(--accent); margin-bottom:18px; }
.lmodal-body .lm-title{ font-size:clamp(1.5rem,2.4vw,2.05rem); color:#fff; letter-spacing:-.014em; }
.lmodal-body .lm-text{ color:var(--gray-40); margin:16px 0 28px; font-size:1.02rem; line-height:1.55; max-width:42ch; }
.lmodal-body .lm-cta{ align-self:flex-start; }

body.lmodal-open{ overflow:hidden; }

@media(max-width:720px){
  .lmodal-panel{ grid-template-columns:1fr; max-height:calc(100vh - 36px); overflow-y:auto; }
  .lmodal-media{ min-height:0; aspect-ratio:16/10; }
  .lmodal-media .lm-img{ position:static; }
}

/* Veröffentlichungen (innerhalb Referenzen) */
.pub-list{ margin-top:14px; border-top:1px solid var(--line-strong); }
.pub{
  display:flex; align-items:flex-start; gap:clamp(16px,3vw,40px);
  padding:clamp(20px,2.3vw,30px) 0;
  border-bottom:1px solid var(--line-strong);
  transition:background .4s var(--ease), padding-inline .35s var(--ease);
}
.pub:hover{ background:var(--paper); padding-inline:clamp(14px,2vw,24px); }
.pub-num{ flex:none; padding-top:6px; font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; color:var(--gray); }
.pub-main{ flex:1 1 auto; min-width:0; }
.pub-where{ display:block; font-family:var(--font-display); font-weight:600; font-size:clamp(1.1rem,1.6vw,1.45rem); letter-spacing:-.012em; color:var(--ink); }
.pub-what{ display:block; margin-top:6px; color:var(--ink-60); font-size:clamp(.95rem,1.05vw,1.04rem); line-height:1.5; max-width:64ch; }
.pub-go{ flex:none; align-self:center; font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray); white-space:nowrap; transition:color .3s var(--ease); }
.pub:hover .pub-go{ color:var(--accent-deep); }
@media(max-width:680px){
  .pub{ flex-wrap:wrap; gap:10px 16px; }
  .pub:hover{ padding-inline:0; background:transparent; }
  .pub-go{ flex-basis:100%; margin-top:4px; }
}

/* ── BILDBAND · full-bleed Interstitial (ALTERA, zwischen 06 Referenzen und 07 FAQ) ── */
.bildband{
  background: var(--ink, #231F20);       /* dunkles Token aus site.css */
  padding: clamp(8px, 3vw, 48px) 0 0;    /* schmaler dunkler Rahmen oben; Seiten bündig; Caption gibt unten Luft */
}
.bildband .bildband-fig{ margin:0; }
.bildband .bildband-fig img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio: 2 / 1;        /* kinematisches Band, geringer Beschnitt */
  object-fit: cover;
  max-height: 78vh;           /* auf Ultrawide nie den Viewport schlucken */
}
.bildband .bildband-cap{
  display:flex; align-items:baseline; gap:14px;
  padding-top:16px;
  padding-bottom: clamp(24px, 4vw, 56px);
  font-family: var(--font-mono, "IBM Plex Mono", ui-monospace, monospace);
  /* .wrap liefert max-width + seitliche Ausrichtung an der Inhaltsspalte */
}
.bildband .bb-name{ color: var(--accent, #f9c85d); letter-spacing:.08em; font-size:.82rem; }
.bildband .bb-sub { color: var(--gray, #888);     letter-spacing:.04em; font-size:.82rem; }
@media (max-width: 640px){
  .bildband .bildband-fig img{ aspect-ratio: 4 / 5; }  /* hochformatiger Crop am Handy statt dünnem Streifen */
}

/* =========================================================================
   ACCESSIBILITY · contrast (WCAG AA) — no visual-identity change
   Bright brand gold (--accent) stays on dark surfaces, borders, fills & hovers.
   Accent TEXT on light surfaces uses the deeper gold (--accent-text).
   ========================================================================= */
.leistung .l-price,
.feat .feat-sub,
.step .s-num,
.tgroup-label,
.quote .q-mark{ color:var(--accent-text); }

/* --gray was darkened for light backgrounds; restore readable tone on the
   few mono labels that sit on DARK surfaces (footer + bildband caption). */
.footer-col h4,
.footer-bottom .legal,
.bildband .bb-sub{ color:var(--gray-40); }
