/*
 * WohlfühlCloud – Design v5
 * Inspired by: Hetzner · IONOS · Mittwald
 * Clean white/blue B2B professional layout
 */

/* ── Tokens ────────────────────────────────────────────────────────────── */
:root {
  --blue:       #2563EB;
  --blue-dark:  #1D4ED8;
  --blue-deep:  #1E3A8A;
  --blue-navy:  #0F172A;
  --blue-100:   #DBEAFE;
  --blue-50:    #EFF6FF;
  --blue-600:   #2563EB;

  --white:  #FFFFFF;
  --bg:     #F8FAFF;   /* barely-there blue tint */
  --bg-2:   #F3F4F6;

  --text:   #111827;
  --body:   #374151;
  --muted:  #6B7280;
  --subtle: #9CA3AF;

  --border: #E5E7EB;
  --border-blue: #BFDBFE;

  --green: #22C55E;
  --amber: #F59E0B;
  --red:   #EF4444;

  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --shadow-xs: 0 1px 2px rgba(0,0,0,.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,.09), 0 2px 4px rgba(0,0,0,.04);
  --shadow-lg: 0 10px 30px rgba(0,0,0,.10), 0 4px 8px rgba(0,0,0,.05);
  --shadow-xl: 0 20px 50px rgba(0,0,0,.12), 0 8px 16px rgba(0,0,0,.06);
  --shadow-blue: 0 4px 16px rgba(37,99,235,.30);

  --r:    8px;
  --r-lg: 14px;
  --r-xl: 20px;

  --wrap:    1160px;
  --px:      clamp(1.25rem, 5vw, 2.5rem);
  --section: clamp(4rem, 7vw, 6rem);

  --t: 180ms cubic-bezier(.4,0,.2,1);
}

/* ── Reset ─────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);font-size:1rem;line-height:1.65;color:var(--body);background:var(--white);-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:var(--blue);text-decoration:underline;text-underline-offset:.2em;transition:color var(--t)}
a:hover{color:var(--blue-dark)}
ul,ol{list-style:none}
dd{margin:0}
address{font-style:normal}
p{max-width:68ch}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── Layout ─────────────────────────────────────────────────────────────── */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--px)}
.section{padding-block:var(--section)}
.section--bg  {background:var(--bg)}
.section--bg2 {background:var(--bg-2)}
.section--blue-tint{background:var(--blue-50)}
.section--dark{background:var(--blue-navy);color:rgba(255,255,255,.8)}

/* ── Typography ─────────────────────────────────────────────────────────── */
h1,h2,h3,h4{color:var(--text);font-weight:700;line-height:1.15;letter-spacing:-.022em}
h1{font-size:clamp(2rem,5vw,3.25rem)}
h2{font-size:clamp(1.625rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.125rem,2vw,1.375rem)}
h4{font-size:1rem;font-weight:600}

.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}

/* Eyebrow / Tag */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.6875rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue);margin-bottom:1rem;
}
.eyebrow::before{content:'';display:block;width:1.5rem;height:2px;background:var(--blue);border-radius:1px;flex-shrink:0}

/* Section heading block */
.sh{margin-bottom:3.5rem}
.sh--c{text-align:center}
.sh--c p,.sh--c .eyebrow{margin-inline:auto}
.sh h2{margin-bottom:1rem}
.sh p{font-size:1.0625rem;color:var(--muted);line-height:1.75;max-width:54ch}
.sh--c p{max-width:50ch}
.section--dark .eyebrow{color:var(--blue-100)}
.section--dark .sh p{color:rgba(255,255,255,.6)}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75em 1.75em;border-radius:var(--r);
  font-family:var(--font);font-size:.9375rem;font-weight:600;
  line-height:1;white-space:nowrap;cursor:pointer;
  text-decoration:none;border:2px solid transparent;
  transition:background var(--t),color var(--t),border-color var(--t),box-shadow var(--t),transform 100ms;
}
.btn:focus-visible{outline:3px solid #93C5FD;outline-offset:3px}
.btn:active{transform:translateY(1px)}

.btn-p{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:var(--shadow-blue)}
.btn-p:hover{background:var(--blue-dark);border-color:var(--blue-dark);color:#fff;box-shadow:0 6px 20px rgba(37,99,235,.4)}

.btn-s{background:var(--white);color:var(--body);border-color:var(--border);box-shadow:var(--shadow-sm)}
.btn-s:hover{border-color:#C3C9D3;color:var(--text);box-shadow:var(--shadow-md)}

.btn-w{background:#fff;color:var(--blue-dark);border-color:#fff;box-shadow:var(--shadow-md)}
.btn-w:hover{background:var(--blue-50);border-color:var(--blue-50)}

.btn-ow{background:transparent;color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.45)}
.btn-ow:hover{border-color:rgba(255,255,255,.85);background:rgba(255,255,255,.1)}

.btn-sm{padding:.5em 1.25em;font-size:.875rem}
.btn-full{width:100%;justify-content:center}

/* ── Header ─────────────────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-xs);
}
.hdr{display:flex;align-items:center;height:4.25rem;gap:1rem}
.hdr-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.nav-wrap{margin-left:auto}

.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo img{height:2.25rem;width:auto}

.nav-wrap{display:flex;align-items:center}
.nav-list{display:flex;align-items:center;gap:.125rem;flex-wrap:nowrap}

.nav-a{
  display:inline-block;padding:.375rem .75rem;
  color:var(--muted);font-size:.9rem;font-weight:500;
  text-decoration:none;border-radius:6px;
  white-space:nowrap;
  transition:color var(--t),background var(--t);
}
.nav-a:hover{color:var(--text);background:var(--bg)}
.nav-a[aria-current="page"]{color:var(--blue);font-weight:600}

.nav-cta{
  display:inline-flex;align-items:center;
  padding:.5rem 1.25rem;
  background:var(--blue);color:#fff;
  font-size:.9rem;font-weight:600;
  border-radius:var(--r);text-decoration:none;
  box-shadow:var(--shadow-blue);
  transition:background var(--t),box-shadow var(--t);
}
.nav-cta:hover{background:var(--blue-dark);color:#fff;box-shadow:0 6px 20px rgba(37,99,235,.35)}

.ham{display:none;flex-direction:column;justify-content:space-between;width:1.5rem;height:1.25rem;background:none;border:none;cursor:pointer;padding:0}
.ham span{display:block;height:2px;background:var(--body);border-radius:1px;transition:transform var(--t),opacity var(--t)}
.ham[aria-expanded=true] span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.ham[aria-expanded=true] span:nth-child(2){opacity:0}
.ham[aria-expanded=true] span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* ── HERO ─────────────────────────────────────────────────────────────────── */
.hero{
  background:var(--white);
  padding-block:clamp(2rem,4vw,3.5rem) clamp(3rem,6vw,5rem);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
/* Subtle radial gradient behind illustration */
.hero::after{
  content:'';position:absolute;
  top:-10%;right:-5%;
  width:55%;height:120%;
  background:radial-gradient(ellipse at 60% 40%, rgba(37,99,235,.07) 0%, transparent 65%);
  pointer-events:none;
}

.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:4rem;
  position:relative;z-index:1;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--blue-50);color:var(--blue);
  border:1px solid var(--blue-100);
  font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:.35em 1em;border-radius:999px;margin-bottom:1.5rem;
}
.hero-badge__dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}

.hero h1{
  font-size:clamp(2.125rem,4.5vw,3.375rem);
  letter-spacing:-.03em;line-height:1.1;
  color:var(--text);margin-bottom:1.25rem;
}
.hero h1 strong{color:var(--blue)}

.hero-sub{
  font-size:1.0625rem;color:var(--muted);line-height:1.75;
  max-width:48ch;margin-bottom:2rem;
}

.hero-actions{display:flex;flex-wrap:wrap;gap:.875rem;margin-bottom:2.5rem}

.hero-trust{
  display:flex;flex-wrap:wrap;gap:1.25rem;
  padding-top:2rem;border-top:1px solid var(--border);
}
.hero-trust-item{
  display:flex;align-items:center;gap:.5rem;
  font-size:.875rem;color:var(--muted);font-weight:500;
}
.hero-trust-item svg{color:var(--green);flex-shrink:0}

.hero-visual{display:flex;justify-content:center;align-items:center;align-self:start;margin-top:-1rem}
.hero-img{width:100%;max-width:680px;filter:drop-shadow(0 12px 40px rgba(37,99,235,.12))}
@media(min-width:1025px){
  .hero-inner{align-items:start}
  .hero-content{padding-top:1rem}
}

/* ── STATS BAR ─────────────────────────────────────────────────────────────── */
.stats-bar{background:var(--white);border-bottom:1px solid var(--border)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-cell{
  padding:2rem 1.5rem;text-align:center;
  border-right:1px solid var(--border);
}
.stat-cell:last-child{border-right:none}
.stat-n{display:block;font-size:clamp(1.75rem,3vw,2.375rem);font-weight:800;color:var(--blue);line-height:1;letter-spacing:-.03em;margin-bottom:.375rem}
.stat-l{display:block;font-size:.875rem;color:var(--subtle)}

/* ── SERVICE CARDS ─────────────────────────────────────────────────────────── */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}

.card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2rem;
  display:flex;flex-direction:column;
  box-shadow:var(--shadow-sm);
  transition:box-shadow var(--t),transform var(--t),border-color var(--t);
  text-decoration:none;color:inherit;
}
.card:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-3px);
  border-color:var(--border-blue);
}
.card-icon{
  width:3rem;height:3rem;
  background:var(--blue-50);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);margin-bottom:1.25rem;flex-shrink:0;
}
.card h3{font-size:1.0625rem;margin-bottom:.625rem;color:var(--text)}
.card p{font-size:.9375rem;color:var(--muted);line-height:1.65;flex:1;margin-bottom:1.25rem}
.card-link{
  font-size:.875rem;font-weight:600;color:var(--blue);
  text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;
  margin-top:auto;
}
.card-link::after{content:'→';font-size:.85em}
.card-link:hover{text-decoration:underline}

