/* ===========================================================================
   NIS2 Readiness Check, styles.css
   cubic solutions Brand-Design. Quelle der Wahrheit: cubicsolutions.tokens.json.
   Flat, geometrisch, präzise. Einziger Markenakzent: Hellgelb #D5D800 mit
   schwarzem Text (WCAG-AA). Orbitron nur für Logo-Kontext, Seitentitel und
   Hero-Headline; Segoe UI für Headings, Body, UI, Captions.

   Aufbau:
     - @font-face (Orbitron, self-hosted Variable-TTF)
     - Tokens (Custom Properties aus den Brand-Tokens)
     - Basis & Layout
     - Icons (Inline-SVG-Sprite via <use>)
     - Buttons
     - Header / Brand
     - Hero
     - Nutzenblock
     - Self-Check (Progress, Fragen, Antworten, Hints)
     - Ergebnis-Teaser (Ampeln)
     - Vollreport / Pricing
     - Kontakt & Consent
     - Technischer Ausblick (dunkel)
     - Footer
     - Legal Modals
     - Responsive
   =========================================================================== */

/* ----------------------------------------------------------- @font-face -- */
/* Orbitron als self-hosted Variable-Font (CSP font-src 'self'). Eine Datei,
   Gewichtsachse 400-900. Display-Font: nur Logo, Seitentitel, Hero-Headline. */
@font-face {
  font-family: "Orbitron";
  src: url("../fonts/Orbitron.ttf") format("truetype-variations"),
       url("../fonts/Orbitron.ttf") format("truetype");
  font-weight: 400 900;
  font-style: normal;
  font-display: swap;
}

/* ---------------------------------------------------------------- Tokens -- */
:root {
  /* --- Brand-Farben (color.brand.*) --- */
  --brand-white: #FFFFFF;
  --brand-primary: #D5D800;        /* Hellgelb: einziger Markenakzent */
  --brand-primary-print: #BCB709;  /* Dunkelgelb (Hover-Tiefe) */
  --brand-text-primary: #5E686E;   /* Dunkelgrau: Haupttext */
  --brand-text-secondary: #717C82; /* Mittelgrau: Sekundärtext */
  --brand-text-subtle: #9BA7B2;    /* Hellgrau: Captions, Borders */
  --brand-black: #000000;

  /* --- UI-State-Farben (color.ui.*) --- */
  --ui-success: #00D870;
  --ui-info: #0400D8;
  --ui-alert: #D80068;

  /* --- Semantische Aliase (color.semantic.*) --- */
  --bg-default: var(--brand-white);
  --bg-dark: var(--brand-black);
  --bg-subtle: #F7F8F8;
  --bg-accent: var(--brand-primary);

  --text-on-light: var(--brand-text-primary);
  --text-on-dark: var(--brand-white);
  --text-on-accent: var(--brand-black);   /* schwarz auf Gelb: WCAG-AA */
  --text-muted: var(--brand-text-secondary);
  --text-caption: var(--brand-text-subtle);

  --border-default: var(--brand-text-subtle);
  --border-strong: var(--brand-text-secondary);
  --border-accent: var(--brand-primary);

  --icon-default: var(--brand-text-primary);
  --icon-muted: var(--brand-text-subtle);
  --icon-accent: var(--brand-primary);
  --icon-on-dark: var(--brand-text-subtle);

  /* --- Ampel / Score (rot/gelb/gruen). Brand-UI-State-Farben. --- */
  --band-gruen: var(--ui-success);   /* #00D870 */
  --band-gelb: var(--brand-primary); /* #D5D800, durch Form+Label vom CTA unterscheidbar */
  --band-rot: var(--ui-alert);       /* #D80068 */
  /* Dezente, flache Tint-Flächen für Bandkontexte (keine Verläufe). */
  --band-gruen-bg: #E6FBF1;
  --band-gelb-bg: #FBFBE6;
  --band-rot-bg: #FBE6F0;
  --band-gruen-border: #99EFC6;
  --band-gelb-border: #ECEE99;
  --band-rot-border: #EF99C3;

  /* --- Typografie (font.*) --- */
  --font-display: "Orbitron", "Segoe UI", system-ui, -apple-system, sans-serif;
  --font-body: "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;

  --fw-regular: 400;
  --fw-medium: 500;   /* nur Display/Orbitron */
  --fw-semibold: 600;
  --fw-bold: 700;

  /* font.size.* (1rem = 16px) */
  --fs-2xs: 0.625rem;  /* 10px */
  --fs-xs: 0.75rem;    /* 12px */
  --fs-sm: 0.875rem;   /* 14px */
  --fs-md: 1rem;       /* 16px */
  --fs-lg: 1.125rem;   /* 18px */
  --fs-xl: 1.25rem;    /* 20px */
  --fs-2xl: 1.5rem;    /* 24px */
  --fs-3xl: 1.75rem;   /* 28px */
  --fs-4xl: 2.25rem;   /* 36px */
  --fs-5xl: 2.75rem;   /* 44px */
  --fs-6xl: 3.75rem;   /* 60px */

  /* font.lineHeight.* */
  --lh-tight: 1.1;
  --lh-snug: 1.25;
  --lh-normal: 1.5;
  --lh-relaxed: 1.75;

  /* font.letterSpacing.* */
  --ls-tight: -0.02em;
  --ls-normal: 0em;
  --ls-wide: 0.05em;
  --ls-wider: 0.1em;

  /* --- Spacing (spacing.*) 4px-Grid --- */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
  --sp-8: 32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;
  --sp-20: 80px;
  --sp-24: 96px;

  /* --- Border (border.*) --- */
  --bw-thin: 1px;
  --bw-default: 1.5px;  /* Standard-Border + Icon-Stroke */
  --bw-medium: 2px;
  --bw-thick: 3px;      /* Emphasis, selected */

  --radius-none: 0;
  --radius-sm: 2px;     /* Tags, Badges */
  --radius-md: 4px;     /* Buttons, Inputs, Cards */
  --radius-pill: 9999px;

  /* --- Shadow (shadow.*), sparsam --- */
  --shadow-sm: 0 1px 3px rgba(94, 104, 110, 0.12);
  --shadow-md: 0 4px 12px rgba(94, 104, 110, 0.16);
  --shadow-focus: 0 0 0 3px rgba(213, 216, 0, 0.4);

  /* --- Motion (motion.*) --- */
  --dur-fast: 100ms;
  --dur-default: 200ms;
  --dur-slow: 350ms;
  --ease-default: cubic-bezier(0.2, 0, 0, 1);
  --ease-enter: cubic-bezier(0, 0, 0.2, 1);
  --ease-exit: cubic-bezier(0.4, 0, 1, 1);

  /* --- Grid / Layout (grid.*) --- */
  --maxw: 1280px;
  --maxw-narrow: 760px;
  --gutter: 24px;

  /* Body-Schriftgröße, leicht fluid zwischen md und lg */
  --fs-body: clamp(1rem, 0.96rem + 0.2vw, 1.0625rem);
}

