/* ============================================================
   TAXI MOERS® – Entwurf im easyCab-Stil (helle Farbwelt)
   hell + warmes Taxi-Gelb + dunkle Akzente
   ============================================================ */
:root{
  --bg:#ffffff;
  --bg-soft:#f4f6fa;
  --bg-soft2:#eef1f6;
  --ink:#15181e;          /* dunkle Flächen: topbar, footer, dark-cards */
  --ink-2:#1c2027;
  --gold:#f9b200;         /* warmes Taxi-Gelb */
  --gold-2:#ffc733;
  --gold-deep:#d99400;
  --text:#1b2230;
  --text-soft:#3c4555;
  --muted:#6a7385;
  --on-dark:#eef1f6;
  --on-dark-mut:#9aa4b6;
  --green:#1fa971;
  --line:#e4e8ef;
  --line-2:#d3d9e3;
  --max:1180px;
  --r:16px;
  --shadow:0 16px 40px rgba(23,33,55,.10);
  --shadow-sm:0 6px 18px rgba(23,33,55,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:"DM Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.55;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.mono{font-family:"Space Mono",ui-monospace,monospace;font-variant-numeric:tabular-nums;letter-spacing:.02em}
.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
h1,h2,h3{margin:0;line-height:1.12;font-weight:900;letter-spacing:-.02em}

/* Taxi-Karo Signature-Strip */
.checker{
  height:8px;width:100%;
  background:
    repeating-linear-gradient(90deg, var(--gold) 0 16px, transparent 16px 32px),
    repeating-linear-gradient(90deg, transparent 0 16px, #15181e 16px 32px);
  background-position:0 0, 16px 0;
  background-size:32px 8px, 32px 8px;
}

/* ---------- Top contact bar (dunkel) ---------- */
.topbar{background:var(--ink);color:var(--on-dark);font-size:13px}
.topbar .wrap{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding-top:8px;padding-bottom:8px}
.topbar .ti{display:inline-flex;align-items:center;gap:7px;color:var(--on-dark-mut)}
.topbar .ti svg{width:15px;height:15px;fill:var(--gold);flex-shrink:0}
.topbar .ti.mono{color:#fff}
.topbar .spacer{margin-left:auto}
.topbar .social{display:inline-flex;gap:8px}
.topbar .social a{width:30px;height:30px;border:1px solid rgba(255,255,255,.16);border-radius:9px;display:grid;place-items:center}
.topbar .social a svg{width:15px;height:15px;fill:#fff}
.topbar .social a:hover{border-color:var(--gold);background:rgba(249,178,0,.16)}
@media(max-width:720px){.topbar .ti.addr{display:none}}

/* ---------- Header (hell) ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(23,33,55,.03)}
.nav{display:flex;align-items:center;gap:16px;padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:10px}
.brand .mark{width:40px;height:40px;border-radius:11px;background:linear-gradient(150deg,var(--gold),var(--gold-deep));display:grid;place-items:center;box-shadow:0 6px 16px rgba(249,178,0,.32)}
.brand .mark svg{width:23px;height:23px;fill:#15181e}
.brand b{font-size:18px;display:block;letter-spacing:-.01em;color:var(--text)}
.brand small{display:block;font-size:11.5px;color:var(--muted);font-weight:600;margin-top:1px}
.mainnav{display:flex;gap:4px;margin-left:14px}
.mainnav a{padding:9px 12px;border-radius:10px;font-weight:600;font-size:14.5px;color:var(--text-soft)}
.mainnav a:hover{background:var(--bg-soft);color:var(--text)}
.nav .right{margin-left:auto;display:flex;align-items:center;gap:10px}
.callbtn{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:#15181e;font-weight:800;padding:10px 16px;border-radius:999px;font-size:15px;white-space:nowrap}
.callbtn svg{width:16px;height:16px;fill:#15181e}
.callbtn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(249,178,0,.4)}
.callbtn .mono{font-size:15px}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line-2);border-radius:10px;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:18px;height:2px;background:var(--text);margin:2.5px 0;border-radius:2px}
@media(max-width:940px){.mainnav{display:none}.burger{display:flex}.callbtn .mono{display:none}}

.mmenu{display:none;border-top:1px solid var(--line);background:var(--bg)}
.mmenu.open{display:block}
.mmenu a{display:block;padding:13px 20px;border-bottom:1px solid var(--line);font-weight:600;color:var(--text)}
.mmenu a:hover{background:var(--bg-soft)}

/* ---------- Hero (hell) ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(820px 420px at 10% -10%, rgba(249,178,0,.16), transparent 60%),
  linear-gradient(180deg,#ffffff 0,var(--bg-soft) 100%);
  padding:54px 0 64px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--gold-deep);background:rgba(249,178,0,.14);border:1px solid rgba(249,178,0,.4);padding:6px 13px;border-radius:999px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(31,169,113,.18)}
.hero h1{font-size:clamp(30px,4.6vw,52px);margin:18px 0 14px;color:var(--text)}
.hero h1 .hl{color:var(--gold-deep)}
.hero .lead{font-size:clamp(15px,1.7vw,18px);color:var(--text-soft);max-width:560px;margin:0 0 22px}
.trust{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.trust .chip{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text-soft);background:#fff;border:1px solid var(--line);padding:7px 12px;border-radius:10px;box-shadow:var(--shadow-sm)}
.trust .chip svg{width:15px;height:15px;fill:var(--gold-deep)}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:800;font-size:15.5px;padding:14px 22px;border-radius:13px;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s,background .15s}
.btn svg{width:18px;height:18px}
.btn-gold{background:var(--gold);color:#15181e;box-shadow:0 6px 18px rgba(249,178,0,.32)}
.btn-gold svg{fill:#15181e}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(249,178,0,.44)}
.btn-ghost{background:#fff;color:var(--text);border:1.5px solid var(--line-2)}
.btn-ghost svg{fill:var(--gold-deep)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(249,178,0,.08);transform:translateY(-2px)}

/* Preisanfrage card – Signature */
.req{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);overflow:hidden;position:relative}
.req::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-2))}
.req-head{padding:20px 22px 14px;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--line)}
.req-head .ic{width:38px;height:38px;border-radius:11px;background:rgba(249,178,0,.14);display:grid;place-items:center}
.req-head .ic svg{width:20px;height:20px;fill:var(--gold-deep)}
.req-head h3{font-size:18px;color:var(--text)}
.req-head p{margin:2px 0 0;font-size:12.5px;color:var(--muted);font-weight:500}
.req-body{padding:18px 22px 22px}
.seg{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:16px}
.seg button{font:inherit;font-size:12.5px;font-weight:700;padding:9px 6px;border-radius:10px;border:1px solid var(--line-2);background:#fff;color:var(--text-soft);cursor:pointer;transition:.12s;line-height:1.2}
.seg button.on{border-color:var(--gold);background:rgba(249,178,0,.16);color:var(--text)}
.seg button:hover{border-color:var(--gold)}
.fld{margin-bottom:12px}
.fld label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:5px}
.fld input{width:100%;padding:11px 13px;border-radius:11px;border:1.5px solid var(--line-2);background:#fff;color:var(--text);font:inherit;font-size:15px}
.fld input::placeholder{color:#9aa3b3}
.fld input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(249,178,0,.16)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.req .btn{width:100%;margin-top:4px}
.req-hint{text-align:center;font-size:12px;color:var(--muted);margin:11px 0 0}
.req-hint a{color:var(--gold-deep);font-weight:700}
.req-ok{display:none;padding:8px 0 0}
.req-ok.show{display:block}
.req-ok .box{background:rgba(31,169,113,.1);border:1px solid rgba(31,169,113,.35);border-radius:12px;padding:14px;font-size:14px;color:var(--text)}
.req-ok .box b{color:var(--green)}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:30px}.req{order:-1}}

/* ---------- Info banner ---------- */
.banner{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.banner .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding-top:22px;padding-bottom:22px}
.bi{display:flex;gap:13px;align-items:flex-start}
.bi .ic{width:42px;height:42px;border-radius:12px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0;box-shadow:var(--shadow-sm)}
.bi .ic svg{width:21px;height:21px;fill:var(--gold-deep)}
.bi b{display:block;font-size:15px;margin-bottom:2px;color:var(--text)}
.bi span{font-size:13px;color:var(--muted)}
.bi .mono{color:var(--text);font-size:13.5px}
@media(max-width:820px){.banner .wrap{grid-template-columns:1fr}}

