/* ============================================================
   BundesEnergiePartner — Main Stylesheet
   Mobile-first. Komponenten + Layout.
   ============================================================ */
@import url("studio.css");

/* ---------- Fonts (self-hosted, DSGVO) ----------
   woff2-Dateien gehören nach assets/fonts/. Fällt sauber auf
   System-Sans zurück, falls Dateien (noch) fehlen. */
@font-face {
  font-family: "Montserrat";
  font-style: normal; font-weight: 400; font-display: swap;
  src: url("../fonts/montserrat-400.woff2") format("woff2");
}
@font-face {
  font-family: "Montserrat";
  font-style: normal; font-weight: 500; font-display: swap;
  src: url("../fonts/montserrat-500.woff2") format("woff2");
}
@font-face {
  font-family: "Montserrat";
  font-style: normal; font-weight: 600; font-display: swap;
  src: url("../fonts/montserrat-600.woff2") format("woff2");
}
@font-face {
  font-family: "Montserrat";
  font-style: normal; font-weight: 700; font-display: swap;
  src: url("../fonts/montserrat-700.woff2") format("woff2");
}
@font-face {
  font-family: "Montserrat";
  font-style: normal; font-weight: 800; font-display: swap;
  src: url("../fonts/montserrat-800.woff2") format("woff2");
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-base);
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: var(--color-steel-dark); text-decoration: none; transition: color var(--t-fast); }
a:hover { color: var(--color-navy); }
ul, ol { padding: 0; list-style: none; }
button { font: inherit; cursor: pointer; }

:focus-visible {
  outline: 3px solid var(--color-steel);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ---------- Typography ---------- */
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  line-height: var(--leading-tight);
  color: var(--color-navy-900);
  font-weight: var(--weight-extra);
  letter-spacing: -0.01em;
}
h1 { font-size: var(--text-5xl); }
h2 { font-size: var(--text-3xl); }
h3 { font-size: var(--text-xl); font-weight: var(--weight-bold); }
p  { color: var(--color-text-muted); }

.overline {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-gold-dark);
}
.overline::before {
  content: ""; width: 28px; height: 2px; background: var(--color-gold);
}
.overline--center::before { display: none; }

.lead { font-size: var(--text-lg); color: var(--color-text-muted); }
.text-gold { color: var(--color-gold-dark); }
.text-steel { color: var(--color-steel-dark); }
.nowrap { white-space: nowrap; }

