@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/archivo-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/archivo-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;src:url('fonts/archivo-800.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:900;font-display:swap;src:url('fonts/archivo-900.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/hanken-grotesk-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/hanken-grotesk-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/hanken-grotesk-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/hanken-grotesk-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/ibm-plex-mono-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/ibm-plex-mono-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

:root{
    --navy:#002B58;
    --navy-900:#001B3A;
    --navy-700:#16335c;
    --navy-card:#0a2549;
    --orange:#E4087E;
    --orange-bright:#ee3e83;
    --concrete:#E9E9E6;
    --concrete-2:#f3f2ef;
    --ink:#14181F;
    --muted:#5d6470;
    --line:rgba(0,43,88,.12);
    --white:#ffffff;
    --r:14px;
    --ease:cubic-bezier(.22,.61,.36,1);
    --container:1200px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Hanken Grotesk',system-ui,sans-serif;
    color:var(--ink);
    background:var(--concrete-2);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  h1,h2,h3,h4{font-family:'Archivo',sans-serif;line-height:1.02;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  .wrap{width:100%;max-width:var(--container);margin:0 auto;padding:0 28px}

  /* ---------- utility / eyebrow ---------- */
  .eyebrow{
    font-family:'IBM Plex Mono',monospace;
    font-size:12px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
    color:var(--orange);
    display:inline-flex;align-items:center;gap:10px;
  }
  .eyebrow::before{content:"";width:26px;height:1px;background:var(--orange);display:inline-block}
  .eyebrow.center::after{content:"";width:26px;height:1px;background:var(--orange);display:inline-block}
  .eyebrow.dark{color:var(--orange)}
  .eyebrow.muted{color:var(--navy)}
  .eyebrow.muted::before,.eyebrow.muted.center::after{background:var(--navy)}

  /* ---------- buttons ---------- */
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    font-family:'Archivo',sans-serif;font-weight:700;font-size:15px;letter-spacing:.01em;
    padding:15px 26px;border-radius:100px;cursor:pointer;border:none;
    transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .25s;
    will-change:transform;
  ;white-space:nowrap}
  .btn svg{width:17px;height:17px;transition:transform .35s var(--ease)}
  .btn-primary{background:var(--orange);color:var(--navy-900)}
  .btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 30px -10px rgba(228,8,126,.6)}
  .btn-primary:hover svg{transform:translateX(4px)}
  .btn-ghost{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.35)}
  .btn-ghost:hover{border-color:var(--white);transform:translateY(-3px)}
  .btn-dark{background:var(--navy);color:#fff}
  .btn-dark:hover{transform:translateY(-3px);box-shadow:0 14px 30px -12px rgba(0,43,88,.5)}

  /* ---------- header ---------- */
  header{
    position:fixed;top:0;left:0;right:0;z-index:100;
    transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
    padding:20px 0;
  }
  header .bar{display:flex;align-items:center;justify-content:space-between;gap:24px}
  header .logo{display:flex;align-items:center;gap:14px;flex-shrink:0}
  header .logo img{height:42px;width:auto;transition:height .4s var(--ease)}
  header .logo .lc{display:none}
  header.scrolled .logo .lw{display:none}
  header.scrolled .logo .lc{display:block}
  header .logo .lt{color:#fff;transition:color .4s var(--ease)}
  header .logo .lt b{font-family:'Archivo';font-weight:800;font-size:16px;display:block;letter-spacing:-.01em;line-height:1.1;white-space:nowrap}
  header .logo .lt span{font-family:'IBM Plex Mono';font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.7}
  nav.main{display:flex;align-items:center;gap:clamp(18px,2vw,34px)}
  nav.main a{font-size:14.5px;font-weight:500;color:rgba(255,255,255,.82);transition:color .25s;position:relative;white-space:nowrap}
  nav.main a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--orange);transition:width .3s var(--ease)}
  nav.main a:hover{color:#fff}
  nav.main a:hover::after{width:100%}
  header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line),0 12px 30px -20px rgba(0,27,58,.35);padding:13px 0}
  header.scrolled .logo img{height:36px}
  header.scrolled .logo .lt,header.scrolled nav.main a{color:var(--navy)}
  header.scrolled nav.main a{color:rgba(0,43,88,.72)}
  header.scrolled nav.main a:hover{color:var(--navy)}
  .navcta{display:none}
  header.scrolled .logo .lt span{opacity:.55}
  .menu-btn{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
  .menu-btn span{width:24px;height:2px;background:#fff;transition:.3s}
  header.scrolled .menu-btn span{background:var(--navy)}

  /* ---------- hero ---------- */
  .hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
  .hero .bg{position:absolute;inset:0;z-index:0}
  .hero .bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:heroZoom 14s var(--ease) forwards}
  @keyframes heroZoom{to{transform:scale(1)}}
  .hero .bg::after{content:"";position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(0,27,58,.78) 0%,rgba(0,27,58,.34) 38%,rgba(0,27,58,.62) 72%,rgba(0,17,38,.95) 100%);}
  .hero .grid-tex{position:absolute;inset:0;z-index:1;opacity:.5;
    background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
    background-size:64px 64px;mask-image:linear-gradient(180deg,transparent,#000 60%,#000)}
  .hero .inner{position:relative;z-index:2;padding-top:150px;padding-bottom:64px;width:100%}
  .hero .eyebrow{margin-bottom:26px}
  .hero h1{font-size:clamp(2.7rem,7vw,6rem);font-weight:800;max-width:15ch;text-transform:none}
  .hero h1 .mark{position:relative;color:var(--orange);display:inline-block}
  .hero h1 .mark svg{position:absolute;left:-2%;bottom:-.16em;width:104%;height:.4em;overflow:visible}
  .hero h1 .mark path{stroke:var(--orange);stroke-width:7;fill:none;stroke-linecap:round;
    stroke-dasharray:520;stroke-dashoffset:520;animation:draw 1s var(--ease) 1.1s forwards}
  @keyframes draw{to{stroke-dashoffset:0}}
  .hero p.sub{font-size:clamp(1.05rem,1.7vw,1.3rem);max-width:52ch;margin-top:28px;color:rgba(255,255,255,.86);font-weight:400}
  .hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
  .hero .scrollcue{position:absolute;right:28px;bottom:40px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;
    font-family:'IBM Plex Mono';font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);writing-mode:vertical-rl}
  .hero .scrollcue i{width:1px;height:46px;background:linear-gradient(var(--orange),transparent);position:relative;overflow:hidden}
  .hero .scrollcue i::after{content:"";position:absolute;top:-46px;left:0;width:1px;height:46px;background:var(--orange);animation:cue 2.2s linear infinite}
  @keyframes cue{to{top:46px}}

  /* ---------- reveal ---------- */
  .reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal[data-d="1"]{transition-delay:.08s}
  .reveal[data-d="2"]{transition-delay:.16s}
  .reveal[data-d="3"]{transition-delay:.24s}

  /* ---------- trust strip ---------- */
  .trust{background:var(--navy-900);color:#fff;border-top:1px solid rgba(255,255,255,.08)}
  .trust .row{display:grid;grid-template-columns:repeat(4,1fr)}
  .trust .item{display:flex;align-items:center;gap:14px;padding:30px 28px;position:relative}
  .trust .item + .item::before{content:"";position:absolute;left:0;top:28px;bottom:28px;width:1px;background:rgba(255,255,255,.12)}
  .trust .ti{width:42px;height:42px;border-radius:11px;background:rgba(228,8,126,.12);display:flex;align-items:center;justify-content:center;flex:none}
  .trust .ti svg{width:21px;height:21px;color:var(--orange)}
  .trust .l{font-family:'IBM Plex Mono';font-size:11.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.72);line-height:1.45}

  /* ---------- section base ---------- */
  section{position:relative}
  .pad{padding:clamp(72px,9vw,128px) 0}
  .head{max-width:62ch}
  .head h2{font-size:clamp(2rem,4.4vw,3.4rem);font-weight:800;margin-top:20px;color:var(--navy)}
  .head h2.light{color:#fff}
  .head p.lead{font-size:1.12rem;color:var(--muted);margin-top:18px;max-width:54ch}
  .head p.lead.light{color:rgba(255,255,255,.78)}

  /* ---------- leistungen ---------- */
  .leistungen{background:var(--concrete)}
  .cards{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:54px}
  .card{background:#fff;border-radius:var(--r);position:relative;
    border:1px solid var(--line);transition:transform .5s var(--ease),box-shadow .5s var(--ease);will-change:transform}
  .card:hover{transform:translateY(-7px);box-shadow:0 30px 50px -28px rgba(0,27,58,.4)}
  .card .ph{position:relative;aspect-ratio:16/10;overflow:hidden;border-radius:var(--r) var(--r) 0 0}
  .card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
  .card:hover .ph img{transform:scale(1.07)}
  .card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,27,58,.28))}
  .card .body{position:relative;padding:46px 26px 28px;background:#fff;border-radius:0 0 var(--r) var(--r)}
  .card .ic{position:absolute;left:26px;top:-28px;width:56px;height:56px;border-radius:14px;background:var(--navy);
    display:flex;align-items:center;justify-content:center;z-index:3;border:1px solid rgba(255,255,255,.12);
    box-shadow:0 18px 26px -14px rgba(0,27,58,.7)}
  .card .ic svg{width:27px;height:27px;color:var(--orange)}
  .card h3{font-size:1.42rem;font-weight:700;color:var(--navy)}
  .card .body>p{color:var(--muted);font-size:.97rem;margin-top:10px}
  .card ul{list-style:none;margin-top:18px;display:flex;flex-wrap:wrap;gap:9px}
  .card li{font-family:'IBM Plex Mono';font-size:11.5px;letter-spacing:.04em;color:var(--navy);
    background:var(--concrete-2);border:1px solid var(--line);padding:6px 11px;border-radius:7px}
  .card .num{position:absolute;top:16px;right:20px;z-index:2;font-family:'IBM Plex Mono';font-size:12px;
    color:rgba(255,255,255,.8);letter-spacing:.1em}

  /* ---------- ablauf / signature spine ---------- */
  .ablauf{background:var(--navy);color:#fff;overflow:hidden}
  .ablauf .grid-tex{position:absolute;inset:0;opacity:.4;
    background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
    background-size:54px 54px;mask-image:radial-gradient(120% 100% at 80% 0%,#000,transparent 75%)}
  .ablauf .wrap{position:relative;z-index:2}
  .spine{margin-top:60px;position:relative}
  .spine .track{position:absolute;left:31px;top:18px;bottom:18px;width:2px;background:rgba(255,255,255,.13)}
  .spine .track .fill{position:absolute;left:0;top:0;width:100%;height:0;background:linear-gradient(var(--orange),var(--orange-bright));transition:height .55s var(--ease)}
  .step{position:relative;display:grid;grid-template-columns:64px 1fr;gap:26px;padding:22px 0;align-items:start}
  .step .node{width:64px;height:64px;border-radius:16px;background:var(--navy-card);border:1px solid rgba(255,255,255,.14);
    display:flex;align-items:center;justify-content:center;position:relative;z-index:2;
    font-family:'IBM Plex Mono';font-weight:600;font-size:17px;color:rgba(255,255,255,.5);transition:.5s var(--ease)}
  .step .node .check{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:.45s var(--ease)}
  .step .node .check svg{width:28px;height:28px;color:var(--navy-900)}
  .step.done .node{background:var(--orange);border-color:var(--orange);color:transparent}
  .step.done .node .check{opacity:1;transform:scale(1)}
  .step .txt{padding-top:6px}
  .step .txt .ph{font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);opacity:.85}
  .step .txt h3{font-size:1.5rem;font-weight:700;margin-top:7px}
  .step .txt p{color:rgba(255,255,255,.72);margin-top:8px;max-width:60ch;font-size:1rem}
  .step.done .txt h3{color:#fff}

  /* ---------- werte ---------- */
  .werte{background:var(--concrete-2)}
  .vals{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
  .val{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px 30px;transition:.5s var(--ease);position:relative;overflow:hidden}
  .val::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--orange);transition:width .5s var(--ease)}
  .val:hover{transform:translateY(-6px);box-shadow:0 26px 44px -30px rgba(0,27,58,.45)}
  .val:hover::before{width:100%}
  .val .vic{width:54px;height:54px;border-radius:13px;background:var(--concrete);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
  .val .vic svg{width:27px;height:27px;color:var(--navy)}
  .val h3{font-size:1.3rem;color:var(--navy);font-weight:700}
  .val p{color:var(--muted);margin-top:11px;font-size:.98rem}

  /* ---------- über uns ---------- */
  .about{background:var(--navy-900);color:#fff;overflow:hidden}
  .about .split{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
  .about .pf{position:relative}
  .about .pf .frame{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.1)}
  .about .pf img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/4.3}
  .about .pf .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(190deg,transparent 55%,rgba(0,17,38,.7))}
  .about .pf .tag{position:absolute;left:20px;bottom:20px;z-index:2}
  .about .pf .tag b{font-family:'Archivo';font-weight:800;font-size:1.2rem;display:block}
  .about .pf .tag span{font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--orange)}
  .about .pf .badge{position:absolute;right:-14px;top:30px;background:var(--orange);color:var(--navy-900);border-radius:13px;
    padding:16px 18px;z-index:3;box-shadow:0 18px 30px -16px rgba(0,0,0,.6);max-width:150px}
  .about .pf .badge b{font-family:'Archivo';font-weight:800;font-size:1.7rem;display:block;line-height:1}
  .about .pf .badge span{font-family:'IBM Plex Mono';font-size:10px;letter-spacing:.08em;text-transform:uppercase;line-height:1.3;display:block;margin-top:5px}
  .about .txt h2{font-size:clamp(1.9rem,3.6vw,2.9rem);font-weight:800;margin-top:18px}
  .about .txt p{color:rgba(255,255,255,.8);margin-top:18px;font-size:1.06rem;max-width:58ch}
  .about .txt .quote{border-left:2px solid var(--orange);padding:4px 0 4px 22px;margin-top:26px;font-size:1.18rem;font-weight:500;color:#fff;font-style:normal}

  /* ---------- gruppe ---------- */
  .gruppe{background:var(--concrete)}
  .gtop{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
  .ggrid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:50px;position:relative}
  .ggrid::before{content:"AK GRUPPE";position:absolute;left:50%;top:-34px;transform:translateX(-50%);
    font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.3em;color:var(--navy);opacity:.5;background:var(--concrete);padding:0 14px;z-index:3}
  .gcol{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px 32px;position:relative;overflow:hidden}
  .gcol.active{background:var(--navy);color:#fff;border-color:var(--navy)}
  .gcol .kicker{font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
  .gcol h3{font-size:1.5rem;font-weight:700;margin-top:10px;color:var(--navy)}
  .gcol.active h3{color:#fff}
  .gcol .sub{font-size:.95rem;color:var(--muted);margin-top:6px}
  .gcol.active .sub{color:rgba(255,255,255,.7)}
  .gcol ul{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:11px}
  .gcol li{display:flex;align-items:center;gap:11px;font-size:.98rem}
  .gcol li svg{width:17px;height:17px;color:var(--orange);flex:none}
  .gcol .pill{position:absolute;top:26px;right:28px;font-family:'IBM Plex Mono';font-size:10.5px;letter-spacing:.1em;
    text-transform:uppercase;padding:6px 12px;border-radius:100px;border:1px solid var(--line);color:var(--muted)}
  .gcol.active .pill{border-color:rgba(255,255,255,.25);color:var(--orange)}

  /* ---------- cta band ---------- */
  .ctaband{background:var(--orange);color:var(--navy-900);position:relative;overflow:hidden}
  .ctaband .wrap{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;position:relative;z-index:2}
  .ctaband h2{font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:800;max-width:20ch}
  .ctaband .bigcheck{position:absolute;right:-40px;top:50%;transform:translateY(-50%);z-index:1;opacity:.16}
  .ctaband .bigcheck svg{width:340px;height:340px;color:var(--navy-900)}

  /* ---------- kontakt ---------- */
  .kontakt{background:var(--navy-900);color:#fff}
  .ksplit{display:grid;grid-template-columns:1fr 1fr;gap:54px}
  .kinfo .eyebrow{margin-bottom:22px}
  .kinfo h2{font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:800}
  .kinfo p.lead{color:rgba(255,255,255,.78);margin-top:18px;max-width:42ch}
  .kinfo .rows{margin-top:36px;display:flex;flex-direction:column;gap:6px}
  .kinfo .krow{display:flex;align-items:center;gap:16px;padding:15px 0;border-top:1px solid rgba(255,255,255,.1)}
  .kinfo .krow:last-child{border-bottom:1px solid rgba(255,255,255,.1)}
  .kinfo .krow .ki{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;flex:none}
  .kinfo .krow .ki svg{width:20px;height:20px;color:var(--orange)}
  .kinfo .krow .kt b{display:block;font-family:'Archivo';font-weight:700;font-size:1.02rem}
  .kinfo .krow .kt span{font-size:.85rem;color:rgba(255,255,255,.55);font-family:'IBM Plex Mono';letter-spacing:.04em}
  .kform{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:34px}
  .kform h3{font-family:'Archivo';font-weight:700;font-size:1.3rem;margin-bottom:6px}
  .kform .fnote{font-size:.86rem;color:rgba(255,255,255,.5);margin-bottom:24px}
  .field{margin-bottom:16px}
  .field label{display:block;font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:8px}
  .field input,.field select,.field textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);
    border-radius:10px;padding:13px 15px;color:#fff;font-family:inherit;font-size:.97rem;transition:.25s}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);background:rgba(255,255,255,.08)}
  .field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.35)}
  .field select option{background:var(--navy-900)}
  .frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .kform .btn{width:100%;justify-content:center;margin-top:6px}

  /* ---------- footer ---------- */
  footer{background:#00132b;color:rgba(255,255,255,.7);padding:64px 0 30px}
  footer .ftop{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
  footer .logo{display:flex;align-items:center;gap:12px;margin-bottom:20px}
  footer .logo img{height:40px}
  footer .logo b{font-family:'Archivo';font-weight:800;color:#fff;font-size:1rem;display:block;line-height:1.1}
  footer .logo span{font-family:'IBM Plex Mono';font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--orange)}
  footer .fcol p{font-size:.92rem;max-width:34ch}
  footer .fcol h4{font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:18px;font-weight:500}
  footer .fcol ul{list-style:none;display:flex;flex-direction:column;gap:11px}
  footer .fcol a{font-size:.94rem;transition:color .2s}
  footer .fcol a:hover{color:var(--orange)}
  footer .fbot{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:26px;font-size:.82rem;color:rgba(255,255,255,.45);font-family:'IBM Plex Mono';letter-spacing:.02em}
  footer .fbot a{color:rgba(255,255,255,.55)}
  footer .fbot a:hover{color:var(--orange)}
  .dummy{display:inline-block;background:rgba(228,8,126,.16);color:var(--orange);font-family:'IBM Plex Mono';font-size:10px;
    letter-spacing:.08em;padding:2px 8px;border-radius:5px;text-transform:uppercase;margin-left:4px}

  /* ---------- responsive ---------- */
  @media(max-width:900px){
    nav.main{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);background:var(--navy-900);flex-direction:column;
      justify-content:center;gap:26px;transform:translateX(100%);transition:transform .45s var(--ease);z-index:99;padding:40px}
    nav.main.open{transform:none}
    nav.main a{font-size:1.2rem;color:#fff!important}
    .menu-btn{display:flex}
    header.scrolled .menu-btn span{background:var(--navy)}
    header .logo .lt{display:none}
    .hero .scrollcue{display:none}
    nav.main .navcta{display:inline-flex;margin-top:10px;padding:14px 26px}
    nav.main .navcta svg{width:17px;height:17px}
    .cards,.vals,.ggrid,.ksplit,.about .split,footer .ftop{grid-template-columns:1fr}
    .trust .row{grid-template-columns:1fr 1fr}
    .trust .item + .item::before{display:none}
    .trust .item{border-top:1px solid rgba(255,255,255,.1)}
    .about .split{gap:36px}
    .about .pf .badge{right:14px}
    .frow{grid-template-columns:1fr}
    .ggrid::before{display:none}
  }
  @media(max-width:560px){
    .wrap{padding:0 18px}
    header .bar>.btn-primary{display:none}
    header .logo img{height:38px}
    .hero .inner{padding-top:116px;padding-bottom:48px}
    .hero .eyebrow{font-size:10px;letter-spacing:.13em}
    .hero h1{font-size:clamp(2.4rem,9vw,3.2rem)}
    .hero .cta{flex-direction:column;align-items:stretch}
    .hero .cta .btn{justify-content:center}
    .trust .row{grid-template-columns:1fr}
    .trust .item{padding:18px 6px;gap:13px}
    .trust .ti{width:38px;height:38px}
    .trust .l{font-size:11px}
    .pad{padding:64px 0}
    .head h2{font-size:clamp(1.8rem,7.5vw,2.4rem)}
    .step{grid-template-columns:52px 1fr;gap:18px}
    .step .node{width:52px;height:52px}
    .step .txt h3{font-size:1.3rem}
    .spine .track{left:25px}
    .ctaband .bigcheck{right:-90px;opacity:.12}
    .ctaband .bigcheck svg{width:240px;height:240px}
    .about .pf .badge{display:none}
    .about .pf .tag{left:16px;bottom:16px}
    .about .pf .tag b{font-size:1.05rem}
    .kform{padding:26px 20px}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important}
    .reveal{opacity:1;transform:none}
    .hero .bg img{transform:none}
  }

  /* ===== GM-specific ===== */
  .hero--graphic{align-items:center;background:radial-gradient(125% 95% at 82% -5%, #0a2549 0%, var(--navy-900) 52%, #00132b 100%)}
  .hero--graphic .inner{padding-top:172px;padding-bottom:88px}
  .herocheck{position:absolute;right:-7%;top:50%;transform:translateY(-50%);z-index:1;opacity:.085;color:var(--orange);pointer-events:none}
  .herocheck svg{width:min(72vw,860px);height:auto;display:block}
  .card.icard{overflow:hidden}
  .card.icard .itop{display:flex;align-items:center;justify-content:space-between;padding:30px 28px 0}
  .card.icard .ic{position:static;top:auto;left:auto;width:62px;height:62px;border-radius:16px;box-shadow:none}
  .card.icard .ic svg{width:30px;height:30px}
  .card.icard .num{position:static;color:var(--muted);font-family:'IBM Plex Mono';font-size:13px;letter-spacing:.1em}
  .card.icard .body{position:static;padding:22px 28px 32px;border-radius:0}
  .card.icard::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--orange);transition:width .55s var(--ease)}
  .card.icard:hover::after{width:100%}
  .statpanel{background:linear-gradient(160deg,var(--navy-card),var(--navy-900));border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .statpanel .stat{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:26px 20px;transition:.4s var(--ease)}
  .statpanel .stat:hover{border-color:rgba(228,8,126,.4)}
  .statpanel .stat b{font-family:'Archivo';font-weight:800;font-size:2rem;color:var(--orange);display:block;line-height:1}
  .statpanel .stat span{font-family:'IBM Plex Mono';font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.62);display:block;margin-top:11px;line-height:1.4}
  @media(max-width:560px){ .hero--graphic .inner{padding-top:120px} .herocheck{opacity:.07} }

  /* GM v2: stat band */
  .statband{background:var(--navy-900)}
  .statband .srow{display:grid;grid-template-columns:repeat(3,1fr)}
  .statband .sitem{text-align:center;padding:40px 24px;position:relative}
  .statband .sitem + .sitem::before{content:"";position:absolute;left:0;top:30px;bottom:30px;width:1px;background:rgba(255,255,255,.12)}
  .statband .sitem b{font-family:'Archivo';font-weight:800;font-size:3rem;color:var(--orange);display:block;line-height:1}
  .statband .sitem span{font-family:'IBM Plex Mono';font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.66);display:block;margin-top:13px}
  /* spezialleistungen */
  .spez{background:var(--concrete)}
  .spezgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:50px}
  .spezitem{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;transition:.5s var(--ease);position:relative;overflow:hidden}
  .spezitem::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--orange);transition:width .5s var(--ease)}
  .spezitem:hover{transform:translateY(-6px);box-shadow:0 24px 40px -30px rgba(0,27,58,.4)}
  .spezitem:hover::before{width:100%}
  .spezitem .si{width:52px;height:52px;border-radius:13px;background:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
  .spezitem .si svg{width:25px;height:25px;color:var(--orange)}
  .spezitem h3{font-size:1.14rem;color:var(--navy);font-weight:700;line-height:1.15}
  .spezitem p{color:var(--muted);font-size:.92rem;margin-top:9px}
  /* reviews */
  .reviews{background:var(--concrete-2)}
  .revgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
  .rev{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;display:flex;flex-direction:column;gap:15px;transition:.5s var(--ease)}
  .rev:hover{transform:translateY(-6px);box-shadow:0 26px 44px -30px rgba(0,27,58,.45)}
  .rev .stars{color:var(--orange);letter-spacing:4px;font-size:15px}
  .rev blockquote{font-size:1rem;color:var(--ink);line-height:1.62;font-weight:500}
  .rev figcaption{display:flex;align-items:center;gap:13px;margin-top:auto}
  .rev .ra{width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Archivo';font-weight:700;font-size:14px;flex:none}
  .rev .rn{font-family:'Archivo';font-weight:700;color:var(--navy);font-size:.98rem;line-height:1.2}
  .rev .rn small{display:block;font-family:'IBM Plex Mono';font-weight:400;font-size:10px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;margin-top:4px}
  .revnote{text-align:center;margin-top:34px;font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.04em;color:var(--muted)}
  @media(max-width:900px){ .revgrid{grid-template-columns:1fr 1fr} .spezgrid{grid-template-columns:1fr 1fr} }
  @media(max-width:560px){ .revgrid{grid-template-columns:1fr} .spezgrid{grid-template-columns:1fr}
    .statband .srow{grid-template-columns:1fr} .statband .sitem + .sitem::before{display:none}
    .statband .sitem{border-top:1px solid rgba(255,255,255,.1);padding:26px} .statband .sitem b{font-size:2.5rem} }

  /* social / whatsapp / instagram */
  .fsocial{display:flex;gap:12px;margin-top:24px}
  .fsocial a{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:.3s var(--ease)}
  .fsocial a:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-3px)}
  .fsocial a svg{width:19px;height:19px;color:#fff}
  .fsocial a:hover svg{color:var(--navy-900)}
  .wafab{position:fixed;right:22px;bottom:22px;z-index:90;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px -8px rgba(37,211,102,.65);transition:transform .35s var(--ease)}
  .wafab:hover{transform:scale(1.08)}
  .wafab svg{width:31px;height:31px;color:#fff}
  .insta{background:var(--navy-900);color:#fff;overflow:hidden}
  .insta .ihead{display:flex;align-items:flex-end;justify-content:space-between;gap:26px;flex-wrap:wrap;margin-bottom:46px}
  .insta h2{font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:800;color:#fff;margin:14px 0 10px}
  .insta .handle{font-family:'IBM Plex Mono';font-size:13px;letter-spacing:.05em;color:var(--orange)}
  .igrid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
  .itile{aspect-ratio:1;border-radius:13px;overflow:hidden;position:relative;background:linear-gradient(150deg,var(--navy-card),#001b3a);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:.4s var(--ease)}
  .itile:hover{transform:translateY(-4px);border-color:rgba(228,8,126,.55)}
  .itile>svg{width:34px;height:34px;color:rgba(255,255,255,.16)}
  .itile .ig-ic{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;background:rgba(228,8,126,.22);transition:.3s}
  .itile:hover .ig-ic{opacity:1}
  .itile .ig-ic svg{width:26px;height:26px;color:#fff}
  .insta .inote{margin-top:26px;text-align:center;font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.04em;color:rgba(255,255,255,.5)}
  @media(max-width:900px){ .igrid{grid-template-columns:repeat(3,1fr)} }
  @media(max-width:560px){ .igrid{grid-template-columns:repeat(2,1fr)} .wafab{width:54px;height:54px;right:16px;bottom:16px} }

  /* reviews slider (solid + swipeable) */
  .rev-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
  .ragg{display:inline-flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:15px;padding:16px 24px;box-shadow:0 18px 40px -30px rgba(0,27,58,.45)}
  .ragg .rnum{font-family:'Archivo';font-weight:800;font-size:2.4rem;color:var(--navy);line-height:1}
  .ragg .rstars{color:var(--orange);letter-spacing:3px;font-size:17px}
  .ragg .rlabel{font-family:'IBM Plex Mono';font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);display:block;margin-top:6px}
  .revwrap{margin-top:48px;overflow:hidden}
  .revslider{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:10px max(28px,calc((100% - 1200px)/2 + 28px))}
  .revslider::-webkit-scrollbar{display:none}
  .rev{scroll-snap-align:start;flex:0 0 auto;width:min(380px,82vw);background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px 30px;display:flex;flex-direction:column;gap:16px;position:relative;box-shadow:0 16px 44px -34px rgba(0,27,58,.55);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
  .rev:hover{transform:translateY(-5px);box-shadow:0 30px 54px -34px rgba(0,27,58,.5)}
  .rev .qmark{position:absolute;top:10px;right:24px;font-family:Georgia,'Times New Roman',serif;font-weight:700;font-size:4.4rem;line-height:1;color:rgba(228,8,126,.13);pointer-events:none}
  .rev .rev-h{display:flex;align-items:center;gap:10px}
  .rev .stars{color:var(--orange);letter-spacing:3px;font-size:15px}
  .rev .gtag{font-family:'IBM Plex Mono';font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:6px;padding:4px 9px}
  .rev blockquote{font-size:1.02rem;color:var(--ink);line-height:1.6;font-weight:500;position:relative;z-index:1}
  .rev figcaption{display:flex;align-items:center;gap:13px;margin-top:auto}
  .rev .ra{width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Archivo';font-weight:700;font-size:15px;flex:none}
  .rev .rn b{font-family:'Archivo';font-weight:700;color:var(--navy);font-size:1rem;display:flex;align-items:center;gap:6px}
  .rev .rn .vchk{width:15px;height:15px;color:var(--orange);flex:none}
  .rev .rn small{display:block;font-family:'IBM Plex Mono';font-weight:400;font-size:10px;letter-spacing:.05em;color:var(--muted);text-transform:uppercase;margin-top:4px}
  .revctrl{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:32px}
  .revnav{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.3s var(--ease);color:var(--navy);flex:none}
  .revnav:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-2px)}
  .revnav svg{width:20px;height:20px}
  .revdots{display:flex;gap:8px;align-items:center}
  .rdot{width:8px;height:8px;border-radius:50%;border:none;background:rgba(0,43,88,.18);cursor:pointer;padding:0;transition:.3s var(--ease)}
  .rdot.on{background:var(--orange);width:24px;border-radius:5px}
  .revnote{text-align:center;margin-top:24px;font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.03em;color:var(--muted)}
  @media(max-width:560px){ .rev{width:84vw;padding:28px 24px} .ragg{padding:13px 18px} .ragg .rnum{font-size:2rem} .rev-head{gap:18px} }

  /* spez photo cards */
  .spezgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px}
  .spezcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.5s var(--ease)}
  .spezcard:hover{transform:translateY(-6px);box-shadow:0 26px 44px -30px rgba(0,27,58,.42)}
  .spezcard .sph{aspect-ratio:16/10;overflow:hidden;position:relative}
  .spezcard .sph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
  .spezcard:hover .sph img{transform:scale(1.06)}
  .spezcard .sph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 52%,rgba(0,27,58,.4))}
  .spezcard .si{position:absolute;left:18px;bottom:14px;width:46px;height:46px;border-radius:12px;background:var(--navy);display:flex;align-items:center;justify-content:center;z-index:2;border:1px solid rgba(255,255,255,.12)}
  .spezcard .si svg{width:23px;height:23px;color:var(--orange)}
  .spezcard .sbody{padding:22px 24px 26px}
  .spezcard h3{font-size:1.16rem;color:var(--navy);font-weight:700;line-height:1.15}
  .spezcard p{color:var(--muted);font-size:.93rem;margin-top:9px}
  @media(max-width:900px){ .spezgrid{grid-template-columns:1fr 1fr} }
  @media(max-width:560px){ .spezgrid{grid-template-columns:1fr} }

  /* drohne highlight */
  .drohne{background:radial-gradient(120% 90% at 85% 0%, #0a2549 0%, var(--navy-900) 55%, #00132b 100%);color:#fff;position:relative;overflow:hidden}
  .dro-top{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;position:relative;z-index:1}
  .neutag{display:inline-flex;align-items:center;gap:9px;font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:#fff;background:var(--orange);padding:8px 15px;border-radius:999px;font-weight:600}
  .neutag svg{width:18px;height:18px;color:#fff}
  .dro-intro h2.light{margin:22px 0 16px;font-size:clamp(2rem,4vw,3.1rem)}
  .dro-intro .hl{color:var(--orange)}
  .dro-chips{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0 30px}
  .dro-chips span{font-family:'IBM Plex Mono';font-size:12px;letter-spacing:.03em;color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:8px 16px}
  .dro-media{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.12);aspect-ratio:4/5;box-shadow:0 40px 80px -40px rgba(0,0,0,.7)}
  .dro-media img{width:100%;height:100%;object-fit:cover}
  .dro-badge{position:absolute;left:18px;top:18px;display:inline-flex;align-items:center;gap:9px;background:rgba(0,19,43,.74);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.16);color:#fff;font-family:'IBM Plex Mono';font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:9px 14px;border-radius:11px}
  .dro-badge svg{width:18px;height:18px;color:var(--orange)}
  .dro-model{position:relative;z-index:1;margin-top:64px;text-align:center}
  .dro-model .eyebrow{justify-content:center;color:var(--orange)}
  .dro-model .eyebrow::before{background:var(--orange)}
  .dmodel-h{color:#fff;font-family:'Archivo';font-weight:800;font-size:clamp(1.5rem,3vw,2.1rem);margin-top:12px}
  .dro-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px;position:relative;z-index:1}
  .dstep{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:30px 26px;position:relative}
  .dstep .dn{font-family:'Archivo';font-weight:800;font-size:2.5rem;color:var(--orange);display:block;line-height:1}
  .dstep h3{color:#fff;font-size:1.18rem;margin:12px 0 9px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
  .dstep h3 em{font-style:normal;font-family:'IBM Plex Mono';font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.22);border-radius:5px;padding:3px 7px}
  .dstep p{color:rgba(255,255,255,.72);font-size:.95rem;line-height:1.55}
  .dstep:not(:last-child)::after{content:"";position:absolute;right:-13px;top:54%;width:13px;height:13px;border-top:2px solid var(--orange);border-right:2px solid var(--orange);transform:translateY(-50%) rotate(45deg);opacity:.55}
  @media(max-width:860px){ .dro-top{grid-template-columns:1fr;gap:32px} .dro-media{aspect-ratio:16/11;order:-1} .dro-steps{grid-template-columns:1fr} .dstep:not(:last-child)::after{display:none} }

  /* drohne highlight v2 (cinematic banner) */
  .drohne{position:relative;background:var(--navy-900)}
  .dro-banner{position:relative;min-height:clamp(560px,74vh,800px);display:flex;align-items:center;overflow:hidden}
  .dro-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:64% center}
  .dro-scrim{position:absolute;inset:0;background:linear-gradient(95deg,rgba(0,19,43,.95) 0%,rgba(0,19,43,.74) 34%,rgba(0,19,43,.22) 58%,rgba(0,19,43,0) 100%)}
  .dro-overlay{position:relative;z-index:2;max-width:660px;padding-top:48px;padding-bottom:48px}
  .neutag{display:inline-flex;align-items:center;gap:9px;font-family:'IBM Plex Mono';font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--orange);padding:9px 17px;border-radius:999px;font-weight:600;box-shadow:0 10px 30px -10px rgba(228,8,126,.7)}
  .neutag svg{width:19px;height:19px;color:#fff}
  .dro-overlay h2{font-family:'Archivo';font-weight:800;color:#fff;font-size:clamp(2.3rem,5.4vw,4rem);line-height:1.02;letter-spacing:-.02em;margin:24px 0 18px}
  .dro-overlay .hl{color:var(--orange)}
  .dro-overlay p{color:rgba(255,255,255,.88);font-size:1.1rem;line-height:1.55;max-width:48ch}
  .dro-chips{display:flex;flex-wrap:wrap;gap:10px;margin:28px 0 32px}
  .dro-chips span{font-family:'IBM Plex Mono';font-size:12px;letter-spacing:.03em;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:9px 17px;backdrop-filter:blur(3px)}
  .btn-lg{padding:18px 34px;font-size:1.02rem}
  .dro-steps-band{position:relative;background:var(--navy-900);padding:clamp(60px,7.5vw,96px) 0;overflow:hidden}
  .dro-model{position:relative;z-index:1;text-align:center}
  .dro-model .eyebrow{justify-content:center;color:var(--orange)}
  .dro-model .eyebrow::before{background:var(--orange)}
  .dmodel-h{color:#fff;font-family:'Archivo';font-weight:800;font-size:clamp(1.6rem,3vw,2.3rem);margin-top:12px}
  .dro-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:46px;position:relative;z-index:1}
  .dstep{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:32px 28px;position:relative}
  .dstep .dn{font-family:'Archivo';font-weight:800;font-size:2.6rem;color:var(--orange);display:block;line-height:1}
  .dstep h3{color:#fff;font-size:1.2rem;margin:13px 0 9px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
  .dstep h3 em{font-style:normal;font-family:'IBM Plex Mono';font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.22);border-radius:5px;padding:3px 7px}
  .dstep p{color:rgba(255,255,255,.72);font-size:.95rem;line-height:1.55}
  .dstep:not(:last-child)::after{content:"";position:absolute;right:-13px;top:54%;width:13px;height:13px;border-top:2px solid var(--orange);border-right:2px solid var(--orange);transform:translateY(-50%) rotate(45deg);opacity:.55}
  @media(max-width:860px){
    .dro-banner{min-height:560px}
    .dro-bg{object-position:68% center}
    .dro-scrim{background:linear-gradient(180deg,rgba(0,19,43,.5) 0%,rgba(0,19,43,.82) 70%,rgba(0,19,43,.92) 100%)}
    .dro-overlay{max-width:none}
    .dro-steps{grid-template-columns:1fr}
    .dstep:not(:last-child)::after{display:none}
  }

/* IG tiles as real photos */
.itile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.itile .ig-ic{z-index:2}
/* ===== Legal pages ===== */
.legal-wrap{max-width:820px;margin:0 auto;padding:140px 24px 90px}
.legal-wrap h1{font-size:clamp(2rem,5vw,2.8rem);color:var(--navy);margin-bottom:8px}
.legal-wrap .back{display:inline-flex;align-items:center;gap:7px;font-family:'IBM Plex Mono';font-size:13px;letter-spacing:.04em;color:var(--orange);text-decoration:none;margin-bottom:30px}
.legal-wrap .back:hover{text-decoration:underline}
.legal-wrap h2{font-size:1.3rem;color:var(--navy);margin:38px 0 12px;font-family:'Archivo'}
.legal-wrap h3{font-size:1.05rem;color:var(--navy);margin:24px 0 8px}
.legal-wrap p,.legal-wrap li{color:var(--ink);line-height:1.7;font-size:1rem}
.legal-wrap ul{margin:10px 0 10px 22px}
.legal-wrap a{color:var(--orange)}
.legal-wrap .todo{background:#FCE4F0;border:1px dashed var(--orange);border-radius:8px;padding:2px 8px;font-family:'IBM Plex Mono';font-size:.85em;color:#9a0a55}
.legal-wrap .muted-note{background:var(--concrete-2,#f3f4f6);border-left:3px solid var(--orange);border-radius:6px;padding:14px 18px;font-size:.92rem;color:var(--muted);margin:24px 0}
.legal-foot{border-top:1px solid var(--line);padding:30px 24px;text-align:center;font-size:.85rem;color:var(--muted)}
.legal-foot a{color:var(--muted)}
.legal-page #hdr{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0}
.legal-page #hdr .lw{display:none}.legal-page #hdr .lc{display:block}
.legal-page #hdr .lt b{color:var(--navy)}.legal-page #hdr .lt span{color:var(--muted)}
.legal-page{background:#fff}

/* ===== WhatsApp Auswahl-Overlay ===== */
.wa-modal{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:20px}
.wa-modal[hidden]{display:none}
.wa-backdrop{position:absolute;inset:0;background:rgba(0,17,38,.6);backdrop-filter:blur(3px)}
.wa-sheet{position:relative;z-index:1;width:min(460px,100%);background:#fff;border-radius:20px;padding:26px 24px 28px;box-shadow:0 30px 80px -20px rgba(0,17,38,.55);animation:waIn .28s ease}
@keyframes waIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.wa-x{position:absolute;right:14px;top:10px;background:none;border:none;font-size:28px;line-height:1;color:var(--muted);cursor:pointer}
.wa-top{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px;padding-right:20px}
.wa-badge{flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center}
.wa-badge svg{width:26px;height:26px;color:#fff}
.wa-titles b{font-family:'Archivo';font-weight:800;font-size:1.15rem;color:var(--navy);display:block}
.wa-titles span{font-size:.92rem;color:var(--muted);display:block;margin-top:3px;line-height:1.45}
.wa-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.wa-opt{font-family:'Hanken Grotesk',sans-serif;font-size:.95rem;font-weight:600;color:var(--navy);background:#f4f5f7;border:1px solid var(--line);border-radius:12px;padding:14px 12px;cursor:pointer;transition:background .2s,border-color .2s,color .2s,transform .2s}
@media(hover:hover){.wa-opt:hover{background:var(--orange);border-color:var(--orange);color:#fff;transform:translateY(-1px)}}
.wa-opt--wide{grid-column:1/-1}
@media(max-width:560px){ .wa-modal{align-items:flex-end;padding:0} .wa-sheet{width:100%;border-radius:20px 20px 0 0;padding-bottom:34px} }

/* WhatsApp Overlay – Schritt 2 (Daten) */
.wa-step[hidden]{display:none}
.wa-back{background:none;border:none;color:var(--muted);font:inherit;font-size:.9rem;font-weight:600;cursor:pointer;padding:0;margin-bottom:14px}
.wa-back:hover{color:var(--navy)}
.wa-chosen{font-size:.9rem;color:var(--muted);background:#f4f5f7;border:1px solid var(--line);border-radius:10px;padding:10px 14px;margin-bottom:14px}
.wa-chosen strong{color:var(--orange)}
.wa-fields{display:flex;flex-direction:column;gap:10px}
.wa-fields input{font:inherit;font-family:'Hanken Grotesk',sans-serif;font-size:1rem;color:var(--navy);background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 15px;width:100%}
.wa-fields input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(228,8,126,.12)}
.wa-send{margin-top:16px;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:10px;background:#25D366;color:#fff;border:none;border-radius:12px;padding:15px 18px;font:inherit;font-weight:700;font-size:1rem;cursor:pointer;transition:opacity .2s,transform .2s}
.wa-send svg{width:20px;height:20px}
.wa-send:disabled{opacity:.45;cursor:not-allowed}
.wa-send:not(:disabled):hover{transform:translateY(-1px)}
