
:root{
  /* ─── Kältekumpels CI Palette (aus CI Manual) ─── */
  --ki-navy:#22283E;         /* CI Navy */
  --ki-navy-deep:#171B2C;    /* dunklere Variante für Tiefe */
  --ki-blue:#315C7F;         /* CI Blue — Primary Brand */
  --ki-blue-light:#4E7CA3;
  --ki-blue-soft:#7BA0C2;    /* sanfter Akzent auf dunkel */
  --ki-orange:#B04525;       /* CI Orange — Wärme-Akzent */
  --ki-orange-light:#D05A34;
  --ki-gold:#D9A337;         /* CI Gold — Premium-Akzent */
  --ki-gold-soft:#E8BB5C;
  --ki-grey:#ACACAC;         /* CI Grey */

  /* Semantic Aliases */
  --frost-deep:var(--ki-navy);
  --frost-night:var(--ki-navy-deep);
  --frost-core:var(--ki-blue);
  --frost-bright:var(--ki-blue);
  --frost-glow:var(--ki-blue-soft);
  --frost-ice:#E6EEF5;
  --snow:#F6F4F0;            /* warmes Off-White, passt zum Palette */
  --mist:#E6E3DD;            /* warmer Divider */
  --graphite:#1A1F30;
  --steel:#5E6378;
  --ember:var(--ki-orange);

  --display:'Fraunces', Georgia, serif;
  --sans:'Inter Tight', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;

  --pad-x: clamp(20px, 5vw, 96px);
  --section-y: clamp(72px, 10vw, 160px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  color:var(--graphite);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* ───── Reusable ───── */
.eyebrow{
  font-family:var(--sans);
  font-size:12px;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--frost-bright);
}
.eyebrow.dark{color:var(--steel)}
.display{
  font-family:var(--display);
  font-weight:400;
  letter-spacing:-.025em;
  line-height:.95;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.mono{font-family:var(--mono);font-feature-settings:"tnum"}

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:18px 28px;
  border-radius:999px;
  font-family:var(--sans);
  font-weight:500;
  font-size:15px;
  letter-spacing:.01em;
  transition:transform .3s cubic-bezier(.16,1,.3,1), box-shadow .3s, background .3s, color .3s;
  white-space:nowrap;
}
.btn-primary{
  background:var(--ki-blue);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.2) inset, 0 12px 32px -12px rgba(49,92,127,.6);
}
.btn-primary:hover{
  background:var(--ki-blue-light);
  transform:translateY(-2px);
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 20px 44px -14px rgba(49,92,127,.75);
}
.btn-accent{
  background:var(--ki-orange);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.2) inset, 0 12px 32px -12px rgba(176,69,37,.6);
}
.btn-accent:hover{
  background:var(--ki-orange-light);
  transform:translateY(-2px);
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 20px 44px -14px rgba(176,69,37,.75);
}
.btn-ghost{
  background:transparent;
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
}
.btn-ghost:hover{border-color:rgba(255,255,255,.6); background:rgba(255,255,255,.04)}
.btn-ghost-dark{background:transparent;color:var(--graphite);border:1px solid var(--mist)}
.btn-ghost-dark:hover{border-color:var(--graphite)}
.btn .arrow{transition:transform .3s cubic-bezier(.16,1,.3,1)}
.btn:hover .arrow{transform:translateX(4px)}

.container{
  width:100%;
  max-width:1440px;
  margin:0 auto;
  padding:0 var(--pad-x);
}

/* ───── Reveal ───── */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.4s}
.reveal[data-d="6"]{transition-delay:.48s}

/* ────────────────────── NAV ────────────────────── */
.nav{
  position:fixed;
  inset:0 0 auto 0;
  z-index:60;
  padding:18px var(--pad-x);
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition:background .35s ease, backdrop-filter .35s ease, padding .35s ease, border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(6,19,35,.78);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:rgba(255,255,255,.06);
  padding-top:14px;padding-bottom:14px;
}
.logo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 22px;
  background:#fff;
  border-radius:16px;
  box-shadow:0 10px 28px -10px rgba(0,0,0,.5);
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.logo:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 38px -14px rgba(0,0,0,.6);
}
.logo img{
  height:56px;
  width:auto;
  display:block;
}
/* Nav wird etwas höher damit das Logo atmen kann */
.nav{padding-top:14px;padding-bottom:14px}
.nav.scrolled{padding-top:10px;padding-bottom:10px}
.nav.scrolled .logo img{height:44px}
.nav.scrolled .logo{padding:10px 18px}

/* Footer-Variante */
footer .logo{margin-bottom:20px;background:none;box-shadow:none;padding:0;border-radius:0}
footer .logo:hover{transform:none;box-shadow:none;opacity:.8}
footer .logo img{height:44px;filter:brightness(0) invert(1)}