/* ---------- Layout ---------- */
.container {
  width: 100%; max-width: var(--container);
  margin-inline: auto; padding-inline: var(--gutter);
}
.container--narrow { max-width: var(--container-narrow); }
.section { padding-block: var(--section-y); }
.section--cream { background: var(--color-cream); }
.section--navy { background: var(--color-navy); color: var(--color-text-inverse); }
.section--navy h2, .section--navy h3 { color: #fff; }
.section--navy p { color: var(--color-text-on-dark-muted); }

.section-head { max-width: 720px; margin-bottom: var(--space-12); }
.section-head--center { margin-inline: auto; text-align: center; }
.section-head h2 { margin-block: var(--space-3) var(--space-4); }

.grid { display: grid; gap: var(--space-6); }
@media (min-width: 640px)  { .grid-sm-2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px)  {
  .grid-md-2 { grid-template-columns: repeat(2, 1fr); }
  .grid-md-3 { grid-template-columns: repeat(3, 1fr); }
  .grid-md-4 { grid-template-columns: repeat(4, 1fr); }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: 0.95rem 1.6rem;
  font-weight: var(--weight-bold);
  font-size: var(--text-base);
  border-radius: var(--radius-full);
  border: 2px solid transparent;
  transition: transform var(--t-fast), background var(--t-base), box-shadow var(--t-base), color var(--t-base);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: var(--color-gold); color: var(--color-navy);
  border-color: var(--color-gold); box-shadow: var(--shadow-gold);
}
.btn--primary:hover { background: var(--color-gold-dark); border-color: var(--color-gold-dark); color: var(--color-navy); }

.btn--outline {
  background: transparent; color: var(--color-navy); border-color: var(--color-border);
}
.btn--outline:hover { border-color: var(--color-navy); color: var(--color-navy); background: var(--color-cream); }

.btn--ghost-light {
  background: rgba(255,255,255,0.08); color: #fff; border-color: rgba(255,255,255,0.25);
}
.btn--ghost-light:hover { background: rgba(255,255,255,0.16); color:#fff; }

.btn--lg { padding: 1.1rem 2rem; font-size: var(--text-lg); }
.btn--block { width: 100%; }
.btn-row { display: flex; flex-wrap: wrap; gap: var(--space-4); }
.btn-row--center { justify-content: center; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: -webkit-sticky; position: sticky; top: 0; z-index: 100;
  background: rgba(12,26,46,0.92);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-navy-700);
}
.nav {
  display: flex; align-items: center; justify-content: space-between;
  height: 72px;
}
.nav__brand {
  display: flex; align-items: center; gap: var(--space-3);
  font-family: var(--font-heading); font-weight: var(--weight-extra);
  font-size: 1.1rem; color: #fff; letter-spacing: -0.01em;
}
.nav__brand:hover { color: #fff; }
/* Echtes Logo (Symbol + Wortmarke) als ein Bild im Header.
   Der gesamte .nav__brand-Link zeigt das Logo; HTML-Text wird ausgeblendet
   (bleibt via aria-label für Screenreader erhalten). Greift auf allen Seiten. */
.nav__brand {
  width: 228px; height: 56px; flex-shrink: 0;
  background: url("../img/logo.png") left center/contain no-repeat;
  text-indent: -9999px; overflow: hidden; white-space: nowrap;
}
.nav__logo { display: none; }

.nav__menu { display: none; }
.nav__links { display: flex; align-items: center; gap: var(--space-6); }
.nav__links a {
  color: rgba(255,255,255,0.82); font-weight: var(--weight-medium); font-size: 0.95rem;
}
.nav__links a:hover, .nav__links a[aria-current="page"] { color: var(--color-gold); }
.nav__actions { display: flex; align-items: center; gap: var(--space-4); }

.nav__toggle {
  display: inline-flex; flex-direction: column; gap: 5px;
  background: none; border: 0; padding: 8px;
}
.nav__toggle span {
  width: 24px; height: 2px; background: #fff; border-radius: 2px;
  transition: transform var(--t-base), opacity var(--t-base);
}
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile drawer */
.nav__drawer {
  position: fixed;
  top: 72px; left: 0; right: 0; bottom: 0;
  height: calc(100dvh - 72px);
  background: var(--color-navy); z-index: 99;
  padding: var(--space-8) var(--gutter);
  display: flex; flex-direction: column; gap: var(--space-6);
  transform: translateX(100%); transition: transform var(--t-base);
  overflow-y: auto;
}
.nav__drawer.is-open { transform: translateX(0); }
.nav__drawer a {
  color: #fff; font-size: var(--text-xl); font-weight: var(--weight-semibold);
  padding-block: var(--space-2); border-bottom: 1px solid var(--color-navy-700);
}
.nav__drawer a:hover { color: var(--color-gold); }
.nav__drawer .btn { margin-top: var(--space-4); border-bottom: 0; }
.nav__drawer a.btn--primary { color: var(--color-navy); }
.nav__drawer a.btn--primary:hover { color: var(--color-navy); }

@media (min-width: 1000px) {
  .nav__toggle { display: none; }
  .nav__menu { display: flex; align-items: center; gap: var(--space-8); }
  .nav__drawer { display: none; }
}

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(0,168,168,0.20), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(74,144,194,0.16), transparent 55%),
    /* dezentes Energie-Foto, stark abgedunkelt, damit Text/Dashboard lesbar bleiben */
    linear-gradient(180deg, rgba(0,43,87,0.93), rgba(0,34,74,0.97)),
    url("../img/energie.jpg") center/cover no-repeat,
    var(--color-navy);
  color: #fff;
  padding-block: clamp(3rem, 6vw, 6rem);
}
.hero__grid { display: grid; gap: var(--space-12); align-items: center; }
.hero h1 { color: #fff; margin-block: var(--space-4) var(--space-5); }
.hero h1 em { font-style: normal; color: var(--color-gold); }
.hero__sub { font-size: var(--text-lg); color: rgba(255,255,255,0.82); max-width: 38ch; }
.hero .btn-row { margin-top: var(--space-8); }
.hero__visual {
  background: linear-gradient(160deg, var(--color-navy-800), var(--color-navy-900));
  border: 1px solid var(--color-navy-700);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  padding: var(--space-5);
}
@media (min-width: 960px) {
  .hero__grid { grid-template-columns: 1.05fr 0.95fr; }
}

/* Trust bar */
.trustbar {
  display: flex; flex-wrap: wrap; gap: var(--space-6) var(--space-8);
  margin-top: var(--space-10); padding-top: var(--space-6);
  border-top: 1px solid var(--color-navy-700);
}
.trustbar__item { display: flex; flex-direction: column; }
.trustbar__num {
  font-family: var(--font-heading); font-weight: var(--weight-extra);
  font-size: var(--text-2xl); color: var(--color-gold); line-height: 1;
}
.trustbar__label { font-size: var(--text-sm); color: rgba(255,255,255,0.7); }

/* Dashboard mockup (inline SVG-ish via divs) */
.mock {
  font-size: var(--text-sm);
}
.mock__bar { display: flex; gap: 6px; margin-bottom: var(--space-4); }
.mock__dot { width: 11px; height: 11px; border-radius: 50%; background: var(--color-navy-700); }
.mock__dot--gold { background: var(--color-gold); }
.mock__row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-4); border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.04); margin-bottom: var(--space-2);
  color: rgba(255,255,255,0.85);
}
.mock__row b { color: var(--color-gold-light); }
.mock__pill {
  font-size: var(--text-xs); padding: 2px 10px; border-radius: var(--radius-full);
  background: rgba(0,168,168,0.20); color: #5CC9C9;
}
.mock__slider {
  height: 8px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.14);
  position: relative;
  margin: 10px 0;
  isolation: isolate;
  overflow: visible;
}
.mock__slider::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 62%;
  border-radius: 99px;
  background: var(--color-gold);
  opacity: 0.72;
  z-index: 1;
}
.mock__knob {
  position: absolute;
  left: 60%;
  top: 50%;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--color-gold);
  transform: translate(-50%, -50%);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.45);
  z-index: 3;
  opacity: 1;
}

