/* ============================================================================
   Systemhaus.IT — Stylesheet
   Konzept „Signal & Schaltplan": Anthrazit + Signalbernstein, Leiterbahn-Motiv.
   Farben kommen aus CSS-Variablen (generiert aus config.php).
   ============================================================================ */

/* ── Reset & Basis ──────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}

body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);background:var(--paper);
  line-height:1.65;font-size:1.0625rem;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.wrap{width:min(1180px,100% - 3rem);margin-inline:auto}
.mono{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums}

/* ── Typografie ─────────────────────────────────────────────────────────── */
h1,h2,h3{font-family:'Space Grotesk',sans-serif;line-height:1.1;font-weight:600;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,5.5vw,3.7rem);font-weight:700}
h2{font-size:clamp(1.7rem,3.8vw,2.6rem)}
h3{font-size:1.25rem}
p{max-width:64ch}

.eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:.78rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--signal);
  display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:1.6rem;height:2px;background:var(--signal)}

/* ── Accessibility ──────────────────────────────────────────────────────── */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.8rem 1.2rem;z-index:200}
.skip:focus{left:1rem;top:1rem}
:focus-visible{outline:3px solid var(--signal);outline-offset:3px;border-radius:2px}

/* ── Buttons ────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1rem;
  padding:.85rem 1.5rem;border-radius:10px;border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s;
  text-align:center;
}
.btn--signal{background:var(--signal);color:#fff;box-shadow:0 6px 0 -2px rgba(255,107,53,.35)}
.btn--signal:hover{transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(255,107,53,.6)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}
.btn--light{background:var(--paper);color:var(--ink)}
.btn--light:hover{transform:translateY(-2px)}
.btn--lg{padding:1.05rem 1.9rem;font-size:1.1rem}

/* ── Topbar ─────────────────────────────────────────────────────────────── */
.topbar{background:var(--ink);color:var(--paper-soft);font-size:.85rem}
.topbar__in{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 0;flex-wrap:wrap}
.topbar__claim{opacity:.75;font-size:.8rem}
.topbar__sos{font-family:'JetBrains Mono',monospace;font-weight:600;letter-spacing:.01em}
.topbar__sos a{color:var(--signal-lo)}
.topbar__sos a:hover{color:var(--signal);text-decoration:underline}

/* ── Header ─────────────────────────────────────────────────────────────── */
.site-head{position:sticky;top:0;z-index:100;background:rgba(247,245,241,.85);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-head__in{display:flex;align-items:center;gap:1.5rem;padding:.85rem 0}
.brand{display:flex;align-items:center;gap:.65rem;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.3rem}
.brand__word{letter-spacing:-.02em}
.brand__dot{color:var(--signal)}
.brand__mark{width:30px;height:30px;border-radius:7px;background:var(--ink);position:relative;flex:none}
.brand__mark::before{content:"";position:absolute;inset:7px;border:2px solid var(--signal);border-radius:3px}
.brand__mark::after{content:"";position:absolute;left:13px;top:-4px;width:2px;height:10px;background:var(--signal)}

.nav{margin-left:auto}
.nav__list{display:flex;gap:.3rem}
.nav__list a{
  display:block;padding:.55rem .85rem;border-radius:8px;font-size:.97rem;font-weight:500;
  position:relative;transition:background .15s,color .15s;
}
.nav__list a:hover{background:var(--paper-soft)}
.nav__list a[aria-current="page"]{color:var(--signal)}
.nav__list a[aria-current="page"]::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.3rem;height:2px;background:var(--signal)}
.nav__toggle{display:none}
.head-cta{flex:none}

/* ── Mobile-Navigation ──────────────────────────────────────────────────── */
@media (max-width:920px){
  .head-cta{display:none}
  .nav__toggle{
    display:flex;flex-direction:column;justify-content:center;gap:5px;
    width:46px;height:46px;background:var(--ink);border:0;border-radius:9px;cursor:pointer;
  }
  .nav__toggle span:not(.visually-hidden){display:block;width:20px;height:2px;background:var(--paper);margin-inline:auto;transition:.25s}
  .nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav__list{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    max-height:0;overflow:hidden;transition:max-height .3s ease;
    box-shadow:0 20px 30px -20px rgba(0,0,0,.25);
  }
  .nav__list.open{max-height:30rem}
  .nav__list li{border-top:1px solid var(--line)}
  .nav__list a{padding:1rem 1.5rem;border-radius:0}
  .nav__list a[aria-current="page"]::after{display:none}
}

