/* ==========================================================================
   BAU INSPEKTA GmbH — Design System 2026 «Swiss Trust»
   Rot = Handlung/Marke · Grün = Sicherheit/Zertifizierung · Weiss = Ruhe
   Fonts: Archivo (Display) · Instrument Sans (Body) · Roboto (Label)
   ========================================================================== */

/* ---------- Fonts (lokal, variabel) ---------- */
@font-face { font-family:'Archivo'; src:url('../fonts/archivo-var.woff2') format('woff2'); font-weight:100 900; font-display:swap; }
@font-face { font-family:'Instrument Sans'; src:url('../fonts/instrument-sans-var.woff2') format('woff2'); font-weight:400 700; font-display:swap; }
@font-face { font-family:'Roboto'; src:url('../fonts/roboto-var.woff2') format('woff2'); font-weight:400 600; font-display:swap; }

/* ---------- Tokens ---------- */
:root{
  --ink:#1A1A1A;
  --ink-soft:#2B2E31;
  --anthracite:#1C1E1F;
  --white:#FFFFFF;
  --soft:#F7F6F4;
  --soft-2:#F1F0ED;
  --line:rgba(26,26,26,.10);
  --line-strong:rgba(26,26,26,.16);

  --brand:#C8102E;      /* Rot — CTAs, Labels, Links */
  --brand-deep:#A50D26; /* Hover */
  --brand-tint:#FBEAEC;

  --trust:#3E8E5A;      /* Grün — Zertifikate, Sicherheits-Icons */
  --trust-deep:#2F7448;
  --trust-soft:#E9F3EC; /* mint Icon-Kreis */

  --mute:#5A6066;
  --faint:#8B9096;

  --font-display:'Archivo','Helvetica Neue',Arial,sans-serif;
  --font-body:'Instrument Sans','Helvetica Neue',Arial,sans-serif;
  --font-label:'Roboto','Helvetica Neue',Arial,sans-serif;

  --container:1200px;
  --gutter:clamp(1.15rem,4vw,2.5rem);
  --header-h:80px;
  --radius:16px;
  --radius-sm:12px;
  --shadow-sm:0 1px 2px rgba(26,26,26,.05);
  --shadow-card:0 4px 24px rgba(26,26,26,.07);
  --shadow-float:0 18px 50px rgba(26,26,26,.13);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{color-scheme:light;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
html,body{overflow-x:clip;}
body{
  font-family:var(--font-body);
  font-size:1.04rem;
  line-height:1.72;
  color:var(--ink-soft);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
}
img,video{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
p{color:var(--mute);}
p+p{margin-top:.85em;}
::selection{background:var(--brand);color:#fff;}

h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.1;letter-spacing:-.02em;font-weight:680;text-wrap:balance;}
h1{font-size:clamp(2.3rem,5.2vw,3.7rem);}
h2{font-size:clamp(1.85rem,3.6vw,2.7rem);}
h3{font-size:1.28rem;letter-spacing:-.01em;}

.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter);}
.section{padding-block:clamp(3.5rem,7vw,6rem);}
.section-soft{background:var(--soft);}
.section-tight{padding-block:clamp(2.5rem,5vw,4rem);}

.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1.2rem;z-index:1001;}
.skip-link:focus{left:0;}

/* ---------- Label ---------- */
.label{
  display:inline-block;font-family:var(--font-label);
  font-size:.74rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  color:var(--brand);margin-bottom:1rem;
}
.label.green{color:var(--trust);}
.label.light{color:rgba(255,255,255,.7);}

.lead{font-size:1.16rem;color:var(--mute);max-width:60ch;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-body);font-size:.98rem;font-weight:600;letter-spacing:.005em;
  padding:.92rem 1.7rem;border-radius:10px;border:1.5px solid transparent;
  cursor:pointer;transition:background .22s,color .22s,border-color .22s,transform .22s;
}
.btn svg{flex:none;}
.btn-primary{background:var(--brand);color:#fff;}
.btn-primary:hover{background:var(--brand-deep);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:#000;}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--line-strong);}
.btn-outline:hover{border-color:var(--ink);background:var(--soft);color:var(--ink);}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);}
.btn-ghost:hover{background:rgba(255,255,255,.16);}
.btn-sm{padding:.62rem 1.15rem;font-size:.9rem;border-radius:9px;}
.btn-block{width:100%;}
.btn .arr{transition:transform .22s;}
.btn:hover .arr{transform:translateX(3px);}