@media (max-width:900px){
  .logo img{height:48px}
  .nav.scrolled .logo img{height:40px}
}
@media (max-width:520px){
  .logo{padding:10px 16px}
  .logo img{height:40px}
  .nav.scrolled .logo img{height:36px}
}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{
  font-size:14px;
  color:rgba(255,255,255,.78);
  font-weight:400;
  transition:color .25s;
  position:relative;
}
.nav-links a:hover{color:#fff}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{
  display:inline-grid;
  grid-template-columns:auto auto;
  grid-template-rows:auto auto;
  align-items:center;
  column-gap:12px;
  row-gap:0;
  padding:9px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.04);
  transition:border-color .25s, background .25s;
  color:#fff;
}
.nav-phone:hover{border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.08)}
.nav-phone svg{
  grid-row:1 / span 2;
  grid-column:1;
  align-self:center;
  opacity:.9;
  flex-shrink:0;
}
.nav-phone .phone-label{
  grid-row:1;grid-column:2;
  font-size:9px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ki-gold-soft);
  font-weight:500;
  line-height:1.1;
  white-space:nowrap;
}
.nav-phone .phone-num{
  grid-row:2;grid-column:2;
  font-family:var(--mono);
  font-size:14px;
  font-weight:500;
  color:#fff;
  line-height:1.2;
  letter-spacing:-.01em;
  white-space:nowrap;
  margin-top:2px;
}
.nav-cta .btn{padding:13px 22px;font-size:14px}
.burger{display:none;width:42px;height:42px;border-radius:10px;border:1px solid rgba(255,255,255,.2);align-items:center;justify-content:center}
.burger span{width:18px;height:1.5px;background:#fff;display:block;position:relative}
.burger span::before,.burger span::after{content:'';position:absolute;left:0;width:18px;height:1.5px;background:#fff}
.burger span::before{top:-6px}.burger span::after{top:6px}

@media (max-width:1080px){
  .nav-links{display:none}
  .nav-cta .nav-phone{display:none}
}
@media (max-width:680px){
  .nav-cta .btn{display:none}
  .burger{display:flex}
}

/* ────────────────────── HERO ────────────────────── */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  background:var(--frost-night);
  color:#fff;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  padding-top:140px;
  padding-bottom:80px;
}
.hero-bg{
  position:absolute;
  inset:0;
  background-image:url('../images/photos/hero-facade.jpg');
  background-size:cover;
  background-position:center right;
  opacity:.55;
  animation:kenburns 24s ease-in-out infinite alternate;
}
@keyframes kenburns{
  from{transform:scale(1.02) translateX(0)}
  to{transform:scale(1.08) translateX(-12px)}
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(105deg, var(--frost-night) 12%, rgba(6,19,35,.72) 48%, rgba(6,19,35,.15) 75%, transparent 100%),
    linear-gradient(180deg, transparent 60%, var(--frost-night) 100%);
}
.hero-grain{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .08 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;opacity:.35;pointer-events:none;
}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:48px;
  align-items:end;
}
.hero h1{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(56px, 9vw, 132px);
  line-height:.92;
  letter-spacing:-.035em;
  color:#fff;
  margin-top:24px;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.hero h1 .accent{
  font-style:italic;
  font-weight:400;
  color:var(--ki-gold-soft);
}
.hero h1 .line2{display:block;padding-left:8%}
.hero-sub{
  margin-top:32px;
  font-size:clamp(16px,1.3vw,19px);
  color:rgba(255,255,255,.72);
  max-width:520px;
  line-height:1.55;
}
.hero-cta{
  margin-top:40px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
@media (max-width:600px){
  .hero-cta{display:none}
}
.hero-side{
  display:flex;
  flex-direction:column;
  gap:14px;
  align-items:flex-end;
  padding-bottom:8px;
}
.hero-quickcard{
  width:100%;
  max-width:340px;
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:18px 22px;
  display:flex;align-items:center;gap:16px;
  transition:border-color .3s, transform .3s;
}
.hero-quickcard:hover{border-color:rgba(255,255,255,.28);transform:translateY(-2px)}
.hero-quickcard .ico{
  width:42px;height:42px;border-radius:12px;
  background:rgba(49,92,127,.18);
  color:var(--frost-glow);
  display:grid;place-items:center;flex-shrink:0;
}
.hero-quickcard .ico svg{width:20px;height:20px}
.hero-quickcard .lbl{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:2px}
.hero-quickcard .val{font-family:var(--mono);font-size:15px;color:#fff}

/* live-bar bottom */
.hero-livebar{
  position:relative;
  z-index:2;
  width:100%;
  margin-top:80px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
  padding-top:32px;
  border-top:1px solid rgba(255,255,255,.12);
}
.live-item{display:flex;align-items:center;gap:14px}
.live-num{
  font-family:var(--mono);
  font-size:28px;
  color:#fff;
  font-weight:500;
  letter-spacing:-.01em;
}
.live-lbl{font-size:13px;color:rgba(255,255,255,.6);line-height:1.4}
.live-dot{
  width:8px;height:8px;border-radius:50%;
  background:#22e3a3;
  box-shadow:0 0 0 0 rgba(34,227,163,.6);
  animation:pulse 2.5s ease-out infinite;
  flex-shrink:0;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(34,227,163,.55)}
  70%{box-shadow:0 0 0 14px rgba(34,227,163,0)}
  100%{box-shadow:0 0 0 0 rgba(34,227,163,0)}
}
@keyframes pulse-red{
  0%{box-shadow:0 0 0 0 rgba(255,80,60,.7)}
  70%{box-shadow:0 0 0 8px rgba(255,80,60,0)}
  100%{box-shadow:0 0 0 0 rgba(255,80,60,0)}
}
.hero-notdienst{
  display:none;align-items:center;gap:12px;
  background:rgba(255,75,55,.08);
  border:1px solid rgba(255,75,55,.2);
  border-radius:14px;
  padding:14px 18px;
  margin-top:14px;
  text-decoration:none;color:#fff;
  transition:background .2s;
}
.hero-notdienst:hover{background:rgba(255,75,55,.14)}
.nd-dot{
  width:9px;height:9px;border-radius:50%;
  background:#ff5a3c;
  animation:pulse-red 2s ease-out infinite;
  flex-shrink:0;
}
.nd-lbl{
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.55);white-space:nowrap;
}
.nd-num{
  font-family:var(--mono);font-size:18px;font-weight:600;
  flex:1;letter-spacing:-.01em;
}

@media (max-width:900px){
  .hero-bg{
    background-size:cover;
    background-position:center top;
    opacity:.35;
  }
  .hero-overlay{
    background:
      linear-gradient(180deg, rgba(6,19,35,.55) 0%, rgba(6,19,35,.2) 40%, rgba(6,19,35,.15) 60%, rgba(6,19,35,.85) 100%),
      linear-gradient(to right, rgba(6,19,35,.7) 0%, transparent 70%);
  }
  .hero{padding-top:120px;align-items:center}
  .hero-grid{grid-template-columns:1fr;gap:16px}
  .hero-side{display:none}
  .hero-quickcard{max-width:none;padding:14px 14px;gap:10px;border-radius:14px;flex-direction:row;align-items:center}
  .hero-quickcard .ico{width:32px;height:32px;border-radius:8px;flex-shrink:0;background:rgba(49,92,127,.25)}
  .hero-quickcard .ico svg{width:15px;height:15px}
  .hero-quickcard .lbl{font-size:9px;letter-spacing:.11em;margin-bottom:3px}
  .hero-quickcard .val{font-size:12px;line-height:1.35}
  .hero h1 .line2{padding-left:0}
  .hero-livebar{
    grid-template-columns:repeat(3,1fr);
    gap:8px;
    margin-top:28px;
    padding-top:0;
    border-top:none;
  }
  .live-item{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:4px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.1);
    border-radius:14px;
    padding:14px 8px 12px;
  }
  .live-dot{display:none}
  .live-num{font-size:17px;font-weight:600;letter-spacing:-.02em}
  .live-lbl{font-size:10px;line-height:1.35;color:rgba(255,255,255,.55)}
  .hero-notdienst{display:flex}
}

/* ────────────────────── TRUST STRIPE ────────────────────── */
.trust{
  background:#fff;
  padding:48px var(--pad-x);
  border-bottom:1px solid var(--mist);
}
.trust-inner{
  max-width:1440px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;
}
.trust-label{
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--steel);
  white-space:nowrap;
}
.trust-logos{
  flex:1;
  overflow:hidden;
  height:36px;
  position:relative;
  font-family:var(--display);
  color:#9aa3b2;
  mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);
  -webkit-mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);
}
.trust-logos-inner{
  display:flex;align-items:center;gap:56px;
  white-space:nowrap;
  animation:trust-scroll 18s linear infinite;
}
.trust-logos span{
  font-size:20px;letter-spacing:-.01em;font-weight:500;
  transition:color .3s, transform .3s;
  cursor:default;
}
.trust-logos span:hover{color:var(--graphite);transform:translateY(-1px)}
@keyframes trust-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@media (max-width:820px){
  .trust{padding:24px var(--pad-x)}
  .trust-inner{flex-direction:row;align-items:center;gap:16px;flex-wrap:nowrap}
  .trust-label{font-size:10px;white-space:nowrap;flex-shrink:0}
  .trust-logos{height:28px}
  .trust-logos-inner{gap:32px;animation-duration:14s}
  .trust-logos span{font-size:15px}
}

/* ────────────────────── SECTION HEADERS ────────────────────── */
section.padded{padding:var(--section-y) var(--pad-x)}
.section-head{max-width:880px;margin-bottom:72px}
.section-head h2{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(36px, 5.5vw, 72px);
  line-height:1.02;
  letter-spacing:-.025em;
  margin-top:18px;
  font-variation-settings:"opsz" 144;
}
.section-head h2 em{font-style:italic;color:var(--frost-bright);font-weight:400}
.section-head p{
  font-size:clamp(15px,1.2vw,18px);
  color:var(--steel);
  margin-top:24px;
  max-width:620px;
  line-height:1.6;
}

