@font-face{font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;src:url('fonts/InterVariable.woff2') format('woff2');font-named-instance:'Regular'}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:100 800;font-display:swap;src:url('fonts/JetBrainsMono.woff2') format('woff2')}
/* ============================================================
   unterlagen.ai — design system used by onboarding/status/impressum.
   The visual spec lives in DESIGN.md at the repo root.

   Tokens here mirror the values in index.html's inline <style> so the
   landing and the funnel render the same hairlines, the same green
   (#1f8a3b — "done"/confidence only), the same Apple-blue accent
   (#2c75fe), the same max-width (1180px). Inter + JetBrains Mono are
   self-hosted from ./fonts/. No all-caps anywhere.
   ============================================================ */
:root{
  --paper:     #FFFFFF;   /* page — white */
  --paper-2:   #f6f7f9;   /* the "sunk" sections — a whisper of cool grey, recessed */
  --paper-3:   #eef0f4;   /* faint fills, chips, insets */
  --surface:   #FFFFFF;   /* cards / panels — white, lifted by a hairline + soft shadow */
  --ink:       #14151A;   /* headlines, primary text */
  --ink-2:     #2B2C32;
  --ink-soft:  #45474E;   /* body copy — dark grey */
  --ink-mute:  #74767C;   /* labels, captions, monospace metadata */
  --ink-faint: #7E8085;   /* fine print — darkened for readability/contrast */
  --line:      rgba(20,21,26,.10);
  --line-2:    rgba(20,21,26,.16);
  --line-on-dark: rgba(255,255,255,.14);
  --ok:        #1f8a3b;
  --ok-bg:     rgba(31,138,59,.10);
  --ok-line:   rgba(31,138,59,.30);
  --err:       #C5391F;

  --accent:      #2c75fe;
  --accent-ink:  #1b66f4;   /* hover / active — darker on light */
  --accent-soft: rgba(44,117,254,.10);
  --accent-line: rgba(44,117,254,.30);
  --gold:        var(--ink-mute);  --gold-line:var(--line-2);  --gold-bg:var(--paper-2);

  --radius:    16px;
  --radius-sm: 11px;
  --radius-lg: 22px;
  --radius-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(16,18,24,.05), 0 4px 16px rgba(16,18,24,.06);
  --shadow-md: 0 2px 4px rgba(16,18,24,.06), 0 14px 40px rgba(16,18,24,.10);
  --shadow-lg: 0 8px 24px rgba(16,18,24,.10), 0 30px 80px rgba(16,18,24,.16);

  --maxw:  1180px;
  --readw: 600px;
  --gutter: clamp(1.25rem, .7rem + 2.8vw, 3.5rem);

  --ease:     cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --sans: "Inter","Inter Variable",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{ font-family:var(--sans); font-optical-sizing:auto; font-size:1.0625rem; line-height:1.6; color:var(--ink-soft); background:var(--paper);
  background-image:radial-gradient(ellipse 100% 56% at 50% -10%, rgba(20,21,26,.02), transparent 66%);
  background-repeat:no-repeat; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden; }
body::after{ content:""; position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:.02; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
@media (prefers-reduced-motion: reduce){ body::after{ display:none; } }
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
.linkish:visited,.src:visited,.footer-links a:visited{ color:var(--ink-mute); }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
ul,ol{ list-style:none; }
::selection{ background:var(--accent); color:#fff; }
*:focus-visible{ outline:2px solid var(--ink); outline-offset:3px; }
.skip-link{ position:fixed; left:-9999px; top:0; z-index:200; background:var(--ink); color:#fff; padding:.7em 1.2em; border-radius:0 0 10px 0; font-weight:600; font-size:.95rem; }
.skip-link:focus{ left:0; }

/* ---------- Type ---------- */
h1,h2,h3,h4{ color:var(--ink); font-weight:500; line-height:1.06; letter-spacing:-.025em; }
h1{ font-size:clamp(3rem, 1.6rem + 6.4vw, 6.4rem); line-height:1; letter-spacing:-.04em; }
h2{ font-size:clamp(2.1rem, 1.4rem + 3.2vw, 4rem); line-height:1.05; letter-spacing:-.032em; }
h3{ font-size:1.32rem; font-weight:600; letter-spacing:-.016em; line-height:1.25; }
h4{ font-size:1.05rem; font-weight:600; }
p{ max-width:var(--readw); }
strong{ color:var(--ink); font-weight:600; }
em{ font-style:italic; }
.eyebrow{ display:inline-flex; align-items:center; gap:.7em; font-family:var(--mono); font-size:.74rem; font-weight:500; letter-spacing:.04em; color:var(--accent); }
.eyebrow::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(44,117,254,.16); flex:none; }
.lead{ font-size:clamp(1.1rem,1rem + .35vw,1.3rem); line-height:1.55; color:var(--ink-soft); }
.tnum{ font-variant-numeric:tabular-nums; }
.metafont{ font-family:var(--mono); font-size:.74rem; font-weight:500; letter-spacing:.07em; color:var(--ink-mute); }
.textlink{ display:inline-flex; align-items:center; gap:.5em; font-size:.92rem; font-weight:500; color:var(--ink-mute); transition:color .2s; }
.textlink:hover{ color:var(--ink); }
.textlink .arr{ transition:transform .25s var(--ease-out); }
.textlink:hover .arr{ transform:translateX(3px); }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.narrow{ max-width:760px; }
section{ padding-block:clamp(4.5rem, 3rem + 4vw, 8rem); position:relative; isolation:isolate; }
section > .wrap{ position:relative; z-index:1; }
.section-glow::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:0; }
.divider{ border:0; border-top:1px solid var(--line); }
.bg-sunk{ background:var(--paper-2); }
.center{ text-align:center; } .center p{ margin-inline:auto; }
.section-head{ display:grid; grid-template-columns:1fr; gap:1.6rem; margin-bottom:clamp(2.8rem,2rem + 2.6vw,4.4rem); }
.section-head h2, .section-head .sh-l h2, .section-head .sh-l h3{ margin:0; }
.section-head .sh-r{ display:flex; flex-direction:column; gap:clamp(1.5rem,1rem + 2vw,2.4rem); }
.section-head .sh-r p{ font-size:clamp(1.05rem,1rem + .3vw,1.22rem); color:var(--ink-soft); line-height:1.55; margin:0; max-width:46ch; }
.section-head .sh-tag{ font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; color:var(--ink-mute); display:inline-flex; align-items:center; gap:.7em; }
.section-head .sh-tag .sh-n{ color:var(--ink-faint); }
.section-head .sh-tag .sh-ar{ color:var(--ink-faint); }
@media (min-width:861px){
  .section-head{ grid-template-columns:minmax(0,1.18fr) minmax(0,1fr); gap:clamp(2.5rem,1rem + 5vw,7rem); align-items:start; }
}

/* ---------- Buttons — sharp rectangle, no bounce ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5em; font-size:1.06rem; font-weight:550;
  padding:.95em 1.7em; border-radius:999px; transition:background-color .2s, color .2s, border-color .2s, box-shadow .2s, transform .18s; white-space:nowrap; }
.btn .arr{ transition:transform .3s var(--ease-out); }
.btn .btn-ic{ width:17px; height:17px; stroke:currentColor; stroke-width:1.8; fill:none; stroke-linecap:round; stroke-linejoin:round; flex:none; }
.btn:hover .arr{ transform:translateX(3px); }
.btn:active{ transform:translateY(1px); }
.btn-primary,.btn-accent,.btn-ink{ background:var(--accent); color:#fff; box-shadow:0 1px 2px rgba(20,30,80,.2),0 8px 24px rgba(44,117,254,.32); }
.btn-primary:hover,.btn-accent:hover,.btn-ink:hover{ background:#1b66f4; transform:translateY(-1px); box-shadow:0 2px 4px rgba(20,30,80,.22),0 12px 30px rgba(44,117,254,.4); }
.btn-ghost{ background:var(--surface); color:var(--ink); border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ background:var(--paper-2); transform:translateY(-1px); }
.btn-on-dark{ background:var(--ink); color:#fff; } .btn-on-dark:hover{ box-shadow:0 8px 26px rgba(20,21,26,.22); }
.btn-lg{ /* alias — base .btn is already this size; kept for existing markup */ }
.btn-sm{ padding:.62em 1.2em; font-size:.92rem; }
/* mobile: bump button vertical padding 25% — bigger touch targets on phones */
@media (max-width:760px){
  .btn{ padding-top:1.19em; padding-bottom:1.19em; }
  .btn-sm{ padding-top:.775em; padding-bottom:.775em; }
  .fileitem .fbtn{ padding-top:.5625em; padding-bottom:.5625em; }
  .copy-btn{ padding-top:.5em; padding-bottom:.5em; }
}
.btn-block{ width:100%; }
.btn:disabled,.btn[disabled]{ opacity:.4; cursor:not-allowed; transform:none !important; box-shadow:none !important; }
.linkish{ color:var(--accent-ink); font-weight:500; border-bottom:1px solid var(--accent-line); transition:border-color .2s; }
.linkish:hover{ border-color:var(--accent-ink); }

/* ---------- Nav ---------- */
.nav{ position:fixed; inset:clamp(.5rem,.3rem + .5vw,.9rem) 0 auto 0; z-index:100; padding-inline:clamp(.8rem,.4rem + 1.6vw,1.4rem); pointer-events:none; transition:transform .4s var(--ease); }
.nav.hidden{ transform:translateY(calc(-100% - 3rem)); }
.nav-island{ pointer-events:auto; position:relative; max-width:1100px; margin-inline:auto; display:flex; align-items:center; gap:1rem;
  padding:.42rem .5rem .42rem 1.1rem; border-radius:999px; background:rgba(255,255,255,.74);
  -webkit-backdrop-filter:saturate(180%) blur(14px); backdrop-filter:saturate(180%) blur(14px);
  box-shadow:0 1px 2px rgba(20,21,26,.05), 0 8px 28px rgba(20,21,26,.10); border:1px solid rgba(20,21,26,.08); }
.nav.scrolled .nav-island{ background:rgba(255,255,255,.88); box-shadow:0 1px 2px rgba(20,21,26,.06), 0 14px 36px rgba(20,21,26,.13); border-color:rgba(20,21,26,.10); }
.brand{ display:inline-flex; align-items:center; gap:10px; font-weight:680; font-size:1.16rem; color:var(--ink); letter-spacing:-.03em; flex:none; padding-block:.4em; }
.brand .dot{ width:9px; height:9px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(44,117,254,.28); position:relative; top:1px; flex:none; animation:brandBreathe 3.4s ease-in-out infinite; }
@keyframes brandBreathe{ 0%,100%{ box-shadow:0 0 0 4px rgba(44,117,254,.3); } 50%{ box-shadow:0 0 0 6.5px rgba(44,117,254,.09); } }
.nav-collapse{ display:flex; align-items:center; gap:.3rem; margin-left:auto; }
.nav-menu{ display:flex; align-items:center; gap:.05rem; }
.nav-link{ padding:.5em .8em; border-radius:7px; font-size:.93rem; font-weight:500; color:var(--ink-soft); transition:color .2s, background-color .2s; white-space:nowrap; }
.nav-link:hover{ color:var(--ink); background:rgba(20,21,26,.05); }
.nav-collapse .btn{ margin-left:.4rem; }
.menu-btn{ display:none; width:44px; height:44px; border-radius:9px; align-items:center; justify-content:center; flex-direction:column; gap:5px; margin-left:auto; flex:none; transition:background-color .2s; }
.menu-btn:hover{ background:rgba(20,21,26,.05); }
.menu-btn span{ width:18px; height:1.7px; background:var(--ink-2); border-radius:2px; transition:transform .3s var(--ease), opacity .2s; }
.menu-btn[aria-expanded="true"] span:nth-child(1){ transform:translateY(3.3px) rotate(45deg); }
.menu-btn[aria-expanded="true"] span:nth-child(2){ transform:translateY(-3.3px) rotate(-45deg); }
@media (max-width:900px){
  .menu-btn{ display:flex; }
  .nav-collapse{ position:absolute; top:calc(100% + .5rem); right:0; left:0; flex-direction:column; align-items:stretch; gap:.15rem;
    background:rgba(255,255,255,.98); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px); border-radius:12px; padding:.7rem; box-shadow:0 12px 36px rgba(20,21,26,.14); border:1px solid rgba(20,21,26,.08);
    transform-origin:top; transition:opacity .22s, transform .22s, visibility .22s; opacity:0; visibility:hidden; transform:scaleY(.97) translateY(-6px); pointer-events:none; }
  .nav.open .nav-collapse{ opacity:1; visibility:visible; transform:none; pointer-events:auto; }
  .nav-menu{ flex-direction:column; align-items:stretch; gap:.1rem; }
  .nav-collapse .nav-link{ padding:1.05em 1rem; border-radius:8px; font-size:1rem; min-height:44px; display:flex; align-items:center; }
  .nav-collapse .btn{ width:100%; margin:.35rem 0 0; justify-content:center; min-height:46px; }
  .nav-island > .nav-link{ min-height:44px; display:inline-flex; align-items:center; }
}
@media (prefers-reduced-motion: reduce){ .nav,.nav-collapse{ transition:none; } .menu-btn span{ transition:none; } }