/* Text-Link mit Pfeil */
.tlink{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.95rem;color:var(--brand);}
.tlink svg{transition:transform .22s;}
.tlink:hover svg{transform:translate(2px,-2px);}
.tlink.dark{color:var(--ink);}

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line);}
.header-inner{display:flex;align-items:center;gap:.8rem;height:var(--header-h);}
.brand{flex:none;display:flex;align-items:center;}
.brand-logo{height:30px;width:auto;}
.mainnav{margin-left:.25rem;}
.nav-list{display:flex;align-items:center;gap:.15rem;list-style:none;}
.nav-list>li>a,.drop-toggle{
  display:inline-flex;align-items:center;gap:.3rem;white-space:nowrap;
  font-size:.9rem;font-weight:550;color:var(--ink-soft);
  padding:.45rem .5rem;border-radius:8px;background:none;border:0;cursor:pointer;font-family:inherit;
  transition:color .18s,background .18s;
}
.nav-list>li>a:hover,.drop-toggle:hover{color:var(--brand);background:var(--soft);}
.nav-list a[aria-current="page"]{color:var(--brand);}
.chev{transition:transform .2s;}
.has-drop{position:static;}
.mega{
  position:absolute;top:var(--header-h);left:50%;transform:translateX(-50%) translateY(8px);
  width:min(720px,94vw);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-float);
  padding:1.1rem;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:60;
}
.has-drop:hover .mega,.has-drop:focus-within .mega,.has-drop.open .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.has-drop:hover .chev,.has-drop.open .chev{transform:rotate(180deg);}
/* Unsichtbare Brücke: überbrückt die Lücke zwischen Button und Panel */
.mega::before{content:"";position:absolute;left:0;right:0;top:-14px;height:14px;}
.mega-head{display:flex;justify-content:space-between;align-items:baseline;padding:0 .3rem .8rem;margin-bottom:.5rem;border-bottom:1px solid var(--line);}
.mega-head .label{margin:0;}
.mega-head a{font-size:.85rem;font-weight:600;color:var(--brand);}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:.2rem;}
.mega-item{display:flex;gap:.85rem;align-items:flex-start;padding:.75rem .8rem;transition:background .15s;}
.mega-item:hover{background:var(--soft);}
.mega-ic{display:grid;place-items:center;width:40px;height:40px;background:var(--trust-soft);color:var(--trust);flex:none;}
.mega-ic svg{display:block;}
.mega-tx{display:flex;flex-direction:column;gap:.1rem;}
.mega-tx strong{font-size:.92rem;font-weight:650;color:var(--ink);}
.mega-tx em{font-style:normal;font-size:.79rem;color:var(--mute);line-height:1.4;}
.header-cta{margin-left:auto;display:flex;align-items:center;gap:.9rem;flex:none;}
.header-phone{display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap;font-weight:650;font-size:.94rem;color:var(--ink);}
.header-phone span{white-space:nowrap;}
.header-phone:hover{color:var(--brand);}
.header-phone svg{color:var(--brand);}
.nav-burger{display:none;margin-left:auto;background:none;border:0;color:var(--ink);cursor:pointer;padding:.3rem;}