/* ---------- Cards ---------- */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--color-gold-light); }
.card__icon {
  width: 52px; height: 52px; border-radius: var(--radius-md);
  display: grid; place-items: center; margin-bottom: var(--space-5);
  background: var(--color-gold-50); color: var(--color-gold-dark);
}
.card__icon svg { width: 26px; height: 26px; }
.card h3 { margin-bottom: var(--space-3); }
.card__link {
  display: inline-flex; align-items: center; gap: 6px; margin-top: var(--space-4);
  font-weight: var(--weight-bold); color: var(--color-steel-dark);
}
.card__link:hover { gap: 10px; color: var(--color-navy); }

/* Pain cards (problem section) */
.pain {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-error);
  border-radius: var(--radius-md); padding: var(--space-6);
}
.pain h3 { font-size: var(--text-lg); margin-bottom: var(--space-2); }

/* ---------- Steps ---------- */
.steps { counter-reset: step; display: grid; gap: var(--space-6); }
.step {
  position: relative; padding: var(--space-6) var(--space-6) var(--space-6) var(--space-16);
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.step::before {
  counter-increment: step; content: "0" counter(step);
  position: absolute; left: var(--space-6); top: var(--space-6);
  font-family: var(--font-heading); font-weight: var(--weight-extra);
  font-size: var(--text-2xl); color: var(--color-gold);
}
.step h3 { font-size: var(--text-lg); margin-bottom: var(--space-2); }

/* ---------- Stats ---------- */
.stats { display: grid; gap: var(--space-8); text-align: center; }
.stat__num {
  font-family: var(--font-heading); font-weight: var(--weight-extra);
  font-size: var(--text-4xl); color: var(--color-gold); line-height: 1;
}
.stat__label { color: rgba(255,255,255,0.78); margin-top: var(--space-2); }

/* ---------- Feature split ---------- */
.split { display: grid; gap: var(--space-10); align-items: center; }
@media (min-width: 900px) {
  .split { grid-template-columns: 1fr 1fr; }
  .split--reverse .split__media { order: 2; }
}
.split__media {
  /* Dunkler Navy-Grund, damit Mockup-Text (weiß) + Türkis-Akzente sichtbar sind */
  background: linear-gradient(160deg, var(--color-navy-800), var(--color-navy-900));
  border: 1px solid var(--color-navy-700);
  border-radius: var(--radius-lg); padding: var(--space-8); min-height: 260px;
  box-shadow: var(--shadow-md);
}
.checklist li {
  display: flex; gap: var(--space-3); align-items: flex-start;
  padding-block: var(--space-2); color: var(--color-text);
}
.checklist svg { flex-shrink: 0; width: 22px; height: 22px; color: var(--color-success); margin-top: 3px; }

/* ---------- Logos ---------- */
.logos { display: flex; flex-wrap: wrap; gap: var(--space-8); align-items: center; justify-content: center; opacity: 0.85; }
.logos__item {
  height: 44px; min-width: 120px; padding: 0 var(--space-5);
  display: grid; place-items: center;
  border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  color: var(--color-text-muted); font-weight: var(--weight-bold); letter-spacing: var(--tracking-wide);
  background: var(--color-white);
}

/* ---------- Testimonials ---------- */
.quote {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-8);
}
.quote__stars { color: var(--color-gold); letter-spacing: 2px; margin-bottom: var(--space-4); }
.quote blockquote { font-size: var(--text-lg); color: var(--color-text); font-weight: var(--weight-medium); }
.quote__author { display: flex; align-items: center; gap: var(--space-3); margin-top: var(--space-5); }
.quote__avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--color-navy); color: #fff; display: grid; place-items: center; font-weight: 700;
}
.quote__name { font-weight: var(--weight-bold); color: var(--color-navy-900); font-size: 0.95rem; }
.quote__role { font-size: var(--text-sm); color: var(--color-text-muted); }