/* ── Hero ───────────────────────────────────────────────────────────────── */
.hero{position:relative;background:var(--ink);color:var(--paper);overflow:hidden}
.hero__pcb{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none}
.hero__in{position:relative;padding:clamp(3.5rem,8vw,6.5rem) 0 clamp(3rem,6vw,5rem);z-index:2}
.hero h1{max-width:18ch;margin:1.2rem 0 1.3rem}
.hero__lead{font-size:clamp(1.1rem,2vw,1.35rem);color:#cdd2dc;max-width:54ch;margin-bottom:2rem}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.6rem}
.hero__phones{display:flex;gap:2rem;flex-wrap:wrap;border-top:1px solid #313845;padding-top:1.6rem}
.hero__phone-label{font-size:.8rem;color:#8b93a3;letter-spacing:.05em;text-transform:uppercase}
.hero__phone-num{font-family:'JetBrains Mono',monospace;font-size:1.25rem;font-weight:600;color:#fff;margin-top:.2rem;display:block}
.hero__phone-num:hover{color:var(--signal-lo)}

/* PCB Leiterbahn-Animation (Signatur) */
.pcb-trace{fill:none;stroke:var(--trace);stroke-width:1.5}
.pcb-pulse{fill:none;stroke:var(--signal);stroke-width:2;
  stroke-dasharray:14 220;stroke-dashoffset:0;animation:pulse 5s linear infinite}
.pcb-node{fill:var(--trace)}
.pcb-node--live{fill:var(--signal)}
@keyframes pulse{to{stroke-dashoffset:-234}}
@media (prefers-reduced-motion:reduce){.pcb-pulse{animation:none;opacity:.6}}

/* ── Sektionen ──────────────────────────────────────────────────────────── */
.section{padding:clamp(3.5rem,7vw,6rem) 0}
.section--soft{background:var(--paper-soft)}
.section--ink{background:var(--ink);color:var(--paper)}
.section__head{max-width:62ch;margin-bottom:2.8rem}
.section__head h2{margin:.9rem 0 .8rem}
.section__head p{color:var(--muted)}
.section--ink .section__head p{color:#aab1bf}

/* ── Leistungs-Karten ───────────────────────────────────────────────────── */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.4rem}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:1.8rem;position:relative;transition:transform .2s ease,border-color .2s,box-shadow .25s;
  overflow:hidden;
}
.card::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--signal),var(--signal-lo));transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.card:hover{transform:translateY(-4px);border-color:var(--signal);box-shadow:0 24px 40px -24px rgba(21,24,29,.4)}
.card:hover::before{transform:scaleX(1)}
.card__icon{width:50px;height:50px;border-radius:12px;background:var(--ink);color:var(--signal);
  display:grid;place-items:center;margin-bottom:1.1rem}
.card__icon svg{width:26px;height:26px}
.card h3{margin-bottom:.3rem}
.card__lead{font-weight:600;color:var(--ink);margin-bottom:.6rem;font-size:1rem}
.card p{color:var(--muted);font-size:.97rem}
.card__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.1rem}
.tag{font-family:'JetBrains Mono',monospace;font-size:.72rem;font-weight:500;
  background:var(--paper-soft);color:var(--ink);padding:.25rem .6rem;border-radius:5px;border:1px solid var(--line)}

/* ── Process / Schritte ─────────────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;counter-reset:step}
.step{position:relative;padding-top:2.2rem}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);
  font-family:'JetBrains Mono',monospace;font-size:.85rem;font-weight:600;color:var(--signal);
  position:absolute;top:0;left:0}
.step::after{content:"";position:absolute;top:.4rem;left:2.6rem;right:0;height:1px;background:var(--line)}
.step h3{margin-bottom:.5rem}
.step p{color:var(--muted);font-size:.97rem}

/* ── Pakete ─────────────────────────────────────────────────────────────── */
.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;align-items:start}
.plan{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:2rem;position:relative}
.plan--hot{border-color:var(--signal);box-shadow:0 30px 50px -30px rgba(255,107,53,.5)}
.plan__badge{position:absolute;top:-13px;left:2rem;background:var(--signal);color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;font-weight:600;letter-spacing:.08em;
  padding:.3rem .8rem;border-radius:6px;text-transform:uppercase}
