/* =========================================================
   gaeb-online.de  -  Design System v2
   Single-stylesheet, keine externen Abhängigkeiten.
   Mobile-first, Darkmode via [data-theme="dark"] auf <html>.
   ========================================================= */

/* ---------- Inter (self-hosted, DSGVO-konform) ---------- */
@font-face { font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap;
  src:url('../fonts/inter-latin-400-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap;
  src:url('../fonts/inter-latin-ext-400-normal.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap;
  src:url('../fonts/inter-latin-500-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap;
  src:url('../fonts/inter-latin-ext-500-normal.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap;
  src:url('../fonts/inter-latin-600-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap;
  src:url('../fonts/inter-latin-ext-600-normal.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:700; font-display:swap;
  src:url('../fonts/inter-latin-700-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:700; font-display:swap;
  src:url('../fonts/inter-latin-ext-700-normal.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:800; font-display:swap;
  src:url('../fonts/inter-latin-800-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Inter'; font-style:normal; font-weight:800; font-display:swap;
  src:url('../fonts/inter-latin-ext-800-normal.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF; }

/* ---------- Design Tokens (Light) ---------- */
:root {
  /* Farben */
  --c-brand:        #0958b3;
  --c-brand-dark:   #074c9e;
  --c-brand-light:  #3a80d4;
  --c-brand-soft:   rgba(9, 88, 179, 0.08);
  --c-brand-softer: rgba(9, 88, 179, 0.04);

  --c-ink:          #0f1e2e;  /* Haupttext, Überschriften */
  --c-ink-2:        #3b4a5c;  /* Fließtext */
  --c-ink-3:        #6b7280;  /* Muted/Meta */
  --c-ink-inv:      #ffffff;

  --c-bg:           #ffffff;
  --c-bg-2:         #f5f7fa;  /* Sanfte Sektions-Flächen */
  --c-bg-3:         #eaeff5;  /* Noch dunkler */
  --c-surface:      #ffffff;  /* Cards */
  --c-border:       #e4e9f0;
  --c-border-strong:#cfd6e0;

  --c-success:      #16a34a;
  --c-warning:      #f59e0b;
  --c-danger:       #dc2626;
  --c-info:         #0284c7;

  --c-footer-bg:    #0f1e2e;
  --c-footer-ink:   #cfd6e0;
  --c-footer-head:  #ffffff;
  --c-footer-link:  #ffffff;
  --c-footer-meta:  #8a95a5;

  /* Typografie */
  --f-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --f-display: clamp(2rem, 4.8vw, 3.25rem);
  --f-h1:      clamp(1.75rem, 3.6vw, 2.375rem);
  --f-h2:      clamp(1.375rem, 2.6vw, 1.75rem);
  --f-h3:      clamp(1.125rem, 1.8vw, 1.3rem);
  --f-body:    1rem;
  --f-small:   0.875rem;
  --f-xs:      0.8125rem;
  --lh-tight:  1.15;
  --lh-heading:1.25;
  --lh-body:   1.65;

  /* Spacing */
  --sp-1:  4px;  --sp-2:  8px;  --sp-3: 12px;  --sp-4: 16px;
  --sp-5: 20px;  --sp-6: 24px;  --sp-7: 28px;  --sp-8: 32px;  --sp-10: 40px;
  --sp-12: 48px; --sp-14: 56px; --sp-16: 64px; --sp-20: 80px;
  --sp-24: 96px; --sp-32: 128px;

  /* Radien */
  --r-sm: 4px;  --r-md: 8px;  --r-lg: 12px;  --r-xl: 16px;  --r-2xl: 20px;  --r-pill: 9999px;

  /* Schatten */
  --sh-sm:  0 1px 2px rgba(15, 30, 46, 0.05);
  --sh-md:  0 4px 12px rgba(15, 30, 46, 0.08);
  --sh-lg:  0 12px 32px rgba(15, 30, 46, 0.10);
  --sh-xl:  0 20px 60px rgba(9, 88, 179, 0.15);

  /* Layout */
  --container-max: 1200px;
  --container-px:  20px;
  --header-h:      72px;
  --topbar-h:      38px;

  /* Motion */
  --ease:     cubic-bezier(.4,0,.2,1);
  --dur-fast: 150ms;
  --dur:      220ms;
  --dur-slow: 400ms;
}
@media (min-width: 768px) { :root { --container-px: 32px; } }

/* ---------- Dark Theme ---------- */
[data-theme="dark"] {
  --c-brand:        #3a80d4;
  --c-brand-dark:   #5a99e2;
  --c-brand-light:  #6fabe8;
  --c-brand-soft:   rgba(58, 128, 212, 0.14);
  --c-brand-softer: rgba(58, 128, 212, 0.07);

  --c-ink:          #f1f5fa;
  --c-ink-2:        #b8c3d0;
  --c-ink-3:        #7a8599;
  --c-ink-inv:      #0f1e2e;

  --c-bg:           #0a0f1a;
  --c-bg-2:         #111827;
  --c-bg-3:         #1a2332;
  --c-surface:      #111827;
  --c-border:       #253142;
  --c-border-strong:#3a4658;

  --c-footer-bg:    #05080f;
  --c-footer-ink:   #b8c3d0;
  --c-footer-head:  #ffffff;
  --c-footer-link:  #ffffff;
  --c-footer-meta:  #7a8599;

  --sh-sm:  0 1px 2px rgba(0, 0, 0, 0.3);
  --sh-md:  0 4px 12px rgba(0, 0, 0, 0.4);
  --sh-lg:  0 12px 32px rgba(0, 0, 0, 0.5);
  --sh-xl:  0 20px 60px rgba(0, 0, 0, 0.6);
}

/* ---------- Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  -moz-tab-size: 4;
  tab-size: 4;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 8px);
}
body {
  font-family: var(--f-sans);
  font-size: var(--f-body);
  line-height: var(--lh-body);
  color: var(--c-ink-2);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
img, svg, video, canvas { display: block; max-width: 100%; height: auto; border-radius: 0; }
button, input, select, textarea { font: inherit; color: inherit; }
a { color: var(--c-brand); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
a:hover { color: var(--c-brand-dark); }
a:focus-visible, button:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid var(--c-brand);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}
hr { border: 0; height: 1px; background: var(--c-border); margin: var(--sp-8) 0; }

/* ---------- Typografie ---------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--f-sans);
  color: var(--c-ink);
  line-height: var(--lh-heading);
  letter-spacing: -0.02em;
  font-weight: 700;
  margin-top: 0;
  margin-bottom: var(--sp-4);
}
h1 { font-size: var(--f-h1); font-weight: 800; letter-spacing: -0.025em; margin-bottom: var(--sp-5); }
h2 { font-size: var(--f-h2); font-weight: 800; margin-bottom: var(--sp-5); }
h3 { font-size: var(--f-h3); font-weight: 700; margin-bottom: var(--sp-4); }
h4 { margin-bottom: var(--sp-3); }
h5, h6 { margin-bottom: var(--sp-2); }
p { margin: 0 0 var(--sp-4); }
p:last-child { margin-bottom: 0; }
ul, ol { padding-left: var(--sp-5); margin: 0 0 var(--sp-4); }
li { margin-bottom: var(--sp-2); }
strong, b { font-weight: 700; color: inherit; }
small { font-size: var(--f-small); }

.display { font-size: var(--f-display); font-weight: 800; line-height: var(--lh-tight); color: var(--c-ink); letter-spacing: -0.025em; }
.eyebrow {
  display: inline-block;
  font-size: var(--f-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-brand);
  margin-bottom: var(--sp-3);
}
.lead { font-size: 1.125rem; line-height: 1.6; color: var(--c-ink-2); }
.muted { color: var(--c-ink-3); }

/* ---------- Layout ---------- */
.container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-px); }
.container-narrow { max-width: 800px; margin: 0 auto; padding: 0 var(--container-px); }
.section { padding: var(--sp-16) 0; }
.section-tight { padding: var(--sp-10) 0; }
.section-alt { background: var(--c-bg-2); }
.section-dark { background: var(--c-ink); color: var(--c-ink-inv); }
.section-dark h1, .section-dark h2, .section-dark h3 { color: #fff; }
@media (min-width: 768px) {
  .section { padding: var(--sp-20) 0; }
  .section-tight { padding: var(--sp-12) 0; }
}

.row { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--sp-6); }
.col-1{grid-column:span 12}.col-2{grid-column:span 12}.col-3{grid-column:span 12}.col-4{grid-column:span 12}
.col-5{grid-column:span 12}.col-6{grid-column:span 12}.col-7{grid-column:span 12}.col-8{grid-column:span 12}
.col-9{grid-column:span 12}.col-10{grid-column:span 12}.col-11{grid-column:span 12}.col-12{grid-column:span 12}
/* Mobile-first defaults: col-md-* and col-lg-* should stack on mobile */
[class*="col-md-"], [class*="col-lg-"] { grid-column: span 12; }
@media (min-width: 768px) {
  .col-md-1{grid-column:span 1}.col-md-2{grid-column:span 2}.col-md-3{grid-column:span 3}.col-md-4{grid-column:span 4}
  .col-md-5{grid-column:span 5}.col-md-6{grid-column:span 6}.col-md-7{grid-column:span 7}.col-md-8{grid-column:span 8}
  .col-md-9{grid-column:span 9}.col-md-10{grid-column:span 10}.col-md-11{grid-column:span 11}.col-md-12{grid-column:span 12}
}
@media (min-width: 1024px) {
  .col-lg-1{grid-column:span 1}.col-lg-2{grid-column:span 2}.col-lg-3{grid-column:span 3}.col-lg-4{grid-column:span 4}
  .col-lg-5{grid-column:span 5}.col-lg-6{grid-column:span 6}.col-lg-7{grid-column:span 7}.col-lg-8{grid-column:span 8}
  .col-lg-9{grid-column:span 9}.col-lg-10{grid-column:span 10}.col-lg-11{grid-column:span 11}.col-lg-12{grid-column:span 12}
}
.items-center { align-items: center; }
.items-start  { align-items: start; }
.gap-2 { gap: var(--sp-2); }  .gap-3 { gap: var(--sp-3); }
.gap-4 { gap: var(--sp-4); }  .gap-6 { gap: var(--sp-6); }
.gap-8 { gap: var(--sp-8); }

/* ---------- Utilities (minimal) ---------- */
.text-center { text-align: center; }
.text-left   { text-align: left; }
.flex { display: flex; }
.inline-flex { display: inline-flex; }
.hidden { display: none !important; }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}
.mt-6{margin-top:var(--sp-6)}.mt-8{margin-top:var(--sp-8)}.mt-10{margin-top:var(--sp-10)}
.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}
.mb-6{margin-bottom:var(--sp-6)}.mb-8{margin-bottom:var(--sp-8)}.mb-10{margin-bottom:var(--sp-10)}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  min-height: 44px; padding: 10px 20px;
  font-family: var(--f-sans); font-weight: 600; font-size: 0.9375rem;
  line-height: 1.2;
  border: 1px solid transparent; border-radius: var(--r-md);
  cursor: pointer; text-decoration: none; white-space: nowrap;
  transition: transform var(--dur-fast) var(--ease),
              background-color var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease);
}
.btn:active { transform: translateY(1px); }
.btn-sm { min-height: 36px; padding: 7px 14px; font-size: 0.875rem; }
.btn-lg { min-height: 52px; padding: 14px 28px; font-size: 1rem; }

.btn-primary { background: var(--c-brand); color: #fff; border-color: var(--c-brand); }
.btn-primary:hover { background: var(--c-brand-dark); border-color: var(--c-brand-dark); color: #fff; box-shadow: var(--sh-md); }

.btn-secondary { background: var(--c-surface); color: var(--c-ink); border-color: var(--c-border-strong); }
.btn-secondary:hover { border-color: var(--c-brand); color: var(--c-brand); }

.btn-ghost { background: transparent; color: var(--c-ink); border-color: transparent; }
.btn-ghost:hover { background: var(--c-brand-soft); color: var(--c-brand); }

.btn-outline { background: transparent; color: var(--c-brand); border-color: var(--c-brand); }
.btn-outline:hover { background: var(--c-brand); color: #fff; }

.btn-icon { padding: 10px; min-width: 44px; }

/* ---------- Top-Bar ---------- */
.topbar {
  background: var(--c-bg-2);
  border-bottom: 1px solid var(--c-border);
  font-size: var(--f-xs);
  color: var(--c-ink-3);
}
.topbar-inner {
  display: flex; align-items: center; justify-content: flex-end;
  min-height: var(--topbar-h);
  gap: var(--sp-5);
}
.topbar a { color: var(--c-ink-3); text-decoration: none; }
.topbar a:hover { color: var(--c-brand); }
.topbar-divider { width: 1px; height: 14px; background: var(--c-border); }
.topbar-btn {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  background: transparent; border: 0; cursor: pointer;
  color: var(--c-ink-3); font-size: var(--f-xs); padding: 4px 8px; border-radius: var(--r-sm);
}
.topbar-btn:hover { color: var(--c-brand); background: var(--c-brand-soft); }
@media (max-width: 767px) { .topbar { display: none; } }

/* ---------- Header ---------- */
.header {
  position: sticky; top: 0; z-index: 100;
  background: var(--c-bg);
  border-bottom: 1px solid var(--c-border);
  transition: box-shadow var(--dur) var(--ease), background-color var(--dur) var(--ease);
}
.header.is-scrolled { box-shadow: var(--sh-md); }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-4); min-height: var(--header-h);
}
.brand { display: inline-flex; align-items: center; gap: var(--sp-3); flex-shrink: 0; }
.brand img { width: 120px; height: 31px; }
.brand-name { font-weight: 800; color: var(--c-ink); font-size: 1rem; letter-spacing: -0.01em; }

/* Main Nav */
.nav { display: none; }
@media (min-width: 1024px) { .nav { display: flex; align-items: center; gap: var(--sp-1); } }
.nav-item { position: relative; }
.nav-link {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 8px 14px;
  font-size: 0.9375rem; font-weight: 500;
  color: var(--c-ink); border-radius: var(--r-md);
  text-decoration: none;
  transition: background-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.nav-link:hover, .nav-link[aria-expanded="true"] { color: var(--c-brand); background: var(--c-brand-soft); }
.nav-caret { width: 12px; height: 12px; opacity: 0.7; transition: transform var(--dur) var(--ease); }
.nav-item.is-open .nav-caret { transform: rotate(180deg); }

/* Dropdown */
.dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; min-width: 320px;
  background: var(--c-surface); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); box-shadow: var(--sh-lg);
  padding: var(--sp-3); z-index: 10;
  opacity: 0; visibility: hidden;
  transform: translateY(-6px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility var(--dur) var(--ease);
}
.nav-item.is-open > .dropdown,
.nav-item:hover > .dropdown,
.nav-item:focus-within > .dropdown {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.dropdown-link {
  display: block;
  padding: 10px 14px; border-radius: var(--r-sm);
  color: var(--c-ink-2); font-size: 0.9375rem; line-height: 1.4;
  text-decoration: none;
}
.dropdown-link:hover { background: var(--c-brand-soft); color: var(--c-brand); }
.dropdown-link strong { display: block; color: var(--c-ink); font-weight: 600; }
.dropdown-link small { display: block; color: var(--c-ink-3); font-size: var(--f-xs); margin-top: 2px; }
.dropdown.dropdown-wide { min-width: 360px; }

/* Mega-Menü (Mehrspaltiges Dropdown) */
.dropdown.dropdown-mega {
  min-width: 640px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-3);
  /* Damit das Menü auf engen Viewports nicht rechts überläuft:
     statt left: 0 an den Rand, zentriert es sich unter dem Nav-Item. */
  left: 50%;
  transform: translate(-50%, -6px);
  max-width: calc(100vw - var(--sp-4) * 2);
}
.nav-item.is-open > .dropdown.dropdown-mega,
.nav-item:hover > .dropdown.dropdown-mega,
.nav-item:focus-within > .dropdown.dropdown-mega {
  transform: translate(-50%, 0);
}
.dropdown-mega .dropdown-col { display: flex; flex-direction: column; }
.dropdown-mega .dropdown-heading {
  display: block;
  padding: 6px 14px 10px;
  color: var(--c-ink-3);
  font-size: var(--f-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--c-border);
  margin-bottom: 4px;
}
@media (max-width: 900px) {
  .dropdown.dropdown-mega { min-width: 100%; grid-template-columns: 1fr; }
}

.header-actions { display: flex; align-items: center; gap: var(--sp-2); }
.theme-toggle {
  background: transparent; border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--c-ink-2);
  transition: border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.theme-toggle:hover { border-color: var(--c-brand); color: var(--c-brand); }
.theme-toggle .icon-sun  { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="dark"] .theme-toggle .icon-sun  { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

/* Mobile Toggle */
.nav-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  background: transparent; border: 1px solid var(--c-border);
  border-radius: var(--r-md); cursor: pointer;
  color: var(--c-ink-2);
}
@media (min-width: 1024px) { .nav-toggle { display: none; } }

/* Mobile Drawer */
.mobile-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(360px, 90vw);
  background: var(--c-surface);
  box-shadow: var(--sh-xl);
  transform: translateX(100%);
  transition: transform var(--dur) var(--ease);
  z-index: 200;
  overflow-y: auto;
  padding: var(--sp-6);
}
.mobile-drawer.is-open { transform: translateX(0); }
.mobile-drawer-close {
  position: absolute; top: 12px; right: 12px;
  width: 40px; height: 40px;
  background: transparent; border: 1px solid var(--c-border);
  border-radius: var(--r-md); cursor: pointer; color: var(--c-ink-2);
  display: inline-flex; align-items: center; justify-content: center;
}
.mobile-backdrop {
  position: fixed; inset: 0; background: rgba(15,30,46,0.55);
  opacity: 0; visibility: hidden; z-index: 150;
  transition: opacity var(--dur) var(--ease), visibility var(--dur) var(--ease);
}
.mobile-backdrop.is-open { opacity: 1; visibility: visible; }
body.nav-open { overflow: hidden; }

.mobile-nav { margin-top: var(--sp-10); display: flex; flex-direction: column; gap: var(--sp-1); }
.mobile-nav a, .mobile-nav button {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; border-radius: var(--r-md);
  color: var(--c-ink); font-weight: 600; font-size: 0.9375rem;
  text-decoration: none; background: transparent; border: 0; cursor: pointer;
  text-align: left; width: 100%;
}
.mobile-nav a:hover, .mobile-nav button:hover { background: var(--c-brand-soft); color: var(--c-brand); }
.mobile-sub {
  padding-left: var(--sp-4); margin-bottom: var(--sp-2);
  border-left: 2px solid var(--c-border);
  display: none;
}
.mobile-sub.is-open { display: block; }
.mobile-sub a { font-weight: 500; font-size: 0.875rem; color: var(--c-ink-2); padding: 8px 10px; }

/* ---------- Hero ---------- */
.hero {
  position: relative; overflow: hidden;
  padding: var(--sp-12) 0 var(--sp-16);
  background: linear-gradient(180deg, var(--c-bg-2) 0%, var(--c-bg) 100%);
}
.hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(circle at 85% 20%, var(--c-brand-soft) 0%, transparent 45%),
    radial-gradient(circle at 10% 90%, var(--c-brand-softer) 0%, transparent 45%);
  z-index: 0;
}
.hero > .container { position: relative; z-index: 1; }
.hero-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-10); align-items: center; }
@media (min-width: 1024px) { .hero-grid { grid-template-columns: 1.1fr 1fr; gap: var(--sp-16); } }
.hero h1 { margin-bottom: var(--sp-5); color: var(--c-ink); }
.hero-lead { font-size: 1.125rem; line-height: 1.55; margin-bottom: var(--sp-8); color: var(--c-ink-2); }
@media (min-width: 768px) { .hero-lead { font-size: 1.25rem; } .hero { padding: var(--sp-16) 0 var(--sp-24); } }
.hero-ctas { display: flex; flex-wrap: wrap; gap: var(--sp-3); }
.hero-image {
  border-radius: 0;
  box-shadow: var(--sh-xl);
  overflow: hidden;
  background: var(--c-surface);
  border: 0;
}
.hero-image img { display: block; width: 100%; height: auto; border-radius: 0; }

.trust-row { margin-top: var(--sp-8); display: flex; flex-wrap: wrap; gap: var(--sp-6); align-items: center; color: var(--c-ink-3); font-size: var(--f-small); }
.trust-row strong { color: var(--c-ink); font-weight: 600; }

/* Schlagwort-Badges – volle Breite unter dem Hero-Grid */
.hero-keywords { margin-top: var(--sp-8); padding-top: var(--sp-6); border-top: 1px solid var(--c-border); }
.keyword-row { margin-top: var(--sp-4); display: flex; flex-wrap: wrap; gap: var(--sp-2); align-items: center; }
.hero-keywords .keyword-row:first-child { margin-top: 0; }
.keyword-row span {
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid var(--c-border);
  border-radius: 999px;
  background: var(--c-surface);
  color: var(--c-ink-2);
  font-size: 0.82rem;
  font-weight: 500;
  line-height: 1.4;
  white-space: nowrap;
}
.keyword-row-formats { margin-top: var(--sp-2); }
.keyword-row-formats span {
  background: transparent;
  color: var(--c-ink-3);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.01em;
}

/* ---------- Card & Produktliste ---------- */
.card {
  background: var(--c-surface); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: var(--sp-6);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.card:hover { border-color: var(--c-brand); box-shadow: var(--sh-lg); }

.prodlist { border-top: 1px solid var(--c-border); list-style: none; padding: 0; margin: var(--sp-6) 0 var(--sp-8); }
.prodlist-item { border-bottom: 1px solid var(--c-border); margin: 0; padding: 0; }
.prodlist-link {
  display: flex; align-items: center; gap: var(--sp-5);
  padding: 20px 12px; color: var(--c-ink); text-decoration: none;
  transition: background-color var(--dur) var(--ease), padding-left var(--dur) var(--ease);
}
.prodlist-link:hover { background: var(--c-brand-softer); padding-left: 18px; color: var(--c-ink); }
.prodlist-icon {
  flex: 0 0 52px; width: 52px; height: 52px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-brand);
  background: var(--c-brand-soft); border-radius: var(--r-md);
}
.prodlist-icon img { width: 32px; height: 32px; }
.prodlist-text { flex: 1 1 auto; min-width: 0; }
.prodlist-title { display: block; font-size: 1rem; font-weight: 700; color: var(--c-ink); line-height: 1.3; margin-bottom: 2px; }
.prodlist-desc  { display: block; font-size: 0.9375rem; color: var(--c-ink-2); line-height: 1.55; }
.prodlist-arrow { flex: 0 0 auto; color: var(--c-brand); font-size: 20px; font-weight: 600; transition: transform var(--dur-fast) var(--ease); }
.prodlist-link:hover .prodlist-arrow { transform: translateX(6px); }
@media (max-width: 640px) {
  .prodlist-link { gap: var(--sp-3); padding: 16px 8px; }
  .prodlist-icon { flex-basis: 40px; width: 40px; height: 40px; }
  .prodlist-icon img { width: 24px; height: 24px; }
  .prodlist-title { font-size: 0.9375rem; }
  .prodlist-desc  { font-size: 0.875rem; }
}

/* Callout (z.B. KI-Produkt) */
.callout {
  position: relative;
  padding: 4px 0 4px 0;
  border-left: 4px solid var(--c-brand);
  background: linear-gradient(90deg, var(--c-brand-soft) 0%, transparent 75%);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  margin-top: var(--sp-6);
}
.callout::before {
  content: attr(data-label);
  position: absolute; top: -10px; left: 20px;
  background: var(--c-brand); color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 4px;
}
.callout .prodlist-link:hover { padding-left: 20px; }

.badge {
  display: inline-block;
  font-size: 11px; font-weight: 700;
  padding: 3px 9px; border-radius: var(--r-pill);
  background: var(--c-brand); color: #fff;
  letter-spacing: 0.02em; vertical-align: middle;
  margin-left: var(--sp-2);
}
.badge-soft { background: var(--c-brand-soft); color: var(--c-brand); }

/* ---------- Section Headings ---------- */
.section-head { text-align: center; max-width: 720px; margin: 0 auto var(--sp-10); }
.section-head h2 { margin-bottom: var(--sp-4); }
.section-head .lead { color: var(--c-ink-2); }

/* ---------- Story (alternierende Bild/Text Blocks) ---------- */
.story-section { padding: var(--sp-16) 0; border-bottom: 1px solid var(--c-border); }
.story-section:last-of-type { border-bottom: 0; }
.story-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-8); align-items: center; }
@media (min-width: 1024px) { .story-grid { grid-template-columns: 1fr 1.3fr; gap: var(--sp-12); } }
.story-section.reverse .story-grid { direction: rtl; }
.story-section.reverse .story-grid > * { direction: ltr; }
.story-image img { border-radius: 0; box-shadow: var(--sh-md); border: 1px solid var(--c-border); }
.story-text h2 { padding-left: var(--sp-4); border-left: 4px solid var(--c-brand); margin-bottom: var(--sp-5); }
.story-text p { font-size: 1.0625rem; line-height: 1.75; color: var(--c-ink-2); }

