/* ========================================================================
   conzito — Website shared styles
   Imports design tokens from colors_and_type.css and adds page-level
   primitives: nav, footer, buttons, hero atmospherics, section patterns.
   ======================================================================== */

@import url('./colors_and_type.css');

/* Globaler Lesbarkeits-Override: fg-3 und fg-4 waren auf hellem BG zu blass.
   Eine Stufe nach dunkler verschoben — gilt für alle Paletten, die diese
   Tokens nicht selbst überschreiben (warm, teal). Aubergine/Forest setzen
   ihre eigenen, jetzt ebenfalls dunkleren Werte. */
:root {
  --fg-3: var(--sand-700);
  --fg-4: var(--sand-600);
}

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

html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg-app);
  color: var(--fg-2);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
}

/* subtle paper texture — warm, unobtrusive */
body::before {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(200,107,74,0.04), transparent 40%),
    radial-gradient(circle at 90% 60%, rgba(101,144,92,0.035), transparent 40%);
  z-index: 0;
}

main, nav, footer, section { position: relative; z-index: 1; }

.wrap { max-width: 1240px; margin: 0 auto; padding: 0 40px; }
.wrap-narrow { max-width: 880px; margin: 0 auto; padding: 0 40px; }

a { color: inherit; text-decoration: none; }

/* =========================================================================
   NAV
   ========================================================================= */
