/* =========================================================
   House of Liberty – Fahrzeugaufbereitung Heitersheim
   Design: "Obsidian Gloss" — Deep Charcoal + Clover Green
   ========================================================= */
:root{
  --ink:#0E0F11; --ink-2:#141619; --ink-3:#1B1E23; --ink-card:#1D2025;
  --paper:#ffffff; --paper-2:#F4F5F6; --paper-3:#E9EBED;
  --text:#111318; --text-2:#3B424C; --muted:#6C737C;
  --line:#E6E8EB; --line-dark:rgba(255,255,255,.10);
  /* Monochromes Akzent-System (kontextabhängig). Default = dunkler Kontext (weißer Akzent). */
  --brand:#ffffff; --brand-bright:#cbced3; --brand-deep:#ffffff; --brand-ink:#111318; --accent-rgb:255,255,255;
  --r-sm:10px; --r:14px; --r-lg:22px;
  --shadow:0 18px 44px rgba(14,16,19,.10);
  --shadow-lg:0 30px 70px rgba(14,16,19,.16);
  --shadow-dark:0 28px 70px rgba(0,0,0,.55);
  --maxw:1200px;
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
/* Helle Flächen kippen den Akzent auf Fast-Schwarz */
.section-light,.modal-card,.cookie-card{--brand:#111318;--brand-bright:#3a4149;--brand-deep:#111318;--brand-ink:#ffffff;--accent-rgb:17,19,24}
/* Dunkle Cards innerhalb heller Sektionen behalten den weißen Akzent */
.quiz-dark{--brand:#ffffff;--brand-bright:#cbced3;--brand-deep:#ffffff;--brand-ink:#111318;--accent-rgb:255,255,255}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.12;letter-spacing:-.02em;font-weight:800}
section[id]{scroll-margin-top:104px}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.container-narrow{max-width:820px}
.container-wide{max-width:1320px}
.center{text-align:center;margin-top:40px}
.desktop-only{display:flex}
.mobile-only{display:none}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--brand-deep),var(--brand-bright));z-index:1200;transition:width .1s linear;box-shadow:0 0 12px rgba(var(--accent-rgb),.6)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:999px;font-weight:700;font-size:.93rem;border:1.5px solid transparent;cursor:pointer;transition:transform .18s ease,box-shadow .2s ease,background .2s ease;white-space:nowrap;font-family:inherit}
.btn i{font-size:1.15em}
.btn-primary{background:var(--brand);color:var(--brand-ink);box-shadow:0 10px 26px rgba(var(--accent-rgb),.34)}
.btn-primary:hover{background:var(--brand-bright);transform:translateY(-2px);box-shadow:0 16px 34px rgba(var(--accent-rgb),.46)}
.btn-whatsapp{background:#25D366;color:#062b14;box-shadow:0 10px 26px rgba(37,211,102,.32)}
.btn-whatsapp:hover{background:#2ee774;transform:translateY(-2px)}
.btn-outline-light{background:rgba(255,255,255,.04);color:#fff;border-color:rgba(255,255,255,.28)}
.btn-outline-light:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.btn-lg{padding:14px 26px;font-size:.98rem}
.btn-block{width:100%}

/* ---------- Brand logo ---------- */
.brand{display:inline-flex;align-items:center;line-height:1}
.brand-img{height:68px;width:auto;display:block;transition:height .25s}
.site-header.is-scrolled .brand-img{height:56px}
.brand-footer .brand-img{height:88px}
.brand-cookie .brand-img{height:64px}
.brand-quiz .brand-img{height:58px}
.legal-header .brand-img{height:50px}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:background .3s,box-shadow .3s,padding .3s;background:linear-gradient(to bottom,rgba(10,12,15,.55),rgba(10,12,15,0))}
.site-header.is-scrolled{background:rgba(12,14,17,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 8px 30px rgba(0,0,0,.4);padding:11px 0;border-bottom:1px solid var(--line-dark)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.main-nav{gap:28px}
.main-nav a{color:rgba(255,255,255,.82);font-weight:600;font-size:.95rem;transition:color .2s;position:relative}
.main-nav a:hover{color:#fff}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--brand);transition:width .25s;border-radius:2px}
.main-nav a:hover::after{width:100%}
.header-actions{align-items:center;gap:16px}
.phone-link{color:#fff;font-weight:700;font-size:.95rem;display:inline-flex;align-items:center;gap:7px}
.phone-link i{color:var(--brand-bright)}
.icon-btn{width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff}
.icon-btn-phone{background:var(--brand);color:var(--brand-ink)}
.icon-btn-wa{background:#25D366;color:#062b14}


/* ---------- Hero ---------- */
.hero{position:relative;background:radial-gradient(120% 90% at 78% 8%,#1a2027 0%,#0E1013 46%,#07090c 100%);color:#fff;padding:150px 0 46px;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
/* Hero-Foto-Slot: hero-bg.webp einfach durch echtes Foto ersetzen (gleicher Dateiname) */
.hero-bg::before{content:"";position:absolute;inset:0;background:url('../images/hero-bg.webp') center/cover no-repeat}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(102deg,rgba(9,10,13,.96) 22%,rgba(9,10,13,.72) 58%,rgba(9,10,13,.9) 100%)}
.hero-glow,.hero-bead{z-index:1}
.hero-glow{position:absolute;top:-14%;right:-6%;width:640px;height:640px;background:radial-gradient(circle,rgba(var(--accent-rgb),.28),rgba(var(--accent-rgb),0) 62%);filter:blur(12px)}
.hero-bead{position:absolute;border-radius:50%;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.9),rgba(214,218,222,.25) 34%,rgba(10,12,15,.5) 100%);box-shadow:inset 0 0 8px rgba(0,0,0,.4)}
.hero-bead.b1{width:26px;height:26px;top:24%;left:8%}
.hero-bead.b2{width:15px;height:15px;top:66%;left:16%}
.hero-bead.b3{width:20px;height:20px;top:80%;left:40%}
.hero-bead.b4{width:12px;height:12px;top:38%;left:47%}
.hero-bead.b5{width:22px;height:22px;top:16%;left:38%}
.hero-grid{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:52px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-family:inherit;transition:background .2s,transform .18s;background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.34);color:var(--brand-bright);padding:8px 15px;border-radius:999px;font-size:.82rem;font-weight:600;margin-bottom:22px;max-width:100%;line-height:1.3}
.hero h1{font-size:clamp(2.3rem,5vw,3.5rem);font-weight:900;letter-spacing:-.03em}
.hero h1 .hl{color:var(--brand);position:relative}
.hero-sub{font-size:1.01rem;color:rgba(255,255,255,.76);margin:18px 0 24px;max-width:540px}
.hero-usps{list-style:none;display:grid;gap:12px;margin-bottom:28px}
.hero-usps li{display:flex;align-items:center;gap:11px;font-weight:600;color:rgba(255,255,255,.92);font-size:1rem}
.hero-usps li i{color:var(--brand);font-size:1.3rem;flex-shrink:0}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* Hero form card */
.hero-form-card{background:rgba(20,23,28,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-dark);position:relative}
.hero-form-card::before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);background:linear-gradient(135deg,rgba(255,255,255,.14),transparent 40%);pointer-events:none}
.hs-step{display:block;text-align:center;color:#fff;font-weight:800;font-size:1.02rem;margin-bottom:14px;letter-spacing:-.01em}
.hs-foot{text-align:center;color:rgba(255,255,255,.6);font-size:.82rem;margin-top:14px;display:flex;align-items:center;justify-content:center;gap:6px}
.hs-foot i{color:var(--brand)}
.hs-rating{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}
.hs-g{width:19px;height:19px}
.hs-score{font-weight:800;color:#fff}
.hs-stars{color:#FFB800;letter-spacing:1px}
.hs-glabel{color:rgba(255,255,255,.55);font-size:.82rem}

/* ---------- Quiz ---------- */
.quiz-progress-head{display:flex;justify-content:space-between;font-size:.78rem;font-weight:700;margin-bottom:7px;color:rgba(255,255,255,.6)}
.quiz-bar{height:6px;background:rgba(255,255,255,.12);border-radius:999px;overflow:hidden;margin-bottom:18px}
.js-bar{height:100%;width:20%;background:linear-gradient(90deg,var(--brand-deep),var(--brand-bright));border-radius:999px;transition:width .35s ease}
.q-title{font-size:1.16rem;font-weight:800;margin-bottom:14px;color:#fff;letter-spacing:-.01em}
.q-note{font-size:.86rem;color:rgba(255,255,255,.6);margin-bottom:14px}
.q-grid{display:grid;gap:10px}
.q-grid-2{grid-template-columns:1fr 1fr}
.q-opt{display:flex;align-items:center;gap:10px;padding:14px 15px;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.12);border-radius:var(--r);cursor:pointer;font-weight:600;color:#fff;font-size:.94rem;transition:all .18s}
.q-opt i{color:var(--brand-bright);font-size:1.25rem}
.q-opt:hover{border-color:var(--brand);background:rgba(var(--accent-rgb),.14);transform:translateY(-1px)}
.q-field{width:100%;padding:14px 15px;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--r);color:#fff;font-size:.96rem;font-family:inherit}
.q-field::placeholder{color:rgba(255,255,255,.45)}
.q-field:focus{outline:none;border-color:var(--brand)}
.q-back{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.6);font-weight:600;font-size:.88rem;cursor:pointer;margin-top:14px}
.q-back:hover{color:#fff}
.quiz-done{text-align:center;padding:20px 6px}
.quiz-done>i{font-size:3.4rem;color:var(--brand);margin-bottom:8px}
.quiz-done strong{display:block;font-size:1.3rem;color:#fff;margin-bottom:6px}
.quiz-done p{color:rgba(255,255,255,.72);font-size:.95rem}
.quiz-done-urgent{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12)}
.quiz-done-urgent-label{display:block;font-size:.84rem;color:rgba(255,255,255,.6);margin-bottom:10px}
.quiz-done-urgent-btns{display:flex;gap:12px;justify-content:center}
.quiz-urgent-btn{width:52px;height:52px;border-radius:50%;background:var(--brand);color:var(--brand-ink);display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem}
.quiz-urgent-wa{background:#25D366;color:#062b14}
.form-consent{display:flex;gap:9px;align-items:flex-start;font-size:.82rem;color:rgba(255,255,255,.66);cursor:pointer;line-height:1.4}
.form-consent input{margin-top:3px;accent-color:var(--brand);width:16px;height:16px;flex-shrink:0}
.form-consent a{color:var(--brand-bright);text-decoration:underline}

/* Quiz in light contexts (contact section keeps dark card) */
.quiz-dark{background:linear-gradient(160deg,#1b1f26,#101317);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-dark)}
.quiz-logo-wrap{display:flex;justify-content:center;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}

/* ---------- Trust strip ---------- */
.trust-strip{position:relative;display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;margin-top:44px;padding:20px 26px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);backdrop-filter:blur(8px)}
.ts-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.82);font-size:.92rem}
.ts-item i{color:var(--brand-bright);font-size:1.5rem}
.ts-item strong{color:#fff;font-weight:800}

/* ---------- Section base ---------- */
.section{padding:88px 0}
.section-tight{padding:26px 0}
.section-light{background:var(--paper)}
.section-light+.section-light{padding-top:0}
.section-dark{background:radial-gradient(120% 100% at 80% 0%,#171b21,#0E1013 60%);color:#fff}
.section-darker{background:linear-gradient(180deg,#0b0d10,#111418);color:#fff}
.eyebrow{display:inline-block;color:var(--brand-deep);font-weight:800;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px}
.eyebrow-light{color:var(--brand-bright)}
.section-title{font-size:clamp(1.85rem,3.6vw,2.7rem);font-weight:900;letter-spacing:-.025em;max-width:820px}
.section-title-light{color:#fff}
.section-sub{font-size:1.08rem;color:var(--muted);margin-top:14px;max-width:640px}
/* Vollbreite Section-Köpfe zentriert (Split-Layouts bleiben linksbündig) */
.container>.eyebrow{display:block;text-align:center}
.container>.section-title,.container>.section-sub{text-align:center;margin-left:auto;margin-right:auto}
.section-sub-light{color:rgba(255,255,255,.7)}

/* ---------- Cards / grids ---------- */
.card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow)}
/* Fix: dunkles Quiz behält dunklen Look, auch mit .card-Klasse (sonst weiß-auf-weiß) */
.card.quiz-dark{background:linear-gradient(160deg,#1b1f26,#101317);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-dark)}
.grid{display:grid;gap:24px}
.grid-cards{grid-template-columns:repeat(3,1fr);margin-top:44px}
.checks{list-style:none;display:grid;gap:9px}
.checks li{position:relative;padding-left:27px;font-size:.93rem;color:var(--text-2)}
.checks li::before{content:"\ea5e";font-family:"tabler-icons";position:absolute;left:0;top:1px;color:var(--brand-deep);font-size:1.05rem}

/* ---------- Leistungen (svc cards) ---------- */
.svc{overflow:hidden;position:relative;transition:transform .22s ease,box-shadow .22s ease;display:flex;flex-direction:column}
.svc:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
/* Foto-Slots: leistung-*.webp durch echte Fotos ersetzen (gleiche Dateinamen) */
.svc-top{position:relative;height:160px;overflow:hidden;background:var(--svc-img,none) center/cover no-repeat,linear-gradient(150deg,#20262e,#0E1013)}
.svc-innen{--svc-img:url('../images/leistung-innen.webp')}
.svc-aussen{--svc-img:url('../images/leistung-aussen.webp')}
.svc-politur{--svc-img:url('../images/leistung-politur.webp')}
.svc-wachs{--svc-img:url('../images/leistung-wachs.webp')}
.svc-keramik{--svc-img:url('../images/leistung-keramik.webp')}
.svc-smart{--svc-img:url('../images/leistung-smart.webp')}
.svc-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.svc-body h3{font-size:1.28rem;margin-bottom:9px}
.svc-body p{color:var(--muted);font-size:.95rem;margin-bottom:16px}
.svc-body .checks{margin-top:auto}
.svc-featured{border:2px solid var(--brand);box-shadow:0 24px 54px rgba(var(--accent-rgb),.22)}
.svc-badge{position:absolute;top:14px;right:14px;z-index:5;background:var(--brand);color:var(--brand-ink);font-size:.72rem;font-weight:800;padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:5px;box-shadow:0 6px 16px rgba(var(--accent-rgb),.4)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,#1c2127,#0E0F11 70%);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-lg);padding:40px 46px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;box-shadow:var(--shadow-lg)}
.cta-band::before{content:"";position:absolute;top:-40%;left:-6%;width:340px;height:340px;background:radial-gradient(circle,rgba(var(--accent-rgb),.32),transparent 64%);pointer-events:none}
.cta-band-text{position:relative;flex:1;min-width:280px;color:#fff}
.cta-band-text h2{font-size:clamp(1.5rem,2.6vw,2rem);color:#fff}
.cta-band-text p{color:rgba(255,255,255,.76);margin-top:10px;max-width:560px}
.cta-band-actions{position:relative;display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Warum / signature ---------- */
.why-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:52px;align-items:center}
.why-copy h2{font-size:clamp(1.8rem,3.3vw,2.5rem);color:#fff}
.why-lead{color:rgba(255,255,255,.74);font-size:1.08rem;margin:16px 0 28px}
.why-points{display:grid;gap:20px;margin-bottom:30px}
.why-point{display:flex;gap:16px}
.wp-ico{flex-shrink:0;width:50px;height:50px;border-radius:14px;background:rgba(var(--accent-rgb),.14);border:1px solid rgba(var(--accent-rgb),.3);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--brand-bright)}
.why-point h4{color:#fff;font-size:1.1rem;margin-bottom:4px}
.why-point p{color:rgba(255,255,255,.66);font-size:.94rem}
.why-visual{position:relative;display:flex;justify-content:center}
.why-card-glow{position:absolute;inset:-10% 6%;background:radial-gradient(circle at 60% 40%,rgba(var(--accent-rgb),.34),transparent 66%);filter:blur(20px)}
.why-stat-card{position:relative;background:linear-gradient(160deg,#1c222a,#0d1013);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:34px 30px;box-shadow:var(--shadow-dark);overflow:hidden;max-width:380px}
.wsc-shine{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent)}
.wsc-num{font-size:3.4rem;font-weight:900;color:var(--brand);letter-spacing:-.03em;line-height:1}
.wsc-label{color:rgba(255,255,255,.72);font-weight:600;margin-top:6px}
.wsc-divider{height:1px;background:rgba(255,255,255,.12);margin:22px 0}
.wsc-row{display:flex;align-items:center;gap:4px;color:#FFB800;font-size:1.05rem}
.wsc-row span{color:rgba(255,255,255,.8);font-weight:700;margin-left:8px;font-size:.9rem}
.wsc-quote{color:#fff;font-size:1.05rem;font-weight:500;font-style:italic;margin-top:18px;line-height:1.5}
.wsc-author{color:rgba(255,255,255,.55);font-size:.86rem;margin-top:10px}

/* ---------- Ergebnisse: Galerie-Marquee ---------- */
.section-gallery{background:#0C0E11;color:#fff}
.gallery-wrap{position:relative;margin-top:44px;overflow:hidden}
.gallery-wrap::before,.gallery-wrap::after{content:"";position:absolute;top:0;bottom:0;width:clamp(70px,12vw,200px);z-index:2;pointer-events:none}
.gallery-wrap::before{left:0;background:linear-gradient(90deg,#0C0E11 8%,rgba(12,14,17,0))}
.gallery-wrap::after{right:0;background:linear-gradient(270deg,#0C0E11 8%,rgba(12,14,17,0))}
.gallery-track{display:flex;gap:20px;width:max-content;animation:gallery-move 80s linear infinite;will-change:transform;align-items:center}
.gallery-wrap:hover .gallery-track{animation-play-state:paused}
.gallery-track img{width:auto;height:320px;border-radius:var(--r-lg);border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 44px rgba(0,0,0,.45);flex-shrink:0}
@keyframes gallery-move{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.section-gallery .center{margin-top:44px}

/* ---------- Steps ---------- */
.steps-grid{display:flex;align-items:stretch;gap:12px;margin-top:44px}
.step-card{flex:1;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 26px;text-align:center;position:relative;box-shadow:var(--shadow)}
.step-num{position:absolute;top:-16px;left:50%;transform:translateX(-50%);width:34px;height:34px;border-radius:50%;background:var(--brand);color:var(--brand-ink);font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(var(--accent-rgb),.4)}
.step-icon{height:64px;display:flex;align-items:center;justify-content:center;margin:10px 0 14px}
.step-title{font-size:1.2rem;margin-bottom:8px}
.step-text{color:var(--muted);font-size:.94rem}
.step-connector{display:flex;align-items:center;color:var(--brand);font-size:1.6rem}
.steps-cta{text-align:center;margin-top:40px}
.steps-cta-sub{margin-top:14px;color:var(--muted);font-size:.9rem;display:flex;justify-content:center;align-items:center;gap:8px}
.pulse-dot{width:9px;height:9px;border-radius:50%;background:#2fbf63;box-shadow:0 0 0 0 rgba(47,191,99,.55);animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,191,99,.5)}70%{box-shadow:0 0 0 11px rgba(47,191,99,0)}100%{box-shadow:0 0 0 0 rgba(47,191,99,0)}}

/* ---------- Pakete ---------- */
.price-grid{grid-template-columns:repeat(3,1fr);margin-top:44px}
.price-card{position:relative;background:linear-gradient(165deg,#1c212a,#111419);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:32px 28px;display:flex;flex-direction:column;box-shadow:var(--shadow-dark)}
.price-card-featured{border:2px solid var(--brand);box-shadow:0 30px 64px rgba(var(--accent-rgb),.24);transform:translateY(-6px)}
.price-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--brand);color:var(--brand-ink);font-size:.74rem;font-weight:800;padding:6px 16px;border-radius:999px;white-space:nowrap}
.price-name{color:#fff;font-size:1.4rem}
.price-desc{color:rgba(255,255,255,.62);font-size:.92rem;margin:6px 0 16px}
.price-val{color:#fff;font-size:2.4rem;font-weight:900;letter-spacing:-.03em;margin-bottom:18px}
.price-from{font-size:.9rem;font-weight:600;color:var(--brand-bright);vertical-align:middle;margin-right:4px}
.price-card .checks{margin-bottom:24px}
.price-card .checks li{color:rgba(255,255,255,.82)}
.price-card .checks li::before{color:var(--brand-bright)}
.price-card .btn{margin-top:auto}
.price-disclaimer{text-align:center;color:rgba(255,255,255,.55);font-size:.86rem;margin-top:26px;display:flex;align-items:center;justify-content:center;gap:7px}
.price-disclaimer i{color:var(--brand-bright)}

/* ---------- Reviews marquee ---------- */
.reviews .marquee-wrap{margin-top:40px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee{display:flex;gap:22px;width:max-content;animation:marquee 46s linear infinite}
.reviews .marquee-wrap:hover .marquee{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.review-card{width:360px;padding:24px;flex-shrink:0}
.review-g{width:26px;height:26px;margin-bottom:12px}
.review-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.avatar{width:44px;height:44px;border-radius:50%;background:#2b2f36;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem}
.avatar-green{background:#565d66}
.avatar-deep{background:#20242a}
.review-head strong{display:block;font-size:.98rem}
.review-head .stars{color:#FFB800;font-size:.9rem}
.review-card p{color:var(--text-2);font-size:.94rem;margin-bottom:14px}
.review-verified{display:flex;align-items:center;gap:6px;color:var(--brand-deep);font-size:.8rem;font-weight:600}

/* ---------- Einzugsgebiet (Foto-Split, keine Karte) ---------- */
.section-region{position:relative;background:radial-gradient(130% 100% at 15% 10%,#161b21,#0E1013 62%);color:#fff;padding:88px 0;overflow:hidden}
.region-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:stretch}
.region-media{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow-dark);min-height:420px}
.region-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.region-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,12,15,0) 46%,rgba(10,12,15,.72) 100%)}
.region-media-badge{position:absolute;left:20px;bottom:20px;z-index:2;background:#fff;color:#111318;border:none;border-radius:var(--r);padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 14px 34px rgba(0,0,0,.4);cursor:pointer;font-family:inherit;text-align:left;transition:transform .18s ease,box-shadow .2s ease}
.region-media-badge:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(0,0,0,.5)}
.region-media-badge strong{font-size:1.9rem;font-weight:900;letter-spacing:-.03em;line-height:1}
.region-media-badge span{font-size:.8rem;font-weight:600;color:#3B424C;line-height:1.35}
.region-media-badge span i{font-size:.85rem;vertical-align:-1px}
.region-content h2{font-size:clamp(1.7rem,3vw,2.3rem);color:#fff;margin-bottom:14px}
.region-lead{color:rgba(255,255,255,.74);margin-bottom:22px;max-width:520px}
.region-stats{display:grid;gap:11px;margin-bottom:24px}
.region-stat{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.11);border-radius:var(--r);padding:12px 15px;font-size:.93rem;color:rgba(255,255,255,.82)}
.region-stat i{color:#fff;font-size:1.35rem;flex-shrink:0}
.region-stat strong{color:#fff}
.region-places-lead{color:rgba(255,255,255,.65);font-weight:600;font-size:.9rem;margin-bottom:12px}
.checks-light li{color:rgba(255,255,255,.82)}
.checks-light li::before{color:#fff}
.checks-2col{grid-template-columns:1fr 1fr;margin-bottom:26px;max-width:520px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,5vw,80px);margin-top:44px;align-items:start}
.contact-left h3{font-size:1.4rem;margin-bottom:8px}
.contact-left>p{color:var(--muted);margin-bottom:22px}
.contact-options{display:grid;gap:12px;margin-bottom:22px}
.contact-option{display:flex;align-items:center;gap:15px;padding:15px 18px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);transition:all .18s}
.contact-option:hover{border-color:var(--brand);transform:translateX(3px);box-shadow:var(--shadow)}
.co-icon{width:46px;height:46px;border-radius:12px;background:rgba(var(--accent-rgb),.12);color:var(--brand-deep);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.co-label{display:block;font-size:.78rem;color:var(--muted);font-weight:600}
.co-value{display:block;font-weight:700;color:var(--text)}

/* ---------- FAQ ---------- */
.faq{margin-top:32px;display:grid;gap:12px}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.faq summary{padding:20px 22px;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;font-size:1.03rem}
.faq summary::-webkit-details-marker{display:none}
.faq-plus{color:var(--brand-deep);font-size:1.3rem;transition:transform .25s;flex-shrink:0}
.faq details[open] .faq-plus{transform:rotate(45deg)}
.faq details p{padding:0 22px 20px;color:var(--text-2);font-size:.96rem}

/* ---------- Final CTA ---------- */
.section-final-cta{position:relative;background:linear-gradient(rgba(8,9,11,.82),rgba(8,9,11,.9)),url('../images/cta-bg.webp') center/cover no-repeat;color:#fff;padding:96px 0;text-align:center;overflow:hidden}
.final-cta-bg{position:absolute;inset:0;pointer-events:none}
.fc-glow{position:absolute;top:-30%;left:50%;transform:translateX(-50%);width:700px;height:500px;background:radial-gradient(circle,rgba(var(--accent-rgb),.2),transparent 66%);filter:blur(14px)}
.final-cta-inner{position:relative;max-width:760px;margin:0 auto}
.final-cta-title{font-size:clamp(2rem,4vw,3rem);font-weight:900;letter-spacing:-.03em;color:#fff;margin-top:6px}
.final-cta-sub{color:rgba(255,255,255,.74);font-size:1.1rem;margin:18px auto 30px;max-width:600px}
.final-cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final-cta-trust{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;margin-top:34px;color:rgba(255,255,255,.7);font-size:.92rem;font-weight:600}
.final-cta-trust span{display:inline-flex;align-items:center;gap:8px}
.final-cta-trust i{color:var(--brand-bright);font-size:1.2rem}

/* ---------- Footer ---------- */
.site-footer{background:#0a0c0e;color:rgba(255,255,255,.7);padding:60px 0 0}
.footer-cols{display:grid;grid-template-columns:1fr 1fr 1.2fr 1.2fr;gap:34px;padding-bottom:44px}
.footer-col h3{color:#fff;font-size:1rem;margin-bottom:16px;letter-spacing:0}
.footer-col ul{list-style:none;display:grid;gap:9px}
.footer-col a{color:rgba(255,255,255,.66);font-size:.92rem;transition:color .18s}
.footer-col a:hover{color:var(--brand-bright)}
.footer-contact-line{display:flex;align-items:center;gap:9px;margin-bottom:10px;font-size:.92rem}
.footer-contact-line i{color:var(--brand-bright)}
.footer-address{margin-top:14px;font-size:.92rem;line-height:1.5;color:rgba(255,255,255,.7)}
.footer-col-logo-hours .brand{margin-bottom:20px}
.footer-hours{display:grid;gap:8px}
.footer-hours div{display:flex;justify-content:space-between;font-size:.88rem;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-hours span:last-child{color:#fff;font-weight:600}
.footer-bottom-wrap{border-top:1px solid rgba(255,255,255,.09)}
.footer-bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:20px 22px;font-size:.84rem;color:rgba(255,255,255,.5)}
.footer-bottom a:hover{color:var(--brand-bright)}

/* ---------- Modals ---------- */
.modal{position:fixed;inset:0;z-index:1300;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-backdrop{position:absolute;inset:0;background:rgba(8,10,12,.72);backdrop-filter:blur(4px)}
.modal-card{position:relative;width:100%;max-width:480px;padding:34px;max-height:92vh;overflow-y:auto;animation:pop .25s ease}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;border:none;background:var(--paper-3);color:var(--text);font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5}
.modal-close:hover{background:var(--line)}
.modal-card h2{font-size:1.5rem;margin-bottom:8px;padding-right:30px}
.modal-sub{color:var(--muted);font-size:.95rem;margin-bottom:20px}
.lead-form{display:grid;gap:12px}
.lead-form input:not([type=checkbox]),.lead-form textarea{width:100%;padding:14px 15px;border:1.5px solid var(--line);border-radius:var(--r);font-size:.96rem;font-family:inherit;background:var(--paper-2);color:var(--text)}
.lead-form .form-consent input[type=checkbox]{width:17px;height:17px;flex-shrink:0;margin-top:2px;accent-color:#111318}
.lead-form input:focus,.lead-form textarea:focus{outline:none;border-color:var(--brand);background:#fff}
.lead-form .form-consent{color:var(--muted)}
.lead-form .form-consent a{color:var(--brand-deep)}
.form-note{text-align:center;color:var(--muted);font-size:.8rem;display:flex;align-items:center;justify-content:center;gap:6px}
.modal-quick{display:flex;gap:8px;margin-top:16px}
.modal-quick a{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px;border-radius:12px;font-weight:700;font-size:.85rem}
.mq-phone{background:var(--paper-3);color:var(--text)}
.mq-wa{background:#25D366;color:#062b14}
.mq-mail{background:var(--paper-3);color:var(--text)}
.form-success{text-align:center;padding:24px 10px}
.form-success>i{font-size:3.4rem;color:var(--brand);margin-bottom:8px}
.form-success strong{display:block;font-size:1.4rem;margin-bottom:6px}
.form-success p{color:var(--muted)}

/* Promo modal (Bild + Formular) */
.promo-card{position:relative;width:100%;max-width:940px;background:#0f1216;border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;max-height:94vh;box-shadow:var(--shadow-dark);animation:pop .25s ease}
.promo-media{position:relative;min-height:100%}
.promo-media img{width:100%;height:100%;object-fit:cover}
.promo-badge{position:absolute;top:16px;left:16px;background:rgba(10,12,15,.7);color:#fff;font-size:.78rem;font-weight:700;padding:7px 13px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;backdrop-filter:blur(6px)}
.promo-badge i{color:var(--brand-bright)}
.promo-body{padding:34px 32px;color:#fff;overflow-y:auto}
.promo-eyebrow{display:inline-flex;align-items:center;gap:7px;color:var(--brand-bright);font-weight:700;font-size:.82rem;margin-bottom:12px}
.promo-body h2{font-size:1.7rem;color:#fff;margin-bottom:10px;line-height:1.15}
.promo-hl{color:var(--brand)}
.promo-text{color:rgba(255,255,255,.74);font-size:.96rem;margin-bottom:20px}
.promo-body .lead-form input{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);color:#fff}
.promo-body .lead-form input::placeholder{color:rgba(255,255,255,.45)}
.promo-body .lead-form input:focus{background:rgba(255,255,255,.1);border-color:var(--brand)}
.promo-body .form-consent{color:rgba(255,255,255,.66)}
.promo-body .form-consent a{color:var(--brand-bright)}
.promo-body .form-note{color:rgba(255,255,255,.5)}
.promo-modal .modal-close{background:rgba(255,255,255,.14);color:#fff}
.promo-modal .modal-close:hover{background:rgba(255,255,255,.24)}

/* ---------- Cookie banner ---------- */
.cookie-wall{position:fixed;inset:0;z-index:1400;display:flex;align-items:center;justify-content:center;padding:16px}
.cookie-backdrop{position:absolute;inset:0;background:rgba(8,10,12,.66);backdrop-filter:blur(3px)}
.cookie-card{position:relative;background:#fff;border-radius:20px;box-shadow:0 24px 64px rgba(0,0,0,.28);max-width:min(520px,calc(100vw - 24px));padding:30px 28px;text-align:center}
.cookie-logo{display:flex;justify-content:center;margin-bottom:16px}
.cookie-title{font-size:1.35rem;margin-bottom:10px}
.cookie-text{color:var(--text-2);font-size:.92rem;margin-bottom:14px}
.cookie-links{display:flex;gap:8px;justify-content:center;font-size:.82rem;margin-bottom:20px;color:var(--muted)}
.cookie-links a{color:var(--brand-deep);font-weight:600}
.cookie-actions{display:flex;flex-direction:column;gap:10px}
.cookie-actions-row{display:flex;gap:10px}
.cookie-btn-accept{width:100%;justify-content:center}
.btn-cookie-reject,.btn-cookie-settings{flex:1;padding:13px;border-radius:999px;font-weight:700;font-size:.92rem;cursor:pointer;font-family:inherit;background:#fff;transition:all .18s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.cookie-btn-accept{border:2px solid #111318}
.btn-cookie-reject{border:2px solid #111318;color:#111318}
.btn-cookie-reject:hover{background:rgba(17,19,24,.06)}
.btn-cookie-settings{border:2px solid #111318;color:#111318}
.btn-cookie-settings:hover{background:rgba(17,19,24,.06)}
.cookie-settings-panel{margin-top:16px;border-top:1px solid var(--line);padding-top:16px;display:grid;gap:14px;text-align:left}
.cookie-category{display:flex;justify-content:space-between;align-items:center;gap:14px}
.cookie-cat-label{font-weight:700;font-size:.92rem}
.cookie-cat-text{font-size:.8rem;color:var(--muted)}
.cookie-always-on{color:var(--brand-deep);font-weight:700;font-size:.82rem;white-space:nowrap}
.cookie-toggle-wrap{position:relative;display:inline-block;width:46px;height:26px;flex-shrink:0}
.cookie-toggle-input{opacity:0;width:0;height:0}
.cookie-toggle-track{position:absolute;inset:0;background:var(--line);border-radius:999px;cursor:pointer;transition:.2s}
.cookie-toggle-track::before{content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.cookie-toggle-input:checked+.cookie-toggle-track{background:var(--brand)}
.cookie-toggle-input:checked+.cookie-toggle-track::before{transform:translateX(20px)}

/* ---------- Legal pages ---------- */
.legal-header{position:relative;background:rgba(12,14,17,.96);padding:14px 0}
.legal-header .legal-back{color:rgba(255,255,255,.8);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:6px}
.legal-header .legal-back:hover{color:#fff}
.legal{max-width:820px;margin:0 auto;padding:54px 22px 70px}
.legal h1{font-size:2.2rem;margin-bottom:8px}
.legal-intro{color:var(--muted);margin-bottom:30px}
.legal h2{font-size:1.25rem;margin:30px 0 10px;color:var(--text)}
.legal p,.legal address,.legal li{color:var(--text-2);font-size:.96rem;margin-bottom:10px}
.legal address{font-style:normal;line-height:1.7}
.legal ul{padding-left:22px;margin-bottom:12px}
.legal a{color:var(--brand-deep);text-decoration:underline}
.legal .note{background:var(--paper-2);border-left:3px solid var(--brand);padding:14px 16px;border-radius:8px;font-size:.9rem;margin-top:24px}
.legal table{width:100%;border-collapse:collapse;margin:14px 0;font-size:.88rem}
.legal th,.legal td{border:1px solid var(--line);padding:10px 12px;text-align:left;color:var(--text-2)}
.legal th{background:var(--paper-2);color:var(--text);font-weight:700}


/* ---------- Inhaber ---------- */
.owner-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:52px;align-items:center}
.owner-media{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-lg);aspect-ratio:4/5;background:#14171c}
.owner-media img{width:100%;height:100%;object-fit:cover}
.owner-badge{position:absolute;left:16px;bottom:16px;background:#fff;color:#111318;border-radius:999px;padding:9px 15px;font-size:.82rem;font-weight:700;display:inline-flex;align-items:center;gap:7px;box-shadow:0 10px 26px rgba(0,0,0,.25)}
.owner-badge i{color:#111318;font-size:1.05rem}
.owner-content h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:16px}
.owner-lead{font-size:1.08rem;color:var(--text-2);margin-bottom:14px}
.owner-lead strong{color:var(--text)}
.owner-text{color:var(--muted);margin-bottom:20px}
.owner-content .checks{margin-bottom:22px}
.owner-sign{font-size:1.25rem;font-weight:800;letter-spacing:-.01em;color:var(--text);margin-bottom:24px}
@media (max-width:1000px){.owner-grid{grid-template-columns:minmax(0,1fr);gap:30px}.owner-media{max-width:420px;margin:0 auto}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:minmax(0,1fr);gap:36px}
  .hero-form{max-width:520px}
  .why-grid,.region-grid,.contact-grid{grid-template-columns:minmax(0,1fr);gap:30px}
  .why-visual{order:-1}
  .region-media{min-height:300px}
  .grid-cards,.price-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
  .price-card-featured{transform:none}
  .promo-card{grid-template-columns:1fr;max-width:440px}
  .promo-media{height:180px;min-height:0}
}
@media (max-width:820px){
  .desktop-only{display:none!important}
  .mobile-only{display:flex!important}
  .section{padding:62px 0}
  .section-region{padding:62px 0}
  .hero{padding:126px 0 40px}
  .brand-img{height:56px}
  .site-header.is-scrolled .brand-img{height:48px}
  .steps-grid{flex-direction:column}
  .step-connector{transform:rotate(90deg);justify-content:center;padding:4px 0}
  .footer-cols{grid-template-columns:1fr 1fr}
  .cta-band{padding:30px 26px}
  .trust-strip{flex-direction:column;align-items:flex-start;gap:12px;width:max-content;max-width:100%;margin-left:auto;margin-right:auto}
  .ts-item{font-size:.9rem}
  .section-title{font-size:1.85rem}
  .section-sub{font-size:.95rem}
  .gallery-track img{height:230px}
  .gallery-track{gap:14px}
}
@media (max-width:560px){
  .grid-cards,.price-grid{grid-template-columns:minmax(0,1fr)}
  .footer-cols{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
  .brand-word b{font-size:.98rem}
  .hero h1{font-size:2.05rem}
  .hero-sub{font-size:.93rem}
  .hero-form{max-width:none}
  .hero-form-card{padding:12px}
  .quiz-dark{padding:18px}
  .quiz-hero.quiz-dark{padding:16px 14px}
  .q-grid-2{grid-template-columns:1fr}
  .modal-card{padding:26px 20px}
  .promo-body{padding:26px 20px}
  .btn{width:100%;white-space:normal}
  .header-actions.mobile-only{width:auto}
  .header-actions.mobile-only .btn{width:auto}
}

button.badge:hover{background:rgba(var(--accent-rgb),.2);transform:translateY(-1px)}
