/* ============================================================
   Light & Living — Stylesheet
   Aufbau:
   1.  Design Tokens (RunDigi Farbsystem, Typografie, Abstände)
   2.  Reset & Basis
   3.  Layout-Hilfsklassen
   4.  Buttons
   5.  Header
   6.  Hero (Produkt-Fokus)
   7.  Kategorien-Grid
   8.  Produkte-Grid
   9.  USP-Sektion
   10. Beratungs-CTA
   11. Footer
   12. Chat-Launcher Button
   13. Overlay-Backdrop
   14. Modal-System (Basis)
   15. Modal 1: Auswahl-Karten
   16. Modal 2: Rückruf-Formular
   17. Modal 3: Bestätigung
   18. n8n Chat-Widget Anpassungen
   ============================================================ */


/* ──────────────────────────────────────────────────────────
   1. DESIGN TOKENS
   ────────────────────────────────────────────────────────── */
:root {
  /* Markenfarben – Grün */
  --green-900: #44641F;
  --green-700: #688F38;
  --green-600: #6F9A3E;
  --green-500: #7CA64C;
  --green-400: #93B86A;
  --green-300: #B0CC8E;
  --green-200: #D2E2BE;
  --green-100: #EDF3E2;
  --green-050: #F6F9EF;

  /* Tintenfarben */
  --ink-900: #182230;
  --ink-800: #1E2A38;
  --ink-700: #2C3A4B;
  --ink-600: #3A4654;
  --ink-500: #54616F;

  /* Schiefergrau */
  --slate-500: #7D8A99;
  --slate-400: #98A4B1;
  --slate-300: #B9C2CC;
  --slate-200: #D6DDE4;
  --slate-100: #E8ECF1;

  /* Akzent – Ziegelrot (Lucide-Icons, Eyebrows) */
  --accent-600: #A23529;

  /* Flächen */
  --white:        #FFFFFF;
  --surface-alt:  #EAF0F5;
  --surface-tint: #F4F7FA;

  /* Rahmen */
  --border:       #E2E8EE;
  --border-green: #CADBB0;

  /* Status */
  --success:    #4F9D5D;
  --success-bg: #E7F3EA;
  --danger:     #C9503E;
  --danger-bg:  #FBEAE7;
  --warning:    #D9933B;

  /* Semantische Aliase */
  --brand:          var(--green-500);
  --brand-hover:    var(--green-600);
  --brand-active:   var(--green-700);
  --brand-tint:     var(--green-100);
  --brand-contrast: #FFFFFF;

  --text-strong: var(--ink-800);
  --text-body:   var(--ink-600);
  --text-muted:  var(--slate-500);
  --text-link:   var(--green-700);

  --bg-page:    var(--white);
  --bg-section: var(--surface-alt);
  --bg-footer:  var(--ink-900);

  --focus-ring: color-mix(in srgb, var(--green-500) 55%, transparent);

  /* Typografie */
  --font: system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  --fw-regular:   400;
  --fw-medium:    500;
  --fw-semibold:  600;
  --fw-bold:      700;
  --fw-extrabold: 800;

  --fs-display: clamp(2.25rem, 5vw, 3.5rem);
  --fs-h1:      clamp(1.75rem, 4vw, 2.75rem);
  --fs-h2:      clamp(1.4rem,  3vw, 2rem);
  --fs-h3:      1.25rem;
  --fs-lead:    1.125rem;
  --fs-body:    1rem;
  --fs-sm:      0.875rem;
  --fs-xs:      0.75rem;

  --lh-tight:   1.12;
  --lh-snug:    1.3;
  --lh-normal:  1.5;
  --lh-relaxed: 1.65;

  --ls-tight:  -0.02em;
  --ls-eyebrow: 0.1em;

  /* Abstände (4px-Raster) */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.5rem;
  --sp-6: 2rem;
  --sp-7: 3rem;
  --sp-8: 4rem;
  --sp-9: 6rem;

  /* Layout */
  --content-max:    1180px;
  --content-narrow: 760px;
  --gutter:         clamp(1.25rem, 4vw, 2.5rem);
  --section-pad-y:  clamp(3.5rem, 7vw, 6rem);

  /* Eckenradien */
  --radius-xs:   4px;
  --radius-sm:   6px;
  --radius-md:   10px;
  --radius-lg:   14px;
  --radius-xl:   20px;
  --radius-pill: 999px;

  /* Schatten */
  --shadow-xs:    0 1px 2px rgba(24, 34, 48, 0.06);
  --shadow-sm:    0 2px 8px rgba(24, 34, 48, 0.06);
  --shadow-md:    0 6px 20px rgba(24, 34, 48, 0.09);
  --shadow-lg:    0 14px 40px rgba(24, 34, 48, 0.12);
  --shadow-brand: 0 8px 24px rgba(124, 166, 76, 0.28);

  /* Bewegung */
  --ease-out:    cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --dur-fast: 130ms;
  --dur-base: 220ms;
  --dur-slow: 360ms;

  /* Z-Ebenen */
  --z-header:   100;
  --z-overlay:  800;
  --z-modal:    900;
  --z-launcher: 950;
}