/* ------------------------------------------------------------- Basis ----- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--brand-text-primary);
  background: var(--bg-default);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Section-Headings, Body: Segoe UI (NICHT Orbitron). */
h1, h2, h3, h4 {
  line-height: var(--lh-snug);
  color: var(--brand-text-primary);
  margin: 0 0 0.5em;
  font-family: var(--font-body);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-normal);
}

p { margin: 0 0 1rem; }

a {
  color: var(--ui-info);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--dur-fast) var(--ease-default);
}
a:hover { color: var(--brand-text-primary); }
a:visited { color: var(--brand-text-secondary); }

:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--radius-md);
}

.container {
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--sp-5);
}

/* Section-Titel: Segoe UI Bold. */
.section-title {
  font-family: var(--font-body);
  font-weight: var(--fw-bold);
  font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2.25rem);
  line-height: var(--lh-snug);
  margin-bottom: 0.6em;
  color: var(--brand-text-primary);
}
.section-title--light { color: var(--brand-white); }

/* 1-2-3-Flow: Schritt-Nummer-Badge inline im Section-Titel. */
.section-title--step { display: flex; align-items: center; gap: 0.6rem; }
.step-num {
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.4em;
  height: 1.4em;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 0.9em;
  line-height: 1;
  color: #000;
  background: var(--brand-primary);
  border-radius: var(--radius-md);
}
.scan-step__detail-link {
  display: inline-block;
  margin-top: 0.4rem;
  color: var(--brand-primary);
  font-weight: var(--fw-semibold);
}

/* Skip-Link */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 200;
  background: var(--brand-primary);
  color: var(--text-on-accent);
  font-weight: var(--fw-bold);
  padding: 12px 18px;
  border-radius: 0 0 var(--radius-md) 0;
  text-decoration: none;
}
.skip-link:focus {
  left: 0;
  color: var(--text-on-accent);
}

/* ------------------------------------------------------------- Icons ----- */
/* Inline-SVG-Sprite via <use>. currentColor erbt die Textfarbe; Akzent nur
   sparsam für aktive/hervorgehobene Zustände. */
/* Das hidden-Attribut muss immer gewinnen, auch gegen Klassen-Regeln mit
   eigenem display (z.B. .consent-return mit display:flex + min-height:70vh).
   Ohne diese Regel rendert ein per [hidden] ausgeblendeter Container sonst
   trotzdem als leerer Block. Elemente werden im Code via .hidden=false gezeigt
   (Attribut entfernt), daher voll kompatibel. */
[hidden] { display: none !important; }

.icon-sprite { display: none; }

.icon {
  display: inline-block;
  width: 24px;
  height: 24px;
  flex: none;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  vertical-align: middle;
}
.icon--sm { width: 16px; height: 16px; }
.icon--lg { width: 32px; height: 32px; }
.icon--xl { width: 48px; height: 48px; }
.icon--accent { color: var(--icon-accent); }
.icon--muted { color: var(--icon-muted); }

/* ------------------------------------------------------------- Buttons --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  line-height: 1;
  text-decoration: none;
  border: var(--bw-default) solid transparent;
  border-radius: var(--radius-md);
  padding: 0.75em 1.25em;
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-default),
              color var(--dur-fast) var(--ease-default),
              border-color var(--dur-fast) var(--ease-default),
              box-shadow var(--dur-fast) var(--ease-default);
  text-align: center;
}
.btn--lg { padding: 0.95em 1.7em; font-size: var(--fs-lg); }
.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.4;          /* opacity.low */
  cursor: not-allowed;
}

/* Primary/CTA: gelber Hintergrund, schwarzer Text. */
.btn--primary {
  background: var(--brand-primary);
  color: var(--text-on-accent);
  border-color: var(--brand-primary);
}
.btn--primary:hover {
  background: var(--brand-primary-print);
  border-color: var(--brand-primary-print);
  color: var(--text-on-accent);
}
.btn--primary.is-loading { opacity: 0.7; }

/* Ghost: transparenter Hintergrund, dunkler Text, dezenter Rand; Hover = Tint. */
.btn--ghost {
  background: transparent;
  color: var(--brand-text-primary);
  border-color: var(--border-default);
}
.btn--ghost:hover {
  background: var(--bg-subtle);
  border-color: var(--border-strong);
  color: var(--brand-text-primary);
}

/* Outline auf dunklem Grund. */
.btn--outline-light {
  background: transparent;
  color: var(--brand-white);
  border-color: rgba(255, 255, 255, 0.45);
}

/* Dezenter Text-Link auf den Beispiel-Report (PDF). */
.report-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  color: var(--brand-text-primary);
  text-decoration: none;
  border-bottom: var(--bw-thin) solid var(--border-default);
  padding-bottom: 2px;
  transition: color var(--dur-fast) var(--ease-default),
              border-color var(--dur-fast) var(--ease-default);
}
.report-link:hover {
  color: var(--brand-black);
  border-bottom-color: var(--brand-primary);
}
.report-link__icon { color: var(--brand-text-secondary); display: inline-flex; }
.report-link:hover .report-link__icon { color: var(--brand-text-primary); }
.hero__report-link { margin: 0 0 1.75rem; }
.benefit-card__link { margin: 0.9rem 0 0; }

