  *,*::before,*::after{box-sizing:border-box}
  html,body{margin:0;padding:0}
  :root{
    --bg:#ecede9;
    --bg-2:#e1e2dd;
    --bg-3:#d4d5cf;
    --ink:#1a1c20;
    --ink-soft:#43474d;
    --ink-mute:#80807a;
    --line:#cdcdc6;
    --line-2:#b6b6ad;
    --accent:#2f3338;
    --accent-2:#5b5f66;
    --warm:#f4eddc;
    --warm-2:#e6dcbf;
  }
  html{scroll-behavior:smooth;scroll-padding-top:5rem}
  body{
    background:var(--bg);
    color:var(--ink);
    font-family:'Inter',system-ui,-apple-system,sans-serif;
    font-weight:400;font-size:17px;line-height:1.7;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  }
  ::selection{background:var(--accent);color:#fff}
  a{color:inherit;text-decoration:none}
  img,svg{display:block;max-width:100%;height:auto}
  .wrap{width:min(1180px,100% - 2.5rem);margin-inline:auto}

  /* brand bar */
  .bar{
    position:sticky;top:0;z-index:30;
    background:color-mix(in srgb, var(--bg) 75%, transparent);
    backdrop-filter:saturate(180%) blur(14px);
    -webkit-backdrop-filter:saturate(180%) blur(14px);
    border-bottom:1px solid color-mix(in srgb, var(--line) 65%, transparent);
  }
  @supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
    .bar{background:color-mix(in srgb, var(--bg) 96%, transparent)}
  }
  .bar-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.05rem 0}
  .brand{display:flex;align-items:center;gap:.75rem;color:var(--ink)}
  .brand svg{width:44px;height:44px;flex-shrink:0}
  .brand-name{font-family:'Spectral',serif;font-size:1.3rem;font-weight:500;letter-spacing:.005em;line-height:1}
  .brand-person{font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute);font-weight:500;white-space:nowrap}
  @media (max-width:540px){
    .brand-name{font-size:1.1rem}
    .brand-person{letter-spacing:.18em;font-size:.66rem}
  }
  @media (max-width:380px){.brand-person{display:none}}

  /* hero */
  .hero{padding:5rem 0 4rem;position:relative;overflow:hidden}
  .hero::before{
    content:"";position:absolute;inset:auto -10% -30% auto;width:55%;aspect-ratio:1/1;border-radius:50%;
    background:radial-gradient(closest-side, color-mix(in srgb,var(--warm) 75%, transparent), transparent 70%);
    z-index:0;pointer-events:none;
  }
  .hero > .wrap{position:relative;z-index:1}
  .hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:5rem;align-items:center}
  @media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:3rem}}
  .eyebrow{font-size:.74rem;letter-spacing:.36em;text-transform:uppercase;color:var(--accent-2);margin-bottom:1.5rem;font-weight:500}
  .h1{font-family:'Spectral',serif;font-weight:400;font-size:clamp(2.3rem,5.8vw,4.8rem);line-height:1.04;letter-spacing:-.014em;margin:0 0 1.4rem;color:var(--ink);overflow-wrap:break-word;hyphens:auto}
  .h1 em{font-style:italic;color:var(--accent);font-weight:400}
  .lead{font-size:1.07rem;line-height:1.72;color:var(--ink-soft);max-width:48ch;margin:0 0 2rem}
  .cta-row{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}
  .btn{
    display:inline-flex;align-items:center;gap:.55rem;
    padding:.95rem 1.55rem;border-radius:999px;
    font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
    background:var(--ink);color:#fff;border:1px solid var(--ink);
    transition:background .25s,color .25s, border-color .25s;
  }
  .btn:hover{background:transparent;color:var(--ink)}
  .btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
  .btn-ghost:hover{background:var(--ink);color:#fff}
  .btn .arr{transition:transform .25s}
  .btn:hover .arr{transform:translateX(4px)}
  @media (max-width:520px){.btn{padding:.85rem 1.2rem;font-size:.74rem;letter-spacing:.12em;width:100%;justify-content:center}}

  /* hero map (word network) */
  .map{
    position:relative;aspect-ratio:1/1;width:100%;max-width:520px;justify-self:end;
    background:
      radial-gradient(circle at 50% 50%, color-mix(in srgb,#fff 60%, transparent) 0%, transparent 70%),
      linear-gradient(180deg, color-mix(in srgb,var(--bg-2) 80%, transparent), color-mix(in srgb,var(--bg-3) 30%, transparent));
    border-radius:50%;
    border:1px solid color-mix(in srgb,var(--line) 90%,transparent);
  }
  .map svg{position:absolute;inset:0;width:100%;height:100%}
  .map .node{font-family:'Spectral',serif;font-style:italic;font-size:clamp(.78rem,1.2vw,1rem);fill:var(--ink-soft);transition:fill .35s, font-weight .35s}
  .map .node-key{font-weight:500;font-style:normal;fill:var(--ink);font-size:clamp(.88rem,1.35vw,1.12rem);letter-spacing:.005em}
  .map .edge{stroke:var(--line-2);stroke-width:.7;fill:none}
  .map .edge-key{stroke:var(--accent-2);stroke-width:1.1;stroke-dasharray:3 5}
  .map .dot{fill:var(--accent-2)}
  .map .dot-key{fill:var(--accent)}
  @media (max-width:960px){.map{justify-self:center;max-width:480px}}

  /* sections */
  section{padding:6rem 0;border-top:1px solid var(--line)}
  .sec-eyebrow{font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:var(--accent-2);margin-bottom:1.4rem;font-weight:500}
  .h2{font-family:'Spectral',serif;font-weight:400;font-size:clamp(2.1rem,4vw,3.1rem);line-height:1.12;letter-spacing:-.012em;margin:0 0 2rem;max-width:22ch}
  .h2 em{font-style:italic;color:var(--accent)}
  .h3{font-family:'Spectral',serif;font-weight:500;font-size:clamp(1.6rem,2.5vw,2.1rem);letter-spacing:-.005em;margin:0 0 1rem;line-height:1.18}
  .body p{margin:0 0 1.05rem;max-width:62ch;color:var(--ink-soft)}
  .body p:last-child{margin-bottom:0}

  /* intro */
  .intro{background:var(--bg-2)}
  /* intro grid layout fuer gitter links */
  .intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:5rem;align-items:start}
  @media (min-width:1200px){
    .intro .wrap{width:min(1340px,100% - 2.5rem)}
    .intro-grid{grid-template-columns:1.2fr .8fr;gap:6rem}
  }
  @media (min-width:1500px){
    .intro .wrap{width:min(1480px,100% - 2.5rem)}
    .intro-grid{grid-template-columns:1.25fr .75fr;gap:7rem}
  }
  @media (min-width:1800px){
    .intro .wrap{width:min(1620px,100% - 2.5rem)}
    .intro-grid{grid-template-columns:1.3fr .7fr;gap:8rem}
  }
  @media (max-width:1024px){.intro-grid{gap:3.5rem}}
  @media (max-width:900px){.intro-grid{grid-template-columns:1fr;gap:2.6rem}}
  .intro-left{min-width:0}
  .intro-text{min-width:0}
  /* gitterwoerter */
  .gitter-grid{
    display:grid;
    grid-template-columns:repeat(34,minmax(0,1fr));
    gap:0;
    width:100%;
    min-width:0;
    font-family:'Inter',sans-serif;
    container-type:inline-size;
    /* leichter Linksversatz, damit die Buchstaben-Linkskanten der
       ersten Spalte optisch auf der Container-Kante sitzen (nicht
       die Zell-Mittelpunkte) */
    margin-left:calc(-100% / 200);
  }
  .gitter-grid .cell{
    aspect-ratio:9/8;
    display:flex;align-items:center;justify-content:center;
    line-height:1;
    /* font skaliert mit der Crossword-Breite, nicht mit der Viewport-Breite.
       So bleibt das Verhaeltnis Schrift/Zelle in jedem Layout konstant. */
    font-size:clamp(9.6px,2cqi,17px);
    font-weight:600;
    letter-spacing:.02em;
    color:color-mix(in srgb, var(--ink-mute) 60%, transparent);
    user-select:none;
    transition:color .8s ease, transform .6s ease;
  }
  .gitter-grid .cell.empty{pointer-events:none}
  .gitter-grid .cell.breathing{
    color:color-mix(in srgb, var(--ink-soft) 88%, transparent);
    transition:color 1.6s ease;
  }
  .gitter-grid .cell.active{
    color:var(--ink);
    transform:scale(1.08);
    transition:color .2s ease, transform .25s ease;
  }
  .gitter-grid .cell.permanent{
    color:var(--accent);
    font-weight:700;
  }
  .gitter-grid .cell.permanent.active{
    color:var(--accent);
    transform:none;
  }
  /* im 1-spaltigen Layout das Crossword auf eine Desktop-aehnliche
     Breite begrenzen, damit Zellen und Buchstaben nicht riesig werden */
  @media (max-width:900px){
    .gitter-grid{max-width:620px}
  }
  @media (prefers-reduced-motion: reduce){
    .gitter-grid .cell{transition:color .25s ease}
    .gitter-grid .cell.breathing{transition:color .35s ease}
  }
  .pull{font-family:'Spectral',serif;font-style:italic;font-size:clamp(1.55rem,2.7vw,2.15rem);line-height:1.32;color:var(--ink);max-width:24ch;margin:0}

  /* leistung: volle Sektionen */
  .leistung{padding:6rem 0;border-top:1px solid var(--line)}
  .leistung--alt{background:var(--bg-2)}
  .leistung-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:4.5rem;align-items:start}
  @media (max-width:900px){.leistung-grid{grid-template-columns:1fr;gap:1.8rem}}
  .leistung-meta{position:sticky;top:6rem;align-self:start}
  @media (max-width:900px){.leistung-meta{position:static;top:auto}}
  .leistung-title{font-family:'Spectral',serif;font-weight:400;font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1.1;letter-spacing:-.012em;margin:0 0 .8rem;color:var(--ink)}
  .leistung-sub{font-family:'Spectral',serif;font-style:italic;font-size:1.05rem;color:var(--ink-soft);margin:0;max-width:24ch}
  .leistung-body p{color:var(--ink-soft);max-width:64ch}
  .leistung-list{margin:1.6rem 0 0;padding:0;list-style:none;display:grid;grid-template-columns:1fr;gap:0}
  .leistung-list li{padding:.85rem 0;border-top:1px solid var(--line);color:var(--ink-soft);display:grid;grid-template-columns:minmax(9rem,11rem) 1fr;gap:1.4rem;font-size:.97rem;align-items:baseline}
  .leistung-list li:last-child{border-bottom:1px solid var(--line)}
  .leistung-list .k{font-family:'Spectral',serif;font-style:italic;font-weight:500;font-size:1.06rem;color:var(--ink)}
  @media (max-width:680px){
    .leistung-list li{grid-template-columns:1fr;gap:.2rem}
    .leistung-list .k{font-size:1rem}
  }

  /* person */
  .person{background:var(--bg)}
  .person-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:4.5rem;align-items:start}
  @media (max-width:820px){.person-grid{grid-template-columns:1fr;gap:2.4rem}}
  .person-photo{aspect-ratio:4/5;background:var(--bg-3);overflow:hidden;position:relative;border-radius:4px}
  .person-photo img{width:100%;height:100%;object-fit:cover}

  /* contact */
  .contact{background:var(--ink);color:#fff}
  .contact .sec-eyebrow{color:#cfcfc9}
  .contact .h2{color:#fff}
  .contact .h2 em{color:#fff}
  .contact .body p{color:inherit}
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
  @media (max-width:820px){.contact-grid{grid-template-columns:1fr;gap:2rem}}
  .contact .btn{background:#fff;color:var(--ink);border-color:#fff}
  .contact .btn:hover{background:transparent;color:#fff}
  .contact .btn-ghost{background:transparent;color:#fff;border-color:color-mix(in srgb,#fff 60%, transparent)}
  .contact .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
  .contact-card{margin-top:.2rem;border-top:1px solid color-mix(in srgb,#fff 20%, transparent)}
  .contact-card a{display:block;padding:1.1rem 0;border-bottom:1px solid color-mix(in srgb,#fff 20%, transparent);color:#fff;transition:padding .25s}
  .contact-card a:hover{padding-left:.5rem}
  .contact-card .lbl{display:block;font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:color-mix(in srgb,#fff 60%, transparent);margin-bottom:.18rem}
  .contact-card .val{font-family:'Spectral',serif;font-size:1.35rem}
  .kontakt-sub{display:block;font-family:inherit;font-style:italic;font-weight:400;font-size:.58em;line-height:1.35;letter-spacing:0;margin-top:.6em}
  .kontakt-info{margin-top:2.4rem;display:grid;grid-template-columns:1fr 1fr;gap:1.6rem 2.6rem}
  @media (max-width:680px){.kontakt-info{grid-template-columns:1fr;gap:1.4rem}}
  .kontakt-info .info-block h4{font-family:inherit;font-weight:500;font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;margin:0 0 .6rem;opacity:.55}
  .kontakt-info .info-block p{margin:0;font-size:.92rem;line-height:1.6;max-width:none}
  .kontakt-info .info-block ul{margin:0;padding:0;list-style:none}
  .kontakt-info .info-block li{padding:.22rem 0;font-size:.92rem;line-height:1.55}
  .kontakt-info .info-block li strong{font-weight:600}

  /* footer */
  footer{padding:2.4rem 0 3rem;color:var(--ink-mute);font-size:.82rem;background:var(--bg)}
  .foot-row{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
  /* hero (slogan) */
  .hero-stage{position:relative;overflow:hidden;padding:6.5rem 0 5.5rem;isolation:isolate}
.hero-stage > .wrap{position:relative;z-index:2}
  .slogan-eyebrow{font-size:.74rem;letter-spacing:.36em;text-transform:uppercase;color:var(--accent-2);margin-bottom:2.4rem;font-weight:500;display:flex;flex-wrap:wrap;gap:.5em;align-items:center}
  .slogan-eyebrow span{white-space:nowrap}
  @media (max-width:600px){
    .slogan-eyebrow{flex-direction:column;align-items:flex-start;flex-wrap:nowrap;gap:.55rem;font-size:.68rem;letter-spacing:.24em;margin-bottom:1.8rem}
    .slogan-eyebrow .sep{display:none}
  }
  .slogan{
    font-family:'Spectral',serif;font-weight:400;
    font-size:clamp(2.8rem,9.2vw,7.2rem);
    line-height:1.02;letter-spacing:-.018em;
    margin:0 0 1.6rem;color:var(--ink);
    max-width:13ch;hyphens:none;overflow-wrap:normal;
  }
  .slogan .k{
    font-style:italic;font-weight:400;
    color:color-mix(in srgb,var(--ink-mute) 90%,transparent);
  }
  .slogan-sub{
    font-family:'Spectral',serif;font-style:italic;
    font-size:clamp(1.15rem,1.7vw,1.5rem);
    line-height:1.5;color:var(--ink-soft);
    max-width:54ch;margin:0 0 2.6rem;
    text-wrap:balance;
  }
  @media (max-width:720px){
    .hero-stage{padding:4.2rem 0 3.6rem}
    .slogan{font-size:clamp(2.4rem,13vw,3.6rem);max-width:none}
  }
  /* intro lead */
  .intro-lead{
    font-family:'Spectral',serif;font-weight:400;
    font-size:clamp(1.85rem,3.2vw,2.6rem);
    line-height:1.14;letter-spacing:-.012em;
    color:var(--ink);margin:0;max-width:20ch;
  }
  .intro-lead em{font-style:italic;color:var(--accent)}

  /* impressum & datenschutz im footer */
  .legal{margin-top:1.6rem;border-top:1px solid color-mix(in srgb,var(--line) 50%,transparent);padding-top:1.2rem}
  .legal summary{cursor:pointer;display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--ink-mute);list-style:none;padding:.3rem 0;transition:color .2s}
  .legal summary::-webkit-details-marker{display:none}
  .legal summary::after{content:"+";display:inline-block;font-size:1rem;line-height:1;transition:transform .25s ease}
  .legal[open] summary::after{transform:rotate(45deg)}
  .legal summary:hover{color:var(--ink-soft)}
  .legal-content{font-size:.85rem;color:var(--ink-mute);max-width:68ch;line-height:1.65;margin-top:1.2rem}
  .legal-content h3{font-family:'Spectral',serif;font-weight:500;font-size:1.05rem;color:var(--ink-soft);margin:1.8rem 0 .55rem;letter-spacing:-.005em}
  .legal-content h3:first-child{margin-top:0}
  .legal-content p{margin:.55rem 0}
  .legal-content strong{color:var(--ink-soft);font-weight:500}
  .legal-content a{color:var(--ink-soft);text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--line-2) 80%,transparent);text-underline-offset:2px}
  .legal-content a:hover{text-decoration-color:var(--ink-soft)}