/* ──────────────────────────────────────────────────────────
   2. RESET & BASIS
   ────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

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

body {
  font-family: var(--font);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--text-body);
  background: var(--bg-page);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  color: var(--text-strong);
  text-wrap: balance;
}

h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); letter-spacing: 0; }
h4 { font-size: 1rem; letter-spacing: 0; }

p { text-wrap: pretty; }

a { color: var(--text-link); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; display: block; }

button { cursor: pointer; border: none; background: none; font: inherit; }

input, textarea { font: inherit; color: var(--text-body); }

:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
  border-radius: var(--radius-xs);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}


/* ──────────────────────────────────────────────────────────
   3. LAYOUT-HILFSKLASSEN
   ────────────────────────────────────────────────────────── */
.rd-container {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.eyebrow {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--accent-600);
  margin-bottom: var(--sp-3);
}

.section-title {
  font-size: var(--fs-h2);
  font-weight: var(--fw-extrabold);
  color: var(--brand);
  text-align: center;
  margin-bottom: var(--sp-7);
}


/* ──────────────────────────────────────────────────────────
   4. BUTTONS
   ────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 0.6em 1.4em;
  border-radius: var(--radius-pill);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-body);
  white-space: nowrap;
  transition:
    background var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out),
    transform  var(--dur-fast) var(--ease-out);
}

.btn:active { transform: scale(0.97); }

.btn-primary {
  background: var(--brand);
  color: var(--brand-contrast);
  box-shadow: var(--shadow-brand);
}
.btn-primary:hover {
  background: var(--brand-hover);
  box-shadow: 0 10px 28px rgba(124, 166, 76, 0.38);
  text-decoration: none;
}

.btn-ghost {
  background: transparent;
  color: var(--text-strong);
  box-shadow: inset 0 0 0 1.5px var(--border);
}
.btn-ghost:hover {
  background: var(--surface-tint);
  box-shadow: inset 0 0 0 1.5px var(--slate-300);
  text-decoration: none;
}

/* Inverse für dunkle Hintergründe */
.btn-inverse {
  background: var(--white);
  color: var(--brand);
  box-shadow: var(--shadow-md);
}
.btn-inverse:hover { background: var(--green-050); text-decoration: none; }

.btn-sm   { font-size: var(--fs-sm); padding: 0.45em 1.1em; }
.btn-lg   { font-size: 1.0625rem;    padding: 0.75em 1.75em; }
.btn-full { width: 100%; }


/* ──────────────────────────────────────────────────────────
   5. HEADER
   ────────────────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 4rem;
  gap: var(--sp-5);
}

.logo {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  text-decoration: none;
}

.logo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5px;
  width: 26px;
  flex-shrink: 0;
}
.logo-grid i {
  display: block;
  aspect-ratio: 1;
  border-radius: 2px;
  background: var(--slate-300);
}
.logo-grid i:nth-child(1) { background: var(--green-500); }
.logo-grid i:nth-child(5) { background: var(--ink-800); }
.logo-grid i:nth-child(7) { background: var(--ink-800); }
.logo-grid i:nth-child(9) { background: var(--green-500); }

.logo-text {
  font-size: 1.125rem;
  font-weight: var(--fw-extrabold);
  color: var(--ink-800);
  letter-spacing: var(--ls-tight);
}
.logo-text em { color: var(--brand); font-style: normal; }
.logo-text--light { color: var(--white); }
.logo-text--light em { color: var(--green-300); }

.main-nav {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
}
.main-nav a {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--text-body);
}
.main-nav a:hover { color: var(--brand); text-decoration: none; }

@media (max-width: 600px) {
  .main-nav a:not(.btn) { display: none; }
}


/* ──────────────────────────────────────────────────────────
   6. HERO — Produkt-Fokus
   ────────────────────────────────────────────────────────── */