/* ------------------------------------------------------ Header / Brand --- */
/* Schwarzer Header mit gelber Unterkante, weißes cubic-Logo. */
.site-header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--brand-black);
  border-bottom: var(--bw-thick) solid var(--brand-primary);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  min-height: 60px;
}
.brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}
/* Logo als Inline-SVG (weiß), tight gecroppt. */
.brand__logo {
  display: block;
  height: 30px;
  width: auto;
}
.site-header__tag {
  font-size: var(--fs-xs);
  color: var(--brand-text-subtle);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

/* -------------------------------------------------- Consent-Rückkehr ---- */
/* Fokussierte Bestätigungs-/Fehler-Ansicht direkt unter dem schwarzen
   Header. Ersetzt den kompletten Funnel nach dem Microsoft-Admin-Consent.
   Brand-konform: helle, zentrierte Karte mit gelbem Akzent; im Fehlerfall
   roter Akzent. Kein Scrollen nötig, oben sichtbar. */
.consent-return {
  background: var(--bg-subtle);
  border-bottom: var(--bw-thin) solid var(--border-default);
  min-height: 70vh;
  display: flex;
  align-items: center;
}
.consent-return__inner {
  padding-block: clamp(2.5rem, 1.5rem + 5vw, 5rem);
}
.consent-return__card {
  max-width: var(--maxw-narrow);
  margin-inline: auto;
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-top: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: clamp(1.6rem, 1rem + 2vw, 2.75rem);
  text-align: center;
}
.consent-return__card--error { border-top-color: var(--band-rot); }

/* Icon-Plakette: schwarzer Kreis, gelbes Icon (Marken-Akzent). */
.consent-return__icon {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  margin: 0 auto 1.25rem;
  border-radius: var(--radius-pill);
  background: var(--brand-black);
  color: var(--brand-primary);
  box-shadow: var(--shadow-md);
}
.consent-return__icon--error { color: var(--band-rot); }
.consent-return__icon .icon { width: 40px; height: 40px; }

/* Headline: Orbitron (erlaubter Display-Kontext, analog Hero). */
.consent-return__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(1.5rem, 1.1rem + 1.9vw, 2.25rem);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  color: var(--brand-text-primary);
  margin: 0 0 0.6em;
}
.consent-return__lead {
  font-size: clamp(1.05rem, 1rem + 0.5vw, 1.2rem);
  color: var(--text-muted);
  max-width: 56ch;
  margin: 0 auto 1.75rem;
  line-height: var(--lh-normal);
}

/* "Was passiert jetzt?"-Hinweis: read-only, ruhige Liste. */
.consent-return__next {
  text-align: left;
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 1.25rem 1.3rem;
  margin: 0 auto 1.5rem;
  max-width: 52ch;
}
.consent-return__next-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--brand-text-secondary);
  margin: 0 0 0.85rem;
}
.consent-return__steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
}
.consent-return__step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.7rem;
  align-items: start;
  font-size: var(--fs-sm);
  color: var(--brand-text-primary);
  line-height: var(--lh-normal);
}
.consent-return__step-icon {
  display: inline-flex;
  color: var(--brand-text-primary);
  margin-top: 0.05rem;
}
.consent-return__step-icon .icon { width: 20px; height: 20px; }

.consent-return__contact {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  margin: 0;
}

/* Fehler-Detail (error_description, escaped). */
.consent-return__detail {
  background: var(--band-rot-bg);
  border: var(--bw-default) solid var(--band-rot-border);
  border-left: var(--bw-thick) solid var(--band-rot);
  border-radius: var(--radius-md);
  padding: 0.8rem 1rem;
  font-size: var(--fs-sm);
  color: var(--brand-text-primary);
  text-align: left;
  max-width: 52ch;
  margin: 0 auto 1.5rem;
  word-break: break-word;
}

.consent-return__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  justify-content: center;
}

/* Inline-Link als Button (öffnet Modal), optisch wie Textlink. */
.consent-return__link {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--ui-info);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--dur-fast) var(--ease-default);
}
.consent-return__link:hover { color: var(--brand-text-primary); }

/* --------------------------------------------------------------- Hero ---- */
.hero {
  background: var(--bg-default);
  border-bottom: var(--bw-thin) solid var(--border-default);
}
.hero__inner {
  padding-block: clamp(2.5rem, 1.5rem + 5vw, 5.5rem);
  max-width: var(--maxw-narrow);
}
.hero__eyebrow {
  display: inline-block;
  font-weight: var(--fw-bold);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--brand-text-primary);
  background: var(--brand-primary);
  padding: 0.45em 0.9em;
  border-radius: var(--radius-sm);
  margin-bottom: 1.1rem;
}
/* Hero-Headline: Orbitron (erlaubter Display-Kontext). */
.hero__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(1.9rem, 1.1rem + 3.4vw, 3.1rem);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  color: var(--brand-text-primary);
  margin-bottom: 0.5em;
}
.hero__subline {
  font-size: clamp(1.05rem, 1rem + 0.5vw, 1.25rem);
  color: var(--text-muted);
  max-width: 56ch;
  margin-bottom: 1.75rem;
  line-height: var(--lh-normal);
}
.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  margin-bottom: 1.75rem;
}
.hero__trust {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem 1.4rem;
  margin: 0;
  padding: 0;
}
.hero__trust-item {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  color: var(--text-muted);
}
.hero__trust-icon {
  display: inline-flex;
  color: var(--brand-text-primary);
}
.hero__trust-icon .icon { width: 20px; height: 20px; }

/* ---------------------------------------------------------- Nutzenblock -- */
.benefits {
  padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
  background: var(--bg-subtle);
  border-top: var(--bw-thin) solid var(--border-default);
}
.benefits__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
.benefit-card {
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 1.5rem 1.4rem;
  box-shadow: var(--shadow-sm);
}
.benefit-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin-bottom: 0.9rem;
  color: var(--brand-text-primary);
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
}
.benefit-card__icon .icon { width: 24px; height: 24px; }
.benefit-card__title {
  font-size: var(--fs-xl);
  margin-bottom: 0.4em;
  color: var(--brand-text-primary);
}
.benefit-card__text { color: var(--text-muted); margin: 0; font-size: var(--fs-md); }