/* ---------- Feature Grid ---------- */
.feature-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-5);
}
@media (min-width: 640px)  { .feature-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .feature-grid { grid-template-columns: repeat(3, 1fr); } }
.feature {
  padding: var(--sp-6);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.feature:hover { border-color: var(--c-brand); box-shadow: var(--sh-md); transform: translateY(-2px); }
.feature-icon {
  width: 48px; height: 48px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--c-brand-soft); color: var(--c-brand);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-4);
}
.feature-icon img { width: 28px; height: 28px; }
.feature h3 { font-size: 1.0625rem; font-weight: 700; color: var(--c-ink); margin-bottom: var(--sp-2); }
.feature p  { font-size: 0.9375rem; color: var(--c-ink-2); line-height: 1.55; }

/* ---------- CTA-Banner ---------- */
.cta-banner {
  background: linear-gradient(135deg, var(--c-brand) 0%, var(--c-brand-dark) 100%);
  color: #fff;
  border-radius: var(--r-2xl);
  padding: var(--sp-12) var(--sp-8);
  text-align: center;
  box-shadow: var(--sh-xl);
}
.cta-banner h2 { color: #fff; margin-bottom: var(--sp-3); }
.cta-banner p  { color: rgba(255,255,255,0.9); font-size: 1.0625rem; margin-bottom: var(--sp-6); }
.cta-banner .btn { min-width: 160px; }
.cta-banner .btn-primary { background: #fff; color: var(--c-brand); border-color: #fff; }
.cta-banner .btn-primary:hover { background: rgba(255,255,255,0.92); color: var(--c-brand-dark); }
.cta-banner .btn-outline { color: #fff; border-color: rgba(255,255,255,0.5); }
.cta-banner .btn-outline:hover { background: rgba(255,255,255,0.12); border-color: #fff; }

/* ---------- FAQ / Accordion ---------- */
.faq-item {
  border-bottom: 1px solid var(--c-border);
}
.faq-summary {
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
  padding: var(--sp-5) 0; cursor: pointer;
  font-weight: 600; color: var(--c-ink); font-size: 1.0625rem;
  list-style: none;
}
.faq-summary::-webkit-details-marker { display: none; }
.faq-summary::after {
  content: '+'; font-size: 24px; font-weight: 300; color: var(--c-brand);
  transition: transform var(--dur) var(--ease);
}
.faq-item[open] .faq-summary::after { transform: rotate(45deg); }
.faq-content { padding: 0 0 var(--sp-5); color: var(--c-ink-2); font-size: 1rem; line-height: 1.7; }

/* ---------- Price Card ---------- */
.price-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-6);
  align-items: stretch;
}
@media (min-width: 768px)  { .price-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .price-grid { grid-template-columns: repeat(3, 1fr); } }
.price-card {
  display: flex; flex-direction: column;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--sp-8);
  position: relative;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.price-card.is-featured {
  border-color: var(--c-brand);
  box-shadow: 0 0 0 2px var(--c-brand-soft), var(--sh-lg);
}
.price-card.is-featured::before {
  content: 'Empfohlen';
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--c-brand); color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 5px 14px; border-radius: var(--r-pill);
}
.price-card-title { font-size: 1.125rem; font-weight: 700; color: var(--c-ink); margin-bottom: var(--sp-2); }
.price-amount { display: flex; align-items: baseline; gap: 4px; margin: var(--sp-4) 0; }
.price-amount strong { font-size: 2.25rem; font-weight: 800; color: var(--c-ink); line-height: 1; letter-spacing: -0.02em; }
.price-amount .currency { font-size: 1.125rem; color: var(--c-ink-2); font-weight: 600; }
.price-amount .unit { font-size: 0.875rem; color: var(--c-ink-3); margin-left: 4px; }
.price-meta { font-size: var(--f-xs); color: var(--c-ink-3); margin-bottom: var(--sp-5); }
.price-features { list-style: none; padding: 0; margin: 0 0 var(--sp-6); flex: 1 1 auto; }
.price-features li {
  display: flex; align-items: flex-start; gap: var(--sp-2);
  padding: 6px 0; font-size: 0.9375rem; color: var(--c-ink-2);
}
.price-features li::before {
  content: '✓'; flex-shrink: 0;
  color: var(--c-success); font-weight: 700; font-size: 1rem;
  margin-top: 1px;
}
.price-card .btn { width: 100%; }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--c-footer-bg);
  color: var(--c-footer-ink);
  padding: var(--sp-16) 0 0;
  margin-top: var(--sp-24);
}
.site-footer h2 {
  color: var(--c-footer-head); font-size: 0.875rem;
  letter-spacing: 0.06em; text-transform: uppercase;
  margin-bottom: var(--sp-4);
  margin-top: 0;
  font-weight: 700;
}
.site-footer a { color: var(--c-footer-link); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
.site-footer a:hover { color: var(--c-brand-light); }
.site-footer p { color: var(--c-footer-ink); font-size: 0.9375rem; line-height: 1.65; }
.footer-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-8);
}
@media (min-width: 768px)  { .footer-grid { grid-template-columns: 2fr 1.5fr 1fr; } }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: var(--sp-2); font-size: 0.9375rem; }
.footer-contact address { font-style: normal; line-height: 1.7; font-size: 0.9375rem; }
.footer-contact .footer-meta { color: var(--c-footer-meta); font-size: var(--f-xs); margin-top: var(--sp-2); }
.footer-social { display: flex; gap: var(--sp-3); }
.footer-social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--r-md);
  background: rgba(255,255,255,0.08);
}
.footer-social a:hover { background: var(--c-brand); color: #fff; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  margin-top: var(--sp-10);
  padding: var(--sp-6) 0;
  display: grid; gap: var(--sp-4);
}
@media (min-width: 768px) { .footer-bottom { grid-template-columns: 1fr auto; align-items: center; } }
.footer-copy {
  display: flex; align-items: center; gap: var(--sp-3);
  font-size: 0.8125rem; color: var(--c-footer-meta);
}
.footer-copy img { width: 32px; height: 32px; border-radius: 0; }
.footer-legal { display: flex; flex-wrap: wrap; gap: var(--sp-4); font-size: 0.8125rem; }
.footer-legal a { color: var(--c-footer-ink); }
.footer-disclaimer {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: var(--sp-5) 0;
  font-size: var(--f-xs);
  color: var(--c-footer-ink);
  line-height: 1.6;
}
.footer-disclaimer strong { color: #ffffff; font-weight: 700; }

/* ---------- Back to top ---------- */
.to-top {
  position: fixed; right: 20px; bottom: 20px; z-index: 50;
  width: 44px; height: 44px;
  background: var(--c-brand); color: #fff;
  border: 0; border-radius: var(--r-pill);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  opacity: 0; visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility var(--dur) var(--ease);
  box-shadow: var(--sh-lg);
}
.to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.to-top:hover { background: var(--c-brand-dark); }

/* ---------- Skip-Link (A11y) ---------- */
.skip-link {
  position: absolute; left: -9999px; top: 8px;
  background: var(--c-brand); color: #fff; padding: 10px 16px;
  border-radius: var(--r-md); z-index: 500; font-weight: 600;
}
.skip-link:focus { left: 8px; color: #fff; }

/* ---------- Reduce Motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ---------- Print ---------- */
@media print {
  .header, .topbar, .site-footer, .to-top, .nav-toggle, .theme-toggle, .cta-banner { display: none !important; }
  body { background: #fff; color: #000; }
  a { color: #000; text-decoration: underline; }
}

/* ==========================================================
   LEGACY-SHIM
   Kompatibilitäts-Styles für aus Porto/Bootstrap portierten
   Body-Content. Primäres Ziel: Inhalte sichtbar & lesbar
   machen, ohne Bootstrap laden zu müssen. Visuelle Politur
   wird pro Seite iteriert.
   ========================================================== */

/* Breadcrumb (semantische Variante aus dem Extractor) */
.breadcrumb { font-size: 0.9rem; color: var(--c-muted); margin-bottom: var(--sp-3); }
.breadcrumb ol, .breadcrumb ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: var(--sp-2);
}
.breadcrumb li + li::before { content: "›"; margin-right: var(--sp-2); color: var(--c-muted); }
.breadcrumb a { color: var(--c-muted); text-decoration: none; }
.breadcrumb a:hover { color: var(--c-brand); text-decoration: underline; }

/* Sidebar (portiert aus Porto-Listings) */
.sidebar {
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  margin-bottom: var(--sp-6);
}
.sidebar h4 {
  font-size: 0.8125rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--c-muted); margin: var(--sp-5) 0 var(--sp-3);
}
.sidebar h4:first-child { margin-top: 0; }
/* Sidebar-Listen sind IMMER vertikal + linksbündig, auch wenn .nav global
   bei Desktop-Breite zu display:flex wird. Darum hier explizit zurücksetzen. */
.sidebar .nav, .sidebar .nav-list, .sidebar ul {
  list-style: none; padding: 0; margin: 0 0 var(--sp-4);
  display: block !important;
  text-align: left;
}
.sidebar .nav-item { display: block; text-align: left; }
.sidebar .nav-link {
  display: block !important;
  padding: 6px 0;
  color: var(--c-ink); text-decoration: none;
  font-size: 0.9375rem; line-height: 1.4;
  border-bottom: 1px solid transparent;
  text-align: left;
  border-radius: 0;
  background: transparent !important;
}
.sidebar .nav-link:hover { color: var(--c-brand); background: transparent !important; }
.sidebar p, .sidebar li { text-align: left; }

/* Jede Nav-Liste mit .flex-column (Bootstrap-Pattern) ist vertikal + linksbündig,
   auch außerhalb einer .sidebar (z.B. 404-Seite, Sitemap). */
.nav.flex-column, ul.nav-list.flex-column, ul.flex-column {
  list-style: none; padding: 0; margin: 0 0 var(--sp-4);
  display: block !important;
  text-align: left;
}
.nav.flex-column .nav-item,
ul.nav-list.flex-column .nav-item,
ul.flex-column li { display: block; text-align: left; }
.nav.flex-column .nav-link,
ul.nav-list.flex-column .nav-link {
  display: block !important;
  padding: 6px 0;
  color: var(--c-ink); text-decoration: none;
  font-size: 0.9375rem; line-height: 1.4;
  text-align: left;
  border-radius: 0;
  background: transparent !important;
}
.nav.flex-column .nav-link:hover,
ul.nav-list.flex-column .nav-link:hover { color: var(--c-brand); background: transparent !important; }

/* Accordion (Bootstrap-5-Pattern) → ohne JS: immer entfaltet */
.accordion, .accordion-item, .accordion-flush { display: block; }
.accordion-item {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-3);
  overflow: hidden;
}
.accordion-header { margin: 0; }
.accordion-button {
  display: block; width: 100%;
  padding: var(--sp-4) var(--sp-5);
  background: var(--c-surface-alt);
  border: 0; text-align: left; cursor: default;
  font: inherit; font-weight: 700; color: var(--c-ink);
  font-size: 1.0625rem; line-height: 1.35;
}
.accordion-button::after { content: none; }
.accordion-collapse, .accordion-collapse.collapse { display: block !important; }
.accordion-body {
  padding: var(--sp-5);
  background: var(--c-surface);
  color: var(--c-ink);
  line-height: 1.65;
}
.accordion-body p:last-child { margin-bottom: 0; }

/* Bootstrap-like utilities used in body content */
.img-fluid, .img-responsive { max-width: 100%; height: auto; }

.table {
  width: 100%; margin: var(--sp-6) 0;
  border-collapse: collapse;
  font-size: 0.9375rem;
}
.table th, .table td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--c-border);
  text-align: left; vertical-align: top;
}
.table thead th { background: var(--c-surface-alt); font-weight: 700; color: var(--c-ink); }
.table-striped tbody tr:nth-child(odd) { background: var(--c-surface-alt); }
.table-bordered, .table-bordered th, .table-bordered td { border: 1px solid var(--c-border); }