.plan h3{font-size:1.4rem}
.plan__lead{color:var(--muted);font-size:.95rem;margin:.3rem 0 1.2rem}
.plan__price{font-family:'Space Grotesk',sans-serif;font-size:2.6rem;font-weight:700;line-height:1}
.plan__price span{font-size:1rem;font-weight:500;color:var(--muted)}
.plan__period{font-size:.85rem;color:var(--muted);margin-top:.2rem}
.plan ul{margin:1.5rem 0;display:grid;gap:.7rem}
.plan li{position:relative;padding-left:1.7rem;font-size:.96rem}
.plan li::before{content:"";position:absolute;left:0;top:.45rem;width:14px;height:8px;
  border-left:2px solid var(--signal);border-bottom:2px solid var(--signal);transform:rotate(-45deg)}
.plan .btn{width:100%;justify-content:center}

/* ── Standorte ──────────────────────────────────────────────────────────── */
.locs{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.loc{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.loc__map{aspect-ratio:16/9;background:var(--ink);position:relative}
.loc__map iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05)}
.loc__body{padding:1.6rem}
.loc__body h3{font-size:1.3rem;margin-bottom:.2rem}
.loc__region{color:var(--signal);font-size:.85rem;font-family:'JetBrains Mono',monospace;margin-bottom:1rem}
.loc address{font-style:normal;line-height:1.9}
.loc__phone{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:1.15rem;color:var(--ink)}
.loc__phone:hover{color:var(--signal)}
.loc__hours{color:var(--muted);font-size:.9rem;margin-top:.8rem;border-top:1px solid var(--line);padding-top:.8rem}

/* ── Areas / Tags-Wolke ─────────────────────────────────────────────────── */
.areas{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem}
.area h3{font-size:1.05rem;color:var(--signal);margin-bottom:.8rem;font-family:'JetBrains Mono',monospace;letter-spacing:.02em}
.area__list{display:flex;flex-wrap:wrap;gap:.5rem}
.area__list span{background:var(--paper);border:1px solid var(--line);border-radius:6px;
  padding:.3rem .7rem;font-size:.88rem;color:var(--ink)}

/* ── FAQ (Accordion) ────────────────────────────────────────────────────── */
.faq{max-width:780px;margin-inline:auto;display:grid;gap:.8rem}
.faq__item{background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.faq__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:1.2rem 1.4rem;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.08rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--ink)}
.faq__q::after{content:"";flex:none;width:12px;height:12px;border-right:2px solid var(--signal);
  border-bottom:2px solid var(--signal);transform:rotate(45deg);transition:transform .25s}