/* ------------------------------------------------------------- Prozess -- */
/* 3-Schritte-Stepper: Self-Assessment -> Auto-Assessment -> Empfehlungen. */
.process {
  padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
  background: var(--bg-default);
  border-top: var(--bw-thin) solid var(--border-default);
}
.process__steps {
  list-style: none;
  margin: 1.75rem 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
.process-step {
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-top: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 1.5rem 1.4rem;
}
.process-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  margin-bottom: 0.9rem;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-lg);
  color: #000;
  background: var(--brand-primary);
  border-radius: var(--radius-md);
}
.process-step__title { font-size: var(--fs-xl); margin: 0 0 0.4em; color: var(--brand-text-primary); }
.process-step__text { color: var(--text-muted); margin: 0; font-size: var(--fs-md); }

/* ----------------------------------------------------------- Self-Check -- */
.check {
  background: var(--bg-default);
  padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
  border-top: var(--bw-thin) solid var(--border-default);
}
.check__intro { max-width: var(--maxw-narrow); }
.check__lead { color: var(--text-muted); font-size: var(--fs-lg); }

/* Statusbar (Fortschritt + Autosave): klebt unter dem Header. */
.check__statusbar {
  position: sticky;
  top: 60px;
  z-index: 100;
  margin: 1.5rem 0 1.75rem;
}
.progress {
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.85rem 1rem;
  box-shadow: var(--shadow-md);
}
.progress__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.55rem;
}
.progress__text { font-weight: var(--fw-bold); font-size: var(--fs-sm); color: var(--brand-text-primary); }
.progress__bar {
  height: 8px;
  background: var(--bg-subtle);
  border: var(--bw-thin) solid var(--border-default);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.progress__bar-fill {
  height: 100%;
  width: 0%;
  background: var(--brand-primary);
  border-radius: var(--radius-pill);
  transition: width var(--dur-slow) var(--ease-default);
}

/* Autosave-Indikator: blitzt kurz auf. */
.save-indicator {
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--text-caption);
  opacity: 0;
  transform: translateY(-2px);
  transition: opacity var(--dur-default) var(--ease-default),
              transform var(--dur-default) var(--ease-default);
  white-space: nowrap;
}
.save-indicator--visible { opacity: 1; transform: translateY(0); }
.save-indicator__dot {
  width: 9px;
  height: 9px;
  border-radius: var(--radius-pill);
  background: var(--band-gruen);
  flex: none;
}
.save-indicator[data-state="saving"] { color: var(--brand-text-secondary); }
.save-indicator[data-state="saving"] .save-indicator__dot {
  background: var(--brand-primary-print);
  animation: pulse 0.9s ease-in-out infinite;
}
.save-indicator[data-state="deferred"] .save-indicator__dot { background: var(--brand-primary); }
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(0.6); opacity: 0.5; }
}

/* Bloecke + Fragen */
.check__blocks { display: grid; gap: 1.25rem; }
.check-loading,
.check-error { color: var(--text-caption); }
.check-error { color: var(--band-rot); font-weight: var(--fw-semibold); }

.check-block {
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 1.4rem 1.25rem 1.5rem;
  box-shadow: var(--shadow-sm);
}
.check-block__header { margin-bottom: 1rem; }
.check-block__eyebrow {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--brand-text-secondary);
  border-bottom: var(--bw-medium) solid var(--brand-primary);
  padding-bottom: 0.2em;
  margin-bottom: 0.6rem;
}
.check-block__title { font-size: var(--fs-2xl); margin-bottom: 0.3em; color: var(--brand-text-primary); }
.check-block__intro { color: var(--text-muted); font-size: var(--fs-md); margin: 0; }

.question-list { display: grid; gap: 0.9rem; }
.question {
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 1.05rem 1rem;
  background: var(--bg-default);
  transition: border-color var(--dur-fast) var(--ease-default),
              background-color var(--dur-fast) var(--ease-default);
}
.question--answered {
  border-color: var(--border-strong);
  background: var(--bg-subtle);
}
.question__head {
  display: flex;
  gap: 0.7rem;
  align-items: flex-start;
  margin-bottom: 0.85rem;
}
.question__num {
  flex: none;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-md);
  background: var(--brand-primary);
  color: var(--text-on-accent);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  margin-top: 0.1rem;
}
.question__text { margin: 0; font-weight: var(--fw-semibold); font-size: var(--fs-md); color: var(--brand-text-primary); }

/* Antwort-Buttons: Ja/Teilweise/Nein/Weiss-nicht. 2-Spalten mobil. */
.answer-group {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}
.answer-btn {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--brand-text-primary);
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.7em 0.5em;
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-default),
              background-color var(--dur-fast) var(--ease-default),
              color var(--dur-fast) var(--ease-default);
}
.answer-btn:hover {
  border-color: var(--border-strong);
  background: var(--bg-subtle);
}
/* Ausgewaehlt: gelber Hintergrund, schwarzer Text (Marken-Akzent, WCAG-AA). */
.answer-btn--selected {
  background: var(--brand-primary);
  border-color: var(--brand-primary);
  color: var(--text-on-accent);
}
.answer-btn--selected:hover {
  background: var(--brand-primary-print);
  border-color: var(--brand-primary-print);
  color: var(--text-on-accent);
}

/* Hint (ausklappbar) */
.question__hint-wrap { margin-top: 0.7rem; }
.hint-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.45em;
  background: none;
  border: none;
  padding: 0.2em 0;
  cursor: pointer;
  color: var(--brand-text-secondary);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
}
.hint-toggle:hover { color: var(--brand-text-primary); text-decoration: underline; }
.hint-toggle__icon {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-pill);
  border: var(--bw-default) solid currentColor;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
}
.hint-toggle[aria-expanded="true"] .hint-toggle__label::after { content: " schließen"; }
.question__hint {
  margin-top: 0.55rem;
  padding: 0.75rem 0.9rem;
  background: var(--bg-subtle);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.question__hint p { margin: 0; font-size: var(--fs-sm); color: var(--text-muted); }

/* ------------------------------------------------------------- Teaser ---- */
.teaser {
  padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
  background: var(--bg-subtle);
  border-top: var(--bw-thin) solid var(--border-default);
}
.teaser__lead { color: var(--text-muted); max-width: 60ch; }

/* Kostenlose Selbsteinschaetzung: Spider-/Radar-Chart. NICHT geblurt. */
.teaser-radar {
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-top: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 1.4rem 1.5rem 1.6rem;
  box-shadow: var(--shadow-sm);
  margin: 1.5rem 0;
}
.teaser-radar__head {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  margin-bottom: 0.5rem;
}
.teaser-radar__badge {
  flex: none;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--text-on-accent);
  background: var(--brand-primary);
  border-radius: var(--radius-sm);
  padding: 0.35em 0.7em;
  margin-top: 0.15rem;
}
.teaser-radar__title { font-size: var(--fs-xl); margin: 0 0 0.2em; color: var(--brand-text-primary); }
.teaser-radar__sub { font-size: var(--fs-sm); color: var(--text-muted); margin: 0; max-width: 60ch; }
.teaser-radar__chart {
  display: flex;
  justify-content: center;
  margin-top: 0.5rem;
}
.teaser-radar__svg {
  width: 100%;
  max-width: 520px;
  height: auto;
}

