/* ============================================================
   Krüger WasserschadenHilfe — Mehrseiten-Komponenten
   (Unterseiten, Service-Seiten, FAQ, Testimonials, Blog, CTA)
   Reines CSS/SVG — kein zusätzliches JS, kein PageSpeed-Einfluss.
   ============================================================ */

/* Breadcrumb */
.crumbs{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--muted);padding-block:18px}
.crumbs a{color:var(--azure)}
.crumbs a:hover{text-decoration:underline}
.crumbs span{opacity:.5;margin:0 6px}

/* Subhero (Unterseiten-Kopf, schlanke Blueprint-Variante) */
.subhero{position:relative;background:var(--azure-900);color:#fff;overflow:hidden;isolation:isolate}
.subhero__bg{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(900px 480px at 85% -20%,rgba(47,182,206,.28),transparent 60%),
  linear-gradient(165deg,#00314E,#013F63 60%,#00263E)}
.subhero__grid{position:absolute;inset:0;z-index:-1;opacity:.45;
  background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:44px 44px;-webkit-mask-image:radial-gradient(120% 100% at 70% 0%,#000 55%,transparent);mask-image:radial-gradient(120% 100% at 70% 0%,#000 55%,transparent)}
.subhero__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding-block:clamp(38px,5vw,72px)}
.subhero h1{color:#fff;font-size:clamp(2rem,1.3rem+3vw,3.2rem);margin-top:14px}
.subhero p{color:#CFE4EE;font-size:clamp(1.02rem,.97rem+.4vw,1.18rem);max-width:46ch;margin-top:16px}
.subhero .eyebrow{color:var(--aqua)}
.subhero__cta{display:flex;flex-wrap:wrap;gap:13px;margin-top:26px}
.subhero__art{position:relative}
@media (max-width:880px){.subhero__inner{grid-template-columns:1fr}.subhero__art{display:none}}

/* Prose (Artikel- und Seiteninhalt) */
.prose{max-width:760px}
.prose h2{font-size:clamp(1.5rem,1.2rem+1.4vw,2.1rem);margin:42px 0 14px}
.prose h3{font-size:1.22rem;margin:28px 0 8px}
.prose p{margin-bottom:16px;font-size:1.04rem}
.prose ul:not(.bare),.prose ol{margin:0 0 18px 0;display:grid;gap:10px}
.prose ul:not(.bare) li{position:relative;padding-left:30px;color:var(--ink-2)}
.prose ul:not(.bare) li::before{content:"";position:absolute;left:2px;top:.45em;width:14px;height:14px;border-radius:50%;background:rgba(0,104,160,.14)}
.prose ul:not(.bare) li::after{content:"";position:absolute;left:6.5px;top:calc(.45em + 4px);width:5px;height:5px;border-radius:50%;background:var(--azure)}
.prose ol{counter-reset:p;padding-left:0}
.prose ol li{position:relative;padding-left:42px;color:var(--ink-2)}
.prose ol li::before{counter-increment:p;content:counter(p);position:absolute;left:0;top:-2px;width:28px;height:28px;border-radius:8px;background:var(--azure);color:#fff;font-family:var(--mono);font-size:.82rem;display:grid;place-items:center;font-weight:600}
.prose strong{color:var(--ink)}
.prose a{color:var(--azure);text-decoration:underline;text-underline-offset:2px}

/* Zwei-Spalten Layout (Inhalt + Sidebar) */
.layout-2col{display:grid;grid-template-columns:1fr 320px;gap:clamp(32px,4vw,56px);align-items:start}
.sidebar{position:sticky;top:96px;display:grid;gap:18px}
.card-cta{background:var(--azure-900);color:#fff;border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow-md)}
.card-cta h3{color:#fff;font-size:1.16rem;margin-bottom:6px}
.card-cta p{color:#CFE4EE;font-size:.92rem;margin-bottom:16px}
.card-cta .btn{width:100%}
.card-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}
.card-box h3{font-size:1rem;margin-bottom:12px}
.card-box ul{display:grid;gap:9px}
.card-box li{font-size:.92rem;color:var(--muted)}
.card-box a{color:var(--azure)}
@media (max-width:900px){.layout-2col{grid-template-columns:1fr}.sidebar{position:static;grid-template-columns:1fr 1fr;display:grid}}
@media (max-width:560px){.sidebar{grid-template-columns:1fr}}

/* Service-Kacheln (Hub) */
.svc-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}
.svc-tile{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;position:relative;overflow:hidden}
.svc-tile::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:linear-gradient(90deg,var(--azure),var(--aqua));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.svc-tile:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.svc-tile:hover::before{transform:scaleX(1)}
.svc-tile__ic{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(150deg,rgba(0,104,160,.12),rgba(47,182,206,.12));color:var(--azure);border:1px solid rgba(0,104,160,.14);margin-bottom:16px}
.svc-tile__ic svg{width:26px;height:26px}
.svc-tile h3{margin-bottom:8px}
.svc-tile p{font-size:.95rem;color:var(--muted);margin-bottom:16px;flex:1}
.svc-tile__link{font-weight:600;color:var(--azure);display:inline-flex;align-items:center;gap:7px;font-size:.95rem}
.svc-tile__link svg{width:16px;height:16px;transition:transform .25s}
.svc-tile:hover .svc-tile__link svg{transform:translateX(4px)}

/* Versprechen (mueller-inspiriert) */
.promises{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}
.promise{display:flex;gap:15px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.promise .ic{width:42px;height:42px;flex:none;border-radius:11px;background:rgba(0,104,160,.1);color:var(--azure);display:grid;place-items:center}
.promise .ic svg{width:22px;height:22px}
.promise b{display:block;font-family:var(--display);font-size:1.02rem;margin-bottom:3px}
.promise span{font-size:.9rem;color:var(--muted)}

/* Testimonials */
.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.review__stars{color:#F5A623;letter-spacing:2px;font-size:1rem;margin-bottom:12px}
.review p{font-size:1rem;color:var(--ink);line-height:1.6;flex:1}
.review__who{display:flex;align-items:center;gap:12px;margin-top:18px}
.review__av{width:40px;height:40px;border-radius:50%;background:linear-gradient(150deg,var(--azure),var(--aqua));color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--display)}
.review__who b{font-size:.94rem}
.review__who span{font-size:.8rem;color:var(--muted)}

/* FAQ (Accordion via <details>) */
.faq{max-width:820px}
.faq details{border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:12px;overflow:hidden;transition:box-shadow .25s}
.faq details[open]{box-shadow:var(--shadow-sm)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--display);font-weight:700;font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";width:11px;height:11px;border-right:2px solid var(--azure);border-bottom:2px solid var(--azure);transform:rotate(45deg);transition:transform .3s var(--ease);flex:none;margin-top:-4px}
.faq details[open] summary::after{transform:rotate(-135deg);margin-top:4px}
.faq__a{padding:0 24px 20px;color:var(--ink-2);line-height:1.65}
.faq__a p{margin-bottom:10px}

/* CTA-Band */
.ctaband{background:var(--azure-900);color:#fff;position:relative;overflow:hidden;isolation:isolate}
.ctaband__bg{position:absolute;inset:0;z-index:-1;opacity:.4;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:radial-gradient(80% 120% at 50% 0%,#000,transparent);mask-image:radial-gradient(80% 120% at 50% 0%,#000,transparent)}
.ctaband__inner{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;padding-block:clamp(38px,5vw,60px)}
.ctaband h2{color:#fff;max-width:20ch}
.ctaband p{color:#CFE4EE;margin-top:8px;max-width:46ch}
.ctaband__btns{display:flex;flex-wrap:wrap;gap:13px}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.post-card__media{aspect-ratio:16/9;background:linear-gradient(150deg,var(--azure-900),var(--azure));position:relative;overflow:hidden}
.post-card__media svg{position:absolute;inset:0;width:100%;height:100%;opacity:.5}
.post-card__cat{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(0,30,49,.7);color:var(--aqua);padding:5px 10px;border-radius:6px}
.post-card__body{padding:22px;display:flex;flex-direction:column;flex:1}
.post-card__body time{font-family:var(--mono);font-size:.72rem;color:var(--muted)}
.post-card h3{margin:8px 0 8px;font-size:1.16rem}
.post-card p{font-size:.94rem;color:var(--muted);flex:1}
.post-card__link{margin-top:14px;font-weight:600;color:var(--azure);font-size:.94rem;display:inline-flex;gap:6px;align-items:center}

/* Glossar / Definition-Box (GEO) */
.keybox{background:linear-gradient(150deg,rgba(0,104,160,.06),rgba(47,182,206,.06));border:1px solid rgba(0,104,160,.16);border-left:4px solid var(--azure);border-radius:12px;padding:20px 24px;margin:24px 0}
.keybox b{font-family:var(--display)}

/* Section tints */
.sec-tint{background:linear-gradient(180deg,#fff,var(--paper))}
.sec-white{background:#fff}

/* Chatbot Bubble Fallback-Style (falls Plattform-Widget lädt, ersetzt es das) */
.cw-launch{position:fixed;right:20px;bottom:20px;z-index:70}

@media (max-width:760px){
  .ctaband__inner{flex-direction:column;align-items:flex-start}
}
