/* Soti's Schlüsseldienst Wiesbaden – eigenes Stylesheet (Trust-Blau + Notfall-Orange) */
:root{
  --blau:#13386b; --blau-dark:#0e2a52; --blau-hell:#1d4f93;
  --orange:#f08c00; --orange-dark:#d97a00;
  --schwarz:#15202b; --grau:#54616e; --grau-hell:#8b97a3;
  --bg:#f5f7fa; --bg2:#e7edf3; --weiss:#fff; --gruen:#1f9d55;
  --maxw:1180px; --r:8px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
.sd-body{font-family:Inter,system-ui,sans-serif;color:var(--schwarz);background:var(--weiss);line-height:1.65;font-size:17px}
h1,h2,h3,h4,.sd-display{font-family:Oswald,sans-serif;font-weight:600;line-height:1.15;letter-spacing:.4px}
h1{font-size:clamp(2rem,5vw,3.2rem);text-transform:uppercase}
h2{font-size:clamp(1.55rem,3.4vw,2.4rem);text-transform:uppercase}
h3{font-size:1.28rem}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
/* Inline-SVG-Icons: globale Standardgröße, damit nichts riesig rendert */
svg{width:1em;height:1em;flex:none}
.sd-container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.sd-section{padding:68px 0}
.sd-section--alt{background:var(--bg)}
.sd-section--blau{background:var(--blau);color:#fff}
.sd-eyebrow{color:var(--orange);font-family:Oswald;font-weight:600;text-transform:uppercase;letter-spacing:2px;font-size:.85rem;display:block;margin-bottom:10px}
.sd-section--blau .sd-eyebrow{color:#ffd28a}
.sd-lead{font-size:1.14rem;color:var(--grau);max-width:780px}
.sd-section--blau .sd-lead{color:#d6e2f0}
.sd-center{text-align:center}.sd-center .sd-lead{margin:0 auto}
.sd-mt{margin-top:32px}

/* Buttons */
.sd-btn{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;font-family:Oswald;font-weight:600;text-transform:uppercase;letter-spacing:.8px;padding:14px 28px;border-radius:var(--r);transition:.2s;border:2px solid var(--orange);cursor:pointer;font-size:1rem}
.sd-btn:hover{background:var(--orange-dark);border-color:var(--orange-dark)}
.sd-btn--wa{background:#25d366;border-color:#25d366}
.sd-btn--wa:hover{background:#1da851;border-color:#1da851}
.sd-btn-blau{background:var(--blau);border-color:var(--blau)}
.sd-btn-blau:hover{background:var(--blau-dark);border-color:var(--blau-dark)}
.sd-btn-white{background:#fff;color:var(--blau);border-color:#fff}
.sd-btn-white:hover{background:var(--bg2)}
.sd-btn-ghost{background:transparent;color:#fff;border-color:#fff}
.sd-btn-ghost:hover{background:#fff;color:var(--blau)}
.sd-btn-sm{padding:9px 18px;font-size:.9rem}
.sd-btn svg{width:18px;height:18px;fill:currentColor}

/* Header */
.sd-header{position:sticky;top:0;z-index:50;background:#fff;box-shadow:0 2px 14px rgba(0,0,0,.07)}
.sd-topbar{background:var(--blau);color:#fff}
.sd-topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:7px 24px;font-size:.88rem}
.sd-topbar-inner a{color:#fff;display:inline-flex;align-items:center;gap:6px}
.sd-topbar-inner a svg{width:15px;height:15px;fill:currentColor}
.sd-topbar-left{display:flex;gap:22px;flex-wrap:wrap}
.sd-topbar .sd-tel{font-weight:700;font-family:Oswald;letter-spacing:.5px;font-size:.95rem}
.sd-tel-label{font-weight:600;opacity:.85}
.sd-topbar .sd-tel svg{width:16px;height:16px}
.sd-topbar-right{display:flex;align-items:center;gap:18px}
.sd-topbar-wa{background:#25d366;color:#fff!important;padding:4px 12px;border-radius:999px;font-weight:600;font-size:.85rem;line-height:1.4}
.sd-topbar-wa:hover{background:#1da851}
.sd-topbar-inner .sd-topbar-wa svg{width:15px;height:15px;fill:#fff}
.sd-nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;gap:24px}
.sd-logo{display:flex;align-items:center;gap:12px;font-family:Oswald;font-weight:700;text-transform:uppercase;color:var(--blau);line-height:1.05}
.sd-logo svg{width:38px;height:38px;flex:none;fill:var(--orange)}
.sd-logo-img{height:88px;width:auto;display:block}
@media(max-width:600px){.sd-logo-img{height:62px}}
.sd-logo .sd-logo-sub{display:block;font-size:.62rem;color:var(--grau);letter-spacing:1px;font-weight:500}
.sd-logo b{font-size:1.18rem}
.sd-nav{display:flex;align-items:center;gap:20px}
.sd-nav>a{font-family:Oswald;text-transform:uppercase;letter-spacing:.4px;font-weight:500;font-size:.94rem;color:var(--schwarz)}
.sd-nav>a:not(.sd-btn):hover{color:var(--orange)}
.sd-burger{display:none;font-size:1.6rem;background:none;border:none;cursor:pointer;color:var(--blau)}
/* Dropdown */
.sd-has-sub{position:relative}
.sd-sub{position:absolute;top:100%;left:0;background:#fff;box-shadow:0 12px 30px rgba(0,0,0,.12);border-radius:var(--r);min-width:240px;padding:8px 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:60}
.sd-has-sub:hover .sd-sub{opacity:1;visibility:visible;transform:translateY(0)}
.sd-sub a{display:block;padding:9px 18px;font-size:.92rem;color:var(--schwarz);text-transform:none;font-family:Inter}
.sd-sub a:hover{background:var(--bg);color:var(--orange)}

/* Hero */
.sd-hero{position:relative;min-height:560px;display:flex;align-items:center;color:#fff;background:var(--blau-dark)}
.sd-hero-bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;opacity:.4}
.sd-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(14,42,82,.92) 30%,rgba(14,42,82,.55) 100%);z-index:1}
.sd-hero-inner{position:relative;z-index:2;max-width:760px;padding:80px 0}
.sd-hero h1{margin-bottom:18px}
.sd-hero p{font-size:1.2rem;color:#e6edf6;margin-bottom:28px;max-width:620px}
.sd-hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.sd-hero picture{display:contents}
.sd-hero-badges{display:flex;gap:18px;flex-wrap:wrap;margin-top:30px}
.sd-hero-badge{display:flex;align-items:center;gap:9px;font-size:.95rem;color:#d6e2f0}
.sd-hero-badge svg{width:20px;height:20px;fill:var(--orange);flex:none}
.sd-hero--page{min-height:300px}
.sd-hero--page .sd-hero-inner{padding:58px 0;max-width:820px}
.sd-breadcrumb{font-size:.82rem;color:#aebfd4;margin-bottom:14px;font-family:Oswald;letter-spacing:1px;text-transform:uppercase}
.sd-breadcrumb a{color:#aebfd4}.sd-breadcrumb a:hover{color:#fff}

/* Sticky Notruf-Leiste (mobil) */
.sd-callbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;background:var(--orange);box-shadow:0 -2px 14px rgba(0,0,0,.18)}
.sd-callbar a{display:flex;align-items:center;justify-content:center;gap:10px;padding:15px;color:#fff;font-family:Oswald;font-weight:700;font-size:1.12rem;letter-spacing:.5px;text-transform:uppercase}
.sd-callbar svg{width:22px;height:22px;fill:#fff}
/* Consent-Banner */
.sd-consent{position:fixed;bottom:0;left:0;right:0;z-index:120;background:var(--blau);color:#fff;box-shadow:0 -2px 18px rgba(0,0,0,.25)}
.sd-consent-inner{display:flex;align-items:center;gap:24px;padding:16px 24px}
.sd-consent-text{margin:0;font-size:.88rem;line-height:1.55;flex:1}
.sd-consent-title{display:block;font-family:Oswald;font-size:1rem;margin-bottom:4px}
.sd-consent-text a{color:#fff;text-decoration:underline}
.sd-consent-actions{flex:none;display:flex;gap:12px;align-items:center}
.sd-consent-btn{font-family:Oswald;font-weight:600;text-transform:uppercase;letter-spacing:.6px;border-radius:var(--r);padding:11px 24px;cursor:pointer;font-size:.92rem;transition:.2s;border:2px solid transparent;white-space:nowrap}
.sd-consent-accept{background:var(--orange);color:#fff;border-color:var(--orange)}
.sd-consent-accept:hover{background:var(--orange-dark);border-color:var(--orange-dark)}
.sd-consent-reject{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.sd-consent-reject:hover{background:rgba(255,255,255,.12);border-color:#fff}
@media(max-width:600px){
  .sd-consent-inner{flex-direction:column;align-items:stretch;gap:12px;padding:14px 18px}
  .sd-consent-actions{flex-direction:column-reverse}
  .sd-consent-btn{width:100%;padding:13px}
  /* Callbar nach unten schieben, solange Consent offen */
  body.sd-consent-open .sd-callbar{bottom:auto;position:static}
}

/* Vorteile / Cards */
.sd-grid{display:grid;gap:24px}
.sd-grid-3{grid-template-columns:repeat(3,1fr)}
.sd-grid-2{grid-template-columns:repeat(2,1fr)}
.sd-grid-4{grid-template-columns:repeat(4,1fr)}

.sd-vorteil{padding:30px;background:#fff;border:1px solid var(--bg2);border-radius:var(--r);transition:.2s}
.sd-vorteil:hover{box-shadow:0 12px 30px rgba(19,56,107,.1);transform:translateY(-3px)}
.sd-vorteil-icon{width:56px;height:56px;background:var(--blau);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.sd-vorteil-icon svg{width:28px;height:28px;fill:#fff}
.sd-vorteil h3{margin-bottom:8px}
.sd-vorteil p{color:var(--grau);font-size:.97rem}

/* Service-Karten */
.sd-serv{background:#fff;border:1px solid var(--bg2);border-radius:var(--r);padding:28px;transition:.2s;display:flex;flex-direction:column;height:100%}
.sd-serv:hover{border-color:var(--orange);box-shadow:0 12px 30px rgba(240,140,0,.1);transform:translateY(-3px)}
.sd-serv-icon{width:54px;height:54px;background:var(--bg);border:2px solid var(--blau);border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.sd-serv-icon svg{width:28px;height:28px;fill:var(--blau)}
.sd-serv:hover .sd-serv-icon{background:var(--blau)}
.sd-serv:hover .sd-serv-icon svg{fill:#fff}
.sd-serv h3{margin-bottom:8px}
.sd-serv p{color:var(--grau);font-size:.96rem;flex:1}
.sd-serv-link{margin-top:16px;color:var(--orange);font-family:Oswald;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:.88rem}

/* Facts-Leiste */
.sd-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bg2);border-radius:var(--r);overflow:hidden}
.sd-fact{background:#fff;padding:28px 20px;text-align:center}
.sd-fact b{display:block;font-family:Oswald;font-size:2rem;color:var(--blau);line-height:1}
.sd-fact span{display:block;margin-top:8px;font-size:.9rem;color:var(--grau)}

/* Split */
.sd-split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.sd-split img{border-radius:var(--r);width:100%;aspect-ratio:4/3;object-fit:cover}
.sd-split-img picture{display:block;width:100%}
.sd-split ul{list-style:none;margin-top:18px}
.sd-split li{padding-left:30px;position:relative;margin-bottom:10px;color:var(--grau)}
.sd-split li::before{content:"✓";position:absolute;left:0;color:var(--gruen);font-weight:700}
.sd-split-text h2{margin-bottom:14px}
.sd-split--rev .sd-split-img{order:2}

/* Preise */
.sd-preis-tabelle{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.05)}
.sd-preis-tabelle th{background:var(--blau);color:#fff;text-align:left;padding:15px 20px;font-family:Oswald;font-weight:500;text-transform:uppercase;letter-spacing:.5px;font-size:.92rem}
.sd-preis-tabelle td{padding:14px 20px;border-bottom:1px solid var(--bg2)}
.sd-preis-tabelle tr:last-child td{border-bottom:none}
.sd-preis-tabelle .sd-preis{font-family:Oswald;font-weight:700;color:var(--orange);font-size:1.15rem;white-space:nowrap}
.sd-preis-tabelle .sd-preis-note{color:var(--grau-hell);font-size:.85rem}
.sd-preis-hinweis{background:var(--bg);border-left:4px solid var(--orange);padding:18px 22px;border-radius:0 var(--r) var(--r) 0;color:var(--grau);font-size:.95rem;margin-top:24px}

/* USP-Liste */
.sd-usps{display:flex;flex-wrap:wrap;gap:12px 26px;list-style:none}
.sd-usps li{display:flex;align-items:center;gap:9px;font-weight:500}
.sd-usps li svg{width:20px;height:20px;fill:var(--gruen);flex:none}

/* Notruf-CTA-Box */
.sd-cta-box{background:var(--blau);color:#fff;border-radius:var(--r);padding:48px;text-align:center;background-image:radial-gradient(circle at 90% 10%,rgba(240,140,0,.18),transparent 55%)}
.sd-cta-box h2{margin-bottom:12px}
.sd-cta-box p{color:#d6e2f0;max-width:560px;margin:0 auto 26px}
.sd-cta-phone{font-family:Oswald;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;color:#fff;display:inline-flex;align-items:center;gap:14px}
.sd-cta-phone svg{width:36px;height:36px;fill:var(--orange)}

/* Standorte-Übersicht */
.sd-kreis{margin-bottom:40px}
.sd-kreis h3{color:var(--blau);margin-bottom:6px;display:flex;align-items:baseline;gap:10px}
.sd-kreis h3 span{font-size:.8rem;color:var(--grau-hell);font-family:Inter;font-weight:400;text-transform:none;letter-spacing:0}
.sd-ort-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-top:16px}
.sd-ort-link{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 16px;background:#fff;border:1px solid var(--bg2);border-radius:var(--r);transition:.16s}
.sd-ort-link:hover{border-color:var(--orange);box-shadow:0 6px 18px rgba(0,0,0,.06)}
.sd-ort-link b{font-weight:500}
.sd-ort-link .sd-km{font-size:.8rem;color:var(--grau-hell);white-space:nowrap}
.sd-ort-link:hover .sd-km{color:var(--orange)}

/* Prose (Long-Form) */
.sd-prose{max-width:820px}
.sd-prose h2{margin:38px 0 14px}
.sd-prose h3{margin:28px 0 10px;color:var(--blau)}
.sd-prose p{margin-bottom:16px;color:#2b3742}
.sd-prose ul,.sd-prose ol{margin:0 0 18px 22px}
.sd-prose li{margin-bottom:8px;color:#2b3742}
.sd-prose strong{color:var(--schwarz)}
.sd-prose a{color:var(--blau-hell);text-decoration:underline}

/* FAQ */
.sd-faq{max-width:840px;margin:0 auto}
.sd-faq details{background:#fff;border:1px solid var(--bg2);border-radius:var(--r);margin-bottom:12px;overflow:hidden}
.sd-faq summary{padding:18px 22px;font-family:Oswald;font-weight:500;font-size:1.05rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.sd-faq summary::-webkit-details-marker{display:none}
.sd-faq summary::after{content:"+";font-size:1.5rem;color:var(--orange);transition:.2s;flex:none}
.sd-faq details[open] summary::after{transform:rotate(45deg)}
.sd-faq details[open] summary{color:var(--blau)}
.sd-faq-a{padding:0 22px 20px;color:var(--grau)}
.sd-faq-a p{margin-bottom:10px}

/* Bewertungen */
.sd-bewertung{background:#fff;border:1px solid var(--bg2);border-radius:var(--r);padding:26px}
.sd-stars{color:var(--orange);font-size:1.05rem;letter-spacing:2px;margin-bottom:10px}
.sd-bewertung p{color:var(--grau);font-style:italic;margin-bottom:14px}
.sd-bewertung .sd-autor{font-weight:600;font-size:.92rem}

/* Karte / Region */
.sd-map-wrap{border-radius:var(--r);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.08);aspect-ratio:16/9}
.sd-map-wrap iframe{width:100%;height:100%;border:0}

/* Footer */
.sd-footer{background:var(--blau-dark);color:#aebfd4}
.sd-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding:64px 24px 40px}
.sd-footer-grid h4{color:#fff;text-transform:uppercase;letter-spacing:1px;font-size:.9rem;margin-bottom:14px;font-family:Oswald}
.sd-footer-grid a{display:block;color:#aebfd4;margin-bottom:6px;font-size:.88rem;transition:.15s}
.sd-footer-grid a:hover{color:#fff}
.sd-footer-brand{display:flex;align-items:center;gap:10px;font-family:Oswald;font-weight:700;text-transform:uppercase;color:#fff;font-size:1.1rem;margin-bottom:14px}
.sd-footer-brand svg{width:34px;height:34px;fill:var(--orange)}
.sd-footer-text{font-size:.88rem;line-height:1.65}
.sd-footer-bottom{border-top:1px solid rgba(255,255,255,.12)}
.sd-footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;padding:18px 24px;font-size:.84rem;color:#7e8ea3}
.sd-footer-bottom-inner a{color:#9fb0c4}
.sd-footer-bottom-inner a:hover{color:#fff}

/* ADAC-Partner-Block */
.sd-adac{display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:center;background:#fff;border:1px solid var(--bg2);border-radius:var(--r);padding:36px;box-shadow:0 6px 24px rgba(19,56,107,.07)}
.sd-adac-badge{width:130px;height:130px;border-radius:50%;background:var(--blau);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;flex:none;border:5px solid var(--orange)}
.sd-adac-badge svg{width:40px;height:40px;fill:#fff}
.sd-adac-badge span{font-family:Oswald;font-weight:700;text-transform:uppercase;letter-spacing:.5px;text-align:center;line-height:1.05;font-size:.95rem}
.sd-adac-text h2{margin-bottom:12px}
.sd-adac-text p{color:var(--grau)}
.sd-adac-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:20px}
.sd-adac-note{font-size:.9rem;color:var(--grau-hell)}
@media(max-width:720px){.sd-adac{grid-template-columns:1fr;text-align:center;padding:28px}.sd-adac-badge{margin:0 auto}.sd-adac-cta{justify-content:center}}

/* Tags/Chips */
.sd-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.sd-chip{background:var(--bg2);color:var(--blau);padding:6px 14px;border-radius:100px;font-size:.85rem;font-weight:500}

/* Responsive */
@media(max-width:980px){
  .sd-footer-grid{grid-template-columns:1fr 1fr}
  .sd-grid-4{grid-template-columns:repeat(2,1fr)}
  .sd-facts{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:820px){
  .sd-nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;background:#fff;padding:10px 0;box-shadow:0 12px 24px rgba(0,0,0,.12)}
  .sd-nav.open{display:flex}
  .sd-nav>a{padding:12px 24px}
  .sd-nav-wrap{position:relative}
  .sd-burger{display:block}
  .sd-has-sub .sd-sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;padding-left:14px}
  .sd-grid-3,.sd-grid-2{grid-template-columns:1fr}
  .sd-split{grid-template-columns:1fr;gap:28px}
  .sd-split--rev .sd-split-img{order:0}
  .sd-callbar{display:block}
  .sd-body{padding-bottom:56px}
  .sd-cta-box{padding:32px 22px}
}
@media(max-width:600px){
  .sd-container{padding:0 18px}
  .sd-topbar-inner{padding:7px 18px}
  .sd-nav-wrap{padding:12px 18px}
  /* Topbar mobil: Zusatzzeile ausblenden; WhatsApp + Notruf zentriert */
  .sd-topbar-left{display:none}
  .sd-topbar-inner{justify-content:center}
  .sd-topbar-right{gap:12px}
  .sd-topbar .sd-tel{font-size:.98rem}
  .sd-topbar-wa span{display:none}
  .sd-topbar-wa{padding:5px 10px}
}
@media(max-width:520px){
  .sd-grid-4,.sd-facts{grid-template-columns:1fr}
  .sd-topbar-left{gap:14px}
}