/* ── BENEFITS SPLIT ────────────────────────────────────────────────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.split--flip .split-visual{order:-1}
.split-content .eyebrow{margin-bottom:.875rem}
.split-content h2{margin-bottom:1.125rem}
.split-content .lead{font-size:1.0625rem;color:var(--muted);line-height:1.75;margin-bottom:2rem}

.benefits-list{display:flex;flex-direction:column;gap:.875rem}
.ben{
  display:flex;gap:1rem;align-items:flex-start;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:1.125rem 1.25rem;
  box-shadow:var(--shadow-xs);
  transition:box-shadow var(--t),border-color var(--t);
}
.ben:hover{box-shadow:var(--shadow-md);border-color:var(--border-blue)}
.ben-icon{
  width:2.25rem;height:2.25rem;flex-shrink:0;
  background:var(--blue-50);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);
}
.ben h4{font-size:.9375rem;font-weight:600;color:var(--text);margin-bottom:.2rem}
.ben p{font-size:.875rem;color:var(--muted);line-height:1.55;max-width:none}

.split-visual{
  display:flex;align-items:center;justify-content:center;
}
.split-img{width:100%;max-width:460px;border-radius:var(--r-xl);box-shadow:var(--shadow-xl)}

/* ── QUOTES / TESTIMONIALS ─────────────────────────────────────────────────── */
.quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}

