/* Self-hosted fonts (latin subset) — replaces Google Fonts for DSGVO + performance */
@font-face{font-family:'Anton';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/anton.woff2') format('woff2')}
@font-face{font-family:'Archivo';font-style:normal;font-weight:500 900;font-display:swap;src:url('../fonts/archivo.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url('../fonts/hanken-grotesk.woff2') format('woff2')}

:root{
    --ink:#14110c;       /* warm anthracite */
    --ink-2:#1c1813;
    --steel:#262019;
    --paper:#f5f1e8;     /* off-white */
    --concrete:#ebe5d8;  /* warm light */
    --hi:#c8962b;        /* refined gold — used sparingly */
    --hi-soft:#e3c179;   /* light gold for accents on dark */
    --hi-deep:#8d6614;   /* deep gold for text on light bg (WCAG AA on paper) */
    --on-gold:#1c1407;   /* near-black text on gold surfaces */
    --muted:#9a9183;     /* warm muted */
    --body-light:#5c554a;/* body text on light */
    --line:rgba(245,241,232,.12);
    --line-dark:rgba(20,17,12,.12);
    --grid:rgba(245,241,232,.035);
    --grid-dark:rgba(20,17,12,.04);
    --maxw:1200px;
    --r:16px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:"Hanken Grotesk",sans-serif;
    background:var(--paper);
    color:var(--ink);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  /* fine film grain over the whole page — adds tactile, matte, "expensive" depth */
  body::after{content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.025;mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='ng'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ng)'/%3E%3C/svg%3E");background-size:160px 160px}
  @media(prefers-reduced-motion:reduce){body::after{opacity:.02}}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  h1,h2,h3{line-height:1.05;letter-spacing:-.022em}
  .anton{font-family:"Anton",sans-serif;font-weight:400;letter-spacing:.004em;text-transform:uppercase;line-height:1.12}
  .archivo{font-family:"Archivo",sans-serif}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}

  /* ---------- Buttons ---------- */
  .btn{
    display:inline-flex;align-items:center;gap:.6em;
    font-family:"Archivo",sans-serif;font-weight:700;font-size:.92rem;
    letter-spacing:.04em;text-transform:uppercase;
    padding:16px 30px;border-radius:999px;border:1.5px solid transparent;
    cursor:pointer;transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
    white-space:nowrap;
  }
  .btn-primary{background:var(--hi);color:var(--on-gold);box-shadow:0 12px 30px -16px rgba(20,17,12,.55), inset 0 1px 0 rgba(255,255,255,.22)}
  .btn-primary:hover{transform:translateY(-2px);background:#d4a23a;box-shadow:0 20px 44px -18px rgba(20,17,12,.6), inset 0 1px 0 rgba(255,255,255,.3)}
  .btn-ghost{border-color:rgba(245,241,232,.32);background:transparent}
  .btn-ghost:hover{background:rgba(245,241,232,.06);border-color:rgba(245,241,232,.6);transform:translateY(-2px)}
  .btn-ghost.dark{border-color:rgba(20,17,12,.28)}
  .btn-ghost.dark:hover{background:rgba(20,17,12,.05);border-color:rgba(20,17,12,.55)}
  .btn-sm{padding:11px 17px;font-size:.8rem}
  .arrow{transition:transform .2s ease}
  .btn:hover .arrow{transform:translateX(4px)}
  .btn{will-change:transform}
  .btn:active{transform:translateY(0) scale(.97)}
  /* keyboard accessibility: visible gold focus ring */
  a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[tabindex]:focus-visible{
    outline:2px solid var(--hi);outline-offset:3px;border-radius:6px}
  .btn:focus-visible{outline-offset:4px}
  .tlr-range:focus-visible{outline:2px solid var(--hi);outline-offset:6px}

  /* ---------- Nav ---------- */
  header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s, backdrop-filter .3s, border-color .3s;border-bottom:1px solid transparent}
  header.scrolled{background:rgba(20,17,12,.86);backdrop-filter:blur(14px);border-color:var(--line)}
  .nav{position:relative;display:flex;align-items:center;justify-content:space-between;height:74px;color:#fff}
  .logo{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:1.35rem;letter-spacing:.01em;display:flex;align-items:center;gap:.5em;flex:none}
  .navlogo{flex:none}
  /* compact bars mark (shown on narrow viewports instead of the wordmark) */
  .logo-mark{display:none;align-items:flex-end;gap:4px;height:26px}
  .logo-mark i{display:block;width:7px;height:26px;border-radius:2px}
  .logo-mark i:nth-child(1){background:var(--hi-soft)}
  .logo-mark i:nth-child(2){background:#d2a23c}
  .logo-mark i:nth-child(3){background:var(--hi)}
  @media(max-width:1080px){.logo .navlogo{display:none}.logo .logo-mark{display:flex}}
  .logo .dot{width:11px;height:11px;background:var(--hi);border-radius:2px;transform:rotate(45deg)}
  .logo small{font-family:"Archivo";font-weight:600;font-size:.62rem;letter-spacing:.28em;color:var(--hi);text-transform:uppercase}
  /* Tubelight pill nav */
  .nav-links{position:relative;
    display:flex;align-items:center;gap:2px;font-family:"Archivo";font-weight:600;font-size:.78rem;letter-spacing:.07em;text-transform:uppercase;
    background:rgba(245,241,232,.05);border:1px solid var(--line);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
    padding:5px;border-radius:999px;box-shadow:0 10px 34px -16px rgba(0,0,0,.6);letter-spacing:.04em}
  .nav-links a{position:relative;z-index:1;color:rgba(245,241,232,.74);padding:9px 15px;border-radius:999px;transition:color .35s ease}
  .nav-links a.lit{color:var(--hi)}
  /* the gliding "tubelight" indicator */
  .nav-lamp{position:absolute;top:0;left:0;z-index:0;border-radius:999px;background:rgba(200,150,43,.12);opacity:0;pointer-events:none;
    transition:transform .45s cubic-bezier(.34,1.4,.5,1), width .45s cubic-bezier(.22,1,.36,1), height .3s ease, opacity .3s ease}
  .nav-lamp::after{content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:28px;height:4px;background:var(--hi);border-radius:0 0 8px 8px;box-shadow:0 5px 18px 2px rgba(200,150,43,.55),0 2px 8px 1px rgba(200,150,43,.85)}
  @media(prefers-reduced-motion:reduce){.nav-lamp{transition:opacity .2s ease}}
  .nav-actions{display:flex;align-items:center;gap:14px;flex:none}
  /* DE/EN language switch */
  .lang-switch{display:inline-flex;align-items:center;gap:1px;padding:3px;border-radius:999px;border:1px solid var(--line);background:rgba(245,241,232,.05);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
  .lang-switch a{font-family:"Archivo";font-weight:700;font-size:.7rem;letter-spacing:.08em;color:rgba(245,241,232,.6);padding:6px 11px;border-radius:999px;transition:color .25s ease, background .25s ease;line-height:1}
  .lang-switch a:hover{color:var(--paper)}
  .lang-switch a.is-active{color:var(--on-gold);background:var(--hi)}
  .nav-phone{font-family:"Archivo";font-weight:700;color:#fff;font-size:.92rem;display:flex;align-items:center;gap:.5em}
  .nav-phone .ph-ic{width:15px;height:15px;color:var(--hi)}
  .nav-phone:hover{color:var(--hi)}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
  .burger span{width:26px;height:2px;background:#fff;display:block;transition:transform .3s ease, opacity .3s ease;transform-origin:center}
  /* burger toggles into an × when the menu is open */
  body.mm-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.mm-open .burger span:nth-child(2){opacity:0}
  body.mm-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  body.mm-open{overflow:hidden}

  /* ---------- Hero ---------- */
  .hero{position:relative;background:var(--ink);color:#fff;padding:150px 0 90px;overflow:hidden}
  .hero::before{
    content:"";position:absolute;inset:0;will-change:background-position;
    background:
      radial-gradient(900px 500px at 78% calc(8% + var(--parg,0px)), rgba(200,150,43,.16), transparent 60%),
      radial-gradient(700px 700px at 12% calc(90% + var(--parg-2,0px)), rgba(200,150,43,.06), transparent 60%);
    pointer-events:none;
  }
  .grain{position:absolute;inset:0;opacity:.045;pointer-events:none;mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
  .hero-grid{position:relative;display:grid;grid-template-columns:1fr 1.12fr;gap:46px;align-items:center}
  .eyebrow{display:inline-flex;align-items:center;gap:.6em;font-family:"Archivo";font-weight:700;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--hi);margin-bottom:24px}
  .eyebrow::before{content:"";width:34px;height:2px;background:var(--hi)}
  .hero h1{font-size:clamp(2.2rem,4.4vw,3.5rem);margin-bottom:24px}
  .hero h1 .y{color:var(--hi)}
  .hero p.lead{font-size:1.18rem;color:rgba(255,255,255,.78);max-width:33em;margin-bottom:14px}
  .hero .chips{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 32px}
  .chip{font-family:"Archivo";font-weight:600;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;
    border:1px solid var(--line);border-radius:999px;padding:8px 15px;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:.5em;
    transition:transform .35s cubic-bezier(.22,1,.36,1),border-color .35s ease,background .35s ease,color .35s ease,box-shadow .35s ease}
  .chip b{color:var(--hi);transition:transform .35s cubic-bezier(.22,1,.36,1)}
  .chip:hover{transform:translateY(-2px);border-color:rgba(200,150,43,.55);background:rgba(200,150,43,.09);color:#fff;box-shadow:0 10px 24px -14px rgba(200,150,43,.5)}
  .chip:hover b{transform:scale(1.18)}
  .hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
  .reassure{margin-top:20px;font-size:.9rem;color:var(--muted);display:flex;align-items:center;gap:.5em}
  .reassure .pulse{width:9px;height:9px;border-radius:50%;background:#3ad17a;box-shadow:0 0 0 0 rgba(58,209,122,.6);animation:pulse 2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(58,209,122,.55)}70%{box-shadow:0 0 0 9px rgba(58,209,122,0)}100%{box-shadow:0 0 0 0 rgba(58,209,122,0)}}

  .hero-visual{position:relative;perspective:1200px}
  .hero-frame{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);
    box-shadow:0 40px 80px -30px rgba(0,0,0,.7);aspect-ratio:4/3.4;background:#222;transform-style:preserve-3d;will-change:transform}
  /* border-beam: a gold glow that travels around the hero frame */
  .border-beam{position:absolute;inset:0;z-index:4;border-radius:inherit;pointer-events:none;
    border:1.5px solid transparent;
    -webkit-mask:linear-gradient(transparent,transparent),linear-gradient(#fff,#fff);
    mask:linear-gradient(transparent,transparent),linear-gradient(#fff,#fff);
    -webkit-mask-clip:padding-box,border-box;mask-clip:padding-box,border-box;
    -webkit-mask-composite:xor;mask-composite:intersect}
  .border-beam::after{content:"";position:absolute;aspect-ratio:1;width:240px;
    offset-anchor:90% 50%;
    offset-path:rect(0 auto auto 0 round 18px);
    background:linear-gradient(to left,var(--hi-soft),var(--hi),transparent);
    animation:border-beam 8s linear infinite}
  @keyframes border-beam{to{offset-distance:100%}}
  @media(prefers-reduced-motion:reduce){.border-beam{display:none}}
  /* cursor-following glow in dark sections (added via JS) */
  .glow-sec{position:relative}
  /* keep content above the decorative grid + glow layers */
  .testi-sec,.portfolio-sec,.steps-sec,.blog-sec,.cta-sec,.anon-sec{position:relative}
  .testi-sec>.wrap,.portfolio-sec>.wrap,.steps-sec>.wrap,.blog-sec>.wrap,.cta-sec>.wrap,.anon-sec>.wrap,.glow-sec>.wrap,
  .hero-grid,.subhero>.wrap,.tech-features>.wrap,.modules-sec>.wrap,.austria-sec>.wrap,.dsgvo-sec>.wrap,.band-sec>.wrap{position:relative;z-index:1}
  /* faint architectural grid, fading from the top (blueprint feel) */
  .testi-sec::before,.portfolio-sec::before,.steps-sec::before,.blog-sec::after,.cta-sec::after,.anon-sec::after,
  .hero::after,.subhero::after,.tech-features::before,.modules-sec::after,.austria-sec::before,.dsgvo-sec::before,.band-sec::before{
    content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
    background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
    background-size:60px 60px;
    background-position:0 var(--par,0px);will-change:background-position;
    -webkit-mask:radial-gradient(120% 95% at 50% -8%, #000 4%, transparent 70%);
    mask:radial-gradient(120% 95% at 50% -8%, #000 4%, transparent 70%)}
  /* dark subpage sections need a positioning context for the grid */
  .tech-features,.austria-sec,.dsgvo-sec,.band-sec{position:relative}
  .sec-glow{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity .8s ease;
    background:radial-gradient(520px circle at var(--gx,50%) var(--gy,50%), rgba(200,150,43,.045), transparent 72%)}
  @media(prefers-reduced-motion:reduce){.sec-glow{display:none}}
  .hero-frame img{width:100%;height:100%;object-fit:cover}
  .hero-frame img,.hero-frame video,.hero-frame .heromedia{transform:scale(1.22);translate:0 var(--ipy,0px);will-change:transform,translate}
  @media(prefers-reduced-motion:reduce){.hero-frame img,.hero-frame video,.hero-frame .heromedia{transform:none;translate:none}}
  .hero-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(20,17,12,.55))}
  .frame-tag{position:absolute;top:16px;left:16px;z-index:2;background:rgba(20,17,12,.7);backdrop-filter:blur(6px);
    border:1px solid var(--line);border-radius:8px;padding:7px 12px;font-family:"Archivo";font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:.5em}
  .frame-tag .rec{width:9px;height:9px;border-radius:50%;background:#ff4040;animation:pulse-red 1.6s infinite}
  @keyframes pulse-red{50%{opacity:.3}}
  .frame-bottom{position:absolute;bottom:14px;left:16px;right:16px;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;font-family:"Archivo"}
  .frame-bottom .loc{font-weight:700;font-size:.9rem}
  .frame-bottom .res{font-weight:800;font-size:.78rem;letter-spacing:.08em;color:var(--hi);border:1px solid var(--hi);border-radius:6px;padding:3px 8px}
  .frame-res-tr{position:absolute;top:16px;right:16px;z-index:2;font-family:"Archivo";font-weight:800;font-size:.74rem;letter-spacing:.1em;color:var(--hi);background:rgba(20,17,12,.7);backdrop-filter:blur(6px);border:1px solid var(--hi);border-radius:6px;padding:5px 9px}
  .float-card{position:absolute;background:rgba(28,24,19,.5);backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3);
    color:#fff;border:1px solid rgba(245,241,232,.16);border-radius:14px;padding:14px 16px;
    box-shadow:0 24px 50px -18px rgba(0,0,0,.55), inset 0 1px 0 rgba(245,241,232,.1);display:flex;align-items:center;gap:12px}
  .float-card.fc1{bottom:-26px;left:-26px;}
  .float-card .ic{width:40px;height:40px;border-radius:10px;background:var(--hi);display:grid;place-items:center;box-shadow:0 6px 16px -6px rgba(200,150,43,.6)}
  .float-card .ic svg{width:20px;height:20px;color:var(--on-gold)}
  .float-card .t{font-family:"Archivo";font-weight:800;font-size:1.05rem;line-height:1}
  .float-card .s{font-size:.74rem;color:rgba(245,241,232,.7);letter-spacing:.02em}

  /* ---------- Trust strip ---------- */
  .trust{background:radial-gradient(900px 320px at 50% -30%, rgba(245,241,232,.05), transparent 60%), var(--ink-2);color:#fff;padding:40px 0;border-top:1px solid var(--line)}
  .trust .lab{text-align:center;font-family:"Archivo";font-weight:600;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}
  /* infinite logo marquee with soft fade edges (progressive-blur equivalent) */
  .trust-marquee{position:relative;overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent)}
  .trust-track{display:flex;align-items:center;gap:30px;width:max-content;padding:6px 0;animation:trust-scroll 42s linear infinite}
  .trust-marquee:hover .trust-track{animation-play-state:paused}
  @keyframes trust-scroll{to{transform:translateX(-50%)}}
  /* keep legible white chips (logos aren't all transparent), refined for the marquee */
  .trust-track .logo-chip{flex:none;height:58px;padding:0 26px;border-radius:14px;
    box-shadow:0 10px 30px -16px rgba(0,0,0,.6);transition:transform .3s ease,box-shadow .3s ease}
  .trust-track .logo-chip:hover{transform:translateY(-3px);box-shadow:0 16px 36px -16px rgba(0,0,0,.7)}
  @media(prefers-reduced-motion:reduce){.trust-track{animation:none;justify-content:center;flex-wrap:wrap;width:100%}}
  .logos{display:flex;align-items:center;justify-content:center;gap:46px;flex-wrap:wrap}
  .logos img{height:46px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.72;transition:opacity .25s}
  .logos img:hover{opacity:1}

  /* ---------- Stats ---------- */
  .stats{background:radial-gradient(760px 340px at 50% 130%, rgba(200,150,43,.07), transparent 62%), var(--ink);color:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
  .stat{padding:52px 24px;text-align:center;border-right:1px solid var(--line)}
  .stat:last-child{border-right:0}
  .stat .n{font-family:"Anton",sans-serif;font-size:clamp(2.6rem,4.2vw,3.6rem);line-height:1;color:var(--hi)}
  .stat .l{font-family:"Archivo";font-weight:600;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-top:10px;color:var(--muted)}

  /* ---------- Section base ---------- */
  section.block{padding:118px 0}
  /* default light sections: subtle warm top glow (overridden by .demo/.*-sec below) */
  .block{background:linear-gradient(var(--grid-dark) 1px,transparent 1px) 0 0/64px 64px, linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px) 0 0/64px 64px, radial-gradient(1300px 760px at 50% -6%, #f3ede0, var(--paper) 58%)}
  .sec-head{max-width:700px;margin-bottom:62px}
  .sec-tag{font-family:"Archivo";font-weight:700;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--hi-deep);display:flex;align-items:center;gap:.7em;margin-bottom:18px}
  .sec-tag::before{content:"";width:34px;height:1.5px;background:var(--hi-deep)}
  .sec-head h2{font-size:clamp(2.1rem,3.9vw,3.15rem)}
  .sec-head p{font-size:1.12rem;color:var(--body-light);margin-top:18px;line-height:1.65}
  .center{text-align:center;margin-left:auto;margin-right:auto}
  .center .sec-tag{justify-content:center}
  .center .sec-tag::before{display:none}

  /* ---------- USP cards ---------- */
  .usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .usp{background:#fff;border:1px solid var(--line-dark);border-radius:var(--r);padding:38px 34px;position:relative;overflow:hidden;box-shadow:0 1px 2px rgba(20,17,12,.04);transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease}
  .usp:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(20,17,12,.35)}
  .usp::after{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--hi);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.22,1,.36,1)}
  .usp:hover::after{transform:scaleX(1)}
  .usp .icon{width:58px;height:58px;border-radius:14px;background:var(--ink);color:var(--hi);display:grid;place-items:center;margin-bottom:24px}
  .usp .icon svg{width:28px;height:28px}
  .usp h3{font-family:"Archivo";font-weight:800;font-size:1.35rem;margin-bottom:10px}
  .usp p{color:#5c554a;font-size:.98rem}
  .usp .kicker{font-family:"Archivo";font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--hi-deep);margin-bottom:6px}

  /* ---------- Steps ---------- */
  .steps-sec{background:radial-gradient(1000px 520px at 50% -10%, rgba(200,150,43,.09), transparent 58%), var(--ink);color:#fff;position:relative;overflow:hidden}
  .steps-sec .grain{opacity:.05}
  .steps-sec .sec-head p{color:rgba(255,255,255,.7)}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;position:relative}
  .step{position:relative;padding-top:8px}
  .step .num{font-family:"Anton",sans-serif;font-size:4rem;color:transparent;-webkit-text-stroke:2px var(--hi);line-height:1;margin-bottom:14px}
  .step h3{font-family:"Archivo";font-weight:800;font-size:1.4rem;margin-bottom:10px}
  .step p{color:rgba(255,255,255,.7);font-size:.98rem}
  .step ul{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:6px}
  .step li{font-size:.92rem;color:rgba(255,255,255,.82);display:flex;gap:.55em;align-items:flex-start}
  .step li::before{content:"→";color:var(--hi);font-weight:700}
  .step-divider{position:absolute;top:34px;right:-13px;color:rgba(255,255,255,.18);font-size:1.6rem}

  /* ---------- Demo portal ---------- */
  .demo{background:linear-gradient(var(--grid-dark) 1px,transparent 1px) 0 0/64px 64px, linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px) 0 0/64px 64px, radial-gradient(1200px 680px at 18% -10%, #f2ecdf, transparent 55%), radial-gradient(900px 700px at 100% 120%, #e2dccd, transparent 60%), var(--concrete)}
  .demo-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:center}
  .demo h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:18px}
  .demo p{color:#5c554a;font-size:1.05rem;margin-bottom:22px}
  .demo-list{list-style:none;display:flex;flex-direction:column;gap:16px;margin-bottom:30px}
  .demo-list li{display:flex;gap:14px;align-items:flex-start}
  .demo-list .di{flex:none;width:40px;height:40px;border-radius:11px;background:#fff;border:1px solid var(--line-dark);display:grid;place-items:center;color:var(--hi-deep)}
  .demo-list .di svg{width:19px;height:19px}
  .demo-list b{font-family:"Archivo";font-weight:700;display:block}
  .demo-list span{font-size:.93rem;color:#5c554a}
  .player{background:var(--ink);border-radius:16px;padding:14px;box-shadow:0 40px 80px -34px rgba(0,0,0,.55)}
  .player-screen{border-radius:10px;overflow:hidden;aspect-ratio:16/10;position:relative;background:#000}
  .player-screen img{width:100%;height:100%;object-fit:cover}
  .player-bar{position:absolute;left:0;right:0;bottom:0;padding:16px;background:linear-gradient(transparent,rgba(0,0,0,.85))}
  .player-meta{display:flex;justify-content:space-between;color:#fff;font-family:"Archivo";font-size:.8rem;font-weight:600;margin-bottom:8px}
  .player-meta .y{color:var(--hi)}
  .track{height:6px;border-radius:4px;background:rgba(255,255,255,.22);position:relative;cursor:pointer}
  .track .fill{height:100%;border-radius:4px;background:var(--hi);width:62%}
  .track .knob{position:absolute;top:50%;left:62%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.4)}
  .player-foot{display:flex;justify-content:space-between;align-items:center;color:#fff;padding:12px 6px 4px;font-family:"Archivo";font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
  .player-foot .live{color:#3ad17a;display:flex;align-items:center;gap:.4em}

  /* ---------- Pricing ---------- */
  .price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
  .plan{background:#fff;border:1px solid var(--line-dark);border-radius:20px;padding:40px 34px;display:flex;flex-direction:column;position:relative;box-shadow:0 1px 2px rgba(20,17,12,.04);transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease}
  .plan:hover{transform:translateY(-6px);box-shadow:0 36px 70px -36px rgba(20,17,12,.3)}
  .plan.featured{background:var(--ink);color:#fff;border-color:var(--hi);box-shadow:0 40px 80px -32px rgba(20,17,12,.55)}
  .badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--hi);color:var(--on-gold);font-family:"Archivo";font-weight:800;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:7px 18px;border-radius:999px;box-shadow:0 10px 24px -10px rgba(200,150,43,.6)}
  .plan .pname{font-family:"Archivo";font-weight:800;font-size:1.5rem;margin-bottom:4px}
  .plan .ptag{font-family:"Archivo";font-weight:700;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--hi-deep);margin-bottom:18px}
  .plan.featured .ptag{color:var(--hi)}
  .plan .pdesc{font-size:.96rem;color:#5c554a;margin-bottom:22px;min-height:58px}
  .plan.featured .pdesc{color:rgba(255,255,255,.72)}
  .plan ul{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:28px;flex:1}
  .plan li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem}
  .plan li svg{flex:none;width:19px;height:19px;margin-top:3px;color:var(--hi-deep)}
  .plan.featured li svg{color:var(--hi)}
  .plan .btn{width:100%;justify-content:center}
  .plan-note{text-align:center;color:#7a7264;font-size:.92rem;margin-top:28px}

  /* ---------- Testimonials ---------- */
  .testi-sec{background:radial-gradient(1000px 520px at 50% -8%, rgba(200,150,43,.11), transparent 58%), radial-gradient(800px 600px at 92% 115%, rgba(200,150,43,.05), transparent 55%), linear-gradient(180deg, #221c15, var(--ink-2));color:#fff}
  .testi-sec .sec-head p{color:rgba(255,255,255,.7)}
  .testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .testi{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:var(--r);padding:30px;display:flex;flex-direction:column;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,border-color .4s ease,background .4s ease}
  .testi:hover{transform:translateY(-5px);border-color:rgba(200,150,43,.4);background:rgba(255,255,255,.06);box-shadow:0 26px 54px -32px rgba(0,0,0,.65)}
  .stars{color:var(--hi);font-size:1.05rem;letter-spacing:.12em;margin-bottom:16px}
  .testi blockquote{font-size:1rem;color:rgba(255,255,255,.88);line-height:1.6;flex:1}
  .testi .who{margin-top:22px;display:flex;align-items:center;gap:12px}
  .testi .av{width:42px;height:42px;border-radius:50%;background:var(--hi);color:var(--on-gold);display:grid;place-items:center;font-family:"Archivo";font-weight:800}
  .testi .who b{font-family:"Archivo";font-weight:700;font-size:.95rem;display:block}
  .testi .who span{font-size:.82rem;color:var(--muted)}

  /* ---------- Team ---------- */
  .team-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
  .team-photos{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .team-photos img{width:100%;height:100%;object-fit:cover;border-radius:12px;aspect-ratio:1;transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s ease;cursor:pointer}
  .team-photos img:hover{transform:scale(1.045);position:relative;z-index:2;box-shadow:0 24px 50px -24px rgba(0,0,0,.55)}
  .team-photos img:first-child{grid-row:span 2;aspect-ratio:auto}
  .team-copy h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:18px}
  .team-copy>p{color:#5c554a;font-size:1.05rem;margin-bottom:22px}
  .team-list{list-style:none;display:flex;flex-direction:column;gap:18px}
  .team-list li b{font-family:"Archivo";font-weight:800;font-size:1.05rem;display:flex;align-items:center;gap:.5em}
  .team-list li b svg{width:20px;height:20px;color:var(--hi-deep)}
  .team-list li p{color:#5c554a;font-size:.96rem;margin:4px 0 0 30px}

  /* ---------- FAQ ---------- */
  .faq-sec{background:linear-gradient(var(--grid-dark) 1px,transparent 1px) 0 0/64px 64px, linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px) 0 0/64px 64px, radial-gradient(1100px 620px at 50% -8%, #f2ecdf, transparent 56%), var(--concrete)}
  .faq-wrap{max-width:840px;margin:0 auto}
  .faq{border-bottom:1px solid rgba(20,17,12,.14)}
  .faq button{width:100%;background:none;border:0;text-align:left;padding:24px 4px;display:flex;justify-content:space-between;align-items:center;gap:20px;cursor:pointer;font-family:"Archivo";font-weight:700;font-size:1.12rem;color:var(--ink)}
  .faq .q-ic{flex:none;width:30px;height:30px;border-radius:8px;background:var(--ink);color:var(--hi);display:grid;place-items:center;font-size:1.2rem;transition:transform .3s}
  .faq.open .q-ic{transform:rotate(45deg)}
  .faq .a{max-height:0;overflow:hidden;transition:max-height .35s ease}
  .faq .a p{padding:0 4px 24px;color:#5c554a;font-size:1rem;max-width:64ch}

  /* ---------- Final CTA ---------- */
  .cta-sec{background:var(--ink);color:#fff;position:relative;overflow:hidden}
  .cta-sec::before{content:"";position:absolute;inset:0;will-change:background-position;background:radial-gradient(700px 400px at 80% calc(20% + var(--parg,0px)),rgba(200,150,43,.16),transparent 60%)}
  .cta-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
  .cta-grid h1,.cta-grid h2{font-size:clamp(2.1rem,4vw,3.2rem);margin-bottom:18px}
  .cta-grid h1 .y{color:var(--hi)}
  .cta-grid h2 .y{color:var(--hi)}
  .cta-grid>div>p{color:rgba(255,255,255,.78);font-size:1.1rem;margin-bottom:26px;max-width:34em}
  .cta-checks{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
  .cta-checks li{display:flex;gap:.6em;align-items:center;font-size:1rem}
  .cta-checks li svg{width:20px;height:20px;color:var(--hi)}
  .cta-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
  .cta-card{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:18px;padding:34px;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,border-color .4s ease}
  .cta-card:hover{transform:translateY(-4px);border-color:rgba(200,150,43,.4);box-shadow:0 28px 56px -32px rgba(0,0,0,.6)}
  .cta-card .ctop{font-family:"Archivo";font-weight:700;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--hi);margin-bottom:20px}
  .contact-row{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
  .contact-row:last-of-type{border-bottom:0}
  .contact-row .ci{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:var(--hi)}
  .contact-row .ci svg{width:22px;height:22px}
  .contact-row .cl{font-size:.78rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-family:"Archivo";font-weight:600}
  .contact-row .cv{font-family:"Archivo";font-weight:700;font-size:1.12rem}
  .contact-row a.cv:hover{color:var(--hi)}

  /* ---------- Footer ---------- */
  footer{background:#0d0b07;color:rgba(255,255,255,.6);padding:56px 0 30px;font-size:.92rem}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid var(--line)}
  .foot-grid .logo{color:#fff;margin-bottom:16px}
  .foot-grid h4{font-family:"Archivo";font-weight:700;color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}
  .foot-grid a{display:block;padding:5px 0;transition:color .2s}
  .foot-grid a:hover{color:var(--hi)}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:16px;font-size:.84rem}
  .foot-social{display:flex;gap:12px}
  .foot-social a{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);display:grid;place-items:center;color:#fff;transition:.2s}
  .foot-social a:hover{background:var(--hi);color:var(--on-gold);border-color:var(--hi)}
  .foot-social svg{width:18px;height:18px}

  /* ---------- SVG scenes ---------- */
  .scene{width:100%;height:100%;display:block}
  .hero-frame .scene,.player-screen .scene{position:absolute;inset:0}
  .wordmarks{display:flex;align-items:center;justify-content:center;gap:54px;flex-wrap:wrap}
  .wm{font-family:"Archivo",sans-serif;font-weight:800;font-size:1.7rem;letter-spacing:.04em;color:rgba(255,255,255,.55);transition:color .25s;line-height:1}
  .wm:hover{color:#fff}
  .wm small{display:block;font-size:.5rem;font-weight:700;letter-spacing:.22em;color:var(--muted);margin-top:3px}
  .scene-panel{border-radius:14px;overflow:hidden;aspect-ratio:1.02;box-shadow:0 30px 60px -34px rgba(0,0,0,.4)}
  .scene-panel .scene{position:static}

  /* ---------- real media ---------- */
  .navlogo{height:26px;width:auto;display:block}
  .hero-frame .heromedia{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .player-screen .playershot{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .logo-row{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}
  .logo-chip{background:#fff;border-radius:12px;padding:0 24px;height:62px;display:flex;align-items:center;justify-content:center;min-width:118px;box-shadow:0 10px 26px -14px rgba(0,0,0,.6)}
  .logo-chip img{max-height:38px;max-width:140px;width:auto;object-fit:contain;display:block;filter:none;opacity:1}
  .gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .gallery-grid figure{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;margin:0;box-shadow:0 20px 40px -26px rgba(0,0,0,.35)}
  .gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
  .gallery-grid figure:hover img{transform:scale(1.06)}
  .gallery-grid figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;font-family:"Archivo",sans-serif;font-weight:600;font-size:.9rem;background:linear-gradient(transparent,rgba(20,17,12,.82))}
  @media(max-width:760px){.gallery-grid{grid-template-columns:1fr 1fr;gap:12px}}
  @media(max-width:480px){.gallery-grid{grid-template-columns:1fr}}

  /* ---------- timelapse slider ---------- */
  .track{position:relative}
  .tlr-range{position:absolute;left:0;top:50%;transform:translateY(-50%);width:100%;height:30px;margin:0;padding:0;background:transparent;cursor:pointer;-webkit-appearance:none;appearance:none;z-index:3}
  .tlr-range:focus{outline:none}
  .tlr-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:30px;height:30px;background:transparent;border:0;cursor:pointer}
  .tlr-range::-moz-range-thumb{width:30px;height:30px;background:transparent;border:0;cursor:pointer}
  .tlr-range::-moz-range-track{background:transparent}
  .player-screen .playershot{transition:opacity .12s ease}
  #tlr-knob{transition:left .05s linear}
  #tlr-fill{transition:width .05s linear}

  /* ---------- Reveal anim (crafted: blur-in + soft rise) ---------- */
  .reveal{opacity:0;transform:translateY(12px);filter:blur(5px);transition:opacity .8s cubic-bezier(.22,1,.36,1), transform .9s cubic-bezier(.22,1,.36,1), filter .8s cubic-bezier(.22,1,.36,1)}
  .reveal.in{opacity:1;transform:none;filter:none}
  /* headline mask-wipe — top inset stays negative so umlaut dots & glow never clip */
  .reveal h1.anton, .reveal h2.anton{clip-path:inset(-16% -4% 100% -4%);transition:clip-path 1.05s cubic-bezier(.22,1,.36,1) .06s}
  .reveal.in h1.anton, .reveal.in h2.anton{clip-path:inset(-16% -4% -16% -4%)}

  /* ---------- Responsive ---------- */
  @media(max-width:980px){
    .hero-grid,.demo-grid,.team-grid,.cta-grid{grid-template-columns:1fr;gap:40px}
    .hero-visual{order:-1}
    .usp-grid,.steps,.price-grid,.testi-grid{grid-template-columns:1fr}
    .step-divider{display:none}
    .stats-grid{grid-template-columns:1fr 1fr}
    .stat:nth-child(2){border-right:0}
    .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
    .nav-links,.nav-phone{display:none}
    .nav>.lang-switch{display:none}   /* header toggle hidden on mobile — the burger menu has its own */
    .burger{display:flex}
    .team-photos img:first-child{grid-row:auto}
    .foot-grid{grid-template-columns:1fr}
  }
  @media(max-width:560px){
    section.block{padding:64px 0}
    .hero{padding:118px 0 64px}
    .float-card.fc1{left:0;bottom:-18px}
    .hero h1{font-size:clamp(2rem,8.6vw,2.75rem)}
    .hero p.lead{font-size:1.05rem}
    .stat{padding:34px 16px}
    .stat:nth-child(3){border-right:1px solid var(--line)}
  }
  /* mobile menu */
  .mobile-menu{position:fixed;inset:0;background:var(--ink);z-index:99;display:none;flex-direction:column;justify-content:center;align-items:center;gap:28px;padding:40px}
  .mobile-menu.show{display:flex}
  .mobile-menu a{color:#fff;font-family:"Archivo";font-weight:700;font-size:1.5rem;text-transform:uppercase;letter-spacing:.04em}
  .mobile-menu a:hover{color:var(--hi)}
  .mobile-menu .lang-switch{margin-top:8px}
  .mobile-menu .lang-switch a{font-size:1rem;letter-spacing:.08em;padding:9px 18px;color:rgba(245,241,232,.6)}
  .mobile-menu .lang-switch a.is-active{color:var(--on-gold);background:var(--hi)}
  .mobile-menu .close{display:none}

  /* ---------- Mobile sticky CTA bar ---------- */
  .mcta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:90;align-items:center;gap:10px;
    padding:10px 14px calc(10px + env(safe-area-inset-bottom));
    background:rgba(20,17,12,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--line)}
  .mcta .btn{flex:1;justify-content:center;padding:16px 18px}
  .mcta-call{flex:none;width:54px;height:54px;display:grid;place-items:center;border-radius:14px;border:1.5px solid rgba(245,241,232,.28);color:#fff;transition:background .2s ease,border-color .2s ease}
  .mcta-call svg{width:22px;height:22px}
  .mcta-call:active{background:rgba(245,241,232,.1)}
  @media(max-width:768px){
    .nav-actions .btn-primary{display:none}
    .burger{padding:10px;margin-right:-6px}
    /* room for the full wordmark again (header CTA is hidden here) */
    .logo .navlogo{display:block}
    .logo .logo-mark{display:none}
    .mcta{display:flex}
    body{padding-bottom:calc(74px + env(safe-area-inset-bottom))}
  }

  /* ---------- Anonymisierung / Video ---------- */
  .anon-sec{background:var(--ink-2);color:#fff;position:relative;overflow:hidden}
  .anon-sec::before{content:"";position:absolute;inset:0;will-change:background-position;background:radial-gradient(620px 380px at 15% calc(25% + var(--parg,0px)),rgba(200,150,43,.14),transparent 60%)}
  .anon-sec .sec-tag{color:var(--hi)}
  .anon-sec .sec-tag::before{background:var(--hi)}
  .anon-grid{position:relative;display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
  .anon-grid h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:18px;line-height:1.04}
  .anon-grid h2 .y{color:var(--hi)}
  .anon-grid p{color:rgba(255,255,255,.78);font-size:1.08rem;margin-bottom:24px;max-width:36em}
  .anon-checks{list-style:none;display:grid;gap:13px}
  .anon-checks li{display:flex;align-items:center;gap:13px;font-family:"Archivo";font-weight:600}
  .anon-checks li svg{width:22px;height:22px;color:var(--hi);flex:none}
  .anon-video-wrap{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 40px 80px -34px rgba(0,0,0,.6)}
  .anon-video{display:block;width:100%;height:auto}
  .anon-video-wrap .frame-tag{top:14px;left:14px}

  /* ---------- Tally Schnellanfrage ---------- */
  .form-wrap{position:relative;margin-top:66px}
  .form-head{max-width:40em;margin-bottom:24px}
  .form-head h3{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:10px}
  .form-head h3 .y{color:var(--hi)}
  .form-head p{color:rgba(255,255,255,.74)}
  .tally-card{position:relative;background:#fff;border-radius:20px;padding:38px 40px 30px;
    border:1px solid rgba(20,17,12,.08);
    box-shadow:0 50px 90px -40px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.6);overflow:hidden}
  /* gold hairline accent — ties the embedded form into the brand */
  .tally-card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;
    background:linear-gradient(90deg,var(--hi-soft),var(--hi) 45%,var(--hi-deep))}
  .tally-card iframe{display:block;width:100%;border:0}
  /* designed reassurance row under the form (matches the site's trust language) */
  .form-trust{display:flex;flex-wrap:wrap;gap:11px 24px;justify-content:center;align-items:center;
    margin-top:22px;padding-top:20px;border-top:1px solid rgba(20,17,12,.08);
    font-family:"Archivo";font-weight:600;font-size:.8rem;letter-spacing:.01em;color:var(--body-light)}
  .form-trust span{display:inline-flex;align-items:center;gap:.55em}
  .form-trust svg{width:16px;height:16px;color:var(--hi-deep);flex:none}
  @media(max-width:980px){.anon-grid{grid-template-columns:1fr;gap:34px}.anon-video-wrap{order:-1}}
  @media(max-width:560px){.tally-card{padding:22px 16px}}

  /* ---------- Wissen / Blog ---------- */
  .blog-sec{background:linear-gradient(180deg,#2a2419,#211c14);color:#fff;position:relative;overflow:hidden}
  .blog-sec::before{content:"";position:absolute;inset:0;will-change:background-position;background:radial-gradient(620px 380px at 85% calc(0% + var(--parg,0px)),rgba(200,150,43,.14),transparent 60%)}
  .blog-sec .sec-head{position:relative}
  .blog-sec .sec-tag{color:var(--hi)}
  .blog-sec .sec-tag::before{background:var(--hi)}
  .blog-sec .sec-head p{color:rgba(255,255,255,.72)}
  .blog-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
  .post-card{display:flex;flex-direction:column;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;text-decoration:none;color:inherit;transition:transform .25s,box-shadow .25s,border-color .25s}
  .post-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(0,0,0,.7);border-color:rgba(200,150,43,.4)}
  .post-media{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,var(--ink-2),#262019);display:grid;place-items:center;overflow:hidden}
  .post-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .post-media .pic{width:46px;height:46px;color:var(--hi);opacity:.9;z-index:0}
  .post-cat{position:absolute;top:12px;left:12px;z-index:2;font-family:"Archivo";font-weight:700;font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--on-gold);background:var(--hi);border-radius:5px;padding:4px 8px}
  .post-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
  .post-body h3{font-family:"Archivo";font-weight:800;font-size:1.06rem;line-height:1.25;margin-bottom:10px}
  .post-body p{font-size:.9rem;color:rgba(255,255,255,.7);line-height:1.55;flex:1}
  .post-more{margin-top:16px;font-family:"Archivo";font-weight:700;font-size:.82rem;letter-spacing:.04em;color:var(--hi);display:inline-flex;align-items:center;gap:.4em}
  .post-card:hover .post-more{gap:.7em}
  .blog-foot{position:relative;text-align:center;margin-top:44px}
  @media(max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.blog-grid{grid-template-columns:1fr}}

  /* ---------- Subpages: hero + article ---------- */
  .subhero{background:var(--ink);color:#fff;padding:124px 0 58px;position:relative;overflow:hidden}
  .subhero::before{content:"";position:absolute;inset:0;will-change:background-position;background:radial-gradient(680px 420px at 82% calc(-10% + var(--parg,0px)),rgba(200,150,43,.13),transparent 60%)}
  .subhero .wrap{position:relative}
  .post-back{display:inline-flex;align-items:center;gap:.4em;color:var(--hi);font-family:"Archivo";font-weight:700;font-size:.82rem;letter-spacing:.04em;margin-bottom:20px}
  .post-back:hover{color:#fff}
  .post-meta{font-family:"Archivo";font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--hi);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
  .post-meta .dotsep{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.35)}
  .subhero h1{font-size:clamp(1.9rem,4.4vw,3.2rem);line-height:1.16;margin:16px 0 0;max-width:20ch}
  .subhero .sub-lead{font-size:1.12rem;color:rgba(255,255,255,.82);line-height:1.6;margin-top:22px;max-width:62ch}
  .article{padding:60px 0 84px;background:#fff}
  .article-wrap{max-width:740px;margin:0 auto;padding:0 24px}
  .article p{font-size:1.06rem;line-height:1.75;color:#2c2c2e;margin:0 0 20px}
  .article h2{font-family:"Archivo";font-weight:800;font-size:1.46rem;line-height:1.22;color:var(--ink);margin:44px 0 14px}
  .article h3{font-family:"Archivo";font-weight:800;font-size:1.14rem;color:var(--ink);margin:30px 0 10px}
  .article ul,.article ol{margin:0 0 22px;padding-left:1.35em}
  .article li{font-size:1.06rem;line-height:1.7;color:#2c2c2e;margin-bottom:9px}
  .article li::marker{color:var(--hi-deep)}
  .article strong{color:var(--ink);font-weight:700}
  .article em{color:#444}
  .article-cta{margin-top:48px;background:var(--ink);color:#fff;border-radius:var(--r);padding:38px 36px;position:relative;overflow:hidden}
  .article-cta::before{content:"";position:absolute;inset:0;will-change:background-position;background:radial-gradient(420px 250px at 92% calc(0% + var(--parg,0px)),rgba(200,150,43,.18),transparent 60%)}
  .article-cta>*{position:relative}
  .article-cta h3{font-family:"Anton",sans-serif;font-weight:400;font-size:1.7rem;line-height:1.12;margin-bottom:10px;color:#fff}
  .article-cta h3 .y{color:var(--hi)}
  .article-cta p{color:rgba(255,255,255,.82);margin-bottom:22px;font-size:1rem;line-height:1.6}
  .related-grid{grid-template-columns:repeat(3,1fr)!important}
  @media(max-width:900px){.related-grid{grid-template-columns:repeat(2,1fr)!important}}
  @media(max-width:560px){.subhero{padding:104px 0 46px}.article{padding:46px 0 66px}.related-grid{grid-template-columns:1fr!important}}

  /* ---------- Technik subpage ---------- */
  .tech-hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center}
  .tech-hero-media{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 40px 80px -34px rgba(0,0,0,.6);aspect-ratio:2.35/1}
  .tech-hero-media video{display:block;width:100%;height:100%;object-fit:cover}
  @media(max-width:900px){.tech-hero-grid{grid-template-columns:1fr;gap:30px}.tech-hero-media{aspect-ratio:16/7}}
  .tech-features{background:var(--ink-2);color:#fff;padding:78px 0}
  .tech-feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .tech-feat{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,border-color .4s ease,background .4s ease}
  .tech-feat:hover{transform:translateY(-5px);border-color:rgba(200,150,43,.4);background:rgba(255,255,255,.06);box-shadow:0 26px 54px -32px rgba(0,0,0,.65)}
  .tech-feat .ic,.tech-feat .step-num{transition:transform .4s cubic-bezier(.22,1,.36,1)}
  .tech-feat:hover .ic,.tech-feat:hover .step-num{transform:translateY(-2px) scale(1.06)}
  .tech-feat .ic{width:44px;height:44px;color:var(--hi);margin-bottom:18px}
  .tech-feat h3{font-family:"Archivo";font-weight:800;font-size:1.1rem;margin-bottom:10px}
  .tech-feat p{color:rgba(255,255,255,.72);font-size:.96rem;line-height:1.6}
  .modules-sec{background:var(--ink);color:#fff;position:relative;overflow:hidden}
  .modules-sec::before{content:"";position:absolute;inset:0;will-change:background-position;background:radial-gradient(620px 400px at 50% calc(-5% + var(--parg,0px)),rgba(200,150,43,.10),transparent 60%)}
  .modules-sec .wrap{position:relative}
  .modules-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px}
  .module-card{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column}
  .module-photo{background:#000;height:240px;display:block;border-bottom:1px solid var(--line);padding:22px 30px}
  .module-photo img{width:100%;height:100%;object-fit:contain;object-position:center}
  .module-body{padding:30px 30px 34px;display:flex;flex-direction:column;flex:1}
  .module-badge{align-self:flex-start;font-family:"Archivo";font-weight:800;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-gold);background:var(--hi);border-radius:6px;padding:5px 12px;margin-bottom:14px}
  .module-card h3{font-family:"Anton",sans-serif;font-weight:400;font-size:1.6rem;margin-bottom:8px}
  .module-tag{color:rgba(255,255,255,.7);font-size:.98rem;line-height:1.55;margin-bottom:20px;min-height:3.1em}
  .spec-row{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-top:1px solid var(--line);font-size:.92rem}
  .spec-row .k{color:rgba(255,255,255,.5);font-family:"Archivo";font-weight:600}
  .spec-row .v{color:#fff;font-weight:600;text-align:right}
  .module-body .btn{margin-top:auto}
  .module-body .spec-row:last-of-type{margin-bottom:24px}
  .austria-sec{background:var(--ink-2);color:#fff}
  .austria-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
  .austria-item .ic{width:40px;height:40px;color:var(--hi);margin-bottom:14px}
  .austria-item h3{font-family:"Archivo";font-weight:800;font-size:1.02rem;margin-bottom:8px}
  .austria-item p{color:rgba(255,255,255,.7);font-size:.92rem;line-height:1.55}
  .tech-cta{background:var(--ink);text-align:center}
  .tech-cta h2{font-size:clamp(1.8rem,4vw,2.8rem);color:#fff}
  .tech-cta p{color:rgba(255,255,255,.7);max-width:540px;margin:14px auto 26px}
  @media(max-width:900px){.tech-feat-grid{grid-template-columns:1fr}.austria-grid{grid-template-columns:repeat(2,1fr)}.modules-grid{grid-template-columns:1fr}}
  @media(max-width:560px){.austria-grid{grid-template-columns:1fr}}

  /* ---------- Selbermacher (Private) subpage ---------- */
  .priv-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
  .priv-hero-grid .pic-frame{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#000;box-shadow:0 40px 80px -34px rgba(0,0,0,.6)}
  .subhero h1 .y{color:var(--hi)}
  .priv-hero-grid .pic-frame img{display:block;width:100%;height:auto}
  .priv-bullets{list-style:none;margin:26px 0 30px;display:flex;flex-direction:column;gap:13px}
  .priv-bullets li{display:flex;align-items:center;gap:12px;font-size:1.05rem;color:rgba(255,255,255,.9)}
  .priv-bullets svg{width:22px;height:22px;color:var(--hi);flex-shrink:0}
  .priv-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
  .priv-actions .nav-phone{color:#fff}
  .media-frame{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#000;box-shadow:0 40px 80px -34px rgba(0,0,0,.6)}
  .media-frame video{display:block;width:100%;height:auto}
  .split-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
  .step-num{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--hi);color:var(--on-gold);font-family:"Anton",sans-serif;font-weight:400;font-size:1.1rem;margin-bottom:16px}
  .band-sec{background:var(--ink-2);color:#fff;text-align:center}
  .band-sec .anton{font-size:clamp(1.6rem,3.4vw,2.4rem);margin-bottom:18px}
  .band-sec p{max-width:760px;margin:0 auto;font-size:1.16rem;line-height:1.6;color:rgba(255,255,255,.85)}
  .priv-quote{max-width:780px;margin:0 auto;text-align:center}
  .priv-quote blockquote{font-family:"Anton",sans-serif;font-weight:400;font-size:clamp(1.4rem,3vw,2rem);line-height:1.32;color:#fff}
  .priv-quote .who{margin-top:20px;color:var(--hi);font-family:"Archivo";font-weight:700;font-size:.9rem;letter-spacing:.06em}
  .dsgvo-sec{background:var(--ink);color:#fff}
  .dsgvo-card{display:flex;gap:20px;align-items:flex-start;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:var(--r);padding:30px 32px;max-width:880px;margin:0 auto;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,border-color .4s ease,background .4s ease}
  .dsgvo-card:hover{transform:translateY(-4px);border-color:rgba(200,150,43,.4);background:rgba(255,255,255,.06);box-shadow:0 26px 54px -32px rgba(0,0,0,.65)}
  .dsgvo-card svg{width:46px;height:46px;color:var(--hi);flex-shrink:0}
  .dsgvo-card h3{font-family:"Archivo";font-weight:800;font-size:1.2rem;margin-bottom:8px}
  .dsgvo-card p{color:rgba(255,255,255,.74);line-height:1.6}
  @media(max-width:900px){.priv-hero-grid,.split-grid{grid-template-columns:1fr;gap:32px}.priv-hero-grid .pic-frame{order:-1}}
  @media(max-width:1080px) and (min-width:981px){.nav-links{gap:20px;font-size:.78rem}}

  /* ---------- Selbermacher: refinements ---------- */
  .priv-hero-grid .pic-frame video{display:block;width:100%;height:auto}
  .band-quote{margin:36px auto 0;max-width:680px;font-size:1.16rem;line-height:1.5;color:#fff;font-style:italic;position:relative;padding-top:30px;border-top:1px solid var(--line)}
  .band-quote cite{display:block;margin-top:14px;font-style:normal;font-family:"Archivo";font-weight:700;font-size:.85rem;letter-spacing:.04em;color:var(--hi)}

  /* ---------- Trust strip clients ---------- */
  .logo-row .wm{font-family:"Archivo";font-weight:800;font-size:1.25rem;letter-spacing:.02em;color:rgba(255,255,255,.5);transition:color .2s}
  .logo-row .wm:hover{color:rgba(255,255,255,.85)}
  .logo-row .cl-logo{height:26px;width:auto;filter:brightness(0) invert(1);opacity:.55;transition:opacity .2s}
  .logo-row .cl-logo:hover{opacity:.9}

  /* ---------- Blog post hero image ---------- */
  .post-hero-img{margin-top:34px;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 60px -30px rgba(0,0,0,.6);aspect-ratio:16/8;background:#000}
  .post-hero-img img{display:block;width:100%;height:100%;object-fit:cover}

  /* ---------- Portfolio / Beispiele ---------- */
  .portfolio-sec{background:radial-gradient(1000px 560px at 50% -10%, rgba(200,150,43,.10), transparent 58%), radial-gradient(760px 560px at 6% 110%, rgba(200,150,43,.045), transparent 55%), linear-gradient(180deg, #1b1610, var(--ink));color:#fff}
  .portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .vid-card{position:relative;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--ink-2);cursor:pointer;text-align:left;padding:0;color:inherit;font:inherit;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s,border-color .25s}
  .vid-card:hover{transform:translateY(-5px);box-shadow:0 30px 60px -30px rgba(0,0,0,.7);border-color:rgba(200,150,43,.45)}
  .vid-thumb{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,var(--ink-2),#262019);overflow:hidden}
  .vid-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .vid-thumb .play{position:absolute;inset:0;margin:auto;width:60px;height:60px;border-radius:50%;background:rgba(20,17,12,.55);backdrop-filter:blur(2px);border:2px solid #fff;display:grid;place-items:center;transition:background .2s,transform .2s}
  .vid-card:hover .play{background:var(--hi);border-color:var(--hi);transform:scale(1.08)}
  .vid-card:hover .play svg{color:var(--on-gold)}
  .vid-thumb .play svg{width:24px;height:24px;color:#fff;margin-left:3px}
  .vid-dur{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.78);color:#fff;font-family:"Archivo";font-weight:700;font-size:.74rem;padding:3px 7px;border-radius:5px}
  .vid-cat{position:absolute;top:10px;left:10px;background:var(--hi);color:var(--on-gold);font-family:"Archivo";font-weight:800;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:4px 8px;border-radius:5px}
  .vid-soon{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.14);color:#fff;font-family:"Archivo";font-weight:700;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;padding:4px 8px;border-radius:5px}
  .vid-body{padding:16px 18px 20px}
  .vid-body h3{font-family:"Archivo";font-weight:700;font-size:1rem;line-height:1.3}
  .vid-body .vid-client{margin-top:5px;font-size:.84rem;color:var(--muted)}
  .vid-card[data-soon="1"]{cursor:default}
  .vid-card[data-soon="1"]:hover{transform:none;box-shadow:none;border-color:var(--line)}
  @media(max-width:900px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.portfolio-grid{grid-template-columns:1fr}}
  /* lightbox */
  .lb{position:fixed;inset:0;z-index:2000;background:rgba(8,9,11,.92);display:none;align-items:center;justify-content:center;padding:24px}
  .lb.open{display:flex}
  .lb-inner{width:min(1040px,100%);aspect-ratio:16/9;position:relative}
  .lb-inner #lb-frame{position:absolute;inset:0}
  .lb-inner iframe{width:100%;height:100%;border:0;border-radius:10px;display:block}
  .lb-close{position:absolute;top:-44px;right:0;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1.3rem;cursor:pointer;display:grid;place-items:center}
  .lb-close:hover{background:var(--hi);color:var(--on-gold);border-color:var(--hi)}

  /* ---------- Portfolio teaser on homepage (dark sec-head) ---------- */
  .portfolio-sec .sec-tag{color:var(--hi)}
  .portfolio-sec .sec-tag::before{background:var(--hi)}
  .portfolio-sec .sec-head h2{color:#fff}
  .portfolio-sec .sec-head p{color:rgba(255,255,255,.72)}

  /* ---------- Garantien (Risk Reversal) ---------- */
  .guar-sec{background:radial-gradient(1000px 560px at 80% -10%, #f3ede0, transparent 55%), var(--concrete)}
  .guar-head{margin-bottom:40px}
  .guar-title{display:flex;align-items:center;gap:30px}
  .guar-title h2{white-space:nowrap;margin:0}
  .guar-rule{flex:1;height:1px;background:var(--line-dark)}
  .guar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .guar-card{background:#fdfaf1;border:1.5px solid var(--hi);border-radius:16px;padding:30px 30px 34px;box-shadow:0 16px 40px -28px rgba(0,0,0,.35)}
  .guar-ic{width:52px;height:52px;border-radius:12px;background:var(--hi);display:grid;place-items:center;margin-bottom:22px}
  .guar-ic svg{width:26px;height:26px;color:var(--on-gold)}
  .guar-card h3{font-family:"Archivo";font-weight:800;font-size:1.2rem;color:var(--ink);margin-bottom:12px}
  .guar-card p{color:#3a3a3c;line-height:1.62;font-size:.98rem}
  @media(max-width:840px){.guar-grid{grid-template-columns:1fr}.guar-rule{display:none}}

  /* ---------- Hero CTA: Buttons nebeneinander ---------- */
  .hero-cta .btn{padding:12px 18px;font-size:.82rem}
  @media(max-width:560px){.hero-cta .btn{flex:1 1 100%;justify-content:center;padding:14px 20px}}

  /* ========== ELEGANTE ANIMATIONEN ========== */
  html{scroll-behavior:smooth}
  section[id]{scroll-margin-top:92px}

  /* sanfter Reveal-Variant für Medien (leichtes Hereinzoomen) */
  .reveal-zoom{opacity:0;transform:scale(.965);transition:opacity 1s cubic-bezier(.22,1,.36,1), transform 1s cubic-bezier(.22,1,.36,1)}
  .reveal-zoom.in{opacity:1;transform:none}

  /* Akzent-Linie der sec-tag zeichnet sich beim Erscheinen ein */
  .reveal .sec-tag::before{transform:scaleX(0);transform-origin:left;transition:transform .7s cubic-bezier(.22,1,.36,1) .2s}
  .reveal.in .sec-tag::before{transform:scaleX(1)}

  /* Hero: gestaffelter Eingang beim Laden */
  @keyframes heroUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
  @keyframes heroPop{from{opacity:0;transform:translateY(22px) scale(.985)}to{opacity:1;transform:none}}
  .hero-copy>*{opacity:0;animation:heroUp .9s cubic-bezier(.22,1,.36,1) both}
  .hero-copy>*:nth-child(1){animation-delay:.10s}
  .hero-copy>*:nth-child(2){animation-delay:.20s}
  .hero-copy>*:nth-child(3){animation-delay:.30s}
  .hero-copy>*:nth-child(4){animation-delay:.40s}
  .hero-copy>*:nth-child(5){animation-delay:.50s}
  .hero-copy>*:nth-child(6){animation-delay:.60s}
  .hero-frame{opacity:0;animation:heroPop 1.1s cubic-bezier(.22,1,.36,1) .28s both}
  .float-card{animation:heroUp .8s cubic-bezier(.22,1,.36,1) .95s both}

  /* sanftes Bild-Zoom beim Hover (Medien) + Scroll-Parallax-Pan (unabhängige translate-Property, kollidiert nicht mit dem Hover-scale) */
  .vid-thumb img,.post-media img,.module-photo img{transform:scale(1.26);translate:0 var(--ipy,0px);transition:transform .7s cubic-bezier(.22,1,.36,1);will-change:transform,translate}
  .vid-card:hover .vid-thumb img,.post-card:hover .post-media img,.module-card:hover .module-photo img{transform:scale(1.32)}
  @media(prefers-reduced-motion:reduce){.vid-thumb img,.post-media img,.module-photo img{translate:none;transform:none}}

  /* (Tubelight-Pille ersetzt die frühere Unterstreichung der Hauptnavigation) */

  /* Footer-Links: dezenter Versatz beim Hover */
  .foot-grid a{transition:color .2s, transform .2s}
  .foot-grid a:hover{color:var(--hi);transform:translateX(4px)}

  /* Garantie-Karten: weicher Lift */
  .guar-card,.module-card{transition:transform .45s cubic-bezier(.22,1,.36,1), box-shadow .45s cubic-bezier(.22,1,.36,1)}
  .guar-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(0,0,0,.4)}

  /* Slider-Knopf: dezenter Hinweis-Glow (signalisiert Verschiebbarkeit) */
  #tlr-knob{box-shadow:0 0 0 0 rgba(200,150,43,.5);animation:knobGlow 2.8s ease-in-out infinite}
  @keyframes knobGlow{0%{box-shadow:0 0 0 0 rgba(200,150,43,.45)}60%{box-shadow:0 0 0 12px rgba(200,150,43,0)}100%{box-shadow:0 0 0 0 rgba(200,150,43,0)}}

  /* Reduzierte Bewegung respektieren */
  @media (prefers-reduced-motion: reduce){
    *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
    .reveal,.reveal-zoom{opacity:1!important;transform:none!important;filter:none!important}
    .reveal h1.anton,.reveal h2.anton{clip-path:none!important}
    .hero-copy>*,.hero-frame,.float-card{opacity:1!important;animation:none!important}
    .hero-frame,.float-card{transform:none!important}
    .reveal .sec-tag::before{transform:scaleX(1)!important}
  }

  /* ============================================================
     MOBILE — designed for phone, not desktop shrunk (≤620px)
     ============================================================ */
  /* never allow a stray transform/marquee to create sideways scroll */
  html{overflow-x:hidden}
  /* when grids collapse to one column, children must shrink to the track —
     otherwise a media frame's intrinsic min-width blows the column wider than
     the viewport (was making the hero frame 483px in a 416px column) */
  @media(max-width:980px){
    .hero-grid>*,.demo-grid>*,.cta-grid>*,.anon-grid>*,.tech-hero-grid>*,
    .priv-hero-grid>*,.split-grid>*,.team-grid>*,
    .price-grid>*,.usp-grid>*,.steps>*,.testi-grid>*,.modules-grid>*,
    .guar-grid>*,.tech-feat-grid>*,.austria-grid>*,.related-grid>*,
    .portfolio-grid>*,.blog-grid>*,.gallery-grid>*{min-width:0}
    .hero-frame,.hero-visual,.anon-video-wrap,.plan,.post-card,.vid-card{max-width:100%}
  }
  @media(max-width:620px){
    /* generous, consistent gutters (premium breathing room) */
    .wrap{padding-left:22px;padding-right:22px}

    /* phone-native type scale — set deliberately, not inherited from desktop */
    /* Anton needs breathing room or the Ü/Ö/Ä dots collide with the line above */
    .hero h1{font-size:clamp(2.05rem,8.8vw,2.7rem);line-height:1.16;letter-spacing:-.01em}
    .hero p.lead{font-size:1.02rem;line-height:1.5;max-width:36ch;margin-bottom:6px}
    .eyebrow{font-size:.66rem;letter-spacing:.15em;margin-bottom:16px}
    h2.anton{font-size:clamp(1.85rem,7.2vw,2.35rem);line-height:1.14}
    .sec-tag{font-size:.67rem;letter-spacing:.14em}

    /* hero dramaturgy: tighter rhythm, visual leads then a punchy headline */
    .hero{padding:102px 0 54px}
    .hero-grid{gap:28px}
    /* float-card stays fully inside the frame on phone (no edge spill) */
    .float-card.fc1{left:10px;right:10px;bottom:10px;width:auto;padding:12px 14px}

    /* hero chips → edge-to-edge horizontal scroller (a real mobile pattern) */
    .hero .chips{flex-wrap:nowrap;overflow-x:auto;margin:16px -22px 24px;padding:2px 22px;
      scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none}
    .hero .chips::-webkit-scrollbar{display:none}
    .hero .chips .chip{flex:none;scroll-snap-align:start}

    /* CTAs: stacked, full-width, thumb-reachable */
    .hero-cta{flex-direction:column;align-items:stretch;gap:12px}
    .hero-cta .btn{width:100%;justify-content:center;padding:15px 22px}
    .reassure{justify-content:center;margin-top:16px}

    /* touch targets ≥ 44px (WCAG / Apple HIG) */
    .burger{min-width:44px;min-height:44px;justify-content:center;align-items:center}
    .mobile-menu a{padding:6px 10px}

    /* trust strip: calmer, smaller chips so it reads as intentional, not clipped */
    .trust{padding:30px 0}
    .trust .lab{margin-bottom:20px;font-size:.68rem;letter-spacing:.16em}
    .trust-track{gap:16px}
    .trust-track .logo-chip{height:44px;padding:0 16px;border-radius:11px}

    /* section rhythm + tighter stats cells */
    section.block{padding:54px 0}
    .stat{padding:30px 14px}
    .stat .n{font-size:2.4rem}

    /* lists & cards: comfortable line-length and spacing on phone */
    .demo-list li span,.anon-checks li,.cta-checks li{font-size:.96rem}
    .post-body h3{font-size:1.12rem}
    .vid-body h3{font-size:1.02rem}

    /* sticky CTA bar: a touch more presence */
    .mcta .btn{padding:15px 16px;font-size:.86rem}
  }

  /* very small phones: keep the headline from crowding the edges */
  @media(max-width:380px){
    .wrap{padding-left:18px;padding-right:18px}
    .hero h1{font-size:clamp(1.9rem,9vw,2.3rem)}
    .trust-track .logo-chip{height:40px;padding:0 13px}
  }