/* Mobile Nav */
.mobile-nav{position:fixed;inset:var(--header-h) 0 0 0;background:#fff;z-index:55;padding:1.5rem var(--gutter) 2rem;transform:translateX(100%);transition:transform .3s ease;overflow-y:auto;visibility:hidden;}
.mobile-nav.open{transform:translateX(0);visibility:visible;}
.mobile-nav ul{list-style:none;display:flex;flex-direction:column;}
.mobile-nav li a{display:block;padding:1rem .2rem;font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line);}
.mobile-nav-cta{display:flex;flex-direction:column;gap:.7rem;margin-top:1.5rem;}
.mobile-nav .btn-ghost{background:var(--soft);color:var(--ink);border-color:var(--line-strong);}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{position:relative;background:var(--ink);}
.hero-media{position:absolute;inset:0;overflow:hidden;}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center;}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(18,18,20,.86) 0%,rgba(18,18,20,.66) 42%,rgba(18,18,20,.28) 100%);}
.hero-inner{position:relative;padding-top:clamp(3.5rem,7vw,6rem);padding-bottom:clamp(6rem,9vw,8.5rem);}
.hero-copy{max-width:640px;}
.hero .label{color:#fff;opacity:.85;}
.hero h1{color:#fff;margin-bottom:1.1rem;}
.hero-sub{color:rgba(255,255,255,.86);font-size:1.18rem;max-width:48ch;margin-bottom:1.9rem;}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;}
.hero .btn-outline{color:#fff;border-color:rgba(255,255,255,.45);}
.hero .btn-outline:hover{background:#fff;color:var(--ink);border-color:#fff;}

/* Schwebende Trust-Leiste */
.hero-trust{position:relative;margin-top:-3.6rem;z-index:5;}
.hero-trust-card{
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-float);
  display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:1.3rem 1.8rem;
}
.hero-trust-item{display:flex;align-items:center;gap:.8rem;font-weight:600;color:var(--ink);font-size:1rem;min-height:46px;}
.hero-trust-item .ic{display:grid;place-items:center;width:42px;height:42px;background:var(--trust-soft);color:var(--trust);flex:none;}
.hero-trust-item .ic svg{display:block;}
.hero-trust-item+.hero-trust-item{border-left:1px solid var(--line);padding-left:1.4rem;}
.hero-trust-item.ht-suva{flex-direction:column;align-items:flex-start;justify-content:center;gap:.35rem;}
.ht-eyebrow{font-family:var(--font-label);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);font-weight:600;}
.ht-suva-logo{height:23px;width:auto;filter:grayscale(1);opacity:.92;display:block;}

/* ==========================================================================
   Sektions-Kopf
   ========================================================================== */
.sec-head{margin-bottom:2.6rem;}
.sec-head.split{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:end;}
.sec-head.split .sh-lead{color:var(--mute);font-size:1.08rem;padding-bottom:.3rem;}
.sec-head .row-link{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;}

/* ==========================================================================
   Vorgehen-Cards (3er)
   ========================================================================== */
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;}
.approach-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem 1.7rem;box-shadow:var(--shadow-sm);transition:box-shadow .25s,transform .25s,border-color .25s;}
.approach-card:hover{box-shadow:var(--shadow-card);transform:translateY(-3px);border-color:var(--line-strong);}
.approach-ic{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:var(--trust-soft);color:var(--trust);margin-bottom:1.3rem;}
.approach-card h3{margin-bottom:.6rem;}
.approach-card p{font-size:.99rem;margin-bottom:1.1rem;}

/* ==========================================================================
   Leistungs-Cards (6er)
   ========================================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.svc-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:box-shadow .25s,transform .25s;}
.svc-card:hover{box-shadow:var(--shadow-card);transform:translateY(-4px);}
.svc-media{position:relative;}
.svc-media-img{aspect-ratio:16/10;overflow:hidden;}
.svc-media-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.svc-card:hover .svc-media-img img{transform:scale(1.05);}
.svc-badge{position:absolute;left:1.1rem;bottom:-26px;width:52px;height:52px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--brand);box-shadow:var(--shadow-card);z-index:2;}
.svc-body{padding:2rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1;}
.svc-body h3{margin-bottom:.5rem;}
.svc-body p{font-size:.97rem;margin-bottom:1.2rem;flex:1;}

/* ==========================================================================
   Über uns / Prozess (Split)
   ========================================================================== */
.about-split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;}
.about-media{position:relative;min-height:420px;}
.about-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;}
.about-panel{background:var(--soft);padding:clamp(2.2rem,4vw,3.6rem);}
.about-panel h2{margin-bottom:1rem;}
.about-panel>p{margin-bottom:2rem;max-width:46ch;}