/* SVG-Innenleben (alle Werte aus app.js gesetzt; nur Optik hier). */
.radar-grid__ring {
  fill: none;
  stroke: var(--border-default);
  stroke-width: 1;
}
.radar-grid__spoke {
  stroke: var(--border-default);
  stroke-width: 1;
}
.radar-axis-label {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  fill: var(--brand-text-secondary);
}
.radar-area {
  fill: rgba(213, 216, 0, 0.22);   /* dezente gelbe Fuellung, niedrige Deckkraft */
  stroke: var(--brand-primary-print);
  stroke-width: 2;
  stroke-linejoin: round;
}
.radar-area__dot {
  fill: var(--brand-primary-print);
  stroke: var(--brand-white);
  stroke-width: 1;
}

.teaser-overall {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-left-width: var(--bw-thick);
  border-radius: var(--radius-md);
  padding: 1.4rem 1.5rem;
  box-shadow: var(--shadow-sm);
  margin: 1.5rem 0;
}
.teaser-overall__gauge {
  flex: none;
  display: grid;
  place-items: center;
  width: 86px;
  height: 86px;
  border-radius: var(--radius-pill);
  background: var(--bg-subtle);
  border: var(--bw-thick) solid var(--border-default);
}
.teaser-overall__value { font-size: var(--fs-2xl); font-weight: var(--fw-bold); color: var(--brand-text-primary); }
.teaser-overall__caption { display: flex; flex-direction: column; gap: 0.2rem; }
.teaser-overall__label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--text-caption);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
}
.teaser-overall__band { font-size: var(--fs-xl); font-weight: var(--fw-bold); color: var(--brand-text-primary); }

/* Bandfärbung Gesamt. Gelb-Band: Form (gestrichelter Rahmen) + Label statt
   reiner Farbe, damit es vom soliden Marken-CTA unterscheidbar bleibt. */
.teaser-overall[data-band="rot"] { border-left-color: var(--band-rot); }
.teaser-overall[data-band="rot"] .teaser-overall__gauge {
  background: var(--band-rot-bg); border-color: var(--band-rot);
}
.teaser-overall[data-band="rot"] .teaser-overall__band,
.teaser-overall[data-band="rot"] .teaser-overall__value { color: var(--band-rot); }

.teaser-overall[data-band="gelb"] { border-left-color: var(--band-gelb); }
.teaser-overall[data-band="gelb"] .teaser-overall__gauge {
  background: var(--band-gelb-bg);
  border-style: dashed;
  border-color: var(--brand-primary-print);
}
.teaser-overall[data-band="gelb"] .teaser-overall__band,
.teaser-overall[data-band="gelb"] .teaser-overall__value { color: var(--brand-primary-print); }

.teaser-overall[data-band="gruen"] { border-left-color: var(--band-gruen); }
.teaser-overall[data-band="gruen"] .teaser-overall__gauge {
  background: var(--band-gruen-bg); border-color: var(--band-gruen);
}
.teaser-overall[data-band="gruen"] .teaser-overall__band,
.teaser-overall[data-band="gruen"] .teaser-overall__value { color: #00a857; }

/* Pro-Block-Reihen. Banddot per Farbe UND Form: gruen=Kreis, gelb=Raute, rot=Quadrat. */
.teaser-blocks {
  display: grid;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}
.teaser-block {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.7rem 0.9rem;
}
.teaser-block__dot {
  flex: none;
  width: 13px;
  height: 13px;
  border-radius: var(--radius-pill);
  background: var(--border-default);
}
.teaser-block[data-band="gruen"] .teaser-block__dot {
  background: var(--band-gruen);
  border-radius: var(--radius-pill);   /* Kreis */
}
.teaser-block[data-band="gelb"] .teaser-block__dot {
  background: var(--band-gelb);
  border-radius: 0;
  transform: rotate(45deg);            /* Raute */
}
.teaser-block[data-band="rot"] .teaser-block__dot {
  background: var(--band-rot);
  border-radius: 0;                    /* Quadrat */
}
.teaser-block__body { display: flex; flex-direction: column; flex: 1 1 auto; min-width: 0; }
.teaser-block__title { font-weight: var(--fw-semibold); font-size: var(--fs-md); color: var(--brand-text-primary); }
.teaser-block__meta { font-size: var(--fs-xs); color: var(--text-caption); }
.teaser-block__value { font-weight: var(--fw-bold); font-size: var(--fs-lg); color: var(--text-muted); }

.teaser__weiss-nicht {
  background: var(--band-gelb-bg);
  border: var(--bw-default) solid var(--band-gelb-border);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 0.8rem 1rem;
  font-size: var(--fs-sm);
  color: var(--brand-text-primary);
  margin-bottom: 1.5rem;
}

.teaser__cta {
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-top: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  text-align: center;
}
.teaser__message { margin-bottom: 1.1rem; color: var(--brand-text-primary); font-size: var(--fs-lg); }

/* ------------------------------------------------ Vollreport / Pricing --- */
.report-offer {
  padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
  background: var(--bg-default);
  border-top: var(--bw-thin) solid var(--border-default);
}
.report-offer__lead { color: var(--text-muted); max-width: 62ch; margin-bottom: 1.75rem; }

.report-offer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  align-items: stretch;
}