/* ---------- CTA band ---------- */
.cta-band {
  background:
    radial-gradient(800px 400px at 90% 10%, rgba(201,165,90,0.22), transparent 60%),
    var(--color-navy);
  color: #fff; border-radius: var(--radius-xl);
  padding: clamp(2.5rem, 5vw, 4.5rem);
  text-align: center;
}
.cta-band h2 { color: #fff; margin-bottom: var(--space-4); }
.cta-band p { color: rgba(255,255,255,0.82); max-width: 52ch; margin-inline: auto; margin-bottom: var(--space-8); }
.cta-reassure { margin-top: var(--space-5); font-size: var(--text-sm); color: rgba(255,255,255,0.7); }

/* ---------- FAQ ---------- */
.faq { max-width: 800px; margin-inline: auto; }
.faq__item { border-bottom: 1px solid var(--color-border); }
.faq__q {
  width: 100%; text-align: left; background: none; border: 0;
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-4);
  padding: var(--space-5) 0; font-weight: var(--weight-bold); font-size: var(--text-lg);
  color: var(--color-navy-900);
}
.faq__q .faq__plus { flex-shrink: 0; transition: transform var(--t-base); color: var(--color-gold-dark); font-size: 1.4rem; }
.faq__q[aria-expanded="true"] .faq__plus { transform: rotate(45deg); }
.faq__a { overflow: hidden; max-height: 0; transition: max-height var(--t-base); }
.faq__a p { padding-bottom: var(--space-5); }

/* ---------- Forms ---------- */
.form { display: grid; gap: var(--space-5); }
.field { display: grid; gap: var(--space-2); }
.field label { font-weight: var(--weight-semibold); font-size: 0.95rem; color: var(--color-navy-900); }
.field input, .field textarea, .field select {
  font: inherit; padding: 0.85rem 1rem; border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); background: #fff; color: var(--color-text);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none; border-color: var(--color-steel); box-shadow: 0 0 0 3px var(--color-steel-50);
}
.field--check { grid-template-columns: auto 1fr; align-items: start; gap: var(--space-3); }
.field--check input { margin-top: 4px; }
.field--check label { font-weight: var(--weight-regular); font-size: var(--text-sm); color: var(--color-text-muted); }
.form-note { font-size: var(--text-sm); color: var(--color-text-muted); }