.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;position:relative;}
.pstep{text-align:left;}
.pstep-top{display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem;}
.pstep-ic{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:#fff;color:var(--trust);border:1px solid var(--line);flex:none;}
.pstep-num{font-family:var(--font-display);font-weight:700;color:var(--faint);font-size:.85rem;letter-spacing:.05em;}
.pstep h4{font-family:var(--font-display);font-size:1rem;color:var(--ink);margin-bottom:.35rem;}
.pstep p{font-size:.9rem;line-height:1.55;}

/* ==========================================================================
   Referenzen + Kontakt-Card
   ========================================================================== */
.ref-block{display:grid;grid-template-columns:1.4fr .9fr;gap:2.5rem;align-items:start;}
.ref-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;}
.ref-gallery img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px;border:1px solid var(--line);}
.ref-intro{margin-bottom:1.4rem;}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:2rem 1.8rem;}
.contact-card h3{font-size:1.35rem;margin-bottom:.7rem;line-height:1.2;}
.contact-card p{font-size:.98rem;margin-bottom:1.4rem;}
.contact-card .btn{width:100%;margin-bottom:1rem;}
.contact-phone{display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:650;color:var(--ink);}
.contact-phone svg{color:var(--brand);}

/* ==========================================================================
   Trust-Band (dunkel, vor Footer)
   ========================================================================== */
.trust-band{background:var(--soft);color:var(--ink);padding-block:2.1rem;border-top:1px solid var(--line);}
.trust-band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;}
.trust-col{display:flex;align-items:center;gap:.9rem;}
.trust-ic{display:grid;place-items:center;width:46px;height:46px;background:#fff;border:1px solid var(--line);color:var(--trust);flex:none;}
.trust-ic svg{display:block;}
.trust-col>div strong{display:block;font-family:var(--font-display);font-size:1rem;font-weight:650;color:var(--ink);}
.trust-col>div span{display:block;font-size:.85rem;color:var(--mute);}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{background:var(--soft);color:var(--mute);border-top:1px solid var(--line);padding-top:clamp(3rem,5vw,4.5rem);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:2.5rem;padding-bottom:3rem;}
.footer-logo{height:34px;width:auto;margin-bottom:1.1rem;}
.footer-brand p{color:var(--mute);font-size:.95rem;max-width:34ch;}
.footer-col h4{font-family:var(--font-display);color:var(--ink);font-size:.95rem;letter-spacing:.02em;margin-bottom:1.1rem;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;}
.footer-col a{color:var(--mute);font-size:.94rem;}
.footer-col a:hover{color:var(--brand);}
.footer-contact li{display:flex;align-items:flex-start;gap:.6rem;font-size:.94rem;color:var(--mute);}
.footer-contact .fi{color:var(--brand);flex:none;margin-top:2px;}
.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-block:1.4rem;font-size:.85rem;color:var(--faint);}

/* ==========================================================================
   Sticky Mobile-CTA
   ========================================================================== */
.mobile-cta-bar{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;grid-template-columns:1fr 1.3fr;gap:.6rem;padding:.6rem;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-top:1px solid var(--line);}
.mcb{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.85rem;border-radius:10px;font-weight:650;font-size:.95rem;}
.mcb-call{background:var(--soft);color:var(--ink);}
.mcb-call svg{color:var(--brand);}
.mcb-ask{background:var(--brand);color:#fff;}

/* ==========================================================================
   Reveal-Animation
   ========================================================================== */
/* Ausfallsicher: ohne JS voll sichtbar, Animation nur mit .js */
.reveal{transition:opacity .7s ease,transform .7s ease;}
.js .reveal{opacity:0;transform:translateY(22px);}
.js .reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .js .reveal,.reveal{opacity:1!important;transform:none!important;transition:none!important;}
  *{scroll-behavior:auto!important;}
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:1200px){
  .mainnav,.header-phone{display:none;}
  .nav-burger{display:block;}
  .header-cta{margin-left:auto;}
  .header-cta .btn{display:none;}
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem;}
  .footer-brand{grid-column:1/-1;}
}
@media (max-width:820px){
  .hero-trust-card{grid-template-columns:repeat(2,1fr);gap:1rem 1.2rem;}
  .hero-trust-item+.hero-trust-item{border-left:0;padding-left:0;}
  .sec-head.split{grid-template-columns:1fr;gap:.8rem;}
  .approach-grid{grid-template-columns:1fr;}
  .about-split{grid-template-columns:1fr;}
  .about-media{min-height:300px;}
  .process-steps{grid-template-columns:1fr 1fr;gap:1.6rem;}
  .ref-block{grid-template-columns:1fr;gap:1.8rem;}
  .trust-band-grid{grid-template-columns:1fr 1fr;gap:1.3rem;}
  .mobile-cta-bar{display:grid;}
  body{padding-bottom:64px;}
}
@media (max-width:560px){
  .svc-grid{grid-template-columns:1fr;}
  .ref-gallery{grid-template-columns:repeat(2,1fr);}
  .hero-trust-card{grid-template-columns:1fr;}
  .process-steps{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .hero-actions .btn{flex:1;}
}

/* ==========================================================================
   Unterseiten — Page-Head, Feature, Details, Kosten, FAQ, Konfigurator …
   ========================================================================== */
.page-head{padding-top:clamp(2.4rem,5vw,3.8rem);padding-bottom:clamp(1.2rem,2.5vw,1.8rem);}
.page-head .lead{margin-top:1rem;}
.page-head-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem;}
.page-strip{margin-top:.6rem;}
.page-strip img{width:100%;height:clamp(230px,36vw,440px);object-fit:cover;}