.hero {
  padding-block: var(--section-pad-y);
  background: linear-gradient(155deg, var(--green-050) 0%, var(--white) 55%);
  overflow: hidden;
}

.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-8);
  align-items: center;
}

@media (max-width: 800px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
}

.hero-content { max-width: 560px; }
.hero-content .eyebrow { color: var(--accent-600); }
.hero h1 { margin-bottom: var(--sp-4); }

.hero-lead {
  font-size: var(--fs-lead);
  color: var(--text-body);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--sp-6);
}

.hero-actions {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

/* Lampen-Illustration */
.hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero-lamp-scene {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-5);
}

.lamp-svg {
  width: 160px;
  height: 210px;
  filter: drop-shadow(0 12px 32px rgba(124, 166, 76, 0.2));
}

.hero-badge-row {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  justify-content: center;
}

.hero-badge {
  display: inline-block;
  padding: 0.3em 0.9em;
  border-radius: var(--radius-pill);
  background: var(--white);
  border: 1.5px solid var(--border-green);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--green-700);
  box-shadow: var(--shadow-xs);
}


/* ──────────────────────────────────────────────────────────
   7. KATEGORIEN-GRID
   ────────────────────────────────────────────────────────── */
.kategorien {
  padding-block: var(--section-pad-y);
  background: var(--bg-section);
}

.kategorien-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}

@media (max-width: 900px) {
  .kategorien-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .kategorien-grid { grid-template-columns: 1fr; }
}

.kategorie-card {
  position: relative;
  border-radius: var(--radius-lg);
  padding: 0;
  overflow: hidden;
  cursor: pointer;
  transition:
    transform  var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
}