.alert {
  padding: var(--sp-4) var(--sp-5);
  margin: var(--sp-5) 0;
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
  background: var(--c-surface-alt);
}
.alert-primary, .alert-info { border-color: var(--c-brand); background: var(--c-brand-soft); color: var(--c-ink); }
.alert-warning { border-color: #e0a23d; background: #fff6e6; color: #5a3d00; }
.alert-success { border-color: #2a8a4a; background: #e9f8ee; color: #1a4d2b; }
.alert-danger  { border-color: #c44a4a; background: #fbeaea; color: #6d1f1f; }

/* Bootstrap button color variants für Body-CTAs */
.btn-outline-primary { background: transparent; color: var(--c-brand); border-color: var(--c-brand); }
.btn-outline-primary:hover { background: var(--c-brand); color: #fff; }
.btn-success { background: #2a8a4a; color: #fff; border-color: #2a8a4a; }
.btn-danger  { background: #c44a4a; color: #fff; border-color: #c44a4a; }

/* Display/flex utilities */
.d-block  { display: block !important; }
.d-inline-block { display: inline-block !important; }
.d-flex   { display: flex !important; }
.d-none   { display: none !important; }
@media (min-width: 768px)  { .d-md-block{display:block!important} .d-md-flex{display:flex!important} .d-md-none{display:none!important} }
@media (min-width: 1024px) { .d-lg-block{display:block!important} .d-lg-flex{display:flex!important} .d-lg-none{display:none!important} }

.justify-content-start   { justify-content: flex-start; }
.justify-content-center  { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.align-items-center      { align-items: center; }
.flex-column             { flex-direction: column; }
.flex-wrap               { flex-wrap: wrap; }

/* Text utilities */
.text-center { text-align: center; }
.text-right, .text-end { text-align: right; }
.text-left,  .text-start { text-align: left; }
.text-muted  { color: var(--c-muted); }
.text-primary{ color: var(--c-brand); }
.text-danger { color: #c44a4a; }
.text-success{ color: #2a8a4a; }
.fw-bold     { font-weight: 700; }
.fw-normal   { font-weight: 400; }
.small       { font-size: 0.875rem; }
.fs-5        { font-size: 1.125rem; }
.fs-4        { font-size: 1.25rem; }

/* Padding/margin shorthand (Bootstrap 4/5) */
.p-0{padding:0}.p-1{padding:var(--sp-1)}.p-2{padding:var(--sp-2)}.p-3{padding:var(--sp-3)}
.p-4{padding:var(--sp-4)}.p-5{padding:var(--sp-5)}
.py-2{padding-top:var(--sp-2);padding-bottom:var(--sp-2)}.py-3{padding-top:var(--sp-3);padding-bottom:var(--sp-3)}
.py-4{padding-top:var(--sp-4);padding-bottom:var(--sp-4)}.py-5{padding-top:var(--sp-5);padding-bottom:var(--sp-5)}
.px-2{padding-left:var(--sp-2);padding-right:var(--sp-2)}.px-3{padding-left:var(--sp-3);padding-right:var(--sp-3)}
.px-4{padding-left:var(--sp-4);padding-right:var(--sp-4)}.px-5{padding-left:var(--sp-5);padding-right:var(--sp-5)}
.pt-2{padding-top:var(--sp-2)}.pt-3{padding-top:var(--sp-3)}.pt-4{padding-top:var(--sp-4)}.pt-5{padding-top:var(--sp-5)}
.pb-2{padding-bottom:var(--sp-2)}.pb-3{padding-bottom:var(--sp-3)}.pb-4{padding-bottom:var(--sp-4)}.pb-5{padding-bottom:var(--sp-5)}
.m-0{margin:0}.m-auto{margin:auto}
.mx-auto{margin-left:auto;margin-right:auto}
.my-2{margin-top:var(--sp-2);margin-bottom:var(--sp-2)}.my-3{margin-top:var(--sp-3);margin-bottom:var(--sp-3)}
.my-4{margin-top:var(--sp-4);margin-bottom:var(--sp-4)}.my-5{margin-top:var(--sp-5);margin-bottom:var(--sp-5)}
.mt-5{margin-top:var(--sp-8)}.mb-5{margin-bottom:var(--sp-8)}

/* Background utilities (werden in alten Seiten für Call-out-Boxen genutzt) */
.bg-light          { background: var(--c-surface-alt); padding: var(--sp-5); border-radius: var(--r-md); }
.bg-primary        { background: var(--c-brand); color: #fff; }
.bg-primary a      { color: #fff; text-decoration: underline; }

/* Order utilities (mobile-first) */
.order-1 { order: 1; } .order-2 { order: 2; } .order-3 { order: 3; }
@media (min-width: 1024px) {
  .order-lg-1 { order: 1; } .order-lg-2 { order: 2; } .order-lg-3 { order: 3; }
}

/* Generic body content rhythm — gleicht die „nackte"-Wirkung abgespeckter
   Original-Seiten aus, ohne Komponenten zu brechen */
main img { max-width: 100%; height: auto; }
main h2 { margin-top: var(--sp-8); }
main h3 { margin-top: var(--sp-6); }
main h4 { margin-top: var(--sp-6); }
main h5, main h6 { margin-top: var(--sp-5); }
/* Keep first heading snug when it's the first child of its wrapper */
main h2:first-child, main h3:first-child,
main h4:first-child, main h5:first-child, main h6:first-child { margin-top: 0; }
main ul, main ol { padding-left: 1.25em; }
main ul li, main ol li { margin-bottom: var(--sp-1); }

/* Vermeidet dass leere Bootstrap-`row`-Wrapper ohne cols die Höhe killen */
.row:empty { display: none; }

/* ============================================================
   Block-Komponenten für Download / System / Preis-Seiten
   (download-card, download-hero, section-tile, message-box…)
   ============================================================ */

/* Hero-Block am Seitenanfang */
.download-hero {
  background: linear-gradient(135deg, var(--c-brand-soft), var(--c-surface-alt));
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-7) var(--sp-8);
  margin-bottom: var(--sp-6);
  box-shadow: var(--sh-sm);
}
.download-hero h1, .download-hero h2 { margin-top: 0; margin-bottom: var(--sp-4); }
.download-hero .lead { font-size: 1.125rem; color: var(--c-ink-2); margin-bottom: var(--sp-5); line-height: 1.55; }
.download-hero .trust-badges { margin-top: var(--sp-5); display: flex; flex-wrap: wrap; gap: 10px; }

/* Einzelner Karten-Block */
.download-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-7);
  margin-bottom: var(--sp-5);
  box-shadow: var(--sh-sm);
  transition: box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.download-card:hover { box-shadow: var(--sh-md); }
.download-card h2 { margin-top: 0; color: var(--c-ink); }
.download-card h3 { margin-top: var(--sp-5); }
.download-card .title { font-weight: 700; font-size: 1.0625rem; color: var(--c-ink); margin: 0 0 var(--sp-2); }
.download-card .kicker { color: var(--c-brand); font-size: var(--f-xs); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; margin: 0 0 4px; }
.download-card .meta { color: var(--c-ink-3); font-size: 0.9375rem; }

/* Grid-Kacheln (Abschnitts-Navigation) */
.section-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--sp-3);
}
.section-tile {
  display: block;
  padding: var(--sp-4);
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  text-decoration: none;
  color: inherit;
  transition: background-color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.section-tile:hover {
  background: var(--c-brand-soft);
  border-color: var(--c-brand);
  transform: translateY(-2px);
}
.section-tile .kicker { color: var(--c-brand); font-size: var(--f-xs); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; margin: 0 0 6px; }
.section-tile .title  { font-weight: 600; font-size: 0.9375rem; color: var(--c-ink); margin: 0; }

/* Trust-Badges (im Hero) */
.trust-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 999px;
  font-size: 0.8125rem;
  line-height: 1.3;
  color: var(--c-ink-2);
}

/* Message-Boxen (Info / Warning / Error / Success) */
.message-box {
  border-left: 4px solid var(--c-brand);
  background: var(--c-brand-soft);
  padding: var(--sp-5) var(--sp-6);
  border-radius: var(--r-md);
  color: var(--c-ink);
  margin: var(--sp-5) 0;
}
.message-box + .message-box { margin-top: var(--sp-5); }
.message-box p { margin: 0; }
.message-box p + p { margin-top: var(--sp-3); }
.message-box.info    { border-left-color: #2a70c4; background: rgba(42, 112, 196, 0.08); }
.message-box.warning { border-left-color: #d08700; background: rgba(208, 135, 0, 0.08); }
.message-box.error   { border-left-color: #c44a4a; background: rgba(196, 74, 74, 0.08); }
.message-box.success { border-left-color: #2a8a4a; background: rgba(42, 138, 74, 0.08); }
[data-theme="dark"] .message-box.info    { background: rgba(42, 112, 196, 0.16); }
[data-theme="dark"] .message-box.warning { background: rgba(208, 135, 0, 0.16); }
[data-theme="dark"] .message-box.error   { background: rgba(196, 74, 74, 0.16); }
[data-theme="dark"] .message-box.success { background: rgba(42, 138, 74, 0.16); }

/* Info-Box (Variante für Absätze) */
.info-box {
  background: var(--c-brand-soft);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  margin: var(--sp-3) 0;
  font-size: 0.9375rem;
  color: var(--c-ink-2);
}

/* Preis-Block (Pricing-Karten) */
.price-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  text-align: center;
  box-shadow: var(--sh-sm);
  display: flex; flex-direction: column;
  transition: box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.price-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.price-card.featured { border: 2px solid var(--c-brand); box-shadow: var(--sh-md); position: relative; }
.price-card.featured::before {
  content: "Beliebteste Wahl";
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--c-brand); color: white; font-size: var(--f-xs);
  padding: 4px 14px; border-radius: 999px; font-weight: 700; letter-spacing: 0.04em;
}
.price-card .name { font-size: 0.875rem; font-weight: 700; color: var(--c-brand); text-transform: uppercase; letter-spacing: 0.08em; margin: 0 0 var(--sp-2); }
.price-card .price { font-size: 2.25rem; font-weight: 800; color: var(--c-ink); line-height: 1.1; margin: 0 0 4px; }
.price-card .price small { font-size: 0.875rem; font-weight: 500; color: var(--c-ink-3); }
.price-card .note { font-size: 0.875rem; color: var(--c-ink-3); margin: 0 0 var(--sp-5); }
.price-card ul { text-align: left; list-style: none; padding: 0; margin: 0 0 var(--sp-5); flex: 1 1 auto; }
.price-card ul li { padding: 8px 0; border-bottom: 1px solid var(--c-border); color: var(--c-ink-2); font-size: 0.9375rem; }
.price-card ul li:last-child { border-bottom: none; }
.price-card .btn { align-self: stretch; }

.price-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-5);
  margin: var(--sp-6) 0;
}

/* Zeitstrahl / Timeline (für Release-Seiten) */
.timeline {
  position: relative;
  padding-left: 40px;
  margin: var(--sp-6) 0;
}
.timeline::before {
  content: "";
  position: absolute; left: 14px; top: 0; bottom: 0;
  width: 3px; background: var(--c-border);
  border-radius: 2px;
}
.timeline-item {
  position: relative;
  margin-bottom: var(--sp-6);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: var(--sh-sm);
}
.timeline-item::before {
  content: "";
  position: absolute;
  left: -33px; top: 22px;
  width: 16px; height: 16px;
  background: var(--c-brand);
  border: 3px solid var(--c-surface);
  box-shadow: 0 0 0 2px var(--c-brand);
  border-radius: 50%;
}
.timeline-item .year {
  display: inline-block;
  background: var(--c-brand);
  color: white;
  font-weight: 700;
  font-size: 0.875rem;
  padding: 4px 12px;
  border-radius: 999px;
  margin-bottom: var(--sp-3);
  letter-spacing: 0.04em;
}
.timeline-item h2, .timeline-item h3 { margin-top: 0; }

/* ============================================================
   Steps-Grid (Was müssen Sie tun? — 3-Schritt-Karten)
   ============================================================ */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-4);
  margin: var(--sp-5) 0 var(--sp-7);
}
.step-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  text-align: center;
  box-shadow: var(--sh-sm);
}
.step-card p { margin: 0; }
.step-card p + p { margin-top: var(--sp-2); }
.step-number {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px;
  background: var(--c-brand);
  color: white;
  border-radius: 50%;
  font-weight: 800;
  font-size: 1.25rem;
  margin-bottom: var(--sp-3);
}

/* ============================================================
   Accordion / Card / Card-Header / Card-Body (Porto/BS4-Kompat)
   (ohne Bootstrap-JS: alles ausgeklappt zeigen)
   ============================================================ */
.download-accordion { display: block; }
.download-accordion .card,
.card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-3);
  overflow: hidden;
}
.card-header {
  background: var(--c-surface-alt);
  border-bottom: 1px solid var(--c-border);
  padding: var(--sp-3) var(--sp-4);
}
.card-header h5 { margin: 0; font-size: 1.0625rem; }
.card-header .btn-link {
  background: transparent; border: 0; padding: 0;
  color: var(--c-ink); font-weight: 600; font-size: inherit;
  text-align: left; cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
}
.card-header .btn-link:hover { color: var(--c-brand); }
.card-body { padding: var(--sp-4) var(--sp-5); }
/* .collapse.show: Bootstrap hides collapsed content, we override */
.collapse, .collapse.show { display: block !important; }

/* ============================================================
   Release-Timeline (gaeb-release-2014/2016/2018/2021/2023/2025)
   ============================================================ */
.release-entry {
  position: relative;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5);
  margin: 0 0 var(--sp-4) 40px;  /* Abstand für Zeitstrahl-Linie links */
  box-shadow: var(--sh-sm);
  transition: box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.release-entry:hover { box-shadow: var(--sh-md); border-color: var(--c-brand); }

/* Zeitstrahl-Linie: Wir nutzen einen Ancestor .col-md-12, der kann nicht
   modifiziert werden, also legen wir die Linie vor jede .release-entry. */
.release-entry::before {
  content: "";
  position: absolute;
  left: -26px; top: 28px;
  width: 14px; height: 14px;
  background: var(--c-brand);
  border: 3px solid var(--c-surface);
  box-shadow: 0 0 0 2px var(--c-brand);
  border-radius: 50%;
  z-index: 2;
}
.release-entry::after {
  /* vertikale Linie, die das nächste Release mit diesem verbindet */
  content: "";
  position: absolute;
  left: -20px; top: 44px; bottom: -20px;
  width: 2px; background: var(--c-border);
  z-index: 1;
}
.release-entry:last-of-type::after { display: none; }

.release-header {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-2);
  border-bottom: 1px solid var(--c-border);
}
.release-date {
  display: inline-block;
  background: var(--c-brand);
  color: white;
  font-weight: 700;
  font-size: 0.875rem;
  padding: 4px 12px;
  border-radius: 999px;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.release-version {
  font-weight: 600;
  font-size: 1.0625rem;
  color: var(--c-ink);
}
.release-version a { color: inherit; text-decoration: none; border-bottom: 1px dotted var(--c-border); }
.release-version a:hover { color: var(--c-brand); border-bottom-color: var(--c-brand); }

.release-changes {
  list-style: none;
  padding: 0;
  margin: 0;
}
.release-changes li {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: 6px 0;
  color: var(--c-ink-2);
  font-size: 0.9375rem;
  line-height: 1.5;
  border-bottom: 1px solid transparent;
}
.release-changes li + li { border-top: 1px solid var(--c-border); }

.rl-badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 3px 10px;
  border-radius: 999px;
  flex-shrink: 0;
  flex-basis: 130px;
  width: 130px;
  text-align: center;
  margin-top: 2px;
  box-sizing: border-box;
}
.rl-neu {
  background: rgba(42, 138, 74, 0.12);
  color: #1f6f3a;
  border: 1px solid rgba(42, 138, 74, 0.3);
}
.rl-fix {
  background: rgba(42, 112, 196, 0.12);
  color: #1f5aa0;
  border: 1px solid rgba(42, 112, 196, 0.3);
}
[data-theme="dark"] .rl-neu { color: #7ee3a0; background: rgba(42, 138, 74, 0.24); }
[data-theme="dark"] .rl-fix { color: #8fbbff; background: rgba(42, 112, 196, 0.24); }

/* Wenn der Release-Container nicht mehr das linke Bullet zulässt (schmale
   Viewports), kollabiere den Zeitstrahl zu einer Auflistung ohne Linie. */
@media (max-width: 640px) {
  .release-entry { margin-left: 0; padding: var(--sp-4); }
  .release-entry::before, .release-entry::after { display: none; }
  .download-hero { padding: var(--sp-5) var(--sp-5); }
  .download-card { padding: var(--sp-5) var(--sp-5); }
  .trust-badge { padding: 7px 14px; }
}

/* ============================================================
   Bestellung / Kauf-Karten (gaeb-bestellung.html)
   ============================================================ */
.buy-hero {
  background: linear-gradient(135deg, var(--c-brand-soft), var(--c-surface-alt));
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-7) var(--sp-7);
  margin-bottom: var(--sp-6);
  text-align: center;
  box-shadow: var(--sh-sm);
}
.buy-hero h2 { margin-top: 0; margin-bottom: var(--sp-3); }
.buy-hero .lead { font-size: 1.125rem; color: var(--c-ink-2); margin: 0 auto var(--sp-5); max-width: 640px; }
.buy-hero .trust-badges { justify-content: center; }

.buy-options-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--sp-5);
  margin: var(--sp-6) 0;
}
.buy-card {
  position: relative;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-6);
  box-shadow: var(--sh-sm);
  display: flex; flex-direction: column;
  transition: box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.buy-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.buy-card.featured { border: 2px solid var(--c-brand); box-shadow: var(--sh-md); }
.buy-card h3 { margin-top: 0; margin-bottom: var(--sp-2); color: var(--c-ink); font-size: 1.375rem; }
.buy-card .card-desc { color: var(--c-ink-2); margin-bottom: var(--sp-4); line-height: 1.6; }
.buy-card .card-badge {
  position: absolute;
  top: -14px; right: var(--sp-5);
  background: var(--c-brand); color: white;
  font-size: var(--f-xs); font-weight: 700;
  padding: 5px 14px;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 6px;
}
.buy-card .card-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-5);
  flex: 1 1 auto;
}
.buy-card .card-features li {
  padding: 10px 0;
  padding-left: 28px;
  position: relative;
  color: var(--c-ink-2);
  font-size: 0.9375rem;
  border-bottom: 1px solid var(--c-border);
}
.buy-card .card-features li:last-child { border-bottom: none; }
.buy-card .card-features li::before {
  content: "✓";
  position: absolute;
  left: 0; top: 10px;
  color: #2a8a4a;
  font-weight: 700;
  font-size: 1rem;
}
.buy-card .btn { align-self: stretch; text-align: center; justify-content: center; }