.mini-trust{display:flex;flex-wrap:wrap;gap:1.4rem;padding:1.05rem 0;margin-top:1.4rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.mini-trust span{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;color:var(--ink);}
.mini-trust svg{color:var(--trust);flex:none;}

.feature-block{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;}
.feature-media img{width:100%;border-radius:var(--radius);border:1px solid var(--line);}
.feature-panel h2{margin-bottom:1rem;}
.checklist{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin:1.4rem 0 1.8rem;}
.checklist li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-soft);}
.checklist svg{color:var(--trust);flex:none;margin-top:3px;}
.checklist strong{font-weight:650;color:var(--ink);}

.detail-list{display:grid;grid-template-columns:1fr 1fr;gap:1.7rem 3rem;}
.detail-item{display:flex;gap:1.1rem;}
.detail-item .num{font-family:var(--font-display);font-weight:700;color:var(--brand);font-size:1rem;padding-top:.15rem;flex:none;}
.detail-item h3{font-size:1.12rem;margin-bottom:.35rem;}
.detail-item p{font-size:.97rem;}

.cost-block{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.6rem);}
.cost-intro h2{margin-bottom:.9rem;}
.cost-factors{list-style:none;display:flex;flex-direction:column;gap:.85rem;padding-top:.3rem;}
.cost-factors li{display:flex;gap:.7rem;align-items:flex-start;font-weight:550;color:var(--ink-soft);}
.cost-factors svg{color:var(--trust);flex:none;margin-top:2px;}

.faq-list{display:flex;flex-direction:column;gap:.7rem;max-width:840px;}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.15rem 1.4rem;font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:1.05rem;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-plus{color:var(--brand);transition:transform .25s;flex:none;}
.faq-item[open] .faq-plus{transform:rotate(180deg);}
.faq-a{padding:0 1.4rem 1.3rem;}
.faq-a p{margin:0;}