nav.top {
  position: sticky; top: 0; z-index: 50;
  background: rgba(251, 248, 244, 0.82);
  backdrop-filter: saturate(1.4) blur(14px);
  -webkit-backdrop-filter: saturate(1.4) blur(14px);
  border-bottom: 1px solid var(--border-subtle);
}
.nav-row { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 32px; }
.brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 800; font-size: 22px; letter-spacing: -0.025em;
  color: var(--fg-1);
}
.brand-glyph {
  width: 38px; height: 38px; border-radius: 50%;
  background: transparent;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--clay-600);
  flex-shrink: 0;
}
.brand-glyph svg,
.brand-glyph img { width: 100%; height: 100%; display: block; object-fit: contain; }
.footer-brand .brand-glyph { color: #fff; }

.nav-links { display: flex; gap: 4px; align-items: center; }
.nav-item {
  position: relative;
  display: inline-flex; align-items: center; gap: 4px;
  padding: 10px 14px;
  color: var(--fg-2); font-size: 15px; font-weight: 500;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.nav-item:hover { color: var(--fg-1); background: var(--sand-100); }
.nav-item.active { color: var(--clay-700); }
.nav-item svg { opacity: 0.6; transition: transform var(--dur-base); }
.nav-item:hover svg { opacity: 1; }

.dropdown { position: relative; }
.dropdown-menu {
  position: absolute; top: calc(100% + 8px); left: -8px;
  min-width: 300px;
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 8px;
  opacity: 0; visibility: hidden; transform: translateY(-4px);
  transition: opacity var(--dur-base) var(--ease-out), visibility var(--dur-base), transform var(--dur-base) var(--ease-out);
  z-index: 60;
}
.dropdown:hover .dropdown-menu,
.dropdown:focus-within .dropdown-menu {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.dropdown:hover > .nav-item svg { transform: rotate(180deg); }

.dm-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--dur-fast);
}
.dm-item:hover { background: var(--sand-50); }
.dm-item.disabled { opacity: 0.5; cursor: default; }
.dm-item.disabled:hover { background: transparent; }
.dm-icon {
  width: 36px; height: 36px; border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.dm-icon.clay { background: var(--clay-50); color: var(--clay-600); }
.dm-icon.sage { background: var(--sage-50); color: var(--sage-600); }
.dm-icon.info { background: var(--info-50); color: var(--info-500); }
.dm-icon.sand { background: var(--sand-100); color: var(--fg-3); }
.dm-title { font-weight: 600; font-size: 14px; color: var(--fg-1); line-height: 1.2; }
.dm-sub { font-size: 12.5px; color: var(--fg-3); margin-top: 2px; }
.dm-tag {
  display: inline-block; margin-left: 8px;
  font-size: 10px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 2px 6px; border-radius: 4px;
  background: var(--sand-200); color: var(--fg-3);
}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: inherit; font-size: 15px; font-weight: 600;
  padding: 11px 20px;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  cursor: pointer; white-space: nowrap;
  transition: all var(--dur-fast) var(--ease-out);
  text-decoration: none;
}
.btn-primary { background: var(--clay-500); color: #fff; box-shadow: var(--shadow-glow-primary); }
.btn-primary:hover { background: var(--clay-600); transform: translateY(-1px); box-shadow: 0 10px 28px -8px rgba(200,107,74,0.5); }
.btn-primary:active { transform: translateY(0); background: var(--clay-700); }

.btn-secondary { background: #fff; color: var(--fg-1); border-color: var(--border-default); }
.btn-secondary:hover { background: var(--sand-50); border-color: var(--border-strong); }

.btn-ghost { background: transparent; color: var(--fg-2); padding: 10px 14px; }
.btn-ghost:hover { color: var(--fg-1); background: var(--sand-100); }

.btn-dark { background: var(--sand-900); color: #fff; }
.btn-dark:hover { background: var(--sand-800); transform: translateY(-1px); }

.btn-lg { padding: 15px 28px; font-size: 16px; }
.btn-sm { padding: 8px 14px; font-size: 13.5px; }

/* =========================================================================
   SHARED PRIMITIVES
   ========================================================================= */
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  background: var(--clay-50); color: var(--clay-700);
  border-radius: var(--radius-pill);
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
}
.eyebrow.sage { background: var(--clay-50); color: var(--clay-700); }
.eyebrow.sand { background: var(--clay-50); color: var(--clay-700); }
.eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--clay-500); }
.eyebrow.sage .dot { background: var(--clay-500); }
.eyebrow.sand .dot { background: var(--clay-500); }

h1.display, .h-display {
  font-size: clamp(44px, 5.5vw, 72px);
  font-weight: 800; line-height: 1.02;
  letter-spacing: -0.03em;
  color: var(--fg-1);
  margin: 0;
  text-wrap: balance;
}
.h-display em, h1.display em, h2.h-section em {
  font-family: var(--font-display);
  font-style: italic; font-weight: 400;
  color: var(--clay-600);
  letter-spacing: -0.01em;
}

h2.h-section {
  font-size: clamp(34px, 3.6vw, 48px);
  font-weight: 700; line-height: 1.08;
  letter-spacing: -0.025em;
  color: var(--fg-1);
  margin: 0;
  text-wrap: balance;
}

.lede {
  font-size: 19px; line-height: 1.55; color: var(--fg-2);
  text-wrap: pretty; margin: 0;
}

/* =========================================================================
   SECTIONS
   ========================================================================= */
section.block { padding: 112px 0; position: relative; }
section.block.tight { padding: 72px 0; }
section.block.bg-sand { background: var(--sand-100); }
section.block.bg-cream { background: var(--sand-50); }
section.block.bg-sage { background: var(--sage-50); }
section.block.bg-clay { background: var(--clay-50); }
section.block.bg-dark { background: var(--sand-900); color: var(--sand-100); }
section.block.bg-dark h2.h-section, section.block.bg-dark .h-display { color: #fff; }
section.block.bg-dark .lede { color: var(--sand-200); }

.section-head {
  text-align: center;
  max-width: 720px; margin: 0 auto 64px;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.section-head.left { text-align: left; margin: 0 0 64px; align-items: flex-start; }

/* =========================================================================
   FOOTER
   ========================================================================= */
footer.site {
  background: var(--sand-900);
  color: var(--sand-200);
  padding: 80px 0 32px;
  position: relative; z-index: 2;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 56px;
}
.footer-brand .brand { color: #fff; margin-bottom: 16px; }
.footer-brand p { color: var(--sand-300); font-size: 14.5px; line-height: 1.65; margin: 0 0 18px; max-width: 340px; }
.footer-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.footer-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px;
  font-size: 11.5px; font-weight: 600;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--sand-200);
  border-radius: var(--radius-pill);
}
.footer-badge svg { color: var(--sage-300); }

footer.site h4 {
  color: #fff;
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  margin: 0 0 18px;
}
footer.site ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
footer.site ul a {
  color: var(--sand-300); font-size: 14px;
  transition: color var(--dur-fast);
}
footer.site ul a:hover { color: #fff; }

.footer-bottom {
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12.5px; color: var(--sand-400);
  flex-wrap: wrap; gap: 16px;
}
.footer-claim {
  font-family: var(--font-display); font-style: italic;
  color: var(--sand-200); font-size: 14.5px;
}

/* =========================================================================
   MISC UTILITIES
   ========================================================================= */
.check svg { color: var(--sage-600); flex-shrink: 0; }
ul.check-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
ul.check-list li { display: flex; gap: 12px; align-items: start; font-size: 15px; color: var(--fg-2); line-height: 1.5; }
ul.check-list li svg { color: var(--sage-600); margin-top: 3px; flex-shrink: 0; }

.pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: var(--radius-pill);
  font-size: 11.5px; font-weight: 600;
}
.pill-ok { background: var(--success-50); color: var(--success-700); }
.pill-warn { background: var(--warn-50); color: var(--warn-700); }
.pill-info { background: var(--info-50); color: var(--info-700); }
.pill-clay { background: var(--clay-50); color: var(--clay-700); }

/* Avatar */
.avat {
  width: 36px; height: 36px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
  flex-shrink: 0;
}
.avat.xs { width: 26px; height: 26px; font-size: 10px; }
.avat.lg { width: 48px; height: 48px; font-size: 14px; }
.avat.clay { background: var(--clay-100); color: var(--clay-800); }
.avat.sage { background: var(--sage-100); color: var(--sage-800); }
.avat.info { background: var(--info-50); color: var(--info-700); }
.avat.sand { background: var(--sand-200); color: var(--sand-800); }

/* Cards */
.card {
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 28px;
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base);
}
.card.hoverable:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }

/* Breadcrumb page hero */
.page-hero {
  padding: 72px 0 56px;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: ''; position: absolute;
  top: -300px; right: -200px;
  width: 620px; height: 620px;
  background: radial-gradient(circle, var(--clay-100), transparent 70%);
  opacity: 0.55; pointer-events: none;
}
.page-hero::after {
  content: ''; position: absolute;
  bottom: -300px; left: -250px;
  width: 640px; height: 640px;
  background: radial-gradient(circle, var(--sage-100), transparent 70%);
  opacity: 0.5; pointer-events: none;
}
.page-hero-inner { position: relative; z-index: 1; max-width: 820px; }
.page-hero .eyebrow { margin-bottom: 20px; }
.page-hero h1 {
  font-size: clamp(42px, 5vw, 64px);
  font-weight: 800; line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--fg-1);
  margin: 0 0 20px;
  text-wrap: balance;
}
.page-hero h1 em {
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  color: var(--clay-600);
}
.page-hero .lede { max-width: 640px; font-size: 20px; }

.breadcrumb {
  display: flex; gap: 8px; align-items: center;
  font-size: 13px; color: var(--fg-4);
  margin-bottom: 16px;
}
.breadcrumb a { color: var(--fg-3); }
.breadcrumb a:hover { color: var(--fg-1); }
.breadcrumb .sep { opacity: 0.5; }

/* =========================================================================
   TWEAKS PANEL
   ========================================================================= */