.faq__item.open .faq__q::after{transform:rotate(-135deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq__a p{padding:0 1.4rem 1.3rem;color:var(--muted)}
.faq__item.open .faq__a{max-height:25rem}

/* ── Formulare ──────────────────────────────────────────────────────────── */
.forms-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;align-items:start}
@media (max-width:860px){.forms-grid{grid-template-columns:1fr}}
.formcard{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:2rem}
.formcard--accent{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.formcard h3{font-size:1.5rem;margin-bottom:.4rem}
.formcard__hint{color:var(--muted);margin-bottom:1.5rem;font-size:.95rem}
.formcard--accent .formcard__hint{color:#aab1bf}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.4rem}
.field .req{color:var(--signal)}
.field input,.field textarea,.field select{
  width:100%;padding:.85rem 1rem;border:2px solid var(--line);border-radius:10px;
  font:inherit;font-size:1rem;background:#fff;color:var(--ink);transition:border-color .15s}
.formcard--accent .field input,.formcard--accent .field textarea,.formcard--accent .field select{
  background:#1c2027;border-color:#333a45;color:#fff}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--signal);outline:none}
.field textarea{min-height:130px;resize:vertical}
.field--error input,.field--error textarea{border-color:var(--err)}
.field__err{color:var(--err);font-size:.85rem;margin-top:.35rem;display:none}
.field--error .field__err{display:block}
.formcard--accent .field__err{color:#ffb3a3}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:520px){.field-row{grid-template-columns:1fr}}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.88rem;color:var(--muted);margin-bottom:1.2rem}
.formcard--accent .consent{color:#aab1bf}
.consent input{width:20px;height:20px;flex:none;margin-top:.15rem;accent-color:var(--signal)}
.consent a{color:var(--signal);text-decoration:underline}
.form-msg{padding:.9rem 1.1rem;border-radius:10px;font-size:.95rem;margin-bottom:1.2rem;display:none}
.form-msg--ok{display:block;background:rgba(46,158,107,.12);color:var(--ok);border:1px solid rgba(46,158,107,.3)}
.form-msg--err{display:block;background:rgba(214,69,69,.1);color:var(--err);border:1px solid rgba(214,69,69,.3)}
.formcard .btn{width:100%;justify-content:center}

/* ── CTA-Band ───────────────────────────────────────────────────────────── */
.cta-band{background:var(--ink);color:var(--paper);border-radius:22px;padding:clamp(2.2rem,5vw,3.5rem);
  display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band__text h2{margin-bottom:.5rem}
.cta-band__text p{color:#aab1bf}
.cta-band__actions{display:flex;gap:1rem;flex-wrap:wrap}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.site-foot{background:var(--ink);color:var(--paper-soft);position:relative;margin-top:auto}
.trace-line{height:3px;background:linear-gradient(90deg,transparent,var(--signal),transparent)}
.site-foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding:3.5rem 0 2.5rem}
@media (max-width:860px){.site-foot__grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.site-foot__grid{grid-template-columns:1fr}}
.site-foot h3{font-size:.95rem;color:#fff;margin-bottom:1rem;font-family:'JetBrains Mono',monospace;letter-spacing:.05em}
.foot-brand .brand__word{font-size:1.3rem;color:#fff;display:inline-block;margin-bottom:.8rem}
.foot-brand p{font-size:.9rem;color:#9aa1b0;margin-bottom:.5rem}
.foot-claim{color:#7d8493!important}
.foot-loc address{font-style:normal;font-size:.92rem;line-height:1.8;color:#9aa1b0}
.foot-loc a{color:var(--signal-lo)}
.foot-nav a{color:#9aa1b0;line-height:2.1;font-size:.92rem}
.foot-nav a:hover{color:#fff}
.site-foot__legal{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:1px solid #2a313c;padding:1.5rem 0;font-size:.85rem;color:#7d8493}
.foot-legal-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.foot-legal-links a:hover{color:#fff}

/* ── Sticky-Actions (mobil) ─────────────────────────────────────────────── */
.sticky-actions{position:fixed;bottom:0;left:0;right:0;z-index:90;display:none;
  background:var(--ink);border-top:1px solid #2a313c;padding:.6rem .8rem;gap:.6rem}
.sticky-actions a{flex:1;justify-content:center;display:flex;align-items:center;gap:.4rem;
  padding:.85rem;border-radius:10px;font-family:'Space Grotesk',sans-serif;font-weight:600}
.sticky-actions__call{background:var(--signal);color:#fff}
.sticky-actions__cb{background:#2a313c;color:#fff}
@media (max-width:920px){.sticky-actions{display:flex}body{padding-bottom:4.5rem}}

/* ── Legal-Text (Impressum/Datenschutz) ─────────────────────────────────── */
.legal{max-width:820px;margin-inline:auto}
.legal h2{font-size:1.5rem;margin:2.2rem 0 .8rem}
.legal h3{font-size:1.15rem;margin:1.6rem 0 .5rem}
.legal h4{font-size:1rem;margin:1.2rem 0 .4rem;color:var(--ink)}
.legal p{margin-bottom:1rem;color:#3a3f48;max-width:none}
.legal ul{margin:0 0 1rem 1.2rem;list-style:disc}
.legal li{margin-bottom:.4rem;color:#3a3f48}
.legal a{color:var(--signal);text-decoration:underline}
.legal address{font-style:normal;background:var(--paper-soft);padding:1.2rem 1.4rem;border-radius:10px;border-left:3px solid var(--signal);margin-bottom:1rem}

/* ── Trust-Reihe ────────────────────────────────────────────────────────── */
.trust{display:flex;flex-wrap:wrap;gap:.8rem 2rem;justify-content:center;
  font-family:'JetBrains Mono',monospace;font-size:.85rem;color:var(--muted)}
.trust span{display:inline-flex;align-items:center;gap:.5rem}
.trust span::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--signal)}

/* ── 404 ────────────────────────────────────────────────────────────────── */
.err-page{text-align:center;padding:6rem 0}
.err-page__code{font-family:'JetBrains Mono',monospace;font-size:6rem;font-weight:600;color:var(--signal);line-height:1}

/* ── Themenseiten (Tags) ────────────────────────────────────────────────── */
.crumbs{font-family:'JetBrains Mono',monospace;font-size:.8rem;color:#8b93a3;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.crumbs a{color:var(--signal-lo)}
.crumbs a:hover{color:var(--signal)}
.topic-grid{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}
@media(max-width:900px){.topic-grid{grid-template-columns:1fr}}
.topic-main h2{margin-top:0}
.ticklist{display:grid;gap:.7rem}
.ticklist li{position:relative;padding-left:1.9rem;font-size:1.02rem;color:#3a3f48}
.ticklist li::before{content:"";position:absolute;left:0;top:.4rem;width:14px;height:8px;border-left:2px solid var(--signal);border-bottom:2px solid var(--signal);transform:rotate(-45deg)}
.topic-side{display:grid;gap:1.2rem;position:sticky;top:90px}
@media(max-width:900px){.topic-side{position:static}}
.topic-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:1.6rem}
.topic-card h3{font-size:1.15rem;margin-bottom:.3rem}
.topic-card a.mono,.topic-card .mono a{color:var(--ink)}
.topic-card .mono a:hover{color:var(--signal)}
.topic-group{margin-bottom:2.5rem}
.topic-group h2{font-size:1.3rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--line)}
.topic-group h2::before{content:"";display:inline-block;width:10px;height:10px;background:var(--signal);border-radius:2px;margin-right:.6rem;vertical-align:middle}
.topic-links{display:flex;flex-wrap:wrap;gap:.5rem}
.topic-links a{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.4rem .8rem;font-size:.9rem;color:var(--ink);transition:border-color .15s,color .15s}
.topic-links a:hover{border-color:var(--signal);color:var(--signal)}

/* ── Cookie-Consent ─────────────────────────────────────────────────────── */
#cc-root{position:relative;z-index:1000}
.cc-banner{position:fixed;left:0;right:0;bottom:0;z-index:1001;background:var(--ink);color:var(--paper);
  border-top:3px solid var(--signal);box-shadow:0 -10px 40px -10px rgba(0,0,0,.5);animation:cc-up .3s ease}
@keyframes cc-up{from{transform:translateY(100%)}to{transform:translateY(0)}}
@media (prefers-reduced-motion:reduce){.cc-banner{animation:none}}
.cc-banner__in{width:min(1180px,100% - 3rem);margin-inline:auto;padding:1.4rem 0;
  display:flex;gap:1.5rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cc-banner__text{flex:1;min-width:280px}
.cc-banner__text h2{font-size:1.15rem;margin-bottom:.4rem;color:#fff}
.cc-banner__text p{font-size:.92rem;color:#c5cad3;max-width:70ch}
.cc-banner__text a{color:var(--signal-lo);text-decoration:underline}
.cc-banner__actions{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.cc-banner__actions .btn{padding:.7rem 1.2rem;font-size:.95rem}
.cc-banner .btn--ghost{color:var(--paper);border-color:#3a4150}
.cc-banner .btn--ghost:hover{background:#222630;color:#fff}
@media(max-width:720px){.cc-banner__actions{width:100%}.cc-banner__actions .btn{flex:1;justify-content:center}}

.cc-modal{position:fixed;inset:0;z-index:1002;display:grid;place-items:center;padding:1rem}
.cc-modal__backdrop{position:absolute;inset:0;background:rgba(10,12,16,.6);backdrop-filter:blur(2px)}
.cc-modal__box{position:relative;background:var(--paper);color:var(--ink);border-radius:18px;
  width:min(640px,100%);max-height:90vh;overflow:auto;box-shadow:0 30px 80px -20px rgba(0,0,0,.5)}
.cc-modal__head{display:flex;justify-content:space-between;align-items:center;
  padding:1.4rem 1.6rem;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--paper);z-index:1}
.cc-modal__head h2{font-size:1.3rem}
.cc-modal__x{background:none;border:0;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--muted);padding:0 .3rem}
.cc-modal__x:hover{color:var(--ink)}
.cc-modal__body{padding:1.4rem 1.6rem}
.cc-modal__lead{color:var(--muted);margin-bottom:1.4rem}
.cc-modal__foot{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end;
  padding:1.2rem 1.6rem;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--paper)}
@media(max-width:560px){.cc-modal__foot .btn{flex:1;justify-content:center}}

.cc-cat{border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.2rem;margin-bottom:1rem}
.cc-cat__head{display:flex;align-items:center;justify-content:space-between}
.cc-cat__name{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem}
.cc-cat__name em{font-style:normal;font-size:.78rem;color:var(--muted);font-weight:500}
.cc-cat__desc{color:var(--muted);font-size:.9rem;margin:.6rem 0 .4rem}
.cc-cat__details summary{cursor:pointer;font-size:.85rem;color:var(--signal);font-weight:600;user-select:none}
.cc-cat__details summary:hover{text-decoration:underline}
.cc-table{width:100%;border-collapse:collapse;margin-top:.7rem;font-size:.82rem}
.cc-table th,.cc-table td{text-align:left;padding:.4rem .5rem;border-bottom:1px solid var(--line);vertical-align:top}
.cc-table th{color:var(--muted);font-weight:600}

/* Toggle-Switch */
.cc-switch{display:inline-flex;align-items:center;gap:.7rem;cursor:pointer}
.cc-switch input{position:absolute;opacity:0;width:0;height:0}
.cc-switch__slider{position:relative;width:44px;height:24px;background:#cdd2d8;border-radius:999px;flex:none;transition:background .2s}
.cc-switch__slider::after{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s}
.cc-switch input:checked + .cc-switch__slider{background:var(--signal)}
.cc-switch input:checked + .cc-switch__slider::after{transform:translateX(20px)}
.cc-switch input:disabled + .cc-switch__slider{background:var(--ok);opacity:.7;cursor:not-allowed}
.cc-switch input:focus-visible + .cc-switch__slider{outline:3px solid var(--signal);outline-offset:2px}

/* Reopen-Button (Fußzeile, schwebend) */
.cc-reopen{position:fixed;left:1rem;bottom:1rem;z-index:900;background:var(--ink);color:var(--paper);
  border:1px solid #3a4150;border-radius:999px;padding:.55rem 1rem;font-size:.82rem;cursor:pointer;
  font-family:'Inter',sans-serif;box-shadow:0 6px 20px -8px rgba(0,0,0,.4);opacity:.85;transition:opacity .2s}
.cc-reopen:hover{opacity:1}
.cc-reopen::before{content:"";display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--signal);margin-right:.5rem;vertical-align:middle}
@media(max-width:920px){.cc-reopen{bottom:5rem}}

/* Karten-Platzhalter (wenn Karten nicht zugestimmt) */
.cc-placeholder{display:grid;place-items:center;text-align:center;padding:2rem 1.5rem;height:100%;
  background:var(--ink-soft);color:var(--paper);gap:.8rem}
.cc-placeholder p{color:#c5cad3;font-size:.92rem;max-width:40ch}
.cc-placeholder .btn{font-size:.9rem}
.foot-cc-link{background:none;border:0;color:inherit;font:inherit;cursor:pointer;padding:0;text-decoration:none}
.foot-cc-link:hover{color:#fff;text-decoration:underline}

/* hidden-Attribut hat Vorrang vor display der Consent-Elemente */
#cc-banner[hidden],#cc-modal[hidden],#cc-root[hidden],.cc-reopen[hidden],.cc-placeholder[hidden]{display:none !important}
