/* ============================================================
   e-Widerruf – gemeinsames Stylesheet
   Wird von index.html, impressum.html, datenschutz.html, 404.html genutzt.
   ============================================================ */

/* ---- Selbstgehostete Schriften (IBM Plex, SIL OFL) ----------
   Kein Google-Fonts-CDN (Datenschutz). Subsets: latin + latin-ext. */

/* IBM Plex Sans */
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,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 Sans';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,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 Sans';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-ext-500.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,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 Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-ext-600.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,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 Sans';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/ibm-plex-sans-latin-ext-700.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

/* IBM Plex Mono */
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/ibm-plex-mono-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,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-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/ibm-plex-mono-latin-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,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-latin-ext-500.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/ibm-plex-mono-latin-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,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:600;font-display:swap;src:url('/fonts/ibm-plex-mono-latin-ext-600.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

/* ============================================================
   Design-Tokens & Basis (aus index.html extrahiert)
   ============================================================ */
:root{
  --paper:#F4F6F9; --surface:#FFFFFF; --surface-2:#FBFCFD;
  --ink:#14233B; --ink-2:#3C4A60; --ink-3:#6B7689;
  --brand:#0F766E; --brand-2:#0B5A54; --brand-tint:#E4F1EF;
  --signal:#B45309; --signal-bg:#FCF1E3; --signal-line:#F0D7B6;
  --danger:#B5341F;
  --line:#E2E7ED; --line-2:#CDD5DE;
  --r:16px; --r-sm:11px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(20,35,59,.05), 0 1px 1px rgba(20,35,59,.04);
  --shadow:0 12px 32px -12px rgba(20,35,59,.18), 0 4px 10px -6px rgba(20,35,59,.10);
  --sans:'IBM Plex Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --maxw:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;font-size:17px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono);font-feature-settings:"tnum" 1}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-2);font-weight:500}

/* focus / a11y floor */
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2.5px solid var(--brand);outline-offset:3px;border-radius:6px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:600;font-size:1rem;line-height:1;padding:15px 24px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}
.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--brand-2);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand-2);transform:translateY(-1px)}
.btn-lg{padding:17px 30px;font-size:1.06rem}
.arrow{transition:transform .15s ease}
.btn:hover .arrow{transform:translateX(3px)}