/* Highlight-Variante */
.message-box.highlight {
  border-left-color: var(--c-brand);
  background: var(--c-brand-soft);
}
.message-box h5 {
  margin: 0 0 var(--sp-2);
  font-size: 1.0625rem;
  color: var(--c-ink);
  display: flex; align-items: center; gap: 8px;
}

/* ---------- Preisliste (Übersichts-Zeilen unter der Price-Grid) ---------- */
.price-list {
  list-style: none;
  padding: 0;
  margin: var(--sp-8) 0 0;
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-surface);
}
.price-list li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--c-border);
  color: var(--c-ink-2);
  font-size: 0.9375rem;
}
.price-list li:last-child { border-bottom: none; }
.price-list .pl-name { flex: 1 1 auto; min-width: 240px; color: var(--c-ink); }
.price-list .pl-amount {
  flex: 0 0 auto;
  font-weight: 700;
  font-size: 1.0625rem;
  color: var(--c-brand);
  letter-spacing: -0.01em;
}
.price-list .pl-note {
  flex: 0 0 auto;
  font-size: 0.8125rem;
  color: var(--c-ink-3);
  min-width: 110px;
  text-align: right;
}
@media (max-width: 640px) {
  .price-list li { flex-direction: column; align-items: flex-start; }
  .price-list .pl-note { text-align: left; }
}

