/* Self-hosted variable fonts (DSGVO: no third-party CDN) */
@font-face{font-family:'Inter';font-style:normal;font-display:swap;font-weight:100 900;
  src:url('/assets/fonts/inter-var.woff2') format('woff2')}
@font-face{font-family:'Libre Franklin';font-style:normal;font-display:swap;font-weight:100 900;
  src:url('/assets/fonts/libre-franklin-var.woff2') format('woff2')}
/* ============================================================
   EnergyFlow Regulatory Desk - Design System
   "Regulatory Command Centre"  ·  v20260622a
   ============================================================ */

:root{
  /* Navy / ink */
  --navy-900:#0A1A2F;
  --navy-800:#0E2238;
  --navy-700:#102A43;
  --navy-600:#1B3A5B;
  --navy-500:#274B6D;
  --ink:#1A2632;
  --ink-soft:#33414F;

  /* Steel / petrol accent */
  --steel-700:#155A72;
  --steel-600:#1C6E87;
  --steel-500:#2A86A0;
  --steel-300:#7FB6C7;
  --steel-100:#E2EEF2;

  /* Gold accent (logo) */
  --gold-600:#A8862F;
  --gold-500:#C6A44E;
  --gold-300:#E2CE92;

  /* Neutrals */
  --white:#FFFFFF;
  --grey-50:#F6F8FA;
  --grey-100:#EEF1F4;
  --grey-200:#DEE4EA;
  --grey-300:#C8D1DA;
  --grey-400:#9AA7B4;
  --grey-500:#6B7886;

  --grey-600:#525E6B;

  /* Risk ampel (sparing) */
  --risk-green:#2E7D5B;
  --risk-green-bg:#E7F2EC;
  --risk-amber:#B9821A;
  --risk-amber-bg:#F8F0DD;
  --risk-red:#B23A48;
  --risk-red-bg:#F7E6E8;

  /* Type */
  --f-display:'Libre Franklin',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --f-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

  /* Spacing scale */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px;
  --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;

  /* Radii / shadow */
  --r-sm:6px; --r-md:10px; --r-lg:16px; --r-xl:24px;
  --sh-sm:0 1px 2px rgba(16,42,67,.06),0 1px 3px rgba(16,42,67,.10);
  --sh-md:0 4px 12px rgba(16,42,67,.08),0 2px 4px rgba(16,42,67,.06);
  --sh-lg:0 18px 48px rgba(10,26,47,.16);
  --sh-card:0 1px 3px rgba(16,42,67,.08),0 12px 28px rgba(16,42,67,.07);

  --container:1180px;
  --container-narrow:820px;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--white);
  line-height:1.62;
  font-size:17px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--steel-600);text-decoration:none;transition:color .18s}
a:hover{color:var(--steel-700)}
ul,ol{padding-left:1.25em}
strong{font-weight:600;color:var(--ink)}

/* ---------- type ---------- */
h1,h2,h3,h4,h5{font-family:var(--f-display);color:var(--navy-800);line-height:1.16;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,4.6vw,3.45rem);font-weight:800;letter-spacing:-.022em}
h2{font-size:clamp(1.6rem,3.1vw,2.4rem);font-weight:750}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
h4{font-size:1.08rem;font-weight:700}
p{margin:0 0 1.05em}
.lead{font-size:clamp(1.08rem,1.7vw,1.32rem);line-height:1.55;color:var(--ink-soft);font-weight:400}