#tweaks-panel {
  position: fixed;
  bottom: 24px; right: 24px;
  z-index: 100;
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: 22px 24px;
  width: 380px;
  max-width: calc(100vw - 48px);
  display: none;
  font-size: 13.5px;
}
#tweaks-panel.show { display: block; }
.tw-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; gap: 16px; flex-wrap: wrap; }
.tw-seg { flex-wrap: wrap; }
.tw-title { font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-4); margin-bottom: 14px; }
.tw-row + .tw-row { border-top: 1px solid var(--border-subtle); }
.tw-label { font-weight: 500; color: var(--fg-2); font-size: 13.5px; }
.tw-seg {
  display: inline-flex; background: var(--sand-100);
  border-radius: var(--radius-sm); padding: 2px;
}
.tw-seg button {
  border: none; background: transparent;
  padding: 5px 10px; font-size: 12px; font-weight: 600;
  color: var(--fg-3); border-radius: 4px; cursor: pointer;
  font-family: inherit;
}
.tw-seg button.on { background: #fff; color: var(--fg-1); box-shadow: var(--shadow-xs); }

/* =========================================================================
   TEAL PALETTE OVERRIDE (legacy figma look)
   Applied when document has data-palette="teal".
   Maps clay → teal tokens so every page re-skins without code changes.
   ========================================================================= */
html[data-palette="teal"] {
  --clay-50:  #ECFEFF;
  --clay-100: #CFFAFE;
  --clay-200: #A5F3FC;
  --clay-300: #67E8F9;
  --clay-400: #22D3EE;
  --clay-500: #06B6D4;
  --clay-600: #0891B2;
  --clay-700: #0E7490;
  --clay-800: #155E75;
  --clay-900: #164E63;
  --shadow-glow-primary: 0 8px 24px -8px rgba(6,182,212,0.4);
  --sage-500: #3B82F6;
  --sage-600: #2563EB;

  /* Kühl-minzige Hintergrund-Familie, harmoniert mit Teal/Cyan-Primaries —
     leicht entsättigt, keine Lagoon-Ästhetik, eher nordisches Porzellan */
  --cream-base:     #EEF5F4;   /* Dusty Mint, Haupt-Flächen */
  --sand-50:        #F4F8F7;   /* fast-weißes Mint für bg-cream-Sektionen */
  --sand-100:       #E1ECEB;   /* tiefere Mint-Stufe für Akzent-Sektionen */
  --sand-300:       #B6CCC9;
  --bg-app:         #F7FAF9;   /* Body: kühles Off-White mit Grün-Hauch */
  --bg-elev:        #FFFFFF;   /* Karten bleiben rein-weiß für Kontrast */
  --border-subtle:  #DCE7E5;
  --border-default: #C5D4D2;
}
html[data-palette="teal"] body {
  background: var(--bg-app);
}
html[data-palette="teal"] .hero::before {
  background: radial-gradient(circle, #CFFAFE, transparent 70%);
  opacity: 0.55;
}
html[data-palette="teal"] .hero::after {
  background: radial-gradient(circle, #DBE9FE, transparent 70%);
  opacity: 0.55;
}

/* =========================================================================
   AUBERGINE — Tiefes Aubergine als Primary, gedämpftes Gold als Eyecatcher
   Sophisticated, distinct, vermeidet Konkurrenz-Clichés
   ========================================================================= */
html[data-palette="aubergine"] {
  --clay-50:  #F6F1F8;
  --clay-100: #ECE0F0;
  --clay-200: #D9C2E1;
  --clay-300: #BC9CC9;
  --clay-400: #97719F;
  --clay-500: #6E4F7F;     /* primary */
  --clay-600: #5B3F6B;
  --clay-700: #472F54;
  --clay-800: #34233E;
  --clay-900: #261A2E;
  --shadow-glow-primary: 0 10px 28px -10px rgba(110,79,127,0.45);

  /* Sage → Sage-Plum, ruhiger blasser Grünton der zum Plum harmoniert */
  --sage-50:  #F1F4EE;
  --sage-100: #E2E9DC;
  --sage-200: #C9D5BF;
  --sage-500: #7B9168;
  --sage-600: #647854;
  --sage-700: #4D5D40;

  /* Warmer "Antik-Gold" Highlight für Eyecatcher */
  --info-50:  #FAF4E5;
  --info-500: #C9A961;
  --info-600: #A88845;
  --info-700: #826831;

  /* Neutrals — entsättigtes Mauve-Grey, kein klinisches Weiß */
  --bg-app:         #F9F6F8;
  --bg-elev:        #FFFFFF;
  --cream-base:     #F4EFF2;
  --sand-50:        #F8F4F6;
  --sand-100:       #EDE5EA;
  --sand-200:       #E0D5DC;
  --sand-300:       #C4B5BF;
  --sand-900:       #2A2230;
  --border-subtle:  #E6DCE3;
  --border-default: #CFC0C9;

  --fg-1: #2A2230;
  --fg-2: #4A4150;
  --fg-3: #6E6275;
  --fg-4: #8A8090;
}
html[data-palette="aubergine"] body { background: var(--bg-app); }
html[data-palette="aubergine"] .h-display em,
html[data-palette="aubergine"] h1.display em,
html[data-palette="aubergine"] h2.h-section em,
html[data-palette="aubergine"] .page-hero h1 em {
  color: #A88845;     /* Antik-Gold als Eyecatcher in Headlines */
}
html[data-palette="aubergine"] .eyebrow .dot { background: #6E4F7F; }
html[data-palette="aubergine"] .eyebrow {
  background: #ECE0F0; color: #5B3F6B;
}
html[data-palette="aubergine"] .hero::before {
  background: radial-gradient(circle, #ECE0F0, transparent 70%);
  opacity: 0.6;
}
html[data-palette="aubergine"] .hero::after {
  background: radial-gradient(circle, #FAF4E5, transparent 70%);
  opacity: 0.55;
}

/* =========================================================================
   OCEAN — Kräftiges Tiefblau als Primary, Warm-Orange als Eyecatcher
   Vertrauen + Energie, klassisch-modern für SaaS
   ========================================================================= */
html[data-palette="ocean"] {
  --clay-50:  #EEF3FB;
  --clay-100: #DCE6F5;
  --clay-200: #B5C8E8;
  --clay-300: #85A4D5;
  --clay-400: #4F7BBE;
  --clay-500: #1F4E8C;     /* primary, kräftiges Tiefblau */
  --clay-600: #173E72;
  --clay-700: #112F58;
  --clay-800: #0C2240;
  --clay-900: #08182D;
  --shadow-glow-primary: 0 10px 28px -10px rgba(31,78,140,0.45);

  /* Sage → ruhiges Stahl-Blau, harmoniert mit Ocean ohne zu konkurrieren */
  --sage-50:  #EEF2F6;
  --sage-100: #DCE4EC;
  --sage-200: #C0CED9;
  --sage-500: #5C7A93;
  --sage-600: #486177;
  --sage-700: #364B5C;

  /* Warm-Orange als Akzent — kräftiger, gesättigter Orangeton */
  --info-50:  #FFEDDC;
  --info-500: #EE6A1F;
  --info-600: #D2581A;
  --info-700: #A23F0F;

  /* Neutrals — kühles Off-White mit minimalem Wärme-Hauch */
  --bg-app:         #F6F8FB;
  --bg-elev:        #FFFFFF;
  --cream-base:     #EEF2F8;
  --sand-50:        #F4F7FB;
  --sand-100:       #E7ECF3;
  --sand-200:       #D6DEE9;
  --sand-300:       #B8C3D2;
  --sand-900:       #0F1A2A;
  --border-subtle:  #E0E6EF;
  --border-default: #C5CFDB;

  --fg-1: #0F1A2A;
  --fg-2: #475467;
  --fg-3: #7A8597;
  --fg-4: #A8B2C0;
}
html[data-palette="ocean"] body { background: var(--bg-app); }
html[data-palette="ocean"] .h-display em,
html[data-palette="ocean"] h1.display em,
html[data-palette="ocean"] h2.h-section em,
html[data-palette="ocean"] .page-hero h1 em {
  color: #D2581A;     /* kräftig-warmer Orange-Akzent in Headlines */
}
html[data-palette="ocean"] .eyebrow .dot { background: #1F4E8C; }
html[data-palette="ocean"] .eyebrow {
  background: #DCE6F5; color: #173E72;
}
html[data-palette="ocean"] .hero {
  background: radial-gradient(120% 80% at 80% 20%, #1F4E8C 0%, #112F58 50%, #08182D 100%);
  color: #DCE6F5;
}
html[data-palette="ocean"] .hero h1,
html[data-palette="ocean"] .hero .h-display { color: #FFFFFF; }
html[data-palette="ocean"] .hero .lede { color: #BFCDE0; }
html[data-palette="ocean"] .hero h1 em,
html[data-palette="ocean"] .hero .h-display em {
  color: #FFB680;
}
html[data-palette="ocean"] .hero .eyebrow {
  background: rgba(255,255,255,0.10); color: #DCE6F5;
  backdrop-filter: blur(8px);
}
html[data-palette="ocean"] .hero .eyebrow .dot { background: #EE6A1F; }
html[data-palette="ocean"] .hero .btn-secondary {
  background: rgba(255,255,255,0.10); color: #FFFFFF;
  border-color: rgba(255,255,255,0.25);
}
html[data-palette="ocean"] .hero .btn-secondary:hover {
  background: rgba(255,255,255,0.18);
}
html[data-palette="ocean"] .hero .btn-ghost {
  color: #FFFFFF;
}
html[data-palette="ocean"] .hero .btn-ghost:hover {
  background: rgba(255,255,255,0.10); color: #FFFFFF;
}
html[data-palette="nebula"] .hero .btn-ghost {
  color: #FFFFFF;
}
html[data-palette="nebula"] .hero .btn-ghost:hover {
  background: rgba(255,255,255,0.10); color: #FFFFFF;
}
html[data-palette="ocean"] .hero::before {
  background: radial-gradient(circle, rgba(31,78,140,0.45), transparent 70%);
  opacity: 1;
}
html[data-palette="ocean"] .hero::after {
  background: radial-gradient(circle, rgba(238,106,31,0.30), transparent 70%);
  opacity: 1;
}

/* Page-Hero (Über uns, Services, Sicherheit, Preise, Kontakt) im Ocean-Look:
   gleicher dunkler Verlauf wie auf der Startseite, damit alle Seiten einheitlich wirken */
html[data-palette="ocean"] .page-hero {
  background: radial-gradient(120% 80% at 80% 20%, #1F4E8C 0%, #112F58 50%, #08182D 100%);
  color: #BFCDE0;
}
html[data-palette="ocean"] .page-hero h1 { color: #FFFFFF; }
html[data-palette="ocean"] .page-hero h1 em {
  color: #FFB680;
}
html[data-palette="ocean"] .page-hero .lede,
html[data-palette="ocean"] .page-hero p { color: #BFCDE0; }
html[data-palette="ocean"] .page-hero .eyebrow {
  background: rgba(255,255,255,0.10); color: #DCE6F5;
  backdrop-filter: blur(8px);
}
html[data-palette="ocean"] .page-hero .eyebrow .dot { background: #EE6A1F; }
html[data-palette="ocean"] .page-hero .breadcrumb,
html[data-palette="ocean"] .page-hero .breadcrumb a { color: #97AFCC; }
html[data-palette="ocean"] .page-hero .breadcrumb a:hover { color: #FFFFFF; }

/* CTA-Banner im Ocean-Modus an den dunklen Header-Look angleichen */
html[data-palette="ocean"] .cta-banner {
  background: radial-gradient(120% 80% at 80% 20%, #1F4E8C 0%, #112F58 50%, #08182D 100%);
}
html[data-palette="ocean"] .cta-banner h2 em {
  color: #FFB680;
}
html[data-palette="ocean"] .cta-banner p {
  color: #DCE6F5; opacity: 0.95;
}
html[data-palette="ocean"] .cta-banner h2 {
  color: #FFFFFF;
}

/* Services-Seite CTA-Box: gleicher dunkler Verlauf wie der Page-Hero */
html[data-palette="ocean"] .cta-banner-services {
  background: radial-gradient(120% 80% at 80% 20%, #1F4E8C 0%, #112F58 50%, #08182D 100%) !important;
}
html[data-palette="ocean"] .cta-banner-services h2 em { color: #FFB680 !important; }
html[data-palette="ocean"] .cta-banner-services h2 { color: #FFFFFF !important; }
html[data-palette="ocean"] .cta-banner-services p { color: #DCE6F5 !important; opacity: 0.95 !important; }
html[data-palette="ocean"] .cta-banner-services .btn-primary {
  background: #fff !important; color: #112F58 !important;
}

/* ROI-Rechner-Box: gleicher dunkler Verlauf wie der Page-Header im Ocean-Modus */
html[data-palette="ocean"] .roi {
  background: radial-gradient(120% 80% at 80% 20%, #1F4E8C 0%, #112F58 50%, #08182D 100%) !important;
}
html[data-palette="ocean"] .cta-banner-talk .eyebrow {
  background: rgba(238,106,31,0.18) !important; color: #FFB680 !important;
}
html[data-palette="ocean"] .cta-banner-talk .eyebrow .dot {
  background: #FFB680 !important;
}

/* Sicherheit-Seite Stats-Bar: gleicher dunkler Verlauf wie der Page-Hero */
html[data-palette="ocean"] .stats-bar {
  background: radial-gradient(120% 80% at 80% 20%, #1F4E8C 0%, #112F58 50%, #08182D 100%) !important;
}
html[data-palette="ocean"] .stats-bar .sbar .big em {
  color: #FFB680 !important;
}
html[data-palette="ocean"] .cta-banner .btn-primary {
  background: #fff; color: #112F58;
}
html[data-palette="ocean"] .cta-banner .btn-primary:hover {
  background: #DCE6F5; color: #08182D;
}


/* =========================================================================
   NEBULA — Tiefes Navy/Indigo + Lila + elektrisches Cyan
   Inspiriert von Enterprise-SaaS · dunkle Hero-Flächen, helle Content-Bereiche,
   Verläufe, kräftige Pop-Akzente
   ========================================================================= */
html[data-palette="nebula"] {
  --clay-50:  #EEF2FF;
  --clay-100: #DCE3FE;
  --clay-200: #BFC9FB;
  --clay-300: #97A4F2;
  --clay-400: #6B7BE0;
  --clay-500: #4756C8;
  --clay-600: #3A3FA9;
  --clay-700: #2D2D87;
  --clay-800: #1F1F62;
  --clay-900: #14143F;
  --shadow-glow-primary: 0 12px 32px -10px rgba(71,86,200,0.50);

  /* Sage → kühles Lavendel-Lila als Sekundärfarbe */
  --sage-50:  #F4EFFF;
  --sage-100: #E6DBFF;
  --sage-200: #C9B5FB;
  --sage-500: #8E5BE8;
  --sage-600: #7340D1;
  --sage-700: #582CA8;

  /* Highlight: elektrisches Cyan für Pop-Akzente, sparsam */
  --info-50:  #E0F7FF;
  --info-500: #00B8E6;
  --info-600: #0096C0;
  --info-700: #006E8C;

  --bg-app:         #F7F8FC;
  --bg-elev:        #FFFFFF;
  --cream-base:     #EEF1FB;
  --sand-50:        #F5F6FB;
  --sand-100:       #E8EAF4;
  --sand-200:       #D6DAEB;
  --sand-300:       #B5BAD0;
  --sand-900:       #0F1130;
  --border-subtle:  #E2E5F0;
  --border-default: #C7CCDF;

  --fg-1: #0F1130;
  --fg-2: #4B4E70;
  --fg-3: #7A7E9C;
  --fg-4: #ABAFC4;
}
html[data-palette="nebula"] body { background: var(--bg-app); }

/* Italic em → elektrisches Cyan als Eyecatcher in Headlines */
html[data-palette="nebula"] .h-display em,
html[data-palette="nebula"] h1.display em,
html[data-palette="nebula"] h2.h-section em,
html[data-palette="nebula"] .page-hero h1 em {
  background: linear-gradient(90deg, #4756C8, #8E5BE8 60%, #00B8E6);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
html[data-palette="nebula"] .eyebrow .dot { background: #4756C8; }
html[data-palette="nebula"] .eyebrow {
  background: #DCE3FE; color: #2D2D87;
}
/* Hero-Hintergrund: dunkle Navy-Lila-Fläche mit Verlauf, weißer Text */
html[data-palette="nebula"] .hero {
  background: radial-gradient(120% 80% at 80% 20%, #2D2D87 0%, #1F1F62 45%, #14143F 100%);
  color: #E2E5F0;
}
html[data-palette="nebula"] .hero h1,
html[data-palette="nebula"] .hero .h-display { color: #FFFFFF; }
html[data-palette="nebula"] .hero .lede { color: #C9CDE8; }
html[data-palette="nebula"] .hero::before {
  background: radial-gradient(circle, rgba(142,91,232,0.45), transparent 70%);
  opacity: 1;
}
html[data-palette="nebula"] .hero::after {
  background: radial-gradient(circle, rgba(0,184,230,0.35), transparent 70%);
  opacity: 1;
}
html[data-palette="nebula"] .hero .eyebrow {
  background: rgba(255,255,255,0.10); color: #DCE3FE;
  backdrop-filter: blur(8px);
}
html[data-palette="nebula"] .hero .eyebrow .dot { background: #00B8E6; }
html[data-palette="nebula"] .hero .btn-secondary {
  background: rgba(255,255,255,0.10); color: #FFFFFF;
  border-color: rgba(255,255,255,0.25);
}
html[data-palette="nebula"] .hero .btn-secondary:hover {
  background: rgba(255,255,255,0.18);
}

/* Page-Hero (Über uns, Services, etc.) ebenfalls dunkel */
html[data-palette="nebula"] .page-hero {
  background: radial-gradient(120% 80% at 80% 20%, #2D2D87 0%, #1F1F62 50%, #14143F 100%);
  color: #C9CDE8;
}
html[data-palette="nebula"] .page-hero h1 { color: #FFFFFF; }
html[data-palette="nebula"] .page-hero h1 em {
  background: linear-gradient(90deg, #97A4F2, #C9B5FB 50%, #00B8E6);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
html[data-palette="nebula"] .page-hero .lede,
html[data-palette="nebula"] .page-hero p { color: #C9CDE8; }
html[data-palette="nebula"] .page-hero .breadcrumb,
html[data-palette="nebula"] .page-hero .breadcrumb a { color: #97A4F2; }

/* Primary-Button mit Verlauf für extra Pop */
html[data-palette="nebula"] .btn-primary {
  background: linear-gradient(135deg, #4756C8, #7340D1);
}
html[data-palette="nebula"] .btn-primary:hover {
  background: linear-gradient(135deg, #3A3FA9, #582CA8);
}

/* Brand-Glyph in der dunklen Hero-Nav: weiß statt Primary */
html[data-palette="nebula"] nav.top { background: rgba(255,255,255,0.92); backdrop-filter: blur(12px); }