.kategorie-img {
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.kategorie-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--dur-base) var(--ease-out);
}
.kategorie-card:hover .kategorie-img img { transform: scale(1.05); }
.kategorie-card--dark  .kategorie-img { background: linear-gradient(160deg,#1E2A38,#2C3A4B); }
.kategorie-card--light .kategorie-img { background: linear-gradient(160deg,#EAF0F5,#D6DDE4); }
.kategorie-card--green .kategorie-img { background: linear-gradient(160deg,#2a4a1a,#44641F); }
.kategorie-card--brand .kategorie-img { background: linear-gradient(160deg,#7CA64C,#6F9A3E); }

.kategorie-body {
  padding: var(--sp-5) var(--sp-5) var(--sp-6);
}
.kategorie-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.kategorie-card--dark  { background: var(--ink-800); }
.kategorie-card--light { background: var(--white); border: 1.5px solid var(--border); }
.kategorie-card--green { background: var(--green-900); }
.kategorie-card--brand { background: var(--brand); }

.kategorie-icon {
  margin-bottom: var(--sp-4);
  line-height: 1;
}
.kategorie-icon svg {
  width: 2rem;
  height: 2rem;
  stroke-width: 1.5;
}

.kategorie-card--dark  .kategorie-icon svg { stroke: var(--green-300); }
.kategorie-card--light .kategorie-icon svg { stroke: var(--accent-600); }
.kategorie-card--green .kategorie-icon svg { stroke: var(--green-200); }
.kategorie-card--brand .kategorie-icon svg { stroke: var(--white); }

.kategorie-info h3 {
  font-size: 1.0625rem;
  margin-bottom: var(--sp-1);
  font-weight: var(--fw-bold);
}

.kategorie-card--dark  .kategorie-info h3 { color: var(--white); }
.kategorie-card--light .kategorie-info h3 { color: var(--ink-800); }
.kategorie-card--green .kategorie-info h3 { color: var(--white); }
.kategorie-card--brand .kategorie-info h3 { color: var(--white); }

.kategorie-info p {
  font-size: var(--fs-xs);
  margin-bottom: var(--sp-4);
}
.kategorie-card--dark  .kategorie-info p { color: var(--slate-400); }
.kategorie-card--light .kategorie-info p { color: var(--text-muted); }
.kategorie-card--green .kategorie-info p { color: var(--green-300); }
.kategorie-card--brand .kategorie-info p { color: rgba(255,255,255,0.75); }

.kategorie-link {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
}
.kategorie-card--dark  .kategorie-link { color: var(--green-400); }
.kategorie-card--light .kategorie-link { color: var(--brand); }
.kategorie-card--green .kategorie-link { color: var(--green-200); }
.kategorie-card--brand .kategorie-link { color: var(--white); }


/* ──────────────────────────────────────────────────────────
   8. PRODUKTE-GRID
   ────────────────────────────────────────────────────────── */
.produkte {
  padding-block: var(--section-pad-y);
}

.produkte-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}

@media (max-width: 900px) {
  .produkte-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .produkte-grid { grid-template-columns: 1fr; }
}

.produkt-card {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition:
    box-shadow var(--dur-base) var(--ease-out),
    transform  var(--dur-base) var(--ease-out),
    border-color var(--dur-base);
}
.produkt-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
  border-color: var(--border-green);
}

/* Produkt-Bild-Platzhalter */
.produkt-visual {
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.produkt-visual svg {
  width: 3.5rem;
  height: 3.5rem;
  stroke-width: 1.5;
  opacity: 0.8;
}

.produkt-visual--pendant { background: linear-gradient(160deg, var(--ink-800), var(--ink-700)); }
.produkt-visual--pendant svg { stroke: var(--green-300); }

.produkt-visual--desk { background: linear-gradient(160deg, var(--surface-alt), var(--slate-100)); }
.produkt-visual--desk svg { stroke: var(--accent-600); }

.produkt-visual--floor { background: linear-gradient(160deg, var(--green-900), var(--green-700)); }
.produkt-visual--floor svg { stroke: var(--green-200); }

.produkt-visual--led { background: linear-gradient(160deg, var(--ink-700), #1a3a2a); }
.produkt-visual--led svg { stroke: var(--green-400); }

.produkt-visual--smart { background: linear-gradient(160deg, var(--brand), var(--green-600)); }
.produkt-visual--smart svg { stroke: var(--white); }

.produkt-visual--wall { background: linear-gradient(160deg, var(--surface-alt), var(--white)); }
.produkt-visual--wall svg { stroke: var(--ink-600); }

.produkt-info {
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
}

.produkt-kategorie {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent-600);
  margin-bottom: var(--sp-1);
}

.produkt-info h3 {
  font-size: 1.0625rem;
  color: var(--ink-800);
  margin-bottom: var(--sp-1);
}

.produkt-variante {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  margin-bottom: var(--sp-4);
}

.produkt-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

.produkt-preis {
  font-size: 1.125rem;
  font-weight: var(--fw-bold);
  color: var(--ink-800);
}

.produkt-bestand {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  padding: 0.25em 0.7em;
  border-radius: var(--radius-pill);
}
.produkt-bestand--ok {
  background: var(--success-bg);
  color: var(--success);
}
.bestand-icon {
  width: 12px;
  height: 12px;
  stroke-width: 2.5;
  vertical-align: middle;
}


/* ──────────────────────────────────────────────────────────
   9. USP-SEKTION
   ────────────────────────────────────────────────────────── */
.usp-section {
  background: var(--bg-section);
  padding-block: var(--section-pad-y);
}

.usp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-6);
}

@media (max-width: 900px) {
  .usp-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .usp-grid { grid-template-columns: 1fr; }
}

.usp-item {
  display: flex;
  gap: var(--sp-4);
  align-items: flex-start;
}

.usp-icon {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-md);
  background: var(--white);
  border: 1.5px solid var(--border-green);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-xs);
}
.usp-icon svg {
  width: 1.125rem;
  height: 1.125rem;
  stroke: var(--accent-600);
  stroke-width: 2;
}

.usp-item h4 {
  font-size: 0.9375rem;
  font-weight: var(--fw-bold);
  color: var(--ink-800);
  margin-bottom: var(--sp-1);
  letter-spacing: 0;
}
.usp-item p {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  line-height: var(--lh-relaxed);
}


/* ──────────────────────────────────────────────────────────
   10. BERATUNGS-CTA
   ────────────────────────────────────────────────────────── */
.beratung-cta {
  background: var(--ink-800);
  padding-block: var(--sp-9);
}

.beratung-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-8);
  align-items: center;
}

@media (max-width: 700px) {
  .beratung-inner { grid-template-columns: 1fr; text-align: center; }
  .beratung-actions { align-items: center; }
}

.beratung-text .eyebrow { color: var(--green-300); }

.beratung-text h2 {
  color: var(--white);
  font-size: var(--fs-h2);
  margin-bottom: var(--sp-3);
}
.beratung-text p {
  color: var(--slate-300);
  font-size: var(--fs-lead);
  line-height: var(--lh-relaxed);
  max-width: 560px;
}

.beratung-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-3);
  flex-shrink: 0;
}