/* Konfigurator */
.cfg-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:clamp(1.5rem,3vw,2.6rem);max-width:840px;}
.cfg-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;}
.cfg-progress{display:none;height:6px;background:var(--soft-2);border-radius:99px;overflow:hidden;}
.cfg-bar{display:block;height:100%;width:33%;background:var(--brand);border-radius:99px;transition:width .35s ease;}
.cfg-steplabel{display:none;font-family:var(--font-label);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin:.7rem 0 1.6rem;}
.js .cfg-progress{display:block;}
.js .cfg-steplabel{display:block;}
.cfg-step{border:0;padding:0;min-width:0;}
.js .cfg-step{display:none;}
.js .cfg-step.is-active{display:block;animation:cfgIn .35s ease;}
@keyframes cfgIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.cfg-step + .cfg-step{margin-top:1.6rem;}
.js .cfg-step + .cfg-step{margin-top:0;}
.cfg-q{font-family:var(--font-display);font-weight:650;color:var(--ink);font-size:1.28rem;margin-bottom:1.2rem;letter-spacing:-.01em;}
.cfg-options{display:grid;gap:.7rem;}
.cfg-options.cols-1{grid-template-columns:1fr;}
.cfg-options.cols-2{grid-template-columns:1fr 1fr;}
.cfg-options.cols-3{grid-template-columns:repeat(3,1fr);}
.cfg-option{position:relative;cursor:pointer;}
.cfg-option>input{position:absolute;opacity:0;inset:0;width:100%;height:100%;cursor:pointer;margin:0;}
.cfg-option-in{display:flex;align-items:center;gap:.8rem;padding:1rem 1.1rem;border:1.5px solid var(--line-strong);border-radius:12px;transition:border-color .18s,background .18s;height:100%;}
.cfg-option:hover .cfg-option-in{border-color:var(--ink);}
.cfg-check{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--line-strong);color:#fff;flex:none;transition:.18s;}
.cfg-check svg{opacity:0;transition:.18s;}
.cfg-option>input:checked ~ .cfg-option-in{border-color:var(--trust);background:var(--trust-soft);}
.cfg-option>input:checked ~ .cfg-option-in .cfg-check{background:var(--trust);border-color:var(--trust);}
.cfg-option>input:checked ~ .cfg-option-in .cfg-check svg{opacity:1;}
.cfg-option>input:focus-visible ~ .cfg-option-in{outline:2px solid var(--ink);outline-offset:2px;}
.cfg-option-t{display:flex;flex-direction:column;}
.cfg-option-t strong{font-weight:600;color:var(--ink);}
.cfg-option-t em{font-style:normal;font-size:.85rem;color:var(--mute);}
.cfg-fields{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.field{display:flex;flex-direction:column;gap:.35rem;}
.field-full{grid-column:1/-1;}
.field label{font-size:.85rem;font-weight:600;color:var(--ink);}
.field input,.field textarea{font-family:inherit;font-size:1rem;padding:.8rem .9rem;border:1.5px solid var(--line-strong);border-radius:10px;background:#fff;color:var(--ink);transition:border-color .18s;width:100%;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink);}
.cfg-consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.88rem;color:var(--mute);cursor:pointer;}
.cfg-consent input{margin-top:3px;accent-color:var(--brand);flex:none;}
.cfg-consent a{color:var(--brand);text-decoration:underline;}
.cfg-error{color:var(--brand);font-size:.9rem;font-weight:600;margin-top:1rem;}
.cfg-actions{margin-top:1.4rem;}
.cfg-actions-final{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;}
.cfg-back{background:none;border:0;font-family:inherit;font-size:.92rem;font-weight:600;color:var(--mute);cursor:pointer;padding:.5rem 0;}
.cfg-back:hover{color:var(--ink);}
.cfg-reassure{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--mute);margin-top:1.1rem;}
.cfg-reassure svg{color:var(--trust);flex:none;}

/* Kontakt */
.kontakt-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:2.5rem;align-items:start;}
.kontakt-card{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;margin-bottom:1.2rem;}
.kontakt-card h2{font-size:1.35rem;margin-bottom:1.2rem;}
.kontakt-list{list-style:none;display:flex;flex-direction:column;gap:1rem;}
.kontakt-list li{display:flex;gap:.8rem;align-items:center;font-weight:550;color:var(--ink);}
.ki-ic{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;background:#fff;color:var(--brand);border:1px solid var(--line);flex:none;}
.kontakt-trust{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid var(--line);}
.kontakt-trust span{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;color:var(--ink);}
.kontakt-trust svg{color:var(--trust);}
.kontakt-map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);height:280px;}
.kontakt-map iframe{width:100%;height:100%;border:0;display:block;}
.kontakt-form .cfg-wrap{max-width:none;}

/* Referenzen */
.ref-grid-lg{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.ref-grid-lg img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px;border:1px solid var(--line);}
.partner-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.partner-card{display:flex;gap:.9rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.2rem;}
.partner-ic{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;background:var(--trust-soft);color:var(--trust);flex:none;}
.partner-card strong{display:block;font-weight:650;color:var(--ink);font-size:.98rem;line-height:1.3;}
.partner-card span{display:block;font-size:.82rem;color:var(--mute);}