/* ────────────────────── LEISTUNGEN — AUDIENCE SPLIT ────────────────────── */
.leistungen{background:#fff}
.leistungen .container{max-width:1440px;margin:0 auto}
.audience-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:stretch;
}
.panel{
  position:relative;
  border-radius:28px;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .6s cubic-bezier(.16,1,.3,1), box-shadow .5s;
  box-shadow:0 10px 40px -20px rgba(11,29,55,.18);
}
.panel:hover{
  transform:translateY(-6px);
  box-shadow:0 40px 80px -30px rgba(11,29,55,.35);
}
.panel-biz{background:var(--frost-night);color:#fff}
.panel-priv{background:#fff;color:var(--graphite);border:1px solid var(--mist)}

/* Big media at top */
.panel-media{
  position:relative;
  height:clamp(280px, 34vw, 460px);
  overflow:hidden;
}
.panel-media img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 1.8s cubic-bezier(.16,1,.3,1);
}
.panel:hover .panel-media img{transform:scale(1.06)}
.panel-media::after{
  content:'';position:absolute;inset:0;
  pointer-events:none;
}
.panel-biz .panel-media::after{
  background:
    linear-gradient(180deg, rgba(6,19,35,.25) 0%, transparent 35%, rgba(6,19,35,.55) 85%, var(--frost-night) 100%);
}
.panel-priv .panel-media::after{
  background:
    linear-gradient(180deg, rgba(255,255,255,.15) 0%, transparent 30%, rgba(255,255,255,.6) 85%, #fff 100%);
}
.panel-media-label{
  position:absolute;
  top:28px;left:28px;
  z-index:2;
  display:inline-flex;align-items:center;gap:12px;
  padding:10px 18px;
  border-radius:999px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.panel-biz .panel-media-label{
  background:rgba(10,27,46,.55);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
}
.panel-priv .panel-media-label{
  background:rgba(255,255,255,.85);
  border:1px solid rgba(11,29,55,.08);
  color:var(--graphite);
}
.panel-media-label::before{
  content:'';width:20px;height:1px;background:currentColor;opacity:.7;
}

/* Content below */
.panel-inner{
  position:relative;
  z-index:2;
  padding:8px 44px 40px;
  display:flex;
  flex-direction:column;
  flex:1;
  margin-top:-40px;
}
.panel-title{
  font-family:var(--display);
  font-size:clamp(36px,4.2vw,56px);
  font-weight:400;
  line-height:1.0;
  letter-spacing:-.025em;
}
.panel-title em{font-style:italic}
.panel-biz .panel-title em{color:var(--frost-glow)}
.panel-priv .panel-title em{color:var(--frost-bright)}
.panel-desc{
  margin-top:22px;
  font-size:15px;
  line-height:1.65;
  max-width:500px;
}
.panel-biz .panel-desc{color:rgba(255,255,255,.62)}
.panel-priv .panel-desc{color:var(--steel)}

.services{
  margin-top:44px;
  padding-top:0;
  display:flex;flex-direction:column;
}
.service{
  display:flex;
  align-items:center;
  gap:20px;
  padding:22px 0;
  border-top:1px solid;
  cursor:pointer;
  transition:padding-left .4s cubic-bezier(.16,1,.3,1);
}
.service:last-child{border-bottom:1px solid}
.panel-biz .service{border-color:rgba(255,255,255,.1)}
.panel-priv .service{border-color:var(--mist)}
.service:hover{padding-left:8px}
.panel-biz .service:hover{border-color:rgba(90,155,255,.35)}
.panel-priv .service:hover{border-color:var(--frost-bright)}

.service-ico{
  width:44px;height:44px;
  border-radius:12px;
  display:grid;place-items:center;
  flex-shrink:0;
  transition:background .3s, color .3s;
}
.panel-biz .service-ico{background:rgba(49,92,127,.14);color:var(--frost-glow)}
.panel-priv .service-ico{background:#fff;color:var(--frost-bright);border:1px solid var(--mist)}
.service:hover .service-ico{background:var(--frost-bright);color:#fff;border-color:var(--frost-bright)}
.service-ico svg{width:20px;height:20px}

.service-body{flex:1;min-width:0}
.service-name{
  font-family:var(--display);
  font-size:22px;
  font-weight:500;
  letter-spacing:-.01em;
  line-height:1.1;
}
.service-sub{
  margin-top:4px;
  font-size:13px;
  line-height:1.45;
}
.panel-biz .service-sub{color:rgba(255,255,255,.55)}
.panel-priv .service-sub{color:var(--steel)}

.service-arrow{
  flex-shrink:0;
  width:36px;height:36px;
  border-radius:50%;
  display:grid;place-items:center;
  transition:background .3s, transform .4s cubic-bezier(.16,1,.3,1);
}
.panel-biz .service-arrow{background:rgba(255,255,255,.06);color:#fff}
.panel-priv .service-arrow{background:#fff;color:var(--graphite);border:1px solid var(--mist)}
.service:hover .service-arrow{transform:translateX(4px)}
.panel-biz .service:hover .service-arrow{background:var(--frost-bright)}
.panel-priv .service:hover .service-arrow{background:var(--graphite);color:#fff;border-color:var(--graphite)}

/* Wärme-Akzent: Orange aus der CI */
.service.warm .service-ico{background:rgba(176,69,37,.1);color:var(--ki-orange);border-color:rgba(176,69,37,.2)}
.service.warm:hover .service-ico{background:var(--ki-orange);color:#fff;border-color:var(--ki-orange)}
.service.warm:hover{border-color:var(--ki-orange) !important}
.panel-priv .service.warm:hover .service-arrow{background:var(--ki-orange);color:#fff;border-color:var(--ki-orange)}

@media (max-width:900px){
  .audience-grid{grid-template-columns:1fr;gap:20px}
  .panel{min-height:auto}
  .panel-inner{padding:36px 28px 28px}
  .service-name{font-size:19px}
}

/* ────────────────────── PROZESS DARK ────────────────────── */
.prozess{
  background:var(--frost-night);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.prozess::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(ellipse at 70% 20%, rgba(49,92,127,.18), transparent 55%);
  pointer-events:none;
}
.prozess .container{position:relative}
.prozess .section-head h2{color:#fff}
.prozess .section-head p{color:rgba(255,255,255,.6)}
.steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  position:relative;
  margin-top:48px;
}
.step{
  position:relative;
  padding:36px 28px 0 0;
  border-top:1px solid rgba(255,255,255,.12);
}
.step:not(:last-child){border-right:1px solid rgba(255,255,255,.06)}
.step-num{
  font-family:var(--mono);
  color:var(--frost-glow);
  font-size:13px;
  letter-spacing:.16em;
  margin-bottom:16px;
}
.step-title{
  font-family:var(--display);
  font-size:26px;
  letter-spacing:-.02em;
  line-height:1.1;
  margin-bottom:14px;
}
.step-text{font-size:14px;color:rgba(255,255,255,.62);line-height:1.6;padding-bottom:32px;padding-right:16px}
.flow-svg{
  position:absolute;
  top:-1px;left:0;right:0;
  height:1px;
  pointer-events:none;
}
.flow-svg line{stroke:var(--frost-bright);stroke-width:1;stroke-dasharray:8 8;animation:flow 3.5s linear infinite}
@keyframes flow{to{stroke-dashoffset:-32}}

@media (max-width:900px){
  .steps{grid-template-columns:1fr}
  .step{padding-right:0}
  .step:not(:last-child){border-right:0}
}

/* ────────────────────── REFERENZ FEATURE ────────────────────── */
.reference{background:#fff}
.ref-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:64px;
  align-items:center;
}
.ref-img{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  aspect-ratio:4/5;
}
.ref-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.16,1,.3,1)}
.ref-img:hover img{transform:scale(1.04)}
.ref-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(6,19,35,.6));
  pointer-events:none;
}
.ref-tag{
  position:absolute;
  top:24px;left:24px;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);
  padding:8px 14px;border-radius:999px;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite);
  z-index:2;
}
.ref-content h3{
  font-family:var(--display);
  font-size:clamp(32px,3.6vw,52px);
  line-height:1.05;
  letter-spacing:-.02em;
  font-weight:400;
}
.ref-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin:36px 0;
  padding:32px 0;
  border-top:1px solid var(--mist);
  border-bottom:1px solid var(--mist);
}
.ref-stat .num{
  font-family:var(--mono);
  font-size:28px;
  color:var(--graphite);
  font-weight:500;
  letter-spacing:-.01em;
}
.ref-stat .lbl{font-size:12px;color:var(--steel);text-transform:uppercase;letter-spacing:.12em;margin-top:6px}
.ref-text{color:var(--steel);font-size:16px;line-height:1.65}
.ref-quote{
  margin:32px 0;
  padding-left:20px;
  border-left:2px solid var(--frost-bright);
  font-family:var(--display);
  font-style:italic;
  font-size:18px;
  color:var(--graphite);
  line-height:1.4;
}
.ref-quote cite{display:block;margin-top:10px;font-size:13px;font-style:normal;color:var(--steel);letter-spacing:.04em}

@media (max-width:900px){
  .ref-grid{grid-template-columns:1fr;gap:40px}
  .ref-stats{gap:18px}
  .ref-stat .num{font-size:22px}
}

/* ── weitere Referenz-Karten ── */
.ref-rail{
  margin-top:96px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.ref-card{
  background:#fff;
  border:1px solid var(--mist);
  border-radius:20px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .5s cubic-bezier(.16,1,.3,1), box-shadow .5s, border-color .3s;
}
.ref-card:hover{
  transform:translateY(-6px);
  border-color:#cbd5e8;
  box-shadow:0 30px 60px -30px rgba(11,29,55,.22);
}
.ref-card-img{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
}
.ref-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s cubic-bezier(.16,1,.3,1);
}
.ref-card:hover .ref-card-img img{transform:scale(1.06)}
.ref-card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(6,19,35,.45));
  pointer-events:none;
}
.ref-card-img .ref-tag{
  position:absolute;
  top:18px;left:18px;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  padding:7px 12px;border-radius:999px;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite);
  font-weight:500;
  z-index:2;
}
.ref-card-body{
  padding:28px 28px 32px;
  display:flex;
  flex-direction:column;
  gap:16px;
  flex:1;
}
.ref-card-body h4{
  font-family:var(--display);
  font-size:22px;
  font-weight:500;
  line-height:1.15;
  letter-spacing:-.015em;
  color:var(--graphite);
}
.ref-card-stats{
  display:flex;
  flex-wrap:wrap;
  gap:8px 20px;
  padding:14px 0;
  border-top:1px solid var(--mist);
  border-bottom:1px solid var(--mist);
  font-size:12px;
  color:var(--steel);
  letter-spacing:.01em;
}
.ref-card-stats span{
  display:inline-flex;
  align-items:baseline;
  gap:5px;
}
.ref-card-stats b{
  font-family:var(--mono);
  font-weight:500;
  font-size:15px;
  color:var(--graphite);
  letter-spacing:-.01em;
}
.ref-card-body p{
  font-size:14px;
  line-height:1.6;
  color:var(--steel);
  margin-top:auto;
}