.beratung-hint {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-xs);
  color: var(--slate-400);
}

.hint-icon {
  width: 14px;
  height: 14px;
  stroke: var(--slate-400);
  stroke-width: 2;
}


/* ──────────────────────────────────────────────────────────
   11. FOOTER
   ────────────────────────────────────────────────────────── */
.site-footer {
  background: var(--bg-footer);
  padding-block: var(--sp-7);
}

.footer-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--sp-6);
}

.footer-brand { flex: 1; min-width: 200px; }
.footer-brand p {
  color: var(--slate-400);
  font-size: var(--fs-sm);
  margin-top: var(--sp-2);
  line-height: var(--lh-relaxed);
}

.footer-nav { display: flex; gap: var(--sp-5); flex-wrap: wrap; }
.footer-nav a { color: var(--slate-300); font-size: var(--fs-sm); }
.footer-nav a:hover { color: var(--white); text-decoration: none; }

.footer-credit {
  width: 100%;
  text-align: right;
  color: var(--slate-500);
  font-size: var(--fs-xs);
  border-top: 1px solid var(--ink-700);
  padding-top: var(--sp-4);
  margin-top: var(--sp-2);
}
.footer-credit strong { color: var(--brand); }


/* ──────────────────────────────────────────────────────────
   12. CHAT-LAUNCHER BUTTON
   ────────────────────────────────────────────────────────── */
.chat-launcher {
  position: fixed;
  bottom: 1.75rem;
  right: 1.75rem;
  z-index: var(--z-launcher);
  width: 3.5rem;
  height: 3.5rem;
  border-radius: var(--radius-pill);
  background: var(--brand);
  color: var(--white);
  box-shadow: var(--shadow-brand), var(--shadow-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    background var(--dur-fast) var(--ease-out),
    transform  var(--dur-fast) var(--ease-spring),
    box-shadow var(--dur-fast) var(--ease-out);
}
.chat-launcher:hover {
  background: var(--brand-hover);
  transform: scale(1.08);
  box-shadow: 0 10px 30px rgba(124, 166, 76, 0.4), var(--shadow-lg);
}
.chat-launcher:active { transform: scale(0.95); }

.launcher-icon {
  width: 1.5rem;
  height: 1.5rem;
  transition: opacity var(--dur-fast), transform var(--dur-fast) var(--ease-out);
  position: absolute;
}
.launcher-icon--open  { opacity: 1;  transform: rotate(0deg)   scale(1); }
.launcher-icon--close { opacity: 0;  transform: rotate(-90deg) scale(0.5); }

.chat-launcher[aria-expanded="true"] .launcher-icon--open  { opacity: 0; transform: rotate(90deg) scale(0.5); }
.chat-launcher[aria-expanded="true"] .launcher-icon--close { opacity: 1; transform: rotate(0deg) scale(1); }

.launcher-pulse {
  position: absolute;
  top: -3px;
  right: -3px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--success);
  border: 2px solid var(--white);
  animation: pulse 2s ease infinite;
}

