/* ===== Dach-VIP Bau — Main stylesheet ===== */

/* ---- Self-hosted fonts ---- */
@font-face{font-family:"Inter";src:url("../fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/inter-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Oswald";src:url("../fonts/oswald-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Oswald";src:url("../fonts/oswald-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ---- Layout helpers ---- */
.section{padding-block:clamp(48px,7vw,92px)}
.section--tight{padding-block:clamp(36px,5vw,64px)}
.section--ink{background:var(--ink);color:#e9eaed}
.section--ink h2,.section--ink h3{color:#fff}
.section--paper{background:var(--paper)}
.section--alt{background:var(--bg-2)}
.lead{font-size:1.16rem;color:var(--muted)}
.section--ink .lead{color:#bfc2c9}
.eyebrow{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.16em;color:var(--red);font-weight:600;font-size:.85rem;display:flex;align-items:center;gap:12px;margin-bottom:14px}
.eyebrow::before{content:"";width:30px;height:3px;background:var(--red)}
.eyebrow.center{justify-content:center}
.sec-head{max-width:62ch}
.sec-head.center{margin-inline:auto;text-align:center}
.grid{display:grid;gap:clamp(20px,3vw,34px)}
.measure{max-width:66ch}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}

/* ---- Trust strip ---- */
.trust{background:var(--ink-2);color:#cfd2d8;border-top:3px solid var(--red)}
.trust .container{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:#33373e}
.trust .item{background:var(--ink-2);padding:20px 18px}
.trust .num{font-family:var(--ff-head);font-size:2rem;color:#fff;line-height:1}
.trust .lbl{font-size:.86rem;color:#aeb2ba;margin-top:4px}
@media(min-width:760px){.trust .container{grid-template-columns:repeat(4,1fr)}}

/* ---- Services editorial list (avoids 3-col icon grid) ---- */
.svc-list{display:grid;gap:0;border-top:1px solid var(--line)}
.svc-row{display:grid;grid-template-columns:1fr;gap:6px 28px;padding:26px 0;border-bottom:1px solid var(--line);align-items:start}
.svc-row .svc-no{font-family:var(--ff-head);color:var(--red);font-size:1.05rem;letter-spacing:.05em}
.svc-row h3{margin:0}
.svc-row .svc-more{font-family:var(--ff-head);text-transform:uppercase;font-size:.85rem;letter-spacing:.05em;white-space:nowrap}
.svc-row p{margin:.3em 0 0;color:var(--muted)}
@media(min-width:780px){
  .svc-row{grid-template-columns:54px 1fr minmax(0,40ch) auto;gap:0 28px;align-items:baseline}
  .svc-row .svc-more{align-self:center}
}
.svc-row:hover{background:var(--paper)}

/* ---- Cards ---- */
.cards{display:grid;gap:clamp(18px,2.6vw,28px);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--red);padding:26px 24px;display:flex;flex-direction:column}
.card h3{margin-top:0}
.card p{color:var(--muted)}
.card .card-link{margin-top:auto;font-family:var(--ff-head);text-transform:uppercase;font-size:.85rem;letter-spacing:.04em;padding-top:14px}
.card--ink{background:var(--ink-2);border-color:#2f333a;color:#d7dade}
.card--ink h3{color:#fff}.card--ink p{color:#aeb2ba}

/* ---- Split / feature ---- */
.split{display:grid;gap:clamp(24px,4vw,56px);align-items:center}
@media(min-width:880px){.split{grid-template-columns:1fr 1fr}.split.reverse>.split-media{order:2}}
.split-media img{width:100%;border-radius:3px;border:1px solid var(--line)}
.split--framed .split-media{position:relative}
.split--framed .split-media::before{content:"";position:absolute;inset:14px 14px -14px -14px;border:3px solid var(--red);z-index:-1;border-radius:3px}
.checklist{list-style:none;margin:1.2em 0;padding:0;display:grid;gap:12px}
.checklist li{position:relative;padding-left:34px;color:var(--ink)}
.checklist li::before{content:"";position:absolute;left:0;top:3px;width:20px;height:20px;background:var(--red);border-radius:2px;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/72% no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/72% no-repeat}
.section--ink .checklist li{color:#dfe1e6}

/* ---- Process steps ---- */
.steps{counter-reset:step;display:grid;gap:2px;background:var(--line)}
.step{background:var(--bg);padding:24px 22px;counter-increment:step;position:relative}
.section--ink .step{background:var(--ink-2)}
.step::before{content:counter(step,decimal-leading-zero);font-family:var(--ff-head);font-size:2.1rem;color:var(--red);line-height:1;display:block;margin-bottom:8px}
.step h3{font-size:1.12rem;margin:0 0 .3em}
.step p{margin:0;color:var(--muted);font-size:.96rem}
.section--ink .step p{color:#aeb2ba}
@media(min-width:720px){.steps{grid-template-columns:repeat(4,1fr)}}

/* ---- Gallery ---- */
.gallery{columns:2;column-gap:14px}
.gallery figure{margin:0 0 14px;break-inside:avoid;position:relative;overflow:hidden;border-radius:3px;background:var(--ink-2)}
.gallery img{width:100%;transition:transform .4s ease;display:block}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(0,0,0,.78));color:#fff;font-size:.82rem;padding:26px 14px 12px;font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.03em;opacity:0;transition:.2s}
.gallery figure:hover figcaption{opacity:1}
@media(min-width:680px){.gallery{columns:3}}
@media(min-width:1040px){.gallery{columns:4}}

/* ---- CTA band ---- */
.cta-band{background:var(--red);color:#fff}
.cta-band .container{display:grid;gap:22px;align-items:center;padding-block:clamp(34px,5vw,56px)}
.cta-band h2{color:#fff;margin:0}
.cta-band p{color:#ffe2e3;margin:.4em 0 0}
@media(min-width:820px){.cta-band .container{grid-template-columns:1fr auto}}
.cta-band .btn-light{font-size:1.05rem}

/* ---- Testimonials ---- */
.quotes{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.quote{background:var(--paper);border:1px solid var(--line);padding:26px 24px;border-left:4px solid var(--red)}
.quote p{font-size:1.04rem}
.quote .who{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.03em;font-size:.9rem;color:var(--ink);margin-top:10px}
.quote .who span{color:var(--muted);font-family:var(--ff-body);text-transform:none;letter-spacing:0}
.placeholder-note{background:var(--red-soft);border:1px dashed var(--red);padding:18px 20px;color:var(--red-dk);font-size:.95rem;border-radius:3px}

/* ---- Breadcrumbs ---- */
.crumbs{font-size:.85rem;color:var(--muted);padding-block:14px}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0}
.crumbs li+li::before{content:"›";margin-right:8px;color:var(--muted-2)}

/* ---- FAQ ---- */
.faq{display:grid;gap:0;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:18px 40px 18px 0;position:relative;font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.02em;font-size:1.05rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:14px;font-size:1.6rem;color:var(--red);font-family:var(--ff-head)}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--muted);margin:0 0 18px}

/* ---- Page header (interior) ---- */
.page-hero{background:var(--ink);color:#fff;position:relative}
.page-hero.has-img{background-size:cover;background-position:center}
.page-hero.has-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,16,19,.92),rgba(15,16,19,.62))}
.page-hero .container{position:relative;z-index:1;padding-block:clamp(40px,6vw,72px)}
.page-hero h1{color:#fff;max-width:20ch}
.page-hero h1 em{color:var(--red);font-style:normal}
.page-hero p{color:#cfd2d8;max-width:54ch;font-size:1.1rem;margin-bottom:0}

/* ---- Two-col content (text + aside) ---- */
.layout{display:grid;gap:clamp(28px,4vw,52px)}
@media(min-width:980px){.layout{grid-template-columns:1fr 320px}}
.prose h2{margin-top:1.6em}
.prose h2:first-child{margin-top:0}
.prose ul{padding-left:0;list-style:none;display:grid;gap:10px;margin:1.2em 0}
.prose ul li{position:relative;padding-left:26px}
.prose ul li::before{content:"";position:absolute;left:0;top:.6em;width:9px;height:9px;background:var(--red);transform:rotate(45deg)}
.aside-card{background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--red);padding:24px 22px;position:sticky;top:96px}
.aside-card h3{margin-top:0}
.aside-card .big-tel{font-family:var(--ff-head);font-size:1.5rem;color:var(--ink);display:block;margin:.2em 0}
.aside-list{list-style:none;margin:14px 0 0;padding:0;display:grid;gap:8px;font-size:.95rem}
.aside-list a{color:var(--ink-3)}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.tag{font-size:.8rem;font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.03em;background:var(--bg-2);color:var(--ink-3);padding:5px 10px;border-radius:2px}

/* ---- Standorte / location index ---- */
.loc-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.loc-grid a{background:var(--paper);border:1px solid var(--line);padding:13px 15px;display:flex;justify-content:space-between;align-items:center;color:var(--ink);font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.02em;font-size:.92rem}
.loc-grid a:hover{border-color:var(--red);color:var(--red);text-decoration:none}
.loc-grid a span{color:var(--muted-2);font-family:var(--ff-body);text-transform:none;font-size:.8rem}

/* ---- Contact ---- */
.contact-grid{display:grid;gap:clamp(28px,4vw,48px)}
@media(min-width:920px){.contact-grid{grid-template-columns:1fr 1fr}}
.field{display:grid;gap:6px;margin-bottom:18px}
.field label{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.03em;font-size:.85rem}
.field input,.field textarea{font:inherit;padding:13px 14px;border:1px solid var(--line);border-radius:2px;background:#fff;color:var(--ink);width:100%}
.field input:focus,.field textarea:focus{border-color:var(--red);outline:none;box-shadow:0 0 0 3px rgba(209,0,7,.12)}
.field textarea{min-height:140px;resize:vertical}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--muted)}
.consent input{margin-top:4px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.85rem;color:var(--muted-2);margin-top:10px}
.info-block{display:grid;gap:18px}
.info-line{display:flex;gap:14px;align-items:flex-start}
.info-line .ic{flex:0 0 42px;height:42px;background:var(--ink);border-radius:2px;display:grid;place-items:center}
.info-line .ic svg{width:20px;height:20px;fill:#fff}
.info-line b{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.02em;font-size:.85rem;color:var(--muted);font-weight:600;display:block}
.info-line a,.info-line span{font-size:1.08rem;color:var(--ink)}
.alert{padding:14px 16px;border-radius:2px;margin-bottom:20px;font-size:.95rem}
.alert-ok{background:#e7f4e8;border:1px solid #b6d8b9;color:#1f6b27}
.alert-err{background:#fbe6e6;border:1px solid #e3aeae;color:#9a1b1b}

/* ---- Legal pages ---- */
.legal{max-width:80ch}
.legal h2{font-size:1.3rem;margin-top:1.8em}
.legal h3{font-size:1.05rem;margin-top:1.3em}
.legal p,.legal li{color:var(--ink-3)}
.legal .todo{background:#fff6d6;border:1px dashed #d4a72c;padding:2px 8px;border-radius:2px;font-size:.9em;color:#7a5c0a}

/* ---- Footer ---- */
.site-footer{background:var(--ink);color:#aeb2ba;font-size:.93rem}
.site-footer a{color:#cfd2d8}
.site-footer a:hover{color:#fff}
.footer-top{padding-block:clamp(40px,6vw,64px);display:grid;gap:clamp(28px,4vw,40px);grid-template-columns:1fr}
.footer-brand img{height:42px;margin-bottom:16px}
.footer-col h4{font-family:var(--ff-head);text-transform:uppercase;color:#fff;font-size:1rem;letter-spacing:.04em;margin:0 0 14px}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.footer-bottom{border-top:1px solid #2c2f35;padding-block:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem;color:#8a8e96}
.footer-bottom a{color:#8a8e96}
@media(min-width:760px){.footer-top{grid-template-columns:1.5fr 1fr 1fr 1.2fr}}

/* ---- WhatsApp float ---- */
.wa-float{position:fixed;right:16px;bottom:16px;z-index:90;width:58px;height:58px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 8px 24px rgba(0,0,0,.28);transition:transform .15s}
.wa-float:hover{transform:scale(1.07);text-decoration:none}
.wa-float svg{width:32px;height:32px;fill:#fff}
.wa-float .wa-pulse{position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(37,211,102,.5);animation:wapulse 2.4s infinite}
@keyframes wapulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@media(min-width:900px){.wa-float{right:24px;bottom:24px}}

/* ---- Cookie banner ---- */
#cookie-banner{position:fixed;left:14px;right:14px;bottom:14px;z-index:120;background:var(--ink);color:#e4e6ea;border-top:3px solid var(--red);border-radius:4px;padding:18px 20px;box-shadow:0 14px 40px rgba(0,0,0,.35);display:flex;gap:18px;flex-wrap:wrap;align-items:center;justify-content:space-between}
#cookie-banner p{margin:0;font-size:.9rem;max-width:62ch}
#cookie-banner a{color:#fff;text-decoration:underline}
.cookie-btns{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btns button{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.03em;font-size:.85rem;padding:.7em 1.2em;border-radius:2px;cursor:pointer;border:2px solid transparent}
#cookie-accept{background:var(--red);color:#fff}
#cookie-decline{background:transparent;color:#fff;border-color:#4a4e56}
@media(min-width:900px){.wa-float{bottom:24px}#cookie-banner{left:auto;right:24px;max-width:560px}}

/* ---- Misc ---- */
.divider-red{height:4px;background:var(--red);width:64px;margin:18px 0}
.bg-note{font-size:.85rem;color:var(--muted-2)}
.kicker-stat{display:flex;gap:26px;flex-wrap:wrap;margin-top:24px}
.kicker-stat div b{font-family:var(--ff-head);font-size:1.8rem;color:#fff;display:block;line-height:1}
.kicker-stat div span{font-size:.82rem;color:#aeb2ba}
.inline-list{display:flex;flex-wrap:wrap;gap:8px 10px;list-style:none;padding:0;margin:12px 0 0}
.inline-list li{font-size:.86rem;background:#fff;border:1px solid var(--line);padding:6px 12px;border-radius:2px;color:var(--ink-3)}
.section--ink .inline-list li{background:var(--ink-2);border-color:#33373e;color:#cfd2d8}
@media (prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto!important;transition:none!important}}
