:root{
    --bg:#020306; --bg-2:#07090d; --panel:#0c0f15;
    --paper:#f3f5ef; --paper-2:#e9ebe4;
    --ink:#0a0c11; --ink-2:#1a1d24;
    --fg:#f3f5ef;
    --muted:rgba(243,245,239,.74); --quiet:#c8ccc6;
    --muted-l:#4f5b57; --quiet-l:#46524f;
    --line:rgba(243,245,239,.14); --line-l:rgba(10,12,17,.12);
    --accent:#c8ccc6;        /* warm chrome / bone — replaces red */
    --accent-2:#7a8a86;      /* deeper steel */
    --chrome:#dce2df;
    --ease:cubic-bezier(.23,1,.32,1);
    --font:'Neue Haas Grotesk Display','Söhne','Avenir Next','Helvetica Neue',Arial,system-ui,sans-serif;
    --mono:'JetBrains Mono','IBM Plex Mono','SFMono-Regular',ui-monospace,Menlo,monospace;
    --maxw:1540px;
  }
  *{box-sizing:border-box}
  html{background:var(--bg);scroll-behavior:smooth;overflow-x:hidden}
  body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;overflow-x:hidden}
  img{display:block;max-width:100%;height:auto}
  a,button{font:inherit;color:inherit}
  a{text-decoration:none}
  button{border:0;background:transparent;cursor:pointer;font:inherit}
  ::selection{background:var(--accent);color:var(--ink)}
  h1,h2,h3,h4{margin:0;font-weight:900;letter-spacing:-.055em}
  p{margin:0}

  /* ============ filmic film-grain overlay ============ */
  body:before{content:"";position:fixed;inset:-18%;z-index:80;pointer-events:none;opacity:.048;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.72' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");mix-blend-mode:screen;animation:grain 2.2s steps(2) infinite}
  @keyframes grain{50%{transform:translate3d(1.2%,-1%,0)}}

  /* Topbar styles live in assets/site-chrome.css (shared across all pages) */

  /* ============ Common ============ */
  main{position:relative;z-index:2}
  section{position:relative}
  .section-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(80px,11vw,160px) clamp(22px,5vw,76px)}
  .kicker{font:10px var(--mono);letter-spacing:.26em;text-transform:uppercase;display:inline-flex;align-items:center;gap:12px;color:var(--accent)}
  .kicker:before{content:"";width:24px;height:1px;background:currentColor}
  .display{font-size:clamp(48px,8.4vw,160px);line-height:.82;letter-spacing:-.075em;text-transform:uppercase}
  .display-md{font-size:clamp(40px,6.6vw,118px);line-height:.84;letter-spacing:-.06em;text-transform:uppercase}
  .display-sm{font-size:clamp(28px,3.4vw,52px);line-height:.96;letter-spacing:-.04em;text-transform:uppercase}
  .lead{font-size:clamp(16px,1.18vw,20px);line-height:1.5;max-width:54ch}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:48px;padding:13px 22px;font:10px var(--mono);letter-spacing:.2em;text-transform:uppercase;transition:transform .3s var(--ease);border:1px solid currentColor;background:transparent}
  .btn:hover{transform:translateY(-2px)}
  .btn.primary{background:var(--paper);color:var(--ink);border-color:var(--paper)}
  .btn.primary:hover{background:#fff;border-color:#fff}
  .btn.dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
  .btn.dark:hover{background:#000;border-color:#000}

  /* ===== Global lazy-fade: every img[loading=lazy] fades in smoothly ===== */
  img[loading="lazy"]{opacity:0;transform:scale(1.018);transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform 1.6s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
  img[loading="lazy"].is-loaded{opacity:1;transform:none}
  @media(prefers-reduced-motion:reduce){
    img[loading="lazy"]{transform:none;transition:opacity .35s linear}
  }

  .sec-dark{background:var(--bg);color:var(--fg)}
  .sec-light{background:var(--paper);color:var(--ink)}
  .sec-light .kicker{color:var(--accent-2)}

  /* ============ HERO — full-bleed name over photo, mouse-reveal shader ============ */
  .hero{position:relative;height:100svh;min-height:600px;max-height:100svh;display:grid;align-items:end;padding:clamp(120px,14vw,180px) clamp(22px,5vw,76px) clamp(48px,7vw,96px);overflow:hidden;isolation:isolate;background:#05070b url('optimized/mpik8b82-dsc3879-1280.webp') center/cover no-repeat;cursor:none;color:#f3f5ef}
  .hero canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;opacity:0;transition:opacity .45s var(--ease)}
  .hero canvas.is-ready{opacity:1}
  /* Cinematic gradient overlays — let the photo breathe but keep text legible */
  .hero:before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(2,3,6,.32) 0%,rgba(2,3,6,0) 22%,rgba(2,3,6,0) 52%,rgba(2,3,6,.55) 86%,rgba(2,3,6,.78) 100%)}
  .hero:after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(95% 60% at 50% 100%,rgba(2,3,6,.42) 0%,rgba(2,3,6,0) 60%)}
  /* aperture scanning line, like the services footer */
  .hero-aperture{position:absolute;z-index:2;left:-15vw;right:-15vw;top:42%;height:96px;pointer-events:none;opacity:.28;transform:rotate(-4deg) translateX(-18vw);background:linear-gradient(90deg,transparent 0%,rgba(243,245,239,.08) 36%,rgba(220,226,223,.44) 49%,rgba(220,226,223,.16) 55%,rgba(42,78,118,.16) 62%,transparent 82%);filter:blur(.2px);mask-image:linear-gradient(180deg,transparent,black 44%,black 56%,transparent);animation:heroAperture 11s var(--ease) infinite}
  @keyframes heroAperture{0%,10%{transform:rotate(-4deg) translateX(-30vw);opacity:0}28%{opacity:.42}58%{transform:rotate(-4deg) translateX(22vw);opacity:.24}100%{transform:rotate(-4deg) translateX(30vw);opacity:0}}
  /* soft moving glow */
  .hero-glow{position:absolute;inset:-30% -18%;z-index:2;pointer-events:none;background:radial-gradient(circle at 22% 28%,rgba(220,226,223,.07),transparent 30%),radial-gradient(circle at 84% 70%,rgba(42,78,118,.16),transparent 36%);filter:blur(38px);opacity:.55;animation:heroGlow 18s var(--ease) infinite alternate}
  @keyframes heroGlow{0%{transform:translate3d(-1.6%,1.2%,0) scale(1)}100%{transform:translate3d(2.2%,-1.2%,0) scale(1.04)}}

  .hero-grid{position:relative;z-index:3;display:block;width:100%;max-width:var(--maxw);margin:0 auto}

  .hero-stage{position:relative;display:block}
  .hero-title{
    position:relative;
    margin:0;
    font-size:clamp(56px,10.6vw,168px);
    line-height:.86;
    letter-spacing:-.058em;
    text-transform:uppercase;
    font-weight:900;
    color:#f6f7f2;
    -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 76%,rgba(0,0,0,.55) 100%);
    mask-image:linear-gradient(180deg,#000 0%,#000 76%,rgba(0,0,0,.55) 100%);
    text-shadow:0 24px 80px rgba(0,0,0,.55),0 2px 18px rgba(0,0,0,.55);
  }
  .hero-title .line{display:block;overflow:hidden;padding:.04em 0 .06em}
  .hero-title .word{
    display:inline-block;
    transform:none;
    opacity:1;
    will-change:transform,opacity;
    transition:transform 1.05s cubic-bezier(.18,.78,.24,1), opacity .82s var(--ease);
  }
  .hero-title.is-in .word{transform:translate3d(0,0,0);opacity:1}
  .hero-title.is-out .word{
    transform:translate3d(112%,0,0);
    opacity:0;
    transition:transform .7s cubic-bezier(.62,.02,.86,.18), opacity .5s var(--ease);
  }
  .hero-title .line:nth-child(2) .word{transition-delay:.10s}
  .hero-title .line:nth-child(2){color:rgba(243,245,239,.86)}
  .hero-title.is-out .line:nth-child(1) .word{transition-delay:.06s}
  .hero-title.is-out .line:nth-child(2) .word{transition-delay:0s}
  .hero-title.no-anim .word{transition:none !important}
  .hero-lead{max-width:46rem;margin-top:22px;color:rgba(243,245,239,.80);font-size:clamp(16px,1.28vw,21px);line-height:1.48;font-weight:520;letter-spacing:-.01em;text-wrap:pretty;text-shadow:0 14px 42px rgba(0,0,0,.50);transition:opacity .42s var(--ease),transform .42s var(--ease)}
  .hero-lead.is-hidden{opacity:0;transform:translateY(10px);pointer-events:none}
  .hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
  .hero-actions .btn{min-height:50px;border-color:rgba(243,245,239,.52);color:#f3f5ef;background:rgba(2,3,6,.22);backdrop-filter:blur(14px)}
  .hero-actions .btn.dark{background:#f3f5ef;color:#090b10;border-color:#f3f5ef}
  .hero-actions .btn:hover{background:#f3f5ef;color:#090b10;border-color:#f3f5ef}

  .hero-cursor{position:fixed;top:0;left:0;width:64px;height:64px;border:1px solid rgba(243,245,239,.78);border-radius:50%;pointer-events:none;z-index:60;transform:translate(-50%,-50%) scale(.6);mix-blend-mode:difference;transition:opacity .35s ease,transform .45s var(--ease),border-color .35s ease;opacity:0;will-change:transform}
  .hero-cursor:before,.hero-cursor:after{content:"";position:absolute;top:50%;left:50%;background:rgba(243,245,239,.85)}
  .hero-cursor:before{width:1px;height:14px;transform:translate(-50%,-50%)}
  .hero-cursor:after{width:14px;height:1px;transform:translate(-50%,-50%)}
  .hero-cursor .ring{position:absolute;inset:-10px;border:1px solid rgba(243,245,239,.20);border-radius:50%;transition:.35s var(--ease)}
  .hero-cursor.is-active{opacity:1;transform:translate(-50%,-50%) scale(1)}
  .hero-cursor.is-pressed{transform:translate(-50%,-50%) scale(.68);border-color:#fff}
  .hero-cursor.is-pressed .ring{inset:-18px;border-color:rgba(243,245,239,.35)}
  .hero a,.hero button{cursor:pointer}
  @media (hover:none), (pointer:coarse), (max-width:900px){.hero{cursor:auto}.hero canvas{display:none}.hero-cursor{display:none}}
  @media(max-width:780px){.hero{padding:120px 20px 88px}.hero-title{font-size:clamp(46px,13vw,82px);letter-spacing:-.05em}.hero-lead{max-width:34rem;margin-top:18px;font-size:16px}.hero-actions{gap:10px;margin-top:22px}.hero-actions .btn{width:auto;min-height:46px;padding:12px 16px;letter-spacing:.14em}}

  /* ============ STATEMENT (light) — editorial pause ============ */
  .statement{position:relative}
  .statement .section-inner{display:grid;grid-template-columns:5fr 7fr;gap:clamp(40px,7vw,120px);align-items:start}
  .statement .label{font:10px var(--mono);letter-spacing:.26em;text-transform:uppercase;color:var(--quiet-l);display:flex;align-items:center;gap:14px}
  .statement .label:before{content:"";width:26px;height:1px;background:currentColor}
  .statement h2{font-size:clamp(40px,6.4vw,108px);line-height:.92;letter-spacing:-.05em;font-weight:850;text-transform:uppercase;max-width:11ch;color:var(--ink);text-wrap:balance;margin-top:22px}
  .statement h2 em{font-style:normal;color:var(--accent-2)}
  .statement .body{display:grid;gap:24px;max-width:54ch;padding-top:6px}
  .statement .body .lead{font-size:clamp(17px,1.32vw,21px);line-height:1.55;color:var(--ink);font-weight:480;letter-spacing:-.005em;text-wrap:pretty}
  .statement .body p{font-size:clamp(15px,1.05vw,16.5px);line-height:1.68;color:var(--muted-l);text-wrap:pretty}
  .statement .body .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

  /* ============ FOTOGRAFIE chapters (dark) — kuratiertes Verzeichnis ============ */
  .chapters{position:relative}
  .chapters-head{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;margin-bottom:clamp(48px,6vw,84px)}
  .chapters-head h2{font-size:clamp(50px,8.4vw,148px);line-height:.86;letter-spacing:-.075em;text-transform:uppercase;max-width:13ch;font-weight:900;text-wrap:balance}
  .chapters-head h2 em{font-style:normal;color:var(--accent-2)}
  .chapters-head .lead{color:var(--muted);max-width:38ch;text-align:right;justify-self:end;font-size:clamp(14px,1.06vw,17px);line-height:1.55}
  .chapter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,2.6vw,42px) clamp(20px,2.4vw,38px)}
  .chapter{position:relative;display:flex;flex-direction:column;gap:18px;padding:0;transition:transform .6s var(--ease)}
  .chapter:hover{transform:translateY(-4px)}
  .chapter .img{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--panel)}
  .chapter .img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease),filter 1.4s var(--ease);filter:grayscale(.15) contrast(1.03) brightness(.92)}
  .chapter:hover .img img{transform:scale(1.04);filter:grayscale(0) contrast(1.06) brightness(1)}
  .chapter .head{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
  .chapter h3{font-size:clamp(22px,2vw,30px);line-height:1.02;letter-spacing:-.035em;text-transform:uppercase;font-weight:850}
  .chapter .num{font:10px var(--mono);letter-spacing:.24em;text-transform:uppercase;color:var(--accent);opacity:1}
  .chapter .meta{display:flex;justify-content:space-between;align-items:center;gap:14px;font:10px var(--mono);letter-spacing:.18em;text-transform:uppercase;color:#dce2df}
  .chapter .meta .arr{color:var(--accent);transition:transform .35s var(--ease)}
  .chapter:hover .meta .arr{transform:translateX(8px);color:#fff}

  /* ============ PORTFOLIO TEASER (light) — Strom: dual counter-marquee ============ */
  .pf-teaser{position:relative;overflow:hidden}
  .pf-teaser .section-inner{display:grid;gap:clamp(48px,6vw,96px);padding-left:0;padding-right:0}
  .pf-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:32px;padding:0 clamp(22px,5vw,76px);max-width:var(--maxw);margin:0 auto;width:100%}
  .pf-head h2{font-size:clamp(50px,8.4vw,148px);line-height:.86;letter-spacing:-.075em;text-transform:uppercase;max-width:11ch;font-weight:900;color:var(--ink);text-wrap:balance;position:relative}
  .pf-head h2 em{font-style:normal;color:var(--accent-2)}
  .pf-head .lead{color:var(--muted-l);max-width:38ch;text-align:right;justify-self:end;font-size:clamp(14px,1.06vw,17px);line-height:1.55}

  .pf-marquee{position:relative;display:grid;gap:clamp(18px,1.8vw,28px);user-select:none}
  .pf-marquee:before,.pf-marquee:after{content:"";position:absolute;top:0;bottom:0;width:clamp(60px,12vw,180px);z-index:3;pointer-events:none}
  .pf-marquee:before{left:0;background:linear-gradient(90deg,var(--paper) 0%,rgba(243,245,239,0) 100%)}
  .pf-marquee:after{right:0;background:linear-gradient(270deg,var(--paper) 0%,rgba(243,245,239,0) 100%)}
  .pf-row{position:relative;overflow:hidden;min-height:clamp(292px,24vw,430px)}
  .pf-track{display:flex;gap:clamp(14px,1.6vw,28px);width:max-content;will-change:transform;padding:6px 0}
  .pf-row.row-1 .pf-track{animation:pfScrollA 115s linear infinite}
  .pf-row.row-2 .pf-track{animation:pfScrollB 138s linear infinite}

  @keyframes pfScrollA{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
  @keyframes pfScrollB{from{transform:translate3d(-50%,0,0)}to{transform:translate3d(0,0,0)}}

  .pf-tile{position:relative;flex:0 0 auto;background:var(--ink);overflow:hidden;cursor:zoom-in;border:0;padding:0;margin:0;transform:translateY(0);transition:transform .55s var(--ease),box-shadow .55s var(--ease)}
  .pf-tile.--w{width:clamp(280px,30vw,460px);aspect-ratio:4/3}
  .pf-tile.--t{width:clamp(210px,18vw,310px);aspect-ratio:3/4}
  .pf-tile.--s{width:clamp(230px,20vw,340px);aspect-ratio:1/1}
  .pf-tile.--ww{width:clamp(340px,38vw,580px);aspect-ratio:16/10}
  .pf-tile img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease),filter 1.4s var(--ease);filter:grayscale(.18) contrast(1.04) brightness(.96);display:block}
  .pf-tile:hover{transform:translateY(-6px);box-shadow:0 22px 60px -28px rgba(10,12,17,.42)}
  .pf-tile:hover img{transform:scale(1.05);filter:grayscale(0) contrast(1.08) brightness(1.02)}
  .pf-tile:focus-visible{outline:1px solid var(--accent-2);outline-offset:3px}

  .pf-foot{display:flex;justify-content:center;align-items:center;gap:24px;padding:34px clamp(22px,5vw,76px) 0;max-width:var(--maxw);margin:0 auto;width:100%;flex-wrap:wrap}

  /* ============ LIGHTBOX ============ */
  .lb{position:fixed;inset:0;z-index:120;display:none;background:rgba(8,10,14,.94);backdrop-filter:blur(18px);align-items:center;justify-content:center;opacity:0;transition:opacity .35s var(--ease)}
  .lb.open{display:flex;opacity:1}
  .lb-stage{position:relative;width:min(94vw,1500px);height:min(86vh,1000px);display:flex;align-items:center;justify-content:center}
  .lb-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;box-shadow:0 30px 80px -30px rgba(0,0,0,.7);opacity:0;transition:opacity .4s var(--ease)}
  .lb-img.show{opacity:1}
  .lb-close,.lb-prev,.lb-next{position:absolute;background:transparent;border:1px solid rgba(255,255,255,.22);color:#fff;font:11px var(--mono);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .3s var(--ease),border-color .3s var(--ease)}
  .lb-close{top:-52px;right:0;width:44px;height:44px;font-size:18px}
  .lb-close:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.55)}
  .lb-prev,.lb-next{top:50%;width:54px;height:54px;transform:translateY(-50%);font-size:20px;font-weight:300}
  .lb-prev{left:-78px}
  .lb-next{right:-78px}
  .lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.55)}
  .lb-counter{position:absolute;bottom:-44px;left:0;font:10px var(--mono);letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.55)}
  @media (max-width: 720px){
    .lb-stage{width:96vw;height:80vh}
    .lb-close{top:-48px;width:40px;height:40px}
    .lb-prev{left:6px;background:rgba(0,0,0,.5)}
    .lb-next{right:6px;background:rgba(0,0,0,.5)}
  }

  /* ============ ABOUT (dark) — Hinter der Kamera ============ */
  .about .section-inner{display:grid;grid-template-columns:5fr 7fr;gap:clamp(36px,6vw,100px);align-items:center}
  .about-img{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--panel)}
  .about-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.12) contrast(1.04)}
  .about-img .badge{position:absolute;left:14px;bottom:14px;font:9px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:#fff;text-shadow:0 4px 14px rgba(0,0,0,.6);background:rgba(2,3,6,.66);padding:8px 12px;backdrop-filter:blur(8px)}
  .about-copy h2{font-size:clamp(42px,6vw,108px);line-height:.92;letter-spacing:-.055em;text-transform:uppercase;max-width:12ch;font-weight:850;margin-top:22px}
  .about-copy h2 em{font-style:normal;color:var(--accent-2)}
  .about-copy .lead{margin-top:26px;color:var(--fg);max-width:50ch;font-size:clamp(17px,1.3vw,21px);line-height:1.55;font-weight:480}
  .about-copy p{margin-top:18px;color:var(--muted);max-width:52ch;font-size:clamp(14px,1.05vw,16.5px);line-height:1.65}
  .about-copy .actions{margin-top:32px;display:flex;gap:10px;flex-wrap:wrap}

  /* ============ LEISTUNGEN INDEX (light) — book-like list ============ */
  .services-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:32px;margin-bottom:clamp(40px,5vw,72px)}
  .services-head h2{font-size:clamp(50px,8.4vw,148px);line-height:.86;letter-spacing:-.075em;text-transform:uppercase;max-width:13ch;font-weight:900;color:var(--ink);text-wrap:balance}
  .services-head h2 em{font-style:normal;color:var(--accent-2)}
  .services-head .lead{color:var(--muted-l);max-width:42ch;text-align:right;justify-self:end;font-size:clamp(14px,1.06vw,17px);line-height:1.55}
  .services-list{border-top:1px solid var(--ink);border-bottom:1px solid var(--line-l)}
  .service-row{display:grid;grid-template-columns:72px minmax(220px,1fr) 2fr 100px;align-items:center;gap:clamp(16px,2vw,32px);padding:clamp(22px,2.4vw,34px) 0;border-bottom:1px solid var(--line-l);transition:transform .35s var(--ease)}
  .service-row:last-child{border-bottom:0}
  .service-row:hover{transform:translateX(18px);background:linear-gradient(90deg,rgba(10,12,17,.025),transparent 60%)}
  .service-row .num{font:10px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:#3f4c49;font-weight:700}
  .service-row h3{font-size:clamp(20px,1.8vw,30px);line-height:1.04;letter-spacing:-.035em;text-transform:uppercase;font-weight:850;color:var(--ink)}
  .service-row p{font-size:clamp(13px,1vw,15.5px);line-height:1.55;color:var(--muted-l);max-width:60ch;margin:0}
  .service-row .arr{justify-self:end;font:10px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink);opacity:.55;display:flex;align-items:center;gap:10px;transition:opacity .3s var(--ease),transform .3s var(--ease)}
  .service-row:hover .arr{opacity:1;transform:translateX(8px)}

  /* ============ BLOG (dark) — Journal ============ */
  .blog-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:32px;margin-bottom:clamp(40px,5vw,68px)}
  .blog-head h2{font-size:clamp(50px,8.4vw,148px);line-height:.86;letter-spacing:-.075em;text-transform:uppercase;max-width:13ch;font-weight:900}
  .blog-head .lead{color:var(--muted);max-width:38ch;text-align:right;justify-self:end;font-size:clamp(14px,1.06vw,17px);line-height:1.55}
  .blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,2.6vw,44px)}
  .post{display:flex;flex-direction:column;gap:14px}
  .post .pimg{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--panel)}
  .post .pimg img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),filter 1.2s var(--ease);filter:grayscale(.12) contrast(1.03)}
  .post:hover .pimg img{transform:scale(1.05);filter:grayscale(0) contrast(1.05)}
  .post .meta{font:10px var(--mono);letter-spacing:.18em;text-transform:uppercase;color:#dce2df;display:flex;gap:14px;align-items:center;margin-top:4px}
  .post h3{font-size:clamp(20px,1.8vw,28px);line-height:1.08;letter-spacing:-.03em;font-weight:800;text-wrap:balance}
  .post p{color:var(--muted);font-size:14px;line-height:1.55;text-wrap:pretty}
  .post .read{font:9px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px;margin-top:6px;transition:transform .3s var(--ease)}
  .post:hover .read{transform:translateX(8px)}

  /* ============ ANFRAGE CTA (light) ============ */
  .anfrage{position:relative}
  .anfrage .section-inner{display:grid;justify-items:center;text-align:center;gap:26px;padding-top:clamp(96px,12vw,180px);padding-bottom:clamp(96px,12vw,180px);max-width:1100px}
  .anfrage .kicker{color:var(--accent-2)}
  .anfrage h2{font-size:clamp(56px,9vw,176px);line-height:.88;letter-spacing:-.075em;text-transform:uppercase;font-weight:900;max-width:14ch;color:var(--ink);text-wrap:balance}
  .anfrage h2 em{font-style:normal;color:var(--accent-2)}
  .anfrage p{max-width:56ch;color:var(--muted-l);font-size:clamp(16px,1.18vw,20px);line-height:1.55}
  .anfrage .mail{font:11px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink);padding-bottom:3px;border-bottom:1px solid var(--ink)}
  .anfrage .mail:hover{padding-bottom:8px;letter-spacing:.26em}
  .anfrage .actions{margin-top:24px;display:flex;gap:24px;flex-wrap:wrap;justify-content:center;align-items:center}

  /* ============ MR-FOOTER (editorial, ruhig, polished) ============ */
  .mr-footer{position:relative;z-index:5;display:block;width:100%;padding:clamp(38px,4vw,60px) 5vw clamp(20px,2vw,28px);overflow:hidden;background:radial-gradient(120% 90% at 50% 100%,rgba(220,226,223,.045),transparent 58%),linear-gradient(180deg,#020306 0%,#04070c 60%,#010204 100%);color:#f3f5ef;border-top:1px solid rgba(243,245,239,.10);font-family:var(--font);isolation:isolate}
  .mr-footer *{box-sizing:border-box}
  .mr-footer a{color:inherit;text-decoration:none}
  .mr-footer__inner{position:relative;z-index:1;max-width:1540px;margin:0 auto;display:grid;gap:clamp(28px,3vw,44px)}

  /* Top zone: editorial mark + claim, kept compact */
  .mr-footer__top{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:clamp(24px,3vw,52px);align-items:center;padding-bottom:clamp(22px,2.4vw,32px);border-bottom:1px solid rgba(243,245,239,.10)}
  .mr-footer__mark{display:block;font-size:clamp(34px,4vw,62px);line-height:.92;font-weight:900;letter-spacing:-.05em;text-transform:uppercase;color:#f3f5ef;transition:opacity .3s var(--ease)}
  .mr-footer__mark span{display:inline;color:rgba(243,245,239,.58);margin-left:.2em}
  .mr-footer__mark:hover{opacity:.92}
  .mr-footer__claim{display:grid;gap:10px;max-width:54ch;justify-self:end}
  .mr-footer__claim p{margin:0;font-size:clamp(13.5px,1.05vw,16px);line-height:1.46;font-weight:520;letter-spacing:-.01em;color:rgba(243,245,239,.82);text-wrap:pretty}
  .mr-footer__claim p em{font-style:normal;color:var(--accent)}
  .mr-footer__meta{display:flex;gap:14px;flex-wrap:wrap;font:9.5px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:rgba(243,245,239,.64);margin-top:8px}
  .mr-footer__meta span{display:inline-block}

  /* Sitemap columns */
  .mr-footer__cols{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(20px,2.4vw,40px)}
  .mr-footer__col{display:grid;gap:10px;align-content:start}
  .mr-footer__col-label{font:9px var(--mono);letter-spacing:.26em;text-transform:uppercase;color:rgba(220,226,223,.72);padding-bottom:8px;border-bottom:1px solid rgba(243,245,239,.12)}
  .mr-footer__col-list{display:grid;gap:0}
  .mr-footer__col-list a{display:inline-flex;align-items:center;gap:8px;min-height:48px;font-size:clamp(12.5px,.9vw,14.5px);line-height:1.3;font-weight:540;letter-spacing:-.012em;color:rgba(243,245,239,.88);transition:transform .2s var(--ease)}
  .mr-footer__col-list a:before{content:"";display:inline-block;width:14px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .26s var(--ease);opacity:.78}
  .mr-footer__col-list a:hover{color:#fff;transform:translateX(2px)}
  .mr-footer__col-list a:hover:before{transform:scaleX(1)}

  /* Contact card inside last column */
  .mr-footer__contact{display:grid;gap:8px}
  .mr-footer__contact-line{display:grid;gap:2px}
  .mr-footer__contact-line span{font:9px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:rgba(243,245,239,.66)}
  .mr-footer__contact-line a,.mr-footer__contact-line strong{font-size:clamp(12.5px,.92vw,14.5px);line-height:1.3;font-weight:580;letter-spacing:-.01em;color:#f3f5ef}
  .mr-footer__contact-line a:hover{color:var(--accent)}

  /* Base row */
  .mr-footer__base{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;padding-top:clamp(16px,1.8vw,24px);border-top:1px solid rgba(243,245,239,.10);font:9.5px var(--mono);letter-spacing:.2em;text-transform:uppercase;color:rgba(243,245,239,.68)}
  .mr-footer__base-left{justify-self:start}
  .mr-footer__base-center{justify-self:center;display:flex;gap:18px;align-items:center}
  .mr-footer__base-center a{display:inline-flex;align-items:center;min-height:44px;padding:0 4px;color:rgba(243,245,239,.7)}
  .mr-footer__base-center a:hover{color:#fff}
  .mr-footer__base-right{justify-self:end;display:flex;gap:18px;flex-wrap:wrap}
  .mr-footer__base-right a{display:inline-flex;align-items:center;min-height:44px;padding:0 4px;color:rgba(243,245,239,.7)}
  .mr-footer__base-right a:hover{color:#fff}

  /* Decorative hairline accent over the mark */
  .mr-footer__hairline{position:absolute;left:5vw;right:5vw;top:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(220,226,223,.32) 22%,rgba(220,226,223,.12) 58%,transparent 100%)}

  /* ============ Responsive ============ */
  @media(max-width:1180px){
    .statement .section-inner{grid-template-columns:1fr;gap:36px}.statement h2{margin-top:6px}
    .chapter-grid{grid-template-columns:repeat(2,1fr);gap:36px}
    .pf-tile.--ww{width:clamp(280px,46vw,460px)}
    .pf-tile.--w{width:clamp(240px,34vw,380px)}
    .pf-tile.--t{width:clamp(180px,22vw,260px)}
    .pf-tile.--s{width:clamp(200px,24vw,280px)}
    .about .section-inner{grid-template-columns:1fr;gap:40px}
    .service-row{grid-template-columns:54px 1fr 100px}.service-row p{grid-column:2 / 3;margin-top:8px}.service-row .arr{grid-column:3 / 4}
    .blog-grid{grid-template-columns:1fr;gap:36px}.post{padding-bottom:32px;border-bottom:1px solid var(--line)}.post:last-child{padding-bottom:0;border-bottom:0}
    .mr-footer{padding:32px 5vw 22px}
    .mr-footer__top{grid-template-columns:1fr;align-items:start;gap:18px}
    .mr-footer__claim{justify-self:start;max-width:none}
    .mr-footer__cols{grid-template-columns:repeat(2,minmax(0,1fr));gap:28px 24px}
  }
  @media(max-width:780px){
    .chapters-head,.pf-head,.services-head,.blog-head{grid-template-columns:1fr;gap:14px}
    .chapters-head .lead,.pf-head .lead,.services-head .lead,.blog-head .lead{text-align:left;justify-self:start}
    .chapter-grid{grid-template-columns:1fr;gap:40px}
    .pf-tile.--ww{width:78vw}
    .pf-tile.--w{width:64vw}
    .pf-tile.--t{width:48vw}
    .pf-tile.--s{width:54vw}
    .pf-row{min-height:64vw}
    .pf-row.row-1 .pf-track{animation-duration:77s}
    .pf-row.row-2 .pf-track{animation-duration:90s}
    .pf-head h2 .num{position:static;display:block;margin-top:14px}
    .service-row{grid-template-columns:48px 1fr;align-items:start;gap:14px 16px}.service-row h3{grid-column:2 / 3;align-self:center}.service-row p{grid-column:2 / 3;margin-top:6px}.service-row .arr{grid-column:2 / 3;justify-self:start;margin-top:10px}
    .anfrage .actions{flex-direction:column;gap:18px}
    .mr-footer__cols{grid-template-columns:1fr;gap:22px}
    .mr-footer__mark{font-size:clamp(28px,8vw,42px)}
    .mr-footer__base{grid-template-columns:1fr;gap:10px;text-align:left}
    .mr-footer__base-left,.mr-footer__base-center,.mr-footer__base-right{justify-self:start}
  }
  @media(prefers-reduced-motion:reduce){body:before{animation:none}.chapter:hover{transform:none}.chapter:hover .img img{transform:none}.pf-row .pf-track{animation:none!important}.pf-tile:hover{transform:none}.pf-tile:hover img{transform:none}.post:hover .pimg img{transform:none}.mr-footer__col-list a:hover{transform:none}}