/* Rechte Spalte: Nutzen + Festpreis + CTA. */
.report-offer__panel {
  display: flex;
  flex-direction: column;
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 1.6rem 1.5rem;
}
.report-offer__list { list-style: none; margin: 0 0 1.4rem; padding: 0; display: grid; gap: 0.7rem; }
.report-offer__list-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.6rem;
  align-items: start;
  font-size: var(--fs-md);
  color: var(--brand-text-primary);
}
.report-offer__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--brand-text-primary);
  margin-top: 0.05rem;
}
.report-offer__check .icon { width: 20px; height: 20px; }

.report-offer__price {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 1.1rem 1.25rem;
  margin-bottom: 1.25rem;
}
.report-offer__price-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--text-caption);
}
.report-offer__price-value {
  font-size: clamp(2rem, 1.4rem + 2.4vw, 2.6rem);
  font-weight: var(--fw-bold);
  color: var(--brand-text-primary);
  line-height: var(--lh-tight);
}
.report-offer__price-note { font-size: var(--fs-sm); color: var(--text-caption); }

.report-offer__cta { align-self: flex-start; }
.report-offer__hint {
  margin: 1.1rem 0 0;
  font-size: var(--fs-sm);
  color: var(--text-muted);
}

/* Free/Paid-Trennung als deutliche Zeile über dem Grid. */
.report-offer__split {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  margin: 0 0 1.5rem;
  font-size: var(--fs-sm);
}
.report-offer__split-free,
.report-offer__split-paid {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-weight: var(--fw-semibold);
  border-radius: var(--radius-md);
  padding: 0.4em 0.8em;
}
.report-offer__split-free {
  color: var(--text-on-accent);
  background: var(--brand-primary);
}
.report-offer__split-paid {
  color: var(--brand-text-primary);
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
}

/* Geblurte technische Scan-Vorschau: rein CSS, keine externen Bilder. NUR die
   technischen Insight-Kacheln sind geblurt (kostenpflichtig). */
.report-preview {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: var(--bw-default) solid var(--border-default);
  min-height: 320px;
  background: var(--bg-default);
}
.report-preview__scan {
  filter: blur(5px);
  padding: 1.4rem 1.3rem;
  display: grid;
  gap: 1.1rem;
  user-select: none;
  pointer-events: none;
}
.report-preview__scan-head { display: flex; align-items: center; justify-content: space-between; gap: 0.8rem; }
.report-preview__scan-eyebrow {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--brand-text-secondary);
}
.report-preview__badge {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--text-on-accent);
  background: var(--brand-primary);
  border-radius: var(--radius-sm);
  padding: 0.25em 0.7em;
  flex: none;
}

/* Mock-Kacheln der technischen Insights (Werte rein illustrativ, geblurt). */
.report-preview__tiles {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}
.scan-tile {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 0.6rem;
  row-gap: 0.1rem;
  align-items: center;
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 0.65rem 0.8rem;
}
.scan-tile__icon {
  grid-row: 1 / span 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--brand-text-primary);
}
.scan-tile__icon .icon { width: 22px; height: 22px; }
.scan-tile__label { font-size: var(--fs-xs); color: var(--text-muted); }
.scan-tile__value { font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--brand-text-primary); }

/* Schloss-/Overlay über dem geblurten Scan. */
.report-preview__lock {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  text-align: center;
  padding: 1.5rem;
  background: rgba(247, 248, 248, 0.55);
}
.report-preview__lock-icon {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-pill);
  background: var(--brand-black);
  color: var(--brand-primary);
  box-shadow: var(--shadow-md);
}
.report-preview__lock-icon .icon { width: 28px; height: 28px; }
.report-preview__lock-text {
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--brand-text-primary);
  background: var(--brand-white);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.4em 1em;
  box-shadow: var(--shadow-sm);
}

/* Vollreport-Wunsch-Checkbox im Kontaktformular, klar abgesetzt vom Consent. */
.report-request { margin: 0 0 1.25rem; }
.report-request__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.7rem;
  align-items: start;
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 0.85rem 1rem;
  cursor: pointer;
}
.report-request__item input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-top: 0.15rem;
  accent-color: var(--brand-primary);
  cursor: pointer;
  flex: none;
}
.report-request__text { font-size: var(--fs-sm); color: var(--brand-text-primary); line-height: var(--lh-normal); font-weight: var(--fw-semibold); }

/* ----------------------------------------------------- Kontakt & Consent - */
.contact {
  padding-block: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
  background: var(--bg-subtle);
  border-top: var(--bw-thin) solid var(--border-default);
}
.contact__lead { color: var(--text-muted); max-width: 60ch; }
.contact-form {
  margin-top: 1.5rem;
  max-width: var(--maxw-narrow);
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 1.6rem 1.4rem;
  box-shadow: var(--shadow-sm);
}
.form-row { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.form-field { display: flex; flex-direction: column; margin-bottom: 1rem; }
.form-field label {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  margin-bottom: 0.35rem;
  color: var(--brand-text-primary);
}
.form-field__opt { font-weight: var(--fw-regular); color: var(--text-caption); }
.form-field input {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  color: var(--brand-text-primary);
  padding: 0.7em 0.85em;
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--bg-default);
  transition: border-color var(--dur-fast) var(--ease-default),
              box-shadow var(--dur-fast) var(--ease-default);
}
.form-field input:hover { border-color: var(--border-strong); }
.form-field input:focus-visible { border-color: var(--brand-primary); box-shadow: var(--shadow-focus); }
/* Fehler-Styling erst nach Nutzer-Interaktion, nicht auf leeren, unberuehrten Pflichtfeldern. */
.form-field input:user-invalid { border-color: var(--band-rot); }

/* Select erbt das Input-Aussehen (Unternehmensgroesse-Dropdown). */
.form-field select {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  color: var(--brand-text-primary);
  padding: 0.7em 0.85em;
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--bg-default);
  width: 100%;
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-default),
              box-shadow var(--dur-fast) var(--ease-default);
}
.form-field select:hover { border-color: var(--border-strong); }
.form-field select:focus-visible { border-color: var(--brand-primary); box-shadow: var(--shadow-focus); }

/* Consent */
.consent { margin: 0.5rem 0 1.25rem; display: grid; gap: 0.85rem; }
.consent__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.7rem;
  align-items: start;
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.85rem 1rem;
  cursor: pointer;
}
.consent__item--secondary { background: var(--bg-default); }
.consent__item input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-top: 0.15rem;
  accent-color: var(--brand-primary);
  cursor: pointer;
  flex: none;
}
.consent__text { font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-normal); }