/* "bald verfügbar"-Zustand (App noch nicht im Store) */
.btn-soon,.btn-soon:hover{background:var(--brand-tint);color:var(--brand-2);border-color:#BFE0DA;box-shadow:none;cursor:not-allowed;transform:none}
.btn-soon .pulse{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px rgba(15,118,110,.16)}
.soonhint{margin-top:14px;font-size:.85rem;color:var(--ink-3);display:flex;align-items:center;gap:8px}
.soonhint .pulse{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px rgba(15,118,110,.16)}

/* urgency strip */
.alertbar{background:var(--signal-bg);border-bottom:1px solid var(--signal-line);color:#7c3a06}
.alertbar .wrap{display:flex;align-items:center;gap:12px;padding:11px 24px;font-size:.92rem;font-weight:500}
.alertbar .dot{flex:0 0 auto;width:9px;height:9px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 4px rgba(180,83,9,.16)}
.alertbar strong{font-weight:600}

/* header */
header.nav{position:sticky;top:0;z-index:50;background:rgba(244,246,249,.82);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{display:flex;align-items:center;gap:9px;font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.logo .mark{font-family:var(--mono);font-weight:600;background:var(--brand);color:#fff;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:1.05rem}
.logo .mark span{transform:translateY(-1px)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:.95rem;color:var(--ink-2);font-weight:500}
.nav-links a:hover{color:var(--brand-2)}
.nav-cta{display:flex;align-items:center;gap:14px}

/* hero */
.hero{padding:74px 0 56px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.1rem,4.4vw,3.4rem);line-height:1.08;letter-spacing:-.022em;font-weight:700;margin:18px 0 0}
.hero h1 .hl{color:var(--brand-2);box-shadow:inset 0 -.32em 0 var(--brand-tint)}
.hero .lede{font-size:1.16rem;color:var(--ink-2);margin-top:22px;max-width:34em}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.trustrow{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:28px;padding-top:24px;border-top:1px solid var(--line)}
.trustrow span{display:inline-flex;align-items:center;gap:7px;font-size:.86rem;color:var(--ink-3);font-weight:500}
.trustrow svg{flex:0 0 auto}

/* hero artifact card (signature) */
.artifact{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:22px}
.artifact .shopbar{display:flex;align-items:center;gap:8px;padding-bottom:16px;border-bottom:1px dashed var(--line-2);margin-bottom:18px}
.artifact .shopbar i{width:10px;height:10px;border-radius:50%;background:var(--line-2);display:inline-block}
.artifact .shopbar .u{margin-left:6px;font-family:var(--mono);font-size:.74rem;color:var(--ink-3)}
.wd-btn{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;background:var(--ink);color:#fff;font-weight:600;padding:14px;border-radius:var(--r-pill);font-size:.98rem}
.wd-btn .ic{font-family:var(--mono)}
.flowline{display:flex;justify-content:center;color:var(--ink-3);margin:14px 0}
.confirm{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:17px}
.confirm .tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-2);background:var(--brand-tint);padding:5px 10px;border-radius:var(--r-pill);font-weight:600}
.confirm .ref{font-family:var(--mono);font-size:.82rem;color:var(--ink-3);margin-top:13px}
.confirm .frist{display:flex;align-items:center;gap:10px;margin-top:11px;padding:11px 13px;background:#fff;border:1px solid var(--line);border-radius:9px}
.confirm .frist .ok{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-size:.7rem}
.confirm .frist b{font-size:.92rem}
.confirm .frist .sub{font-family:var(--mono);font-size:.74rem;color:var(--ink-3)}
.confirm .note{font-size:.8rem;color:var(--ink-3);margin-top:13px;padding-top:12px;border-top:1px dashed var(--line-2)}
.confirm .note b{color:var(--ink-2);font-weight:600}

/* section scaffold */
section{padding:78px 0}
.sec-head{max-width:40em;margin-bottom:44px}
.sec-head h2{font-size:clamp(1.7rem,3vw,2.35rem);line-height:1.12;letter-spacing:-.02em;font-weight:700;margin-top:12px}
.sec-head p{color:var(--ink-2);font-size:1.08rem;margin-top:14px}

/* stakes */
.stakes{background:var(--ink);color:#fff}
.stakes .eyebrow{color:#7FD8C9}
.stakes h2{color:#fff}
.stakes .sec-head p{color:#AFBACB}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.stat{background:#1B2C46;border:1px solid #283B58;border-radius:var(--r);padding:28px 26px}
.stat .num{font-family:var(--mono);font-size:clamp(1.7rem,3vw,2.25rem);font-weight:600;letter-spacing:-.01em;color:#fff}
.stat .num.warn{color:#FBBF77}
.stat .lbl{color:#AFBACB;margin-top:8px;font-size:.98rem}
.stakes .src{font-family:var(--mono);font-size:.76rem;color:#7C8AA3;margin-top:26px}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:step}
.step{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px 26px;box-shadow:var(--shadow-sm)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--mono);font-weight:600;font-size:.8rem;color:var(--brand-2);background:var(--brand-tint);width:38px;height:38px;border-radius:10px;display:grid;place-items:center;margin-bottom:18px}
.step h3{font-size:1.12rem;font-weight:600;letter-spacing:-.01em}
.step p{color:var(--ink-2);font-size:.96rem;margin-top:8px}
.steps-note{margin-top:26px;font-size:.98rem;color:var(--ink-2);display:flex;gap:10px;align-items:flex-start}
.steps-note .ic{color:var(--brand);flex:0 0 auto;margin-top:2px}

/* features */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card .ico{width:42px;height:42px;border-radius:11px;background:var(--brand-tint);color:var(--brand-2);display:grid;place-items:center;margin-bottom:18px}
.card h3{font-size:1.1rem;font-weight:600;letter-spacing:-.01em}
.card p{color:var(--ink-2);font-size:.95rem;margin-top:9px}

/* precision callout */
.precision{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--line);border-radius:24px;padding:clamp(34px,5vw,60px);box-shadow:var(--shadow)}
.precision .inner{max-width:46em}
.precision h2{font-size:clamp(1.6rem,2.8vw,2.2rem);line-height:1.14;letter-spacing:-.02em;margin:14px 0 0}
.precision p{color:var(--ink-2);font-size:1.1rem;margin-top:18px}
.precision .compare{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:30px}
.cmp{border-radius:var(--r-sm);padding:18px 20px;font-size:.95rem}
.cmp.bad{background:#FCF2F0;border:1px solid #F0D2CB}
.cmp.good{background:var(--brand-tint);border:1px solid #BFE0DA}
.cmp .h{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:7px}
.cmp.bad .h{color:var(--danger)}
.cmp.good .h{color:var(--brand-2)}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.plan{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%}
.plan.feature{border:1.5px solid var(--brand);box-shadow:var(--shadow);position:relative}
.plan .ribbon{position:absolute;top:-12px;left:28px;background:var(--brand);color:#fff;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:5px 12px;border-radius:var(--r-pill)}
.plan .pname{font-weight:600;font-size:1.05rem;letter-spacing:-.01em}
.plan .pdesc{color:var(--ink-3);font-size:.88rem;margin-top:4px;min-height:2.4em}
.plan .pprice{margin:18px 0 4px;display:flex;align-items:baseline;gap:6px}
.plan .pprice .v{font-family:var(--mono);font-size:2.1rem;font-weight:600;letter-spacing:-.02em}
.plan .pprice .per{color:var(--ink-3);font-size:.9rem}
.plan .ptrial{font-size:.82rem;color:var(--brand-2);font-weight:500;min-height:1.4em}
.plan ul{list-style:none;margin:22px 0 26px;display:flex;flex-direction:column;gap:11px}
.plan li{display:flex;gap:10px;font-size:.93rem;color:var(--ink-2);align-items:flex-start}
.plan li svg{flex:0 0 auto;margin-top:3px;color:var(--brand)}
.plan li .pre{color:var(--ink-3);font-style:italic}
.plan .btn{width:100%;justify-content:center;margin-top:auto}
.price-foot{text-align:center;margin-top:26px;font-size:.86rem;color:var(--ink-3)}

/* faq */
.faq-wrap{max-width:780px;margin:0 auto}
details{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:12px;overflow:hidden;transition:border-color .15s ease}
details[open]{border-color:var(--line-2);box-shadow:var(--shadow-sm)}
summary{cursor:pointer;list-style:none;padding:20px 22px;font-weight:600;font-size:1.02rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
summary::-webkit-details-marker{display:none}
summary .plus{flex:0 0 auto;font-family:var(--mono);color:var(--brand-2);transition:transform .2s ease}
details[open] summary .plus{transform:rotate(45deg)}
details .body{padding:0 22px 22px;color:var(--ink-2);font-size:.97rem}
details .body a{color:var(--brand-2);text-decoration:underline;text-underline-offset:2px}

/* final cta */
.final{background:var(--ink);color:#fff;border-radius:28px;padding:clamp(40px,6vw,70px);text-align:center;background-image:radial-gradient(120% 120% at 50% 0%,#1d3050 0%,#14233B 60%)}
.final h2{font-size:clamp(1.8rem,3.4vw,2.6rem);line-height:1.1;letter-spacing:-.02em;color:#fff}
.final p{color:#AFBACB;margin-top:16px;font-size:1.1rem}
.final .btn-primary{margin-top:30px;background:var(--brand);color:#fff}
.final .btn-primary:hover{background:#12877d}
.final .btn-soon{margin-top:30px}
.final .fine{margin-top:16px;font-size:.84rem;color:#8794AB;font-family:var(--mono)}

/* social proof */
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-sm)}
.quote .stars{color:#D9A441;letter-spacing:2px;font-size:.95rem}
.quote p{margin-top:12px;font-size:.97rem;color:var(--ink-2)}
.quote .who{margin-top:16px;font-size:.84rem;color:var(--ink-3);font-family:var(--mono)}
.proof-disclaimer{text-align:center;margin-top:22px;font-size:.8rem;color:var(--ink-3);font-style:italic}
.proof-single{max-width:720px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:clamp(30px,4vw,46px);box-shadow:var(--shadow-sm);text-align:center}
.proof-single::before{content:"§";display:block;font-family:var(--mono);font-weight:600;font-size:1.9rem;line-height:1;color:var(--brand);margin-bottom:16px}
.proof-single blockquote{font-size:clamp(1.1rem,2vw,1.32rem);line-height:1.5;color:var(--ink);font-weight:500;letter-spacing:-.01em}
.proof-single figcaption{margin-top:24px;display:flex;flex-direction:column;gap:3px}
.proof-single .who-name{font-weight:600;color:var(--ink)}
.proof-single .who-role{font-family:var(--mono);font-size:.82rem;color:var(--ink-3)}
.proof-single .who-role a{color:var(--brand-2);text-decoration:underline;text-underline-offset:2px}
.proof-single .who-role a:hover{color:var(--brand)}

/* footer */
footer{background:var(--surface);border-top:1px solid var(--line);padding:54px 0 40px;margin-top:20px}
.foot-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:26px;align-items:flex-start}
.foot-links{display:flex;gap:28px;flex-wrap:wrap;align-items:center}
.foot-links a{font-size:.92rem;color:var(--ink-2)}
.foot-links a:hover{color:var(--brand-2)}
.foot-links .soon{font-size:.92rem;color:var(--ink-3);cursor:not-allowed}
.foot-disclaimer{margin-top:30px;padding-top:22px;border-top:1px solid var(--line);font-size:.84rem;color:var(--ink-3);max-width:60em}
.foot-disclaimer .mono{color:var(--ink-2)}

/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   Unterseiten: Lesespalte (Impressum / Datenschutz) + 404
   ============================================================ */
.legal{max-width:760px;margin:0 auto;padding:64px 24px 72px}
.legal .eyebrow{display:block;margin-bottom:12px}
.legal h1{font-size:clamp(1.9rem,3.6vw,2.6rem);line-height:1.12;letter-spacing:-.02em;font-weight:700}
.legal .lead{font-size:1.12rem;color:var(--ink-2);margin-top:16px}
.legal h2{font-size:1.22rem;font-weight:600;letter-spacing:-.01em;margin-top:2em;margin-bottom:.5em}
.legal h3{font-size:1.02rem;font-weight:600;margin-top:1.5em;margin-bottom:.3em}
.legal p{color:var(--ink-2);margin-bottom:1em}
.legal ul,.legal ol{margin:0 0 1.1em 1.25em;color:var(--ink-2)}
.legal li{margin-bottom:.45em}
.legal a{color:var(--brand-2);text-decoration:underline;text-underline-offset:2px}
.legal address{font-style:normal}
.legal .ph{font-family:var(--mono);font-size:.9em;background:var(--signal-bg);color:#7c3a06;border:1px solid var(--signal-line);border-radius:5px;padding:1px 7px;white-space:nowrap}
.legal .callout{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:var(--r-sm);padding:16px 18px;margin:1.4em 0;font-size:.95rem;color:var(--ink-2)}
.legal .callout p:last-child{margin-bottom:0}
.legal .updated{font-family:var(--mono);font-size:.8rem;color:var(--ink-3);margin-top:2.6em;padding-top:1.2em;border-top:1px solid var(--line)}
.legal .backlink{display:inline-flex;align-items:center;gap:.5em;margin-top:1.6em;font-family:var(--mono);font-size:.82rem;color:var(--brand-2);text-decoration:none}
.legal .backlink:hover{text-decoration:underline}

.notfound{min-height:62vh;display:grid;place-items:center;text-align:center;padding:64px 24px}
.notfound .box{max-width:480px}
.notfound .bigmark{font-family:var(--mono);font-weight:600;background:var(--brand);color:#fff;width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:1.7rem;margin:0 auto 24px}
.notfound .code{font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-2);background:var(--brand-tint);display:inline-block;padding:5px 12px;border-radius:var(--r-pill);font-weight:600}
.notfound h1{font-size:1.8rem;letter-spacing:-.02em;margin:18px 0 10px}
.notfound p{color:var(--ink-2);margin-bottom:28px}

@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .stat-grid,.steps,.feat-grid,.price-grid,.proof-grid{grid-template-columns:1fr}
  .precision .compare{grid-template-columns:1fr}
  .nav-links{display:none}
  .hero{padding:48px 0 40px}
  section{padding:60px 0}
}
@media (max-width:520px){
  body{font-size:16px}
  .alertbar .wrap{align-items:flex-start}
  .hero-cta .btn{width:100%;justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.card,.arrow{transition:none}
}