@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%       { transform: scale(1.25); opacity: 0.7; }
}

.chat-launcher[aria-expanded="true"] .launcher-pulse { display: none; }


/* ──────────────────────────────────────────────────────────
   13. OVERLAY-BACKDROP
   ────────────────────────────────────────────────────────── */
.overlay-backdrop {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  background: rgba(24, 34, 48, 0.55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-base) var(--ease-out);
}
.overlay-backdrop.is-visible { opacity: 1; pointer-events: auto; }


/* ──────────────────────────────────────────────────────────
   14. MODAL-BASIS
   ────────────────────────────────────────────────────────── */
.modal {
  position: fixed;
  bottom: calc(1.75rem + 3.5rem + 1rem);
  right: 1.75rem;
  z-index: var(--z-modal);
  width: min(26rem, calc(100vw - 2 * 1.75rem));
  max-height: calc(100vh - 8rem);
  overflow-y: auto;
  overscroll-behavior: contain;
  background: var(--white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px) scale(0.97);
  transition:
    opacity   var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out);
}
.modal.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0) scale(1); }

.modal-header {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  border-bottom: 1px solid var(--border);
}
.modal-header .eyebrow { margin-bottom: var(--sp-1); }
.modal-header h2 { flex: 1; font-size: 1.125rem; margin: 0; }

.modal-close {
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  flex-shrink: 0;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.modal-close svg { width: 1rem; height: 1rem; }
.modal-close:hover { background: var(--slate-100); color: var(--text-strong); }

.modal-back {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--text-muted);
  padding: var(--sp-1) 0;
  transition: color var(--dur-fast);
  flex-shrink: 0;
}
.modal-back:hover { color: var(--brand); }


/* ──────────────────────────────────────────────────────────
   15. MODAL 1 — AUSWAHL-KARTEN
   ────────────────────────────────────────────────────────── */
.choice-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
  padding: var(--sp-5);
}

@media (max-width: 480px) {
  .choice-cards { grid-template-columns: 1fr; }
}

.choice-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-2);
  padding: var(--sp-5) var(--sp-4);
  border-radius: var(--radius-lg);
  border: 1.5px solid var(--border);
  background: var(--surface-tint);
  text-align: left;
  transition:
    border-color var(--dur-fast),
    box-shadow  var(--dur-fast),
    transform   var(--dur-fast) var(--ease-out),
    background  var(--dur-fast);
}
.choice-card:hover {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px var(--green-100), var(--shadow-sm);
  background: var(--white);
  transform: translateY(-2px);
}
.choice-card:active { transform: scale(0.98); }

.choice-icon { font-size: 2rem; line-height: 1; }
.choice-card h3 { font-size: 0.9375rem; color: var(--text-strong); margin: 0; letter-spacing: 0; }
.choice-card p  { font-size: var(--fs-xs); color: var(--text-muted); line-height: var(--lh-normal); margin: 0; }
.choice-cta {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--brand);
  margin-top: auto;
  padding-top: var(--sp-2);
}

.choice-disclaimer {
  margin: 0 var(--sp-5) var(--sp-5);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--border);
  font-size: var(--fs-xs);
  color: var(--text-muted);
  line-height: var(--lh-normal);
  text-align: center;
}
.choice-disclaimer a { color: var(--text-muted); text-decoration: underline; }
.choice-disclaimer a:hover { color: var(--brand); }


/* ──────────────────────────────────────────────────────────
   16. MODAL 2 — RÜCKRUF-FORMULAR
   ────────────────────────────────────────────────────────── */
.callback-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  padding: var(--sp-5);
}

.form-group { display: flex; flex-direction: column; gap: var(--sp-2); }

.form-group label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--text-strong);
}

.required { color: var(--danger); margin-left: 2px; }

.form-optional {
  font-weight: var(--fw-regular);
  color: var(--text-muted);
  font-size: var(--fs-xs);
}

.form-group input,
.form-group textarea {
  width: 100%;
  padding: 0.6em 0.875em;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--white);
  font-size: var(--fs-sm);
  line-height: var(--lh-normal);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--slate-400); }