/* ---------- Content-Card (generische Textblöcke in Sidebar-Seiten) ---------- */
.content-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-6) var(--sp-5);
  margin: var(--sp-6) 0;
  box-shadow: var(--sh-sm);
}
.content-card > h2:first-child,
.content-card > h3:first-child,
.content-card > h4:first-child { margin-top: 0; }
.content-card > *:last-child { margin-bottom: 0; }

/* Kompakte Info-Kachel für Format-Listen (GAEB-Datei Seiten) */
.format-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin: var(--sp-5) 0 var(--sp-6);
}
/* X80-X89 Blöcke immer über die volle Breite – kein Mehrspalten-Grid */
.format-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-left: 4px solid var(--c-brand);
  border-radius: var(--r-md);
  padding: var(--sp-4) var(--sp-5);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.format-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.format-card h4 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--c-brand);
  margin: 0 0 var(--sp-2);
  letter-spacing: 0.02em;
}
.format-card h4 .fmt-label {
  display: inline-block;
  margin-left: var(--sp-2);
  color: var(--c-ink);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0;
}
.format-card p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--c-ink-2);
  line-height: 1.55;
}
.format-card p strong { color: var(--c-ink); }

/* Tabellen in Sidebar-Content (Bootstrap-Kompat) */
main table.table, main .content-card table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
  margin: var(--sp-4) 0 var(--sp-6);
  font-size: 0.9375rem;
}
main table.table th, main table.table td,
main .content-card table th, main .content-card table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--c-border);
  border-right: 1px solid var(--c-border);
  vertical-align: middle;
  color: var(--c-ink-2);
}
main table.table th, main .content-card table th { background: var(--c-muted); color: var(--c-ink); font-weight: 700; }
main table.table tr td:last-child, main table.table tr th:last-child,
main .content-card table tr td:last-child, main .content-card table tr th:last-child { border-right: none; }
main table.table tr:last-child td, main .content-card table tr:last-child td { border-bottom: none; }
main table.table tr:nth-child(even) td, main .content-card table tr:nth-child(even) td { background: color-mix(in srgb, var(--c-muted) 50%, transparent); }