/* Über uns */
.about-stats{display:flex;gap:2.2rem;margin-top:2rem;flex-wrap:wrap;}
.stat-num{font-family:var(--font-display);font-weight:700;font-size:2rem;color:var(--ink);letter-spacing:-.02em;line-height:1;}
.stat-label{font-size:.85rem;color:var(--mute);margin-top:.3rem;}
.cred-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;}
.cred-card{display:flex;align-items:center;gap:1.6rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.8rem;}
.cred-logo{display:grid;place-items:center;width:150px;flex:none;padding-right:1.5rem;border-right:1px solid var(--line);}
.cred-logo img{width:auto;max-height:46px;filter:grayscale(1);opacity:.85;}
.cred-card strong{display:block;font-family:var(--font-display);font-size:1.1rem;color:var(--ink);margin-bottom:.25rem;}
.cred-card p{margin:0;font-size:.95rem;}
@media (max-width:640px){.cred-grid{grid-template-columns:1fr;}.cred-card{flex-direction:column;text-align:center;gap:1rem;}.cred-logo{border-right:0;border-bottom:1px solid var(--line);padding:0 0 1rem;width:100%;}}

/* CTA-Box */
.cta-box{display:flex;justify-content:space-between;align-items:center;gap:2rem;background:var(--white);color:var(--ink);border:1px solid var(--line);border-left:3px solid var(--brand);padding:clamp(1.8rem,4vw,3rem);flex-wrap:wrap;}
.cta-box h2{color:var(--ink);margin-bottom:.5rem;}
.cta-box p{color:var(--mute);margin:0;max-width:46ch;}
.cta-side{display:flex;flex-direction:column;gap:.8rem;}
.cta-box .cta-phone{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;color:var(--ink);font-weight:600;}
.cta-box .cta-phone svg{color:var(--brand);}

/* Legal + Danke */
.legal{max-width:760px;}
.legal h2{font-size:1.25rem;margin:2rem 0 .7rem;color:var(--ink);}
.legal h2:first-child{margin-top:0;}
.legal a{color:var(--brand);text-decoration:underline;}
.danke-ic{display:inline-grid;place-items:center;width:84px;height:84px;border-radius:50%;background:var(--trust-soft);color:var(--trust);}
.page-plain .page-head{display:none;}

/* Responsive Unterseiten */
@media (max-width:880px){
  .feature-block{grid-template-columns:1fr;}
  .detail-list{grid-template-columns:1fr;}
  .cost-block{grid-template-columns:1fr;}
  .kontakt-grid{grid-template-columns:1fr;}
  .ref-grid-lg{grid-template-columns:1fr 1fr;}
  .partner-grid{grid-template-columns:1fr 1fr;}
  .cfg-fields{grid-template-columns:1fr;}
  .cta-box{flex-direction:column;align-items:flex-start;}
  .cta-side{width:100%;}
  .cta-side .btn{width:100%;}
}
@media (max-width:560px){
  .cfg-options.cols-2,.cfg-options.cols-3{grid-template-columns:1fr;}
  .ref-grid-lg,.partner-grid{grid-template-columns:1fr;}
  .page-head-cta .btn{flex:1;}
}

/* ==========================================================================
   Partner-Logo-Wall (echte Logos, feine Linien)
   ========================================================================== */
.logo-wall{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line);}
.logo-cell{display:grid;place-items:center;padding:2.4rem 1.5rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:130px;background:#fff;}
.logo-cell img{max-height:54px;max-width:170px;width:auto;filter:grayscale(1);opacity:.62;transition:opacity .2s,filter .2s;}
.logo-cell:hover img{filter:grayscale(0);opacity:1;}
.partner-more{margin-top:1.6rem;color:var(--mute);font-size:.95rem;}
.partner-more strong{color:var(--ink);font-weight:650;}
@media (max-width:600px){.logo-wall{grid-template-columns:repeat(2,1fr);}.logo-cell{padding:1.7rem 1rem;min-height:104px;}}

/* ==========================================================================
   Icon-Zentrierung (SVG als Block in allen Icon-Flächen)
   ========================================================================== */
.approach-ic svg,.pstep-ic svg,.svc-badge svg,.ki-ic svg,.partner-ic svg,
.danke-ic svg,.mega-ic svg,.mini-trust svg,.cost-factors svg,.checklist svg,
.cfg-check svg,.trust-col svg,.kontakt-trust svg,.cfg-reassure svg{display:block;}

/* ==========================================================================
   Design-Gesetz: keine abgerundeten Ecken — überall scharfe Kanten
   ========================================================================== */
*,*::before,*::after{border-radius:0 !important;}