/* ---------- HERO — type + CTA, almost nothing else ---------- */
.hero{ padding-top:clamp(8.5rem,6.5rem + 7vw,13rem); padding-bottom:clamp(2.2rem,1.6rem + 1.8vw,3.4rem); overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2.8rem,2rem + 2.5vw,4rem); }
.hero-copy .eyebrow{ margin-bottom:1.6rem; }
.hero h1{ margin:0; max-width:22ch; font-size:clamp(2rem, 1rem + 4.6vw, 6.2rem); line-height:1.03; }
.hero h1 em{ font-style:normal; white-space:nowrap; }
.hero-pitch{ margin:1.8rem 0 0; max-width:660px; font-size:clamp(1.2rem,1.05rem + .55vw,1.5rem); font-weight:400; color:var(--ink-2); line-height:1.4; }
.hero-pitch strong{ font-weight:600; }
.hero-trust{ margin:1.8rem 0 0; font-size:.95rem; color:var(--ink-mute); display:inline-flex; align-items:center; gap:.7rem; flex-wrap:wrap; }
.hero-trust .ihk-tag{ display:inline-flex; align-items:center; gap:.5em; font-weight:600; color:var(--ink); background:var(--accent-soft); border:1px solid var(--accent-line); padding:.4em .85em; border-radius:var(--radius-pill); }
.hero-trust .ihk-tag::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--accent-ink); flex:none; box-shadow:0 0 8px rgba(44,117,254,.7); }
.hero .lead{ margin:1.6rem 0 0; max-width:520px; font-size:1.06rem; color:var(--ink-soft); }
.hero-facts{ margin-top:1.6rem; display:flex; flex-wrap:wrap; gap:.55rem 1.8rem; }
.hero-facts li{ display:flex; align-items:center; gap:.6em; font-size:.92rem; font-weight:500; color:var(--ink-soft); }
.hero-facts li::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--accent-ink); flex:none; }
.hero-facts li svg{ display:none; }
.hero-cta{ margin-top:2.2rem; display:flex; flex-wrap:wrap; gap:.8rem 1rem; }
.hero-note{ margin-top:1.6rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; color:var(--ink-mute); }
.hero-in{ opacity:0; transform:translateY(20px); animation:heroIn 1s var(--ease-out) forwards; }
@keyframes heroIn{ to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .hero-in{ opacity:1 !important; transform:none !important; animation:none !important; } }
@media (min-width:921px){
  .hero-grid{ grid-template-columns:minmax(0,1fr) minmax(0,440px); gap:clamp(2.5rem,1rem + 4vw,5.5rem); align-items:center; }
}