/* icon-check + table-functions */
.icon-check{
  width:1.1rem;height:1.1rem;
  color:var(--color-brand);
  vertical-align:-0.18em;
}
.table-functions{
  width:100%;
  border-collapse:collapse;
  margin:var(--sp-4) 0 var(--sp-8);
}
.table-functions tr{
  border-bottom:1px solid var(--color-border);
}
.table-functions tr:first-child{
  background:var(--color-surface-alt);
  font-weight:600;
}
.table-functions td{
  padding:var(--sp-2) var(--sp-3);
}
.table-functions td:last-child{
  width:72px;
  text-align:center;
}
[data-theme="dark"] .icon-check{ color:var(--color-brand-hi,#7aa7ff); }


/* Dark-mode high-contrast links */
[data-theme="dark"] a {
  color: #7ab0ff;
}
[data-theme="dark"] a:hover,
[data-theme="dark"] a:focus-visible {
  color: #bcd6ff;
  text-decoration: underline;
}
/* preserve footer / header / button colours */
[data-theme="dark"] .site-footer a { color: var(--c-footer-link); }
[data-theme="dark"] .site-footer a:hover { color: var(--c-brand-light); }
[data-theme="dark"] .btn,
[data-theme="dark"] .btn:hover,
[data-theme="dark"] .btn:focus-visible {
  color: inherit;
  text-decoration: none;
}
[data-theme="dark"] .btn-primary,
[data-theme="dark"] .btn-primary:hover {
  color: #fff;
}
[data-theme="dark"] .header a,
[data-theme="dark"] .dropdown-link,
[data-theme="dark"] .nav-link {
  color: inherit;
}


/* sitemap */
.sitemap-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:var(--sp-6);
}
@media (min-width:640px){ .sitemap-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px){ .sitemap-grid{ grid-template-columns:repeat(3,1fr); } }
.sitemap-card{
  background:var(--c-surface);
  border:1px solid var(--c-border);
  border-radius:var(--r-lg);
  padding:var(--sp-5) var(--sp-6);
  box-shadow:var(--sh-sm);
  transition:box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.sitemap-card:hover{ box-shadow:var(--sh-md); transform:translateY(-2px); }
.sitemap-card h3{
  margin:0 0 var(--sp-3);
  padding-bottom:var(--sp-2);
  border-bottom:2px solid var(--c-brand);
  color:var(--c-ink);
  font-size:1.125rem;
  font-weight:700;
  letter-spacing:-0.01em;
}
.sitemap-list{
  list-style:none;
  padding:0;
  margin:0;
}
.sitemap-list li{
  margin:0;
  padding:var(--sp-1) 0;
  border-bottom:1px solid var(--c-border);
}
.sitemap-list li:last-child{ border-bottom:0; }
.sitemap-list li a{
  display:flex;
  align-items:center;
  gap:var(--sp-2);
  color:var(--c-ink);
  text-decoration:none;
  font-size:0.9375rem;
  padding:var(--sp-1) 0;
  transition:color var(--dur-fast) var(--ease);
}
.sitemap-list li a::before{
  content:"›";
  color:var(--c-brand);
  font-weight:700;
  flex-shrink:0;
}
.sitemap-list li a:hover{ color:var(--c-brand); }
[data-theme="dark"] .sitemap-list li a{ color:var(--c-ink); }
[data-theme="dark"] .sitemap-list li a:hover{ color:#7ab0ff; }

/* ---------- Dark-Mode Override für inline FAQ-Styles ---------- */
/* Greift Klassen wie .aufmass-faq, .da84-faq, .rueck-faq, .kalk-faq usw. ab.
   Höhere Spezifität als die inline <style>-Blöcke (0,3,1 vs 0,1,1). */
[data-theme="dark"] [class*="-faq"] details,
[data-theme="dark"] [class*="-faq"] details[open] {
  border-bottom-color: var(--c-border);
}
[data-theme="dark"] [class*="-faq"] summary {
  color: var(--c-ink);
}
[data-theme="dark"] [class*="-faq"] summary:hover {
  color: #7ab0ff;
}
[data-theme="dark"] [class*="-faq"] .faq-answer,
[data-theme="dark"] [class*="-faq"] .faq-answer p,
[data-theme="dark"] [class*="-faq"] .faq-answer li {
  color: var(--c-ink-2);
}
[data-theme="dark"] [class*="-faq"] .faq-answer strong {
  color: var(--c-ink);
}
[data-theme="dark"] [class*="-faq"] summary::after {
  color: #7ab0ff;
}

/* ---------- Dark-Mode Fix: Inline-gestylte Vorteils-Boxen (3er-Grid) ---------- */
/* Diese Boxen stehen auf 27+ Seiten mit hart codierten Inline-Styles:
   background:#f8faff (hell), border-left:4px solid #0958b3, color:#1d2127.
   Im Dark Mode müssen wir sie per attribute selector + !important überschreiben. */
[data-theme="dark"] [style*="background:#f8faff"],
[data-theme="dark"] [style*="background: #f8faff"] {
  background: rgba(42, 112, 196, 0.12) !important;
}
[data-theme="dark"] [style*="#1d2127"] {
  color: var(--c-ink) !important;
}
/* Text innerhalb der Boxen (p-Elemente) heller färben */
[data-theme="dark"] [style*="background:#f8faff"] p,
[data-theme="dark"] [style*="background: #f8faff"] p {
  color: var(--c-ink-2);
}

/* ======================================================================
   Produktberater-Modal (Menü-Button: „Produktberater")
   ====================================================================== */
.pf-backdrop {
  position: fixed; inset: 0;
  background: rgba(12, 18, 30, 0.58);
  display: none;
  align-items: center; justify-content: center;
  z-index: 9999;
  padding: 16px;
  animation: pf-fade 0.2s ease both;
}
.pf-backdrop.is-open { display: flex; }
@keyframes pf-fade { from { opacity: 0; } to { opacity: 1; } }

.pf-modal {
  background: var(--c-surface);
  color: var(--c-ink);
  border: 1px solid var(--c-border);
  border-radius: 12px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.28);
  max-width: 720px; width: 100%;
  max-height: 92vh;
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: pf-pop 0.24s cubic-bezier(.2, .9, .3, 1.2) both;
}
@keyframes pf-pop {
  from { transform: translateY(14px) scale(0.98); opacity: 0; }
  to   { transform: none; opacity: 1; }
}

.pf-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px 0 20px;
}
.pf-progress-wrap { flex: 1; padding-right: 16px; }
.pf-progress-label {
  font-size: 11px; color: var(--c-ink-3);
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 6px; font-weight: 600;
}
.pf-progress-bar {
  background: var(--c-border);
  height: 5px; border-radius: 999px; overflow: hidden;
}
.pf-progress-fill {
  background: var(--c-brand);
  height: 100%; border-radius: 999px;
  transition: width 0.3s ease;
}
.pf-close {
  background: transparent; border: 0;
  width: 32px; height: 32px; border-radius: 50%;
  display: grid; place-items: center;
  cursor: pointer; color: var(--c-ink-3);
  font-size: 18px; line-height: 1;
}
.pf-close:hover { background: rgba(0, 0, 0, 0.06); color: var(--c-ink); }
[data-theme="dark"] .pf-close:hover { background: rgba(255, 255, 255, 0.08); }

.pf-body { padding: 16px 28px 24px 28px; overflow-y: auto; flex: 1; }
.pf-body h2 { font-size: 22px; margin: 6px 0 6px; font-weight: 700; line-height: 1.3; color: var(--c-ink); }
.pf-body .pf-sub { color: var(--c-ink-3); font-size: 14px; margin: 0 0 20px; }

.pf-options {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
@media (max-width: 560px) { .pf-options { grid-template-columns: 1fr; } }
.pf-options.cols-3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 680px) { .pf-options.cols-3 { grid-template-columns: 1fr; } }
.pf-options.cols-1 { grid-template-columns: 1fr; }

.pf-option {
  text-align: left;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: 10px;
  padding: 14px 16px;
  cursor: pointer;
  font: inherit;
  color: var(--c-ink);
  text-decoration: none;
  transition: border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
  display: flex; gap: 12px; align-items: flex-start;
}
.pf-option:hover {
  border-color: var(--c-brand);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(9, 88, 179, 0.10);
  text-decoration: none;
}
.pf-option .pf-icon {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  color: var(--c-ink-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color .15s ease;
}
.pf-option .pf-icon svg { width: 100%; height: 100%; display: block; }
.pf-option:hover .pf-icon,
.pf-option:focus-visible .pf-icon { color: var(--c-brand); }
.pf-option .pf-title { display: block; font-weight: 600; margin-bottom: 2px; color: var(--c-ink); }
.pf-option .pf-desc { display: block; font-size: 13px; color: var(--c-ink-3); line-height: 1.45; }

.pf-foot {
  padding: 14px 20px;
  border-top: 1px solid var(--c-border);
  display: flex; justify-content: space-between; gap: 12px;
}
.pf-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 6px;
  background: transparent;
  border: 1.5px solid var(--c-border);
  color: var(--c-ink-2);
  font-size: 14px; font-weight: 500;
  cursor: pointer;
}
.pf-btn:hover { border-color: var(--c-brand); color: var(--c-brand); }

/* Ergebnis-Ansicht */
.pf-result-main {
  background: linear-gradient(135deg, rgba(9, 88, 179, 0.06), rgba(9, 88, 179, 0.02));
  border: 1.5px solid var(--c-brand);
  border-radius: 10px;
  padding: 18px 20px;
  margin-bottom: 10px;
}
[data-theme="dark"] .pf-result-main {
  background: linear-gradient(135deg, rgba(42, 112, 196, 0.20), rgba(42, 112, 196, 0.08));
}
.pf-result-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--c-brand); margin-bottom: 6px;
}
[data-theme="dark"] .pf-result-label { color: #7ab0ff; }
.pf-result-title { font-size: 20px; font-weight: 700; margin: 0 0 2px; color: var(--c-ink); }
.pf-result-price { font-size: 15px; font-weight: 600; color: var(--c-ink-2); }
.pf-result-desc { font-size: 14px; color: var(--c-ink-3); margin: 10px 0 0; line-height: 1.5; }

.pf-addons { display: grid; gap: 10px; margin-top: 6px; }
.pf-addon {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 12px 14px;
  border: 1px solid var(--c-border);
  border-radius: 8px;
  background: var(--c-surface);
  color: var(--c-ink);
  text-decoration: none;
  transition: border-color 0.15s ease;
}
.pf-addon:hover { border-color: var(--c-brand); text-decoration: none; }
.pf-addon-icon {
  color: #2a8a4a; font-size: 12px; font-weight: 700; flex-shrink: 0;
  background: rgba(42, 138, 74, 0.12);
  width: 22px; height: 22px;
  border-radius: 50%;
  display: grid; place-items: center;
}
[data-theme="dark"] .pf-addon-icon { color: #7ee3a0; background: rgba(42, 138, 74, 0.24); }
.pf-addon-text strong { display: block; margin-bottom: 2px; font-size: 14px; color: var(--c-ink); }
.pf-addon-price { display: block; font-size: 13px; font-weight: 600; color: var(--c-brand); margin-bottom: 2px; }
[data-theme="dark"] .pf-addon-price { color: var(--c-brand-light, #6aa9e6); }
.pf-addon-text .desc { font-size: 13px; color: var(--c-ink-3); line-height: 1.45; }

.pf-ctas { display: flex; gap: 10px; margin-top: 18px; }
@media (max-width: 480px) { .pf-ctas { flex-direction: column; } }
.pf-cta {
  flex: 1; text-align: center;
  padding: 11px 16px; border-radius: 6px;
  font-size: 14px; font-weight: 600;
  font-family: inherit;
  text-decoration: none;
  cursor: pointer;
  transition: filter 0.15s ease, transform 0.15s ease, opacity 0.15s ease;
}
.pf-cta:hover { filter: brightness(0.95); transform: translateY(-1px); text-decoration: none; }
.pf-cta-primary { background: var(--c-brand); color: #fff; border: 2px solid var(--c-brand); }
.pf-cta-outline { background: transparent; color: var(--c-brand); border: 2px solid var(--c-brand); }
[data-theme="dark"] .pf-cta-outline { color: #7ab0ff; border-color: #7ab0ff; }
.pf-cta:disabled,
.pf-cta[aria-disabled="true"] {
  opacity: 0.45; cursor: not-allowed; filter: none; transform: none;
}
.pf-cta:disabled:hover { filter: none; transform: none; }

/* Bestätigung (Checkbox-Screen vor FastSpring-Weiterleitung) */
.pf-confirm-list {
  display: flex; flex-direction: column; gap: 14px;
  margin: 18px 0 8px;
}
.pf-confirm-item {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 14px;
  border: 1px solid var(--c-border);
  border-radius: 8px;
  background: var(--c-surface);
  color: var(--c-ink);
  font-size: 14px; line-height: 1.5;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.pf-confirm-item:hover { border-color: var(--c-brand); }
.pf-confirm-item input[type="checkbox"] {
  margin: 2px 0 0;
  width: 18px; height: 18px;
  flex-shrink: 0;
  accent-color: var(--c-brand);
  cursor: pointer;
}
.pf-confirm-item:has(input:checked) {
  border-color: var(--c-brand);
  background: rgba(9, 88, 179, 0.04);
}
[data-theme="dark"] .pf-confirm-item:has(input:checked) {
  background: rgba(42, 112, 196, 0.12);
}
.pf-confirm-item a { color: var(--c-brand); text-decoration: underline; }
[data-theme="dark"] .pf-confirm-item a { color: #7ab0ff; }

.pf-fallback {
  margin-top: 18px; padding-top: 14px;
  border-top: 1px solid var(--c-border);
  font-size: 13px; color: var(--c-ink-3); text-align: center;
}
.pf-fallback a { color: var(--c-brand); text-decoration: none; font-weight: 500; }
.pf-fallback a:hover { text-decoration: underline; }
[data-theme="dark"] .pf-fallback a { color: #7ab0ff; }

/* Embedded FastSpring-Checkout (inline im Modal) */
.pf-modal.pf-modal--checkout { max-width: 960px; }

/* Permanente Shell — seit Seitenstart im DOM, nur hidden bis zum Checkout-Schritt.
   Damit findet die FastSpring-SBL den Container #fsc-embedded-checkout-container
   zuverlässig bei jedem Durchlauf (nicht nur beim ersten). */
.pf-checkout-shell {
  padding: 10px 20px 16px 20px;
  overflow-y: auto;
  flex: 1;
  display: flex; flex-direction: column; gap: 8px;
}
.pf-checkout-shell[hidden] { display: none; }

.pf-checkout-head { padding: 0; }
.pf-checkout-head h2 { font-size: 17px; margin: 2px 0 4px; font-weight: 700; line-height: 1.25; color: var(--c-ink); }
.pf-checkout-head .pf-sub { color: var(--c-ink-3); font-size: 12.5px; margin: 0 0 8px; line-height: 1.45; }

.pf-checkout-items {
  list-style: none;
  margin: 0; padding: 0;
  display: grid; gap: 4px;
}
.pf-co-item {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 10px;
  border: 1px solid var(--c-border);
  border-radius: 6px;
  background: var(--c-surface);
  min-height: 28px;
}
.pf-co-item.pf-co-main { border-color: var(--c-brand); background: color-mix(in srgb, var(--c-brand) 6%, var(--c-surface)); }
.pf-co-check {
  flex: 0 0 auto;
  width: 15px; height: 15px;
  border-radius: 50%;
  background: var(--c-brand);
  color: #fff;
  display: grid; place-items: center;
  font-size: 9px; font-weight: 700;
}
.pf-co-text {
  display: flex; flex-direction: row; align-items: baseline;
  gap: 8px; min-width: 0; flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pf-co-title {
  font-weight: 600; font-size: 13px; color: var(--c-ink);
  overflow: hidden; text-overflow: ellipsis;
}
.pf-co-price {
  font-size: 12px; color: var(--c-ink-2); font-weight: 600;
  margin-left: auto;
  flex-shrink: 0;
}
/* Beschreibung in der Warenkorb-Liste ausblenden – nur Titel + Preis */
.pf-co-desc { display: none; }

.pf-checkout-frame {
  position: relative;
  min-height: 520px;
  flex: 1;
  border: 1px solid var(--c-border);
  border-radius: 8px;
  background: var(--c-surface);
  overflow: hidden;
}
.pf-checkout-frame iframe {
  width: 100% !important;
  min-height: 520px;
  border: 0;
  display: block;
}
@media (max-width: 720px) {
  .pf-checkout-frame, .pf-checkout-frame iframe { min-height: 640px; }
}

/* pfBody kann per hidden-Attribut temporär verborgen werden */
.pf-body[hidden] { display: none; }

/* Produktberater-Button im Menü (als Button statt Link) */
.nav-link-btn {
  background: transparent; border: 0; padding: 0;
  font: inherit; color: inherit;
  cursor: pointer;
}

/* Produktberater-Button in der Header-Aktionsleiste (neben "Kaufen").
   Unter 1024 px übernimmt der Mobile-Drawer die Navigation. */
.header-pf-btn { white-space: nowrap; }
@media (max-width: 1023.98px) {
  .header-pf-btn { display: none; }
}

/* ======================================================================
   EOL-Download-Modal (Rückfrage beim Laden abgekündigter Setup-Dateien)
   Aufgerufen aus assets/app.js → window.confirmDownloadOld(link).
   ====================================================================== */
.eol-backdrop {
  position: fixed; inset: 0;
  background: rgba(12, 18, 30, 0.62);
  display: none;
  align-items: center; justify-content: center;
  z-index: 10000;
  padding: 16px;
  animation: eol-fade 0.18s ease both;
}
.eol-backdrop.is-open { display: flex; }
@keyframes eol-fade { from { opacity: 0; } to { opacity: 1; } }

.eol-modal {
  position: relative;
  background: var(--c-surface);
  color: var(--c-ink);
  border: 1px solid var(--c-border);
  border-top: 4px solid var(--c-warning);
  border-radius: 14px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.32);
  max-width: 460px; width: 100%;
  padding: 28px 28px 22px;
  text-align: center;
  animation: eol-pop 0.22s cubic-bezier(.2, .9, .3, 1.2) both;
}
@keyframes eol-pop {
  from { transform: translateY(10px) scale(0.97); opacity: 0; }
  to   { transform: none; opacity: 1; }
}

.eol-close {
  position: absolute; top: 10px; right: 10px;
  width: 30px; height: 30px; border-radius: 50%;
  background: transparent; border: 0;
  display: grid; place-items: center;
  cursor: pointer; color: var(--c-ink-3);
  font-size: 16px; line-height: 1;
}
.eol-close:hover { background: rgba(0, 0, 0, 0.06); color: var(--c-ink); }
[data-theme="dark"] .eol-close:hover { background: rgba(255, 255, 255, 0.08); }

.eol-icon {
  width: 64px; height: 64px;
  margin: 0 auto 14px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: color-mix(in srgb, var(--c-warning) 16%, transparent);
  color: var(--c-warning);
}
.eol-icon svg { width: 34px; height: 34px; display: block; }

.eol-modal h2 {
  font-size: 20px; font-weight: 700; line-height: 1.3;
  margin: 0 0 10px;
  color: var(--c-ink);
}
.eol-text {
  color: var(--c-ink-2);
  font-size: 14.5px; line-height: 1.55;
  margin: 0 0 22px;
}

.eol-ctas {
  display: flex; justify-content: center; gap: 10px;
  flex-wrap: wrap;
}
.eol-ctas .btn {
  min-width: 150px;
}
@media (max-width: 420px) {
  .eol-ctas { flex-direction: column-reverse; }
  .eol-ctas .btn { width: 100%; }
}