/* ---------- layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.narrow{max-width:var(--container-narrow);margin-left:auto;margin-right:auto}
section{padding:var(--s-9) 0}
.sec-sm{padding:var(--s-7) 0}
.bg-grey{background:var(--grey-50)}
.bg-navy{background:var(--navy-800);color:#D9E2EC}
.bg-navy h1,.bg-navy h2,.bg-navy h3,.bg-navy h4{color:#fff}
.bg-steel{background:var(--steel-100)}

.eyebrow{
  font-family:var(--f-display);
  font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--steel-600);display:inline-flex;align-items:center;gap:.6em;margin-bottom:1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold-500);display:inline-block}
.bg-navy .eyebrow{color:var(--gold-300)}
.bg-navy .eyebrow::before{background:var(--gold-500)}

.sec-head{max-width:760px;margin-bottom:var(--s-7)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head p{color:var(--ink-soft);font-size:1.12rem}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--f-display);font-weight:650;font-size:1rem;line-height:1;
  padding:15px 26px;border-radius:var(--r-sm);border:1.5px solid transparent;
  cursor:pointer;transition:.18s ease;text-align:center;
}
.btn-primary{background:var(--steel-600);color:#fff;border-color:var(--steel-600);box-shadow:0 6px 18px rgba(28,110,135,.28)}
.btn-primary:hover{background:var(--steel-700);border-color:var(--steel-700);color:#fff;transform:translateY(-1px);box-shadow:0 10px 24px rgba(21,90,114,.34)}
.btn-gold{background:var(--gold-500);color:var(--navy-900);border-color:var(--gold-500)}
.btn-gold:hover{background:var(--gold-600);border-color:var(--gold-600);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--navy-800);border-color:var(--grey-300)}
.btn-ghost:hover{border-color:var(--navy-800);color:var(--navy-800);background:var(--grey-50)}
.bg-navy .btn-ghost,.hero .btn-ghost,.cta-band .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.bg-navy .btn-ghost:hover,.hero .btn-ghost:hover,.cta-band .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.12);color:#fff}
.btn-lg{padding:18px 34px;font-size:1.06rem}
.btn-block{width:100%}
.btn-arrow::after{content:"\2192";font-weight:500;transition:transform .18s}
.btn-arrow:hover::after{transform:translateX(3px)}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--grey-200)}
.nav{display:flex;align-items:center;justify-content:space-between;--navh:160px;height:var(--navh);gap:24px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:124px;width:auto}
.brand-txt{display:flex;flex-direction:column;line-height:1}
.brand-txt .b1{font-family:var(--f-display);font-weight:800;font-size:1.18rem;color:var(--navy-800);letter-spacing:-.01em}
.brand-txt .b2{font-family:var(--f-display);font-weight:600;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--steel-600);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--f-display);font-size:.95rem;font-weight:550;color:var(--ink-soft);padding:9px 13px;border-radius:6px}
.nav-links a:hover{color:var(--navy-800);background:var(--grey-50)}
.nav-links a.active{color:var(--navy-800)}
.nav-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;flex-direction:column;justify-content:center;gap:5px}
.nav-toggle span{display:block;height:2.5px;width:24px;background:var(--navy-800);border-radius:2px;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:1080px){
  .nav{--navh:124px}
  .brand img{height:96px}
  .nav-links{position:fixed;inset:var(--navh) 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:12px 20px 24px;border-bottom:1px solid var(--grey-200);box-shadow:var(--sh-lg);transform:translateY(-130%);transition:transform .3s;max-height:calc(100vh - var(--navh));overflow-y:auto}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:13px 8px;border-bottom:1px solid var(--grey-100);border-radius:0}
  .nav-toggle{display:flex}
  .nav-cta .btn:not(.nav-cta-keep){display:none}
}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--navy-800);color:#D9E2EC;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;z-index:0}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(1100px 520px at 78% -8%,rgba(42,134,160,.30),transparent 60%),
  radial-gradient(720px 420px at 8% 108%,rgba(198,164,78,.10),transparent 60%);
  pointer-events:none;z-index:1}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;gap:56px;align-items:center;padding:var(--s-9) 0 calc(var(--s-9) + 8px)}
.hero h1{color:#fff;margin-bottom:1.1rem}
.hero .lead{color:#B9C7D6;max-width:36ch}
.hero-claim{font-family:var(--f-display);font-weight:600;color:var(--gold-300);font-size:1.05rem;margin:0 0 1.4rem;letter-spacing:.01em}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:34px;padding-top:26px;border-top:1px solid rgba(255,255,255,.13)}
.hero-trust span{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:#9FB1C2;font-weight:500}
.hero-trust span::before{content:"\2713";color:var(--steel-300);font-weight:700}
.hero-visual{position:relative}
.hero-card{background:linear-gradient(165deg,#102A43,#0A1A2F);border:1px solid rgba(127,182,199,.22);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-lg)}
.hero-card h4{color:#fff;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.hero-card h4::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--steel-500);box-shadow:0 0 0 4px rgba(42,134,160,.22)}
.mini-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:.92rem}
.mini-row:last-child{border-bottom:0}
.mini-row .lbl{color:#AFC0D0}
.hero-img{width:100%;border-radius:var(--r-lg);box-shadow:var(--sh-lg)}

@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px;padding:var(--s-8) 0}
  .hero .lead,.hero h1{max-width:none}
}

/* ---------- chips / ampel ---------- */
.chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--f-display);font-weight:650;font-size:.8rem;padding:5px 12px;border-radius:100px;letter-spacing:.02em}
.chip::before{content:"";width:8px;height:8px;border-radius:50%}
.chip-green{background:var(--risk-green-bg);color:#1F5C42}.chip-green::before{background:var(--risk-green)}
.chip-amber{background:var(--risk-amber-bg);color:#85610F}.chip-amber::before{background:var(--risk-amber)}
.chip-red{background:var(--risk-red-bg);color:#8A2A35}.chip-red::before{background:var(--risk-red)}
.chip-steel{background:var(--steel-100);color:var(--steel-700)}.chip-steel::before{background:var(--steel-500)}
.chip-neutral{background:var(--grey-100);color:var(--grey-600)}.chip-neutral::before{background:var(--grey-400)}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--grey-200);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-sm);transition:.2s}
.card:hover{box-shadow:var(--sh-card);transform:translateY(-2px);border-color:var(--grey-300)}
.card h3{margin-bottom:.5em}
.card p:last-child{margin-bottom:0}
.card-ico{width:46px;height:46px;border-radius:10px;background:var(--steel-100);color:var(--steel-700);display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:1.3rem;font-weight:700;font-family:var(--f-display)}
.card-num{font-family:var(--f-display);font-weight:800;font-size:1.05rem;color:var(--gold-600);background:var(--grey-50);border:1px solid var(--grey-200);width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card-top-accent{border-top:3px solid var(--steel-500)}

/* feature list */
.flist{list-style:none;padding:0;margin:0}
.flist li{position:relative;padding:9px 0 9px 30px;border-bottom:1px solid var(--grey-100)}
.flist li:last-child{border-bottom:0}
.flist li::before{content:"\2713";position:absolute;left:0;top:9px;color:var(--steel-600);font-weight:800}
.flist.gold li::before{color:var(--gold-600)}
.flist.cross li::before{content:"\2715";color:var(--risk-red)}

/* ---------- tables ---------- */
.tbl-wrap{overflow-x:auto;border:1px solid var(--grey-200);border-radius:var(--r-md);box-shadow:var(--sh-sm)}
table.data{width:100%;border-collapse:collapse;font-size:.94rem;min-width:540px;background:#fff}
table.data th,table.data td{text-align:left;padding:14px 18px;border-bottom:1px solid var(--grey-100);vertical-align:top}
table.data thead th{background:var(--navy-800);color:#fff;font-family:var(--f-display);font-weight:600;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase}
table.data tbody tr:nth-child(even){background:var(--grey-50)}
table.data tbody tr:hover{background:var(--steel-100)}
table.data td strong{color:var(--navy-700)}

/* ---------- 7-Felder model ---------- */
.felder{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.felder{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.felder{grid-template-columns:1fr}}
.feld{background:#fff;border:1px solid var(--grey-200);border-radius:var(--r-md);padding:22px;position:relative;box-shadow:var(--sh-sm)}
.feld .fno{font-family:var(--f-display);font-weight:800;font-size:.8rem;color:var(--gold-600);letter-spacing:.1em}
.feld h4{margin:8px 0 6px;font-size:1.02rem}
.feld p{font-size:.9rem;color:var(--ink-soft);margin:0}

/* ---------- process ladder ---------- */
.ladder{position:relative;margin-top:var(--s-6)}
.step{display:grid;grid-template-columns:64px 1fr;gap:22px;padding-bottom:34px;position:relative}
.step:not(:last-child)::before{content:"";position:absolute;left:31px;top:56px;bottom:-6px;width:2px;background:linear-gradient(var(--steel-300),var(--grey-200))}
.step-no{width:64px;height:64px;border-radius:50%;background:var(--navy-800);color:#fff;font-family:var(--f-display);font-weight:800;font-size:1.3rem;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(14,34,56,.22);z-index:2}
.step-body{padding-top:6px}
.step-body h4{margin-bottom:.3em}
.step-body p{margin:0;color:var(--ink-soft)}

/* ---------- pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;align-items:stretch}
@media(max-width:1080px){.price-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.price-grid{grid-template-columns:1fr}}
.price-card{background:#fff;border:1px solid var(--grey-200);border-radius:var(--r-lg);padding:30px 26px;display:flex;flex-direction:column;box-shadow:var(--sh-sm);position:relative}
.price-card.featured{border:2px solid var(--steel-500);box-shadow:var(--sh-card)}
.price-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--steel-600);color:#fff;font-family:var(--f-display);font-weight:650;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 16px;border-radius:100px;white-space:nowrap}
.price-card h3{font-size:1.22rem;margin-bottom:6px}
.price-card .ptag{font-size:.9rem;color:var(--grey-600);min-height:42px;margin-bottom:14px}
.price-amount{font-family:var(--f-display);font-weight:800;color:var(--navy-800);font-size:2rem;line-height:1.1}
.price-amount small{display:block;font-size:.78rem;font-weight:500;color:var(--grey-500);letter-spacing:.02em;margin-top:5px;font-family:var(--f-body)}
.price-card .flist{margin:20px 0 24px;font-size:.92rem}
.price-card .flist li{padding:7px 0 7px 28px}
.price-card .btn{margin-top:auto}

/* ---------- tools ---------- */
.tool-shell{background:#fff;border:1px solid var(--grey-200);border-radius:var(--r-xl);box-shadow:var(--sh-card);overflow:hidden}
.tool-head{background:var(--navy-800);color:#fff;padding:26px 32px}
.tool-head h3{color:#fff;margin:0}
.tool-head p{color:#A9BACB;margin:.4em 0 0;font-size:.95rem}
.tool-body{padding:32px}
.q-block{padding:20px 0;border-bottom:1px solid var(--grey-100)}
.q-block:first-child{padding-top:0}
.q-block .q{font-family:var(--f-display);font-weight:650;color:var(--navy-800);margin-bottom:14px;display:block;font-size:1.02rem}
.opts{display:flex;flex-wrap:wrap;gap:10px}
.opt{position:relative}
.opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.opt label{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border:1.5px solid var(--grey-300);border-radius:8px;cursor:pointer;font-weight:550;font-size:.94rem;transition:.16s;background:#fff}
.opt input:checked+label{border-color:var(--steel-600);background:var(--steel-100);color:var(--steel-700)}
.opt input:focus-visible+label{outline:2px solid var(--steel-500);outline-offset:2px}

.field{margin-bottom:20px}
.field label{display:block;font-family:var(--f-display);font-weight:600;color:var(--navy-800);margin-bottom:7px;font-size:.95rem}
.field .hint{font-size:.82rem;color:var(--grey-500);font-weight:400;margin-top:4px}
input[type=text],input[type=email],input[type=tel],input[type=number],select,textarea{
  width:100%;font-family:var(--f-body);font-size:1rem;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--grey-300);border-radius:8px;background:#fff;transition:.16s}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--steel-500);box-shadow:0 0 0 3px rgba(42,134,160,.16)}
.range-row{display:flex;align-items:center;gap:16px}
.range-row input[type=range]{flex:1;accent-color:var(--steel-600)}
.range-val{font-family:var(--f-display);font-weight:700;color:var(--navy-800);min-width:84px;text-align:right}

/* score gauge */
.gauge-wrap{display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px 0}
.gauge{position:relative;width:200px;height:200px}
.gauge svg{transform:rotate(-90deg)}
.gauge .gnum{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.gauge .gnum b{font-family:var(--f-display);font-weight:800;font-size:3rem;color:var(--navy-800);line-height:1}
.gauge .gnum span{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500);margin-top:4px}

.result-box{background:var(--grey-50);border:1px solid var(--grey-200);border-radius:var(--r-md);padding:24px;margin-top:8px}
.result-box.show{animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0}
@media(max-width:560px){.kpi-row{grid-template-columns:1fr}}
.kpi{background:#fff;border:1px solid var(--grey-200);border-radius:var(--r-md);padding:18px;text-align:center}
.kpi b{display:block;font-family:var(--f-display);font-weight:800;font-size:1.7rem;color:var(--navy-800);line-height:1.1}
.kpi span{font-size:.82rem;color:var(--grey-600);margin-top:5px;display:block}
.hidden{display:none!important}

/* ---------- callouts ---------- */
.callout{border-left:4px solid var(--steel-500);background:var(--grey-50);padding:20px 24px;border-radius:0 var(--r-md) var(--r-md) 0;margin:24px 0}
.callout.gold{border-left-color:var(--gold-500)}
.callout.amber{border-left-color:var(--risk-amber);background:var(--risk-amber-bg)}
.callout h4{margin-bottom:.4em}
.callout p:last-child{margin-bottom:0}
.disclaimer{font-size:.88rem;color:var(--grey-600);background:var(--grey-50);border:1px dashed var(--grey-300);border-radius:var(--r-md);padding:18px 22px;margin:22px 0}
.disclaimer strong{color:var(--ink-soft)}

/* stat band */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
@media(max-width:780px){.stat-band{grid-template-columns:repeat(2,1fr);gap:34px 20px}}
.stat b{display:block;font-family:var(--f-display);font-weight:800;font-size:clamp(2rem,4vw,2.8rem);color:#fff;line-height:1}
.stat span{color:#9FB1C2;font-size:.92rem;margin-top:8px;display:block}
.stat .src{font-size:.72rem;color:#6E8094;margin-top:4px}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid var(--grey-200)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:22px 44px 22px 0;font-family:var(--f-display);font-weight:650;font-size:1.08rem;color:var(--navy-800);position:relative;line-height:1.4}
.faq-q::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:1.6rem;font-weight:400;color:var(--steel-600);transition:.2s}
.faq-q[aria-expanded=true]::after{transform:translateY(-50%) rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a-inner{padding:0 44px 24px 0;color:var(--ink-soft)}
.faq-a-inner p:last-child{margin-bottom:0}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--navy-800),var(--navy-700));color:#fff;border-radius:var(--r-xl);padding:clamp(36px,6vw,68px);text-align:center;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 85% 10%,rgba(42,134,160,.30),transparent 60%);pointer-events:none}
.cta-band h2{color:#fff;position:relative}
.cta-band p{color:#B9C7D6;max-width:56ch;margin-left:auto;margin-right:auto;position:relative}
.cta-band .hero-cta{justify-content:center;position:relative}

/* ---------- breadcrumb ---------- */
.crumb{font-size:.85rem;color:var(--grey-500);padding:18px 0 0}
.crumb a{color:var(--grey-600)}
.crumb span{color:var(--grey-400);margin:0 7px}

/* ---------- article ---------- */
.article{max-width:760px;margin:0 auto}
.article h2{margin:1.6em 0 .5em}
.article h3{margin:1.3em 0 .4em}
.article ul,.article ol{margin:0 0 1.1em}
.article li{margin-bottom:.4em}
.article .lead{margin-bottom:1.4em}
.toc{background:var(--grey-50);border:1px solid var(--grey-200);border-radius:var(--r-md);padding:22px 26px;margin:0 0 32px}
.toc h4{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--grey-600);margin-bottom:12px}
.toc ol{margin:0;padding-left:1.2em}
.toc li{margin-bottom:6px}

/* ---------- footer ---------- */
.site-footer{background:var(--navy-900);color:#92A4B6;padding:var(--s-8) 0 var(--s-5);font-size:.92rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:var(--s-7);border-bottom:1px solid rgba(255,255,255,.09)}
@media(max-width:880px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}}
.f-brand .fb1{font-family:var(--f-display);font-weight:800;color:#fff;font-size:1.16rem;letter-spacing:-.01em}
.f-brand .fb2{font-family:var(--f-display);font-weight:600;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-300);margin-top:4px}
.f-brand p{margin-top:16px;max-width:34ch;color:#7E91A4;font-size:.9rem}
.site-footer h5{font-family:var(--f-display);color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px;font-weight:600}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:10px}
.site-footer a{color:#92A4B6}
.site-footer a:hover{color:#fff}
.footer-desks li{color:#7E91A4}
.footer-desks .soon{font-size:.7rem;background:rgba(255,255,255,.08);color:#9FB1C2;padding:2px 8px;border-radius:100px;margin-left:6px;letter-spacing:.04em}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;padding-top:24px;font-size:.84rem;color:#6E8094}
.footer-bottom a{color:#6E8094}.footer-bottom a:hover{color:#fff}
.footer-legal-links{display:flex;gap:18px;flex-wrap:wrap}

/* ---------- misc ---------- */
.divider{height:1px;background:var(--grey-200);border:0;margin:0}
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.mt-4{margin-top:24px}.mt-5{margin-top:32px}
.maxw-60{max-width:60ch}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy-800);color:#fff;padding:12px 18px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--steel-500);outline-offset:3px}
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.pill{display:inline-block;background:var(--grey-100);color:var(--ink-soft);border-radius:100px;padding:6px 14px;font-size:.85rem;font-weight:550}
.pill a{color:inherit}

/* ---------- price card inner (pages3) ---------- */
.price-card .pc-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold-500);color:#23303f;font-family:var(--f-display);font-weight:700;font-size:.72rem;padding:5px 14px;border-radius:100px;letter-spacing:.04em;white-space:nowrap}
.price-card.featured{border:2px solid var(--gold-500)}
.pc-name{font-family:var(--f-display);font-weight:750;color:var(--navy-800);font-size:1.18rem;margin-bottom:6px}
.pc-price{font-family:var(--f-display);font-weight:800;color:var(--ink);font-size:1.8rem;line-height:1}
.pc-price span{font-size:.84rem;font-weight:600;color:var(--grey-500)}
.pc-meta{font-size:.82rem;color:var(--steel-600);font-weight:600;margin:6px 0 14px}
.pc-for{font-size:.9rem;color:var(--grey-600);min-height:66px;margin-bottom:4px}
.price-card .flist{margin:6px 0 22px;flex:1}
.price-card .btn{margin-top:auto}

/* ---------- table ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--grey-200);border-radius:var(--r-lg);background:#fff}
table.ctable{width:100%;border-collapse:collapse;font-size:.95rem;min-width:520px}
table.ctable th,table.ctable td{text-align:left;padding:14px 18px;border-bottom:1px solid var(--grey-100);vertical-align:top}
table.ctable thead th{background:var(--navy-800);color:#fff;font-family:var(--f-display);font-weight:650;font-size:.8rem;letter-spacing:.03em;text-transform:uppercase}
table.ctable tbody tr:last-child td{border-bottom:0}
table.ctable tbody tr:nth-child(even){background:var(--grey-50)}
.bg-navy .table-wrap{border-color:rgba(255,255,255,.14)}
.bg-navy table.ctable td{color:#C7D4E0;border-color:rgba(255,255,255,.08)}
.bg-navy table.ctable tbody tr:nth-child(even){background:rgba(255,255,255,.03)}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:32px}}

/* ---------- ladder wide + step link ---------- */
.ladder-wide{display:grid;gap:14px;margin-top:var(--s-6)}
.step-link{display:inline-block;margin-top:10px;font-family:var(--f-display);font-weight:700;font-size:.86rem;color:var(--steel-600)}
.step-link::after{content:" \2192"}
.bg-navy .step-link{color:var(--gold-300)}

/* ---------- clickable cards (wissen hub) ---------- */
.card-link{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.card-link h3{color:var(--navy-800)}
.card-link p{color:var(--grey-600);flex:1}
.card-more{display:inline-block;margin-top:14px;font-family:var(--f-display);font-weight:700;font-size:.86rem;color:var(--steel-600)}
.card-more::after{content:" \2192";transition:.2s}
.card-link:hover .card-more{color:var(--steel-700)}
.card-link:hover .card-more::after{margin-left:4px}

/* ---------- block title ---------- */
.block-title{font-family:var(--f-display);font-weight:750;color:var(--navy-800);font-size:1.05rem;
  text-transform:uppercase;letter-spacing:.08em;padding-bottom:12px;margin:0 0 24px;
  border-bottom:2px solid var(--steel-100)}

/* ---------- pill row ---------- */
.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill em{font-style:normal;color:var(--steel-300);font-weight:600;margin-left:4px;font-size:.78rem}
.bg-navy .pill{background:rgba(255,255,255,.07);color:#D9E2EC}

/* ---------- contact block ---------- */
.contact-block{margin-top:28px;border-top:1px solid var(--grey-200)}
.contact-row{display:flex;gap:18px;padding:14px 0;border-bottom:1px solid var(--grey-100)}
.cr-label{font-family:var(--f-display);font-weight:700;color:var(--navy-800);font-size:.86rem;
  min-width:90px;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}
.contact-row a{color:var(--steel-600);font-weight:600}

/* ---------- form card ---------- */
.form-card{background:#fff;border:1px solid var(--grey-200);border-radius:var(--r-lg);
  padding:30px 28px;box-shadow:var(--sh-card)}
.form-card h3{margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.check a{color:var(--steel-600);font-weight:600}

/* ---------- success mark (danke) ---------- */
.success-mark{width:78px;height:78px;border-radius:50%;background:var(--risk-green-bg);
  color:var(--risk-green);display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;margin:0 auto 24px}

/* ---------- faq list wrapper ---------- */
.faq-list{border-top:1px solid var(--grey-200)}

/* ---------- prose (article pages) ---------- */
.prose{max-width:760px}
.prose h1{margin-bottom:.5em}
.prose h2{font-size:1.4rem;margin:2em 0 .6em}
.prose h3{font-size:1.12rem;margin:1.6em 0 .5em}
.prose p{margin:0 0 1.05em}
.prose ul,.prose ol{padding-left:22px;margin:0 0 1.1em}
.prose li{margin-bottom:.5em}
.prose a{color:var(--steel-600);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.prose table{margin:1.2em 0}

/* logo auf kleinen Screens leicht reduzieren */
@media(max-width:600px){.nav{--navh:104px}.brand img{height:78px}}

/* ---------- media ---------- */
.media{margin:0;border-radius:14px;overflow:hidden;border:1px solid rgba(16,42,67,.10);box-shadow:0 22px 48px -26px rgba(10,26,47,.55);background:#0A1A2F}
.media img{display:block;width:100%;height:auto}
.prose .media{margin:26px 0}