/* ---------- Section base ---------- */
.sec{padding:64px 0}
.sec.alt{background:var(--bg-soft)}
.sec-head{text-align:center;max-width:640px;margin:0 auto 40px}
.sec-head .kick{font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
.sec-head h2{font-size:clamp(24px,3vw,36px);margin:10px 0 12px;color:var(--text)}
.sec-head p{color:var(--muted);font-size:15.5px;margin:0}

/* services */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow-sm);transition:transform .18s,border-color .18s,box-shadow .18s}
.card:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:var(--shadow)}
.card .ic{width:50px;height:50px;border-radius:13px;background:rgba(249,178,0,.14);display:grid;place-items:center;margin-bottom:16px}
.card .ic svg{width:26px;height:26px;fill:var(--gold-deep)}
.card h3{font-size:19px;margin-bottom:9px;color:var(--text)}
.card p{margin:0;color:var(--text-soft);font-size:14.5px}
.card ul{margin:12px 0 0;padding:0;list-style:none}
.card li{position:relative;padding-left:20px;margin:6px 0;font-size:14px;color:var(--text-soft)}
.card li::before{content:"";position:absolute;left:0;top:8px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
@media(max-width:900px){.cards{grid-template-columns:1fr}}

/* price/cost cards */
.pcards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.pcard.feature{border-color:rgba(249,178,0,.5);box-shadow:0 0 0 1px rgba(249,178,0,.25),var(--shadow)}
.pcard.feature::before{content:"Beliebt";position:absolute;top:14px;right:14px;font-size:11px;font-weight:800;color:#15181e;background:var(--gold);padding:3px 10px;border-radius:999px}
.pcard .t{font-size:13px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--gold-deep)}
.pcard .big{margin:12px 0 4px;font-size:30px;font-weight:900;color:var(--text)}
.pcard .big small{font-size:14px;font-weight:600;color:var(--muted)}
.pcard .desc{font-size:14px;color:var(--text-soft);margin:10px 0 16px}
.pcard ul{margin:0;padding:0;list-style:none}
.pcard li{display:flex;gap:9px;align-items:flex-start;font-size:14px;margin:8px 0;color:var(--text-soft)}
.pcard li svg{width:17px;height:17px;fill:var(--green);flex-shrink:0;margin-top:2px}
.pcard .btn{width:100%;margin-top:18px}
@media(max-width:900px){.pcards{grid-template-columns:1fr}}

/* why us */
.why{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.why-list{display:grid;gap:14px}
.wl{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px;box-shadow:var(--shadow-sm)}
.wl .n{font-family:"Space Mono",monospace;font-weight:700;color:var(--gold-deep);font-size:15px;flex-shrink:0;width:34px;height:34px;border:1px solid rgba(249,178,0,.45);border-radius:9px;display:grid;place-items:center}
.wl b{display:block;font-size:15.5px;margin-bottom:3px;color:var(--text)}
.wl span{font-size:14px;color:var(--muted)}
/* dunkler Kontrast-Block rechts */
.why-art{background:linear-gradient(160deg,var(--ink-2),var(--ink));border-radius:20px;padding:32px;text-align:center;box-shadow:var(--shadow)}
.why-art .num{font-family:"Space Mono",monospace;font-size:58px;font-weight:700;color:var(--gold);line-height:1}
.why-art .num small{display:block;font-size:14px;color:var(--on-dark-mut);font-weight:400;letter-spacing:.1em;text-transform:uppercase;margin-top:8px}
.why-art .div{height:1px;background:rgba(255,255,255,.12);margin:24px 0}
.why-art .phone{font-family:"Space Mono",monospace;font-size:26px;font-weight:700;color:#fff}
.why-art .lbl{font-size:13px;color:var(--on-dark-mut);margin-top:4px}
@media(max-width:900px){.why{grid-template-columns:1fr;gap:28px}}

/* areas */
.areas{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.areas a{font-weight:700;font-size:14px;padding:10px 18px;border-radius:999px;border:1px solid var(--line-2);background:#fff;color:var(--text-soft);box-shadow:var(--shadow-sm)}
.areas a:hover{border-color:var(--gold);background:rgba(249,178,0,.1);color:var(--text)}

/* google cta */
.gcta{max-width:560px;margin:34px auto 0;text-align:center;background:#fff;border:1px solid rgba(249,178,0,.4);border-radius:18px;padding:26px;box-shadow:var(--shadow-sm)}
.gcta .stars{font-size:22px;color:var(--gold);letter-spacing:3px;margin-bottom:8px}
.gcta p{color:var(--text-soft);font-size:14.5px;margin:0 0 16px}

/* footer (dunkel) */
footer.site{background:var(--ink);color:var(--on-dark);padding:48px 0 28px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:30px}
.fbrand b{font-size:18px;color:#fff}
.fbrand p{color:var(--on-dark-mut);font-size:14px;margin:10px 0 0;max-width:320px}
.fcol h4{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);margin:0 0 12px}
.fcol a{display:block;color:var(--on-dark);font-size:14px;padding:5px 0}
.fcol a:hover{color:var(--gold)}
.fcol .ci{display:flex;gap:8px;align-items:center;color:var(--on-dark);font-size:14px;padding:5px 0}
.fcol .ci svg{width:15px;height:15px;fill:var(--gold)}
.fbot{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:var(--on-dark-mut);font-size:13px}
@media(max-width:820px){.fgrid{grid-template-columns:1fr 1fr}.fbrand{grid-column:1/-1}}
@media(max-width:520px){.fgrid{grid-template-columns:1fr}}

/* sticky mobile bar */
.mbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:70;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line-2);padding:10px 14px calc(10px + env(safe-area-inset-bottom,0px));gap:10px;box-shadow:0 -6px 20px rgba(23,33,55,.08)}
.mbar a{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;font-weight:800;font-size:14.5px;padding:13px;border-radius:12px}
.mbar .c{background:var(--gold);color:#15181e}.mbar .c svg{fill:#15181e;width:17px;height:17px}
.mbar .p{background:#fff;color:var(--text);border:1px solid var(--line-2)}.mbar .p svg{fill:var(--gold-deep);width:17px;height:17px}
@media(max-width:940px){.mbar{display:flex}body{padding-bottom:74px}}

/* reveal */
.rv{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}
:focus-visible{outline:2px solid var(--gold-deep);outline-offset:2px}

/* ============================================================
   DARK MODE  (Standard = Hell; <html class="dark"> = Dunkel)
   Nur Token-Überschreibungen + Flächen, die hell hartcodiert waren.
   ============================================================ */
:root{
  --surface:#ffffff;
  --surface-2:#f7f9fc;
  --header-bg:rgba(255,255,255,.92);
}
html.dark{
  --bg:#0e1320;
  --bg-soft:#121a28;
  --bg-soft2:#0c121e;
  --surface:#161f30;
  --surface-2:#1b2536;
  --ink:#0a0e16;
  --ink-2:#0f1622;
  --on-dark:#eef1f6;
  --on-dark-mut:#9aa4b6;
  --gold:#ffc02e;
  --gold-2:#ffd45e;
  --gold-deep:#ffca4a;
  --text:#e7ecf5;
  --text-soft:#c2cbdb;
  --muted:#8c96a8;
  --green:#39d98a;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.17);
  --header-bg:rgba(14,19,32,.9);
  --shadow:0 16px 40px rgba(0,0,0,.5);
  --shadow-sm:0 6px 18px rgba(0,0,0,.4);
}
/* hell hartcodierte Flächen im Dark-Mode auf Tokens umbiegen */
html.dark header.site{background:var(--header-bg)}
html.dark .hero{background:
  radial-gradient(820px 420px at 10% -10%, rgba(249,178,0,.10), transparent 60%),
  linear-gradient(180deg,var(--bg) 0,var(--bg-soft) 100%)}
html.dark .trust .chip,
html.dark .req,
html.dark .fld input,
html.dark .seg button,
html.dark .bi .ic,
html.dark .card,
html.dark .pcard,
html.dark .wl,
html.dark .areas a,
html.dark .gcta,
html.dark .btn-ghost{background:var(--surface)}
html.dark .mbar{background:var(--header-bg)}
html.dark .seg button{color:var(--text-soft)}
html.dark .fld input::placeholder{color:#73809a}

/* ============================================================
   THEME-UMSCHALTER (Sonne/Mond)
   ============================================================ */
.theme-tog{
  width:42px;height:42px;border-radius:999px;cursor:pointer;
  border:1px solid var(--line-2);background:var(--surface);color:var(--text);
  display:grid;place-items:center;transition:.15s;flex-shrink:0;
}
.theme-tog:hover{border-color:var(--gold);background:rgba(249,178,0,.1)}
.theme-tog svg{width:20px;height:20px;fill:var(--gold-deep)}
.theme-tog .moon{display:none}
html.dark .theme-tog .sun{display:none}
html.dark .theme-tog .moon{display:block}

/* ============================================================
   DOKUMENT-SEITEN (agb/haftung/imp/ds …)  – Scope: .doc
   Nutzt durchgehend Tokens -> Hell/Dunkel automatisch.
   ============================================================ */
.doc-page{padding-bottom:40px}
.doc-head{position:sticky;top:0;z-index:60;background:var(--header-bg);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.doc-head .inner{max-width:920px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:12px}
.doc-head .right{margin-left:auto;display:flex;align-items:center;gap:10px}
.doc{max-width:920px;margin:0 auto;padding:clamp(14px,2.5vw,26px)}
.doc .card{background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);padding:clamp(16px,2.5vw,28px)}
.doc h1,.doc .page-title{font-size:clamp(22px,3vw,30px);font-weight:900;color:var(--text);margin:0 0 .35rem;letter-spacing:-.01em;line-height:1.2}
.doc h2,.doc .section-title{font-size:1.12rem;font-weight:800;color:var(--text);margin:1.1rem 0 .4rem}
.doc h3{font-size:1rem;font-weight:700;color:var(--text);margin:.8rem 0 .3rem}
.doc p,.doc li{color:var(--text-soft);font-size:.96rem;line-height:1.62}
.doc strong{color:var(--text)}
.doc a{color:var(--gold-deep);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.doc a:hover{text-decoration:none}
.doc .muted,.doc small,.doc .sub,.doc .footnote{color:var(--muted);font-size:.9rem}
.doc .underline{height:3px;width:84px;border-radius:3px;background:linear-gradient(90deg,var(--gold),transparent);margin:12px 0 18px}
.doc .block{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin:.7rem 0}
.doc .hr{border:0;border-top:1px solid var(--line);margin:1rem 0}
.doc ul,.doc ol{margin:.4rem 0 .6rem 1.2rem}
.doc li{margin:.25rem 0}
.doc .pill{display:inline-block;padding:.32rem .72rem;border:1px solid var(--line);border-radius:999px;background:var(--bg-soft);color:var(--text);font-weight:700;font-size:.82rem;margin:.15rem .15rem 0 0}
.doc .kv{display:grid;grid-template-columns:220px 1fr;gap:10px 16px;align-items:start;margin:.3rem 0}
.doc .kv dt{font-weight:800;color:var(--text)}
.doc .kv dd{margin:0;color:var(--text-soft)}
@media(max-width:640px){.doc .kv{grid-template-columns:1fr}.doc .kv dt{margin-top:8px}}
.doc table{width:100%;border-collapse:collapse;margin:.4rem 0}
.doc th,.doc td{border-bottom:1px solid var(--line);padding:.5rem;text-align:left;vertical-align:top;font-size:.88rem;color:var(--text-soft)}
.doc th{color:var(--text);font-weight:800}
.doc .grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:640px){.doc .grid{grid-template-columns:1fr}}
.doc .actions{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:1rem 0}
@media(max-width:680px){.doc .actions{grid-template-columns:1fr}}
.doc .a-btn,.doc .btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;text-align:center;
  padding:13px 16px;border-radius:12px;font-weight:800;text-decoration:none;cursor:pointer;border:1px solid var(--line-2);
  background:var(--surface);color:var(--text);transition:transform .15s,border-color .15s,box-shadow .15s;min-height:58px}
.doc .a-btn:hover,.doc .btn:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:var(--shadow-sm)}
.doc .a-btn small{font-weight:600;color:var(--muted)}
.doc .a-btn.primary,.doc .btn.primary,.doc .btn:not(.warn):not(.ghost){background:var(--gold);color:#15181e;border-color:transparent}
.doc .a-btn.primary small{color:rgba(0,0,0,.6)}
.doc .a-btn.ghost,.doc .btn.ghost{background:transparent}
.doc .btn.warn{background:linear-gradient(90deg,#f7b740,#f59e0b);color:#15181e;border-color:transparent}
.doc-foot{max-width:920px;margin:30px auto 0;padding:20px;border-top:1px solid var(--line);color:var(--muted);font-size:.86rem;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center}
.doc-foot a{color:var(--gold-deep);font-weight:600}

/* ============================================================
   FAQ-Raster + SEO-/SR-Hilfsklassen (für index-neu.php)
   ============================================================ */
.faqgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.faq-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow-sm)}
.faq-card h3{font-size:16px;margin:0 0 6px;color:var(--text);font-weight:800;line-height:1.3}
.faq-card p{margin:0;color:var(--text-soft);font-size:14px;line-height:1.55}
.faq-card a{color:var(--gold-deep);font-weight:600}
@media(max-width:760px){.faqgrid{grid-template-columns:1fr}}
.visually-hidden,.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}
/* Verordnungs-Teaser im Hero */
.verordnung-teaser{margin:18px 0 0;padding:14px 16px;background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:12px;font-size:14px;color:var(--text-soft)}
.verordnung-teaser strong{color:var(--text)}
.verordnung-teaser p{margin:.3rem 0}

/* ============================================================
   LOGO im Header
   ============================================================ */
.brand-logo{height:44px;width:auto;display:block}
@media(max-width:520px){.brand-logo{height:38px}}

/* ============================================================
   FESTPREIS-MERKLISTE (Floating-Button) + BESTELL-MODAL
   Logik 1:1 aus index.php, Optik neu (hell + dark)
   ============================================================ */
.qb-fab{position:fixed;right:16px;bottom:84px;z-index:75;display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);color:#15181e;border:none;border-radius:999px;padding:12px 18px;font:inherit;font-weight:800;font-size:15px;
  cursor:pointer;box-shadow:0 8px 22px rgba(249,178,0,.4)}
.qb-fab:hover{transform:translateY(-2px)}
.qb-fab svg{width:18px;height:18px;fill:#15181e}
.qb-fab #qb-badge{display:none;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#15181e;color:var(--gold);font-size:12px;font-weight:800}
@media(min-width:941px){.qb-fab{bottom:20px}}

.q-panel{position:fixed;right:16px;bottom:140px;z-index:76;width:min(360px,calc(100vw - 32px));
  background:var(--surface);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow);
  padding:16px;display:none}
.q-panel.active{display:block}
.q-panel h4{margin:0 0 10px;font-size:16px;color:var(--text)}
.qlist{max-height:46vh;overflow:auto;display:flex;flex-direction:column;gap:8px}
.qlist .muted{color:var(--muted);font-size:14px;margin:4px 0}
.qrow{display:flex;align-items:flex-start;gap:9px;background:var(--bg-soft);border:1px solid var(--line);border-radius:11px;padding:10px}
.qrow .qinfo{flex:1;display:flex;flex-direction:column;gap:2px}
.qrow .qinfo strong{color:var(--text);font-size:14px}
.qrow .qinfo .meta{color:var(--text-soft);font-size:12.5px}
.qrow .qinfo .time{color:var(--muted);font-size:11.5px}
.qrow .qrmd{border:none;background:transparent;color:var(--muted);font-size:20px;line-height:1;cursor:pointer;padding:0 2px}
.qrow .qrmd:hover{color:#d64646}
.q-panel .row{display:flex;gap:8px}
.q-panel button.primary,.q-panel button.ghost{flex:1;font:inherit;font-weight:800;font-size:14px;padding:11px;border-radius:11px;cursor:pointer;border:1px solid var(--line-2)}
.q-panel button.primary{background:var(--gold);color:#15181e;border-color:transparent}
.q-panel button.ghost{background:transparent;color:var(--text)}

.order-overlay{position:fixed;inset:0;background:rgba(10,14,22,.55);z-index:90;display:none}
.order-overlay.show{display:block}
.order-modal{position:fixed;inset:0;z-index:91;display:none;align-items:center;justify-content:center;padding:16px}
.order-modal.show{display:flex}
.order-card{background:var(--surface);border:1px solid var(--line-2);border-radius:18px;box-shadow:var(--shadow);width:min(560px,100%);max-height:90vh;overflow:auto}
.order-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}
.order-head strong{font-size:17px;color:var(--text)}
.order-body{padding:18px 20px}
.order-body .row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:520px){.order-body .row{grid-template-columns:1fr}}
.order-body label{display:block;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:5px}
.order-body input{width:100%;padding:11px 13px;border-radius:11px;border:1.5px solid var(--line-2);background:var(--surface);color:var(--text);font:inherit;font-size:15px}
.order-body input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(249,178,0,.16)}
.otrip{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:12px;margin:10px 0}
.otrip>label{text-transform:none;font-size:14px;font-weight:700;color:var(--text);letter-spacing:0}
.otrip .row{margin-top:8px;margin-bottom:0}
.order-card .actions{display:flex;gap:10px;margin-top:14px}
.btnp{font:inherit;font-weight:800;font-size:15px;padding:12px 18px;border-radius:12px;cursor:pointer;border:1px solid var(--line-2);background:transparent;color:var(--text)}
.btnp.primary{background:var(--gold);color:#15181e;border-color:transparent;flex:1}
.btnp.ghost{background:transparent;color:var(--text)}
.msg{font-size:14px;margin:10px 0 0;white-space:pre-line}
.msg.ok{color:var(--green);font-weight:700}
.msg.err{color:#d64646;font-weight:700}
#orderSummary{color:var(--text-soft);font-weight:700;margin-bottom:6px}


/* ============================================================
   Token-Scope für portierte Original-Sektionen (Bewertungen + partner-care)
   Bewusst dunkle Sektionen -> eigene Tokens, lesbar auf der hellen Seite
   ============================================================ */
#bewertungen,#partner-care{--neon:#ffd000;--line:rgba(255,255,255,.12);--glow1:rgba(255,208,0,.15);--glow2:rgba(255,208,0,.06);--cols:3;--gap:16px}
#bewertungen.section,#partner-care.section{padding:60px 0}
@media(max-width:760px){#bewertungen,#partner-care{--cols:1}}

/* ============================================================
   FIXES (Screenshots): Lesbarkeit, Navbar, FAB
   ============================================================ */
/* Buttons gegen geleakte globale .btn-Regeln absichern -> immer lesbar */
a.btn-gold{background:var(--gold)!important;color:#15181e!important;border:none!important;padding:14px 22px!important;border-radius:13px!important;font-weight:800!important}
a.btn-gold svg{fill:#15181e!important}
a.btn-ghost{background:#fff!important;color:var(--text)!important;border:1.5px solid var(--line-2)!important;padding:14px 22px!important;border-radius:13px!important;font-weight:800!important}
a.btn-ghost svg{fill:var(--gold-deep)!important}
html.dark a.btn-ghost{background:var(--surface)!important;color:var(--text)!important}

/* Burger = klares „☰ Menü" */
.burger{width:auto!important;height:44px;padding:0 14px;display:none;align-items:center;gap:9px;border:1px solid var(--line-2);border-radius:11px;background:var(--surface);cursor:pointer}
.burger .bl{display:flex;flex-direction:column;gap:4px}
.burger .bl span{display:block;width:18px;height:2px;background:var(--text);border-radius:2px;margin:0}
.burger-txt{font-size:14.5px;font-weight:800;color:var(--text)}
@media(max-width:940px){.burger{display:flex}}
.mmenu{max-height:70vh;overflow:auto}

/* Festpreis-Merkliste-FAB: nur sichtbar wenn etwas gemerkt ist (JS schaltet) */
.qb-fab{display:none}

/* Öffnungszeiten: Sektions-Überschrift dunkel/hell – Box bleibt dunkles Highlight */
#oeffnungszeiten .k-headline{color:#0f172a!important;text-shadow:none!important}
html.dark #oeffnungszeiten .k-headline{color:#e7ecf5!important}

/* ============================================================
   MENÜ-OVERLAY (wie Original) + sauberer Burger
   ============================================================ */
.burger{width:auto!important;height:44px;padding:0 16px;display:none;align-items:center;gap:9px;
  border:1.5px solid var(--gold)!important;border-radius:12px;background:rgba(249,178,0,.12)!important;
  color:var(--text)!important;font-weight:800;font-size:15px;cursor:pointer}
.burger .bl{display:flex;flex-direction:column;gap:4px}
.burger .bl span{display:block;width:18px;height:2px;background:var(--gold-deep);border-radius:2px;margin:0}
.burger-txt{display:none}
@media(max-width:940px){.burger{display:flex}}

.navsheet{position:fixed;inset:0;z-index:200;display:none;background:rgba(8,12,20,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.navsheet.open{display:block}
.navsheet-panel{position:absolute;top:0;right:0;height:100%;width:min(430px,90vw);background:var(--surface);
  box-shadow:-24px 0 70px rgba(0,0,0,.35);display:flex;flex-direction:column;animation:navIn .26s cubic-bezier(.2,.7,.3,1)}
@keyframes navIn{from{transform:translateX(102%)}to{transform:translateX(0)}}
.navsheet-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface)}
.navsheet-head .brand-logo{height:40px}
.navsheet-x{width:44px;height:44px;border-radius:11px;border:1px solid var(--line-2);background:var(--bg-soft);font-size:17px;color:var(--text);cursor:pointer}
.navsheet-links{flex:1;overflow:auto;padding:4px 0}
.navsheet-links>a,.navgroup>summary{display:block;padding:16px 22px;font-weight:800;font-size:18px;color:var(--text);
  border-bottom:1px solid var(--line);text-decoration:none;cursor:pointer;transition:background .12s}
.navsheet-links>a:hover{background:var(--bg-soft);padding-left:26px}
.navgroup{border-bottom:1px solid var(--line)}
.navgroup>summary{list-style:none;display:flex;align-items:center;justify-content:space-between;border-bottom:none}
.navgroup>summary::-webkit-details-marker{display:none}
.navgroup>summary::after{content:"▾";color:var(--gold-deep);font-size:15px;transition:transform .2s}
.navgroup[open]>summary::after{transform:rotate(180deg)}
.navgroup a{display:block;padding:12px 22px 12px 40px;font-weight:600;font-size:15.5px;color:var(--text-soft);text-decoration:none}
.navgroup a:hover{background:var(--bg-soft);color:var(--text)}
.navsheet-cta{padding:16px 18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px;background:var(--surface)}
.navsheet-cta .btn{width:100%}

/* ============================================================
   ÖFFNUNGSZEITEN -> HELL (Box war dunkel)
   ============================================================ */
#oeffnungszeiten{--card:#ffffff;--line:rgba(10,20,40,.13);--text:#0f172a;--muted:#475569;--neon:#c98a00}
#oeffnungszeiten .neo{background:#fff!important;border:1px solid rgba(10,20,40,.10)!important;box-shadow:0 22px 54px rgba(23,33,55,.13)!important}
#oeffnungszeiten .neo__header h3,#oeffnungszeiten .k-headline{color:#0f172a!important;text-shadow:none!important}
#oeffnungszeiten .k-status .detail{color:#475569!important}
#oeffnungszeiten .k-hours li{background:#f6f8fc!important;border-color:rgba(10,20,40,.12)!important;color:#0f172a!important}
#oeffnungszeiten .k-hours li:nth-child(odd){background:#f6f8fc!important}
#oeffnungszeiten .k-hours li:nth-child(even){background:#eef2f8!important;border-color:rgba(10,20,40,.12)!important}
#oeffnungszeiten .k-hours li span,#oeffnungszeiten .k-hours li .k-cell{color:#0f172a!important}
#oeffnungszeiten .k-hours li b{color:#c98a00!important}
#oeffnungszeiten .k-hours li.active{background:linear-gradient(180deg,rgba(201,138,0,.15),rgba(201,138,0,.06))!important;border-color:rgba(201,138,0,.55)!important}
#oeffnungszeiten .k-hint{color:#475569!important;background:linear-gradient(180deg,rgba(201,138,0,.12),rgba(201,138,0,.05))!important;border-color:rgba(201,138,0,.4)!important}

/* ============================================================
   BEWERTUNGEN -> HELL (Section + Karten + Google-Box)
   ============================================================ */
#bewertungen{background:linear-gradient(180deg,#f7f9fd,#eef2f8)!important}
#bewertungen h2,#bewertungen .rev-title{color:#0f172a!important}
#bewertungen .rev-toggle-btn{background:#fff!important;color:#0f172a!important;border:1px solid rgba(10,20,40,.14)!important}
#bewertungen .rev-card{background:#fff!important;border:1px solid rgba(10,20,40,.10)!important;box-shadow:0 14px 36px rgba(23,33,55,.10)!important}
#bewertungen .rev-text{color:#1b2230!important}
#bewertungen .rev-meta{color:#64748b!important}
#bewertungen .rev-meta a{color:#c98a00!important;border-bottom-color:rgba(201,138,0,.4)!important}
#bewertungen .rev-stars span,#bewertungen .rev-stars{color:#e0a200!important}
#bewertungen .rev-badge{background:#eef2fb!important;color:#1b2230!important;border:1px solid rgba(10,20,40,.12)!important}
#bewertungen .rev-arrow{background:#fff!important;color:#0f172a!important;border:1px solid rgba(10,20,40,.14)!important;box-shadow:0 6px 18px rgba(23,33,55,.12)!important}
#bewertungen .rev-google-box{background:#fff!important;border:1px solid rgba(201,138,0,.45)!important;box-shadow:0 18px 44px rgba(23,33,55,.12)!important}
#bewertungen .rev-google-badge{background:#fff7e0!important}
#bewertungen .rev-google-badge,#bewertungen .rev-google-badge span{color:#b07d00!important}
#bewertungen .rev-google-title{color:#c98a00!important}
#bewertungen .rev-google-text{color:#475569!important}
#bewertungen .rev-google-stars span{color:#e0a200!important}

/* ============================================================
   HERO -> auffällig (warmer animierter Verlauf + Glow + Taxi-Streifen)
   ============================================================ */
.hero{position:relative;overflow:hidden;
  background:
   radial-gradient(1100px 480px at 88% -12%, rgba(249,178,0,.26), transparent 60%),
   radial-gradient(820px 460px at -8% 8%, rgba(249,178,0,.14), transparent 55%),
   linear-gradient(180deg,#fffdf6,#f5f8fc)}
.hero::before{content:"";position:absolute;left:0;right:0;top:0;height:8px;
  background:repeating-linear-gradient(90deg,#15181e 0 26px,var(--gold) 26px 52px);
  box-shadow:0 2px 10px rgba(0,0,0,.12);z-index:2}
.hero::after{content:"";position:absolute;top:-35%;right:-12%;width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(249,178,0,.22),transparent 70%);filter:blur(22px);
  animation:heroPulse 6.5s ease-in-out infinite;pointer-events:none;z-index:0}
@keyframes heroPulse{0%,100%{transform:scale(1);opacity:.65}50%{transform:scale(1.18);opacity:1}}
.hero .wrap{position:relative;z-index:1}
.hero .eyebrow{box-shadow:0 0 0 1px rgba(249,178,0,.4),0 8px 24px rgba(249,178,0,.18)}
.hero .eyebrow .dot{box-shadow:0 0 0 4px rgba(249,178,0,.25);animation:dotPulse 2s ease-in-out infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 3px rgba(249,178,0,.3)}50%{box-shadow:0 0 0 7px rgba(249,178,0,.08)}}
html.dark .hero{background:
   radial-gradient(1100px 480px at 88% -12%, rgba(249,178,0,.16), transparent 60%),
   radial-gradient(820px 460px at -8% 8%, rgba(249,178,0,.08), transparent 55%),
   linear-gradient(180deg,#0e1320,#0b0f1a)}

/* ============================================================
   FIX v3 – Menü, Burger, Klinikkarten, Google-Box
   ============================================================ */
/* Burger: kompakt, proportional, SVG-Icon */
.burger{width:auto!important;height:42px!important;min-width:0!important;padding:0 14px!important;gap:8px;
  display:none;align-items:center;justify-content:center;border:1.5px solid var(--gold)!important;border-radius:11px;
  background:rgba(249,178,0,.12)!important;color:var(--text)!important;font-weight:800;font-size:15px;line-height:1}
.burger svg{stroke:var(--gold-deep);width:20px;height:20px}
.burger>span{color:var(--text)!important}
@media(max-width:940px){.burger{display:inline-flex!important}}

/* Menü-Panel: garantiert deckend + volle Höhe, Links sichtbar */
.navsheet-panel{position:fixed!important;top:0;right:0;bottom:0;height:100dvh;width:min(430px,90vw);
  background:#ffffff!important}
html.dark .navsheet-panel{background:#141a26!important}
.navsheet-links>a,.navgroup>summary{color:#0f172a!important;background:transparent}
html.dark .navsheet-links>a,html.dark .navgroup>summary{color:#eef2f8!important}
.navgroup a{color:#475569!important}
html.dark .navgroup a{color:#aab4c5!important}

/* Klinikfahrten + EA-Rechner: blasse/weiße Texte lesbar machen (pc-light war unvollständig) */
#partner-care .pc-title{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important;text-shadow:none!important;background:none!important}
#partner-care .pc-sub,#partner-care .pc-sub b,#partner-care .pc-sub *{color:#334155!important}
#partner-care .pc-name,.pc-name{color:#0f172a!important;-webkit-text-fill-color:#0f172a!important}
#partner-care .pc-card,.pc-card{background:#ffffff!important;border:1px solid rgba(10,20,40,.12)!important;
  box-shadow:0 10px 28px rgba(23,33,55,.08)!important}
#partner-care .pc-card p,#partner-care .pc-card span,#partner-care .pc-card li,#partner-care .pc-card div{color:#334155!important}
#partner-care .pc-card strong,#partner-care .pc-card b{color:#0f172a!important}
#partner-care .pc-card a[href^="tel"]{color:#b07d00!important;-webkit-text-fill-color:#b07d00!important}
#partner-care .pc-pill{color:#334155!important;border-color:rgba(10,20,40,.2)!important}
#partner-care .pc-pill.is-active{color:#0f172a!important;background:rgba(249,178,0,.16)!important;border-color:var(--gold)!important}
#partner-care .pc-mini,#partner-care .pc-r-sub,#partner-care .pc-field span{color:#475569!important}
#partner-care .pc-input,#partner-care input{background:#fff!important;color:#0f172a!important;border-color:rgba(10,20,40,.2)!important}

/* Google-Bewertungs-Box: zwingend hell (höhere Spezifität) */
html body #bewertungen .rev-google-box{background:#fff!important;background-image:none!important;
  border:1px solid rgba(201,138,0,.5)!important;box-shadow:0 18px 44px rgba(23,33,55,.12)!important}
html body #bewertungen .rev-google-badge{background:#fff7e0!important;border:1px solid rgba(201,138,0,.35)!important}
html body #bewertungen .rev-google-badge,html body #bewertungen .rev-google-badge span{color:#b07d00!important}
html body #bewertungen .rev-google-title{color:#c98a00!important;-webkit-text-fill-color:#c98a00!important}
html body #bewertungen .rev-google-text,html body #bewertungen .rev-google-box p{color:#475569!important}
html body #bewertungen .rev-google-stars span{color:#e0a200!important}

/* ============================================================
   PREMIUM GLAS  –  Aurora-Hintergrund, Glas-Karten, Glow
   ============================================================ */
html,body{background:transparent!important}
.aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none;
  background:linear-gradient(180deg,#fbfcfe,#eef2f9)}
.aurora b{position:absolute;display:block;border-radius:50%;filter:blur(64px);opacity:.55;will-change:transform}
.aurora b:nth-child(1){width:48vw;height:48vw;left:-8vw;top:-12vw;
  background:radial-gradient(circle,rgba(249,178,0,.55),transparent 70%);animation:au1 19s ease-in-out infinite}
.aurora b:nth-child(2){width:42vw;height:42vw;right:-10vw;top:6vh;
  background:radial-gradient(circle,rgba(120,165,255,.42),transparent 70%);animation:au2 23s ease-in-out infinite}
.aurora b:nth-child(3){width:52vw;height:52vw;left:18vw;bottom:-22vw;
  background:radial-gradient(circle,rgba(249,178,0,.38),transparent 70%);animation:au3 27s ease-in-out infinite}
@keyframes au1{0%,100%{transform:translate(0,0)}50%{transform:translate(6vw,5vh)}}
@keyframes au2{0%,100%{transform:translate(0,0)}50%{transform:translate(-5vw,6vh)}}
@keyframes au3{0%,100%{transform:translate(0,0)}50%{transform:translate(-4vw,-5vh)}}
html.dark .aurora{background:linear-gradient(180deg,#0a0e18,#0e1320)}
html.dark .aurora b{opacity:.38}
@media(prefers-reduced-motion:reduce){.aurora b{animation:none}}

/* Marketing-Sektionen transparent -> Aurora scheint durch */
.hero,.sec,.sec.alt,#leistungen,#preise,#faq,#kontakt,#oeffnungszeiten,#bewertungen,#partner-care{background:transparent!important;background-color:transparent!important}
.hero::after{opacity:.55}

/* Glas-Karten */
.card,.pcard,.faq-card,.req,.bi,#oeffnungszeiten .neo,#bewertungen .rev-card,#bewertungen .rev-google-box,.pc-card{
  background:rgba(255,255,255,.58)!important;
  -webkit-backdrop-filter:blur(16px) saturate(1.35);backdrop-filter:blur(16px) saturate(1.35);
  border:1px solid rgba(255,255,255,.75)!important;
  box-shadow:0 16px 48px rgba(23,33,55,.12),inset 0 1px 0 rgba(255,255,255,.75)!important;
  border-radius:20px!important}
html.dark .card,html.dark .pcard,html.dark .faq-card,html.dark .req,html.dark .bi,
html.dark #oeffnungszeiten .neo,html.dark #bewertungen .rev-card,html.dark #bewertungen .rev-google-box,html.dark .pc-card{
  background:rgba(22,31,48,.52)!important;border:1px solid rgba(255,255,255,.12)!important;
  box-shadow:0 16px 48px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.08)!important}

/* Highlight-Karte + CTAs mit Glow */
.pcard.feature{border-color:rgba(249,178,0,.45)!important;
  box-shadow:0 22px 64px rgba(249,178,0,.28),inset 0 1px 0 rgba(255,255,255,.75)!important}
.btn-gold{box-shadow:0 10px 34px rgba(249,178,0,.48)!important}
.btn-gold:hover{box-shadow:0 14px 44px rgba(249,178,0,.62)!important}

/* Trust-Chips als Glas-Pills */
.trust .chip{background:rgba(255,255,255,.55)!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.75)!important;box-shadow:0 6px 20px rgba(23,33,55,.08)}
html.dark .trust .chip{background:rgba(22,31,48,.5)!important;border-color:rgba(255,255,255,.12)!important}

/* Header + Mobile-Bar glasig */
.site{background:rgba(255,255,255,.72)!important;-webkit-backdrop-filter:blur(18px) saturate(1.3);backdrop-filter:blur(18px) saturate(1.3);
  border-bottom:1px solid rgba(255,255,255,.6)}
html.dark .site{background:rgba(14,19,32,.72)!important;border-bottom-color:rgba(255,255,255,.08)}
.mbar{background:rgba(255,255,255,.82)!important;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}
html.dark .mbar{background:rgba(14,19,32,.82)!important}

/* Typo etwas größer/edler */
.sec-head h2{font-size:clamp(27px,5.2vw,42px);letter-spacing:-.02em;line-height:1.08}
.hero h1{letter-spacing:-.025em}

/* Glas-Karten Innentexte sicher lesbar */
.card,.pcard,.faq-card,.req,.bi{color:#1b2230}

/* ============================================================
   FIX v4 – Footer-Glas dunkel, Glas sichtbarer, mehr Akzente
   ============================================================ */
/* Header hell-Glas, Footer eigenes DUNKLES Glas (war fälschlich hell) */
header.site{background:rgba(255,255,255,.7)!important;-webkit-backdrop-filter:blur(18px) saturate(1.3);backdrop-filter:blur(18px) saturate(1.3);border-bottom:1px solid rgba(255,255,255,.6)}
html.dark header.site{background:rgba(14,19,32,.72)!important}
footer.site{background:rgba(12,17,28,.93)!important;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:2px solid rgba(249,178,0,.4)!important;border-bottom:none!important}
footer.site .fbrand b{color:#fff!important}
footer.site .fbrand p,footer.site .fbot{color:#aeb6c6!important}
footer.site .fcol h4{color:var(--gold)!important}
footer.site .fcol a,footer.site .ci{color:#e7ecf5!important}
footer.site .fcol a:hover{color:var(--gold)!important}
footer.site .ci svg{fill:var(--gold)!important}

/* Aurora kräftiger -> Glas wird sichtbar */
.aurora{background:linear-gradient(180deg,#f3f6fc,#e7edf6)!important}
.aurora b{filter:blur(54px)!important;opacity:.72!important}
.aurora b:nth-child(1){background:radial-gradient(circle,rgba(249,178,0,.8),transparent 66%)!important}
.aurora b:nth-child(2){background:radial-gradient(circle,rgba(90,150,255,.62),transparent 66%)!important}
.aurora b:nth-child(3){background:radial-gradient(circle,rgba(255,150,55,.6),transparent 66%)!important}

/* Glas-Karten: transparenter + klarer Glasrand */
.card,.pcard,.faq-card,.req,.bi,#oeffnungszeiten .neo,#bewertungen .rev-card,#bewertungen .rev-google-box,.pc-card{
  background:rgba(255,255,255,.40)!important;
  -webkit-backdrop-filter:blur(24px) saturate(1.6)!important;backdrop-filter:blur(24px) saturate(1.6)!important;
  border:1px solid rgba(255,255,255,.85)!important;
  box-shadow:0 20px 54px rgba(23,33,55,.18), inset 0 1px 0 rgba(255,255,255,.95)!important;
  border-radius:22px!important}
html.dark .card,html.dark .pcard,html.dark .faq-card,html.dark .req,html.dark .bi,
html.dark #oeffnungszeiten .neo,html.dark #bewertungen .rev-card,html.dark #bewertungen .rev-google-box,html.dark .pc-card{
  background:rgba(18,26,42,.44)!important;border:1px solid rgba(255,255,255,.16)!important;
  box-shadow:0 20px 54px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.10)!important}

/* Gold-Akzentlinie oben auf Marketing-Karten */
.card,.pcard,.faq-card,.req{position:relative;overflow:hidden}
.card::after,.pcard::after,.faq-card::after,.req::after{content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--gold),var(--gold-deep),var(--gold),transparent);box-shadow:0 0 14px rgba(249,178,0,.5)}
.pcard.feature{border-color:rgba(249,178,0,.6)!important;
  box-shadow:0 26px 70px rgba(249,178,0,.35), inset 0 1px 0 rgba(255,255,255,.95)!important}

/* Mehr Akzente: Kicker-Glow, Heading-Unterstrich, CTA-Glow */
.sec-head{text-align:center}
.sec-head .kick{color:var(--gold-deep)!important;text-shadow:0 0 20px rgba(249,178,0,.4);font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.sec-head h2{position:relative;display:inline-block}
.sec-head h2::after{content:"";display:block;width:66px;height:4px;margin:16px auto 0;border-radius:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-deep));box-shadow:0 0 18px rgba(249,178,0,.55)}
.btn-gold{box-shadow:0 12px 40px rgba(249,178,0,.55)!important}
.btn-gold:hover{box-shadow:0 16px 50px rgba(249,178,0,.7)!important}
.eyebrow{background:rgba(255,255,255,.6)!important;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
.trust .chip{background:rgba(255,255,255,.5)!important}

/* Glas-Karten Text sicher dunkel/lesbar */
.card,.card *,.pcard,.pcard *,.faq-card,.faq-card *,.req,.req *,.bi,.bi *{text-shadow:none}
.card,.pcard,.faq-card,.req,.bi{color:#141a26!important}
html.dark .card,html.dark .pcard,html.dark .faq-card,html.dark .req,html.dark .bi{color:#e7ecf5!important}

/* ============================================================
   FIX v5 – Header aufgeräumt: kein Doppel-Streifen, cooler Menü-Button
   ============================================================ */
/* Beide Streifen raus (Doppel-Linie) */
.checker{display:none!important}
.hero::before{display:none!important}

/* Menü-Button: cooler Taxi-Pill (schwarz + Gold-Icon), sauber proportioniert */
.burger{
  display:none!important; width:auto!important; height:46px!important; min-width:0!important;
  padding:0 18px!important; gap:9px!important; align-items:center!important; justify-content:center!important;
  border:none!important; border-radius:14px!important;
  background:linear-gradient(180deg,#222a38,#141a26)!important;
  color:#fff!important; font-weight:800!important; font-size:15px!important; line-height:1!important;
  cursor:pointer; box-shadow:0 8px 22px rgba(15,20,30,.4), inset 0 1px 0 rgba(255,255,255,.08)!important;
  transition:transform .12s, box-shadow .15s}
.burger svg{stroke:var(--gold)!important; width:19px!important; height:19px!important; margin:0!important}
.burger>span{display:inline!important; color:#fff!important; font-size:15px!important; font-weight:800!important; letter-spacing:.01em}
.burger:hover{box-shadow:0 12px 30px rgba(249,178,0,.4), inset 0 1px 0 rgba(255,255,255,.1)!important}
.burger:active{transform:translateY(1px)}
@media(max-width:940px){.burger{display:inline-flex!important}}
@media(max-width:520px){.burger{padding:0 14px!important;font-size:14px!important}.burger>span{font-size:14px!important}}


/* FIX v6: Header garantiert sticky, Menü beim Öffnen oben */
header.site{position:sticky!important;top:0!important;z-index:90!important}
.navsheet-links{scroll-behavior:auto}

/* ============================================================
   FIX v7 – Menü-Button: Text bleibt IM Button (kein Überlauf)
   ============================================================ */
.burger{flex:0 0 auto!important;min-width:max-content!important;white-space:nowrap!important;overflow:visible!important}
.burger>span{flex:0 0 auto!important;white-space:nowrap!important}
.nav .right{flex-wrap:nowrap;min-width:0}
/* Telefon-Button im Header etwas kompakter, damit alles passt */
@media(max-width:940px){
  .callbtn{padding:10px 14px!important}
}
/* Sehr schmale Handys: nur Icon, kein „Menü"-Text -> nie Überlauf */
@media(max-width:430px){
  .burger{padding:0 13px!important}
  .burger>span{display:none!important}
  .callbtn{padding:9px 12px!important}
}

/* ════════════════════════════════════════════════════════════
   FIX v8 – GLOW EDITION
   1) Darkmode-Schleier killen  2) Bewertungsliste hell
   3) Mobile-Bar lesbar  4) Wow: Reveal, Shimmer, Glow, Lift
   ════════════════════════════════════════════════════════════ */

/* ---- 1) DARK AURORA: echte dunkle Tiefe (überschreibt den erzwungen-hellen Bug aus v4) ---- */
html.dark .aurora{background:
  radial-gradient(1200px 700px at 50% -8%, #16203a 0%, transparent 60%),
  linear-gradient(180deg,#080c16 0%,#0b1120 55%,#090e1a 100%)!important}
html.dark .aurora b{filter:blur(64px)!important;opacity:.55!important;mix-blend-mode:screen}
html.dark .aurora b:nth-child(1){background:radial-gradient(circle,rgba(255,190,46,.55),transparent 64%)!important}
html.dark .aurora b:nth-child(2){background:radial-gradient(circle,rgba(72,132,255,.46),transparent 64%)!important}
html.dark .aurora b:nth-child(3){background:radial-gradient(circle,rgba(255,120,40,.42),transparent 64%)!important}

/* ---- DARK: Karten satt & klar statt matschig-transparent ---- */
html.dark .card,html.dark .pcard,html.dark .faq-card,html.dark .req,html.dark .bi,
html.dark #oeffnungszeiten .neo,html.dark #bewertungen .rev-card,html.dark #bewertungen .rev-google-box,html.dark .pc-card{
  background:linear-gradient(180deg,rgba(28,37,58,.94),rgba(18,25,42,.94))!important;
  -webkit-backdrop-filter:blur(10px) saturate(1.2)!important;backdrop-filter:blur(10px) saturate(1.2)!important;
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:0 24px 64px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.07)!important}
/* DARK: Hero-Texte hell halten */
html.dark .hero h1,html.dark .hero h1 *{color:#f3f6fc!important}
html.dark .hero p,html.dark .hero .lead{color:#c6cedd!important}
html.dark .hero strong,html.dark .hero b{color:#ffd45e!important}
/* DARK: Karteninhalte hell, Akzente bleiben gold */
html.dark :is(.card,.pcard,.faq-card,.req,.bi) :is(p,li,h3,h4){color:#dde4ef!important}
html.dark :is(.card,.pcard,.faq-card,.req,.bi) .muted{color:#9aa6b9!important}

/* ---- 2) BEWERTUNGS-LISTE: im Hellmodus auch hell ---- */
html.light #bewertungen .rev-list-panel{
  background:rgba(255,255,255,.66)!important;
  -webkit-backdrop-filter:blur(18px) saturate(1.4);backdrop-filter:blur(18px) saturate(1.4);
  border:1px solid rgba(255,255,255,.8)!important;
  box-shadow:0 18px 50px rgba(23,33,55,.16)!important}
html.light #bewertungen .rev-list-head{border-bottom-color:rgba(15,23,42,.10)!important}
html.light #bewertungen .rev-list-title{color:#0f172a!important}
html.light #bewertungen .rev-list-item{border-bottom-color:rgba(15,23,42,.08)!important}
html.light #bewertungen .rev-list-top{color:#334155!important}
html.light #bewertungen .rev-list-name{color:#0f172a!important}
html.light #bewertungen .rev-list-text{color:#1e293b!important}
html.light #bewertungen .rev-list-date,html.light #bewertungen .rev-list-meta{color:#64748b!important}
html.light #bewertungen .rev-list-stars{color:var(--gold-deep)!important}

/* ---- 3) MOBILE-BAR: „Festpreis" in beiden Modi lesbar ---- */
.mbar .p{background:#fff!important;color:#0f172a!important;border:1px solid rgba(15,23,42,.12)!important}
.mbar .p svg{fill:var(--gold-deep)!important}
html.dark .mbar .p{background:rgba(36,46,68,.95)!important;color:#eef2f8!important;border:1px solid rgba(255,255,255,.14)!important}
html.dark .mbar .p svg{fill:var(--gold-2)!important}
.mbar .c{color:#0f172a!important}.mbar .c svg{fill:#0f172a!important}

/* ════════════════ WOW-SCHICHT ════════════════ */

/* (A) Scroll-Reveal: nur aktiv wenn JS die Klasse setzt -> ohne JS bleibt alles sichtbar */
html.reveal-on .reveal{opacity:0;transform:translateY(28px) scale(.985);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}
html.reveal-on .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.reveal-on .reveal{opacity:1!important;transform:none!important}}

/* (B) Gold-Akzentlinie schimmert (Lauflicht über die Top-Linie) */
.card::after,.pcard::after,.faq-card::after,.req::after{
  background:linear-gradient(90deg,transparent,var(--gold),#fff7df,var(--gold-deep),transparent)!important;
  background-size:220% 100%!important;animation:shimmerLine 4.5s linear infinite}
@keyframes shimmerLine{0%{background-position:220% 0}100%{background-position:-120% 0}}
@media(prefers-reduced-motion:reduce){.card::after,.pcard::after,.faq-card::after,.req::after{animation:none}}

/* (C) CTA atmet (sanfter Goldpuls) */
.btn-gold{animation:ctaPulse 3.2s ease-in-out infinite}
@keyframes ctaPulse{0%,100%{box-shadow:0 12px 40px rgba(249,178,0,.45)}
  50%{box-shadow:0 16px 54px rgba(249,178,0,.72)}}
@media(prefers-reduced-motion:reduce){.btn-gold{animation:none}}

/* (D) Karten heben sich beim Hover (Desktop) */
@media(hover:hover){
  .card,.pcard,.faq-card,.bi{transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s}
  .card:hover,.pcard:hover,.faq-card:hover,.bi:hover{transform:translateY(-7px);
    border-color:rgba(249,178,0,.5)!important;
    box-shadow:0 30px 72px rgba(23,33,55,.22),0 0 0 1px rgba(249,178,0,.25)!important}
  html.dark .card:hover,html.dark .pcard:hover,html.dark .faq-card:hover,html.dark .bi:hover{
    box-shadow:0 30px 72px rgba(0,0,0,.6),0 0 0 1px rgba(255,192,46,.3)!important}
}

/* (E) Hero-Headline mit lebendigem Gold-Schimmer im Wort-Akzent */
.hero h1 .hl,.hero h1 em{background:linear-gradient(100deg,var(--gold-deep),#ffd45e,var(--gold-deep));
  background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  color:transparent;font-style:normal;animation:goldFlow 6s linear infinite}
@keyframes goldFlow{to{background-position:200% center}}

/* (F) Aurora driftet lebendiger (langsame Skalierung zusätzlich) */
.aurora b{animation-duration:22s,18s!important}

/* ════════════════════════════════════════════════════════════
   FIX v9 – Menü-Clip, Partner-Care Dark, Rechts-Dock
   ════════════════════════════════════════════════════════════ */

/* ---- A) Menü-Button: nie mehr am Bildschirmrand abgeschnitten ---- */
.wrap.nav{padding-right:max(16px,env(safe-area-inset-right))!important;
  padding-left:max(16px,env(safe-area-inset-left))!important}
.burger{width:max-content!important;min-width:max-content!important;max-width:none!important;
  flex:0 0 auto!important;overflow:visible!important}
.burger>span{display:inline!important;white-space:nowrap!important;flex:0 0 auto!important}
@media(max-width:430px){.burger>span{display:none!important}}

/* ---- B) PARTNER-CARE folgt im Darkmode dem globalen Theme ---- */
html.dark #partner-care.pc-theme.pc-light{
  --pc-bg:transparent;--pc-surface:rgba(255,255,255,.06);--pc-surface2:rgba(255,255,255,.08);
  --pc-border:rgba(255,255,255,.12);--pc-text:#eef2f8;--pc-muted:#aab4c5;
  --pc-shadow:0 12px 36px rgba(0,0,0,.4)}
html.dark #partner-care.pc-theme .pc-card{
  background:linear-gradient(180deg,rgba(28,37,58,.94),rgba(18,25,42,.94))!important;
  border:1px solid rgba(255,255,255,.12)!important;color:#eef2f8!important}
html.dark #partner-care .pc-name,html.dark #partner-care .pc-title,html.dark #partner-care .pc-r-title{color:#fff!important}
html.dark #partner-care .pc-sub,html.dark #partner-care .pc-pill,html.dark #partner-care .pc-r-sub{color:#c8d0de!important}
html.dark #partner-care .pc-pill.is-active{color:#fff!important}
html.dark #partner-care .pc-meta,html.dark #partner-care .pc-meta .muted,html.dark #partner-care .muted{color:#a7b1c2!important}
html.dark #partner-care .pc-input,html.dark #partner-care input[type=number]{
  background:rgba(255,255,255,.07)!important;color:#eef2f8!important;border-color:rgba(255,255,255,.14)!important}
html.dark #partner-care .pc-seg label{background:rgba(255,255,255,.07)!important;color:#c8d0de!important}
html.dark #partner-care .pc-badge{color:#c8d0de!important}

/* ---- C) RECHTS-DOCK (Schnellaktionen zum Aufklappen) ---- */
.fabdock{position:fixed;right:14px;bottom:calc(86px + env(safe-area-inset-bottom));z-index:85;
  display:flex;flex-direction:column;align-items:flex-end;gap:11px;pointer-events:none}
@media(min-width:941px){.fabdock{bottom:calc(26px + env(safe-area-inset-bottom))}}
.fab-act{pointer-events:auto;display:inline-flex;align-items:center;gap:11px;text-decoration:none;cursor:pointer;
  background:rgba(255,255,255,.92);color:#0f172a;border:1px solid rgba(15,23,42,.10);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-radius:999px;padding:7px 7px 7px 17px;font-weight:800;font-size:14px;font-family:inherit;
  box-shadow:0 12px 30px rgba(23,33,55,.22);
  transform:translateX(24px) scale(.85);opacity:0;visibility:hidden;
  transition:transform .3s cubic-bezier(.2,.7,.2,1),opacity .3s,visibility .3s}
.fab-act .fi{width:40px;height:40px;border-radius:999px;display:grid;place-items:center;flex:0 0 auto;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));box-shadow:0 4px 12px rgba(249,178,0,.4)}
.fab-act .fi svg{width:20px;height:20px;fill:#1a1206}
html.dark .fab-act{background:rgba(30,40,60,.94);color:#eef2f8;border-color:rgba(255,255,255,.13)}
.fabdock.open .fab-act{transform:none;opacity:1;visibility:visible}
.fabdock.open .fab-act:nth-last-child(2){transition-delay:.04s}
.fabdock.open .fab-act:nth-last-child(3){transition-delay:.08s}
.fabdock.open .fab-act:nth-last-child(4){transition-delay:.12s}
.fabdock.open .fab-act:nth-last-child(5){transition-delay:.16s}
.fab-trigger{pointer-events:auto;width:62px;height:62px;border-radius:999px;border:none;cursor:pointer;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  box-shadow:0 16px 38px rgba(249,178,0,.6),inset 0 1px 0 rgba(255,255,255,.4);
  display:grid;place-items:center;transition:transform .25s;animation:ctaPulse 3.2s ease-in-out infinite}
.fab-trigger:active{transform:scale(.94)}
.fab-trigger svg{width:27px;height:27px;fill:#1a1206;transition:transform .3s}
.fabdock.open .fab-trigger svg{transform:rotate(135deg)}
.fab-trigger .lbl{position:absolute;right:74px;white-space:nowrap;background:rgba(20,26,38,.92);color:#fff;
  font-size:12.5px;font-weight:700;padding:5px 11px;border-radius:999px;opacity:0;transform:translateX(8px);
  transition:.25s;pointer-events:none}
.fabdock:not(.open) .fab-trigger:hover .lbl{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.fab-trigger{animation:none}.fab-act{transition:opacity .2s}}

/* ════════════════════════════════════════════════════════════
   FIX v10 – Menü icon-only, Klinik-Text Dark, Liste hell robust
   ════════════════════════════════════════════════════════════ */

/* ---- Menü: nur noch Icon (Text kann nie mehr überlaufen) ---- */
.burger>span{display:none!important}
.burger{width:48px!important;min-width:48px!important;max-width:48px!important;
  height:48px!important;padding:0!important;justify-content:center!important;gap:0!important}
.burger svg{width:22px!important;height:22px!important;stroke:var(--gold)!important;fill:var(--gold)!important}

/* ---- Klinik-Karten im Darkmode: Text garantiert hell ---- */
html.dark #partner-care .pc-card h3,
html.dark #partner-care .pc-name{color:#ffffff!important}
html.dark #partner-care .pc-card div,
html.dark #partner-care .pc-meta,
html.dark #partner-care .pc-meta div,
html.dark #partner-care .pc-meta .muted,
html.dark #partner-care .pc-card .muted{color:#cdd5e2!important}
/* gold Telefonlink bleibt gold (inline-style), Buttons unverändert */

/* ---- Bewertungsliste: hell auch ohne html.light-Klasse abgesichert ---- */
html:not(.dark) #bewertungen .rev-list-panel{
  background:rgba(255,255,255,.66)!important;
  -webkit-backdrop-filter:blur(18px) saturate(1.4);backdrop-filter:blur(18px) saturate(1.4);
  border:1px solid rgba(255,255,255,.8)!important;
  box-shadow:0 18px 50px rgba(23,33,55,.16)!important}
html:not(.dark) #bewertungen .rev-list-head{border-bottom-color:rgba(15,23,42,.10)!important}
html:not(.dark) #bewertungen .rev-list-title{color:#0f172a!important}
html:not(.dark) #bewertungen .rev-list-item{border-bottom-color:rgba(15,23,42,.08)!important}
html:not(.dark) #bewertungen .rev-list-top{color:#334155!important}
html:not(.dark) #bewertungen .rev-list-name{color:#0f172a!important}
html:not(.dark) #bewertungen .rev-list-text{color:#1e293b!important}
html:not(.dark) #bewertungen .rev-list-date,
html:not(.dark) #bewertungen .rev-list-meta{color:#64748b!important}
html:not(.dark) #bewertungen .rev-list-stars{color:var(--gold-deep)!important}

/* ════════════════════════════════════════════════════════════
   SIGNATURE v11 – Film-Grain · Hero-Lichtkegel (folgt Finger) · Magnet-Glanz
   Award-Gallery-Techniken 2026, performance- & mobil-first
   ════════════════════════════════════════════════════════════ */

/* Feiner Film-Grain über der ganzen Seite (edel, „analog") */
.grain{position:fixed;inset:0;z-index:3;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter%20id='n'%3E%3CfeTurbulence%20type='fractalNoise'%20baseFrequency='0.9'%20numOctaves='2'%20stitchTiles='stitch'/%3E%3C/filter%3E%3Crect%20width='100%25'%20height='100%25'%20filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:170px 170px}
html.dark .grain{opacity:.06;mix-blend-mode:soft-light}
@media(prefers-reduced-motion:reduce){.grain{display:none}}

/* Hero-Lichtkegel: warmer Schein, der dem Finger/Cursor folgt */
.hero{position:relative;overflow:hidden}
.hero .wrap{position:relative;z-index:1}
.hero-spot{position:absolute;inset:-12% -6%;z-index:0;pointer-events:none;mix-blend-mode:screen;
  background:radial-gradient(440px circle at var(--mx,50%) var(--my,26%),
    rgba(249,178,0,.30),rgba(249,178,0,.10) 38%,transparent 64%)}
html.dark .hero-spot{background:radial-gradient(480px circle at var(--mx,50%) var(--my,26%),
    rgba(255,198,64,.36),rgba(255,150,40,.12) 40%,transparent 66%)}
@media(prefers-reduced-motion:reduce){.hero-spot{--mx:50%;--my:24%}}

/* Magnet-Glanz: Lichtstrahl wandert über den Haupt-Button */
.btn-gold{position:relative;overflow:hidden}
.btn-gold::before{content:"";position:absolute;top:0;left:-140%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-18deg);pointer-events:none;animation:shineSweep 4.6s ease-in-out infinite}
@keyframes shineSweep{0%,74%{left:-140%}90%,100%{left:140%}}
@media(prefers-reduced-motion:reduce){.btn-gold::before{display:none}}
