







: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 — kein weißer Kasten */
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:auto;
  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;
}
.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)}
}

@media (max-width:900px){
  .hero{padding-top:120px;align-items:center}
  .hero-grid{grid-template-columns:1fr;gap:24px}
  .hero-side{align-items:flex-start}
  .hero-quickcard{max-width:none}
  .hero h1 .line2{padding-left:0}
  .hero-livebar{grid-template-columns:1fr;gap:18px;margin-top:48px}
  .live-num{font-size:22px}
}

/* ────────────────────── 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{
  display:flex;align-items:center;gap:48px;flex-wrap:wrap;
  font-family:var(--display);
  color:#9aa3b2;
}
.trust-logos span{
  font-size:22px;letter-spacing:-.01em;font-weight:500;
  transition:color .3s, transform .3s;
}
.trust-logos span:hover{color:var(--graphite);transform:translateY(-1px)}

/* ────────────────────── 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}}

/* ────────────────────── 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:56px;
  border-bottom:none;
}
.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}

/* ── Einzugsgebiet als eigene Row unter den Haupt-Cols ── */
.foot-cities{
  max-width:1440px;
  margin:0 auto;
  padding:48px 0 56px;
  border:none;
  display:grid;
  grid-template-columns:minmax(220px, 300px) 1fr;
  gap:64px;
  align-items:start;
}
.foot-cities-head h5{
  font-family:var(--display);
  font-size:28px;
  font-weight:400;
  line-height:1.05;
  letter-spacing:-.015em;
  color:#fff;
  margin:0;
}
.foot-cities-head h5 em{font-style:italic;color:var(--ki-gold-soft)}
.foot-cities-head .eyebrow{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin-bottom:14px;display:block;
}
.foot-cities-head p{
  font-size:13px;line-height:1.65;
  color:rgba(255,255,255,.5);
  max-width:260px;
  margin-top:14px;
}
.foot-cities-list{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:8px 32px;
  align-content:start;
  padding-top:6px;
}
.foot-cities-list a{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  padding:5px 0;
  color:rgba(255,255,255,.72);
  transition:color .2s, transform .2s;
}
.foot-cities-list a::before{
  content:'';
  width:4px;height:4px;border-radius:50%;
  background:rgba(255,255,255,.18);
  transition:background .2s, transform .2s, box-shadow .2s;
  flex-shrink:0;
}
.foot-cities-list a:hover{color:#fff;transform:translateX(2px)}
.foot-cities-list a:hover::before{background:var(--ki-gold-soft)}
.foot-cities-list a[aria-current="page"]{
  color:var(--ki-gold-soft);
  font-weight:500;
}
.foot-cities-list a[aria-current="page"]::before{
  background:var(--ki-gold-soft);
  box-shadow:0 0 0 3px rgba(217,163,55,.18);
}
.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);
  border:none;
}
.foot-bottom a{color:rgba(255,255,255,.55)}
.foot-bottom a:hover{color:#fff}
@media (max-width:1100px){
  .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
  .foot-cities{grid-template-columns:1fr;gap:28px;padding:44px 0}
  .foot-cities-list{grid-template-columns:repeat(3, 1fr);gap:6px 24px}
}
@media (max-width:820px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
  .foot-cities-list{grid-template-columns:repeat(2, 1fr)}
  .foot-cities-head h5{font-size:24px}
}
@media (max-width:520px){
  .foot-grid{grid-template-columns:1fr}
  .foot-cities-list{grid-template-columns:1fr;gap:4px}
}

/* ────────────────────── 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}


/* inherit subpage-hero/content styles from build_pages.py */
.page-hero{position:relative;background:var(--ki-navy-deep);color:#fff;padding:200px var(--pad-x) 120px;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.06)}
.page-hero::after{content:'';position:absolute;inset:0;background-image:url('../images/kk-pattern-tile.png');background-size:30px auto;background-repeat:repeat;background-position:right center;opacity:.08;pointer-events:none;z-index:1;mask-image:linear-gradient(to left, black 0%, rgba(0,0,0,.6) 20%, rgba(0,0,0,.1) 35%, transparent 40%);-webkit-mask-image:linear-gradient(to left, black 0%, rgba(0,0,0,.6) 20%, rgba(0,0,0,.1) 35%, transparent 40%)}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%, rgba(49,92,127,.35), transparent 60%),radial-gradient(ellipse at 20% 80%, rgba(49,92,127,.15), transparent 55%)}
.page-hero-inner{position:relative;max-width:1440px;margin:0 auto;z-index:2}
.page-hero .eyebrow{color:var(--ki-gold-soft);margin-bottom:24px}
.page-hero h1{font-family:var(--display);font-weight:300;font-size:clamp(44px,6.5vw,88px);line-height:.98;letter-spacing:-.03em;color:#fff;max-width:900px;font-variation-settings:"opsz" 144,"SOFT" 50}
.page-hero h1 em{font-style:italic;color:var(--ki-gold-soft);font-weight:400}
.page-hero p.lead{margin-top:28px;font-size:clamp(16px,1.3vw,20px);color:rgba(255,255,255,.7);max-width:680px;line-height:1.55}
.page-hero .hero-cta{margin-top:40px;display:flex;gap:14px;flex-wrap:wrap}
.hero-notdienst{display:none}
@media(max-width:900px){
  .hero-notdienst{display:flex;align-items:center;gap:10px;background:rgba(255,75,55,.1);border:1px solid rgba(255,75,55,.22);border-radius:12px;padding:12px 16px;margin-top:16px;color:#fff;font-size:13px}
  .hero-notdienst .notdienst-badge{background:#ff5a3c;color:#fff;font-size:10px;font-weight:700;letter-spacing:.08em;padding:2px 7px;border-radius:6px;flex-shrink:0}
  .hero-notdienst a{color:var(--ki-gold-soft);text-decoration:none;margin-left:auto;white-space:nowrap}
}
.crumb{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:32px}
.crumb a{color:rgba(255,255,255,.75)}
.crumb a:hover{color:#fff}
.crumb::before{content:'';width:24px;height:1px;background:currentColor;opacity:.6}
.content{padding:var(--section-y) var(--pad-x);background:#fff}
.content.alt{background:var(--snow)}
.content-inner{max-width:1440px;margin:0 auto}
.content h2{font-family:var(--display);font-weight:400;font-size:clamp(32px,4.5vw,56px);line-height:1.02;letter-spacing:-.025em;max-width:900px;margin-bottom:32px}
.content h2 em{font-style:italic;color:var(--ki-blue)}
.content h3{font-family:var(--display);font-weight:500;font-size:clamp(22px,2vw,28px);line-height:1.15;letter-spacing:-.015em;margin-bottom:14px;color:var(--graphite)}
.content p{color:var(--steel);font-size:17px;line-height:1.7;max-width:760px;margin-bottom:18px}
.content p.lead{font-size:19px;color:var(--graphite);max-width:780px;margin-bottom:40px}
.content ul{margin:18px 0 28px 0;padding:0;list-style:none;max-width:720px}
.content ul li{position:relative;padding:14px 0 14px 36px;color:var(--graphite);font-size:16px;line-height:1.55;border-top:1px solid var(--mist)}
.content ul li:last-child{border-bottom:1px solid var(--mist)}
.content ul li::before{content:'';position:absolute;left:0;top:22px;width:18px;height:2px;background:var(--ki-blue)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr 1fr;gap:20px}.page-hero{padding:160px var(--pad-x) 80px}}
@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:16px}}
/* ── Price Cards ── */
.price-card{background:#fff;border:1px solid var(--mist);border-radius:20px;padding:40px 36px;display:flex;flex-direction:column;gap:0;position:relative;transition:transform .35s ease,box-shadow .35s ease,border-color .3s}
.price-card:hover{transform:translateY(-4px);box-shadow:0 24px 56px -20px rgba(11,29,55,.18);border-color:#cbd5e8}
.price-card.featured{border-color:var(--ki-gold);box-shadow:0 8px 40px -12px rgba(217,163,55,.25)}
.price-card.featured:hover{box-shadow:0 24px 56px -16px rgba(217,163,55,.35)}
.price-card .badge{display:inline-block;background:var(--ki-gold);color:var(--graphite);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 12px;border-radius:100px;margin-bottom:16px;font-family:var(--mono)}
.price-card h3{font-family:var(--display);font-size:clamp(20px,1.8vw,26px);font-weight:500;color:var(--graphite);margin-bottom:8px;letter-spacing:-.02em}
.price-card .tagline{font-size:13px;color:var(--steel);margin-bottom:20px}
.price-card .price-amount{font-family:var(--mono);font-size:clamp(26px,2.5vw,36px);font-weight:700;color:var(--ki-navy-deep);letter-spacing:-.03em;line-height:1;margin-bottom:4px}
.price-card .price-from{font-size:12px;color:var(--steel);margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--mist)}
.price-card ul{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:0;flex:1}
.price-card ul li{font-size:14px;color:var(--graphite);padding:10px 0 10px 0;border-top:none;border-bottom:1px solid var(--mist);display:flex;align-items:center;gap:10px;position:static}
.price-card ul li:last-child{border-bottom:none}
.price-card ul li::before{content:'';position:static;display:inline-block;width:18px;height:2px;min-width:18px;background:var(--ki-blue);flex-shrink:0;top:auto;left:auto}
.price-card .btn{margin-top:auto;text-align:center;justify-content:center}
/* ── Contact Page ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:0}
.info-row{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid var(--mist)}
.info-row:first-of-type{border-top:1px solid var(--mist);margin-top:32px}
.info-row .ico{width:36px;height:36px;background:var(--ki-navy-deep);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.info-row .ico svg{width:16px;height:16px;stroke:#fff}
.info-row .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--steel);margin-bottom:4px;font-family:var(--mono)}
.info-row .val{font-size:15px;color:var(--graphite);line-height:1.5}
.info-row .val a{color:var(--graphite);text-decoration:none;transition:color .2s}
.info-row .val a:hover{color:var(--ki-blue)}
/* Contact Form */
.contact{background:#fff;border:1px solid var(--mist);border-radius:24px;padding:48px 44px}
.contact h3{margin-bottom:0}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}
.field.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field.row > div{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--steel)}
.field input,.field select,.field textarea{border:1px solid var(--mist);border-radius:10px;padding:12px 16px;font-size:15px;font-family:inherit;color:var(--graphite);background:#fff;transition:border-color .2s,box-shadow .2s;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ki-blue);box-shadow:0 0 0 3px rgba(49,92,127,.1)}
.field textarea{min-height:120px;resize:vertical}
.check{display:flex;align-items:flex-start;gap:12px;font-size:13px;color:var(--steel);margin-bottom:24px;cursor:pointer}
.check input[type=checkbox]{width:16px;height:16px;flex-shrink:0;margin-top:2px;accent-color:var(--ki-blue)}
.contact button[type=submit]{width:100%;padding:16px;background:var(--ki-navy-deep);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;letter-spacing:.02em;transition:background .2s,transform .15s}
.contact button[type=submit]:hover{background:var(--ki-blue);transform:translateY(-1px)}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:48px}.field.row{grid-template-columns:1fr}.contact{padding:32px 28px}}
/* ── Info Cards ── */
.info-card{background:#fff;border:1px solid var(--mist);border-radius:20px;padding:36px 32px;transition:transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s, border-color .3s}
.info-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -24px rgba(11,29,55,.2);border-color:#cbd5e8}
.info-card .num{font-family:var(--mono);font-size:13px;color:var(--ki-blue);letter-spacing:.1em;margin-bottom:16px;display:block}
.info-card h3{font-size:22px;margin-bottom:12px}
.info-card p{font-size:15px;margin-bottom:0;line-height:1.65}
.cta-banner{background:var(--ki-navy-deep);color:#fff;padding:var(--section-y) var(--pad-x);text-align:center;position:relative;overflow:hidden}
/* ── Notdienst Page — Red Emergency Theme ── */
body.notdienst .page-hero{background:#1a0505;overflow:hidden}
body.notdienst .page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(200,30,20,.55),transparent 55%),radial-gradient(ellipse at 80% 20%,rgba(140,10,10,.3),transparent 50%)}
body.notdienst .page-hero::after{background-image:url('../images/kk-pattern-tile.png');background-size:30px auto;background-repeat:repeat;opacity:.04}
body.notdienst .page-hero .crumb{color:rgba(255,120,100,.7)}
body.notdienst .page-hero h1 em{color:#ff7060}
body.notdienst .page-hero .btn-ghost{border-color:rgba(255,255,255,.25);color:#fff}
/* Pulsing alarm dot in hero */
body.notdienst .page-hero-inner::before{content:'● NOTDIENST AKTIV';display:inline-flex;align-items:center;gap:8px;background:rgba(220,30,20,.2);border:1px solid rgba(220,30,20,.4);border-radius:100px;padding:6px 16px;font-size:11px;font-weight:700;letter-spacing:.14em;color:#ff6050;font-family:var(--mono);margin-bottom:24px;animation:nd-blink 2s ease-in-out infinite}
@keyframes nd-blink{0%,100%{opacity:1}50%{opacity:.5}}
/* Emergency call section */
.emergency{background:#130202;color:#fff;padding:80px var(--pad-x);text-align:center;border-top:1px solid rgba(220,30,20,.2);border-bottom:1px solid rgba(220,30,20,.2);position:relative;overflow:hidden}
.emergency::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(180,20,10,.25),transparent 65%);pointer-events:none}
.emergency h2{font-family:var(--display);font-weight:300;font-size:clamp(36px,5vw,64px);letter-spacing:-.025em;color:#fff;margin-bottom:16px;position:relative}
.emergency p{color:rgba(255,255,255,.55);font-size:18px;max-width:560px;margin:0 auto 40px;line-height:1.6;position:relative}
/* Pulsing phone button */
.phone-big{display:inline-flex;align-items:center;gap:16px;background:#c01a0e;border:none;border-radius:100px;padding:20px 40px;color:#fff;text-decoration:none;font-family:var(--mono);font-size:clamp(22px,3vw,36px);font-weight:700;letter-spacing:.04em;position:relative;transition:transform .2s,box-shadow .25s;box-shadow:0 0 0 0 rgba(192,26,14,.5);animation:nd-pulse 2.4s ease-out infinite}
.phone-big:hover{transform:scale(1.04);box-shadow:0 16px 48px -8px rgba(192,26,14,.6);animation:none}
.phone-big svg{width:28px;height:28px;flex-shrink:0;stroke:#fff}
@keyframes nd-pulse{0%{box-shadow:0 0 0 0 rgba(192,26,14,.55)}70%{box-shadow:0 0 0 22px rgba(192,26,14,0)}100%{box-shadow:0 0 0 0 rgba(192,26,14,0)}}
/* ── Check List (Festpreis etc.) ── */
.check-list{display:flex;flex-direction:column;gap:0}
.check-item{display:flex;align-items:flex-start;gap:16px;padding:22px 0;border-bottom:1px solid var(--mist)}
.check-item:first-child{border-top:1px solid var(--mist)}
.check-ico{width:28px;height:28px;border-radius:50%;background:var(--ki-navy-deep);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;margin-top:2px}
.check-item > div{flex:1}
.check-item > div > p{font-size:13px;color:var(--steel);margin:4px 0 0;line-height:1.55}
.check-item > div > strong,.check-item > div:first-of-type{font-size:15px;font-weight:600;color:var(--graphite);line-height:1.4}
/* first direct text node — style the label */
.check-item > div{font-size:15px;font-weight:600;color:var(--graphite)}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center, rgba(49,92,127,.3), transparent 60%)}
.cta-banner-inner{position:relative;max-width:900px;margin:0 auto;z-index:2}
.cta-banner h2{font-family:var(--display);font-weight:300;font-size:clamp(32px,5vw,64px);line-height:1;letter-spacing:-.025em;color:#fff;margin-bottom:20px}
.cta-banner h2 em{font-style:italic;color:var(--ki-gold-soft)}
.cta-banner p{color:rgba(255,255,255,.65);font-size:18px;margin-bottom:36px}
.cta-banner .btn-group{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* ── 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);
}










/* ────────────────────── LONGREAD CONTENT ────────────────────── */

      .longread{max-width:760px;margin:80px auto 0;font-size:18px;line-height:1.78;color:rgba(10,26,46,.82);font-feature-settings:"kern","liga","ss01";counter-reset:chapter;position:relative}
      .longread::before{content:"";position:absolute;left:50%;top:-40px;transform:translateX(-50%);width:1px;height:56px;background:linear-gradient(to bottom,transparent,var(--ki-gold))}
      .longread > h3{font-family:var(--display);font-weight:400;font-size:clamp(28px,2.8vw,40px);line-height:1.08;letter-spacing:-.018em;color:var(--ki-navy-deep);margin:96px 0 28px;padding-top:40px;border-top:1px solid rgba(10,26,46,.12);position:relative;counter-increment:chapter;max-width:640px}
      .longread > h3::before{content:"Kapitel " counter(chapter,decimal-leading-zero);display:block;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ki-orange);margin-bottom:20px}
      .longread > h3 em{font-style:italic;color:var(--ki-blue);font-weight:300;display:block}
      .longread p{margin:0 0 26px;hyphens:auto;-webkit-hyphens:auto}
      .longread p strong{color:var(--ki-navy-deep);font-weight:600;background-image:linear-gradient(transparent 78%,rgba(217,163,55,.28) 78%,rgba(217,163,55,.28) 96%,transparent 96%);padding:0 1px}
      .longread p.dropcap{font-size:19px;line-height:1.72}
      .longread p.dropcap::first-letter{font-family:var(--display);float:left;font-size:116px;line-height:.78;padding:12px 18px 0 0;color:var(--ki-blue);font-weight:400;font-style:italic;text-shadow:0 2px 0 rgba(49,92,127,.08)}
      .longread .pullquote{position:relative;margin:64px -48px;padding:56px 64px 48px;background:var(--ki-navy-deep);color:#fff;border-radius:2px;font-family:var(--display);font-style:italic;font-size:clamp(22px,2.2vw,30px);line-height:1.35;font-weight:300;letter-spacing:-.008em;overflow:hidden}
      .longread .pullquote::before{content:"\201C";position:absolute;top:-28px;left:44px;font-family:var(--display);font-size:180px;line-height:1;color:var(--ki-gold);font-style:italic;opacity:.9}
      .longread .pullquote::after{content:"";position:absolute;right:0;bottom:0;width:160px;height:160px;background:radial-gradient(circle at bottom right,rgba(176,69,37,.22),transparent 70%);pointer-events:none}
      .longread .pullquote span{display:block;margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.14);font-family:var(--mono);font-style:normal;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500}
      .longread .entity-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin:56px 0 64px;background:#fff;border:1px solid rgba(10,26,46,.1);border-radius:3px;overflow:hidden;box-shadow:0 20px 60px -30px rgba(10,26,46,.18)}
      .longread .entity-grid > div{padding:28px 32px;border-right:1px solid rgba(10,26,46,.08);border-bottom:1px solid rgba(10,26,46,.08);position:relative}
      .longread .entity-grid > div::before{content:"";position:absolute;top:0;left:0;width:24px;height:1px;background:var(--ki-orange)}
      .longread .entity-grid > div:nth-child(2n){border-right:none}
      .longread .entity-grid > div:nth-last-child(-n+2){border-bottom:none}
      .longread .entity-grid div span{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ki-orange);margin-bottom:12px;font-weight:500}
      .longread .entity-grid div strong{display:block;font-family:var(--display);font-size:17px;font-weight:400;color:var(--ki-navy-deep);line-height:1.35;letter-spacing:-.005em}
      .longread > p:last-of-type{font-family:var(--display);font-size:clamp(20px,1.9vw,24px);line-height:1.45;font-style:italic;color:var(--ki-navy-deep);font-weight:300;margin-top:64px;padding-top:48px;border-top:1px solid rgba(10,26,46,.12);letter-spacing:-.01em}
      @media (max-width:800px){
        .longread{font-size:16px;line-height:1.72;margin-top:56px}
        .longread > h3{margin:72px 0 22px;padding-top:32px}
        .longread p.dropcap{font-size:17px}
        .longread p.dropcap::first-letter{font-size:82px;padding:8px 12px 0 0}
        .longread .pullquote{margin:44px 0;padding:44px 28px 36px;font-size:19px}
        .longread .pullquote::before{left:20px;top:-18px;font-size:120px}
        .longread .entity-grid{grid-template-columns:1fr;margin:40px 0 48px}
        .longread .entity-grid > div{border-right:none;padding:22px 24px}
        .longread .entity-grid > div:nth-last-child(2){border-bottom:1px solid rgba(10,26,46,.08)}
        .longread > p:last-of-type{font-size:19px;margin-top:48px;padding-top:36px}
      }
    


/* ═══════════════════════════════════════════════════════════
   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; }
}