@media (max-width:960px){
  .ref-rail{grid-template-columns:1fr;gap:24px;margin-top:72px}
}

/* ────────────────────── USPs ────────────────────── */
.usps{background:var(--snow)}
.usps-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--mist);
  border:1px solid var(--mist);
  border-radius:24px;
  overflow:hidden;
}
.usp{
  background:#fff;
  padding:44px 36px 48px;
  transition:background .35s;
}
.usp:hover{background:#fafbff}
.usp-ico{
  width:56px;height:56px;
  border-radius:16px;
  background:var(--ki-blue);
  color:#fff;
  display:grid;place-items:center;
  margin-bottom:28px;
  box-shadow:0 12px 28px -12px rgba(49,92,127,.55);
  transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.usp-ico svg{width:24px;height:24px;stroke-width:1.8}
.usp:hover .usp-ico{transform:translateY(-3px) rotate(-3deg)}
/* Alternierend: CI-Gold für zwei Karten */
.usp:nth-child(2) .usp-ico,
.usp:nth-child(5) .usp-ico{
  background:var(--ki-gold);
  box-shadow:0 12px 28px -12px rgba(217,163,55,.6);
}
/* 24/7 Notdienst in CI-Orange für Signalwirkung */
.usp:nth-child(4) .usp-ico{
  background:var(--ki-orange);
  box-shadow:0 12px 28px -12px rgba(176,69,37,.55);
}
.usp h4{
  font-family:var(--display);
  font-size:22px;
  letter-spacing:-.015em;
  line-height:1.15;
  font-weight:500;
  margin-bottom:12px;
}
.usp p{font-size:14px;color:var(--steel);line-height:1.6}
.usps-bottom{
  margin-top:32px;
  text-align:center;
  padding:28px;
  background:var(--frost-night);
  color:#fff;
  border-radius:24px;
  font-family:var(--display);
  font-size:clamp(18px,2vw,24px);
  font-weight:400;
  letter-spacing:-.01em;
}
.usps-bottom em{color:var(--ki-gold-soft);font-style:italic}

@media (max-width:900px){
  .usps-grid{grid-template-columns:1fr 1fr !important}
  .usp{padding:16px 14px 18px}
  .usp-ico{width:34px;height:34px;border-radius:9px;margin-bottom:10px}
  .usp-ico svg{width:15px;height:15px}
  .usp h4{font-size:13px;margin-bottom:0;line-height:1.3}
  .usp p{display:none}
}

/* ────────────────────── CTA BLOCK ────────────────────── */
.cta-block{
  background:var(--frost-night);
  color:#fff;
  position:relative;
  overflow:hidden;
  text-align:center;
}
.cta-block::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 40%, rgba(78,124,163,.28), transparent 55%),
    radial-gradient(circle at 75% 60%, rgba(49,92,127,.18), transparent 50%);
}
.cta-inner{position:relative;max-width:1100px;margin:0 auto}
.cta-inner h2{
  font-family:var(--display);
  font-size:clamp(40px,7vw,96px);
  line-height:.98;
  letter-spacing:-.03em;
  font-weight:300;
  font-variation-settings:"opsz" 144,"SOFT" 60;
}
.cta-inner h2 em{font-style:italic;color:var(--ki-gold-soft);font-weight:400}
.cta-inner > p{
  margin-top:24px;
  color:rgba(255,255,255,.66);
  font-size:18px;
}
.cta-ways{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-top:56px;
}
.way{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  padding:32px 28px;
  border-radius:20px;
  text-align:left;
  transition:background .3s, border-color .3s, transform .3s;
}
.way:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.25);transform:translateY(-3px)}
.way-ico{
  width:38px;height:38px;border-radius:11px;
  background:rgba(49,92,127,.18);color:var(--frost-glow);
  display:grid;place-items:center;margin-bottom:18px;
}
.way h4{font-family:var(--display);font-size:22px;font-weight:500;letter-spacing:-.01em;margin-bottom:6px}
.way p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.55;margin-bottom:14px}
.way .val{font-family:var(--mono);font-size:18px;color:#fff;letter-spacing:-.01em}
.way .small{font-size:13px;color:var(--frost-glow);font-weight:500;display:flex;align-items:center;gap:6px}
@media (max-width:820px){.cta-ways{grid-template-columns:1fr}}

/* ────────────────────── FOOTER ────────────────────── */
footer{
  position:relative;
  background:var(--frost-night);
  color:rgba(255,255,255,.7);
  padding:96px var(--pad-x) 32px;
  border-top:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
/* KK-Pattern weich und dezent über gesamten Footer-Hintergrund */
footer::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:url('../images/kk-pattern-tile.png');
  background-size:30px auto;
  background-repeat:repeat-x;
  background-position:bottom center;
  opacity:.09;
  pointer-events:none;
  z-index:1;
  mask-image:linear-gradient(to top, black 0%, black 20%, rgba(0,0,0,.3) 50%, transparent 75%);
  -webkit-mask-image:linear-gradient(to top, black 0%, black 20%, rgba(0,0,0,.3) 50%, transparent 75%);
}
@media (max-width:900px){
  footer::before{background-size:30px auto;opacity:.07}
}
footer > *{position:relative;z-index:2}
.foot-grid{
  max-width:1440px;margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:72px;
}
.foot-brand{max-width:340px}
.foot-brand .logo{margin-bottom:20px}
.foot-brand p{font-size:14px;line-height:1.6;color:rgba(255,255,255,.55)}
.foot-col h5{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.45);
  margin-bottom:20px;font-weight:500;
}
.foot-col a{display:block;font-size:14px;padding:6px 0;color:rgba(255,255,255,.78);transition:color .25s}
.foot-col a:hover{color:#fff}
.foot-col--cities .city-links{
  columns:2;
  column-gap:28px;
}
.foot-col--cities .city-links a{
  break-inside:avoid;
  padding:5px 0;
  font-size:13.5px;
}
.foot-col--cities .city-links a[aria-current="page"]{
  color:var(--ki-gold-soft);
  font-weight:500;
}
.foot-bottom{
  max-width:1440px;margin:0 auto;
  padding-top:32px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:12px;color:rgba(255,255,255,.4);
}
.foot-bottom a{color:rgba(255,255,255,.55)}
.foot-bottom a:hover{color:#fff}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ────────────────────── MOBILE STICKY BAR ────────────────────── */
.mobile-bar{
  display:none;
  position:fixed;
  z-index:60;
  left:12px;right:12px;bottom:12px;
  background:rgba(6,19,35,.92);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  padding:10px;
  gap:8px;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.55);
}
.mobile-bar a{
  flex:1;
  display:flex;align-items:center;justify-content:center;gap:8px;
  height:54px;
  border-radius:12px;
  font-size:14px;
  font-weight:500;
  color:#fff;
}
.mobile-bar .call{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.mobile-bar .req{background:var(--frost-bright)}
@media (max-width:820px){
  .mobile-bar{display:flex}
}

/* selection */

/* ── MOBILE DRAWER ── */
.nav-drawer{
  display:none;
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  z-index:55;
  background:rgba(6,19,35,.98);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:80px 24px 40px;
  padding-top:calc(80px + env(safe-area-inset-top));
  overflow-y:auto;
  transform:translateY(-100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
}
.nav-drawer.open{display:block;transform:translateY(0)}
.nav-drawer-links{display:flex;flex-direction:column;gap:4px;margin-bottom:24px}
.nav-drawer-links a{
  display:block;padding:14px 4px;
  font-size:22px;font-weight:300;letter-spacing:-.02em;
  color:rgba(255,255,255,.85);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:color .2s;
  touch-action:manipulation;
}
.nav-drawer-links a:last-child{border-bottom:none}
.nav-drawer-links a:active{color:#fff}
.nav-drawer-cta{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.nav-drawer-cta a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  height:52px;border-radius:12px;
  font-size:15px;font-weight:500;
  touch-action:manipulation;
}
.nav-drawer-cta .d-call{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#fff}
.nav-drawer-cta .d-req{background:var(--frost-bright);color:#fff}
.drawer-backdrop{
  display:none;position:fixed;inset:0;z-index:54;
  background:rgba(0,0,0,.5);
}
.drawer-backdrop.open{display:block}
.burger.open span{background:transparent}
.burger.open span::before{transform:translateY(6px) rotate(45deg);transition:.25s}
.burger.open span::after{transform:translateY(-6px) rotate(-45deg);transition:.25s}
.burger span::before,.burger span::after{transition:.25s}
/* safe area for mobile bar */
@media (max-width:820px){
  .mobile-bar{padding-bottom:calc(10px + env(safe-area-inset-bottom))}
  body{padding-bottom:calc(90px + env(safe-area-inset-bottom))}
}

::selection{background:var(--frost-bright);color:#fff}

/* ────────────────────── VAN STRIP ────────────────────── */
.van-strip{
  background:#fff;
  padding:var(--section-y) 0;
  overflow:hidden;
  border-top:1px solid #eee;
  border-bottom:1px solid #eee;
}
.van-inner{
  max-width:1280px;margin:0 auto;
  padding:0 var(--pad-x);
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:40px 80px;
  align-items:center;
}
.van-text .eyebrow{color:var(--ki-blue-soft)}
.van-text h2{
  font-family:var(--display);
  font-size:clamp(32px,3.5vw,52px);
  font-weight:400;letter-spacing:-.025em;line-height:.95;
  color:var(--ki-navy-deep);margin-top:16px;
}
.van-text h2 em{color:var(--ki-orange);font-style:italic}
.van-text p{margin-top:18px;color:#555;font-size:16px;line-height:1.75;max-width:420px}
.van-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.van-badge{
  padding:6px 16px;border-radius:999px;
  border:1.5px solid var(--ki-navy-deep);
  font-size:12px;font-weight:600;letter-spacing:.04em;
  color:var(--ki-navy-deep);
  background:transparent;
}
.van-img{
  display:flex;justify-content:center;align-items:center;
}
.van-img img{
  width:100%;max-width:680px;
  display:block;
}
@media(max-width:900px){
  .van-inner{grid-template-columns:1fr;gap:8px}
  .van-img img{max-width:480px;margin:0 auto}
}

/* ────────────────────── NOTDIENST BANNER (removed) ────────────────────── */
.nd-banner{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:linear-gradient(90deg, #8B2E10 0%, var(--ki-orange) 40%, #C94F2A 100%);
  color:#fff;
  padding:0 var(--pad-x);
  height:48px;
  display:flex;align-items:center;justify-content:center;gap:16px;
  font-size:13px;font-weight:400;letter-spacing:.01em;
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.16,1,.3,1);
  pointer-events:none;
  box-shadow:0 2px 20px rgba(176,69,37,.5);
}
.nd-banner::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);
  pointer-events:none;
}
.nd-banner.active{transform:translateY(0);pointer-events:auto}
.nd-pill{
  display:flex;align-items:center;gap:7px;
  background:rgba(0,0,0,.2);
  border:1px solid rgba(255,255,255,.15);
  border-radius:999px;
  padding:4px 10px 4px 8px;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  flex-shrink:0;
}
.nd-pulse{
  width:7px;height:7px;border-radius:50%;background:#fff;flex-shrink:0;
  animation:nd-pulse 1.4s ease-in-out infinite;
}
@keyframes nd-pulse{
  0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}
  70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}
  100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}
}
.nd-text{color:rgba(255,255,255,.85);font-size:13px}
.nd-banner a{
  display:inline-flex;align-items:center;gap:7px;
  color:#fff;font-weight:600;font-size:13px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  border-radius:999px;
  padding:5px 14px;
  transition:background .2s,border-color .2s;
  white-space:nowrap;
}
.nd-banner a:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.45)}
.nd-close{
  position:absolute;right:clamp(12px,3vw,48px);
  width:28px;height:28px;border-radius:50%;
  background:rgba(0,0,0,.15);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.7);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;
  transition:background .2s,color .2s;
}
.nd-close:hover{background:rgba(0,0,0,.3);color:#fff}
body.nd-active .nav{top:48px}

/* ────────────────────── BEWERTUNGEN ────────────────────── */
.bewertungen{background:var(--snow);padding:var(--section-y) 0}
.bew-head{text-align:center;margin-bottom:48px}
.g-badge{
  display:inline-flex;align-items:center;gap:12px;
  background:#fff;border:1px solid var(--mist);border-radius:999px;
  padding:10px 24px;font-size:14px;font-weight:500;color:var(--graphite);margin-bottom:20px;
}
.g-badge .gstars{color:#FBBC04;font-size:16px;letter-spacing:1px}
.bew-wrap{overflow:hidden;position:relative}
.bew-wrap::before,.bew-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none;
}
.bew-wrap::before{left:0;background:linear-gradient(to right,var(--snow),transparent)}
.bew-wrap::after{right:0;background:linear-gradient(to left,var(--snow),transparent)}
.bew-track{
  display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;padding:8px 64px 28px;-webkit-overflow-scrolling:touch;
}
.bew-track::-webkit-scrollbar{display:none}
.bew-card{
  flex:0 0 330px;scroll-snap-align:start;
  background:#fff;border-radius:20px;padding:26px;
  border:1px solid var(--mist);box-shadow:0 2px 10px rgba(0,0,0,.05);
  transition:box-shadow .3s,transform .3s;
}
.bew-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.1);transform:translateY(-2px)}
.bew-top{display:flex;align-items:center;gap:13px;margin-bottom:14px}
.bew-av{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:18px;font-weight:500;color:#fff;
}
.bew-name{font-weight:600;font-size:14px}
.bew-date{font-size:11px;color:var(--steel);margin-top:2px}
.bew-stars{color:#FBBC04;font-size:16px;letter-spacing:1px;margin-bottom:10px}
.bew-text{font-size:13.5px;line-height:1.7;color:var(--steel)}
.bew-foot{
  display:flex;align-items:center;gap:6px;
  margin-top:16px;padding-top:14px;border-top:1px solid var(--mist);
  font-size:11px;font-weight:600;letter-spacing:.02em;
}
.g-ico span:nth-child(1){color:#4285F4}
.g-ico span:nth-child(2){color:#EA4335}
.g-ico span:nth-child(3){color:#FBBC04}
.g-ico span:nth-child(4){color:#34A853}

/* ────────────────────── EINZUGSGEBIET KARTE ────────────────────── */
.karte-sec{
  background:linear-gradient(150deg,#161d30 0%,#1e2a42 50%,#22283E 100%);
  color:#fff;padding-top:var(--section-y);padding-bottom:0;
  position:relative;overflow:hidden;
}
.karte-sec::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:36px 36px;pointer-events:none;
}
.karte-sec::after{
  content:'';position:absolute;top:-120px;right:-80px;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(49,92,127,.28) 0%,transparent 65%);
  pointer-events:none;
}
.karte-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:0;align-items:flex-end;position:relative;z-index:1}
.karte-text{padding-bottom:64px}
.karte-text .eyebrow{color:var(--ki-gold-soft);letter-spacing:.18em}
.karte-text h2{
  font-family:var(--display);font-size:clamp(40px,4.8vw,72px);
  font-weight:400;letter-spacing:-.03em;line-height:.88;
  color:#fff;margin-top:18px;
}
.karte-text h2 em{color:var(--ki-gold-soft);font-style:italic}
.karte-text p{margin-top:22px;color:rgba(255,255,255,.5);font-size:15.5px;line-height:1.75;max-width:400px}
.karte-stats{display:flex;gap:36px;margin-top:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08)}
.kstat{display:flex;flex-direction:column;gap:4px}
.kstat-num{font-family:var(--display);font-size:32px;font-weight:400;color:#fff;line-height:1}
.kstat-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.karte-van{display:flex;align-items:flex-end;justify-content:flex-end;overflow:visible}
.karte-van img{width:110%;max-width:780px;display:block;
  filter:drop-shadow(0 48px 96px rgba(0,0,0,.65));
  transform:translateX(40px)}
.karte-chips{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:28px 0 52px;
  border-top:1px solid rgba(255,255,255,.07);
  position:relative;z-index:1;
}
.kc-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:7px 15px;border-radius:6px;
  font-size:12.5px;font-weight:400;letter-spacing:.01em;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  color:rgba(255,255,255,.38);
  text-decoration:none;
  transition:all .18s;
}
.kc-chip svg{flex-shrink:0;opacity:.4;transition:opacity .18s}
.kc-chip.active{
  background:rgba(217,163,55,.09);
  border-color:rgba(217,163,55,.28);
  color:rgba(217,163,55,.85);
}
.kc-chip.active svg{opacity:.7;color:var(--ki-gold-soft)}
a.kc-chip:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:#fff}
a.kc-chip:hover svg{opacity:.7}
.kc-more{font-style:italic;background:none;border-style:dashed;color:rgba(255,255,255,.25)}
@media(max-width:1100px){.karte-grid{grid-template-columns:1fr}.karte-van{justify-content:center;margin-top:48px}.karte-van img{width:100%;max-width:520px;transform:none}}
@media(max-width:640px){.karte-text{padding-bottom:16px}.karte-stats{gap:20px;margin-top:20px;padding-top:20px}.kstat-num{font-size:22px}.karte-text h2{font-size:clamp(32px,8vw,52px)}.karte-text p{font-size:14px;margin-top:12px}.karte-van{justify-content:center;margin-top:24px}.karte-van img{max-width:260px;width:100%}}

/* ────────────────────── FAQ ────────────────────── */
.faq-sec{background:#fff;padding:var(--section-y) 0}
.faq-sec .section-head{text-align:center;margin-bottom:52px}
.faq-wrap{max-width:820px;margin:0 auto}
details.faq-item{border-bottom:1px solid var(--mist)}
details.faq-item:first-child{border-top:1px solid var(--mist)}
summary.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:22px 0;cursor:pointer;
  font-weight:500;font-size:17px;color:var(--graphite);
  list-style:none;user-select:none;transition:color .2s;
}
summary.faq-q::-webkit-details-marker{display:none}
summary.faq-q:hover{color:var(--ki-blue)}
.faq-ico{
  flex-shrink:0;width:32px;height:32px;border-radius:50%;
  border:1px solid var(--mist);
  display:flex;align-items:center;justify-content:center;
  color:var(--steel);
  transition:background .25s,border-color .25s,transform .4s cubic-bezier(.16,1,.3,1),color .25s;
}
details[open] summary.faq-q .faq-ico{
  background:var(--ki-blue);border-color:var(--ki-blue);color:#fff;transform:rotate(45deg);
}
.faq-body{
  padding:0 0 22px;font-size:15.5px;line-height:1.7;color:var(--steel);max-width:720px;
  animation:faq-drop .3s cubic-bezier(.16,1,.3,1);
}
@keyframes faq-drop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.faq-body a{color:var(--ki-blue);text-decoration:underline;text-underline-offset:3px}

/* ────────────────────── KONFIGURATOR MODAL ────────────────────── */
.kfg-overlay{
  position:fixed;inset:0;z-index:400;
  background:rgba(23,27,44,.78);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;transition:opacity .35s ease;
}
.kfg-overlay.open{opacity:1;pointer-events:auto}
.kfg-box{
  background:#fff;border-radius:24px;
  width:100%;max-width:560px;max-height:90vh;overflow-y:auto;
  padding:44px;position:relative;
  transform:translateY(28px) scale(.97);
  transition:transform .45s cubic-bezier(.16,1,.3,1);
  box-shadow:0 48px 120px -20px rgba(0,0,0,.45);
}
.kfg-overlay.open .kfg-box{transform:none}
.kfg-close{
  position:absolute;top:18px;right:18px;
  width:34px;height:34px;border-radius:50%;
  background:var(--snow);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;color:var(--steel);transition:background .2s;
}
.kfg-close:hover{background:var(--mist)}
.kfg-prog{display:flex;gap:6px;margin-bottom:32px}
.kfg-seg{height:3px;flex:1;border-radius:999px;background:var(--mist);transition:background .4s}
.kfg-seg.on{background:var(--ki-blue)}
.kfg-ey{font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ki-blue);margin-bottom:10px}
.kfg-tit{font-family:var(--display);font-size:28px;font-weight:400;letter-spacing:-.02em;line-height:1.1;margin-bottom:26px}
.kfg-opts{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:28px}
.kfg-opt{
  border:2px solid var(--mist);border-radius:16px;padding:17px 15px;
  cursor:pointer;text-align:left;background:#fff;
  transition:border-color .25s,background .25s;
}
.kfg-opt:hover{border-color:var(--ki-blue);background:rgba(49,92,127,.03)}
.kfg-opt.sel{border-color:var(--ki-blue);background:rgba(49,92,127,.07)}
.kfg-opt-ic{font-size:22px;margin-bottom:7px}
.kfg-opt-lb{font-weight:600;font-size:14px;line-height:1.3;color:var(--graphite)}
.kfg-opt-sb{font-size:12px;color:var(--steel);margin-top:3px}
.kfg-r{margin-bottom:18px}
.kfg-r label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--graphite)}
.kfg-r input,.kfg-r textarea{
  width:100%;padding:12px 15px;border:1.5px solid var(--mist);border-radius:12px;
  font:inherit;font-size:15px;color:var(--graphite);background:#fff;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.kfg-r input:focus,.kfg-r textarea:focus{border-color:var(--ki-blue);box-shadow:0 0 0 3px rgba(49,92,127,.12)}
.kfg-r textarea{resize:vertical;min-height:76px}
.kfg-r2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kfg-acts{display:flex;gap:12px;margin-top:10px}
.kfg-back{
  background:none;border:1.5px solid var(--mist);border-radius:999px;
  padding:13px 21px;font:inherit;font-size:14px;font-weight:500;color:var(--steel);cursor:pointer;
  transition:border-color .2s,color .2s;
}
.kfg-back:hover{border-color:var(--graphite);color:var(--graphite)}
.kfg-next{
  flex:1;background:var(--ki-blue);color:#fff;border:none;
  border-radius:999px;padding:15px 24px;font:inherit;font-size:15px;font-weight:500;cursor:pointer;
  box-shadow:0 8px 22px -8px rgba(49,92,127,.5);transition:background .2s,transform .2s;
}
.kfg-next:hover{background:var(--ki-blue-light);transform:translateY(-1px)}
.kfg-step{display:none}.kfg-step.on{display:block}
.kfg-done{text-align:center;padding:16px 0}
.kfg-done-ic{
  width:60px;height:60px;border-radius:50%;background:rgba(49,92,127,.1);
  display:flex;align-items:center;justify-content:center;margin:0 auto 20px;
}
.kfg-done h3{font-family:var(--display);font-size:26px;font-weight:400;margin-bottom:10px}
.kfg-done p{color:var(--steel);font-size:14.5px;line-height:1.7}
@media(max-width:560px){
  .kfg-box{padding:28px 20px}
  .kfg-opts{grid-template-columns:1fr}
  .kfg-r2{grid-template-columns:1fr}
  .bew-card{flex-basis:280px}
}

/* ── Footer Einzugsgebiet-Block ── */
.einzugsgebiet{
  grid-column:1 / -1;
  margin-top:48px;
  padding-top:48px;
  border-top:1px solid rgba(255,255,255,.1);
}
.einzugsgebiet h5{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ki-gold-soft);
  margin-bottom:24px;font-weight:500;
}
.einzug-links{
  display:flex;flex-wrap:wrap;gap:10px 12px;
}
.einzug-links a{
  display:inline-block;
  padding:10px 18px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  font-size:13px;
  color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.03);
  transition:background .25s, border-color .25s, color .25s, transform .25s;
}
.einzug-links a:hover{
  background:var(--ki-blue);
  border-color:var(--ki-blue);
  color:#fff;
  transform:translateY(-2px);
}
.einzug-links a[aria-current="page"]{
  background:var(--ki-gold);
  border-color:var(--ki-gold);
  color:var(--graphite);
}