.embed-placeholder {
  border: 2px dashed var(--color-border); border-radius: var(--radius-lg);
  padding: var(--space-12) var(--space-6); text-align: center; color: var(--color-text-muted);
  background: var(--color-cream);
}

/* ---------- Contact info blocks ---------- */
.info-list { display: grid; gap: var(--space-5); }
.info-item { display: flex; gap: var(--space-4); align-items: flex-start; }
.info-item svg { width: 24px; height: 24px; color: var(--color-gold-dark); flex-shrink: 0; margin-top: 2px; }
.info-item b { display: block; color: var(--color-navy-900); }

/* ---------- Prose (legal pages + Blog-Artikel) ---------- */
.prose { max-width: 760px; }
.prose h2 { font-size: var(--text-2xl); margin-block: var(--space-10) var(--space-4); }
.prose h3 { margin-block: var(--space-6) var(--space-3); }
.prose p, .prose li { color: var(--color-text); margin-bottom: var(--space-4); }
.prose ul, .prose ol { list-style: disc; padding-left: 1.4rem; margin-bottom: var(--space-4); }
.prose ol { list-style: decimal; }
.prose a { color: var(--color-steel-dark); text-decoration: underline; }
.prose blockquote {
  border-left: 4px solid var(--color-gold); background: var(--color-gold-50);
  padding: var(--space-4) var(--space-6); margin: var(--space-6) 0;
  border-radius: 0 var(--radius-md) var(--radius-md) 0; font-size: var(--text-lg); color: var(--color-navy-900);
}
.prose .lead { font-size: var(--text-xl); color: var(--color-text); font-weight: var(--weight-medium); margin-bottom: var(--space-8); }

/* ---------- Blog ---------- */
.blog-grid { display: grid; gap: var(--space-8); }
@media (min-width: 720px)  { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

.post-card {
  display: flex; flex-direction: column;
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--color-gold-light); }
.post-card__media {
  height: 168px; background: linear-gradient(135deg, var(--color-navy-800), var(--color-navy-900));
  background-size: cover; background-position: center;
}
.post-card__body { padding: var(--space-6); display: flex; flex-direction: column; flex: 1; }
.post-card__cat {
  display: inline-block; align-self: flex-start; font-size: var(--text-xs); font-weight: var(--weight-bold);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  color: var(--color-gold-dark); background: var(--color-gold-50);
  padding: 3px 10px; border-radius: var(--radius-full); margin-bottom: var(--space-3);
}
.post-card__title { font-size: var(--text-lg); color: var(--color-navy-900); margin-bottom: var(--space-2); line-height: var(--leading-snug); }
.post-card__excerpt { color: var(--color-text-muted); font-size: 0.95rem; margin-bottom: var(--space-4); flex: 1; }
.post-card__meta { font-size: var(--text-sm); color: var(--color-text-muted); }
.post-card__link { color: var(--color-steel-dark); font-weight: var(--weight-bold); font-size: 0.95rem; }

/* Artikel-Header */
.article-head { max-width: 760px; }
.article-head .post-card__cat { margin-bottom: var(--space-4); }
.article-meta { display: flex; flex-wrap: wrap; gap: var(--space-4); align-items: center; color: var(--color-text-muted); font-size: var(--text-sm); margin-top: var(--space-4); }
.article-meta__author { display: flex; align-items: center; gap: var(--space-2); font-weight: var(--weight-semibold); color: var(--color-navy-900); }