.contact-form__submit-row {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  align-items: flex-start;
}
.contact-form__note { font-size: var(--fs-sm); color: var(--text-caption); margin: 0; }

.contact-feedback {
  margin: 1.1rem 0 0;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
}
.contact-feedback[data-kind="success"] {
  background: var(--band-gruen-bg);
  color: #0a7a44;
  border: var(--bw-default) solid var(--band-gruen-border);
}
.contact-feedback[data-kind="error"] {
  background: var(--band-rot-bg);
  color: #a3034f;
  border: var(--bw-default) solid var(--band-rot-border);
}
.contact-feedback[data-kind="pending"] {
  background: var(--bg-subtle);
  color: var(--brand-text-primary);
  border: var(--bw-default) solid var(--border-default);
}

/* Promo-Code-Status (unter dem Promo-Feld). */
.promo-status { margin: 0.4rem 0 0; font-size: var(--fs-sm); font-weight: var(--fw-semibold); }
.promo-status--ok { color: #0a7a44; }
.promo-status--err { color: #a3034f; }

/* --------------------------------------------------- Technischer Ausblick - */
/* Dunkler Bereich (background-dark = schwarz). Weisser Text, gelbe Akzente. */
.tech {
  background: var(--brand-black);
  color: var(--brand-white);
  padding-block: clamp(2.75rem, 1.5rem + 5vw, 5rem);
  border-top: var(--bw-thick) solid var(--brand-primary);
}
.tech__eyebrow {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--brand-primary);
  margin-bottom: 0.6rem;
}
.tech__lead { color: rgba(255, 255, 255, 0.78); max-width: 65ch; font-size: var(--fs-lg); }

.tech__principles {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin: 1.75rem 0 2.5rem;
}
.tech-principle {
  background: rgba(255, 255, 255, 0.04);
  border: var(--bw-thin) solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-md);
  padding: 1.2rem 1.15rem;
}
.tech-principle__icon {
  display: inline-flex;
  margin-bottom: 0.7rem;
  color: var(--brand-primary);
}
.tech-principle__title { color: var(--brand-white); font-size: var(--fs-lg); margin-bottom: 0.4em; }
.tech-principle p { color: rgba(255, 255, 255, 0.72); font-size: var(--fs-sm); margin: 0; }

.tech__subtitle { color: var(--brand-white); font-size: var(--fs-2xl); margin-top: 1rem; }
.tech__subnote { color: rgba(255, 255, 255, 0.6); font-size: var(--fs-sm); max-width: 70ch; }

.tech-dimensions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.55rem;
  margin: 1.25rem 0 2.25rem;
}
.tech-dim {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  background: rgba(255, 255, 255, 0.03);
  border: var(--bw-thin) solid rgba(255, 255, 255, 0.12);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 0.7rem 0.95rem;
}
.tech-dim__icon {
  display: inline-flex;
  flex: none;
  margin-top: 0.1rem;
  color: var(--brand-text-subtle);
}
.tech-dim__icon .icon { width: 20px; height: 20px; }
.tech-dim__body { display: flex; flex-direction: column; gap: 0.15rem; min-width: 0; }
.tech-dim__name { color: var(--brand-white); font-weight: var(--fw-semibold); font-size: var(--fs-md); }
.tech-dim__src { color: rgba(255, 255, 255, 0.55); font-size: var(--fs-xs); }

.tech__app-cta {
  background: rgba(255, 255, 255, 0.04);
  border: var(--bw-default) solid rgba(255, 255, 255, 0.18);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 1.4rem;
  text-align: center;
}
.tech__app-note { color: rgba(255, 255, 255, 0.6); font-size: var(--fs-sm); margin: 0.85rem auto 0; max-width: 62ch; }

/* Statuszeile unter dem Freigabe-Button: Platzhalter-Hinweis / Dank / Fehler. */
.tech__app-status {
  margin: 1rem auto 0;
  max-width: 62ch;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  text-align: left;
}
.tech__app-status[data-kind="info"] {
  background: rgba(213, 216, 0, 0.12);
  border: var(--bw-default) solid rgba(213, 216, 0, 0.4);
  color: var(--brand-white);
}
.tech__app-status[data-kind="success"] {
  background: rgba(0, 216, 112, 0.12);
  border: var(--bw-default) solid rgba(0, 216, 112, 0.45);
  color: var(--brand-white);
}
.tech__app-status[data-kind="error"] {
  background: rgba(216, 0, 104, 0.12);
  border: var(--bw-default) solid rgba(216, 0, 104, 0.45);
  color: var(--brand-white);
}

/* -------------------------------------------------------------- Footer --- */
/* Schwarzer Footer, weißes Logo + Tagline. */
.site-footer {
  background: var(--brand-black);
  color: var(--brand-text-subtle);
  border-top: var(--bw-thick) solid var(--brand-primary);
  padding-block: 2.5rem;
}
.site-footer__inner { display: grid; gap: 1.5rem; }
.site-footer__logo {
  display: block;
  height: 28px;
  width: auto;
}
.site-footer__tagline {
  margin: 1rem 0 0;
  font-size: var(--fs-sm);
  max-width: 60ch;
  color: var(--brand-text-subtle);
}
/* Marken-Tagline (Claim) unter dem Logo: Segoe UI, weit gesperrt. */
.site-footer__claim {
  margin: 0.4rem 0 0;
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wider);
  color: var(--brand-text-subtle);
}
.site-footer__nav { display: flex; flex-wrap: wrap; gap: 1.25rem; }
.site-footer__legal {
  margin: 0;
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.45);
  border-top: var(--bw-thin) solid rgba(255, 255, 255, 0.12);
  padding-top: 1.25rem;
}

/* Footer nav buttons (legal) */
.site-footer__nav-btn {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--brand-text-subtle);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--dur-fast) var(--ease-default);
}
.site-footer__nav-btn:hover { color: var(--brand-white); }

/* ---------------------------------------------------- Legal Modals ----- */
.legal-modal {
  display: none; /* hidden-Attribut allein reicht; JS setzt is-open -> flex */
  position: fixed;
  inset: 0;
  z-index: 400;
  align-items: flex-start;
  justify-content: center;
  padding: 1.5rem 1rem 2rem;
  overflow-y: auto;
}
.legal-modal.is-open {
  display: flex;
}