/* ═══════════════════════════════════════════════════════════
   KONFIGURATOR — Sofort-Rechner
═══════════════════════════════════════════════════════════ */
.kalk-section {
  background: var(--frost-night);
  color: #fff;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.kalk-section .section-head h2,
.kalk-section .section-head p { color: #fff; }
.kalk-section .eyebrow { color: var(--ki-gold-soft); }

.kalk-wrap {
  max-width: 860px;
  margin: 0 auto;
}

/* Progress bar */
.kalk-progress {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 48px;
}
.kalk-step-dot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  flex: 1;
}
.kalk-dot-circle {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.04);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,.3);
  transition: all .35s ease;
  position: relative;
  z-index: 2;
}
.kalk-dot-label {
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
  text-align: center;
  transition: color .35s ease;
  white-space: nowrap;
}
.kalk-step-dot.active .kalk-dot-circle {
  border-color: var(--ki-gold);
  background: rgba(217,163,55,.15);
  color: var(--ki-gold);
  box-shadow: 0 0 20px rgba(217,163,55,.25);
}
.kalk-step-dot.active .kalk-dot-label { color: var(--ki-gold); }
.kalk-step-dot.done .kalk-dot-circle {
  border-color: rgba(217,163,55,.4);
  background: rgba(217,163,55,.08);
  color: rgba(217,163,55,.6);
}
.kalk-step-dot.done .kalk-dot-label { color: rgba(255,255,255,.4); }
.kalk-connector {
  flex: 2;
  height: 1px;
  background: rgba(255,255,255,.08);
  position: relative;
  top: -12px;
  transition: background .35s ease;
}
.kalk-connector.done { background: rgba(217,163,55,.3); }