/* ---------- Page hero (sub-pages) ---------- */
.page-hero {
  background:
    radial-gradient(900px 400px at 85% -20%, rgba(0,168,168,0.18), transparent 60%),
    var(--color-navy);
  color: #fff; padding-block: clamp(3rem, 5vw, 5rem);
}
/* Variante mit Energie-Foto-Hintergrund (für "Für Versorger") */
.page-hero--image {
  position: relative;
  background:
    /* links dunkel für Textlesbarkeit, rechts klar sichtbares Energie-Motiv */
    linear-gradient(100deg, rgba(0,34,74,0.80) 22%, rgba(0,43,87,0.30) 60%, rgba(0,43,87,0.05) 100%),
    var(--hero-img) right bottom/cover no-repeat,
    var(--color-navy);
  padding-block: clamp(4rem, 7vw, 7rem);
}
@media (max-width: 720px) {
  /* Auf Mobile gleichmäßiger + etwas dunkler, damit Text über dem Bild lesbar bleibt */
  .page-hero--image {
    background:
      linear-gradient(180deg, rgba(0,34,74,0.80), rgba(0,43,87,0.62)),
      var(--hero-img) center/cover no-repeat,
      var(--color-navy);
  }
}
.page-hero h1 { color: #fff; font-size: var(--text-4xl); margin-block: var(--space-3) var(--space-4); }
.page-hero p { color: rgba(255,255,255,0.82); max-width: 60ch; }
.breadcrumb { font-size: var(--text-sm); color: rgba(255,255,255,0.6); margin-bottom: var(--space-2); }
.breadcrumb a { color: rgba(255,255,255,0.75); }
.breadcrumb a:hover { color: var(--color-gold); }

/* ---------- Footer ---------- */
.site-footer { background: var(--color-navy-900); color: rgba(255,255,255,0.7); padding-block: var(--space-16) var(--space-8); }
.footer__grid { display: grid; gap: var(--space-10); }
@media (min-width: 720px) { .footer__grid { grid-template-columns: 1.4fr 1fr 1fr; } }
.footer__brand { display: flex; align-items: center; gap: var(--space-3); color:#fff; font-weight: 800; font-size: 1.1rem; margin-bottom: var(--space-4); }
.footer__brand b { color: var(--color-gold); }
.footer h4 { color: #fff; font-size: var(--text-sm); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-4); }
.footer__nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-1);
}
.footer__nav a {
  color: rgba(255, 255, 255, 0.78);
  display: block;
  padding-block: 6px;
  font-size: var(--text-sm);
  line-height: 1.3;
}
.footer a { color: rgba(255,255,255,0.7); display: inline-block; padding-block: 4px; }
.footer a:hover { color: var(--color-gold); }
.footer__bottom {
  margin-top: var(--space-12); padding-top: var(--space-6);
  border-top: 1px solid var(--color-navy-700);
  display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: space-between;
  font-size: var(--text-sm);
}

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 90;
  background: rgba(12,26,46,0.96); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border-top: 1px solid var(--color-navy-700);
  padding: var(--space-3) var(--gutter);
  display: flex; gap: var(--space-3); align-items: center; justify-content: space-between;
  transform: translateY(120%); transition: transform var(--t-base);
}
.sticky-cta.is-visible { transform: translateY(0); }
.sticky-cta__text { color: #fff; font-weight: var(--weight-bold); font-size: 0.95rem; }
.sticky-cta .btn { padding: 0.7rem 1.2rem; }
@media (min-width: 1000px) { .sticky-cta { display: none; } }
body.has-sticky { padding-bottom: 76px; }
@media (min-width: 1000px) { body.has-sticky { padding-bottom: 0; } }

/* ---------- Reveal on scroll (Progressive Enhancement) ----------
   WICHTIG: Inhalte sind standardmäßig sichtbar. Nur wenn JS läuft und die
   Klasse `js` am <html> gesetzt hat, starten die Reveals unsichtbar und
   werden beim Scrollen eingeblendet. So bleibt die Seite ohne/bei langsamem
   JS, in WebKit/Safari, in Privacy-Browsern und in Screenshot-Tools voll
   nutzbar (kein leerer Bildschirm unterhalb des Heros). */
.js .reveal { opacity: 0; transform: translateY(24px); transition: opacity var(--t-slow), transform var(--t-slow); }
.js .reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------- Utilities ---------- */
.mt-0 { margin-top: 0; }
.mt-4 { margin-top: var(--space-4); }
.mt-8 { margin-top: var(--space-8); }
.mb-0 { margin-bottom: 0; }
.center { text-align: center; }
.badge {
  display: inline-block; font-size: var(--text-xs); font-weight: var(--weight-bold);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  padding: 4px 12px; border-radius: var(--radius-full);
  background: var(--color-gold-50); color: var(--color-gold-dark);
}
.badge--steel { background: var(--color-steel-50); color: var(--color-steel-dark); }
.skip-link {
  position: absolute; left: -999px; top: 0;
  background: var(--color-gold); color: var(--color-navy); padding: 10px 16px; z-index: 200; font-weight: 700;
}
.skip-link:focus { left: 8px; top: 8px; border-radius: 6px; }

/* ============================================================
   Animierte Produkt-UI (Premium-SaaS-Look, reines CSS)
   Lebendige Dashboard-Mockups + Hero-Tiefe. Wird per
   prefers-reduced-motion am Ende komplett abgeschaltet.
   ============================================================ */

/* ---- Hero: schwebender Glow + Floating Visual ---- */
.hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(600px 300px at 78% 12%, rgba(201,165,90,0.16), transparent 60%);
  animation: heroGlow 9s ease-in-out infinite;
}
@keyframes heroGlow {
  0%, 100% { opacity: 0.65; transform: translateY(0); }
  50%      { opacity: 1;    transform: translateY(-14px); }
}
.hero__visual { animation: floatY 7s ease-in-out infinite; }
@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}