.legal-modal__backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.8);   /* background-overlay @ opacity.high */
  z-index: 0;
}

.legal-modal__box {
  position: relative;
  z-index: 1;
  background: var(--bg-default);
  border: var(--bw-default) solid var(--border-default);
  border-top: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  width: 100%;
  max-width: 740px;
  margin: auto;
}
.legal-modal__box--narrow {
  max-width: 480px;
}

.legal-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem 1rem;
  border-bottom: var(--bw-thin) solid var(--border-default);
  position: sticky;
  top: 0;
  background: var(--bg-default);
  z-index: 2;
}

.legal-modal__title {
  font-size: clamp(1.2rem, 1rem + 1vw, 1.5rem);
  margin: 0;
  color: var(--brand-text-primary);
}

.legal-modal__close {
  flex: none;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  color: var(--brand-text-secondary);
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  font-family: var(--font-body);
  transition: background-color var(--dur-fast) var(--ease-default),
              color var(--dur-fast) var(--ease-default),
              border-color var(--dur-fast) var(--ease-default);
}
.legal-modal__close:hover {
  background: var(--brand-primary);
  border-color: var(--brand-primary);
  color: var(--text-on-accent);
}

.legal-modal__body {
  padding: 1.5rem;
  display: grid;
  gap: 2rem;
}

.legal-modal__body section {
  display: grid;
  gap: 0.75rem;
}

.legal-modal__body h3 {
  font-size: var(--fs-lg);
  margin: 0;
  color: var(--brand-text-primary);
  border-bottom: var(--bw-medium) solid var(--brand-primary);
  padding-bottom: 0.3em;
}

.legal-modal__body h4 {
  font-size: var(--fs-md);
  margin: 0 0 0.35em;
  color: var(--brand-text-primary);
  font-weight: var(--fw-bold);
}

.legal-modal__body p,
.legal-modal__body li {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  margin: 0;
}

.legal-modal__body ul,
.legal-modal__body ol {
  margin: 0;
  padding-left: 1.4em;
  display: grid;
  gap: 0.45rem;
}

/* ---------------------------------------------------------------- */
/* Tabellen in Legal-Modals (z. B. AVV-Anlagen A3/A4). Brand-konform: */
/* dezente Kopfzeile, 1px-Border in --brand-text-subtle (#9BA7B2),    */
/* border-collapse. Bei schmalen Screens horizontal scrollbar, damit  */
/* breite 3-Spalten-Tabellen das Modal-Layout nicht sprengen.         */
/* ---------------------------------------------------------------- */
.legal-modal__body table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  color: var(--text-muted);
  background: var(--bg-default);
  /* Horizontale Scrollbarkeit auf engen Viewports ohne Layout-Bruch. */
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.legal-modal__body table thead {
  /* Bricht den display:block-Kontext nicht; Zellen bleiben ausgerichtet. */
  background: var(--bg-subtle);
}
.legal-modal__body th,
.legal-modal__body td {
  border: var(--bw-thin) solid var(--brand-text-subtle);
  padding: 0.55rem 0.7rem;
  text-align: left;
  vertical-align: top;
  line-height: var(--lh-snug);
}
.legal-modal__body th {
  font-weight: var(--fw-bold);
  color: var(--brand-text-primary);
  background: var(--bg-subtle);
}
/* Platzhalterzeile für noch leere Fill-in-Tabellen (Anlage A4). */
.legal-modal__body td.legal-table__placeholder {
  font-style: italic;
  color: var(--text-caption);
  text-align: center;
}

/* Hinweis-Box in der Datenschutzerklärung. */
.legal-notice-box {
  background: var(--band-gelb-bg);
  border: var(--bw-default) solid var(--band-gelb-border);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 0.9rem 1rem;
  font-size: var(--fs-sm);
  color: var(--brand-text-primary);
}
.legal-notice-box strong { color: var(--brand-black); }

/* Definition List für Impressum und Kontakt. */
.legal-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.5rem 1.25rem;
  align-items: baseline;
  margin: 0;
  padding: 0;
}
.legal-dl dt {
  font-weight: var(--fw-bold);
  font-size: var(--fs-xs);
  color: var(--text-caption);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  white-space: nowrap;
}
.legal-dl dd {
  margin: 0;
  font-size: var(--fs-sm);
  color: var(--text-muted);
}
.legal-dl dd a {
  color: var(--ui-info);
}

/* Kontaktkarte */
.contact-card {
  display: grid;
  gap: 1.5rem;
}
.contact-card__brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.contact-card__logo {
  display: block;
  height: 30px;
  width: auto;
}
.contact-card__name {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--brand-text-primary);
}
.contact-card__booking {
  background: var(--bg-subtle);
  border: var(--bw-default) solid var(--border-default);
  border-left: var(--bw-thick) solid var(--brand-primary);
  border-radius: var(--radius-md);
  padding: 1.2rem;
  display: grid;
  gap: 0.75rem;
}
.contact-card__booking p {
  font-size: var(--fs-sm);
  color: var(--text-muted);
}
.contact-card__booking-note {
  font-size: var(--fs-xs);
  color: var(--text-caption);
}

/* Body-Scroll-Lock wenn ein Modal offen ist. */
body.modal-open {
  overflow: hidden;
}

/* ----------------------------------------------------------- Responsive -- */
@media (min-width: 600px) {
  .form-row { grid-template-columns: 1fr 1fr; }
  .contact-form__submit-row { flex-direction: row; align-items: center; }
}

@media (min-width: 720px) {
  .answer-group { grid-template-columns: repeat(4, 1fr); }
  .tech__principles { grid-template-columns: 1fr 1fr; }
  .tech-dimensions { grid-template-columns: 1fr 1fr; }
  .check-block { padding: 1.75rem 1.75rem 1.9rem; }
  .question { padding: 1.2rem 1.25rem; }
}

@media (min-width: 860px) {
  .report-offer__grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 920px) {
  .benefits__grid { grid-template-columns: repeat(3, 1fr); }
  .process__steps { grid-template-columns: repeat(3, 1fr); }
}