/* ---------- THE "01 → 02 → 03" FLOW — the centrepiece ---------- */
.steps{ counter-reset:step; display:grid; grid-template-columns:repeat(3,1fr); gap:0; position:relative; }
.step{ position:relative; padding:0 clamp(1rem,.5rem + 1.6vw,2.4rem); }
.step:first-child{ padding-left:0; } .step:last-child{ padding-right:0; }
.step .num{ counter-increment:step; display:inline-block; position:relative; z-index:1; font-family:var(--sans); font-feature-settings:"tnum"; font-size:clamp(2.6rem,2rem + 1.6vw,3.6rem); font-weight:600; color:var(--ink); letter-spacing:-.04em; line-height:1; background:var(--paper); padding-right:.55em; }
.bg-sunk .step .num{ background:var(--paper-2); }
.step .num::before{ content:counter(step,decimal-leading-zero); }
.step .step-ico{ margin:1.6rem 0 1.2rem; width:clamp(60px,4vw + 40px,86px); height:auto; }
.step .step-ico{ display:none; }
.step h3{ font-size:clamp(1.2rem,1rem + .7vw,1.6rem); font-weight:600; letter-spacing:-.015em; margin-top:clamp(1.6rem,1.2rem + 1vw,2.4rem); margin-bottom:.5rem; }
.step p{ font-size:1rem; color:var(--ink-soft); max-width:24ch; line-height:1.5; }
.loop-note{ display:flex; align-items:center; gap:.65em; margin-top:clamp(1.8rem,1.2rem + 1.6vw,2.6rem); font-size:.96rem; color:var(--ink-mute); }
.loop-note strong{ color:var(--ink-soft); font-weight:600; }
.loop-note svg{ width:15px; height:15px; flex:none; color:var(--accent-ink); stroke:currentColor; stroke-width:2; fill:none; stroke-linecap:round; stroke-linejoin:round; }
@media (max-width:820px){
  .steps{ grid-template-columns:1fr; gap:clamp(2.4rem,1.8rem + 2vw,3.6rem); }
  .step{ padding:0 0 0 clamp(2.8rem,3vw + 2rem,4rem); }
  .step:first-child,.step:last-child{ padding-left:clamp(2.8rem,3vw + 2rem,4rem); }
  .step .num{ position:absolute; left:0; top:0; padding-right:0; background:transparent; font-size:1.6rem; }
  .bg-sunk .step .num{ background:transparent; }
    .step p{ max-width:38ch; }
}

/* "Im Hintergrund" — the autonomous-AI line + pipeline */
.howai{ margin-top:clamp(3.5rem,2.4rem + 3vw,5.5rem); padding-top:clamp(2.6rem,1.8rem + 2vw,3.6rem); border-top:1px solid var(--line); }
.howai-head{ max-width:820px; }
.howai-head .eyebrow{ margin-bottom:1.1rem; }
.howai-head h3{ font-size:clamp(1.8rem,1.4rem + 1.6vw,2.6rem); font-weight:500; letter-spacing:-.02em; line-height:1.15; margin-bottom:1.1rem; }
.howai-head p{ font-size:1.08rem; color:var(--ink-soft); line-height:1.6; max-width:720px; }
.pipeline{ display:flex; flex-wrap:wrap; align-items:center; gap:.5rem .55rem; margin:clamp(2rem,1.4rem + 1.5vw,3rem) 0 1.4rem; }
.pipeline li{ display:flex; align-items:center; gap:.5rem; font-size:.9rem; font-weight:500; color:var(--ink); }
.pipeline li .pn{ display:inline-flex; align-items:center; justify-content:center; width:20px; height:20px; border-radius:50%; border:1.5px solid var(--ink); font-size:.7rem; font-weight:600; flex:none; }
.pipeline li:not(:last-child)::after{ content:"\2192"; color:var(--ink-faint); margin-left:.3rem; font-size:.95rem; }
.howai-foot{ font-size:.9rem; color:var(--ink-mute); line-height:1.55; max-width:720px; }