/* ---- Dashboard-Mockup: Zeilen ticken nacheinander rein ----
   Im Hero (nicht in .reveal) laufen sie sofort. In .reveal-Sektionen
   (z. B. Plattform-Seite) starten sie erst, wenn die Sektion sichtbar
   wird (.is-in) — so sieht man das Eintickern beim Scrollen. */

/* Sofort animieren: Mockups, die NICHT in einer reveal-Sektion stecken */
.hero__visual .mock__row,
.split:not(.reveal) .mock__row {
  opacity: 0; transform: translateY(8px);
  animation: rowIn 0.55s cubic-bezier(.4,0,.2,1) forwards;
}

/* In reveal-Sektionen: erst beim Sichtbarwerden eintickern */
.js .reveal .mock__row { opacity: 0; transform: translateY(8px); }
.reveal.is-in .mock__row { animation: rowIn 0.55s cubic-bezier(.4,0,.2,1) forwards; }

/* Staffelung gilt für beide Fälle */
.mock__row:nth-child(1) { animation-delay: 0.10s; }
.mock__row:nth-child(2) { animation-delay: 0.22s; }
.mock__row:nth-child(3) { animation-delay: 0.34s; }
.mock__row:nth-child(4) { animation-delay: 0.46s; }
.mock__row:nth-child(5) { animation-delay: 0.58s; }
.mock__row:nth-child(6) { animation-delay: 0.70s; }
.mock__row:nth-child(7) { animation-delay: 0.82s; }
@keyframes rowIn {
  to { opacity: 1; transform: translateY(0); }
}

/* ---- Pills pulsieren dezent (Status "signiert", "live", "erreicht") ---- */
.mock__pill {
  position: relative;
  animation: pillPulse 2.6s ease-in-out infinite;
}
@keyframes pillPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(46,158,107,0.0); }
  50%      { box-shadow: 0 0 0 5px rgba(46,158,107,0.12); }
}

/* ---- Aufschlag-Slider: Knopf + Füllung gleiten hin und her ---- */
.mock__slider::after {
  animation: sliderFill 5s ease-in-out infinite;
}
@keyframes sliderFill {
  0%, 100% { width: 48%; }
  50%      { width: 74%; }
}
.mock__knob {
  animation: sliderKnob 5s ease-in-out infinite;
}
@keyframes sliderKnob {
  0%, 100% { left: 46%; }
  50%      { left: 72%; }
}

/* ---- Gold-Werte (b) zart aufleuchten ---- */
.mock__row b { animation: valueGlow 4s ease-in-out infinite; }
@keyframes valueGlow {
  0%, 100% { color: var(--color-gold); }
  50%      { color: var(--color-gold-light); }
}

/* ---- Status-Dot im Header der Mockup-Karte blinkt "live" ---- */
.mock__dot--gold { animation: liveDot 2s ease-in-out infinite; }
@keyframes liveDot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201,165,90,0.5); }
  50%      { box-shadow: 0 0 0 4px rgba(201,165,90,0); }
}

/* ---- Buttons: Gold-CTA bekommt sanften "Shine"-Sweep beim Hover ---- */
.btn--primary { position: relative; overflow: hidden; }
.btn--primary::after {
  content: ""; position: absolute; top: 0; left: -120%; width: 60%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.45), transparent);
  transform: skewX(-18deg); transition: left 0.6s ease;
}
.btn--primary:hover::after { left: 130%; }