/* Steps */
.kalk-step-panel {
  display: none;
  animation: kalkFadeIn .4s ease;
}
.kalk-step-panel.active { display: block; }

@keyframes kalkFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.kalk-question {
  font-family: var(--display, 'Syne', sans-serif);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 700;
  color: #fff;
  margin-bottom: 28px;
  letter-spacing: -.02em;
}

/* Option cards */
.kalk-cards {
  display: grid;
  gap: 14px;
}
.kalk-cards.cols-3 { grid-template-columns: repeat(3, 1fr); }
.kalk-cards.cols-4 { grid-template-columns: repeat(4, 1fr); }

.kalk-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 16px;
  padding: 28px 20px;
  cursor: pointer;
  transition: all .25s ease;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  user-select: none;
}
.kalk-card:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.2);
  transform: translateY(-2px);
}
.kalk-card.selected {
  border-color: var(--ki-gold);
  background: rgba(217,163,55,.08);
  box-shadow: 0 0 32px rgba(217,163,55,.1), inset 0 1px 0 rgba(217,163,55,.15);
}
.kalk-card-ico {
  font-size: 32px;
  line-height: 1;
}
.kalk-card-label {
  font-size: 14px;
  font-weight: 600;
  color: rgba(255,255,255,.8);
  letter-spacing: .01em;
  line-height: 1.3;
}
.kalk-card.selected .kalk-card-label { color: var(--ki-gold-soft); }