.form-group input:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px var(--green-100);
}

.form-group textarea { resize: vertical; min-height: 5rem; }

.form-error {
  font-size: var(--fs-xs);
  color: var(--danger);
  font-weight: var(--fw-medium);
}

.btn-spinner {
  display: none;
  width: 1em;
  height: 1em;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: var(--white);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}
.btn-spinner:not([hidden]) {
  display: inline-block;
}

@keyframes spin { to { transform: rotate(360deg); } }


/* ──────────────────────────────────────────────────────────
   17. MODAL 3 — BESTÄTIGUNG
   ────────────────────────────────────────────────────────── */
.modal--confirm .modal-header {
  justify-content: flex-end;
  border-bottom: none;
  padding-bottom: 0;
}

.confirm-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--sp-4) var(--sp-6) var(--sp-7);
  gap: var(--sp-4);
}

.confirm-icon {
  font-size: 3rem;
  line-height: 1;
  animation: popIn 0.4s var(--ease-spring) both;
}

@keyframes popIn {
  from { transform: scale(0.4); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}

.confirm-body h2 { font-size: 1.25rem; color: var(--text-strong); }
.confirm-body p  { font-size: var(--fs-sm); color: var(--text-body); line-height: var(--lh-relaxed); }


/* ──────────────────────────────────────────────────────────
   18. N8N CHAT-WIDGET ANPASSUNGEN
   Basis-Tokens: werden vom n8n-Widget nativ ausgewertet.
   Feinere Overrides + injizierte Controls: app.js (initChatWidget)
   ────────────────────────────────────────────────────────── */
:root {
  /* Primärfarbe / Schaltflächen */
  --chat--color-primary:           var(--green-500);
  --chat--color-primary-shade-50:  var(--green-400);
  --chat--color-primary-shade-100: var(--green-600);
  --chat--color-secondary:         var(--ink-800);

  /* Hintergrund & Schrift */
  --chat--color-background: var(--white);
  --chat--color-font:        var(--ink-600);

  /* Header (neuere n8n-Versionen) */
  --chat--header--background: #1E2A38;
  --chat--header--color:      #ffffff;

  /* Nachrichten-Bubbles */
  --chat--message-bot-background:  var(--green-050);
  --chat--message-user-background: var(--green-500);
  --chat--message-user-color:      var(--white);
  --chat--message--border-radius:  12px;

  /* Eingabefeld */
  --chat--input--border-color:  #e2e8ee;
  --chat--input--background:    #ffffff;

  /* Fenster-Geometrie */
  --chat--window--width:  400px;
  --chat--window--height: 590px;
  --chat--border-radius-bottom-left:  var(--radius-xl);
  --chat--border-radius-bottom-right: var(--radius-xl);
}


/* ──────────────────────────────────────────────────────────
   19. USP-CHECK BADGE (grüner Haken)
   ────────────────────────────────────────────────────────── */
.usp-check {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  background: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-xs);
}
.usp-check svg {
  width: 1rem;
  height: 1rem;
  stroke: var(--white);
  stroke-width: 2.5;
}

/* Kategorie-Karten als Links */
a.kategorie-card {
  display: block;
  text-decoration: none;
}

/* Produkt-Seiten Breadcrumb */
.breadcrumb {
  padding: var(--sp-4) 0 var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.breadcrumb a { color: var(--text-muted); }
.breadcrumb a:hover { color: var(--brand); text-decoration: none; }
.breadcrumb-sep { color: var(--slate-300); }

/* IP-Schutz Badge */
.produkt-ip-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  padding: 0.2em 0.65em;
  border-radius: var(--radius-pill);
  background: var(--brand-tint);
  color: var(--green-700);
  border: 1px solid var(--border-green);
  margin-bottom: var(--sp-1);
}

/* Produkt-Seiten spezifisch */
.page-hero {
  background: linear-gradient(155deg, var(--green-050) 0%, var(--white) 60%);
  padding-block: var(--sp-8) var(--sp-6);
  border-bottom: 1px solid var(--border);
}
.page-hero-inner { max-width: var(--content-max); margin-inline: auto; padding-inline: var(--gutter); }
.page-hero h1 { font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: var(--sp-2); }
.page-hero p { color: var(--text-muted); font-size: var(--fs-lead); }