/* ---- Karten-Icons: kleiner Lift beim Karten-Hover ---- */
.card:hover .card__icon { transform: translateY(-3px) scale(1.06); transition: transform var(--t-base); }

/* ============================================================
   "Noch lebendiger" — zweite Animationsebene
   ============================================================ */

/* ---- Wandernder Schimmer über die Dashboard-Karten (Datenfluss) ---- */
.hero__visual, .split__media {
  position: relative; overflow: hidden;
}
.hero__visual::after, .split__media::after {
  content: ""; position: absolute; top: 0; left: -60%;
  width: 45%; height: 100%; pointer-events: none;
  background: linear-gradient(100deg, transparent, rgba(201,165,90,0.10), transparent);
  transform: skewX(-16deg);
  animation: cardSheen 6.5s ease-in-out infinite;
}
@keyframes cardSheen {
  0%   { left: -60%; }
  55%  { left: 130%; }
  100% { left: 130%; }
}

/* ---- Trust-Bar-Zahlen: dezenter Dauer-Puls + Gold-Schimmer ---- */
.trustbar__num {
  display: inline-block;
  animation: numPulse 3.4s ease-in-out infinite;
}
.trustbar__item:nth-child(2) .trustbar__num { animation-delay: 0.5s; }
.trustbar__item:nth-child(3) .trustbar__num { animation-delay: 1s; }
@keyframes numPulse {
  0%, 100% { transform: scale(1); text-shadow: 0 0 0 rgba(201,165,90,0); }
  50%      { transform: scale(1.05); text-shadow: 0 0 16px rgba(201,165,90,0.35); }
}

/* ---- Stat-Zahlen (Navy-Sektion): Glow-Puls ---- */
.stat__num { animation: statGlow 3.8s ease-in-out infinite; }
@keyframes statGlow {
  0%, 100% { text-shadow: 0 0 0 rgba(201,165,90,0); }
  50%      { text-shadow: 0 0 22px rgba(201,165,90,0.45); }
}

/* ---- Karten-Icons: sanfter Dauer-Glow (lebendig, auch ohne Hover) ---- */
.card__icon { animation: iconBreathe 4.5s ease-in-out infinite; }
@keyframes iconBreathe {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201,165,90,0); }
  50%      { box-shadow: 0 0 0 6px rgba(201,165,90,0.10); }
}

/* ---- Hero: zweite driftende Lichtquelle für mehr Tiefe ---- */
.hero {
  position: relative;
}
.hero > .container { position: relative; z-index: 1; }
.hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(420px 240px at 12% 88%, rgba(91,143,168,0.16), transparent 60%);
  animation: heroDrift 11s ease-in-out infinite;
}
@keyframes heroDrift {
  0%, 100% { opacity: 0.5; transform: translate(0, 0); }
  50%      { opacity: 0.9; transform: translate(20px, -16px); }
}

/* ---- Overline-Strich "lädt" wie ein Fortschrittsbalken ---- */
.hero .overline::before { animation: lineGrow 2.4s ease-in-out infinite; transform-origin: left; }
@keyframes lineGrow {
  0%, 100% { transform: scaleX(0.6); opacity: 0.7; }
  50%      { transform: scaleX(1.3); opacity: 1; }
}

/* ---- Count-up: Start-Zustand (JS zählt hoch) ---- */
.js [data-countup] { font-variant-numeric: tabular-nums; }

/* ============================================================
   Reduced Motion: ALLE Animationen aus (Barrierefreiheit)
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .hero::before, .hero__visual, .mock__row, .mock__pill,
  .mock__slider::after, .mock__knob, .mock__row b, .mock__dot--gold,
  .hero__visual .mock__row, .split:not(.reveal) .mock__row,
  .js .reveal .mock__row, .reveal.is-in .mock__row {
    animation: none !important;
  }
  .mock__row, .js .reveal .mock__row { opacity: 1 !important; transform: none !important; }
  .btn--primary::after { display: none; }
  /* zweite Ebene ebenfalls aus */
  .hero__visual::after, .split__media::after, .trustbar__num, .stat__num,
  .card__icon, .hero::after, .hero .overline::before {
    animation: none !important;
  }
}