/* Slider step */
.kalk-slider-wrap {
  padding: 8px 0;
}
.kalk-slider-val {
  font-family: var(--mono);
  font-size: clamp(52px, 7vw, 80px);
  font-weight: 700;
  color: var(--ki-gold);
  letter-spacing: -.04em;
  line-height: 1;
  margin-bottom: 6px;
}
.kalk-slider-unit {
  font-size: 20px;
  color: rgba(255,255,255,.4);
  font-weight: 400;
  margin-left: 4px;
}
.kalk-slider-hint {
  font-size: 13px;
  color: rgba(255,255,255,.3);
  margin-bottom: 32px;
  font-style: italic;
}
input[type=range].kalk-range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,.1);
  outline: none;
  cursor: pointer;
  margin: 0;
}
input[type=range].kalk-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--ki-gold);
  border: 3px solid var(--ki-navy-deep);
  box-shadow: 0 0 12px rgba(217,163,55,.4);
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
input[type=range].kalk-range::-webkit-slider-thumb:hover {
  transform: scale(1.15);
  box-shadow: 0 0 20px rgba(217,163,55,.6);
}
input[type=range].kalk-range::-moz-range-thumb {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--ki-gold);
  border: 3px solid var(--ki-navy-deep);
  cursor: pointer;
}
.kalk-range-labels {
  display: flex;
  justify-content: space-between;
  margin-top: 12px;
  font-size: 12px;
  color: rgba(255,255,255,.25);
  font-family: var(--mono);
}