.quote{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2rem;
  display:flex;flex-direction:column;gap:1.25rem;
  box-shadow:var(--shadow-sm);
  position:relative;
}
.quote::before{
  content:'';position:absolute;top:0;left:2rem;right:2rem;
  height:3px;background:linear-gradient(90deg,var(--blue),#60A5FA);
  border-radius:0 0 3px 3px;
}
.stars{display:flex;gap:3px;color:#F59E0B}
.quote-text{
  font-size:.9375rem;color:var(--body);line-height:1.75;
  flex:1;max-width:none;font-style:italic;
}
.quote-trans{
  font-size:.6875rem;color:var(--subtle);
  margin-top:-.5rem;margin-bottom:.75rem;
  font-style:normal;letter-spacing:.02em;
}
.quote-author{
  display:flex;align-items:center;gap:.875rem;
  padding-top:1.125rem;border-top:1px solid var(--border);
}
.avatar{
  width:2.5rem;height:2.5rem;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue),#1E40AF);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.875rem;font-weight:700;
}
.qname{font-size:.9375rem;font-weight:600;color:var(--text)}
.qrole{font-size:.8125rem;color:var(--subtle)}

/* ── CTA BAND ──────────────────────────────────────────────────────────────── */
.cta-section{
  background:linear-gradient(135deg,#1D4ED8 0%,#2563EB 60%,#3B82F6 100%);
  padding-block:var(--section);position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Ccircle cx='30' cy='30' r='1' fill='rgba(255,255,255,0.08)'/%3E%3C/svg%3E");
  pointer-events:none;
}
.cta-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:3rem;position:relative;z-index:1;
}
.cta-inner h2{color:#fff;margin-bottom:1rem;font-size:clamp(1.625rem,3vw,2.375rem)}
.cta-inner p{color:rgba(255,255,255,.8);font-size:1.0625rem;line-height:1.7;max-width:50ch}
.cta-actions{display:flex;flex-direction:column;gap:.875rem;flex-shrink:0;min-width:220px}

/* ── PAGE HERO (inner pages) ───────────────────────────────────────────────── */
.page-hero{
  background:linear-gradient(135deg,#0F172A 0%,#1E3A8A 60%,#1D4ED8 100%);
  padding-block:3.5rem 3rem;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cpath d='M0 80 L80 0' stroke='rgba(255,255,255,0.04)' stroke-width='1'/%3E%3C/svg%3E");
  background-size:80px 80px;
}
.page-hero>.wrap{position:relative;z-index:1;max-width:760px}
.page-hero .eyebrow{color:var(--blue-100)}
.page-hero h1{color:#fff;margin-bottom:1rem}
.page-hero>div>p,.page-hero>.wrap>p{color:rgba(255,255,255,.75);font-size:1.0625rem;line-height:1.75;max-width:56ch}

/* ── SVC ROWS (alternating detail sections) ────────────────────────────────── */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.svc-row--flip .svc-visual{order:-1}
.svc-row .eyebrow{margin-bottom:.75rem}
.svc-row h2{margin-bottom:1rem;font-size:clamp(1.5rem,3vw,2.25rem)}
.svc-lead{font-size:1.0625rem;color:var(--muted);line-height:1.75;margin-bottom:1.5rem}

/* svc-visual: image fills directly, no box */

/* Feature list */
.flist{display:flex;flex-direction:column;gap:.875rem;margin-bottom:2rem}
.flist li{
  display:flex;gap:.875rem;align-items:flex-start;
  font-size:.9375rem;color:var(--body);line-height:1.6;
}
.flist li::before{
  content:'';display:block;flex-shrink:0;
  width:1.25rem;height:1.25rem;margin-top:2px;
  border-radius:50%;
  background:var(--blue-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath fill='%232563EB' d='M11.2 3.8a.875.875 0 0 1 0 1.225l-5.25 5.25a.875.875 0 0 1-1.236 0L2.3 7.86a.875.875 0 1 1 1.238-1.236L5.333 8.42 9.975 3.8a.875.875 0 0 1 1.225 0Z'/%3E%3C/svg%3E") center/65% no-repeat;
}

/* Spec table */
.spec-tbl,.sla-tbl,.ptbl{width:100%;border-collapse:collapse;font-size:.9375rem;margin-bottom:2rem;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(min-width:640px){.spec-tbl,.sla-tbl,.ptbl{display:table}}
.spec-tbl th,.sla-tbl th,.ptbl th{
  text-align:left;padding:.625rem 1rem;
  font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);
  background:var(--bg);border-bottom:2px solid var(--border);
}
.ptbl th.r{text-align:right}
.spec-tbl td,.sla-tbl td,.ptbl td{
  padding:.75rem 1rem;border-bottom:1px solid var(--border);
  color:var(--body);vertical-align:top;
}
.spec-tbl tr:last-child td,.sla-tbl tr:last-child td{border-bottom:none}
.spec-tbl tr:hover td,.sla-tbl tr:hover td{background:var(--blue-50)}
.spec-ok{color:var(--blue);font-weight:700}
.ptbl td.r{text-align:right;font-weight:600;color:var(--text);white-space:nowrap}
.ptbl__group td{background:var(--blue-50);color:var(--blue-dark);font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em}
.ptbl__total td{background:var(--bg)}
.ptbl__total td.r{font-size:1.375rem;color:var(--blue);font-weight:800}

/* ── TIER CARDS ─────────────────────────────────────────────────────────────── */
.tier-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}
.tier{
  border:1.5px solid var(--border);border-radius:var(--r);
  padding:1.5rem;background:var(--white);
  display:flex;flex-direction:column;gap:.875rem;
  box-shadow:var(--shadow-xs);
}
.tier--hi{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1),var(--shadow-md)}
.tier-badge{
  display:inline-block;background:var(--blue);color:#fff;
  font-size:.75rem;font-weight:700;padding:.25em .875em;
  border-radius:999px;align-self:flex-start;margin-bottom:.25rem;
}
.tier h4{
  font-size:1.375rem;font-weight:800;color:var(--text);
  letter-spacing:-.02em;
}
.tier-sub{
  font-size:.875rem;color:var(--muted);line-height:1.6;
  padding-bottom:.875rem;
  border-bottom:1px solid var(--border);
}
.tier-dl{
  border-top:1px solid var(--border);
  padding-top:.875rem;
  display:table;width:100%;border-collapse:collapse;
}
.tier-row_{
  display:table-row;
}
.tier-row_ dt,.tier-row_ dd{
  display:table-cell;
  padding:.3125rem 0;
  font-size:.875rem;
  border-bottom:1px solid var(--border-light,#F3F4F6);
  vertical-align:middle;
}
.tier-row_:last-child dt,
.tier-row_:last-child dd { border-bottom:none; }
.tier-row_ dt{
  color:var(--muted);
  padding-right:1rem;
  white-space:nowrap;
  width:55%;
}
.tier-row_ dd{
  color:var(--text);
  font-weight:700;
  text-align:right;
  white-space:nowrap;
  margin:0;
}

/* ── PRICING ─────────────────────────────────────────────────────────────────── */
.pricing-box{border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;max-width:880px;margin-inline:auto;box-shadow:var(--shadow-lg)}
.pricing-head{background:linear-gradient(135deg,#0F172A,#1E3A8A);color:#fff;padding:2.5rem 3rem}
.pricing-head h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}
.pricing-head p{color:rgba(255,255,255,.55);font-size:.9375rem;max-width:none}
.pricing-note{display:flex;gap:.875rem;align-items:flex-start;padding:1.25rem 2rem;background:var(--bg);border-top:1px solid var(--border);font-size:.875rem;color:var(--subtle)}
.pricing-note svg{flex-shrink:0;color:var(--subtle);margin-top:1px}
.pricing-note p{max-width:none;margin:0}

.modules{display:grid;grid-template-columns:repeat(3,1fr);gap:.875rem;max-width:880px;margin-inline:auto}
.mod{
  display:flex;align-items:center;gap:.875rem;
  padding:1rem 1.25rem;border:1px solid var(--border);border-radius:var(--r);
  font-size:.9375rem;color:var(--body);font-weight:500;background:var(--white);
  box-shadow:var(--shadow-xs);
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
}
.mod:hover{border-color:var(--blue-100);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.mod-icon{width:2.25rem;height:2.25rem;flex-shrink:0;background:var(--blue-50);border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--blue)}

/* ── PARTNER / SUPPORT CARDS ─────────────────────────────────────────────────── */
.partner-grid,.sup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}

.p-card,.s-card{
  background:var(--white);border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:2rem;
  display:flex;flex-direction:column;gap:1rem;
  box-shadow:var(--shadow-sm);
  transition:box-shadow var(--t),border-color var(--t);
}
.p-card:hover,.s-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-blue)}
.p-card--hi,.s-card--hi{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.08),var(--shadow-md)}

.p-badge,.s-badge{display:inline-block;background:var(--blue);color:#fff;font-size:.75rem;font-weight:700;padding:.25em .75em;border-radius:999px;align-self:flex-start}
.p-idx{font-size:.75rem;font-weight:700;letter-spacing:.1em;color:var(--subtle);text-transform:uppercase}
.p-card h3,.s-card h3{font-size:1.25rem;color:var(--text)}
.p-desc,.s-card p{font-size:.9375rem;color:var(--muted);line-height:1.65;flex:1}

.p-list,.s-list{display:flex;flex-direction:column;gap:.5rem}
.p-list li,.s-list li{
  display:flex;align-items:flex-start;gap:.625rem;
  font-size:.9375rem;color:var(--body);
}
.p-list li::before,.s-list li::before{
  content:'';display:block;flex-shrink:0;
  width:1.125rem;height:1.125rem;margin-top:2px;
  border-radius:50%;
  background:var(--blue-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath fill='%232563EB' d='M11.2 3.8a.875.875 0 0 1 0 1.225l-5.25 5.25a.875.875 0 0 1-1.236 0L2.3 7.86a.875.875 0 1 1 1.238-1.236L5.333 8.42 9.975 3.8a.875.875 0 0 1 1.225 0Z'/%3E%3C/svg%3E") center/65% no-repeat;
}

.s-icon{width:3rem;height:3rem;flex-shrink:0;background:var(--blue-50);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--blue)}

.resp-tbl{border-top:1px solid var(--border);padding-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.resp-row{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem}
.resp-row dt{color:var(--subtle)}
.resp-row dd{font-weight:700}
.r-you{color:var(--blue)} .r-wfc{color:var(--green)} .r-shared{color:#D97706}

/* ── ABOUT ─────────────────────────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:3fr 2fr;gap:4.5rem;align-items:start}
.about-grid h2{margin-bottom:1.5rem}
.about-grid p{color:var(--muted);line-height:1.75;margin-bottom:1rem}
.stat-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.sc{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;box-shadow:var(--shadow-sm);text-align:center}
.sc-n{display:block;font-size:2rem;font-weight:800;color:var(--blue);line-height:1;letter-spacing:-.03em;margin-bottom:.5rem}
.sc-l{font-size:.8125rem;color:var(--subtle);line-height:1.4}

.val-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.val-num{font-size:.75rem;font-weight:700;letter-spacing:.1em;color:var(--blue);text-transform:uppercase;margin-bottom:.5rem}
.val h3{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:.375rem}
.val p{font-size:.9375rem;color:var(--muted);line-height:1.65}
.section--dark .val h3{color:#fff} .section--dark .val p{color:rgba(255,255,255,.55)} .section--dark .val-num{color:rgba(255,255,255,.25)}

.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.loc{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem;box-shadow:var(--shadow-sm)}
.loc-icon{width:2.75rem;height:2.75rem;background:var(--blue-50);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--blue);margin-bottom:1.25rem}
.loc h3{font-size:1.125rem;margin-bottom:1rem;color:var(--text)}
.loc address,.loc p{font-size:.9375rem;color:var(--muted);line-height:1.8}
.loc address a{color:var(--muted);text-decoration:none}
.loc address a:hover{color:var(--blue)}

/* ── CONTACT ─────────────────────────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 360px;gap:4.5rem;align-items:start}
.contact-form-wrap h2{margin-bottom:.75rem}
.contact-form-wrap .sub{color:var(--muted);font-size:.9375rem;margin-bottom:2rem}
.cform{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:flex;gap:1rem}
.form-row>*{flex:1}
.fgroup{display:flex;flex-direction:column;gap:.5rem}
.flabel{font-size:.8125rem;font-weight:600;color:var(--text)}
.freq{color:var(--red);margin-left:2px}
.freq-note{font-size:.8125rem;color:var(--subtle)}
.finput{
  width:100%;padding:.75rem 1rem;
  border:1.5px solid var(--border);border-radius:var(--r);
  font-family:var(--font);font-size:.9375rem;
  color:var(--text);background:var(--white);line-height:1.5;
  transition:border-color var(--t),box-shadow var(--t);
}
.finput:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.finput::placeholder{color:var(--subtle)}
.ftextarea{resize:vertical;min-height:7rem}
.finput--err{border-color:var(--red)!important}
.ferr{display:block;font-size:.8125rem;color:var(--red);margin-top:.25rem}

.fnote{display:flex;gap:.75rem;align-items:flex-start;background:var(--blue-50);border:1px solid var(--blue-100);border-radius:var(--r);padding:.875rem 1rem;font-size:.875rem;color:var(--blue-dark);line-height:1.65}
.fnote svg{flex-shrink:0;margin-top:1px}

.fcheck-wrap{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-size:.9375rem;color:var(--body);line-height:1.6}
.fcheck{appearance:none;-webkit-appearance:none;width:1.125rem;height:1.125rem;flex-shrink:0;margin-top:3px;border:1.5px solid var(--border);border-radius:4px;background:var(--white);cursor:pointer;transition:border-color var(--t),background var(--t);position:relative}
.fcheck:checked{background:var(--blue);border-color:var(--blue)}
.fcheck:checked::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath fill='none' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1.5 5l2.5 2.5 4.5-4.5'/%3E%3C/svg%3E") center/75% no-repeat}
.fcheck:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

.contact-aside{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem;position:sticky;top:calc(4.25rem + 1.5rem)}
.contact-aside h3{font-size:1.25rem;margin-bottom:1.5rem;color:var(--text)}
.ci-list{display:flex;flex-direction:column;gap:1.25rem}
.ci-row{display:flex;gap:1rem;align-items:flex-start}
.ci-icon{width:2.25rem;height:2.25rem;flex-shrink:0;background:var(--white);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--blue);box-shadow:var(--shadow-xs)}
.ci-key{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--subtle);margin-bottom:2px}
.ci-val{font-size:.9375rem;color:var(--body)}
.ci-val a{color:var(--body);text-decoration:none;font-weight:500}
.ci-val a:hover{color:var(--blue)}
.ci-sep{border:none;border-top:1px solid var(--border);margin-block:1.5rem}
.ci-note h4{font-size:.9375rem;font-weight:600;margin-bottom:.375rem;color:var(--text)}
.ci-note p{font-size:.875rem;color:var(--subtle);line-height:1.65;max-width:none}

.alert{display:flex;align-items:flex-start;gap:.875rem;padding:1rem 1.125rem;border-radius:var(--r);font-size:.9375rem;border:1px solid transparent}
.alert--ok{background:#F0FDF4;color:#166534;border-color:#BBF7D0}
.alert--err{background:#FEF2F2;color:#991B1B;border-color:#FECACA}
.alert svg{flex-shrink:0;margin-top:1px}

/* ── PORTAL MOCKUP ─────────────────────────────────────────────────────────── */
.portal{width:280px;background:#0F172A;border-radius:12px;border:1px solid #1E293B;overflow:hidden;box-shadow:var(--shadow-xl)}
.portal-bar{background:#1E293B;padding:.75rem 1rem;display:flex;gap:.5rem;align-items:center}
.portal-dot{width:8px;height:8px;border-radius:50%}
.portal-dot--r{background:#FF5F57} .portal-dot--y{background:#FFBD2E} .portal-dot--g{background:#28CA41}
.portal-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem}
.portal-row{display:flex;align-items:center;gap:.5rem;font-size:.6875rem;padding:.5rem .75rem;border-radius:6px}
.portal-row--ok{background:rgba(34,197,94,.15);color:#86EFAC}
.portal-row--warn{background:rgba(245,158,11,.15);color:#FCD34D}
.portal-sep{border-top:1px solid #1E293B;margin-block:.25rem}
.portal-kv{display:flex;justify-content:space-between;padding:.25rem .25rem}
.portal-kv span{font-size:.6875rem;color:#64748B}
.portal-kv strong{font-size:.8125rem;color:#CBD5E1}

/* SLA priorities */
.prio{display:inline-block;padding:.2em .75em;border-radius:999px;font-size:.8125rem;font-weight:700;white-space:nowrap}
.prio-1{background:#FEE2E2;color:#991B1B} .prio-2{background:#FEF3C7;color:#92400E}
.prio-3{background:var(--blue-50);color:#1E40AF} .prio-4{background:var(--bg-2);color:var(--muted)}

/* ── LEGAL ─────────────────────────────────────────────────────────────────── */
.legal{max-width:740px;padding-block:.5rem}
.legal h2{font-size:1.25rem;margin-top:3rem;margin-bottom:1rem;padding-top:2rem;border-top:1px solid var(--border);color:var(--text)}
.legal h2:first-child{border-top:none;margin-top:0;padding-top:0}
.legal h3{font-size:1rem;margin-top:1.5rem;margin-bottom:.75rem;color:var(--body)}
.legal p,.legal address{font-size:.9375rem;color:var(--muted);margin-bottom:1rem;line-height:1.75;max-width:none}
.legal ul{margin-bottom:1rem}
.legal ul li{font-size:.9375rem;color:var(--muted);padding:.25rem 0}

/* ── FOOTER ─────────────────────────────────────────────────────────────────── */
.site-footer{background:var(--blue-navy);color:rgba(255,255,255,.55)}
.footer-grid{display:grid;grid-template-columns:2.25fr 1fr 1fr 1.5fr;gap:3.5rem;padding-block:5rem;border-bottom:1px solid rgba(255,255,255,.07)}
.foot-brand-logo{margin-bottom:1.25rem;opacity:.85}
.foot-brand p{font-size:.9375rem;color:rgba(255,255,255,.35);line-height:1.7}
.foot-col h4{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:1.25rem}
.foot-col nav{display:flex;flex-direction:column;gap:.75rem}
.foot-col nav a{font-size:.9375rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color var(--t)}
.foot-col nav a:hover{color:rgba(255,255,255,.9)}
.foot-contact{display:flex;flex-direction:column;gap:1rem}
.fci{display:flex;gap:.875rem;align-items:flex-start}
.fci svg{flex-shrink:0;color:rgba(255,255,255,.2);margin-top:2px}
.fci span,.fci a{font-size:.9375rem;color:rgba(255,255,255,.5);text-decoration:none;line-height:1.6}
.fci a:hover{color:rgba(255,255,255,.9)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-block:1.5rem}
.footer-bottom p{font-size:.875rem;color:rgba(255,255,255,.25);max-width:none}
.footer-bottom nav{display:flex;gap:1.5rem}
.footer-bottom a{font-size:.875rem;color:rgba(255,255,255,.25);text-decoration:none;transition:color var(--t)}
.footer-bottom a:hover{color:rgba(255,255,255,.65)}

/* ── COOKIE BANNER ─────────────────────────────────────────────────────────── */
.cookie{position:fixed;bottom:1.25rem;left:50%;transform:translateX(-50%);z-index:300;width:min(560px,calc(100vw - 2rem));background:#1E293B;color:rgba(255,255,255,.8);border:1px solid #334155;border-radius:var(--r-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-xl)}
.cookie[hidden]{display:none}
.cookie__inner{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.cookie__inner p{font-size:.9375rem;flex:1;max-width:none;line-height:1.6}
.cookie__inner a{color:rgba(255,255,255,.7)}

/* ── RESPONSIVE ─────────────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .hero-inner    {grid-template-columns:1fr}
  .hero-visual   {display:none}
  .cards-grid    {grid-template-columns:repeat(2,1fr)}
  .quotes-grid   {grid-template-columns:repeat(2,1fr)}
  .stats-grid    {grid-template-columns:repeat(2,1fr)}
  .stat-cell:nth-child(2){border-right:none}
  .stat-cell     {border-bottom:1px solid var(--border)}
  .stat-cell:nth-last-child(-n+2){border-bottom:none}
  .split         {grid-template-columns:1fr}
  .split-visual  {display:none}
  .tier-row      {grid-template-columns:1fr}
  .val-grid      {grid-template-columns:repeat(2,1fr)}
  .footer-grid   {grid-template-columns:1fr 1fr}
  .about-grid    {grid-template-columns:1fr}
  .svc-row       {grid-template-columns:1fr}
  .svc-visual    {display:none}
  .contact-grid  {grid-template-columns:1fr}
  .contact-aside {position:static}
  .partner-grid  {grid-template-columns:1fr;max-width:500px;margin-inline:auto}
  .sup-grid      {grid-template-columns:1fr;max-width:500px;margin-inline:auto}
  .modules       {grid-template-columns:repeat(2,1fr)}
  .loc-grid      {grid-template-columns:repeat(2,1fr)}
  .cta-inner     {flex-direction:column}
}
@media(max-width:768px){
  :root{--section:3rem}
  .ham{display:flex}
  .nav-wrap{position:absolute;top:100%;left:0;right:0;background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1rem;display:none}
  .nav-wrap.open{display:flex}
  .nav-list{flex-direction:column;width:100%;gap:.25rem}
  .nav-a{display:block;padding:.75rem 1rem;font-size:1rem}
  .nav-cta{margin-top:.5rem;justify-content:center}

  .hero h1{font-size:2rem}
  .hero-actions{flex-direction:column}
  .hero-trust{flex-direction:column;gap:.625rem}
  .cards-grid{grid-template-columns:1fr}
  .quotes-grid{grid-template-columns:1fr}
  .tier-row{grid-template-columns:1fr}
  .val-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .stat-cards{grid-template-columns:1fr 1fr}
  .loc-grid{grid-template-columns:1fr}
  .modules{grid-template-columns:1fr 1fr}
  .form-row{flex-direction:column}
  .sh{margin-bottom:2.5rem}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .modules{grid-template-columns:1fr}
  .stat-cards{grid-template-columns:1fr}
}
@media print{
  .site-header,.site-footer,.cookie,.ham{display:none!important}
  body{font-size:11pt;background:#fff;color:#000}
}

/* ─── Mobile Optimization ─────────────────────────────────────────────────── */

/* Prevent iOS zoom on form focus (font-size ≥ 16px) */
@media(max-width:768px){
  input,select,textarea,.finput,.fselect{font-size:16px!important}
}

/* Touch targets – min 44×44px on mobile (WCAG AAA) */
@media(hover:none) and (pointer:coarse){
  .btn,.nav-a,.nav-cta,.card-link,.srv-card__link,.lang-btn,.theme-toggle,.kb-chip,.kb-q,.calc2-ma-btn,.calc2-preset,.faq-tab,.form-tab{min-height:44px}
  .lang-switcher{height:auto;min-height:44px}
  .nav-a,.nav-cta{padding:.75rem 1rem}
  .ham{width:2.75rem;height:2.75rem;padding:.75rem}
}

/* Prevent horizontal scroll globally */
html,body{max-width:100%;overflow-x:hidden}
img,svg,video{max-width:100%;height:auto}

/* Better word-breaking on mobile (prevent long URLs/emails overflowing) */
@media(max-width:768px){
  a,p,h1,h2,h3{word-break:break-word;overflow-wrap:anywhere}
  .hero h1{font-size:clamp(1.75rem,7vw,2.5rem);line-height:1.15}
  h2{font-size:clamp(1.375rem,5vw,2rem)}
  .trust-label{font-size:clamp(1.125rem,4vw,1.375rem)}
  .cta-band h2{font-size:clamp(1.375rem,5vw,1.875rem)}
}

/* Smooth scrolling respecting reduced motion preferences */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* Focus-visible: proper keyboard focus outline */
:focus-visible{outline:3px solid #60A5FA;outline-offset:2px;border-radius:4px}

/* Skip link for accessibility */
.skip-to-main{
  position:absolute;left:-9999px;top:0;z-index:9999;
  background:#2563EB;color:white;padding:.75rem 1.25rem;
  border-radius:0 0 8px 0;font-weight:600;text-decoration:none;
}
.skip-to-main:focus{left:0}

/* ── Stats Bar: Blue Background ──────────────────────────────────────── */
.stats-bar{background:var(--blue);border-bottom:none}
.stat-cell{border-right:1px solid rgba(255,255,255,.2)}
.stat-cell:last-child{border-right:none}
.stat-n{color:#fff}
.stat-l{color:rgba(255,255,255,.75)}

/* ── Eyebrow: stronger blue pill ────────────────────────────────────── */
.eyebrow{
  background:var(--blue-50);color:var(--blue);
  padding:.3em .875em;border-radius:999px;
  border:1px solid var(--blue-100);
  font-size:.6875rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:1.25rem;
  display:inline-flex;align-items:center;gap:.5rem;
}
.eyebrow::before{display:none}
.page-hero .eyebrow{
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.95);
  border-color:rgba(255,255,255,.25);
}
.section--dark .eyebrow,.cta-section .eyebrow{
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.95);
  border-color:rgba(255,255,255,.25);
}

/* ── Contact Tabs ────────────────────────────────────────────────────── */
.form-tabs{
  display:flex;gap:.5rem;
  border-bottom:2px solid var(--border);
  margin-bottom:2rem;
}
.form-tab{
  display:flex;align-items:center;gap:.5rem;
  padding:.75rem 1.5rem;
  font-family:var(--font);font-size:.9375rem;font-weight:600;
  color:var(--muted);background:transparent;
  border:none;border-bottom:2px solid transparent;
  margin-bottom:-2px;cursor:pointer;
  transition:color var(--t),border-color var(--t);
  white-space:nowrap;
}
.form-tab:hover{color:var(--text)}
.form-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.form-tab svg{flex-shrink:0}

.form-panel{display:none}
.form-panel.active{display:block}

/* ── Select / Dropdown ───────────────────────────────────────────────── */
.fselect{
  width:100%;padding:.75rem 2.5rem .75rem 1rem;
  border:1.5px solid var(--border);border-radius:var(--r);
  font-family:var(--font);font-size:.9375rem;
  color:var(--text);background:var(--white);
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right .875rem center;
  background-size:1rem;
  cursor:pointer;
  transition:border-color var(--t),box-shadow var(--t);
}
.fselect:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.fselect option[value=""]{color:var(--subtle)}

/* ── Trust / Customer Logos ──────────────────────────────────────────── */
.trust-section{
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding-block:3rem;background:var(--white);
}
.trust-label{
  text-align:center;
  font-size:clamp(1.25rem, 2.2vw, 1.75rem);
  font-weight:800;
  letter-spacing:-.01em;
  color:var(--text);
  margin-bottom:2.25rem;
  line-height:1.3;
}
.trust-logos{
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:center;gap:1rem 2rem;
}
.trust-logo{
  display:flex;align-items:center;gap:.75rem;
  padding:.875rem 1.75rem;
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r);
  font-size:.875rem;font-weight:600;color:var(--body);
  white-space:nowrap;
  transition:border-color var(--t),box-shadow var(--t);
}
.trust-logo:hover{border-color:var(--blue-100);box-shadow:var(--shadow-md)}

.trust-logo-img{
  display:flex;align-items:center;justify-content:center;
  padding:.875rem 1.75rem;
  background:var(--white);border:1px solid var(--border);border-radius:var(--r);
  transition:border-color var(--t),box-shadow var(--t),filter var(--t),transform var(--t);
  filter:grayscale(30%) opacity(.85);
  text-decoration:none;
  cursor:default;
}
a.trust-logo-img{cursor:pointer}
.trust-logo-img:hover{border-color:var(--blue-100);box-shadow:var(--shadow-md);filter:grayscale(0%) opacity(1)}
a.trust-logo-img:hover{transform:translateY(-2px)}
.trust-logo-img img{height:44px;width:auto;object-fit:contain}
.trust-logo__icon{
  width:2rem;height:2rem;border-radius:6px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:800;color:#fff;
  background:linear-gradient(135deg,var(--blue),var(--blue-deep));
}

/* ── ITS AG / DSV Badge ──────────────────────────────────────────────── */
.product-badge{
  display:inline-flex;align-items:center;gap:.625rem;
  background:var(--blue-50);border:1px solid var(--blue-100);
  border-radius:var(--r);padding:.5rem 1rem;
  font-size:.8125rem;color:var(--blue-deep);
  margin-bottom:1.5rem;
}
.product-badge strong{font-weight:700}
.product-badge__sep{color:var(--blue-100)}

/* ── Service Section Visual ──────────────────────────────────────────── */
.svc-visual{
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--r-xl);overflow:hidden;
}
.svc-visual img{
  width:100%;height:auto;
  border-radius:var(--r-xl);
  box-shadow:0 16px 48px rgba(15,23,42,.18), 0 4px 12px rgba(15,23,42,.10);
  display:block;
}

/* ── Ben Items: more blue ────────────────────────────────────────────── */
.ben{border-left:3px solid var(--blue-100);border-left-width:0}
.ben:hover{border-color:var(--blue)}
.ben-icon{background:var(--blue-50)}

/* ── Cards: left accent on hover ─────────────────────────────────────── */
.card{border-top:3px solid transparent;transition:box-shadow var(--t),transform var(--t),border-color var(--t)}
.card:hover{border-top-color:var(--blue)}

/* ── Nav CTA: more prominent ─────────────────────────────────────────── */
.nav-cta{background:var(--blue);padding:.55rem 1.5rem;letter-spacing:.01em}

/* ── Section blue tint stronger ─────────────────────────────────────── */
.section--blue-tint{background:#EBF2FF}

/* ── Quote top accent ─────────────────────────────────────────────────── */
.quote::before{height:4px}

/* ── Hero badge green dot ────────────────────────────────────────────── */
.hero-badge__dot{width:7px;height:7px;background:var(--green);box-shadow:0 0 0 2px rgba(34,197,94,.3);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 2px rgba(34,197,94,.3)}50%{box-shadow:0 0 0 5px rgba(34,197,94,.15)}}

/* ── Blue highlight boxes ─────────────────────────────────────────────── */
.blue-box{
  background:var(--blue-50);border:1px solid var(--blue-100);
  border-radius:var(--r-lg);padding:2rem 2.5rem;
  border-left:4px solid var(--blue);
}

/* ── Booking summary (termin form) ───────────────────────────────────── */
.booking-hint{
  display:flex;gap:.875rem;align-items:flex-start;
  background:linear-gradient(135deg,var(--blue-50),#E0EAFF);
  border:1px solid var(--blue-100);border-radius:var(--r);
  padding:1.25rem 1.5rem;margin-bottom:1.5rem;
}
.booking-hint__icon{
  width:2.5rem;height:2.5rem;flex-shrink:0;
  background:var(--blue);border-radius:var(--r-sm, 6px);
  display:flex;align-items:center;justify-content:center;color:#fff;
}
.booking-hint h4{font-size:.9375rem;color:var(--blue-deep);margin-bottom:.25rem}
.booking-hint p{font-size:.875rem;color:var(--muted);max-width:none;line-height:1.6}
[data-theme="dark"] .booking-hint{background:rgba(37,99,235,.12);border-color:rgba(37,99,235,.35)}
[data-theme="dark"] .booking-hint h4{color:#93C5FD}
[data-theme="dark"] .booking-hint p{color:var(--body)}

/* ── Kostenrechner (Tabellen-Layout) ─────────────────────────────────── */
.calc-layout{
  display:grid;grid-template-columns:1fr 300px;
  gap:2rem;align-items:start;
}
/* MA Row */
.calc-ma-row{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--blue);color:#fff;
  border-radius:var(--r-md) var(--r-md) 0 0;
  padding:1rem 1.25rem;gap:1rem;
}
.calc-ma-label{
  display:flex;align-items:center;gap:.5rem;
  font-size:.9375rem;font-weight:700;color:#fff;
}
.calc-ma-ctrl{display:flex;align-items:center;gap:.5rem}
.calc-ma-btn{
  width:2rem;height:2rem;border-radius:50%;
  background:rgba(255,255,255,.2);color:#fff;
  border:none;font-size:1.25rem;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background var(--t);line-height:1;
}
.calc-ma-btn:hover{background:rgba(255,255,255,.35)}
.calc-ma-num{
  width:4rem;text-align:center;background:rgba(255,255,255,.15);
  border:1.5px solid rgba(255,255,255,.3);border-radius:var(--r-sm);
  color:#fff;font-family:var(--font);font-size:1.125rem;
  font-weight:700;padding:.25rem .5rem;
}
.calc-ma-num:focus{outline:none;border-color:#fff;background:rgba(255,255,255,.25)}

/* Table headers */
.calc-thead{
  display:grid;grid-template-columns:2.5rem 1fr 6rem;
  background:var(--bg-2);border-bottom:2px solid var(--border);
  padding:.625rem 1rem;gap:.5rem;
}
.calc-thead > *{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.calc-th-num,.calc-th-unit,.calc-th-total{text-align:right}

/* Group header */
.calc-group-header{
  padding:.5rem 1rem .375rem;
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.07em;color:var(--blue);
  background:var(--blue-50);border-top:1px solid var(--blue-100);
  border-bottom:1px solid var(--blue-100);
  margin-top:.25rem;
}
.calc-group-header:first-child{margin-top:0}

/* Item row */
.calc-row{
  display:grid;grid-template-columns:2.5rem 1fr 6rem;
  align-items:center;gap:.5rem;
  padding:.75rem 1rem;
  border-bottom:1px solid var(--border);
  background:var(--white);
  transition:background var(--t),opacity var(--t);
}
.calc-row:hover{background:var(--bg)}

/* Toggle switch */
.calc-cb-wrap{display:inline-flex;align-items:center;cursor:pointer}
.calc-cb{display:none}
.calc-cb-track{
  display:block;width:2.25rem;height:1.25rem;
  background:var(--border);border-radius:999px;position:relative;
  transition:background var(--t);flex-shrink:0;
}
.calc-cb-track::after{
  content:'';position:absolute;top:2px;left:2px;
  width:calc(1.25rem - 4px);height:calc(1.25rem - 4px);
  border-radius:50%;background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
  transition:transform var(--t);
}
.calc-cb:checked + .calc-cb-track{background:var(--blue)}
.calc-cb:checked + .calc-cb-track::after{transform:translateX(1rem)}

.calc-td-name{display:flex;flex-direction:column;gap:.125rem}
.calc-name{font-size:.9375rem;font-weight:500;color:var(--text)}
.calc-einheit{font-size:.75rem;color:var(--subtle)}

.calc-qty{
  width:100%;text-align:right;padding:.375rem .5rem;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  font-family:var(--font);font-size:.9375rem;color:var(--text);
  background:var(--white);transition:border-color var(--t);
}
.calc-qty:focus{outline:none;border-color:var(--blue)}
.calc-qty:disabled{opacity:.35;cursor:not-allowed}

.calc-td-unit{text-align:right;font-size:.9375rem;color:var(--muted)}
.calc-td-total{text-align:right;font-size:.9375rem;font-weight:600;color:var(--text)}
.calc-line-total{transition:color var(--t)}

/* Totals */
.calc-totals{
  background:var(--bg);border-top:2px solid var(--border);
  border-radius:0 0 var(--r-md) var(--r-md);
  padding:1rem 1.25rem;
}
.calc-total-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:.5rem 0;border-bottom:1px solid var(--border);
  font-size:.9375rem;color:var(--muted);
}
.calc-total-row:last-of-type{border-bottom:none}
.calc-total-row--main{
  font-size:1.25rem;font-weight:800;color:var(--text);
  padding-top:.75rem;
}
.calc-total-row--main span:last-child{color:var(--blue);font-size:1.5rem}
.calc-hint{font-size:.8125rem;color:var(--subtle);margin-top:.625rem}

/* Sidebar CTA */
.calc-cta-sidebar{position:sticky;top:calc(4.25rem + 1.5rem)}
.calc-cta-box{
  background:linear-gradient(160deg,var(--blue-deep) 0%,var(--blue) 100%);
  border-radius:var(--r-lg);padding:2rem;
  box-shadow:0 8px 32px rgba(37,99,235,.3);
  display:flex;flex-direction:column;gap:1rem;
}
.calc-cta-total-label{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.6)}
.calc-cta-total{font-size:2.25rem;font-weight:800;color:#fff;line-height:1;letter-spacing:-.03em}
.calc-cta-per-ma{font-size:.875rem;color:rgba(255,255,255,.65);margin-top:-.25rem}
.calc-cta-btn{
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  width:100%;padding:.875rem 1.25rem;
  background:#fff;color:var(--blue-deep);
  border:none;border-radius:var(--r-sm);
  font-family:var(--font);font-size:.9375rem;font-weight:700;
  text-decoration:none;cursor:pointer;
  transition:background var(--t),color var(--t);
}
.calc-cta-btn:hover{background:var(--blue-50);color:var(--blue)}
.calc-cta-link{
  display:block;text-align:center;
  color:rgba(255,255,255,.75);font-size:.875rem;font-weight:500;
  text-decoration:none;
}
.calc-cta-link:hover{color:#fff;text-decoration:underline}
.calc-cta-checks{
  list-style:none;display:flex;flex-direction:column;gap:.375rem;
  padding-top:.75rem;border-top:1px solid rgba(255,255,255,.15);
}
.calc-cta-checks li{font-size:.8125rem;color:rgba(255,255,255,.65)}

@media(max-width:1100px){.calc-layout{grid-template-columns:1fr}}
@media(max-width:768px){
  .calc-thead,.calc-row{grid-template-columns:2rem 1fr 4rem 0 6rem}
  .calc-th-unit,.calc-td-unit{display:none}
  .calc-cta-sidebar{position:static}
}

/* ── Kostenrechner (alt, Toggles) ───────────────────────────────────── */
.calc-group{
  border-bottom:1px solid var(--border);
  padding-block:1rem;
}
.calc-group:first-of-type{padding-top:0}
.calc-row-head{
  display:flex;align-items:center;
  justify-content:space-between;gap:1rem;
}
.calc-toggle-label{
  display:flex;align-items:center;gap:.625rem;
  font-size:.9375rem;font-weight:500;color:var(--body);
  cursor:pointer;flex:1;user-select:none;
}
.calc-toggle-label input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:2.5rem;height:1.375rem;flex-shrink:0;
  background:var(--border);border-radius:999px;
  position:relative;cursor:pointer;
  transition:background var(--t);
}
.calc-toggle-label input[type="checkbox"]:checked{background:var(--blue)}
.calc-toggle-label input[type="checkbox"]::after{
  content:'';position:absolute;
  top:2px;left:2px;width:calc(1.375rem - 4px);height:calc(1.375rem - 4px);
  border-radius:50%;background:white;
  transition:transform var(--t);box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.calc-toggle-label input[type="checkbox"]:checked::after{
  transform:translateX(1.125rem);
}
.calc-select{
  font-family:var(--font);font-size:.875rem;color:var(--body);
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--r-sm);padding:.375rem .75rem;
  cursor:pointer;flex-shrink:0;max-width:220px;
  transition:border-color var(--t);
}
.calc-select:focus{outline:none;border-color:var(--blue)}
.calc-select:disabled{opacity:.4;cursor:not-allowed}
.calc-fixed{
  font-size:.875rem;font-weight:600;color:var(--muted);
  flex-shrink:0;white-space:nowrap;
}

.calc-line{
  display:flex;justify-content:space-between;
  font-size:.875rem;color:rgba(255,255,255,.7);
}
.calc-line span:last-child{font-weight:600;color:rgba(255,255,255,.9)}

@media(max-width:1024px){
  #calc{grid-template-columns:1fr!important}
}
@media(max-width:768px){
  .calc-row-head{flex-direction:column;align-items:flex-start;gap:.5rem}
  .calc-select{max-width:100%;width:100%}
  .calc-thead,.calc-row{grid-template-columns:2rem 1fr 5rem}
}

/* ── Knowledge Base FAQ Accordion ───────────────────────────────────── */
.kb-item{border:1.5px solid var(--border);border-radius:var(--r);background:var(--white);overflow:hidden;transition:border-color var(--t),box-shadow var(--t)}
.kb-item:has(.kb-q[aria-expanded="true"]){border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-100)}

.kb-q{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:1.125rem 1.25rem;
  background:none;border:none;cursor:pointer;
  font-family:var(--font);font-size:.9375rem;font-weight:600;
  color:var(--text);text-align:left;gap:1rem;
  transition:background var(--t);
}
.kb-q:hover{background:var(--bg)}
.kb-q[aria-expanded="true"]{color:var(--blue);background:var(--blue-50)}
.kb-chevron{flex-shrink:0;color:var(--muted);transition:transform var(--t)}
.kb-q[aria-expanded="true"] .kb-chevron{transform:rotate(180deg);color:var(--blue)}

.kb-a{
  padding:0 1.25rem 1.25rem;
  border-top:1px solid var(--blue-100);
}
.kb-a p{font-size:.9375rem;color:var(--body);line-height:1.75;margin-top:.875rem}
.kb-a p:first-child{margin-top:.875rem}

/* ── Cookie Modal ───────────────────────────────────────────────────── */
.cookie-modal{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem}
.cookie-modal[hidden]{display:none}
.cookie-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.6);backdrop-filter:blur(4px)}
.cookie-modal__box{
  position:relative;z-index:1;
  background:var(--white);border-radius:var(--r-xl);
  width:100%;max-width:560px;max-height:90vh;overflow-y:auto;
  box-shadow:var(--shadow-xl);
}
.cookie-modal__head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;
  padding:1.75rem 1.75rem 1.25rem;
  border-bottom:1px solid var(--border);
}
.cookie-modal__title{font-size:1.25rem;color:var(--text);margin-bottom:.375rem}
.cookie-modal__sub{font-size:.9375rem;color:var(--muted);max-width:none}
.cookie-modal__close{
  flex-shrink:0;background:none;border:none;cursor:pointer;
  color:var(--muted);padding:.375rem;border-radius:var(--r-sm);
  transition:background var(--t),color var(--t);
}
.cookie-modal__close:hover{background:var(--bg);color:var(--text)}

.cookie-modal__body{padding:1.25rem 1.75rem;display:flex;flex-direction:column;gap:.75rem}
.cookie-modal__legal{font-size:.8125rem;color:var(--subtle);line-height:1.6;padding-top:.75rem;border-top:1px solid var(--border)}
.cookie-modal__foot{
  display:flex;justify-content:flex-end;gap:.75rem;
  padding:1.25rem 1.75rem;border-top:1px solid var(--border);
}

.cookie-cat{border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.cookie-cat__head{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1rem 1.125rem;background:var(--bg);
}
.cookie-cat__name{font-size:.9375rem;font-weight:600;color:var(--text);margin-bottom:.25rem}
.cookie-cat__desc{font-size:.8125rem;color:var(--muted);max-width:none}
.cookie-cat__detail{padding:.875rem 1.125rem;background:var(--white);border-top:1px solid var(--border)}

.cookie-toggle{font-size:.75rem;font-weight:600;color:var(--muted);white-space:nowrap}
.cookie-toggle--on{color:var(--green)}

.cookie-switch{display:inline-flex;align-items:center;cursor:pointer}
.cookie-switch input{display:none}
.cookie-switch__track{
  width:44px;height:24px;background:var(--border);border-radius:12px;
  position:relative;transition:background var(--t);flex-shrink:0;
}
.cookie-switch__track::after{
  content:'';position:absolute;top:3px;left:3px;
  width:18px;height:18px;border-radius:50%;background:white;
  box-shadow:var(--shadow-sm);transition:transform var(--t);
}
.cookie-switch input:checked + .cookie-switch__track{background:var(--blue)}
.cookie-switch input:checked + .cookie-switch__track::after{transform:translateX(20px)}

.cookie-table{width:100%;border-collapse:collapse;font-size:.8125rem}
.cookie-table td{padding:.375rem .5rem;color:var(--muted);border-bottom:1px solid var(--border)}
.cookie-table tr:last-child td{border-bottom:none}
.cookie-table strong{color:var(--text)}

/* ── Cookie Banner Bar ──────────────────────────────────────────────── */
.cookie-banner-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:400;
  background:var(--white);border-top:1px solid var(--border);
  box-shadow:0 -4px 20px rgba(0,0,0,.08);
  padding:1.25rem var(--px);
}
.cookie-banner-bar[hidden]{display:none}
.cookie-banner-bar__inner{
  max-width:var(--wrap);margin-inline:auto;
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
}
.cookie-banner-bar__text{font-size:.9375rem;color:var(--body);flex:1;line-height:1.6}
.cookie-banner-bar__text a{color:var(--blue)}
.cookie-banner-bar__actions{display:flex;gap:.75rem;flex-shrink:0}

/* ── Responsive additions ────────────────────────────────────────────── */
@media(max-width:768px){
  .form-tabs{flex-wrap:wrap}
  .form-tab{flex:1;justify-content:center;padding:.625rem 1rem;font-size:.875rem}
  .trust-logos{gap:.75rem}
  .trust-logo{padding:.625rem 1rem;font-size:.8125rem}
  .cookie-modal__head,.cookie-modal__body,.cookie-modal__foot{padding-inline:1.25rem}
  .cookie-banner-bar__inner{flex-direction:column;align-items:flex-start}
}


/* ── Breadcrumb navigation ────────────────────────────────────────── */
.breadcrumb{background:#F8FAFC;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:.625rem 0;font-size:.8125rem}
[data-theme="dark"] .breadcrumb{background:#060B18;border-top-color:var(--border);border-bottom-color:var(--border);box-shadow:inset 0 1px 0 rgba(255,255,255,.03)}
[data-theme="dark"] .breadcrumb .sep{color:var(--subtle)}
.breadcrumb ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;align-items:center;gap:.25rem}
.breadcrumb li{display:inline-flex;align-items:center;color:var(--muted)}
.breadcrumb a{color:var(--muted);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:var(--blue);text-decoration:underline}
.breadcrumb li[aria-current="page"]{color:var(--text);font-weight:600}
.breadcrumb .sep{margin:0 .5rem;color:#CBD5E1;user-select:none}

/* ─── Preisrechner v2 ──────────────────────────────────────────────── */
.calc2-layout{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:2.5rem;align-items:start}
.calc2-main{min-width:0}
/* ─── Wissensbasis: Category chips ─────────────────────────────────── */
.kb-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.5rem;max-width:820px}
.kb-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1.5px solid var(--border);border-radius:999px;color:var(--text);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1}
.kb-chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-50)}
.kb-chip.is-active{background:var(--blue);border-color:var(--blue);color:#fff}
.kb-chip-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.25rem;padding:0 .4rem;background:var(--bg);color:var(--muted);border-radius:999px;font-size:.75rem;font-weight:700;line-height:1}
.kb-chip:hover .kb-chip-count{background:#fff;color:var(--blue)}
.kb-chip.is-active .kb-chip-count{background:rgba(255,255,255,.22);color:#fff}

.calc2-step{background:#fff;border:1px solid var(--border);border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 2px 8px rgba(15,23,42,.04);opacity:.55;transition:opacity .4s ease,box-shadow .4s ease,border-color .4s ease}
.calc2-step.is-active{opacity:1;box-shadow:0 4px 16px rgba(37,99,235,.08);border-color:#CBD5E1}
.calc2-summary{opacity:.75;transition:opacity .4s ease}
.calc2-summary.is-active{opacity:1}
.calc2-step-head{display:flex;gap:1rem;margin-bottom:1.5rem}
.calc2-step-num{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:2.25rem;height:2.25rem;background:var(--blue);color:#fff;border-radius:999px;font-weight:800;font-size:1rem;line-height:1}
.calc2-step-num--dark{background:#0F172A}
.calc2-step-head h2{font-size:1.25rem;font-weight:700;margin-bottom:.375rem;line-height:1.3;letter-spacing:-.01em}
.calc2-step-head p{font-size:.9375rem;color:var(--muted);line-height:1.6;margin:0}

.calc2-ma-picker{display:flex;align-items:center;gap:.625rem;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:.5rem;max-width:fit-content;margin:0 auto}
.calc2-ma-btn{width:2.5rem;height:2.5rem;border-radius:8px;background:#fff;border:1px solid var(--border);font-size:1.25rem;font-weight:700;color:var(--blue);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}
.calc2-ma-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.calc2-ma-input{width:5rem;text-align:center;font-size:1.5rem;font-weight:800;color:var(--text);background:transparent;border:none;font-family:inherit;-moz-appearance:textfield}
.calc2-ma-input::-webkit-outer-spin-button,.calc2-ma-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.calc2-ma-input:focus{outline:none}
.calc2-ma-unit{font-size:.875rem;color:var(--muted);font-weight:600;padding:0 .75rem 0 .25rem}
.calc2-ma-presets{display:flex;align-items:center;justify-content:center;gap:.375rem;margin-top:1.25rem;flex-wrap:wrap}
.calc2-presets-label{font-size:.8125rem;color:var(--muted);margin-right:.375rem}
.calc2-preset{padding:.375rem .875rem;background:#fff;border:1px solid var(--border);border-radius:999px;font-size:.8125rem;font-weight:600;color:var(--text);cursor:pointer;transition:all .15s;font-family:inherit}
.calc2-preset:hover{background:var(--blue-50);border-color:var(--blue);color:var(--blue)}

.calc2-group-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin:1.75rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.calc2-group-title:first-of-type{margin-top:0}

.calc2-item{display:grid;grid-template-columns:2.5rem minmax(0,1fr) auto;gap:1rem;align-items:center;padding:1rem;border:1.5px solid var(--border);border-radius:12px;margin-bottom:.625rem;background:#fff;transition:border-color .15s,background .15s}
.calc2-item.is-on{border-color:var(--blue);background:var(--blue-50)}
.calc2-item-switch{cursor:pointer;display:flex;align-items:center;justify-content:center}
.calc2-cb{display:none}
.calc2-track{display:inline-block;width:2.25rem;height:1.25rem;background:#CBD5E1;border-radius:999px;position:relative;transition:background .15s}
.calc2-track::after{content:"";position:absolute;top:2px;left:2px;width:1rem;height:1rem;background:#fff;border-radius:50%;transition:transform .15s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.calc2-cb:checked + .calc2-track{background:var(--blue)}
.calc2-cb:checked + .calc2-track::after{transform:translateX(1rem)}
.calc2-item-body{min-width:0}
.calc2-item-title{display:flex;align-items:baseline;gap:.625rem;flex-wrap:wrap;margin-bottom:.25rem}
.calc2-item-name{font-size:1rem;font-weight:600;color:var(--text);line-height:1.3}
.calc2-item-unit{font-size:.75rem;color:var(--subtle);background:var(--bg);padding:.15em .6em;border-radius:999px;font-weight:500}
.calc2-item-desc{font-size:.875rem;color:var(--muted);line-height:1.55;margin:0}
.calc2-item-qty{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}
.calc2-qty-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--subtle)}
.calc2-qty{width:4.5rem;height:2.25rem;text-align:center;border:1.5px solid var(--border);border-radius:6px;font-size:.9375rem;font-weight:700;color:var(--text);font-family:inherit;background:#fff;transition:border-color .15s}
.calc2-qty:focus{outline:none;border-color:var(--blue)}
.calc2-qty:disabled{opacity:.4;cursor:not-allowed;background:var(--bg)}
.calc2-qty-auto{font-size:.7rem;color:var(--subtle);font-style:italic}

.calc2-summary{position:sticky;top:calc(4.25rem + 1.5rem);background:linear-gradient(180deg,#0F172A,#1E293B);color:#fff;border-radius:16px;padding:1.75rem;box-shadow:0 8px 32px rgba(15,23,42,.18)}
.calc2-summary-head{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.calc2-summary-head h2{font-size:1.0625rem;font-weight:700;color:#fff;line-height:1.2}
.calc2-sum-meta{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:.875rem;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:1rem}
.calc2-sum-ma{font-size:1rem;font-weight:700;color:#fff}
.calc2-sum-count{font-size:.75rem;color:rgba(255,255,255,.55)}
.calc2-sum-list{list-style:none;margin:0 0 1.25rem;padding:0;max-height:260px;overflow-y:auto}
.calc2-sum-list li{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;padding:.5rem 0;font-size:.875rem;color:rgba(255,255,255,.85);border-bottom:1px solid rgba(255,255,255,.06)}
.calc2-sum-list li:last-child{border-bottom:none}
.calc2-sum-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}
.calc2-sum-qty{font-weight:700;color:#60A5FA;flex-shrink:0;font-variant-numeric:tabular-nums}
.calc2-sum-empty{color:rgba(255,255,255,.4);font-style:italic;text-align:center;padding:1rem 0!important}

.calc2-gate{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;margin-bottom:1rem}
.calc2-gate-head{display:flex;align-items:center;gap:.5rem;color:#60A5FA;margin-bottom:.375rem}
.calc2-gate-head strong{font-size:.9375rem;font-weight:700;color:#fff}
.calc2-gate-sub{font-size:.75rem;color:rgba(255,255,255,.55);line-height:1.5;margin:0 0 .875rem}
.calc2-gate-form{display:flex;flex-direction:column;gap:.5rem}
.calc2-gate-form input{background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:6px;padding:.625rem .75rem;color:#fff;font-family:inherit;font-size:.875rem;transition:border-color .15s;width:100%}
.calc2-gate-form input:focus{outline:none;border-color:#60A5FA;background:rgba(255,255,255,.12)}
.calc2-gate-form input::placeholder{color:rgba(255,255,255,.4)}
.calc2-gate-btn{display:block;width:100%;padding:.75rem 1rem;background:var(--blue);color:#fff;border:none;border-radius:8px;font-family:inherit;font-size:.9375rem;font-weight:700;cursor:pointer;transition:background .15s;text-align:center;text-decoration:none;margin-top:.25rem}
.calc2-gate-btn:hover{background:#1D4ED8}
.calc2-gate-btn:disabled{opacity:.6;cursor:wait}
.calc2-gate-btn--light{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2)}
.calc2-gate-btn--light:hover{background:rgba(255,255,255,.15)}
.calc2-gate-err{color:#FCA5A5;font-size:.8125rem;text-align:center;margin:.25rem 0 0}

.calc2-gate-success{text-align:center;padding:.5rem 0}
.calc2-gate-check{width:3rem;height:3rem;margin:0 auto .75rem;border-radius:50%;background:#065F46;color:#6EE7B7;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;border:2px solid #10B981}
.calc2-gate-success strong{display:block;color:#fff;font-size:1rem;margin-bottom:.5rem}
.calc2-gate-success p{font-size:.8125rem;color:rgba(255,255,255,.6);line-height:1.6;margin-bottom:1rem}
.calc2-gate-success span{color:#60A5FA;font-weight:600}

.calc2-gate-trust{list-style:none;margin:0;padding:0}
.calc2-gate-trust li{font-size:.75rem;color:rgba(255,255,255,.5);padding:.25rem 0}

.trust-benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.tb{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1.5rem;text-align:center}
.tb-icon{font-size:2rem;margin-bottom:.75rem}
.tb h3{font-size:1rem;font-weight:700;margin-bottom:.5rem;color:var(--text)}
.tb p{font-size:.875rem;color:var(--muted);line-height:1.6;margin:0}

@media(max-width:1080px){
  .calc2-layout{grid-template-columns:1fr}
  .calc2-summary{position:static;margin-top:1.5rem}
  .calc2-sum-list{max-height:none}
}
@media(max-width:720px){
  .calc2-step{padding:1.5rem}
  .calc2-step-head{flex-direction:column;gap:.5rem}
  .calc2-step-head h2{font-size:1.125rem}
  .calc2-item{grid-template-columns:2.5rem 1fr;gap:.75rem;padding:.875rem}
  .calc2-item-qty{grid-column:2;flex-direction:row;align-items:center;justify-content:flex-end;gap:.5rem}
  .calc2-qty-label{display:none}
  .trust-benefits{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .trust-benefits{grid-template-columns:1fr}
  .calc2-ma-input{width:3.5rem;font-size:1.25rem}
  .calc2-ma-unit{display:none}
}

/* ══════════════════════════════════════════════════════════════════════
   Dark mode
   Activated by <html data-theme="dark">
   ══════════════════════════════════════════════════════════════════════ */
:root{color-scheme:light}
[data-theme="dark"]{
  color-scheme:dark;
  --white:  #1E293B;
  --bg:     #0F172A;
  --bg-2:   #111827;
  --text:   #F1F5F9;
  --body:   #CBD5E1;
  --muted:  #94A3B8;
  --subtle: #64748B;
  --border: #334155;
  --border-blue: #2563EB;
  --blue-50:  rgba(37,99,235,.12);
  --blue-100: rgba(37,99,235,.28);
  --shadow-xs: 0 1px 2px rgba(0,0,0,.35);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.3);
  --shadow-md: 0 4px 12px rgba(0,0,0,.5);
  --shadow-lg: 0 10px 30px rgba(0,0,0,.55);
  --shadow-xl: 0 20px 50px rgba(0,0,0,.6);
}

/* Logo swap */
.logo .logo-dark{display:none}
[data-theme="dark"] .logo .logo-light{display:none}
[data-theme="dark"] .logo .logo-dark{display:inline-block}

/* Header translucent surface */
[data-theme="dark"] .site-header{background:rgba(15,23,42,.92);border-bottom-color:var(--border);box-shadow:0 1px 0 rgba(255,255,255,.04)}

/* Surfaces that use hardcoded #fff */
[data-theme="dark"] .calc2-step,
[data-theme="dark"] .calc2-ma-btn,
[data-theme="dark"] .calc2-preset,
[data-theme="dark"] .calc2-item,
[data-theme="dark"] .calc2-qty,
[data-theme="dark"] .tb,
[data-theme="dark"] .kb-chip,
[data-theme="dark"] .ref-block{background:var(--white)}

[data-theme="dark"] .calc2-item.is-on{background:var(--blue-50)}
[data-theme="dark"] .calc2-ma-picker{background:var(--bg-2)}
[data-theme="dark"] .kb-chip-count{background:var(--bg-2);color:var(--muted)}
[data-theme="dark"] .kb-chip:hover{background:var(--blue-50)}
[data-theme="dark"] .kb-chip:hover .kb-chip-count{background:var(--white);color:var(--blue)}

/* Btn w (white button on blue hero) — keep inverted intent */
[data-theme="dark"] .btn-w{background:#E2E8F0;color:var(--blue-deep);border-color:#E2E8F0}

/* Inputs / textareas / selects */
[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select,
[data-theme="dark"] .finput,
[data-theme="dark"] .fselect{background:var(--bg-2);color:var(--text);border-color:var(--border)}
[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus{border-color:var(--blue)}
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder{color:var(--subtle)}

/* Form tabs underline color stays fine; page-hero gradient stays fine */
[data-theme="dark"] .page-hero{background:linear-gradient(180deg,var(--bg-2),var(--bg))}

/* Section alternating backgrounds */
[data-theme="dark"] .section--bg2{background:var(--bg-2)}
/* The blue-tint section has a hard-coded light override further up — re-override for dark */
[data-theme="dark"] .section--blue-tint{background:rgba(37,99,235,.06);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* ITS AG / DSV product badge: dark-blue text would be invisible on dark bg */
[data-theme="dark"] .product-badge{background:rgba(37,99,235,.15);border-color:rgba(37,99,235,.35);color:#93C5FD}
[data-theme="dark"] .product-badge__sep{color:rgba(147,197,253,.4)}

/* Hero: keep slight tint so there's visual separation from page bg */
[data-theme="dark"] .hero{background:linear-gradient(180deg,var(--white),var(--bg))}

/* Quote / testimonial boxes */
[data-theme="dark"] .quote{background:var(--white);border-color:var(--border)}

/* Wissensbasis search bar band */
[data-theme="dark"] .kb-chips{--_ignore:0} /* no-op to anchor selectors below */
[data-theme="dark"] main > div[style*="background:var(--blue-50)"]{background:var(--bg-2)!important;border-bottom-color:var(--border)!important}

/* Blue-50 block backgrounds (used as soft info boxes inline) */
[data-theme="dark"] [style*="background:var(--blue-50)"]{background:rgba(37,99,235,.12)!important;border-color:rgba(37,99,235,.25)!important;color:var(--body)!important}
[data-theme="dark"] [style*="background:var(--blue-50)"] *{color:inherit!important}

/* FAQ accordion */
[data-theme="dark"] .kb-item{background:var(--white);border-color:var(--border)}
[data-theme="dark"] .kb-q{color:var(--text)}
[data-theme="dark"] .kb-q:hover{background:var(--bg-2)}

/* Language switcher */
.lang-switcher{display:inline-flex;align-items:center;background:transparent;border:1px solid var(--border);border-radius:8px;overflow:hidden;flex-shrink:0;height:2.25rem}
.lang-btn{display:inline-flex;align-items:center;justify-content:center;min-width:2.25rem;padding:0 .5rem;height:100%;font-family:inherit;font-size:.75rem;font-weight:700;color:var(--muted);text-decoration:none;letter-spacing:.05em;transition:color var(--t),background var(--t);border:none;cursor:pointer}
.lang-btn:hover{color:var(--text);background:var(--bg)}
.lang-btn.is-active{background:var(--blue);color:#fff}
.lang-btn + .lang-btn{border-left:1px solid var(--border)}
.lang-btn.is-active + .lang-btn,.lang-btn:has(+ .lang-btn.is-active),.lang-btn.is-active{border-left-color:var(--blue)}

/* Theme toggle button */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:8px;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:color var(--t),background var(--t),border-color var(--t);padding:0;flex-shrink:0}
.theme-toggle:hover{color:var(--text);background:var(--bg);border-color:var(--subtle)}
.theme-toggle svg{width:1rem;height:1rem}
.theme-toggle .sun,.theme-toggle .moon{transition:opacity .2s,transform .2s}
.theme-toggle .moon{display:none}
[data-theme="dark"] .theme-toggle .sun{display:none}
[data-theme="dark"] .theme-toggle .moon{display:inline-block}

/* Mobile: push toggle before the hamburger */
@media(max-width:768px){
  .theme-toggle{margin-right:.5rem}
}