/* ---------- DAS PROBLEM — big numbers ---------- */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(2.6rem,1.4rem + 4vw,5rem); }
.stat .num{ display:block; font-size:clamp(2.6rem,1.7rem + 3vw,4.2rem); font-weight:600; color:var(--ink); letter-spacing:-.045em; line-height:1; }
.stat.highlight .num{ color:var(--ink); }
.stat .lbl{ display:block; margin-top:1.5rem; font-size:.94rem; color:var(--ink-soft); line-height:1.55; max-width:28ch; }
.stat .lbl .src{ display:inline-block; padding:.35em .2em; margin:-.2em -.2em; color:var(--ink-mute); font-weight:500; border-bottom:1px solid var(--line-2); white-space:nowrap; transition:opacity .2s; }
.stat .lbl .src:hover{ opacity:.6; }
.stats-note{ margin-top:clamp(1.8rem,1.2rem + 1vw,2.4rem); font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; color:var(--ink-faint); }
.dienst-scope{ margin-top:clamp(2.6rem,1.8rem + 2vw,4rem); text-align:center; font-family:var(--mono); font-size:clamp(.82rem,.78rem + .15vw,.95rem); letter-spacing:.02em; color:var(--ink-mute); line-height:2; max-width:780px; margin-inline:auto; }
#warum{ padding-block:clamp(2.2rem,1.6rem + 1.4vw,3rem); }
.guarantees{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.8rem,1.1rem + 2.2vw,2.8rem); margin:0 auto; max-width:1020px; border-top:1px solid var(--line); padding-top:clamp(2.6rem,1.8rem + 1.8vw,3.8rem); }
.grt-ic{ display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; color:var(--ink); }
.grt-ic svg{ width:100%; height:100%; }
.grt-ic svg:not(.flag){ fill:none; stroke:currentColor; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.grt h3{ font-size:clamp(1.02rem,.95rem + .25vw,1.18rem); font-weight:600; letter-spacing:-.012em; margin:.85rem 0 .3rem; }
.grt p{ font-size:.92rem; color:var(--ink-mute); line-height:1.4; margin:0; max-width:24ch; }
@media (max-width:880px){ .guarantees{ grid-template-columns:repeat(2,1fr); gap:2.2rem 1.8rem; } }
@media (max-width:520px){ .guarantees{ grid-template-columns:1fr; gap:1.7rem; } }
.problem-bridge{ margin-top:clamp(2.8rem,1.8rem + 2.2vw,4rem); max-width:920px; font-size:clamp(1.5rem,1.1rem + 1.4vw,2.4rem); font-weight:500; color:var(--ink); line-height:1.25; letter-spacing:-.02em; }
.problem-bridge strong{ font-weight:600; }
@media (max-width:760px){ .stats{ grid-template-columns:1fr; gap:2.4rem; } }

/* ---------- DIRECT RECEIPT — the "step 0" relay ---------- */
#weiter::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:0; background:radial-gradient(ellipse 60% 55% at 74% 36%, rgba(20,21,26,.018), transparent 64%); }
#funktion::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:0; background:radial-gradient(ellipse 56% 44% at 50% 8%, rgba(20,21,26,.015), transparent 62%); }
.relay{ display:grid; grid-template-columns:repeat(3,1fr); column-gap:0; position:relative; margin-top:clamp(2.2rem,1.6rem + 1.5vw,3.4rem); }
.relay::before{ content:""; position:absolute; left:7px; right:calc(33.333% - 7px); top:6.25px; height:1.5px; background:var(--line-2); transform:scaleX(0); transform-origin:left center; transition:transform 1.1s var(--ease-out) .25s; }
.relay.in::before{ transform:scaleX(1); }
.relay .rstep{ position:relative; padding:0 clamp(1rem,.5rem + 2vw,3rem) 0 0; }
.relay .rstep:last-child{ padding-right:0; }
.relay .rdot{ position:relative; z-index:1; display:flex; align-items:center; justify-content:center; width:14px; height:14px; border-radius:50%; background:#CDCEC9; box-shadow:0 0 0 4px var(--paper); }
.relay .rdot-accent{ width:14px; height:14px; background:var(--accent); box-shadow:0 0 0 4px var(--paper), 0 0 0 6px rgba(44,117,254,.18), 0 0 12px rgba(44,117,254,.22); }
.relay .rdot-ok{ width:14px; height:14px; background:var(--ok); box-shadow:0 0 0 4px var(--paper); }
.relay .rdot-ok svg{ width:8px; height:8px; stroke:#fff; stroke-width:2.7; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.relay .rh{ font-size:clamp(1rem,.95rem + .25vw,1.15rem); font-weight:600; letter-spacing:-.012em; margin-top:1.3rem; margin-bottom:.45rem; }
.relay .rd{ font-size:.95rem; color:var(--ink-soft); max-width:23ch; line-height:1.5; }
@media (max-width:760px){
  .relay{ grid-template-columns:1fr; gap:1.9rem; }
  .relay::before{ left:7px; right:auto; top:.25rem; bottom:.25rem; width:1px; height:auto; transform:scaleY(0); transform-origin:top center; }
  .relay.in::before{ transform:scaleY(1); }
  .relay .rstep{ padding:0 0 1.6rem 2.6rem; } .relay .rstep:last-child{ padding-bottom:0; }
  .relay .rdot{ position:absolute; left:0; top:.35rem; }
  .relay .rd{ max-width:42ch; }
}
.weiter-points{ margin-top:clamp(2rem,1.4rem + 1.5vw,3rem); max-width:820px; display:flex; flex-direction:column; gap:1.1rem; }
.weiter-points p{ font-size:1.06rem; color:var(--ink-soft); line-height:1.6; max-width:none; }
.weiter-points strong{ color:var(--ink); font-weight:600; }
.weiter-points .weiter-stage{ padding-top:1.1rem; border-top:1px solid var(--line); }
@media (max-width:760px){ .relay{ flex-direction:column; align-items:stretch; gap:.5rem; } .relay .ra{ transform:rotate(90deg); align-self:center; } }



/* ---------- WARUM — three numbered statements ---------- */
.trust-list{ counter-reset:trust; display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(2.2rem,1.4rem + 2vw,3.6rem) clamp(2rem,1.5rem + 2vw,3.6rem); margin-top:clamp(2.8rem,1.8rem + 2vw,3.8rem); }
.trust-item{ counter-increment:trust; }
.trust-item .ti-ic{ display:none; }
.trust-item .ti-ic svg{ display:none; }
.trust-item h3{ font-size:1.15rem; font-weight:600; margin-bottom:.5rem; }
.trust-item p{ font-size:.98rem; color:var(--ink-soft); line-height:1.55; }
.madein{ display:flex; align-items:center; gap:1.6rem; margin-top:clamp(3rem,2rem + 2.5vw,4.2rem); padding-top:clamp(2rem,1.4rem + 1.5vw,2.6rem); border-top:1px solid var(--line); }
.madein .mig{ display:inline-flex; align-items:center; gap:.7rem; font-size:.85rem; font-weight:600; letter-spacing:.01em; color:var(--ink-2); flex:none; }
.madein .mig-flag{ width:26px; height:17px; border-radius:3px; flex:none; border:1px solid rgba(20,21,26,.16); background:linear-gradient(180deg, #1A1A1A 0 33.33%, #DD0000 33.33% 66.66%, #FFCE00 66.66% 100%); }
.madein p{ font-size:.95rem; color:var(--ink-mute); line-height:1.55; max-width:520px; }
@media (max-width:760px){ .trust-list{ grid-template-columns:1fr; gap:2.2rem; } .trust-list .trust-item + .trust-item{ border-top:1px solid var(--line); padding-top:1.8rem; } .madein{ flex-direction:column; align-items:flex-start; gap:1rem; } }

/* ---------- PREISE ---------- */
#preise::before{ content:""; position:absolute; inset:0; pointer-events:none; z-index:0; background:radial-gradient(ellipse 42% 64% at 80% 50%, rgba(20,21,26,.016), transparent 60%); }
.prices{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1rem,.5rem + 1.5vw,1.7rem); align-items:stretch; max-width:780px; margin-inline:auto; }
.price{ position:relative; display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:2rem 1.85rem 1.95rem; transition:border-color .2s, box-shadow .2s, transform .18s; }
.price:hover{ border-color:var(--line-2); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.price.feat{ border:1px solid var(--accent-line); background:linear-gradient(180deg, rgba(44,117,254,.07), var(--surface) 50%); box-shadow:0 0 0 1px var(--accent-line), 0 16px 40px -8px rgba(44,117,254,.18); }
.price.feat:hover{ border-color:var(--accent-line); }
.price .ribbon{ position:absolute; top:-.85rem; left:1.85rem; background:var(--accent); color:#fff; font-size:.74rem; font-weight:600; padding:.42em .9em; border-radius:var(--radius-pill); }
.price .pname{ font-size:1.05rem; font-weight:600; color:var(--ink); }
.price .ptag{ font-size:.88rem; color:var(--ink-mute); margin-top:.3rem; }
.price .pamt{ margin-top:1.5rem; display:flex; align-items:baseline; gap:.35rem; }
.price .pamt .big{ font-size:2.7rem; font-weight:500; color:var(--ink); letter-spacing:-.04em; }
.price .pamt .per{ font-size:1rem; color:var(--ink-mute); font-weight:500; }
.price .pamt.pamt-tiered{ display:block; }
.price .pamt.pamt-tiered .pt-line{ display:flex; align-items:baseline; gap:.35rem; flex-wrap:wrap; }
.price .pamt.pamt-tiered .big{ font-size:2.05rem; }
.price .pamt.pamt-tiered .pt-pre{ font-size:.92rem; font-weight:500; color:var(--ink-mute); }
.price .pamt.pamt-tiered .pt-note{ font-size:.78rem; color:var(--ink-faint); margin-top:.18rem; }
.price .pamt.pamt-tiered .pt-rule{ border:0; border-top:1px solid var(--line); margin:.7rem 0; }
.price .psetup{ font-size:.88rem; color:var(--ink-mute); margin-top:.5rem; }
.price .psetup.psetup-ok{ color:var(--ok); font-weight:600; }
.price .pmeta{ font-size:.92rem; color:var(--ink-mute); margin-top:.85rem; flex:1; line-height:1.55; }
.price .pfeat{ list-style:none; margin:1rem 0 0; padding:0; display:flex; flex-direction:column; gap:.6rem; flex:1; }
.price .pfeat li{ font-size:.9rem; color:var(--ink-soft); line-height:1.42; display:flex; gap:.5rem; align-items:flex-start; }
.price .pfeat li::before{ content:"\2713"; flex:none; color:var(--ok); font-weight:700; font-size:.82em; line-height:1.55; }
.price .pfeat-head{ font-size:.92rem; font-weight:600; color:var(--ink); margin:1rem 0 .15rem; }
.price .pmeta.gold{ color:var(--ink-soft); font-weight:600; }
.price .btn{ margin-top:1.9rem; }
.price-fine{ margin-top:1.9rem; font-size:.85rem; color:var(--ink-faint); text-align:center; max-width:760px; margin-inline:auto; line-height:1.55; }
@media (max-width:820px){ .prices{ grid-template-columns:1fr; } .price.feat{ order:-1; } }


/* ---------- Footer ---------- */
.footer{ padding-block:clamp(3.2rem,2.2rem + 3vw,4.5rem) 2.5rem; border-top:1px solid var(--line); }
.footer-top{ display:flex; justify-content:space-between; gap:2rem; flex-wrap:wrap; align-items:flex-start; }
.footer .brand{ font-size:1.12rem; }
.footer-links{ display:flex; gap:.7rem 1.5rem; flex-wrap:wrap; max-width:560px; }
.footer-links a{ font-size:.92rem; color:var(--ink-soft); border-bottom:1px solid transparent; transition:border-color .2s, color .2s; }
.footer-links a:hover{ color:var(--ink); border-color:var(--line-2); }
.footer-trust{ display:flex; align-items:center; gap:1.2rem; margin-top:2.6rem; padding-top:1.9rem; border-top:1px solid var(--line); flex-wrap:wrap; }
.footer-trust .mig{ display:inline-flex; align-items:center; gap:.6rem; font-size:.82rem; font-weight:600; color:var(--ink-2); flex:none; }
.footer-trust .mig-flag{ width:22px; height:14px; border-radius:2.5px; flex:none; border:1px solid rgba(20,21,26,.16); background:linear-gradient(180deg, #1A1A1A 0 33.33%, #DD0000 33.33% 66.66%, #FFCE00 66.66% 100%); }
.footer-trust span{ font-size:.85rem; color:var(--ink-mute); }
.footer .disclaim{ margin-top:2.4rem; font-size:.85rem; color:var(--ink-mute); max-width:660px; line-height:1.55; }
.footer .copy{ margin-top:1.4rem; font-size:.85rem; color:var(--ink-mute); }
@media (max-width:760px){ .footer-top{ flex-direction:column; gap:1.4rem; } .footer-links a{ display:inline-flex; align-items:center; min-height:44px; padding:.4em .15em; } }

/* ---------- Scroll-reveal (quiet) ---------- */
/* progressive enhancement: hide-until-revealed only when JS is on (html.js, set by the head <script>) AND motion is welcome — otherwise content is just visible */
@media (prefers-reduced-motion:no-preference){
  .js [data-anim]{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
}
[data-anim].in{ opacity:1; transform:none; }

/* ============================================================
   ONBOARDING (onboarding.html — body.ob-body)
   ============================================================ */
.ob-body{ background:var(--paper); }
.ob-main{ max-width:880px; margin-inline:auto; padding:clamp(1.4rem,1rem + .8vw,2.2rem) var(--gutter) 5rem; }
.st-main, .ob-main{ position:relative; }
.ob-head{ display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:.85rem; }
.ob-back{ display:inline-flex; align-items:center; gap:.4rem; font-size:.92rem; font-weight:500; color:var(--ink-mute); padding:.45em .15em; margin:-.45em -.15em; transition:color .2s; cursor:pointer; }
.ob-back:hover{ color:var(--ink); }
.ob-back svg{ width:13px; height:13px; stroke:currentColor; stroke-width:1.9; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.ob-stepn{ font-family:var(--mono); font-size:.74rem; font-weight:500; letter-spacing:.07em; color:var(--ink-mute); white-space:nowrap; }
.ob-progress{ height:5px; border-radius:999px; background:var(--line-2); overflow:hidden; margin-bottom:clamp(1.8rem,1.4rem + 1.5vw,2.8rem); }
.ob-progress-fill{ display:block; height:100%; border-radius:999px; background:var(--accent); box-shadow:0 0 10px rgba(44,117,254,.45); transition:width .6s cubic-bezier(.16,1,.3,1); }
.stepper{ display:flex; align-items:center; gap:.5rem; margin-bottom:clamp(.7rem,.5rem + .5vw,1.1rem); flex-wrap:wrap; }
.stepper .dot{ display:flex; align-items:center; gap:.5rem; font-size:.9rem; color:var(--ink-faint); }
.stepper .dot .pip{ width:24px; height:24px; border-radius:50%; border:1.5px solid var(--line-2); display:grid; place-items:center; font-size:.78rem; font-weight:600; transition:all .25s; }
.stepper .dot .pip svg{ width:11px; height:11px; stroke:currentColor; stroke-width:2.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.stepper .dot.active{ color:var(--ink); }
.stepper .dot.active .pip{ background:var(--accent); color:#fff; border-color:var(--accent); }
.stepper .dot.done .pip{ background:var(--ok-bg); color:var(--ok); border-color:var(--ok-line); }
.stepper .bar{ flex:1; min-width:14px; height:1.5px; background:var(--line-2); }
.stepper .bar.filled{ background:var(--ok-line); }
.ob-step{ display:none; padding-block:0; }
.ob-step.active{ display:block; animation:stepIn .55s var(--ease-out); }
@keyframes stepIn{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){ .ob-step.active{ animation:none; } .voll-doc .sb .sigtext{ transition:none; } .ob-progress-fill{ transition:none; } }
@media (max-width:640px){
  .stepper{ gap:.3rem; }
  .stepper .dot .lbl{ display:none; }
  .stepper .dot .pip{ width:21px; height:21px; font-size:.7rem; }
  .stepper .dot .pip svg{ width:9px; height:9px; }
}
.ob-step .kicker{ font-family:var(--mono); font-size:.72rem; font-weight:500; color:var(--ink-mute); letter-spacing:.07em; }
.ob-step > h1{ font-size:clamp(2rem,1.5rem + 1.8vw,2.8rem); margin:.6rem 0; outline:none; }
.ob-step > h1:focus,.ob-step > h1:focus-visible{ outline:none; }
.ob-step > .sub{ font-size:1.06rem; color:var(--ink-soft); max-width:640px; margin-bottom:1.7rem; line-height:1.55; }
.ob-nav{ display:flex; align-items:center; justify-content:flex-end; gap:.7rem; margin-top:clamp(2rem,1.4rem + 1.5vw,3rem); padding-top:1.6rem; border-top:1px solid var(--line); flex-wrap:wrap; }
.ob-nav .back{ display:inline-flex; align-items:center; gap:.4rem; font-size:.95rem; font-weight:500; color:var(--ink-mute); padding:.7em .4em; margin:-.7em -.4em; }
.ob-nav .back:hover{ color:var(--ink); }
.ob-nav .back svg{ width:14px; height:14px; stroke:currentColor; stroke-width:1.8; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.tier-pick{ display:grid; grid-template-columns:repeat(2,1fr); gap:.95rem; max-width:640px; }
.tier-opt{ position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:1.5rem 1.4rem; cursor:pointer; transition:border-color .22s, box-shadow .22s, transform .18s; }
.tier-opt:hover{ border-color:var(--line-2); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.tier-opt .rdo{ position:absolute; top:1.3rem; right:1.3rem; width:20px; height:20px; border-radius:50%; border:1.5px solid var(--line-2); transition:all .25s; }
.tier-opt .rdo::after{ content:""; position:absolute; inset:4px; border-radius:50%; background:var(--accent); transform:scale(0); transition:transform .25s var(--ease); }
.tier-opt[aria-checked="true"]{ border-color:var(--accent); border-width:1.5px; background:rgba(44,117,254,.06); }
.tier-opt[aria-checked="true"] .rdo{ border-color:var(--accent); }
.tier-opt[aria-checked="true"] .rdo::after{ transform:scale(1); }
.tier-opt .tn{ font-size:1rem; font-weight:600; color:var(--ink); }
.tier-opt .tp{ font-size:1.55rem; font-weight:500; color:var(--ink); margin-top:.55rem; letter-spacing:-.03em; }
.tier-opt .tp .u{ font-size:.95rem; font-weight:500; color:var(--ink-mute); letter-spacing:0; }
.tier-opt .tx{ font-size:.88rem; color:var(--ink-soft); margin-top:.5rem; line-height:1.45; }
.tier-opt .tbest{ display:inline-block; margin-top:.7rem; font-size:.74rem; font-weight:600; color:#fff; background:var(--accent); padding:.32em .65em; border-radius:var(--radius-pill); }
@media (max-width:760px){ .tier-pick{ grid-template-columns:1fr; } .tier-opt.gold{ order:-1; } }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem 1.4rem; }
.field{ display:flex; flex-direction:column; gap:.4rem; }
.field.full{ grid-column:1 / -1; }
.field label{ font-size:.9rem; font-weight:500; color:var(--ink); }
.field label .opt{ color:var(--ink-faint); font-weight:400; }
.field input,.field select{ font:inherit; font-size:1rem; color:var(--ink); background:var(--surface); border:1px solid var(--line-2); border-radius:var(--radius-sm); padding:.7em .85em; transition:border-color .2s, box-shadow .2s; }
.field input:focus,.field select:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); }
.field input::placeholder{ color:var(--ink-faint); }
.field .hint{ font-size:.8rem; color:var(--ink-mute); }
.field .field-err{ font-size:.8rem; color:var(--err); line-height:1.35; }
.field .field-err:empty{ display:none; }
.field input[aria-invalid="true"],.field select[aria-invalid="true"]{ border-color:var(--err); box-shadow:0 0 0 3px rgba(197,57,31,.12); }
@media (max-width:600px){ .form-grid{ grid-template-columns:1fr; } }
.voll{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.6rem,1rem + 2vw,2.6rem); align-items:start; }
.voll-doc{ position:relative; background:var(--surface); border:1px solid var(--line-2); border-radius:var(--radius); padding:1.6rem 1.7rem 2.8rem; box-shadow:var(--shadow-sm); }
.voll-doc .voll-party{ font-size:.78rem; color:var(--ink-mute); line-height:1.4; margin:.4rem 0; }
.voll-doc .voll-party + .voll-party{ margin-top:-.2rem; }
.voll-doc .voll-party.voll-stellen{ margin-bottom:.8rem; }
.voll-doc .voll-party .vp-l{ color:var(--ink-faint); }
.voll-doc .voll-party b{ color:var(--ink-2); font-weight:600; }
.voll-doc .dh{ font-weight:600; font-size:1.1rem; color:var(--ink); }
.voll-doc .ds{ font-size:.82rem; color:var(--ink-mute); margin-top:.2rem; }
.voll-doc .dl{ margin-top:1.4rem; display:flex; flex-direction:column; gap:.5rem; }
.voll-doc .dl .ln{ height:.5rem; border-radius:3px; background:var(--paper-2); }
.voll-doc .dl .ln.s{ width:35%; } .voll-doc .dl .ln.m{ width:65%; } .voll-doc .dl .ln.l{ width:92%; }
.voll-doc .dl .dgap{ height:.6rem; }
.voll-doc .sigrow{ margin-top:1.6rem; }
.voll-doc .sb .line{ border-bottom:1px solid var(--line-2); padding-bottom:.3rem; }
.voll-doc .sb .script{ color:var(--ink); opacity:0; transform:translateY(4px); transition:opacity .6s, transform .6s; }
.voll-doc .sb .sigscribble{ display:block; width:130px; height:auto; }
.voll-doc .sb .sigtext{ display:inline-block; font-family:'Segoe Script','Bradley Hand','Snell Roundhand','Apple Chancery','Brush Script MT',cursive; font-size:1.65rem; line-height:1; color:var(--ink); padding:0 4px .12rem 0; transform:rotate(-3deg); opacity:0; clip-path:inset(0 100% 0 0); transition:clip-path 1.1s cubic-bezier(.4,0,.2,1) .15s, opacity .25s .15s; }
.voll-doc.signed .sb .sigtext{ opacity:1; clip-path:inset(0 0 0 0); }
.voll-doc.signed .sb .script{ opacity:1; transform:none; }
.voll-doc .sb small{ display:block; margin-top:.4rem; font-size:.72rem; color:var(--ink-faint); padding-right:90px; line-height:1.45; }
.voll-doc .seal{ position:absolute; right:1.4rem; bottom:1.4rem; width:62px; height:62px; border-radius:50%; border:1.5px dashed var(--ok-line); color:var(--ok); display:grid; place-items:center; text-align:center; font-size:.62rem; font-weight:600; line-height:1.1; transform:rotate(-12deg) scale(.6); opacity:0; transition:transform .5s var(--ease-out), opacity .5s; }
.voll-doc.signed .seal{ transform:rotate(-12deg) scale(1); opacity:1; }
.voll-side > h3{ font-size:1.2rem; font-weight:600; margin-bottom:.6rem; }
.voll-side > p{ font-size:.98rem; color:var(--ink-soft); line-height:1.55; }
.checks{ margin-top:1.2rem; display:flex; flex-direction:column; gap:.6rem; }
.checks li{ display:flex; gap:.65rem; font-size:.92rem; color:var(--ink-soft); align-items:flex-start; }
.checks li svg{ width:14px; height:14px; flex:none; margin-top:.2rem; color:var(--ink); stroke:currentColor; stroke-width:2.4; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.voll-actions{ margin-top:1.6rem; display:flex; flex-direction:column; gap:.8rem; align-items:flex-start; }

.signed-pill{ display:none; align-items:center; gap:.5rem; font-size:.9rem; font-weight:500; color:var(--ok); background:var(--ok-bg); border:1px solid var(--ok-line); padding:.55em .85em; border-radius:var(--radius-sm); }
.signed-pill svg{ width:14px; height:14px; stroke:currentColor; stroke-width:2.4; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.voll-doc.signed ~ .voll-side .signed-pill{ display:inline-flex; }
@media (max-width:840px){ .voll{ grid-template-columns:1fr; } .voll-doc{ order:2; } }
.korr{ margin-top:clamp(2.4rem,1.8rem + 2vw,3.4rem); padding-top:clamp(2rem,1.4rem + 1.5vw,2.6rem); border-top:1px solid var(--line); }
.korr > h3{ font-size:1.2rem; font-weight:600; margin-bottom:.7rem; }
.korr .korr-intro{ font-size:.98rem; color:var(--ink-soft); line-height:1.55; max-width:660px; margin-bottom:1.2rem; }
.korr .korr-intro strong{ color:var(--ink); font-weight:600; }
.korr-list{ display:flex; flex-direction:column; gap:.55rem; max-width:600px; }
.korr-opt{ display:flex; align-items:center; gap:.75rem; padding:.7rem .9rem; border:1px solid var(--line); border-radius:var(--radius-sm); background:var(--surface); cursor:pointer; transition:border-color .2s; }
.korr-opt:hover{ border-color:var(--line-2); }
.korr-opt input{ width:18px; height:18px; flex:none; accent-color:var(--ink); cursor:pointer; }
.korr-opt .ko-name{ font-weight:500; color:var(--ink); }
.korr-opt .ko-note{ margin-left:auto; font-size:.78rem; color:var(--ink-mute); text-align:right; }
.korr-opt.disabled{ opacity:.62; cursor:default; background:var(--paper-2); }
.korr-opt.disabled:hover{ border-color:var(--line); }
@media (max-width:560px){ .korr-opt{ flex-wrap:wrap; } .korr-opt .ko-note{ margin-left:2.6rem; text-align:left; flex-basis:100%; } }
/* --- step-3 note (replaces the per-Stelle picklist) --- */
.korr-note{ margin-top:clamp(1.6rem,1.2rem + 1vw,2.2rem); padding-top:clamp(1.3rem,1rem + 1vw,1.8rem); border-top:1px solid var(--line); display:flex; flex-direction:column; gap:.95rem; max-width:720px; }
.korr-note > p{ font-size:.95rem; color:var(--ink-soft); line-height:1.55; }
.korr-note > p strong{ color:var(--ink); font-weight:600; }
.korr-note .korr-fa{ display:flex; gap:.7rem; align-items:flex-start; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius-sm); padding:.9rem 1rem; }
.korr-note .korr-fa svg{ width:18px; height:18px; flex:none; margin-top:.05rem; stroke:var(--ink-mute); stroke-width:1.7; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.korr-note .korr-fa span{ font-size:.9rem; color:var(--ink-soft); line-height:1.5; }
.korr-note .korr-fa strong{ color:var(--ink); font-weight:600; }
.dropzone{ border:1.5px dashed var(--line-2); border-radius:var(--radius); padding:clamp(1.8rem,1.2rem + 2vw,2.6rem); text-align:center; background:var(--surface); transition:border-color .2s, background-color .2s; }
.dropzone.hot{ border-color:var(--ink); background:var(--paper-3); }
.dropzone .dz-ic{ width:34px; height:34px; margin:0 auto .8rem; color:var(--ink-mute); }
.dropzone .dz-ic svg{ width:100%; height:100%; stroke:currentColor; stroke-width:1.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.dropzone p{ font-size:.98rem; color:var(--ink-soft); margin:0 auto; max-width:480px; }
.dropzone .dz-photo{ display:flex; gap:.6rem; align-items:flex-start; max-width:480px; margin:.85rem auto .2rem; text-align:left; font-size:.85rem; color:var(--ink-mute); line-height:1.45; }
.dropzone .dz-photo svg{ width:18px; height:18px; flex:none; margin-top:.05rem; stroke:var(--ink-mute); stroke-width:1.5; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.dropzone .dz-or{ display:inline-block; margin:.7rem 0 .3rem; font-size:.85rem; color:var(--ink-faint); }
.filelist{ margin-top:1.4rem; display:flex; flex-direction:column; gap:.6rem; }
.fileitem{ display:flex; align-items:center; gap:.9rem; padding:.85rem 1rem; border:1px solid var(--line); border-radius:var(--radius-sm); background:var(--surface); }
.fileitem.optional{ background:var(--paper-2); }
.fileitem.done{ border-color:var(--ok-line); background:rgba(46,125,50,.07); }
.fileitem .fic{ width:30px; height:38px; border-radius:4px; background:var(--paper-2); border:1px solid var(--line-2); flex:none; position:relative; }
.fileitem .fic::after{ content:""; position:absolute; left:5px; right:5px; top:7px; height:2px; background:var(--line-2); box-shadow:0 5px 0 var(--line-2),0 10px 0 var(--line-2); }
.fileitem .fmeta{ flex:1; min-width:0; }
.fileitem .fn{ font-size:.95rem; font-weight:500; color:var(--ink); }
.fileitem .fn .req{ font-size:.7rem; font-weight:600; color:var(--err); background:rgba(224,101,74,.14); padding:.18em .5em; border-radius:var(--radius-pill); margin-left:.4rem; }
.fileitem .fd{ display:block; font-size:.8rem; color:var(--ink-mute); margin-top:.15rem; }
.fileitem .fprog{ display:none; width:90px; height:5px; border-radius:3px; background:var(--paper-2); overflow:hidden; flex:none; }
.fileitem .fprog i{ display:block; height:100%; width:0; background:var(--ink); transition:width .25s linear; }
.fileitem.uploading .fprog{ display:block; }
.fileitem .fbtn{ font-size:.85rem; font-weight:500; color:var(--ink); border:1px solid var(--line-2); border-radius:999px; padding:.45em .95em; transition:all .2s; flex:none; }
.fileitem .fbtn:hover{ background:var(--paper-3); }
.fileitem.uploading .fbtn,.fileitem.done .fbtn{ display:none; }
.fileitem .fstate{ display:none; flex:none; }
.fileitem.done .fstate{ display:block; }
.fileitem .ck{ width:22px; height:22px; border-radius:50%; background:var(--ok-bg); color:var(--ok); display:grid; place-items:center; }
.fileitem .ck svg{ width:12px; height:12px; stroke:currentColor; stroke-width:2.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.upload-summary{ margin-top:1.1rem; font-size:.92rem; color:var(--ink-mute); } .upload-summary b{ color:var(--ink); }
.ob-trustline{ display:flex; align-items:flex-start; gap:.7rem; margin-top:1.6rem; font-size:.9rem; color:var(--ink-mute); line-height:1.5; max-width:640px; }
.ob-trustline svg{ width:18px; height:18px; flex:none; margin-top:.1rem; color:var(--ink-faint); stroke:currentColor; stroke-width:1.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.done-hero{ text-align:center; max-width:680px; margin-inline:auto; }
.done-check{ width:64px; height:64px; border-radius:50%; background:var(--ok-bg); color:var(--ok); display:grid; place-items:center; margin:0 auto 1.2rem; position:relative; }
.done-check svg{ width:30px; height:30px; stroke:currentColor; stroke-width:2.4; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.done-check::before{ content:""; position:absolute; inset:-6px; border-radius:50%; border:1.5px solid var(--ok-line); animation:pulseRing 2.4s var(--ease-out) infinite; }
@keyframes pulseRing{ 0%{ transform:scale(.85); opacity:.8; } 100%{ transform:scale(1.25); opacity:0; } }
@media (prefers-reduced-motion: reduce){ .done-check::before{ animation:none; } }
.done-hero .sub{ margin-inline:auto; }
.addr-card{ margin:1.8rem auto 0; max-width:520px; background:var(--surface); border:1px solid var(--line-2); border-radius:var(--radius); padding:1.2rem 1.4rem; text-align:left; }
.addr-card .al{ font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; color:var(--ink-mute); }
.addr-card .arow{ display:flex; align-items:center; gap:.8rem; margin-top:.5rem; flex-wrap:wrap; }
.addr-card .addr{ font-family:var(--mono); font-size:.98rem; color:var(--ink); word-break:break-all; }
.copy-btn{ margin-left:auto; display:inline-flex; align-items:center; gap:.4rem; font-size:.82rem; font-weight:500; color:var(--ink); border:1px solid var(--line-2); border-radius:999px; padding:.4em .8em; transition:all .2s; }
.copy-btn:hover{ background:var(--paper-3); }
.copy-btn svg{ width:13px; height:13px; stroke:currentColor; stroke-width:1.7; fill:none; stroke-linecap:round; stroke-linejoin:round; }
/* --- done step: the 3-step flow + heading --- */
.flow-head{ margin:2.6rem auto .2rem; font-size:clamp(1.15rem,1rem + .7vw,1.5rem); font-weight:600; color:var(--ink); }
.flow3{ display:flex; align-items:stretch; gap:.6rem; margin:1.2rem auto 0; max-width:820px; text-align:left; }
.flow3-step{ flex:1; min-width:0; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:1.2rem 1.2rem 1.3rem; position:relative; box-shadow:var(--shadow-sm); }
.flow3-step .f3-ic{ display:flex; width:34px; height:34px; align-items:center; justify-content:center; border-radius:9px; background:rgba(44,117,254,.10); color:var(--accent-ink); margin-bottom:.7rem; }
.flow3-step .f3-ic svg{ width:19px; height:19px; stroke:currentColor; stroke-width:1.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.flow3-step:last-child .f3-ic{ background:var(--ok-bg); color:var(--ok); }
.flow3-step .f3-n{ position:absolute; top:1.05rem; right:1.1rem; font-family:var(--mono); font-size:.7rem; color:var(--ink-faint); }
.flow3-step h3{ font-size:1rem; font-weight:600; color:var(--ink); margin-bottom:.35rem; }
.flow3-step p{ font-size:.86rem; color:var(--ink-soft); line-height:1.5; }
.flow3-arrow{ display:flex; align-items:center; color:var(--line-2); flex:none; }
.flow3-arrow svg{ width:22px; height:22px; stroke:currentColor; stroke-width:1.5; fill:none; stroke-linecap:round; stroke-linejoin:round; }
@media (max-width:760px){ .flow3{ flex-direction:column; } .flow3-arrow{ transform:rotate(90deg); align-self:center; margin:-.2rem 0; } }
.next-list{ margin:2.2rem auto 0; max-width:600px; text-align:left; display:flex; flex-direction:column; gap:1.1rem; }
.next-list .ni{ display:flex; gap:1rem; align-items:flex-start; }
.next-list .nn{ width:28px; height:28px; border-radius:50%; border:1.5px solid var(--accent-line); color:var(--accent-ink); display:grid; place-items:center; font-size:.8rem; font-weight:600; flex:none; }
.next-list .nn svg{ width:15px; height:15px; stroke:currentColor; stroke-width:1.6; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.next-list .nt{ font-size:.95rem; color:var(--ink-soft); line-height:1.55; } .next-list .nt b{ color:var(--ink); }
.done-cta{ margin-top:2.4rem; display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   STATUS (status.html)
   ============================================================ */
.st-main{ max-width:840px; margin-inline:auto; padding:clamp(1.4rem,1rem + .8vw,2.2rem) var(--gutter) 5rem; }
.st-confirm{ text-align:center; max-width:680px; margin-inline:auto; }
.st-confirm .ok-ic{ width:56px; height:56px; border-radius:50%; background:var(--ok-bg); color:var(--ok); display:grid; place-items:center; margin:0 auto 1rem; }
.st-confirm .ok-ic svg{ width:26px; height:26px; stroke:currentColor; stroke-width:2.4; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.st-confirm h1{ font-size:clamp(1.9rem,1.4rem + 1.6vw,2.6rem); margin-top:.6rem; }
.st-confirm p{ margin:1.1rem auto 0; color:var(--ink-soft); }
.st-confirm .st-az{ display:inline-block; margin-top:1.2rem; font-family:var(--mono); font-size:.74rem; letter-spacing:.04em; color:var(--ink-mute); } .st-confirm .st-az b{ color:var(--ink); }
.st-block{ margin-top:clamp(2.6rem,1.8rem + 2vw,3.6rem); padding-top:clamp(2rem,1.4rem + 1.5vw,2.6rem); border-top:1px solid var(--line); }
.st-block h2{ font-size:1.4rem; font-weight:600; margin-bottom:1.3rem; }
.st-acct{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem 1.8rem; }
.st-acct .ac.full{ grid-column:1 / -1; }
.st-acct .acl{ font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; color:var(--ink-mute); }
.st-acct .acv{ font-size:.98rem; color:var(--ink); margin-top:.25rem; }
.st-acct .acv.addr{ font-weight:600; font-variant-numeric:tabular-nums; word-break:break-all; }
.timeline{ display:flex; flex-direction:column; }
.tlitem{ position:relative; padding:0 0 1.6rem 1.8rem; border-left:1.5px solid var(--line-2); }
.tlitem:last-child{ border-left-color:transparent; padding-bottom:0; }
.tlitem::before{ content:""; position:absolute; left:-6.5px; top:.3rem; width:11px; height:11px; border-radius:50%; background:var(--paper); border:1.5px solid var(--line-2); }
.st-acct .addr-row{ display:flex; align-items:center; gap:.7rem; flex-wrap:wrap; }
.st-acct .addr-row .copy-btn{ flex:none; }
.tlitem.active::before{ border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-soft); }
.tlitem.ok::before{ border-color:var(--ok); background:var(--ok); }
.tlitem .tlt{ font-family:var(--mono); font-size:.72rem; letter-spacing:.05em; color:var(--ink-mute); }
.tlitem .tlh{ font-size:.98rem; font-weight:600; color:var(--ink); margin-top:.2rem; }
.tlitem .tlx{ font-size:.91rem; color:var(--ink-soft); margin-top:.28rem; line-height:1.5; }
.tlitem .tlbadge{ display:inline-flex; align-items:center; gap:.4em; margin-top:.55rem; font-size:.74rem; font-weight:600; padding:.3em .62em; border-radius:var(--radius-pill); }
.tlitem .tlbadge-prog{ background:var(--paper-3); color:var(--ink); }
.tlitem .tlbadge-ok{ background:var(--ok-bg); color:var(--ok); }
.st-note{ margin-top:2.6rem; padding:1.25rem 1.4rem; border:1px solid var(--line); border-radius:var(--radius-sm); background:var(--paper-2); font-size:.93rem; color:var(--ink-soft); line-height:1.55; } .st-note b{ color:var(--ink); }
@media (max-width:680px){ .st-acct{ grid-template-columns:1fr; } }