/* Nav buttons */
.kalk-nav {
  margin-top: 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.kalk-back {
  background: none;
  border: none;
  color: rgba(255,255,255,.35);
  font-size: 14px;
  cursor: pointer;
  padding: 8px 0;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-family: var(--mono);
  transition: color .2s;
}
.kalk-back:hover { color: rgba(255,255,255,.7); }
.kalk-back[hidden] { visibility: hidden; }

/* Result */
.kalk-result {
  display: none;
  animation: kalkFadeIn .5s ease;
}
.kalk-result.active { display: block; }

.kalk-result-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(217,163,55,.1);
  border: 1px solid rgba(217,163,55,.25);
  border-radius: 100px;
  padding: 6px 16px;
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ki-gold);
  margin-bottom: 24px;
  font-family: var(--mono);
}

.kalk-result-system {
  font-family: var(--display, 'Syne', sans-serif);
  font-size: clamp(26px, 3.5vw, 40px);
  font-weight: 700;
  color: #fff;
  letter-spacing: -.025em;
  margin-bottom: 8px;
}

.kalk-result-price {
  font-family: var(--mono);
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 700;
  color: var(--ki-gold);
  letter-spacing: -.04em;
  line-height: 1;
  margin-bottom: 4px;
}

.kalk-result-info {
  font-size: 15px;
  color: rgba(255,255,255,.45);
  margin-bottom: 36px;
  max-width: 480px;
  line-height: 1.6;
}

.kalk-result-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: end;
}

.kalk-result-disclaimer {
  font-size: 12px;
  color: rgba(255,255,255,.2);
  line-height: 1.6;
  max-width: 380px;
}

.kalk-reset {
  background: none;
  border: none;
  color: rgba(255,255,255,.3);
  font-size: 13px;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-family: var(--mono);
  padding: 0;
  margin-top: 16px;
  display: block;
  transition: color .2s;
}
.kalk-reset:hover { color: rgba(255,255,255,.6); }

/* ═══════════════════════════════════════════════════════════
   ENERGIESPAR-RECHNER
═══════════════════════════════════════════════════════════ */
.spar-section {
  background: var(--ki-navy);
  color: #fff;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.spar-section .section-head h2,
.spar-section .section-head p { color: #fff; }
.spar-section .eyebrow { color: var(--ki-gold-soft); }

.spar-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: start;
}

/* Sliders panel */
.spar-controls {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.spar-slider-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.spar-slider-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.spar-slider-label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.4);
  font-family: var(--mono);
}

.spar-slider-val {
  font-family: var(--mono);
  font-size: 22px;
  font-weight: 700;
  color: var(--ki-gold);
  transition: all .2s ease;
}

input[type=range].spar-range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 3px;
  border-radius: 2px;
  background: rgba(255,255,255,.1);
  outline: none;
  cursor: pointer;
}
input[type=range].spar-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--ki-gold);
  border: 2px solid var(--ki-navy-deep);
  box-shadow: 0 0 10px rgba(217,163,55,.35);
  cursor: pointer;
  transition: transform .15s ease;
}
input[type=range].spar-range::-webkit-slider-thumb:hover {
  transform: scale(1.2);
}
input[type=range].spar-range::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--ki-gold);
  border: 2px solid var(--ki-navy-deep);
}

/* Results panel */
.spar-results {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: 100px;
}

/* Comparison cards */
.spar-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.spar-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 20px 18px;
}
.spar-card.alt { border-color: rgba(255,255,255,.08); }
.spar-card.neu {
  border-color: rgba(78,124,163,.4);
  background: rgba(78,124,163,.06);
}

.spar-card-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.3);
  font-family: var(--mono);
  margin-bottom: 14px;
}
.spar-card.neu .spar-card-label { color: var(--ki-blue-soft); }

.spar-card-eer {
  font-family: var(--mono);
  font-size: 13px;
  color: rgba(255,255,255,.35);
  margin-bottom: 10px;
}
.spar-card.neu .spar-card-eer { color: rgba(123,160,194,.7); }

.spar-card-kwh {
  font-family: var(--mono);
  font-size: 24px;
  font-weight: 700;
  color: rgba(255,255,255,.5);
  margin-bottom: 4px;
}
.spar-card.neu .spar-card-kwh { color: var(--ki-blue-soft); }

.spar-card-cost {
  font-size: 13px;
  color: rgba(255,255,255,.25);
  font-family: var(--mono);
}
.spar-card.neu .spar-card-cost { color: rgba(123,160,194,.5); }

/* Big savings */
.spar-savings {
  background: rgba(217,163,55,.08);
  border: 1px solid rgba(217,163,55,.2);
  border-radius: 14px;
  padding: 28px 24px;
  text-align: center;
}

.spar-savings-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(217,163,55,.6);
  font-family: var(--mono);
  margin-bottom: 8px;
}

.spar-savings-num {
  font-family: var(--mono);
  font-size: clamp(40px, 5vw, 58px);
  font-weight: 700;
  color: var(--ki-gold);
  letter-spacing: -.04em;
  line-height: 1;
  transition: opacity .2s ease;
}

.spar-savings-unit {
  font-size: 16px;
  font-weight: 400;
  opacity: .6;
}

/* Meta row */
.spar-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.spar-meta-card {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  padding: 16px;
}
.spar-meta-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.25);
  font-family: var(--mono);
  margin-bottom: 8px;
}
.spar-meta-val {
  font-family: var(--mono);
  font-size: 20px;
  font-weight: 700;
  color: rgba(255,255,255,.7);
  transition: opacity .2s ease;
}
.spar-meta-val span { font-size: 13px; font-weight: 400; color: rgba(255,255,255,.3); }

.spar-cta-wrap {
  margin-top: 8px;
}

/* Update flash */
@keyframes sparFlash {
  0%   { opacity: .4; }
  100% { opacity: 1; }
}
.spar-updating {
  animation: sparFlash .25s ease forwards;
}

/* Responsive */
@media (max-width: 900px) {
  .kalk-cards.cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .kalk-cards.cols-3 { grid-template-columns: 1fr 1fr; }
  .kalk-cards.cols-4 { grid-template-columns: 1fr 1fr; }
  .kalk-result-grid { grid-template-columns: 1fr; }
  .spar-layout { grid-template-columns: 1fr; gap: 40px; }
  .spar-results { position: static; }
  .kalk-progress { gap: 0; }
  .kalk-dot-label { display: none; }
}
@media (max-width: 480px) {
  .kalk-cards.cols-3 { grid-template-columns: 1fr; }
  .spar-cards { grid-template-columns: 1fr; }
  .spar-meta { grid-template-columns: 1fr; }
}

