
  *{box-sizing:border-box;}
  html{-webkit-text-size-adjust:100%;}
  @media (prefers-reduced-motion: no-preference){ html{scroll-behavior:smooth;} }
  body{ margin:0; background:var(--paper); color:var(--ink); font-family:var(--ff-body);
    font-size:1.0625rem; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden; }
  img{max-width:100%; display:block;}
  a{color:inherit;}
  button{font:inherit; cursor:pointer;}
  h1,h2,h3,h4,p{margin:0;}

  :root{
    --paper:#F8F7F3; --surface:#FFFFFF; --ink:#191917; --ink-soft:#3B3B37; --muted:#5E5E55;
    --hairline:#E7E4DB; --hairline-strong:#D9D5CA;
    --accent:#172844; --accent-dark:#27406A; --accent-tint:#E8EBF2; --cream:#F3EFE1; --navy:#172844;
    --sand:#F1EEE5; --sand-line:#E6E1D4; --gold:#A07E4F;
    --max:1180px; --pad:clamp(1.25rem, 4vw, 2.75rem);
    --radius-sm:10px; --radius:16px; --radius-lg:22px;
    --shadow-sm:0 1px 2px rgba(25,25,23,.04), 0 2px 8px rgba(25,25,23,.04);
    --shadow-md:0 8px 24px rgba(25,25,23,.07), 0 2px 6px rgba(25,25,23,.05);
    --ff-display:"Bricolage Grotesque", system-ui, sans-serif;
    --ff-brand:"Cormorant Garamond", Georgia, serif;
    --ff-body:"Inter", system-ui, sans-serif;
    --ff-mono:"JetBrains Mono", ui-monospace, monospace;
    --logo:url("data:image/png;base64,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");
  }

  .wrap{ max-width:var(--max); margin-inline:auto; padding-inline:var(--pad); }
  .section{ padding-block:clamp(4.5rem, 9vw, 8rem); scroll-margin-top:clamp(80px, 12vw, 96px); }
  .section--tight{ padding-block:clamp(3rem, 6vw, 5rem); }
  .section--sand{ background:var(--sand); }
  .rule{ border:0; border-top:1px solid var(--hairline); }
  .narrow{ max-width:760px; }

  .eyebrow{ font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
    color:var(--muted); display:inline-flex; align-items:center; gap:.65rem; }
  .eyebrow::before{ content:""; width:1.6rem; height:1px; background:var(--gold); display:inline-block; flex:none; }
  .display{ font-family:var(--ff-display); font-weight:700; letter-spacing:-.02em; line-height:1.02; }
  h2.display{ font-size:clamp(1.95rem, 3.6vw, 2.9rem); font-weight:600; line-height:1.06; }
  h3{ font-family:var(--ff-display); font-weight:600; font-size:1.2rem; letter-spacing:-.01em; }
  .lead{ font-size:clamp(1.05rem, 1.6vw, 1.22rem); color:var(--ink-soft); }
  .muted{ color:var(--muted); }
  .accent-link{ color:var(--accent); text-decoration:none; font-weight:500; display:inline-flex; align-items:center; gap:.4rem; position:relative; border-bottom:1px solid var(--accent-tint); padding-bottom:.1rem; }
  .accent-link::after{ content:""; position:absolute; left:0; bottom:-1px; width:100%; height:1px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .28s cubic-bezier(.2,.7,.2,1); }
  .accent-link:hover::after{ transform:scaleX(1); }
  .accent-link .arr{ transition:transform .18s ease; }
  .accent-link:hover .arr{ transform:translateX(3px); }

  .btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; padding:.78rem 1.35rem;
    border-radius:999px; font-weight:500; font-size:.97rem; text-decoration:none; border:1px solid transparent;
    transition:transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease; }
  .btn--primary{ background:var(--accent); color:#fff; }
  .btn--primary:hover{ background:var(--accent-dark); transform:translateY(-1px); }
  .btn--ghost{ background:transparent; color:var(--ink); border-color:var(--hairline-strong); }
  .btn--ghost:hover{ border-color:var(--ink); transform:translateY(-1px); }
  .btn .arr{ transition:transform .18s ease; }
  .btn:hover .arr{ transform:translateX(3px); }
  :where(a,button,input,textarea):focus-visible{ outline:2.5px solid var(--accent); outline-offset:3px; border-radius:6px; }

  /* Header */
  .site-header{ position:sticky; top:0; z-index:50; background:rgba(248,247,243,.85);
    background:color-mix(in srgb, var(--paper) 80%, transparent);
    backdrop-filter:saturate(140%) blur(10px); -webkit-backdrop-filter:saturate(140%) blur(10px);
    border-bottom:1px solid transparent; transition:border-color .25s ease, background .25s ease; }
  .site-header.is-scrolled{ border-bottom-color:var(--hairline); }
  .nav{ display:flex; align-items:center; justify-content:space-between; height:68px; }
  .brand{ display:inline-flex; align-items:center; gap:.65rem; text-decoration:none; }
  .logo-mark{ width:40px; height:40px; border-radius:9px; flex:none; transition:transform .25s cubic-bezier(.2,.7,.2,1);
    background:var(--logo) center/cover no-repeat, var(--navy); box-shadow:0 1px 4px rgba(23,40,68,.28); }
  .brand:hover .logo-mark{ transform:scale(1.05); }
  .brand-word{ font-family:var(--ff-brand); font-weight:600; font-size:1.45rem; letter-spacing:.12em;
    text-transform:uppercase; line-height:1; color:var(--ink); white-space:nowrap; }
  .brand-word .suffix{ font-size:.62em; letter-spacing:.16em; color:var(--muted); margin-left:.5em; }
  .nav-links{ display:flex; align-items:center; gap:.4rem; }
  .nav-links a:not(.btn){ position:relative; text-decoration:none; color:var(--ink-soft); font-size:.95rem;
    padding:.5rem .7rem; border-radius:8px; transition:color .15s ease, background .15s ease; }
  .nav-links a:not(.btn):hover{ color:var(--ink); background:rgba(25,25,23,.04); }
  .nav-links a.is-active{ color:var(--ink); }
  .nav-links a.is-active::after{ content:""; position:absolute; left:.7rem; right:.7rem; bottom:.3rem; height:1.5px; background:var(--gold); border-radius:1px; }
  .nav-cta{ margin-left:.5rem; }
  .nav-toggle{ display:none; align-items:center; justify-content:center; width:42px; height:42px; border-radius:10px;
    background:transparent; border:1px solid var(--hairline-strong); }
  .nav-toggle span{ position:relative; width:18px; height:1.5px; background:var(--ink); transition:.2s ease; }
  .nav-toggle span::before,.nav-toggle span::after{ content:""; position:absolute; left:0; width:18px; height:1.5px; background:var(--ink); transition:.2s ease; }
  .nav-toggle span::before{ top:-6px; } .nav-toggle span::after{ top:6px; }
  .nav-toggle[aria-expanded="true"] span{ background:transparent; }
  .nav-toggle[aria-expanded="true"] span::before{ top:0; transform:rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span::after{ top:0; transform:rotate(-45deg); }

  /* Hero */
  .hero{ position:relative; padding-top:clamp(3.5rem,7vw,6rem); padding-bottom:clamp(3.5rem,8vw,7rem); overflow:hidden; }
  .hero-grid{ position:absolute; inset:0; pointer-events:none; z-index:0;
    background-image:linear-gradient(to right, var(--hairline) 1px, transparent 1px);
    background-size:calc(100% / 6) 100%; opacity:.55;
    -webkit-mask-image:radial-gradient(120% 90% at 75% 10%, #000 0%, transparent 72%);
            mask-image:radial-gradient(120% 90% at 75% 10%, #000 0%, transparent 72%); }
  .tick{ position:absolute; width:14px; height:14px; z-index:1; pointer-events:none; opacity:.8; }
  .tick::before,.tick::after{ content:""; position:absolute; background:var(--hairline-strong); }
  .tick::before{ left:50%; top:0; width:1px; height:100%; transform:translateX(-.5px); }
  .tick::after{ top:50%; left:0; height:1px; width:100%; transform:translateY(-.5px); }
  .tick--accent::before,.tick--accent::after{ background:var(--accent); }
  .t1{ top:22%; left:33.2%; } .t2{ top:64%; left:66.4%; } .t3{ top:40%; left:83.1%; }
  .hero-inner{ position:relative; z-index:2; max-width:50rem; }
  .locchip{ display:inline-flex; align-items:center; gap:.55rem; font-family:var(--ff-mono); font-size:.72rem;
    letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); background:var(--surface);
    border:1px solid var(--hairline); padding:.45rem .85rem; border-radius:8px; box-shadow:var(--shadow-sm); }
  .locchip::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--gold); flex:none; }
  .hero h1{ font-size:clamp(2.6rem, 6.4vw, 4.7rem); margin-top:1.5rem; }
  .hero h1 .hl{ color:var(--accent); position:relative; }
  .hero h1 .hl::after{ content:""; position:absolute; left:0; right:0; bottom:.04em; height:.085em; background:var(--gold); border-radius:2px; transform:scaleX(0); transform-origin:left; }
  .hero .lead{ margin-top:1.5rem; max-width:34rem; }
  .hero-actions{ margin-top:2.25rem; display:flex; flex-wrap:wrap; gap:.85rem; }
  .hero-meta{ margin-top:3.25rem; display:flex; flex-wrap:wrap; gap:1.75rem 2.5rem; font-size:.92rem; color:var(--muted); }
  .hero-meta b{ color:var(--ink); font-weight:600; font-family:var(--ff-display); }

  /* Page hero (subpages) */
  .page-hero{ padding-top:clamp(3rem,6vw,5rem); padding-bottom:clamp(2.5rem,5vw,4rem); }
  .page-hero h1{ font-size:clamp(2.3rem,5.2vw,3.6rem); margin-top:1.1rem; }
  .page-hero .lead{ margin-top:1.25rem; max-width:42rem; }

  /* Section head */
  .sec-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:1.25rem; margin-bottom:2.75rem; }
  .sec-head .copy{ max-width:38rem; } .sec-head h2{ margin-top:.85rem; } .sec-head p{ margin-top:.9rem; }

  /* Services */
  .services{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--hairline);
    border:1px solid var(--hairline); border-radius:var(--radius); overflow:hidden; }
  .service{ background:var(--surface); padding:clamp(1.5rem,3vw,2.25rem); display:flex; flex-direction:column; gap:.7rem; }
  .service{ transition:background .25s ease; }
  .service:hover{ background:var(--sand); }
  .service h3{ font-size:1.3rem; transition:color .2s ease; } .service:hover h3{ color:var(--accent); } .service p{ color:var(--muted); font-size:.98rem; }

  /* Work / examples */
  .work-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
  .work-card{ background:var(--surface); border:1px solid var(--hairline); border-radius:var(--radius); overflow:hidden;
    text-decoration:none; color:inherit; display:flex; flex-direction:column; position:relative;
    transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
  .work-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--gold);
    transform:scaleX(0); transform-origin:left; transition:transform .25s ease; z-index:3; }
  .work-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--hairline-strong); }
  .work-card:hover::before{ transform:scaleX(1); }
  .preview{ aspect-ratio:16/10; background:var(--paper); border-bottom:1px solid var(--hairline); padding:14px;
    display:flex; flex-direction:column; gap:8px; }
  .pv-bar{ height:8px; border-radius:4px; background:var(--hairline-strong); }
  .pv-row{ display:flex; gap:8px; }
  .pv-block{ border-radius:6px; background:#fff; border:1px solid var(--hairline); flex:1; }
  .pv-accent{ background:var(--accent); border-color:var(--accent); }
  .pv-gold{ background:var(--gold); border-color:var(--gold); }
  .pv-tint{ background:var(--accent-tint); border-color:var(--accent-tint); }
  .pv-sand{ background:var(--sand); border-color:var(--sand-line); }
  .pv-text{ height:6px; border-radius:3px; background:var(--hairline); }
  .work-body{ padding:1.1rem 1.2rem 1.3rem; }
  .work-body .meta{ display:flex; justify-content:space-between; align-items:center; gap:.5rem; }
  .work-body .tag{ font-family:var(--ff-mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
  .work-body .yr{ font-family:var(--ff-mono); font-size:.68rem; color:var(--muted); }
  .work-body h3{ margin-top:.5rem; font-size:1.18rem; } .work-body p{ margin-top:.4rem; font-size:.93rem; color:var(--muted); }
  .work-note{ margin-top:1.5rem; font-size:.85rem; color:var(--muted); font-family:var(--ff-mono); letter-spacing:.02em; }

  /* Realistische Mini-Startseiten in den Vorschau-Fenstern (eigene Marken je Beispiel) */
  .site-preview{ padding:0; gap:0; background:#fff; overflow:hidden; container-type:size; }
  .bp-bar{ flex:none; display:flex; align-items:center; gap:1.1cqw; padding:1.5cqw 2.2cqw; background:#ECEAE3; border-bottom:1px solid #D9D5CC; }
  .bp-bar .d{ width:1.5cqw; height:1.5cqw; border-radius:50%; background:#C9C5BA; flex:none; }
  .bp-url{ margin-left:1.4cqw; flex:1; min-width:0; font-family:ui-monospace,"SF Mono",Menlo,monospace; font-size:1.45cqw; color:#8A867D;
    background:#fff; border:1px solid #DED9D0; border-radius:1.2cqw; padding:0.7cqw 1.8cqw; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .bp-page{ flex:1; min-height:0; display:flex; flex-direction:column; background:#fff; overflow:hidden; }
  .bp-page.bar .bp-head{ border-top:2.5px solid var(--mp-accent); }
  .bp-head{ flex:none; display:flex; align-items:center; gap:1.4cqw; padding:1.8cqw 2.6cqw; border-bottom:1px solid var(--mp-line); }
  .bp-logo{ width:2.8cqw; height:2.8cqw; border-radius:0.7cqw; flex:none; background:var(--mp-accent); }
  .bp-name{ font-family:var(--mp-fhead); font-weight:700; font-size:1.85cqw; letter-spacing:.06em; color:var(--mp-ink); }
  .bp-nav{ margin-left:auto; display:flex; gap:1.8cqw; }
  .bp-nav span{ font-family:var(--mp-fbody); font-size:1.2cqw; letter-spacing:.04em; color:var(--mp-muted); }
  .bp-hero{ flex:1; min-height:0; display:flex; gap:2.4cqw; padding:2.4cqw 2.6cqw; background:var(--mp-band); }
  .bp-htext{ min-width:0; display:flex; flex-direction:column; justify-content:center; gap:1.2cqw; }
  .bp-hero.r{ flex-direction:row; align-items:stretch; }
  .bp-hero.r .bp-htext{ flex:1.05; } .bp-hero.r .bp-art{ flex:.9; align-self:stretch; }
  .bp-hero.l{ flex-direction:row-reverse; align-items:stretch; }
  .bp-hero.l .bp-htext{ flex:1.05; } .bp-hero.l .bp-art{ flex:.9; align-self:stretch; }
  .bp-hero.center{ flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:1cqw; }
  .bp-hero.center .bp-art{ order:-1; flex:none; height:16cqh; aspect-ratio:1.2/1; }
  .bp-hero.center .bp-h{ font-size:2.5cqw; }
  .bp-hero.center .bp-htext{ align-items:center; gap:0.8cqw; }
  .bp-hero.center .bp-btn{ align-self:center; margin-top:0.3cqw; }
  .bp-hero.bottom{ flex-direction:column; align-items:stretch; gap:1.6cqw; }
  .bp-hero.bottom .bp-htext{ flex:none; } .bp-hero.bottom .bp-art{ flex:1; min-height:0; }
  .bp-eyebrow{ font-family:var(--mp-fbody); font-size:1.2cqw; letter-spacing:.14em; text-transform:uppercase; color:var(--mp-accent); font-weight:600; }
  .bp-h{ font-family:var(--mp-fhead); font-weight:700; font-size:2.9cqw; line-height:1.08; letter-spacing:-.005em; color:var(--mp-ink); }
  .bp-page.ed .bp-h{ text-transform:uppercase; letter-spacing:.04em; }
  .bp-sub{ font-family:var(--mp-fbody); font-size:1.5cqw; line-height:1.45; color:var(--mp-muted); }
  .bp-btn{ align-self:flex-start; font-family:var(--mp-fbody); font-size:1.45cqw; font-weight:600; color:var(--mp-btnfg); background:var(--mp-btnbg); padding:1.1cqw 2.4cqw; border-radius:var(--mp-rbtn); margin-top:0.5cqw; }
  .bp-search{ display:flex; align-items:center; gap:1cqw; margin-top:0.4cqw; }
  .bp-search .f{ flex:1; min-width:0; font-family:var(--mp-fbody); font-size:1.35cqw; color:var(--mp-muted); background:#fff;
    border:1px solid var(--mp-line); border-radius:var(--mp-rbtn); padding:1.05cqw 2cqw; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .bp-search .s{ flex:none; font-family:var(--mp-fbody); font-size:1.35cqw; font-weight:600; color:var(--mp-btnfg); background:var(--mp-btnbg); border-radius:var(--mp-rbtn); padding:1.05cqw 2cqw; }
  .bp-art{ display:flex; align-items:center; justify-content:center; }
  .bp-art svg{ width:100%; height:100%; display:block; }
  .bp-art .abg{ fill:var(--mp-artbg); }
  .bp-art .fa1{ fill:var(--mp-art1); } .bp-art .fa2{ fill:var(--mp-art2); }
  .bp-art .sa1{ stroke:var(--mp-art1); } .bp-art .sa2{ stroke:var(--mp-art2); } .bp-art .smut{ stroke:var(--mp-amut); }
  .bp-art .pg{ fill:#fff; stroke:var(--mp-art1); } .bp-art .fwin{ fill:var(--mp-artbg); }
  .bp-strip{ flex:none; display:flex; gap:1.6cqw; padding:0 2.6cqw 2.4cqw; background:var(--mp-band); }
  .bp-tile{ flex:1; min-width:0; border:1px solid var(--mp-line); border-radius:var(--mp-rtile); padding:1.5cqw 1.7cqw; display:flex; flex-direction:column; gap:0.7cqw; background:#fff; }
  .bp-tile .tt{ font-family:var(--mp-fhead); font-weight:700; font-size:1.5cqw; color:var(--mp-ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .bp-tile .pr{ font-family:var(--mp-fbody); font-size:1.2cqw; letter-spacing:.01em; color:var(--mp-accent); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  /* Laufband: Beispiele laufen kontinuierlich von rechts nach links */
  .marquee{ --card-w:400px; --gap:1.5rem; position:relative; width:100vw; margin-left:calc(50% - 50vw); overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
            mask-image:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent); }
  .marquee-track{ display:flex; gap:var(--gap); width:max-content; padding-block:.5rem; will-change:transform; animation:marquee 44s linear infinite; }
  .marquee:hover .marquee-track{ animation-play-state:paused; }
  .marquee .work-card{ flex:none; width:var(--card-w); }
  @keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(calc((var(--card-w) + var(--gap)) * -4)); } }
  @media (max-width:480px){ .marquee{ --card-w:300px; } }
  @media (prefers-reduced-motion: reduce){
    .marquee{ overflow-x:auto; }
    .marquee-track{ animation:none; }
    .marquee-track .dupe{ display:none; }
  }

  /* Process */
  .process{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
  .step{ position:relative; padding-top:1.5rem; }
  .step::before{ content:""; position:absolute; top:0; left:0; height:2px; width:100%; background:var(--ink); transform-origin:left; }
  .js .step.reveal::before{ transform:scaleX(0); transition:transform .7s cubic-bezier(.2,.7,.2,1) .12s; }
  .js .step.reveal.is-visible::before{ transform:scaleX(1); }
  .step .num{ font-family:var(--ff-display); font-weight:700; font-size:1.05rem; color:var(--accent); }
  .step h3{ margin-top:.75rem; font-size:1.18rem; } .step p{ margin-top:.55rem; color:var(--muted); font-size:.95rem; }

  /* Studio / principles */
  .studio{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
  .principles{ display:flex; flex-direction:column; gap:1.4rem; }
  .principle{ display:flex; gap:1rem; padding-bottom:1.4rem; border-bottom:1px solid var(--hairline); }
  .principle:last-child{ border-bottom:0; padding-bottom:0; }
  .principle .pno{ font-family:var(--ff-mono); font-size:.78rem; color:var(--gold); padding-top:.2rem; }
  .principle h3{ font-size:1.1rem; } .principle p{ margin-top:.3rem; color:var(--muted); font-size:.95rem; }
  .studio .lead{ margin-top:1.1rem; } .studio .body-copy{ margin-top:1.1rem; color:var(--muted); }

  /* Team */
  .team{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.25rem; margin-top:2.5rem; }
  .member{ display:flex; align-items:center; gap:1rem; background:var(--surface); border:1px solid var(--hairline);
    border-radius:var(--radius); padding:1.1rem 1.25rem; }
  .member .ini{ width:48px; height:48px; flex:none; border-radius:12px; background:var(--navy); color:var(--cream);
    display:flex; align-items:center; justify-content:center; font-family:var(--ff-brand); font-weight:600; font-size:1.15rem; letter-spacing:.04em; }
  .member h3{ font-size:1.08rem; }
  .member .role{ font-size:.82rem; color:var(--muted); font-family:var(--ff-mono); letter-spacing:.04em; margin-top:.2rem; }

  /* Leistungen detail */
  .lstack{ display:flex; flex-direction:column; }
  .leistung{ display:grid; grid-template-columns:1fr 1.4fr; gap:clamp(1.5rem,4vw,3.5rem); padding:clamp(2rem,4vw,3rem) 0; border-top:1px solid var(--hairline); align-items:start; }
  .leistung:first-child{ border-top:0; padding-top:0; }
  .leistung h2{ font-family:var(--ff-display); font-weight:600; font-size:clamp(1.5rem,2.6vw,2.05rem); letter-spacing:-.01em; }
  .leistung .kept{ margin-top:1rem; color:var(--muted); }
  .feat{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.7rem; }
  .feat li{ position:relative; padding-left:1.5rem; color:var(--ink-soft); font-size:.98rem; }
  .feat li::before{ content:""; position:absolute; left:0; top:.55em; width:8px; height:8px; border-radius:2px; background:var(--gold); }

  /* Pricing */
  .pricing{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
  .price-card{ background:var(--surface); border:1px solid var(--hairline); border-radius:var(--radius);
    padding:clamp(1.6rem,3vw,2.2rem); display:flex; flex-direction:column; gap:.9rem; transition:box-shadow .2s ease, transform .2s ease, border-color .2s ease; }
  .price-card:hover{ box-shadow:var(--shadow-md); transform:translateY(-3px); border-color:var(--hairline-strong); }
  .price-card h3{ font-size:1.3rem; }
  .price-card .desc{ color:var(--muted); font-size:.97rem; flex:1; }
  .price-tag{ display:flex; align-items:baseline; gap:.5rem; padding-top:.6rem; border-top:1px solid var(--hairline); }
  .price-tag .amount{ font-family:var(--ff-display); font-weight:700; font-size:1.4rem; color:var(--ink); }
  .price-tag .unit{ font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color:var(--gold); }
  .price-card .btn{ align-self:flex-start; margin-top:.4rem; }
  .price-note{ margin-top:2rem; padding:1.25rem 1.4rem; background:var(--accent-tint); border-radius:var(--radius);
    color:var(--accent); font-size:.97rem; }

  /* FAQ */
  .faq{ border-top:1px solid var(--hairline); }
  .faq details{ border-bottom:1px solid var(--hairline); }
  .faq summary{ list-style:none; cursor:pointer; padding:1.4rem 2.5rem 1.4rem 0; position:relative;
    font-family:var(--ff-display); font-weight:600; font-size:1.12rem; letter-spacing:-.01em; color:var(--ink); }
  .faq summary::-webkit-details-marker{ display:none; }
  .faq summary::after{ content:""; position:absolute; right:.3rem; top:1.7rem; width:13px; height:13px;
    background:
      linear-gradient(var(--gold),var(--gold)) center/13px 1.5px no-repeat,
      linear-gradient(var(--gold),var(--gold)) center/1.5px 13px no-repeat;
    transition:transform .2s ease; }
  .faq details[open] summary::after{ transform:rotate(45deg); }
  .faq .answer{ padding:0 2.5rem 1.5rem 0; color:var(--muted); font-size:1rem; max-width:60ch; }
  .faq .answer p + p{ margin-top:.8rem; }

  /* Legal pages */
  .legal{ max-width:760px; }
  .legal h2{ font-family:var(--ff-display); font-weight:600; font-size:1.3rem; letter-spacing:-.01em; margin-top:2.5rem; margin-bottom:.6rem; }
  .legal h2:first-of-type{ margin-top:0; }
  .legal p{ color:var(--ink-soft); margin-bottom:.6rem; }
  .legal .ph{ color:var(--gold); font-family:var(--ff-mono); font-size:.92rem; }
  .legal .notice{ background:var(--sand); border:1px solid var(--sand-line); border-radius:var(--radius); padding:1.1rem 1.3rem; color:var(--ink-soft); font-size:.95rem; margin-bottom:2rem; }

  /* CTA band */
  .cta-band{ background:var(--sand); }
  .cta-inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1.5rem; }
  .cta-inner h2{ font-family:var(--ff-display); font-weight:600; font-size:clamp(1.6rem,3vw,2.3rem); letter-spacing:-.01em; max-width:24ch; }

  /* Contact */
  .contact{ background:var(--navy); color:#EAE8DC; border-radius:var(--radius-lg); padding:clamp(2rem,5vw,4rem); }
  .contact-inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
  .contact h2{ color:#fff; } .contact .eyebrow{ color:#A7A79C; } .contact .lead{ color:#C9C8C0; margin-top:1.1rem; }
  .contact-direct{ margin-top:2rem; display:flex; flex-direction:column; gap:.85rem; }
  .contact-direct a{ color:#fff; text-decoration:none; font-family:var(--ff-display); font-weight:600; font-size:1.18rem;
    letter-spacing:-.01em; border-bottom:1px solid rgba(255,255,255,.25); padding-bottom:.15rem; width:fit-content; transition:border-color .15s ease; }
  .contact-direct a:hover{ border-color:#fff; }
  .contact-direct .lbl{ font-family:var(--ff-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:#8E8E84; border:0; padding:0; }
  .form{ display:flex; flex-direction:column; gap:1.1rem; }
  .field{ display:flex; flex-direction:column; gap:.4rem; }
  .field label{ font-size:.82rem; color:#B6B5AC; font-family:var(--ff-mono); letter-spacing:.06em; text-transform:uppercase; }
  .field input,.field textarea,.field select{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16); color:#fff;
    border-radius:12px; padding:.8rem .95rem; font:inherit; font-size:.98rem; transition:border-color .15s ease, background-color .15s ease; }
  .field input::placeholder,.field textarea::placeholder{ color:#7E7E74; }
  .field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:rgba(243,239,225,.75); background-color:rgba(255,255,255,.1); }
  .field select{ appearance:none; -webkit-appearance:none; cursor:pointer; padding-right:2.4rem;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%23B6B5AC' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right .95rem center; background-size:.72rem; }
  .field select:invalid{ color:#7E7E74; }
  .field select option{ color:#191917; background:#fff; }
  .contact .btn--primary{ background:var(--cream); color:var(--navy); }
  .contact .btn--primary:hover{ background:#fff; }
  .contact :where(a,button,input,textarea):focus-visible{ outline-color:var(--cream); }
  .field textarea{ resize:vertical; min-height:120px; }
  .form .btn--primary{ align-self:flex-start; }
  .form-status{ font-size:.95rem; color:#9FE6B4; min-height:1.2em; }

  /* Footer */
  .site-footer{ padding-block:3.5rem 2.5rem; }
  .footer-top{ display:flex; flex-wrap:wrap; gap:2rem; justify-content:space-between; }
  .footer-brand{ max-width:22rem; } .footer-brand p{ margin-top:.9rem; color:var(--muted); font-size:.95rem; }
  .footer-cols{ display:flex; gap:clamp(2rem,6vw,5rem); flex-wrap:wrap; }
  .footer-col h4{ margin:0 0 .9rem; font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); font-weight:500; }
  .footer-col a{ display:block; text-decoration:none; color:var(--ink-soft); font-size:.95rem; padding:.28rem 0; transition:color .15s ease; }
  .footer-col a:hover{ color:var(--accent); }
  .footer-bottom{ margin-top:3rem; padding-top:1.5rem; border-top:1px solid var(--hairline); display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center; font-size:.85rem; color:var(--muted); }
  .footer-bottom .legal-links{ display:flex; gap:1.5rem; flex-wrap:wrap; }
  .footer-bottom a{ color:var(--muted); text-decoration:none; } .footer-bottom a:hover{ color:var(--ink); }

  /* Reveal */
  .js .reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s cubic-bezier(.2,.7,.2,1), transform .6s cubic-bezier(.2,.7,.2,1); }
  .js .reveal.is-visible{ opacity:1; transform:none; }
  .js .reveal[data-d="1"]{ transition-delay:.07s; } .js .reveal[data-d="2"]{ transition-delay:.14s; } .js .reveal[data-d="3"]{ transition-delay:.21s; }

  /* Motion accents */
  @media (prefers-reduced-motion: no-preference){
    .js .hero h1 .hl::after{ animation:underlineDraw .7s cubic-bezier(.2,.7,.2,1) .85s forwards; }
    .faq details[open] .answer{ animation:answerIn .35s ease; }
    .js .tick{ opacity:0; animation:tickIn .55s ease forwards; }
    .js .t1{ animation-delay:.55s; } .js .t2{ animation-delay:.7s; } .js .t3{ animation-delay:.85s; }
  }
  @keyframes underlineDraw{ to{ transform:scaleX(1); } }
  @keyframes answerIn{ from{ opacity:0; transform:translateY(-4px); } to{ opacity:1; transform:none; } }
  @keyframes tickIn{ to{ opacity:.8; } }
  @media (prefers-reduced-motion: reduce){
    *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
    .hero h1 .hl::after{ transform:scaleX(1); }
    .js .step.reveal::before{ transform:scaleX(1); }
    .js .tick{ opacity:.8; }
  }

  @media (max-width:900px){
    .nav-links{ position:fixed; inset:68px 0 auto 0; flex-direction:column; align-items:stretch; gap:.25rem;
      background:var(--paper); border-bottom:1px solid var(--hairline); padding:1rem var(--pad) 1.5rem;
      transform:translateY(-12px); opacity:0; pointer-events:none; transition:opacity .2s ease, transform .2s ease; box-shadow:var(--shadow-md); }
    .nav-links.is-open{ transform:none; opacity:1; pointer-events:auto; }
    .nav-links a:not(.btn){ padding:.85rem .5rem; font-size:1.05rem; border-radius:10px; }
    .nav-links a.is-active::after{ left:.5rem; right:auto; width:1.3rem; bottom:.55rem; }
    .nav-cta{ margin-left:0; margin-top:.5rem; }
    .nav-toggle{ display:inline-flex; }
    .process{ grid-template-columns:repeat(2,1fr); }
    .studio{ grid-template-columns:1fr; } .contact-inner{ grid-template-columns:1fr; }
    .leistung{ grid-template-columns:1fr; gap:1rem; } .pricing{ grid-template-columns:1fr; }
    .hero-grid{ display:none; } .tick{ display:none; }
  }
  @media (max-width:560px){
    .services{ grid-template-columns:1fr; } .process{ grid-template-columns:1fr; } .team{ grid-template-columns:1fr; } .hero-meta{ gap:1.1rem 2rem; }
  }
  @media (max-width:430px){
    .work-grid{ grid-template-columns:1fr; }
  }