/* ──────────────────────────────────────────────────────────
   19. PRODUKT-BILDER & NEUE ELEMENTE (v2)
   ────────────────────────────────────────────────────────── */

/* Hero Rabatt-Badge */
.hero-rabatt-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  margin-top: var(--sp-5);
  padding: var(--sp-2) var(--sp-4);
  background: var(--green-100);
  border: 1.5px solid var(--border-green);
  border-radius: var(--radius-pill);
  font-size: var(--fs-sm);
  color: var(--green-700);
}
.rabatt-icon { font-size: 1.1em; }

/* Section Lead Text */
.section-lead {
  text-align: center;
  color: var(--text-muted);
  font-size: var(--fs-sm);
  margin-top: calc(-1 * var(--sp-3));
  margin-bottom: var(--sp-8);
}

/* Produktbild-Wrapper (ersetzt .produkt-visual) */
.produkt-img-wrap {
  width: 100%;
  height: 320px;
  min-height: 320px;
  max-height: 320px;
  flex-shrink: 0;
  overflow: hidden;
  background: var(--surface-alt);
  position: relative;
  display: block;
}

.produkt-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform 0.35s var(--ease-out);
}
.produkt-card:hover .produkt-img {
  transform: scale(1.04);
}

/* Fallback wenn kein Bild vorhanden */
.produkt-img-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(160deg, var(--surface-alt), var(--slate-100));
}
.produkt-img-fallback svg {
  width: 3.5rem;
  height: 3.5rem;
  stroke: var(--slate-400);
  stroke-width: 1.5;
}

/* Produkt-Merkmale (gemeinsame Eigenschaften) */
.produkt-merkmale {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  margin-bottom: var(--sp-1);
}

/* Produkt-Varianten */
.produkt-varianten {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  margin-bottom: var(--sp-4);
}
.produkt-varianten span {
  color: var(--ink-600);
  font-weight: var(--fw-medium);
}

/* Rabatt-Banner unter Produkten */
.rabatt-banner {
  margin-top: var(--sp-10);
  padding: var(--sp-6) var(--sp-8);
  background: linear-gradient(135deg, var(--green-900), var(--green-700));
  border-radius: var(--radius-xl);
  display: flex;
  align-items: center;
  gap: var(--sp-6);
  flex-wrap: wrap;
  color: var(--white);
}
.rabatt-tag {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  background: rgba(255,255,255,0.15);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-pill);
  white-space: nowrap;
}
.rabatt-banner p {
  flex: 1;
  font-size: var(--fs-sm);
  color: var(--green-100);
  margin: 0;
}
.rabatt-banner strong { color: var(--white); }
.rabatt-banner .btn {
  white-space: nowrap;
  background: var(--white);
  color: var(--green-800, var(--green-900));
}
.rabatt-banner .btn:hover {
  background: var(--green-100);
}

@media (max-width: 600px) {
  .rabatt-banner {
    flex-direction: column;
    text-align: center;
    padding: var(--sp-5) var(--sp-5);
  }
  .rabatt-banner p { flex: none; }
  .hero-rabatt-badge { font-size: 0.8rem; }
}


/* ──────────────────────────────────────────────────────────
   19. RECHTLICHE SEITEN (AGB, DATENSCHUTZ)
   ────────────────────────────────────────────────────────── */
.legal-content {
  max-width: var(--content-narrow);
  margin-inline: auto;
  padding-block: var(--sp-8);
  padding-inline: var(--gutter);
}
.legal-content h2 {
  font-size: 1.25rem;
  color: var(--brand);
  margin-top: var(--sp-8);
  margin-bottom: var(--sp-3);
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content p, .legal-content li {
  color: var(--text-body);
  line-height: var(--lh-loose, 1.75);
  margin-bottom: var(--sp-3);
}
.legal-content ul { padding-left: var(--sp-5); }
.legal-content strong { color: var(--text-strong); }
.legal-content .legal-updated {
  color: var(--text-muted);
  font-size: var(--fs-sm);
  margin-bottom: var(--sp-6);
}
