/* style.css */

/* ══════════════════════════════════════════════════════
   1. RESET  (Josh W. Comeau)
   ══════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; }
*:not(dialog)          { margin: 0; }
*                      { user-select: none; -webkit-user-select: none; }
[hidden]               { display: none !important; }

input, textarea, [contenteditable] { user-select: text; -webkit-user-select: text; }

@media (prefers-reduced-motion: no-preference) {
  html { interpolate-size: allow-keywords; }
}

html {
  overflow-x: clip;
  overscroll-behavior: none;
}

body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  max-width: 100vw;
  max-width: 100dvw;
  touch-action: pan-y;           /* NUR vertikal — horizontales Wischen komplett blockiert */
}


img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select { font: inherit; }

button, input, select, textarea, a, label { touch-action: manipulation; }

p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }

p                          { text-wrap: pretty; }
h1, h2, h3, h4, h5, h6    { text-wrap: balance; }

#root, #__next             { isolation: isolate; }

table                      { border-collapse: collapse; }


/* ══════════════════════════════════════════════════════
   1a. ACCESSIBILITY — Skip Link
   ══════════════════════════════════════════════════════ */

.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  z-index: 99999;
  padding: 0.5rem 1rem;
  background: var(--color-primary, #1a3d7a);
  color: #fff;
  font-size: 14px;
  border-radius: 0 0 4px 4px;
  text-decoration: none;
  transition: top 0.1s;
}

.skip-link:focus-visible {
  top: 0;
}


/* ══════════════════════════════════════════════════════
   2. SCHRIFTEN
   ══════════════════════════════════════════════════════ */

@font-face {
  font-family: 'DINAlternate';
  src: url('/static/fonts/DINAlternate-Bold.ttf') format('truetype');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'EuroPlate';
  src: url('/static/fonts/EuroPlate.woff2') format('woff2'),
       url('/static/fonts/EuroPlate.ttf')   format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: block;
}


/* ══════════════════════════════════════════════════════
   3. DESIGN TOKENS
   ══════════════════════════════════════════════════════ */

:root {

  /* ── Palette: Marine Blau ──────────────────────────── */
  --marine-950: #030d1c;
  --marine-900: #071428;
  --marine-800: #0d2040;
  --marine-700: #143060;
  --marine-600: #1a3d7a;
  --marine-500: #2250a0;
  --marine-400: #3d6ec2;
  --marine-300: #6692d8;
  --marine-200: #9db8e8;
  --marine-100: #cddaf4;
  --marine-50:  #eef3fb;

  /* ── Palette: Creme / Silberweiß ───────────────────── */
  --cream-950: #1a1812;
  --cream-900: #2e2c22;
  --cream-800: #4a4735;
  --cream-700: #6b6750;
  --cream-600: #8e8972;
  --cream-500: #b0ab98;
  --cream-400: #c8c4b5;
  --cream-300: #dedad0;
  --cream-200: #ece9e0;
  --cream-100: #f5f3ec;
  --cream-50:  #faf9f6;

  /* ── Palette: Sonder-Farben ────────────────────────── */
  --black:        #000;
  --white:        #fff;
  --baby-blue:    #89cff0;

  /* ── Palette: Graphit / Fast-Schwarz ───────────────── */
  --graphite-950: #0a0a0b;
  --graphite-900: #111113;
  --graphite-800: #1c1c1f;
  --graphite-700: #28282c;
  --graphite-600: #3a3a40;
  --graphite-500: #52525a;
  --graphite-400: #71717a;
  --graphite-300: #a0a0aa;
  --graphite-200: #c8c8d0;
  --graphite-100: #e4e4e8;
  --graphite-50:  #f4f4f6;

  /* ── Semantisch: Hell-Modus (Standard) ─────────────── */
  --color-bg:            var(--cream-50);
  --color-surface:       var(--cream-100);
  --color-surface-raised:var(--cream-200);
  --color-border:        var(--cream-300);
  --color-border-strong: var(--cream-400);

  --color-text:          var(--graphite-950);
  --color-text-muted:    var(--graphite-500);
  --color-text-subtle:   var(--graphite-400);

  --color-primary:       var(--marine-600);
  --color-primary-hover: var(--marine-700);
  --color-primary-fg:    var(--cream-50);

  --color-accent:        var(--baby-blue);
  --color-accent-subtle: var(--marine-50);

  /* ── Status-Farben ─────────────────────────────────── */
  --color-success:       #16a34a;
  --color-success-bg:    #dcfce7;
  --color-warning:       #d97706;
  --color-warning-bg:    #fef3c7;
  --color-danger:        #dc2626;
  --color-danger-hover:  #b91c1c;
  --color-danger-bg:     #fee2e2;
  --color-info:          var(--marine-500);
  --color-info-bg:       var(--marine-50);

  /* ── Typografie ────────────────────────────────────── */
  --font-sans: 'DINAlternate', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --font-mono: 'SF Mono', 'Fira Code', Consolas, monospace;

  --text-xs:   0.75rem;    /* 12px */
  --text-sm:   0.875rem;   /* 14px */
  --text-base: 1rem;       /* 16px */
  --text-lg:   1.125rem;   /* 18px */
  --text-xl:   1.25rem;    /* 20px */
  --text-2xl:  1.5rem;     /* 24px */
  --text-3xl:  1.875rem;   /* 30px */
  --text-4xl:  2.25rem;    /* 36px */

  --weight-normal:   400;
  --weight-medium:   500;
  --weight-semibold: 600;
  --weight-bold:     700;

  --leading-tight:  1.25;
  --leading-snug:   1.375;
  --leading-normal: 1.5;
  --leading-relaxed:1.625;

  /* ── Abstände (4px Basis) ──────────────────────────── */
  --space-1:  0.25rem;   /*  4px */
  --space-2:  0.5rem;    /*  8px */
  --space-3:  0.75rem;   /* 12px */
  --space-4:  1rem;      /* 16px */
  --space-5:  1.25rem;   /* 20px */
  --space-6:  1.5rem;    /* 24px */
  --space-8:  2rem;      /* 32px */
  --space-10: 2.5rem;    /* 40px */
  --space-12: 3rem;      /* 48px */
  --space-16: 4rem;      /* 64px */
  --space-20: 5rem;      /* 80px */
  --space-24: 6rem;      /* 96px */

  /* ── Border Radius ─────────────────────────────────── */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   12px;
  --radius-xl:   16px;
  --radius-2xl:  24px;
  --radius-full: 9999px;

  /* ── Schatten ──────────────────────────────────────── */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);
  --shadow-md: 0 4px 12px 0 rgb(0 0 0 / .08);
  --shadow-lg: 0 8px 24px 0 rgb(0 0 0 / .12);
  --shadow-xl: 0 16px 40px 0 rgb(0 0 0 / .16);

  /* ── Übergänge ─────────────────────────────────────── */
  --transition-fast: 100ms ease;
  --transition-base: 150ms ease;
  --transition-slow: 300ms ease;

  /* ── Layout ────────────────────────────────────────── */
  --max-width: 1200px;
  --nav-height: 52px;
  --header-height: 90px;
  --footer-height: 36px;

  /* ── Pattern ────────────────────────────────────────── */
  --pattern-marine: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='32' viewBox='0 0 16 32'%3E%3Cg fill='%2389CFF0' fill-opacity='0.06'%3E%3Cpath fill-rule='evenodd' d='M0 24h4v2H0v-2zm0 4h6v2H0v-2zm0-8h2v2H0v-2zM0 0h4v2H0V0zm0 4h2v2H0V4zm16 20h-6v2h6v-2zm0 4H8v2h8v-2zm0-8h-4v2h4v-2zm0-20h-6v2h6V0zm0 4h-4v2h4V4zm-2 12h2v2h-2v-2zm0-8h2v2h-2V8zM2 8h10v2H2V8zm0 8h10v2H2v-2zm-2-4h14v2H0v-2zm4-8h6v2H4V4zm0 16h6v2H4v-2zM6 0h2v2H6V0zm0 24h2v2H6v-2z'/%3E%3C%2Fg%3E%3C%2Fsvg%3E");

  /* ── Z-Index ────────────────────────────────────────── */
  --z-below:    -1;
  --z-base:      0;
  --z-raised:   10;
  --z-dropdown: 100;
  --z-sticky:   200;
  --z-nav:      300;
  --z-overlay:  500;
  --z-modal:    800;
  --z-toast:    900;
}

/* ── Dunkel-Modus ──────────────────────────────────────── */
[data-theme="dark"] {
  --color-bg:            var(--graphite-900);
  --color-surface:       var(--graphite-800);
  --color-surface-raised:var(--graphite-700);
  --color-border:        var(--graphite-700);
  --color-border-strong: var(--graphite-600);

  --color-text:          var(--cream-100);
  --color-text-muted:    var(--graphite-300);
  --color-text-subtle:   var(--graphite-400);

  --color-primary:       var(--marine-400);
  --color-primary-hover: var(--marine-300);
  --color-primary-fg:    var(--graphite-950);

  --color-accent:        var(--marine-300);
  --color-accent-subtle: var(--marine-900);

  --color-success-bg:    #14532d;
  --color-warning-bg:    #451a03;
  --color-danger-bg:     #450a0a;
  --color-info-bg:       var(--marine-900);
}


/* ══════════════════════════════════════════════════════
   4. BASIS
   ══════════════════════════════════════════════════════ */

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg);
  opacity: 0;                   /* FOUC-Schutz: CSSBridge.reveal() setzt opacity:1 */
  transition: color var(--transition-base), background-color var(--transition-base),
              opacity var(--transition-slow);
}

.c-site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: var(--header-height);
  overflow: hidden;
  background-color: var(--marine-800);
  background-image: var(--pattern-marine);
  border-bottom: 1.5px solid var(--white);
  box-shadow: inset 0 -12px 24px -4px rgb(0 0 0 / 0.45);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 var(--space-8);
}

.c-site-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background-color: var(--marine-800);
  background-image: var(--pattern-marine);
  border-top: 1.5px solid var(--white);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: var(--space-1) 0;
  padding-bottom: env(safe-area-inset-bottom);
}

.c-site-footer__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.c-site-footer__copy {
  font-size: 0.6rem;
  color: rgba(255, 255, 255, 0.4);
  margin: 0;
  letter-spacing: 0.02em;
}

.c-site-footer__link {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-size: 0.75rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: color var(--transition-base);
}

.c-site-footer__link:hover {
  color: var(--white);
}

.c-site-footer__sep {
  color: rgba(255, 255, 255, 0.3);
  font-size: 0.75rem;
}

@media (max-width: 609px) {
  .c-site-footer__nav {
    gap: var(--space-2);
  }

  .c-site-footer__link {
    font-size: 0.6rem;
  }

  .c-site-footer__sep {
    font-size: 0.5rem;
  }

  .c-site-footer__copy {
    font-size: 0.5rem;
  }
}


.c-header-badge {
  position: fixed;
  top: var(--header-height);
  right: var(--space-3);
  left: auto;
  transform: translateY(calc(-50% + 30px)) rotate(-9deg);
  z-index: 102;
  pointer-events: none;
}

.c-header-badge__full {
  display: none;
}

@media (min-width: 610px) {
  .c-header-badge {
    left: 50%;
    right: auto;
    transform: translate(-50%, calc(-50% + 70px)) rotate(-9deg);
  }

  .c-header-badge__full {
    display: block;
    height: 300px;
    width: auto;
    max-width: none;
    filter: drop-shadow(0 0 18px rgba(255, 255, 255, 0.75))
            drop-shadow(0 0 40px rgba(255, 255, 255, 0.35))
            drop-shadow(0 8px 20px rgba(0, 0, 0, 0.3))
            drop-shadow(0 3px 8px rgba(0, 0, 0, 0.18));
  }

  main {
    padding-top: calc(var(--header-height) + 234px); /* Desktop: badge-unten(240px) + 60px offset + 24px Luft */
  }
}

.c-site-header__brand {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  font-family: "DIN Alternate", "DIN Next", "Arial Narrow", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #ffffff;
  pointer-events: none;
  white-space: nowrap;
  opacity: 1;
  transition: opacity 220ms ease;
}

.c-site-header__brand--hidden {
  opacity: 0;
  pointer-events: none;
}

.c-typewriter-cursor {
  display: inline-block;
  opacity: 1;
  margin-left: 0.04em;
  /* GPU-Layer erzwingen – nötig für zuverlässige opacity-Animation auf iOS Safari */
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  will-change: opacity;
  -webkit-animation: tw-blink 0.9s steps(1, end) infinite;
  animation: tw-blink 0.9s steps(1, end) infinite;
}

@-webkit-keyframes tw-blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}
@keyframes tw-blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .c-typewriter-cursor {
    -webkit-animation: none;
    animation: none;
    opacity: 1;
    will-change: auto;
  }
}

.c-site-header__plate {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  opacity: 0;
  transition: opacity 220ms ease;
  pointer-events: none;
}

.c-site-header__plate--visible {
  opacity: 1;
}

.c-site-header .c-btn--primary {
  background: var(--white);
  color: var(--black);
  font-size: 1.1rem;
  padding: var(--space-3) var(--space-8);
  outline: 1px solid var(--white);
  outline-offset: 1px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: transform var(--transition-fast),
              filter var(--transition-base),
              color var(--transition-base),
              outline-color var(--transition-base),
              box-shadow var(--transition-base);
}

.c-site-header .c-btn--primary:hover {
  background: var(--white);
  opacity: 1;
  color: var(--baby-blue);
  transform: scale(1.03);
  filter: brightness(0.96);
  outline-color: var(--baby-blue);
  box-shadow: 0 2px 10px rgb(137 207 240 / 0.35);
}

.c-site-header .c-btn--primary:active,
.c-site-header .c-btn--primary:active:hover {
  background: var(--white);
  transform: scale(0.97);
  filter: brightness(0.88);
  outline-color: var(--baby-blue);
  box-shadow: 0 1px 4px rgb(137 207 240 / 0.2);
}

.c-site-header .c-btn--primary:focus,
.c-site-header .c-btn--primary:focus-visible {
  outline: 1px solid var(--baby-blue);
  outline-offset: 1px;
}

* {
  scrollbar-width: none;        /* Firefox (Desktop + Mobile) */
  -ms-overflow-style: none;     /* IE 10+ / Edge Legacy */
}
*::-webkit-scrollbar {
  display: none;                /* Chrome · Safari · iOS Safari · Android Chrome · Edge */
}
*::-webkit-scrollbar-track,
*::-webkit-scrollbar-thumb,
*::-webkit-scrollbar-corner {
  display: none;                /* iOS Safari / iPad — Track & Thumb explizit ausblenden */
}

/* ── Fokus-Stile (Tastaturnavigation) ──────────────────── */

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

:focus:not(:focus-visible) {
  outline: none;
}


/* ══════════════════════════════════════════════════════
   5. KOMPONENTEN
   ══════════════════════════════════════════════════════ */

/* ── Buttons ────────────────────────────────────────── */

.c-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  border: 1px solid transparent;
  border-radius: 3px;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  line-height: 1;
  cursor: pointer;
  transition: background var(--transition-base), color var(--transition-base), border-color var(--transition-base);
  background: var(--color-primary);
  color: var(--color-primary-fg);
}

.c-btn:hover {
  background: var(--color-primary-hover);
}

.c-btn--secondary {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--color-border);
}

.c-btn--secondary:hover {
  background: var(--color-surface-raised);
}

.c-btn--ghost {
  background: transparent;
  color: var(--color-primary);
  border-color: transparent;
}

.c-btn--ghost:hover {
  background: var(--color-accent-subtle);
}

.c-btn--danger {
  background: var(--color-danger);
  color: #fff;
  border: 3px solid var(--color-danger);
  outline: 1px solid var(--color-danger);
  outline-offset: 1px;
  transition: transform var(--transition-base);
}

.c-btn--danger:hover {
  background: var(--color-danger-hover);
  transform: scale(1.05);
}

.c-btn--danger:active {
  transform: scale(0.97);
  outline: 1px solid var(--color-danger-hover);
}

.c-btn--danger:focus,
.c-btn--danger:focus-visible {
  outline: 1px solid var(--color-danger-hover);
  outline-offset: 1px;
}

.c-btn--primary {
  text-transform: uppercase;
  background-color: var(--marine-600);
  background-image: var(--pattern-marine);
  color: var(--cream-50);
  height: 59.5px;
  padding: 0 var(--space-12);
  border-radius: 3px;
  font-size: 2rem;
  font-weight: var(--weight-semibold);
  cursor: pointer;
  border: 3px solid var(--marine-600);
  outline: 1px solid var(--marine-600);
  outline-offset: 1px;
  white-space: nowrap;
  transition: transform var(--transition-base);
}

.c-btn--primary:hover {
  transform: scale(1.05);
}

.c-btn--primary:active {
  transform: scale(0.97);
  outline: 1px solid var(--marine-600);
}

.c-btn--primary:focus,
.c-btn--primary:focus-visible {
  outline: 1px solid var(--marine-600);
  outline-offset: 1px;
}

#btn-kaufen {
  user-select: none;
  -webkit-user-drag: none;
  transition: opacity var(--transition-fast, 150ms ease), transform var(--transition-base);
}

#btn-kaufen:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

#cta-row {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-4);
}

.c-btn-group {
  display: inline-flex;
  gap: var(--space-2);
}


/* ── Inputs ─────────────────────────────────────────── */

.c-input {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.c-input__field {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  background: var(--color-surface);
  color: var(--color-text);
  font-size: 1rem; /* min. 16px — verhindert iOS-Auto-Zoom beim Fokussieren */
  transition: border-color var(--transition-base);
}

.c-input__field:focus {
  outline: none;
  border-color: var(--color-primary);
}

.c-input__field--search {
  width: 260px;
}

/* ── Search-Komponente (Admin-Header) ───────────────── */

.c-search {
  position: relative;
  display: flex;
  align-items: center;
  width: 400px;
}

.c-search__icon {
  position: absolute;
  left: 13px;
  display: flex;
  color: var(--color-text-muted);
  pointer-events: none;
}

.c-search__input {
  width: 100%;
  height: 40px;
  padding: 0 var(--space-4) 0 40px;
  border: 1.5px solid var(--color-border-strong);
  border-radius: var(--radius-full);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: 0.9375rem;
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
}

.c-search__input::placeholder {
  color: var(--color-text-subtle);
}

.c-search__input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(26, 61, 122, 0.1);
}


/* ── Checkbox ───────────────────────────────────────── */

.c-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
}

.c-checkbox__input {
  width: 1rem;
  height: 1rem;
  accent-color: var(--color-primary);
  cursor: pointer;
}

/* Tabellen-Checkbox — passend zum Toggle-Design */
.c-table-check {
  appearance: none;
  -webkit-appearance: none;
  width: 15px;
  height: 15px;
  border: 1.5px solid var(--color-border);
  border-radius: 3px;
  background: #fff;
  cursor: pointer;
  position: relative;
  display: block;
  transition: background var(--transition-fast), border-color var(--transition-fast);
  outline-offset: 2px;
}

.c-table-check:hover {
  border-color: var(--color-primary);
  background: #f0f7ff;
}

.c-table-check:focus-visible {
  outline: 2px solid var(--color-primary);
}

.c-table-check:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.c-table-check:checked::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}

.c-table__th--check,
.c-table__td--check {
  width: 36px;
  padding-left: var(--space-4);
  padding-right: 0;
  vertical-align: middle;
}



/* ── Alert ──────────────────────────────────────────── */

.c-alert {
  padding: var(--space-4);
  border-radius: 3px;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  font-size: var(--text-sm);
}


/* ── Spinner ────────────────────────────────────────── */

.c-spinner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.c-spinner__ring {
  width: 1.5rem;
  height: 1.5rem;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 3px;
  animation: spin 0.7s linear infinite;
}

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


/* ── Badge ──────────────────────────────────────────── */

.c-icon-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--color-text-muted);
}

.c-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  background: var(--color-surface-raised);
  color: var(--color-text-muted);
}

.c-badge--success {
  background: var(--color-success-bg);
  color: var(--color-success);
}

.c-badge--warning {
  background: var(--color-warning-bg);
  color: var(--color-warning);
}

.c-badge--danger {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}

.c-badge--info {
  background: var(--color-info-bg);
  color: var(--color-info);
}

.c-badge--neutral {
  background: rgba(0, 0, 0, 0.08);
  color: var(--color-text);
}


/* ── Button: Small ──────────────────────────────────── */

.c-btn--sm {
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-3);
  height: 28px;
}


/* ── Modal ──────────────────────────────────────────── */

.c-modal {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgb(0 0 0 / .5);
  padding: var(--space-4);
}

.c-modal__box {
  background: var(--color-surface);
  border-radius: 3px;
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 480px;
  padding: var(--space-8);
}

.c-modal__box--wide {
  width: 92vw;
  max-width: 1200px;
  height: 92vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: var(--space-4);
}

.c-modal__box--wide .c-modal__header {
  flex-shrink: 0;
}

.c-modal__box--wide .c-modal__pdf-frame {
  flex: 1;
  min-height: 0;
}

.c-modal__pdf-frame {
  display: block;
  width: 100%;
  height: 75vh;
  border: none;
  border-radius: 2px;
}

.c-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.c-modal__body {
  padding: 0 var(--space-6) var(--space-6);
}

.c-modal__text {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--space-5);
  line-height: 1.6;
}

.c-modal__actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
}


/* ── Navigation ─────────────────────────────────────── */

.c-nav__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: 3px;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: background var(--transition-base), color var(--transition-base);
  cursor: pointer;
}

.c-nav__item:hover,
.c-nav__item--active {
  background: var(--color-surface-raised);
  color: var(--color-text);
}

.c-nav__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  background: #dc2626;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  margin-left: auto;
  animation: badge-pop 0.2s ease-out;
}

@keyframes badge-pop {
  from { transform: scale(0.5); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}


/* ── Abhol-Code Verify Widget ───────────────────────── */

.c-abhol-verify {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.c-abhol-verify__hint {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-align: center;
  margin: 0;
}
.c-abhol-verify__otp {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.c-abhol-verify__otp-char {
  width: 46px;
  height: 54px;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 1.5rem;
  font-weight: 700;
  text-transform: uppercase;
  border: 2px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  caret-color: transparent;
}
.c-abhol-verify__otp-char:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}
.c-abhol-verify__otp-char.is-filled {
  border-color: var(--color-text-muted);
}
.c-abhol-verify__result {
  padding: var(--space-2) var(--space-4);
  border-radius: 6px;
  font-size: var(--text-sm);
  font-weight: 500;
  border: 1px solid transparent;
}
.c-abhol-verify__result--ok {
  background: var(--color-surface-raised);
  color: var(--color-text);
  border-color: var(--color-border);
}
.c-abhol-verify__result--error {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  border-color: var(--color-danger);
}

/* ── Abhol-Verify Result Card ────────────────────────── */

.c-abhol-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.c-abhol-card__head {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--color-success);
}
.c-abhol-card__plate {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  padding: var(--space-2) 0;
}
.c-abhol-card__fsp {
  position: relative;
  width: 80px;
  height: 80px;
  flex-shrink: 0;
}
.c-abhol-card__fsp img {
  width: 80px;
  height: 80px;
  display: block;
}
.c-abhol-card__kfz-field {
  position: absolute;
  left: 16.3%;
  top: 50%;
  width: 67.4%;
  height: 22.4%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'EuroPlate', 'FE-Font', monospace;
  font-size: 10px;
  color: #111;
  white-space: nowrap;
  overflow: hidden;
  letter-spacing: 0.05em;
}
.c-abhol-card__banner {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-radius: 8px;
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1.3;
}
.c-abhol-card__banner--ok   { background: var(--color-success-bg); color: var(--color-success); }
.c-abhol-card__banner--warn { background: var(--color-warning-bg); color: var(--color-warning); }
.c-abhol-card__invoice-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  justify-content: center;
  width: 100%;
}
.c-abhol-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}
.c-abhol-card__tag {
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 20px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
}

/* ── Abhol-Code Table Cell ──────────────────────────── */

.c-abhol-code {
  display: inline-block;
  font-family: monospace;
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 2px;
  padding: 2px var(--space-2);
  border-radius: 4px;
  background: var(--color-surface-raised);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.c-abhol-code:hover {
  background: var(--color-primary);
  color: var(--color-primary-fg);
  border-color: var(--color-primary);
}

/* ── Table ──────────────────────────────────────────── */

.c-table-wrap {
  border: 1px solid #d1d5db;
  border-radius: 6px;
  overflow-x: auto;
  overscroll-behavior-x: none;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.c-table-wrap::-webkit-scrollbar {
  display: none;
}

.c-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  background: #fff;
  min-width: 640px;
}

.c-table thead {
  background: #f1f3f5;
  border-bottom: 1px solid #d1d5db;
}

.c-table th {
  padding: var(--space-2) var(--space-4);
  text-align: left;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.c-table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
  color: var(--color-text);
  vertical-align: middle;
  white-space: nowrap;
}

.c-table tbody tr:last-child td {
  border-bottom: none;
}

.c-table tbody tr {
  transition: background 0.15s, opacity 0.2s;
}

/* Markierte Zeile: ausgegraut + durchgestrichen */
.c-table tbody tr:has(.c-table-check:checked) {
  opacity: 0.5;
}

.c-table tbody tr:has(.c-table-check:checked) td:not(.c-table__td--check) {
  text-decoration: line-through;
  text-decoration-color: currentColor;
  text-decoration-thickness: 1.5px;
}

.c-table tbody tr:nth-child(odd) {
  background: #f8f9fa;
}

.c-table tbody tr:nth-child(even) {
  background: #ffffff;
}

.c-table tbody tr:hover {
  background: #e9ecef;
}

.c-table__row {
  transition: background 0.15s;
}

.c-table__row:hover {
  background: #e9ecef;
}

.c-table__row--done td {
  opacity: 0.45;
  text-decoration: line-through;
}

.c-table__row--done .c-table__cell--plate {
  text-decoration: none;
}

.c-table__row--done .c-status-drop,
.c-table__row--done .c-btn {
  opacity: 1;
  text-decoration: none;
}

.c-table__cell--plate {
  vertical-align: middle;
  line-height: 0;
}

.c-table__cell-subtext {
  display: block;
  font-size: 0.5rem;
  color: var(--color-text-muted, #888);
  margin-top: -5px;
  font-weight: 400;
  letter-spacing: 0.03em;
  text-align: center;
}

/* ── Status Inline Dropdown ──────────────────────────── */

.c-status-drop {
  position: relative;
  display: inline-block;
}

.c-status-drop__trigger {
  appearance: none;
  -webkit-appearance: none;
  border: none;
  background: none;
  margin: 0;
  padding: 2px 4px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  border-radius: 4px;
  font: inherit;
  transition: opacity 0.12s;
}

.c-status-drop__trigger:hover {
  opacity: 0.75;
}

.c-status-drop__menu {
  position: absolute;
  top: calc(100% + 5px);
  left: 0;
  z-index: 200;
}

.c-status-drop__menu--portal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 4px;
  min-width: 175px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.22);
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.c-status-drop__item {
  appearance: none;
  -webkit-appearance: none;
  border: none;
  background: none;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 7px 10px;
  border-radius: 5px;
  cursor: pointer;
  font-size: var(--text-xs, 0.65rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-align: left;
  transition: background 0.1s;
}

.c-status-drop__item:hover {
  background: rgba(128,128,128,0.1);
}

.c-status-drop__item.is-active {
  background: rgba(128,128,128,0.07);
}

.c-status-drop__item--warning { color: var(--color-warning); }
.c-status-drop__item--success { color: var(--color-success); }
.c-status-drop__item--info    { color: var(--color-info); }
.c-status-drop__item--default { color: var(--color-text-muted); }

/* PIN-Zelle: klickbar + Clipboard-Feedback */
.ar-pin-cell {
  cursor: pointer;
  position: relative;
  user-select: none;
}

.ar-pin-cell code {
  transition: opacity 0.15s;
}

.ar-pin-cell--copied code {
  opacity: 0;
}

.ar-pin-cell::after {
  content: '✓';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #16a34a;
  font-size: 1.1rem;
  font-weight: 700;
  opacity: 0;
  transition: opacity 0.15s;
  pointer-events: none;
}

.ar-pin-cell--copied::after {
  opacity: 1;
}

.c-table__empty {
  padding: var(--space-8) var(--space-4);
  text-align: center;
  color: #9ca3af;
  font-style: italic;
}


/* ── Stat Card ──────────────────────────────────────── */

.c-stat-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.c-stat-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--color-primary);
  border-radius: 8px 8px 0 0;
}

.c-stat-card__icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: var(--color-accent-subtle);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-4);
  flex-shrink: 0;
}

.c-stat-card__label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.c-stat-card__value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
  margin-bottom: var(--space-1);
}

.c-stat-card__sub {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}


/* ── Plate Preview ──────────────────────────────────── */

.c-plate-preview {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 3px;
}


/* ── Price Card ─────────────────────────────────────── */

.c-price-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  padding: var(--space-6);
}


/* ── Order Summary ─────────────────────────────────── */
.c-order-summary {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.c-order-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}


/* ── Invoice / Lieferschein ─────────────────────────── */

/* ── Invoice – Weißes Papier-Dokument ──────────────────── */
.c-invoice {
  background: #fff;
  color: #1c1c1e;
  border-radius: 3px;
  padding: var(--space-8) var(--space-8) 0;
  font-size: 0.8125rem;
  line-height: 1.55;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, .07),
    0 2px 8px  rgba(0, 0, 0, .06),
    0 12px 40px rgba(0, 0, 0, .09);
  border-top: 4px solid var(--color-primary);
}

/* Kopfzeile */
.c-invoice__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.c-invoice__head-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-3);
}

.c-invoice__company {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.c-invoice__company strong {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--color-primary);
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.c-invoice__company-addr {
  color: #6b7280;
  font-size: var(--text-xs);
  line-height: 1.65;
}

.c-invoice__meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: right;
}

.c-invoice__meta-row {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
}

.c-invoice__meta-label {
  color: #9ca3af;
  font-size: var(--text-xs);
}

.c-invoice__meta-value {
  font-weight: var(--weight-semibold);
  color: #1c1c1e;
  min-width: 9ch;
  text-align: right;
  font-size: var(--text-xs);
  font-variant-numeric: tabular-nums;
}

/* Trennlinie */
.c-invoice__divider {
  border: none;
  border-top: 1px solid #e5e7eb;
  margin: var(--space-5) 0;
}

/* Positionstabelle */
.c-invoice__table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 0;
}

.c-invoice__table thead tr {
  background: none;
}

.c-invoice__table thead th {
  padding: var(--space-2) var(--space-2) var(--space-2) 0;
  font-weight: var(--weight-semibold);
  font-size: 0.6875rem;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  border-bottom: 2px solid var(--color-primary);
}

.c-invoice__table thead th:first-child {
  padding-left: 0;
}

.c-invoice__table tbody td {
  padding: var(--space-3) var(--space-2) var(--space-3) 0;
  border-bottom: 1px solid #f0f0f0;
  vertical-align: top;
  color: #374151;
}

.c-invoice__table tbody td:first-child {
  padding-left: 0;
}

.c-invoice__table tbody tr:last-child td {
  border-bottom: none;
}

.c-invoice__col-pos {
  width: 2rem;
  text-align: left;
  color: #9ca3af;
  font-size: var(--text-xs);
}

.c-invoice__col-desc {
  text-align: left;
}

.c-invoice__col-desc strong {
  font-weight: var(--weight-semibold);
  color: #1c1c1e;
  display: block;
  font-size: var(--text-sm);
  margin-bottom: 2px;
}

.c-invoice__desc-detail {
  display: block;
  font-size: var(--text-xs);
  color: #9ca3af;
  margin-top: 2px;
  line-height: 1.5;
}

.c-invoice__col-num {
  text-align: right;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  color: #374151;
}

/* Summenblock */
.c-invoice__totals {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-1);
  padding: var(--space-4) var(--space-8);
  margin: var(--space-3) calc(-1 * var(--space-8));
  border-top: 1px solid #e5e7eb;
  background: #f9fafb;
}

.c-invoice__total-row {
  display: flex;
  gap: var(--space-8);
  justify-content: flex-end;
  color: #6b7280;
  min-width: 18rem;
  font-size: var(--text-xs);
}

.c-invoice__total-row span:last-child {
  min-width: 7rem;
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: #374151;
}

.c-invoice__total-row--grand {
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 2px solid var(--color-primary);
  font-weight: var(--weight-bold);
  font-size: var(--text-sm);
  color: #1c1c1e;
}

.c-invoice__total-row--grand span:last-child {
  color: var(--color-primary);
  font-size: var(--text-base);
}

/* Fußzeile */
.c-invoice__footer {
  display: flex;
  gap: var(--space-8);
  margin: 0 calc(-1 * var(--space-8));
  padding: var(--space-3) var(--space-8);
  border-top: 1px solid #e5e7eb;
  background: #f3f4f6;
  border-radius: 0 0 3px 3px;
  font-size: var(--text-xs);
  color: #6b7280;
}

.c-invoice__footer-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.c-invoice__footer-label {
  font-weight: var(--weight-semibold);
  color: #374151;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.65rem;
}

@media (max-width: 609px) {
  .c-invoice {
    padding: var(--space-3) var(--space-3) 0;
    font-size: var(--text-xs);
    box-shadow:
      0 0 0 1px rgba(0, 0, 0, .05),
      0 1px 4px  rgba(0, 0, 0, .04);
  }

  .c-invoice__head {
    flex-direction: column;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
  }

  .c-invoice__head-right {
    align-items: flex-start;
  }

  .c-invoice__company strong {
    font-size: var(--text-base);
  }

  .c-invoice__company-addr {
    font-size: 0.65rem;
  }

  .c-invoice__meta {
    text-align: left;
  }

  .c-invoice__meta-row {
    justify-content: flex-start;
    gap: var(--space-2);
  }

  .c-invoice__col-pos,
  .c-invoice__table thead th.c-invoice__col-pos,
  .c-invoice__table tbody td.c-invoice__col-pos {
    display: none;
  }

  .c-invoice__table thead th {
    padding: var(--space-1) var(--space-1) var(--space-1) 0;
    font-size: 0.6rem;
  }

  .c-invoice__table tbody td {
    padding: var(--space-2) var(--space-1) var(--space-2) 0;
    font-size: var(--text-xs);
  }

  .c-invoice__col-desc strong {
    font-size: var(--text-xs);
  }

  .c-invoice__desc-detail {
    font-size: 0.65rem;
  }

  .c-invoice__totals {
    align-items: stretch;
    padding: var(--space-3) var(--space-3);
    margin-left: calc(-1 * var(--space-3));
    margin-right: calc(-1 * var(--space-3));
  }

  .c-invoice__total-row {
    min-width: unset;
    width: 100%;
    justify-content: space-between;
    gap: var(--space-4);
  }

  .c-invoice__total-row span:last-child {
    min-width: unset;
  }

  .c-invoice__footer {
    flex-direction: column;
    gap: var(--space-2);
    margin-left: calc(-1 * var(--space-3));
    margin-right: calc(-1 * var(--space-3));
    padding: var(--space-2) var(--space-3);
    font-size: 0.65rem;
  }

  .c-invoice__footer-label {
    font-size: 0.6rem;
  }

  .c-invoice kfz-kennzeichen {
    --kfz-scale: 0.35;
  }
}


/* ── Menge Group (#menge-group) ─────────────────────── */

#menge-group {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  gap: 17px;
  transition: opacity 0.15s ease;
  position: relative;
  background: #efefef;
  border-radius: 3px;
  outline: 1px solid #ccc;
  outline-offset: 1px;
  padding: var(--space-4) var(--space-6);
  width: calc(600px * var(--kfz-zoom, 1));
  max-width: 100%;
  box-sizing: border-box;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.05), inset 0 -1px 3px rgba(0,0,0,0.05);
}


#menge-stepper {
}

/* ── Menge Input (#menge-input) ─────────────────────── */

#menge-input {
  width: 1ch;
  height: 6rem;
  font-size: 6rem;
  line-height: 6rem;
  font-family: 'DINAlternate', 'DIN 1451', 'Arial Narrow', Arial, sans-serif;
  font-weight: 700;
  text-align: center;
  padding: 0 0.25rem;
  margin: 0;
  border: none;
  border-bottom: none;
  border-radius: 0;
  background: transparent;
  color: var(--color-primary);
  outline: none;
  box-sizing: content-box;
  -webkit-appearance: textfield;
  touch-action: none;
  pointer-events: none;
  overflow: hidden;
  clip-path: inset(0);
  -moz-appearance: textfield;
  appearance: textfield;
  transform: translateY(0px);
  transition: opacity 0.15s ease, transform 0.15s ease;
  caret-color: transparent;
  cursor: default;
}

@media (hover: hover) {
  #menge-stepper:hover #menge-input {
    opacity: 0.9;
  }

  #menge-group:hover #menge-input {
    transform: translateY(0px) scale(1.04);
  }

  #menge-group:hover #menge-label {
    transform: translateY(1px) scale(1.04);
  }
}

#menge-input::-webkit-outer-spin-button,
#menge-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

#menge-controls {
  position: absolute;
  top: 50%;
  left: var(--space-6);
  right: var(--space-6);
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  align-items: center;
  pointer-events: none;
  opacity: 1;
}

#menge-controls button {
  pointer-events: all;
}

#menge-controls button {
  flex: 0 0 auto;
  width: 2rem;
  height: 2rem;
  border: 1px solid transparent;
  border-radius: 3px;
  background: var(--color-primary);
  color: var(--color-primary-fg);
  font-size: 1.2rem;
  font-weight: var(--weight-semibold);
  line-height: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background var(--transition-base), color var(--transition-base), transform var(--transition-base);
}

#menge-plus  { order: 1; }

#menge-controls button:hover:not(:disabled) {
  background: var(--color-primary-hover);
  transform: scale(1.05);
}

#menge-controls button:active:not(:disabled) {
  background: var(--color-primary-hover);
  transform: scale(0.97);
  filter: brightness(0.9);
}

#menge-controls button:disabled {
  opacity: 0.2;
  cursor: default;
}

@media (min-width: 610px) {
  #menge-input {
    font-size: 6rem;
  }

  #menge-controls button {
    width: 2.6rem;
    height: 2.6rem;
    font-size: 1.6rem;
    padding: 0;
  }

  #menge-group {
    padding: var(--space-4) calc(var(--space-6) * 1.5);
  }
}

#menge-label {
  display: block;
  width: 3rem;
  height: 3rem;
  color: var(--color-primary);
  flex-shrink: 0;
  transform: translateY(1px);
  transition: transform 0.15s ease;
}


/* ── Home Main Layout ───────────────────────────────── */

/* Desktop: Body + Main gesperrt — nur .s-home__scroll scrollt intern */
@media (min-width: 610px) {
  body[data-page="home"],
  body[data-page="checkout"] {
    overflow: hidden;
    height: 100dvh;
  }

  [data-page="home"] main,
  [data-page="checkout"] main,
  [data-page="upsell"] main {
    position: fixed;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: unset;
    padding: calc(var(--header-height) + 234px) var(--space-3) var(--space-2);
    overflow: hidden;
  }
}

/* Mobile: normaler Body-Scroll — kein fixed, kein gesperrter Overflow */
@media (max-width: 609px) {
  body[data-page="home"],
  body[data-page="checkout"],
  body[data-page="upsell"] {
    background: var(--color-surface);
  }

  [data-page="home"] main,
  [data-page="checkout"] main,
  [data-page="upsell"] main {
    position: static;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: calc(var(--header-height) + var(--space-8)) 0 var(--space-6);
  }
}

/* Mobile: kein Container — Inhalt fließt natürlich, kein seitliches Padding */
.s-home__scroll {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding: 0;
}

@media (max-width: 609px) {
  #plate-row {
    padding-left: 0;
    padding-right: 0;
  }

  #menge-group,
  #plate-controls {
    padding-left: var(--space-3);
    padding-right: var(--space-3);
  }
}

/* Desktop: Scroll-Container mit Karte */
@media (min-width: 610px) {
  .s-home__scroll {
    position: relative;
    margin-top: -95px;
    max-width: 660px;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    background: #ffffff;
    border-radius: var(--radius-xl);
    box-shadow: 0 4px 40px rgba(0, 0, 0, 0.10);
    padding: 0 var(--space-4) 0;
  }
}


main {
  min-height: 100dvh;
  overflow-x: hidden;
}

#plate-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  margin: 20px 0 0;
  padding: 0 var(--space-5);
  max-width: 100%;
  overflow-x: hidden;
}

/* ── Plate Column (#plate-col) ──────────────────────── */

#plate-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}


#plate-controls {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  background: #efefef;
  border-radius: 3px;
  outline: 1px solid #ccc;
  outline-offset: 1px;
  padding: var(--space-4) var(--space-6);
  padding-bottom: var(--space-4);
  width: calc(600px * var(--kfz-zoom, 1));
  max-width: 100%;
  box-sizing: border-box;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.05), inset 0 -1px 3px rgba(0,0,0,0.05);
  transition: padding-bottom var(--transition-fast, 150ms ease);
}


/* ── Reservier layout classes — also used in admin/reservierung ── */

.reservier-form__row {
  display: flex;
  gap: 10px;
  margin-bottom: 8px;
}

.reservier-form__field {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.reservier-form__label {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.reservier-form__input,
.reservier-form__select {
  width: 100%;
  padding: 6px 8px;
  font-size: 0.82rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  transition: border-color 120ms ease;
}

.reservier-form__input:focus,
.reservier-form__select:focus {
  outline: none;
  border-color: var(--color-primary);
}

.reservier-form__footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 4px;
}

.reservier-form__anonym-btn {
  font-size: 0.75rem;
  padding: 4px 12px;
  color: var(--color-text-muted);
  border-color: var(--color-border);
}

.reservier-form__anonym-btn:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background: var(--color-accent-subtle);
}

/* ── Admin Reservierung page layout ───────────────────── */

.s-admin-reservierung {
  width: 100%;
  max-width: 720px;
  position: relative;
}

.s-admin-reservierung__header {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.s-admin-reservierung__status {
  font-family: var(--font-mono, monospace);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--color-danger);
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.s-admin-reservierung__title {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-text);
}

.s-admin-reservierung__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.s-admin-reservierung__plate-wrap {
  display: flex;
  justify-content: center;
}

.s-admin-reservierung__form-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.s-admin-reservierung__top-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.s-admin-reservierung__anonym-bar {
  display: flex;
  align-items: center;
}

.s-admin-reservierung__actions {
  display: flex;
  gap: var(--space-3);
}

.s-admin-reservierung__actions .c-btn--primary,
.s-admin-reservierung__actions .c-btn--danger {
  height: 30px;
  padding: 0 var(--space-6);
  font-size: 1rem;
  text-transform: uppercase;
}

.s-admin-reservierung__session-panel {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font-mono, monospace);
  font-size: 0.7rem;
  line-height: 1.6;
  background: #050f05;
  border: 0 solid #1a4d1a;
  border-bottom-width: 1px;
  border-radius: 0;
  padding: var(--space-3) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: 0;
  box-shadow: inset 0 0 20px rgba(0, 80, 0, 0.15);
}

[data-page="admin-reservierung"] .l-admin__main {
  position: relative;
  padding-top: 2.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: calc(100dvh - 2.5rem);
}

.ar-sp-label {
  color: #2d6b2d;
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-1);
  user-select: none;
}

summary.ar-sp-label {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

summary.ar-sp-label::before {
  content: '▶';
  font-size: 0.5rem;
  transition: transform 0.2s ease;
  transform: rotate(90deg);
}

#ar-session-panel:not([open]) summary.ar-sp-label {
  margin-bottom: 0;
}

#ar-session-panel:not([open]) summary.ar-sp-label::before {
  transform: rotate(0deg);
}

.ar-sp-divider {
  border-top: 1px solid #0f2e0f;
  margin: var(--space-1) 0;
}

.ar-sp-row {
  display: flex;
  gap: var(--space-3);
  align-items: baseline;
  min-width: 0;
}

.ar-sp-key {
  color: #2a6b2a;
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 14ch;
}

.ar-sp-key::after {
  content: ' =';
  color: #1a4d1a;
}

.ar-sp-val {
  color: #4ade80;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ar-sp-val--muted  { color: #2d7a2d; }
.ar-sp-val--idle   { color: #1e5c1e; }
.ar-sp-val--active { color: #86efac; font-weight: 600; }

.s-admin-reservierung__history {
  margin-top: var(--space-8);
  max-width: 900px;
}

.s-admin-reservierung__history-header {
  margin-bottom: var(--space-4);
}

.s-admin-reservierung__history-title {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
}

.c-kennzeichen-badge {
  display: inline-block;
  font-family: var(--font-mono, monospace);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  background: var(--color-surface-raised, #f1f5f9);
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: var(--radius-sm, 4px);
  padding: 0 var(--space-2);
  letter-spacing: 0.05em;
}


#ar-progress {
  margin-top: var(--space-2);
}

/* ── Wildcard-Ergebnisliste ─────────────────────────────── */

.ar-wildcard-results {
  margin-top: var(--space-4);
  margin-bottom: var(--space-6);
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: var(--radius-md, 8px);
  padding: 16px 20px;
  background: var(--color-surface, #fff);
  max-height: 400px;
  overflow-y: auto;
}

.ar-wildcard-results__count {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--marine-400);
  margin-bottom: 14px;
}

.ar-wildcard-results__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(192px, 1fr));
  gap: 8px;
}

.ar-wildcard-results__item {
  display: contents;
}

/* Wrapper-Button für kfz-kennzeichen Web Component */
.ar-wildcard-results__btn {
  padding: 4px;
  border: 2px solid transparent;
  border-radius: 6px;
  background: transparent;
  cursor: pointer;
  transition: background 150ms;
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
}

.ar-wildcard-results__btn:hover {
  background: rgba(0, 0, 0, 0.25);
}

.ar-wildcard-results__btn:focus-visible {
  outline: 2px solid var(--marine-400);
  outline-offset: 2px;
}

/* Ausgewählt */
.ar-wildcard-results__btn[aria-pressed="true"] {
  background: rgba(0, 0, 0, 0.5);
}

/* ── ar-btn-starten Zustandsfarben ───────────────────────── */

#ar-btn-starten {
  transition: transform var(--transition-base), background-color 200ms, border-color 200ms;
}

/* ABBRECHEN — Rot */
#ar-btn-starten[data-state="running"] {
  background-color: #dc2626;
  background-image: none;
  border-color: #dc2626;
  outline-color: #dc2626;
}
#ar-btn-starten[data-state="running"]:hover {
  background-color: #b91c1c;
  border-color: #b91c1c;
  transform: scale(1.02);
}

/* NOCHMAL PRÜFEN — Amber */
#ar-btn-starten[data-state="recheck"] {
  background-color: #b45309;
  background-image: none;
  border-color: #b45309;
  outline-color: #b45309;
}
#ar-btn-starten[data-state="recheck"]:hover {
  background-color: #92400e;
  border-color: #92400e;
}

/* RESERVIEREN — Grün */
#ar-btn-starten[data-state="confirm"] {
  background-color: #15803d;
  background-image: none;
  border-color: #15803d;
  outline-color: #15803d;
}
#ar-btn-starten[data-state="confirm"]:hover {
  background-color: #14532d;
  border-color: #14532d;
}

/* BESETZT — Deaktiviert */
#ar-btn-starten[data-state="busy"],
#ar-btn-starten:disabled {
  background-color: var(--marine-400, #64748b);
  background-image: none;
  border-color: transparent;
  outline-color: transparent;
  cursor: not-allowed;
  transform: none !important;
  opacity: 0.65;
}

#ar-btn-abort:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none !important;
  pointer-events: none;
}

.reservier-progress__header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.reservier-progress__elapsed {
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--marine-700);
  min-width: 2.4ch;
}

.reservier-progress__label {
  font-size: 0.72rem;
  font-weight: 400;
  color: var(--marine-500);
  flex: 1;
}

.reservier-progress__pct {
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--marine-700);
}

.reservier-progress__track {
  width: 100%;
  height: 7px;
  background: var(--marine-100);
  border-radius: 999px;
  overflow: hidden;
}

.reservier-progress__fill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--marine-600) 0%, var(--baby-blue) 100%);
  transition: width 1100ms cubic-bezier(0.25, 1, 0.5, 1);
  position: relative;
  overflow: hidden;
}

.reservier-progress__fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,0.35) 50%,
    transparent 100%
  );
  animation: shimmer 1.8s infinite;
  transform: translateX(-100%);
}

@keyframes shimmer {
  to { transform: translateX(200%); }
}

/* ── Plate Size Buttons (#plate-size-buttons) ───────── */

#plate-size-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
}

#plate-size-buttons button {
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  background: var(--color-surface);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), opacity var(--transition-fast);
}

#plate-size-buttons button:hover:not([disabled]) {
  background: var(--color-surface-raised);
  color: var(--color-text);
  border-color: var(--color-border-strong);
}

#plate-size-buttons button[data-active] {
  background: var(--color-primary);
  color: var(--color-primary-fg);
  border-color: var(--color-primary);
}

#plate-size-buttons button[data-active]:hover {
  background: var(--color-primary);
  color: var(--color-primary-fg);
  border-color: var(--color-primary);
  opacity: 0.85;
}

#plate-size-buttons button[disabled] {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}


/* ── Plate Option Toggles (#plate-option-toggles) ───── */

#plate-option-toggles {
  display: flex;
  flex-direction: row;
  gap: var(--space-5);
}

.c-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  user-select: none;
}

.c-toggle__input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.c-toggle__track {
  display: inline-block;
  width: 40px;
  height: 22px;
  border-radius: 3px;
  background: var(--color-border);
  outline: 1px solid var(--color-border);
  outline-offset: 1px;
  position: relative;
  transition: background var(--transition-fast), outline-color var(--transition-fast);
  flex-shrink: 0;
}

.c-toggle__track::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 4px;
  width: 16px;
  height: 16px;
  border-radius: 3px;
  background: #fff;
  transition: transform var(--transition-fast);
  box-shadow: 0 1px 3px rgba(0,0,0,.25);
}

.c-toggle:hover .c-toggle__track {
  background: #b3d4f5;
  outline-color: #b3d4f5;
}

.c-toggle__input:checked ~ .c-toggle__track {
  background: var(--color-primary);
  outline-color: #1a3a5c;
}

.c-toggle:hover .c-toggle__input:checked ~ .c-toggle__track {
  opacity: 0.85;
  background: var(--color-primary);
}

.c-toggle__input:checked ~ .c-toggle__track::after {
  transform: translateX(16.5px);
}

/* Gesperrter Toggle via disabled-Attribut auf Input */
.c-toggle:has(.c-toggle__input:disabled) {
  opacity: 0.38;
  cursor: not-allowed;
  pointer-events: none;
}

/* Gesperrter Toggle (H wenn E aktiv) */
.c-toggle--disabled {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}

.c-toggle__label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  transition: color var(--transition-base);
}

.c-toggle:hover .c-toggle__label {
  color: var(--baby-blue);
}

.c-toggle__saison-input {
  width: 32px;
  text-align: center;
  font-size: var(--text-sm);
  font-family: inherit;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  padding: 2px 4px;
  outline: none;
  transition: border-color var(--transition-fast), opacity var(--transition-fast);
}

.c-toggle__saison-input:focus {
  border-color: var(--color-primary);
}

.c-toggle__saison-input:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.c-toggle__saison-sep {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0 2px;
}

/* ── Responsive: unter 610px ────────────────────────── */

@media (max-width: 609px) {
  #plate-col {
    align-items: stretch;
  }

  kfz-kennzeichen {
    align-self: center;
  }

  #plate-controls {
    width: 100% !important;
    margin-left: var(--space-3);
    margin-right: var(--space-3);
    max-width: calc(100% - var(--space-6));
  }

  #menge-group {
    width: 100% !important;
    margin-left: var(--space-3);
    margin-right: var(--space-3);
    max-width: calc(100% - var(--space-6));
  }

  #cta-row {
    width: 100%;
  }

  #btn-kaufen {
    width: 100% !important;
    margin-left: var(--space-3);
    margin-right: var(--space-3);
    max-width: calc(100% - var(--space-6));
  }

  #plate-size-buttons {
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    width: 100%;
    gap: var(--space-1);
  }

  #plate-size-buttons button {
    flex: 1;
    padding: var(--space-1) var(--space-1);
    font-size: var(--text-xs);
    min-height: 36px;
  }

  #plate-option-toggles {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2) var(--space-3);
  }

  .c-toggle__label {
    font-size: var(--text-xs);
  }
}


/* ══════════════════════════════════════════════════════
   6. LAYOUT
   ══════════════════════════════════════════════════════ */

/* ── Navigation ─────────────────────────────────────── */

.l-nav {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
  height: var(--nav-height);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  padding: 0 var(--space-6);
  gap: var(--space-4);
  transition: background var(--transition-base), border-color var(--transition-base);
}

.l-nav__brand {
  font-weight: var(--weight-bold);
  font-size: var(--text-lg);
  color: var(--color-text);
  text-decoration: none;
  flex-shrink: 0;
}

.l-nav__links {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 1;
}

.l-nav__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-left: auto;
}


/* ── Seite ──────────────────────────────────────────── */

.l-page {
  min-height: calc(100dvh - var(--nav-height));
  display: flex;
  flex-direction: column;
}


/* ── Container ──────────────────────────────────────── */

.l-container {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.l-container--narrow {
  max-width: 680px;
}

.l-container--wide {
  max-width: 1400px;
}


/* ── Grid ───────────────────────────────────────────── */

.l-grid {
  display: grid;
  gap: var(--space-6);
}

.l-grid--2 {
  grid-template-columns: repeat(2, 1fr);
}

.l-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

.l-grid--sidebar {
  grid-template-columns: 240px 1fr;
  min-height: calc(100dvh - var(--nav-height));
}


/* ── App Shell (l-app) ──────────────────────────────── */

.l-app,
.l-app__body {
  display: contents;
}

.l-app[data-layout="admin"] {
  min-height: 100dvh;
  overflow-x: hidden;
}

.l-app[data-layout="admin"] .l-app__body {
  padding-left: 240px;
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}

/* ── Admin Layout ───────────────────────────────────── */

.l-admin__sidebar {
  background-color: var(--marine-800);
  background-image: var(--pattern-marine);
  padding: var(--space-6) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  position: fixed;
  top: 0;
  left: 0;
  width: 240px;
  height: 100dvh;
  overflow-y: auto;
  z-index: 40;
}

.l-admin__sidebar .c-nav__item {
  color: rgba(255, 255, 255, 0.65);
}

.l-admin__sidebar .c-nav__item:hover,
.l-admin__sidebar .c-nav__item--active {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.l-admin__sidebar .c-nav__item--logout {
  color: rgba(255, 255, 255, 0.5);
  background: none;
  border: none;
  font-family: inherit;
  width: 100%;
  text-align: left;
}

.l-admin__sidebar .c-nav__item--logout:hover {
  background: rgba(220, 38, 38, 0.2);
  color: #fca5a5;
}

/* Chevron für Sidebar-Nav-Items mit Submenu */
.c-nav__chevron {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  margin-left: auto;
  opacity: 0.45;
  transition: transform 0.2s ease, opacity 0.2s;
}

.c-nav__item--sub-open .c-nav__chevron {
  transform: rotate(180deg);
  opacity: 0.8;
}

/* Sidebar-Submenu (z.B. E-Mail Vorschau Vorlage-Liste) */
.c-nav__sub {
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding: var(--space-2) 0;
  margin-bottom: var(--space-1);
}

.c-nav__sub .s-email-vorschau__group-label {
  padding-left: var(--space-8);
}

.c-nav__sub .s-email-vorschau__item {
  padding-left: var(--space-8);
}

.l-admin__main {
  padding: var(--space-8) var(--space-6);
  overflow-x: hidden;
  min-width: 0;
}

.l-admin__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
  color: #fff;
  font-weight: var(--weight-bold);
  font-size: var(--text-base);
}

.l-admin__logo {
  width: 100%;
  height: auto;
  filter: drop-shadow(0 1px 6px rgba(255, 255, 255, 0.75))
          drop-shadow(0 0 18px rgba(255, 255, 255, 0.75));
}

.l-admin__sessions-badge {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: rgba(255, 255, 255, 0.07);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: rgba(255, 255, 255, 0.4);
  transition: color 0.3s ease, background 0.3s ease;
  width: 100%;
}

.l-admin__sessions-badge--active {
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.11);
}

.l-admin__sessions-label {
  font-size: 10px;
  font-weight: var(--weight-medium);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.35);
}

.l-admin__sessions-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.l-admin__sessions-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transition: background 0.3s ease, box-shadow 0.3s ease;
}

.l-admin__sessions-badge--active .l-admin__sessions-dot {
  background: #22c55e;
  box-shadow: 0 0 6px rgba(34, 197, 94, 0.7);
  animation: sessions-pulse 2s ease-in-out infinite;
}

@keyframes sessions-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

.l-admin__logout {
  margin-top: auto;
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

/* ── Admin: Dashboard ───────────────────────────────── */

.s-admin-dashboard {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.s-admin-dashboard__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}

.s-admin-dashboard__title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
}

.s-admin-dashboard__actions {
  display: flex;
  gap: var(--space-3);
}

.s-admin-dashboard__export-row {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--space-3);
}

/* ── Admin: Abhol-Code Scanner ──────────────────────── */

.c-admin-abhol-scan {
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.c-admin-abhol-scan__title {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0;
}

.c-admin-abhol-scan__otp {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.c-admin-abhol-scan__otp-digit {
  font-family: var(--font-mono, monospace);
  font-size: var(--text-xl);
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  width: 52px;
  height: 60px;
  padding: 0;
  border: 1.5px solid var(--color-border);
  border-radius: 8px;
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  caret-color: var(--color-primary);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.c-admin-abhol-scan__otp-digit:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}

.c-admin-abhol-scan__otp-digit--filled {
  border-color: color-mix(in srgb, var(--color-primary) 60%, transparent);
}

.c-admin-abhol-scan__result {
  padding: var(--space-3) var(--space-4);
  border-radius: 6px;
  font-size: var(--text-sm);
  border: 1px solid transparent;
}

.c-admin-abhol-scan__result--ok {
  background: var(--color-surface);
  border-color: var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.c-admin-abhol-scan__result--error {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  border-color: var(--color-danger);
}

.c-admin-abhol-scan__info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}

.c-admin-abhol-scan__name {
  font-weight: 600;
  color: var(--color-text);
}

.c-admin-abhol-scan__kz {
  font-family: var(--font-mono, monospace);
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.05em;
}

.c-admin-abhol-scan__status {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 4px;
}

.c-admin-abhol-scan__status--neu           { background: var(--color-warning-bg); color: var(--color-warning); }
.c-admin-abhol-scan__status--bezahlt       { background: var(--color-success-bg); color: var(--color-success); }
.c-admin-abhol-scan__status--abgeschlossen { background: var(--color-surface-raised); color: var(--color-text-muted); }
.c-admin-abhol-scan__status--storniert     { background: var(--color-danger-bg);  color: var(--color-danger); }

.c-admin-abhol-scan__zahl {
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.c-admin-abhol-scan__note {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
}

.c-admin-abhol-scan__actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* ── Admin: Header-Typewriter-Section ───────────────── */

.s-admin-typewriter__heading {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0 0 var(--space-4);
}

.s-admin-typewriter__rows {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.s-admin-typewriter__row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.s-admin-typewriter__label {
  flex: 0 0 90px;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  user-select: none;
}

.s-admin-typewriter__input {
  flex: 1 1 auto;
  font-family: var(--font-mono, monospace);
  font-size: var(--text-sm);
}

.s-admin-typewriter__duration {
  flex: 0 0 64px;
  font-size: var(--text-sm);
  text-align: right;
  -moz-appearance: textfield;
}
.s-admin-typewriter__duration::-webkit-inner-spin-button,
.s-admin-typewriter__duration::-webkit-outer-spin-button {
  opacity: 1;
}

.s-admin-typewriter__unit {
  flex: 0 0 auto;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  user-select: none;
}

.s-admin-typewriter__remove-btn {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-muted);
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.s-admin-typewriter__remove-btn:hover:not(:disabled) {
  border-color: var(--color-danger, #e53e3e);
  color: var(--color-danger, #e53e3e);
  background: var(--color-danger-subtle, #fff5f5);
}
.s-admin-typewriter__remove-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.s-admin-typewriter__add-btn {
  margin-top: var(--space-3);
  padding: var(--space-1) var(--space-3);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  width: 100%;
}
.s-admin-typewriter__add-btn:hover:not(:disabled) {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.s-admin-typewriter__add-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.s-admin-typewriter__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.s-admin-typewriter__preview-wrap {
  flex: 1 1 auto;
  overflow: hidden;
}

.s-admin-typewriter__preview {
  font-family: var(--font-mono, monospace);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ── DSGVO-Compliance-Sektion ───────────────────────── */

.s-dsgvo {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.s-dsgvo__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface-raised, var(--color-surface));
}

.s-dsgvo__header-icon {
  color: var(--color-primary);
  flex-shrink: 0;
}

.s-dsgvo__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
}

.s-dsgvo__subtitle {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-left: auto;
}

.s-dsgvo__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.s-dsgvo__group {
  padding: var(--space-6);
}

.s-dsgvo__group + .s-dsgvo__group {
  border-left: 1px solid var(--color-border);
}

.s-dsgvo__group-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: var(--space-1) var(--space-3);
  border-radius: 999px;
  margin-bottom: var(--space-4);
}

.s-dsgvo__group-label--ok {
  background: color-mix(in srgb, #22c55e 12%, transparent);
  color: #16a34a;
}

.s-dsgvo__group-label--info {
  background: color-mix(in srgb, var(--color-primary) 12%, transparent);
  color: var(--color-primary);
}

.s-dsgvo__group-label--warn {
  background: color-mix(in srgb, #f59e0b 12%, transparent);
  color: #b45309;
}

.s-dsgvo__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.s-dsgvo__item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}

.s-dsgvo__dot {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 5px;
}

.s-dsgvo__dot--ok   { background: #22c55e; }
.s-dsgvo__dot--info { background: var(--color-primary); }
.s-dsgvo__dot--warn { background: #f59e0b; }

.s-dsgvo__item strong {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-1);
}

.s-dsgvo__item p {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.55;
  margin: 0;
}

.s-dsgvo__item a {
  color: var(--color-primary);
  text-decoration: none;
}
.s-dsgvo__item a:hover { text-decoration: underline; }

.s-dsgvo__item code {
  font-family: var(--font-mono, monospace);
  font-size: 0.7rem;
  background: var(--color-border);
  padding: 1px 4px;
  border-radius: 3px;
}

.s-dsgvo__footer {
  border-top: 1px solid var(--color-border);
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.s-dsgvo__footer a {
  color: var(--color-primary);
  text-decoration: none;
}
.s-dsgvo__footer a:hover { text-decoration: underline; }

.s-dsgvo__footer-sep { opacity: 0.35; }

[data-device="mobile"] .s-dsgvo__grid,
[data-device="pad"] .s-dsgvo__grid {
  grid-template-columns: 1fr;
}
[data-device="mobile"] .s-dsgvo__group + .s-dsgvo__group,
[data-device="pad"] .s-dsgvo__group + .s-dsgvo__group {
  border-left: none;
  border-top: 1px solid var(--color-border);
}
[data-device="mobile"] .s-dsgvo__subtitle { display: none; }

/* ── Order Detail ───────────────────────────────────── */

.od-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.od-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

@media (max-width: 768px) {
  .od-grid { grid-template-columns: 1fr; }
}

.od-card {
  background: #f1f3f5;
  border: 1px solid #d1d5db;
  border-radius: 3px;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.od-card__title {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  margin: 0;
}

.od-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-2) var(--space-4);
  margin: 0;
}

.od-dl dt {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: var(--weight-semibold);
  white-space: nowrap;
}

.od-dl dd {
  font-size: var(--text-sm);
  color: var(--color-text);
  margin: 0;
}

.od-card--hint {
  border-left: 3px solid var(--color-warning);
  background: #fffbeb;
}

.od-card--hint .od-card__title {
  color: #92400e;
}

/* ── Lieferung-Countdown-Banner ──────────────────────── */
.od-delivery-banner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-5);
  border-radius: var(--radius-md);
  background: rgba(230, 57, 70, 0.1);
  border: 2px solid #e63946;
}

.od-delivery-banner--expired {
  background: rgba(100, 100, 100, 0.08);
  border-color: var(--color-text-muted);
}

.od-delivery-banner__icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  color: #e63946;
}

.od-delivery-banner--expired .od-delivery-banner__icon {
  color: var(--color-text-muted);
}

.od-delivery-banner__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.od-delivery-banner__label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #e63946;
}

.od-delivery-banner--expired .od-delivery-banner__label {
  color: var(--color-text-muted);
}

.od-delivery-banner__time {
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
  color: #e63946;
  line-height: 1.1;
}

.od-delivery-banner--expired .od-delivery-banner__time {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  font-weight: 600;
}

/* ── Lieferschein (Modal + Druck) ───────────────────── */
.c-lieferschein {
  font-family: Arial, Helvetica, sans-serif;
  color: #000;
  background: #fff;
  min-width: 340px;
}
.c-lieferschein__section {
  margin-bottom: 18px;
}
.c-lieferschein__section-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #555;
  border-bottom: 1px solid #bbb;
  padding-bottom: 3px;
  margin-bottom: 7px;
}
.c-lieferschein__row {
  display: flex;
  gap: 8px;
  margin-bottom: 3px;
  font-size: 13px;
}
.c-lieferschein__label {
  font-weight: 700;
  min-width: 90px;
  flex-shrink: 0;
  color: #000;
}
.c-lieferschein__value {
  color: #111;
}
.c-lieferschein__kfz {
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 4px;
  border: 3px solid #000;
  display: inline-block;
  padding: 6px 18px;
  border-radius: 5px;
  margin: 4px 0 2px;
  font-family: 'DINAlternate', 'Arial Narrow', Arial, sans-serif;
}
.c-lieferschein__deadline {
  font-size: 14px;
  font-weight: 700;
  border: 2px solid #000;
  padding: 6px 12px;
  display: inline-block;
  margin-top: 5px;
}
.c-lieferschein__print-btn {
  display: block;
  width: 100%;
  margin-top: 20px;
}

/* ── Umsatz-Auswertung (Rechnungen-Seite) ───────────── */
.s-umsatz {
  padding-top: 0;
}
.s-umsatz__header {
  display: flex;
  align-items: center;
  margin-bottom: var(--space-4);
}
.s-umsatz__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
}
.s-umsatz__tabs {
  display: flex;
  gap: var(--space-2);
}
.s-umsatz__tab {
  padding: 5px 16px;
  font-size: var(--text-sm);
  font-weight: 600;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: background var(--duration-fast), color var(--duration-fast), border-color var(--duration-fast);
}
.s-umsatz__tab:hover {
  background: var(--color-surface-hover);
  color: var(--color-text);
}
.s-umsatz__tab--active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.s-umsatz__loading {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  padding: var(--space-6) 0;
}
.s-umsatz__empty {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  padding: var(--space-4) 0;
  margin: 0;
}
.s-umsatz__kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  margin-top: var(--space-4);
}
.s-umsatz__kpi {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-top: 3px solid var(--color-primary);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  min-width: 0;
  flex: 1;
  transition: box-shadow var(--duration-fast);
}
.s-umsatz__kpi:hover {
  box-shadow: 0 2px 12px color-mix(in srgb, var(--color-primary) 12%, transparent);
}
.s-umsatz__kpi-value {
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.s-umsatz__kpi-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
}
.s-umsatz__bars {
  display: flex;
  gap: var(--space-8);
  align-items: flex-end;
  height: 120px;
  margin-bottom: var(--space-8);
}
.s-umsatz__bar-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex: 1;
}
.s-umsatz__bar {
  width: 100%;
  min-height: 4px;
  background: var(--color-primary);
  opacity: 0.35;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  transition: height var(--duration-normal);
}
.s-umsatz__bar--today {
  opacity: 1;
}
.s-umsatz__bar-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--color-text-muted);
}
.s-umsatz__bar-val {
  font-size: 10px;
  font-variant-numeric: tabular-nums;
  color: var(--color-text-muted);
  text-align: center;
}
.s-umsatz__bar-cnt {
  font-size: 10px;
  color: var(--color-primary);
  font-weight: 700;
}
/* Woche-Tabelle */
.s-umsatz__week-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  margin-top: var(--space-4);
}
.s-umsatz__week-table th {
  text-align: left;
  padding: var(--space-2) var(--space-3);
  border-bottom: 2px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
}
.s-umsatz__week-table td {
  padding: 10px var(--space-3);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
}
.s-umsatz__week-table tr:last-child td {
  border-bottom: none;
}
.s-umsatz__week-row--today td {
  background: color-mix(in srgb, var(--color-primary) 8%, transparent);
  font-weight: 600;
}

/* Period-Kacheln (Monate / Jahre) */
.s-umsatz__period-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-4);
}
.s-umsatz__period-grid--years {
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.s-umsatz__period-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast);
}
.s-umsatz__period-card:hover {
  border-color: var(--color-primary);
  box-shadow: 0 2px 12px color-mix(in srgb, var(--color-primary) 10%, transparent);
}
.s-umsatz__period-name {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.s-umsatz__period-revenue {
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  margin-top: var(--space-1);
}
.s-umsatz__period-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border);
}
.s-umsatz__period-avg {
  font-weight: 600;
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}

/* Delivery deadline subtext in orders table */
.c-table__delivery-deadline {
  display: block;
  margin-top: 3px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #f4a261;
  font-variant-numeric: tabular-nums;
  animation: countdown-blink 2.4s ease-in-out infinite;
}
.c-table__delivery-deadline--urgent {
  color: #f4a261;
}
.c-table__delivery-deadline--overdue {
  color: #e63946;
}

.od-status-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding: var(--space-4) var(--space-5);
  background: #f1f3f5;
  border: 1px solid #d1d5db;
  border-radius: 3px;
  margin-top: var(--space-4);
}

.od-status-bar__label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  white-space: nowrap;
}

/* ── Admin-Einstellungsformular ─────────────────────── */

.c-settings-section {
  background: #f1f3f5;
  border: 1px solid #d1d5db;
  border-radius: 3px;
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-3);
}

.c-settings-section__title {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 var(--space-3);
}

summary.c-settings-section__title {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  user-select: none;
}
summary.c-settings-section__title::-webkit-details-marker { display: none; }
summary.c-settings-section__title::before {
  content: '▶';
  font-size: 0.45rem;
  transition: transform 0.2s ease;
  transform: rotate(90deg);
}
details:not([open]) > summary.c-settings-section__title {
  margin-bottom: 0;
}
details:not([open]) > summary.c-settings-section__title::before {
  transform: rotate(0deg);
}

.c-settings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  row-gap: var(--space-1);
  column-gap: var(--space-3);
}

.c-field {
  grid-column: span 2;
}

.c-field--half {
  grid-column: span 1;
}

.c-field__input {
  padding: var(--space-2) var(--space-2);
  background: #ffffff;
  border: 1px solid #d1d5db;
  border-radius: 3px;
  font-size: var(--text-sm);
  color: var(--color-text);
  font-family: inherit;
  height: 36px;
  width: 100%;
  transition: border-color 0.15s;
}

.c-field__input::placeholder {
  color: var(--color-text-muted);
  opacity: 0.65;
}

.c-field__input:focus {
  outline: none;
  border-color: var(--color-primary);
}

.c-field__hint {
  display: block;
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-snug);
}

.c-settings-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: var(--space-3);
}

.c-settings-section__hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: calc(var(--space-1) * -1);
  margin-bottom: var(--space-2);
}

/* ── Collapsible block ───────────────────────────────────────────────────── */
.c-collapse {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}

.c-collapse__trigger {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  cursor: pointer;
  user-select: none;
  list-style: none;
}

.c-collapse__trigger::before {
  content: '▶';
  font-size: var(--text-xs);
  transition: transform 150ms ease;
  flex-shrink: 0;
}

.c-collapse[open] .c-collapse__trigger::before {
  transform: rotate(90deg);
}

.c-collapse[open] .c-settings-section {
  padding: 0 var(--space-4) var(--space-4);
}

.c-field__label {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.c-field__currency-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.c-field__input--currency {
  padding-right: var(--space-5);
}

.c-field__currency-suffix {
  position: absolute;
  right: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  pointer-events: none;
}

@media (max-width: 600px) {
  .c-settings-grid {
    grid-template-columns: 1fr;
  }
  .c-field,
  .c-field--half {
    grid-column: span 1;
  }
}


/* ══════════════════════════════════════════════════════
   7. SEITEN-LAYOUTS
   ══════════════════════════════════════════════════════ */

/* ── Konfigurator (/) ───────────────────────────────── */

.s-konfigurator {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-10) var(--space-6);
  gap: var(--space-8);
}

.s-konfigurator__stage {
  width: 100%;
  max-width: 640px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.s-konfigurator__controls {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.s-konfigurator__sizes {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  justify-content: center;
}

.s-konfigurator__cta {
  width: 100%;
  max-width: 320px;
}


/* ── Checkout (/checkout) ───────────────────────────── */

.s-checkout {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.s-checkout__inner {
  width: 100%;
  max-width: 520px;
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* Step indicator */
.s-checkout__steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--color-border);
}

.s-checkout__step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

.s-checkout__step-num {
  width: 32px;
  height: 32px;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  background: #c5e8f7;
  color: var(--color-text-muted);
  border: 2px solid #c5e8f7;
  transition: background var(--transition-base), color var(--transition-base), border-color var(--transition-base);
}

.s-checkout__step-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: var(--weight-medium);
  transition: color var(--transition-base);
  white-space: nowrap;
}

.s-checkout__step--active .s-checkout__step-num {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

.s-checkout__step--active .s-checkout__step-label {
  color: var(--color-primary);
  font-weight: var(--weight-bold);
}

.s-checkout__step--done .s-checkout__step-num {
  background: var(--baby-blue, #89cff0);
  color: var(--color-primary);
  border-color: var(--baby-blue, #89cff0);
}

.s-checkout__step--done .s-checkout__step-label {
  color: var(--color-text-muted);
}

.s-checkout__step-line {
  flex: 1;
  height: 2px;
  background: var(--color-border);
  margin-top: 15px;
  min-width: var(--space-6);
  transition: background var(--transition-base);
}

.s-checkout__step--done + .s-checkout__step-line,
.s-checkout__step--active + .s-checkout__step-line {
  background: var(--color-primary);
}

/* Card container */
.s-checkout__card {
  position: relative;
  top: 45px;
  overflow: hidden;
}

/* Sliding viewport */
.s-checkout__viewport {
  overflow: hidden;
  transition: height 220ms ease;
}

.s-checkout__track {
  display: flex;
  width: 300%;
  --checkout-step: 0;
  transform: translateX(calc(var(--checkout-step) * (-100% / 3)));
  transition: transform 320ms cubic-bezier(0.4, 0, 0.2, 1);
}

@media (prefers-reduced-motion: reduce) {
  .s-checkout__track {
    transition: none;
  }
}

/* Individual panel */
.s-checkout__panel {
  width: calc(100% / 3);
  flex-shrink: 0;
  padding: var(--space-5) var(--space-6) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  box-sizing: border-box;
}

.s-checkout__panel-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 0 var(--space-1);
}

.s-checkout__panel-title {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--color-text);
  margin: 0;
}

.s-checkout__print-actions {
  display: flex;
  gap: var(--space-2);
}

.s-checkout__print-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.s-checkout__print-btn svg {
  width: 18px;
  height: 18px;
}

.s-checkout__print-btn:hover {
  color: var(--color-text);
  border-color: var(--color-text-muted);
  background: var(--color-surface-hover, rgba(0,0,0,0.04));
}

.s-checkout__print-btn:active {
  opacity: 0.75;
}

/* 2-column grid inside panels */
.s-checkout__grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

/* Form vertical spacing */
[data-form="checkout-address"] {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* Touch-target inputs */
.s-checkout__label {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.s-checkout__field {
  height: 44px;
  background: #eef6fc;
}

.s-checkout__field--invalid {
  border-color: var(--color-danger, #ef4444) !important;
  background: #fff5f5 !important;
}

.s-checkout__field-error {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-danger, #ef4444);
  margin-top: var(--space-1);
}

/* Required indicator */
.s-checkout__required {
  color: var(--color-danger);
  margin-left: 1px;
}

/* Panel action buttons */
.s-checkout__actions {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}

.s-checkout__btn-primary {
  flex: 1;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  overflow: hidden;
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: 3px;
  font-size: var(--text-base);
  font-weight: var(--weight-bold);
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), opacity var(--transition-fast);
}

.s-checkout__btn-primary:hover {
  opacity: 0.88;
}

.s-checkout__btn-primary:active {
  opacity: 0.75;
}

.s-checkout__btn-primary:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  pointer-events: none;
}

.s-checkout__btn-primary--outline {
  background: transparent;
  color: var(--marine-400);
  border: 2px solid var(--marine-400);
}

.s-checkout__btn-primary--outline:hover {
  background: var(--marine-400);
  color: var(--cream-50);
  opacity: 1;
}

.s-checkout__btn-primary--outline:active {
  background: var(--marine-500);
  border-color: var(--marine-500);
  color: var(--cream-50);
  opacity: 1;
}

/* CTA — Zahlungspflichtig bestellen */
.s-checkout__btn-primary--cta {
  background: #16a34a;
  height: 54px;
  font-size: var(--text-lg);
  border-radius: 4px;
  animation: cta-pulse 2.6s ease-in-out infinite;
}
.s-checkout__btn-primary--cta:hover {
  background: #15803d;
  opacity: 1;
  animation: none;
  box-shadow: 0 4px 18px rgba(22, 163, 74, 0.45);
}
.s-checkout__btn-primary--cta:active {
  background: #166534;
  opacity: 1;
}

@keyframes cta-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(22, 163, 74, 0.45); }
  55%       { box-shadow: 0 0 0 10px rgba(22, 163, 74, 0); }
}

.s-checkout__btn-ghost--back {
  height: 54px;
  font-size: var(--text-base);
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  color: var(--color-text-muted);
  padding: 0 var(--space-5);
  gap: var(--space-2);
  flex: 0 0 auto;
}
.s-checkout__btn-ghost--back:hover {
  background: transparent;
  border-color: #dc2626;
  color: #dc2626;
  opacity: 1;
  animation: back-spring 0.4s ease-out forwards;
}
.s-checkout__btn-ghost--back:active {
  background: rgba(220, 38, 38, 0.06);
  border-color: #b91c1c;
  color: #b91c1c;
  opacity: 1;
}

@keyframes back-spring {
  0%   { transform: translateX(0); }
  25%  { transform: translateX(-7px); }
  55%  { transform: translateX(3px); }
  75%  { transform: translateX(-3px); }
  90%  { transform: translateX(1px); }
  100% { transform: translateX(0); }
}

.s-checkout__btn-primary--success {
  background: var(--color-success, #22c55e);
  border: none;
  color: #fff;
  opacity: 1;
}

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

.s-checkout__spinner {
  width: 16px;
  height: 16px;
  animation: s-checkout-spin 0.7s linear infinite;
  flex-shrink: 0;
}

.s-checkout__btn-ghost {
  height: 54px;
  padding: 0 var(--space-5);
  background: transparent;
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: border-color var(--transition-fast), color var(--transition-fast);
}

.s-checkout__btn-ghost:hover {
  border-color: var(--color-text-muted);
  color: var(--color-text);
}

/* Delivery options (ABHOLUNG / LIEFERADRESSE) */
.s-checkout__delivery-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.s-checkout__delivery-card,
.s-checkout__pay-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-border);
  border-radius: 3px;
  cursor: pointer;
  background: #eef6fc;
  transition: border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
  position: relative;
  user-select: none;
}

.s-checkout__delivery-card:hover,
.s-checkout__pay-card:hover {
  border-color: var(--color-primary);
  background: hsl(240 100% 50% / 0.03);
}

.s-checkout__pay-card--disabled {
  opacity: 0.38;
  pointer-events: none;
}

.s-checkout__pay-hint {
  display: block;
  margin-top: 3px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
}

.s-checkout__delivery-card:has(.s-checkout__pay-radio:checked),
.s-checkout__pay-card:has(.s-checkout__pay-radio:checked) {
  border-color: var(--marine-600);
  background: var(--marine-600);
  box-shadow: 0 2px 12px rgba(26, 61, 122, 0.25);
  color: #fff;
}

.s-checkout__delivery-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-name,
.s-checkout__pay-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-name,
.s-checkout__delivery-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-desc,
.s-checkout__pay-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-desc,
.s-checkout__delivery-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-icon,
.s-checkout__pay-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-icon {
  color: #fff;
}

.s-checkout__delivery-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-indicator,
.s-checkout__pay-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-indicator {
  border-color: rgba(255, 255, 255, 0.6);
}

.s-checkout__delivery-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-indicator::after,
.s-checkout__pay-card:has(.s-checkout__pay-radio:checked) .s-checkout__pay-indicator::after {
  opacity: 1;
  transform: scale(1);
  background: #fff;
}

/* Address fields – per JS dynamisch in den DOM eingefügt, dann animiert */
.s-checkout__address-fields {
  display: grid;
  gap: var(--space-2);
}
.s-checkout__address-fields--open {
  max-height: none;
  opacity: 1;
}
.s-checkout__address-hint {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-secondary);
  margin: 0;
}
.s-checkout__optional {
  font-weight: 400;
  color: var(--text-muted);
  font-size: var(--text-xs);
}

/* Abweichende Lieferadresse (Toggle-gesteuert) */
.s-checkout__lieferadresse {
  border-top: 1px solid var(--border);
  padding-top: var(--space-3);
  margin-top: var(--space-2);
}
.s-checkout__lieferadresse__fields {
  display: grid;
  gap: var(--space-4);
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 380ms ease, opacity 280ms ease, padding-top 280ms ease;
  padding-top: 0;
}
.s-checkout__lieferadresse:has(.c-toggle__input:checked) .s-checkout__lieferadresse__fields {
  max-height: 600px;
  opacity: 1;
  padding-top: var(--space-4);
}

/* Payment options */
.s-checkout__payment-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.s-checkout__pay-radio {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Custom radio circle */
.s-checkout__pay-indicator {
  width: 18px;
  height: 18px;
  border-radius: 3px;
  border: 2px solid var(--color-border);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 180ms ease;
  position: relative;
}

.s-checkout__pay-indicator::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 1px;
  background: var(--color-primary);
  opacity: 0;
  transform: scale(0);
  transition: opacity 180ms ease, transform 180ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Payment icon */
.s-checkout__pay-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-text-muted);
}

.s-checkout__pay-icon svg {
  width: 22px;
  height: 22px;
}

/* ── Upsell-Zwischenseite (/upsell) ─────────────────── */

.s-upsell {
  flex: 1;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.s-upsell__inner {
  width: 100%;
  max-width: 560px;
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.s-upsell__card {
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.s-upsell__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.s-upsell__badge {
  display: inline-block;
  background: var(--color-accent-subtle);
  color: var(--color-primary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-4);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}

.s-upsell__step-hint {
  font-size: var(--text-sm);
  color: var(--color-text-subtle);
}

.s-upsell__title {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  line-height: 1.25;
  margin: 0;
  color: var(--color-text);
}

.s-upsell__subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: calc(-1 * var(--space-2)) 0 0;
  line-height: 1.5;
}

.s-upsell__product {
  display: flex;
  gap: var(--space-5);
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  align-items: flex-start;
}

.s-upsell__product-icon {
  flex-shrink: 0;
  width: 96px;
  height: 96px;
  background: var(--color-accent-subtle);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  overflow: hidden;
}

.s-upsell__plakette-wrap {
  position: relative;
  width: 100%;
  height: 100%;
}

.s-upsell__plakette-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.s-upsell__plakette-kz {
  position: absolute;
  left: 16.3%;
  top: 50%;
  width: 67.4%;
  height: 22.4%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'EuroPlate', 'FE-Font', monospace;
  font-size: 12px;
  color: #111;
  white-space: nowrap;
  overflow: hidden;
  letter-spacing: 0.05em;
}

.s-upsell__product-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.s-upsell__product-name {
  font-size: var(--text-base);
  font-weight: var(--weight-bold);
  color: var(--color-text);
}

.s-upsell__product-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
  margin: 0;
}

.s-upsell__product-price {
  display: inline-block;
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--color-primary);
  margin-top: var(--space-1);
}

/* ── Upsell — Grünes Thema (Feinstaubplakette) ──────── */

.s-upsell__badge--green {
  background: #d1fae5;
  color: #065f46;
  border-color: #a7f3d0;
}

.s-upsell__product--green {
  background: #f0fdf4;
  border: 1.5px solid #bbf7d0;
}

.s-upsell__product-icon--green {
  background: transparent;
  color: #059669;
}

.s-upsell__product-name--green {
  color: #065f46;
  font-size: var(--text-base);
  line-height: 1.35;
}

.s-upsell__product-price--green {
  color: #059669;
}

/* Hinweis-Box */
.s-upsell__hint {
  display: flex;
  gap: var(--space-3);
  background: #10b981;
  border: 1px solid rgba(255,255,255,0.3);
  border-left: 3px solid #ffffff;
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  margin-top: var(--space-1);
}

.s-upsell__hint-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  color: #ffffff;
  margin-top: 2px;
}

.s-upsell__hint-title {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: #ffffff;
  margin-bottom: var(--space-1);
}

.s-upsell__hint-text {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.9);
  line-height: 1.55;
  margin: 0;
}

/* Accept-Button grün */
.s-upsell__btn-accept {
  flex: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: #10b981;
  color: #ffffff;
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  cursor: pointer;
  transition: background 150ms ease, transform 100ms ease;
  white-space: nowrap;
}

.s-upsell__btn-accept:hover {
  background: #059669;
}

.s-upsell__btn-accept:active {
  transform: scale(0.98);
}

.s-upsell__btn-accept:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}


.s-upsell__actions {
  display: flex;
  align-items: stretch;
  gap: var(--space-3);
  padding-top: var(--space-2);
}

.s-upsell__actions .s-checkout__btn-ghost {
  flex: 1;
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #065f46;
}

.s-upsell__actions .s-checkout__btn-ghost:hover {
  background: #d1fae5;
  border-color: #6ee7b7;
  color: #064e3b;
}

[data-theme="dark"] .s-upsell__actions .s-checkout__btn-ghost {
  background: rgba(16, 185, 129, 0.08);
  border-color: rgba(16, 185, 129, 0.25);
  color: #6ee7b7;
}

[data-theme="dark"] .s-upsell__actions .s-checkout__btn-ghost:hover {
  background: rgba(16, 185, 129, 0.15);
  border-color: rgba(16, 185, 129, 0.4);
  color: #a7f3d0;
}

/* ── Upsell Mobile ──────────────────────────────────── */
@media (max-width: 609px) {
  .s-upsell__card {
    padding: var(--space-4);
    gap: var(--space-3);
  }

  .s-upsell__title {
    font-size: var(--text-lg);
  }

  .s-upsell__subtitle {
    font-size: var(--text-xs);
  }

  .s-upsell__product {
    flex-direction: column;
    align-items: center;
    padding: var(--space-3);
    gap: var(--space-3);
  }

  .s-upsell__product-icon {
    width: 72px;
    height: 72px;
  }

  .s-upsell__product-name {
    font-size: var(--text-sm);
    text-align: center;
  }

  .s-upsell__product-desc {
    font-size: var(--text-xs);
  }

  .s-upsell__hint {
    padding: var(--space-2) var(--space-3);
  }

  .s-upsell__hint-title {
    font-size: 0.65rem;
  }

  .s-upsell__hint-text {
    font-size: 0.65rem;
  }

  .s-upsell__actions {
    flex-direction: column;
    gap: var(--space-2);
  }

  .s-upsell__btn-accept {
    order: -1;
    font-size: var(--text-sm);
    padding: var(--space-3);
    white-space: normal;
  }

  .s-upsell__actions [data-action="upsell-back"] {
    order: 1;
  }

  .s-upsell__actions .s-checkout__btn-ghost {
    font-size: var(--text-xs);
    padding: var(--space-2);
  }
}

.s-upsell__actions .s-checkout__btn-primary {
  flex: 2;
  font-size: var(--text-lg);
}

/* ── Print / PDF ────────────────────────────────────── */

/* Print-Fallback für kfz-kennzeichen (im normalen View versteckt) */
.c-invoice__kfz-print {
  display: none;
}

@media print {
  body * {
    visibility: hidden;
  }
  .c-invoice,
  .c-invoice * {
    visibility: visible;
  }
  .c-lieferschein,
  .c-lieferschein * {
    visibility: visible;
  }
  .c-lieferschein {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: #fff;
    padding: 20px;
  }
  .c-lieferschein__print-btn,
  .c-modal__header {
    display: none !important;
  }
  .c-invoice {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    box-shadow: none;
    border: none;
  }
  /* Shadow DOM von kfz-kennzeichen wird beim Drucken nicht gerendert → ausblenden */
  .c-invoice kfz-kennzeichen {
    display: none !important;
  }
  /* Text-basierter Kennzeichen-Fallback für Print */
  .c-invoice__head-right {
    position: relative;
  }
  .c-invoice__kfz-print {
    display: flex !important;
    visibility: visible !important;
    position: absolute;
    top: 0;
    right: 0;
    align-items: center;
    height: 22px;
    border: 1px solid #000;
    border-radius: 3px;
    overflow: hidden;
    background: #fff;
    min-width: 80px;
  }
  .c-invoice__kfz-print-eu {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    min-width: 14px;
    height: 100%;
    background: #003399;
    color: #fff;
    font-size: 5pt;
    font-weight: bold;
    border-right: 1px solid #000;
  }
  .c-invoice__kfz-print-text {
    flex: 1;
    text-align: center;
    font-size: 10pt;
    font-weight: 900;
    letter-spacing: 1px;
    padding: 0 4px;
    color: #000;
    font-family: 'Arial Narrow', Arial, sans-serif;
    white-space: nowrap;
  }
}


.s-checkout__pay-icon--stripe {
  color: #635bff;
}

/* Stripe Payment Element container */
.s-checkout__stripe-element {
  margin-top: var(--space-4);
  padding: var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-2);
}

/* PayPal button container — Untermenü-Style */
.s-checkout__paypal-container {
  margin-top: var(--space-3);
  padding: var(--space-4) var(--space-4) var(--space-3);
  border: 1px solid var(--border);
  border-left: 3px solid #009cde;
  border-radius: var(--radius-md);
  background: var(--surface-2);
}

.s-checkout__paypal-container::before {
  content: 'Zahlungsmethode wählen';
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

/* Payment text */
.s-checkout__pay-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.s-checkout__pay-name {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--color-text);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.s-checkout__pay-name-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.s-checkout__countdown {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  font-variant-numeric: tabular-nums;
  text-transform: uppercase;
  padding: 1px 7px;
  border-radius: 3px;
  background: #fff;
  border: 1.5px solid currentColor;
  line-height: 1.6;
}
.s-checkout__countdown--open         { color: #2a9d5e; }
.s-checkout__countdown--closing-soon { color: #e63946; animation: countdown-blink 2.4s ease-in-out infinite; }
.s-checkout__countdown--soon         { color: #f4a261; }
.s-checkout__countdown--closed       { color: var(--color-text-muted); }

@keyframes countdown-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.35; }
}

.s-checkout__pay-desc {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.4;
}

.s-checkout__addr-hours {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  margin-top: var(--space-1);
}

.s-checkout__addr-divider {
  width: 1px;
  align-self: stretch;
  flex-shrink: 0;
  background: var(--color-border);
  opacity: 0.5;
}

.s-checkout__hours {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.s-checkout__hours-row {
  display: flex;
  gap: var(--space-2);
  font-size: 11px;
  color: #fff;
  line-height: 1.4;
}

.s-checkout__hours-day {
  min-width: 44px;
  font-weight: 500;
  opacity: 0.75;
}

.s-checkout__express-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: var(--space-2);
  padding: 3px 8px;
  background: rgba(244, 162, 97, 0.12);
  border: 1px solid rgba(244, 162, 97, 0.35);
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 700;
  color: #f4a261;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.s-checkout__express-badge svg {
  width: 11px;
  height: 11px;
  flex-shrink: 0;
}

.s-checkout__express-note {
  display: block;
  margin-top: 5px;
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--color-text-muted);
}

.s-checkout__route-link {
  display: none;
}

@media (max-width: 609px) {
  /* Countdown unter den Namen, nicht daneben */
  .s-checkout__pay-name-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 3px;
  }

  /* Adresse + Öffnungszeiten untereinander statt nebeneinander */
  .s-checkout__addr-hours {
    flex-direction: column;
    gap: var(--space-2);
  }

  /* Vertikale Trennlinie entfällt auf Mobile */
  .s-checkout__addr-divider {
    display: none;
  }

  .s-checkout__route-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    margin-top: var(--space-1);
    font-size: var(--text-xs);
    color: var(--color-primary);
    text-decoration: none;
    font-weight: var(--font-medium);
    /* Touch target: min 44×44px */
    min-height: 44px;
    padding: 0 var(--space-2);
    margin-left: calc(-1 * var(--space-2));
  }
  .s-checkout__route-link svg {
    width: 12px;
    height: 12px;
    flex-shrink: 0;
  }
  .s-checkout__route-link:active {
    opacity: 0.7;
  }
}


/* ── Legal (/impressum, /datenschutz) ───────────────── */

[data-page="legal"] .c-header-badge {
  display: none;
}

[data-page="legal"] main {
  justify-content: flex-start;
  padding-top: calc(var(--header-height) + var(--space-10));
  padding-bottom: var(--space-16);
}

.s-legal__back {
  display: inline-block;
  margin-bottom: var(--space-6);
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-decoration: none;
}

.s-legal__back:hover {
  color: var(--color-text);
}

.s-legal__title {
  font-size: 1.75rem;
  font-weight: 700;
  margin-bottom: var(--space-8);
  color: var(--color-text);
}

.s-legal__section {
  margin-bottom: var(--space-8);
}

.s-legal__section h2 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: var(--space-3);
  color: var(--color-text);
}

.s-legal__section p,
.s-legal__section ul {
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}

.s-legal__section ul {
  padding-left: var(--space-6);
}

.s-legal__section li {
  margin-bottom: var(--space-1);
}

.s-legal__section a {
  color: var(--color-primary);
  text-decoration: none;
}

.s-legal__section a:hover {
  text-decoration: underline;
}

.s-legal__section code {
  font-family: monospace;
  font-size: 0.875em;
  background: var(--color-surface-raised);
  padding: 0.1em 0.4em;
  border-radius: var(--radius-sm);
}

.s-legal__cert {
  margin: var(--space-5) 0 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
}

.s-legal__cert img {
  border-radius: var(--radius-sm);
  background: #fff;
  padding: var(--space-2);
}

.s-legal__cert figcaption {
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.s-legal__section--highlight {
  background: color-mix(in srgb, var(--color-warning, #f59e0b) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--color-warning, #f59e0b) 30%, transparent);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6);
  margin-bottom: var(--space-2);
}

.s-legal__section--highlight h2 {
  color: color-mix(in srgb, var(--color-warning, #f59e0b) 80%, var(--color-text));
}

.s-legal__section address {
  font-style: normal;
  margin: var(--space-4) 0;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface-raised);
  border-left: 3px solid var(--color-primary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  line-height: 1.7;
}

.s-legal__quote {
  margin: var(--space-4) 0 0;
  padding: var(--space-4) var(--space-5);
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--color-text-muted);
}

.s-legal__quote p {
  margin: 0 0 var(--space-3);
}

.s-legal__quote p:last-child {
  margin-bottom: 0;
}


/* ── Rechnung (/rechnung/:id) ───────────────────────── */

.s-rechnung {
  padding: calc(var(--header-height) + var(--space-10)) var(--space-6) var(--space-10);
}

.s-rechnung__header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.s-rechnung__title {
  font-size: var(--text-2xl);
  font-weight: 600;
  flex: 1;
}

@media print {
  .s-rechnung__header .c-btn { display: none; }
}


/* ── Bestellung (/bestellung/:id) ───────────────────── */

.s-bestellung {
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--header-height) + var(--space-10)) var(--space-6) var(--space-10);
}

.s-bestellung__card {
  max-width: 560px;
  margin-inline: auto;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  padding: var(--space-10);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  text-align: center;
}

.s-bestellung__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  margin-inline: auto;
  background: var(--color-success-bg);
  border-radius: 50%;
  color: var(--color-success);
}

.s-bestellung__icon svg {
  width: 32px;
  height: 32px;
}

.s-bestellung__plate {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.s-bestellung__fsp {
  position: relative;
  display: inline-block;
  line-height: 0;
}

.s-bestellung__fsp-kz {
  position: absolute;
  left: 16%;
  top: 50%;
  width: 68%;
  height: 23%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono, 'FE-Schrift', monospace);
  font-size: 9px;
  font-weight: 700;
  color: #000;
  letter-spacing: 0.04em;
  white-space: nowrap;
  overflow: hidden;
  pointer-events: none;
}

.s-bestellung__abholung {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  background: var(--color-info-bg);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  padding: var(--space-4) var(--space-5);
  text-align: left;
}

.s-bestellung__abholung-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  margin-top: 2px;
  color: var(--color-info);
}

.s-bestellung__abholung-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--text-sm);
}

.s-bestellung__abholung-body strong {
  font-size: var(--text-base);
}

.s-bestellung__abholung-address {
  font-style: normal;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.s-bestellung__maps-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  color: var(--color-info);
  font-weight: 500;
  text-decoration: none;
  width: fit-content;
}

.s-bestellung__maps-link:hover {
  text-decoration: underline;
}

.s-bestellung__actions {
  display: flex;
  justify-content: center;
  gap: var(--space-4);
  margin-top: var(--space-6);
}


/* ── Bestellung Mobile ──────────────────────────────── */
@media (max-width: 609px) {
  .s-bestellung {
    padding: calc(var(--header-height) + var(--space-6)) var(--space-3) var(--space-6);
    align-items: stretch;
  }

  .s-bestellung__card {
    padding: var(--space-5) var(--space-4);
    gap: var(--space-4);
  }

  .s-bestellung__icon {
    width: 48px;
    height: 48px;
  }

  .s-bestellung__icon svg {
    width: 24px;
    height: 24px;
  }

  .s-bestellung__abholung {
    padding: var(--space-3) var(--space-3);
    gap: var(--space-2);
  }

  .s-bestellung__abholung-body {
    font-size: var(--text-xs);
  }

  .s-bestellung__abholung-body strong {
    font-size: var(--text-sm);
  }

  .s-bestellung__plate kfz-kennzeichen {
    --kfz-scale: 0.35 !important;
  }

  .s-bestellung__card h1 {
    font-size: var(--text-lg);
  }

  .s-bestellung__card p {
    font-size: var(--text-xs);
    word-break: break-all;
  }

  .s-bestellung__actions {
    flex-direction: column;
    gap: var(--space-2);
    margin-top: var(--space-3);
  }

  .s-bestellung__actions .c-btn {
    width: 100%;
    justify-content: center;
    font-size: var(--text-sm);
  }
}

/* ── Legal Mobile (Impressum, Datenschutz, Widerruf) ── */
@media (max-width: 609px) {
  [data-page="legal"] main {
    padding: calc(var(--header-height) + var(--space-6)) var(--space-4) var(--space-10);
  }

  .s-legal__title {
    font-size: 1.25rem;
    margin-bottom: var(--space-5);
  }

  .s-legal__section {
    margin-bottom: var(--space-5);
  }

  .s-legal__section h2 {
    font-size: var(--text-sm);
  }

  .s-legal__section p,
  .s-legal__section ul {
    font-size: var(--text-xs);
    line-height: 1.6;
  }

  .s-legal__section ul {
    padding-left: var(--space-4);
  }

  .s-legal__section--highlight {
    padding: var(--space-3) var(--space-4);
  }

  .s-legal__section address {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-xs);
  }

  .s-legal__quote {
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-xs);
  }

  .s-legal__back {
    font-size: var(--text-xs);
  }
}

/* ── Rechnung Mobile ────────────────────────────────── */
@media (max-width: 609px) {
  .s-rechnung {
    padding: calc(var(--header-height) + var(--space-6)) var(--space-3) var(--space-6);
  }

  .s-rechnung__header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
  }

  .s-rechnung__title {
    font-size: var(--text-lg);
  }
}

/* ── Admin Login Mobile ─────────────────────────────── */
@media (max-width: 609px) {
  .s-admin-login__card {
    margin: 0 var(--space-3);
    padding: var(--space-6);
  }

  .s-admin-login__title {
    font-size: var(--text-lg);
  }
}

/* ── Admin Login (/admin/login) ─────────────────────── */

.s-admin-login {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-6);
}

.s-admin-login__card {
  width: 100%;
  max-width: 400px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  padding: var(--space-10);
  box-shadow: var(--shadow-lg);
}

.s-admin-login__title {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-text);
  margin-bottom: var(--space-8);
  text-align: center;
}

.s-admin-login__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.s-admin-login__form .c-input__field,
.s-admin-login__form .c-btn {
  width: 100%;
  height: 48px;
  box-sizing: border-box;
  font-size: 1rem;
}


/* ══════════════════════════════════════════════════════
   8. TOAST
   ══════════════════════════════════════════════════════ */

/* <c-toast> Web Component Host */
.c-toast--error {
  border-color: var(--color-danger);
  background: var(--color-danger-bg);
}

c-toast {
  position: fixed;
  inset: 0;
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  pointer-events: none;
}

.c-toast__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: 3px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
  font-size: var(--text-sm);
  max-width: 360px;
  width: max-content;
  pointer-events: all;
  animation: toast-in var(--transition-slow) ease both;
}

.c-toast__item--success {
  background: var(--color-success-bg);
  border-color: var(--color-success);
  color: var(--color-success);
}

.c-toast__item--warning {
  background: var(--color-warning-bg);
  border-color: var(--color-warning);
  color: var(--color-warning);
}

.c-toast__item--error {
  background: var(--color-danger-bg);
  border-color: var(--color-danger);
  color: var(--color-danger);
}

.c-toast__message {
  flex: 1;
  color: inherit;
  line-height: var(--leading-snug);
}

.c-toast__close {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: inherit;
  opacity: 0.6;
  flex-shrink: 0;
  line-height: 1;
}

.c-toast__close:hover {
  opacity: 1;
}

@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateY(var(--space-4));
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 609px) {
  c-toast {
    padding: 0 var(--space-4);
  }

  .c-toast__item {
    max-width: 100%;
    width: 100%;
    font-size: var(--text-xs);
  }
}


/* ══════════════════════════════════════════════════════
   9. UTILITIES
   ══════════════════════════════════════════════════════ */

/* ── Screenreader-only ──────────────────────────────── */

.u-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;
}

/* ── Anzeige ────────────────────────────────────────── */

.u-hidden {
  display: none !important;
}

.u-invisible {
  visibility: hidden;
}

/* ── Text ───────────────────────────────────────────── */

.u-text-muted  { color: var(--color-text-muted); }
.u-text-subtle { color: var(--color-text-subtle); }
.u-text-center { text-align: center; }
.u-text-sm     { font-size: var(--text-sm); }
.u-text-xs     { font-size: var(--text-xs); }

/* ── Abstände ───────────────────────────────────────── */

.u-mt-4  { margin-top: var(--space-4); }
.u-mt-6  { margin-top: var(--space-6); }
.u-mt-8  { margin-top: var(--space-8); }
.u-mb-4  { margin-bottom: var(--space-4); }
.u-mb-6  { margin-bottom: var(--space-6); }
.u-mb-8  { margin-bottom: var(--space-8); }


/* ── Responsive: Mobile ─────────────────────────────── */

[data-device="mobile"] .l-grid--2,
[data-device="mobile"] .l-grid--3 {
  grid-template-columns: 1fr;
}

[data-device="mobile"] .l-app[data-layout="admin"] {
  grid-template-columns: 1fr;
}

/* ── Admin: Mobile-Layout ────────────────────────────── */

/* Sidebar wird zur horizontalen Tab-Leiste oben:
   Zeile 1 — Brand + Logout; Zeile 2 — Nav-Items */
[data-device="mobile"] .l-admin__sidebar {
  position: sticky;
  top: 0;
  width: 100%;
  height: auto;
  padding: 0;
  gap: 0;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: stretch;
  z-index: 50;
  overflow: visible;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

/* Brand-Header: links, nimmt restlichen Platz in Zeile 1 */
[data-device="mobile"] .l-admin__header {
  flex: 1 1 auto;
  order: 1;
  display: flex;
  align-items: center;
  padding: var(--space-3) var(--space-4);
  margin-bottom: 0;
  font-size: var(--text-sm);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* Logout: rechts in Zeile 1, neben dem Brand-Namen */
[data-device="mobile"] .l-admin__logout {
  flex: 0 0 auto;
  order: 2;
  margin-top: 0;
  padding-top: 0;
  border-top: none;
  display: flex;
  align-items: center;
  padding-right: var(--space-2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

[data-device="mobile"] .l-admin__logout .c-nav__item--logout {
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  min-height: 44px;
  width: auto;
  border-radius: var(--radius-md);
}

/* Nav: volle Breite in Zeile 2, horizontal scrollbar */
[data-device="mobile"] .l-admin__sidebar nav {
  flex: 0 0 100%;
  order: 3;
  display: flex;
  flex-direction: row;
  overflow-x: auto;
  scrollbar-width: none;
  gap: 0;
  padding: 0 var(--space-2);
}

[data-device="mobile"] .l-admin__sidebar nav::-webkit-scrollbar {
  display: none;
}

/* Nav-Items: horizontal, 44 px touch-target */
[data-device="mobile"] .l-admin__sidebar nav .c-nav__item {
  white-space: nowrap;
  flex-shrink: 0;
  min-height: 44px;
  display: flex;
  align-items: center;
  padding: var(--space-2) var(--space-4);
  border-radius: 0;
  border-bottom: 3px solid transparent;
  background: none;
}

[data-device="mobile"] .l-admin__sidebar nav .c-nav__item--active {
  background: rgba(255, 255, 255, 0.08);
  border-bottom-color: #fff;
}

/* Main-Bereich: kein Padding-Links (kein Sidebar-Offset) */
[data-device="mobile"] .l-app[data-layout="admin"] .l-app__body {
  padding-left: 0;
}

/* Hauptinhalt: reduzierte Abstände */
[data-device="mobile"] .l-admin__main {
  padding: var(--space-4) var(--space-3);
}

/* Dashboard-Header: vertikal stapeln */
[data-device="mobile"] .s-admin-dashboard__header {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
  padding-bottom: var(--space-4);
}

/* Actions-Bereich: volle Breite */
[data-device="mobile"] .s-admin-dashboard__actions {
  width: 100%;
}

/* Suchfeld: volle Breite auf Mobile */
[data-device="mobile"] .c-input__field--search {
  width: 100%;
}

[data-device="mobile"] .c-search {
  width: 100%;
}

/* Tabelle: horizontal scrollbar auf kleinen Bildschirmen */
[data-device="mobile"] .c-table-wrap {
  overflow-x: auto;
}

[data-device="mobile"] .c-table {
  min-width: 520px;
}

[data-device="mobile"] .s-checkout__layout {
  grid-template-columns: 1fr;
}

[data-device="mobile"] .l-nav__links {
  display: none;
}


/* ── Responsive: Tablet ─────────────────────────────── */

[data-device="pad"] .l-grid--3 {
  grid-template-columns: repeat(2, 1fr);
}

[data-device="pad"] .s-checkout__layout {
  grid-template-columns: 1fr;
}


/* ══════════════════════════════════════════════════════
   7. RESPONSIVE (Mobile-First)
   ══════════════════════════════════════════════════════ */

/* ── Touch-Geräte: Mengen-Controls immer sichtbar ────── */
/* Auf touch-only-Geräten gibt es kein Hover — Controls
   müssen dauerhaft sichtbar und groß genug sein (≥ 44px). */
@media (hover: none) and (pointer: coarse) {
  #menge-controls {
    opacity: 1;
  }


  #menge-controls button {
    min-height: 44px;
    height: auto;
    padding: 0 var(--space-2);
  }

  #plate-size-buttons button {
    min-height: 44px;
    padding: var(--space-2) var(--space-3);
  }
}

/* ── Kleine Smartphones (≤ 520 px) ──────────────────── */
@media (max-width: 520px) {
  /* Header-Brand auf schmale Viewports skalieren */
  .c-site-header__brand {
    font-size: 1.15rem;
  }

  /* Checkout-Panel: Innenabstand reduzieren */
  .s-checkout__panel {
    padding: var(--space-4) var(--space-4) var(--space-5);
  }
  .s-checkout__steps {
    padding: var(--space-3) var(--space-4);
  }

  /* Zwei-Spalten-Grid auf eine Spalte kollabieren */
  .s-checkout__grid-2 {
    grid-template-columns: 1fr;
  }

  /* Plate-Controls volle Breite */
  #plate-controls {
    width: 100%;
  }
}

/* ── Sehr kleine Smartphones (≤ 375 px) ─────────────── */
@media (max-width: 375px) {
  .c-site-header__brand {
    font-size: 0.9rem;
    letter-spacing: 0.03em;
  }

  /* Kaufen-Button leicht verkleinert */
  .c-site-header .c-btn--primary {
    font-size: 0.95rem;
    padding: var(--space-3) var(--space-5);
  }

  /* Menge-Zahl auf sehr kleinen Screens verkleinern */
  #menge-input {
    font-size: 4.5rem;
  }
}


/* ── Checkout Mobile ─────────────────────────────────── */
@media (max-width: 609px) {
  .s-checkout__card {
    top: 0;
  }

  .s-checkout__inner {
    max-width: 100%;
    gap: var(--space-4);
  }

  .s-checkout__steps {
    padding: var(--space-3) var(--space-3);
    gap: 0;
  }

  .s-checkout__step-num {
    width: 26px;
    height: 26px;
    font-size: var(--text-xs);
  }

  .s-checkout__step-label {
    font-size: 0.6rem;
  }

  .s-checkout__step-line {
    margin-top: 13px;
  }

  .s-checkout__panel {
    padding: var(--space-3) var(--space-3) var(--space-4);
    gap: var(--space-3);
  }

  .s-checkout__panel-title {
    font-size: var(--text-lg);
  }

  .s-checkout__delivery-card,
  .s-checkout__pay-card {
    padding: var(--space-2) var(--space-3);
    gap: var(--space-2);
  }

  .s-checkout__pay-icon {
    width: 28px;
    height: 28px;
  }

  .s-checkout__pay-name {
    font-size: var(--text-sm);
  }

  .s-checkout__pay-desc {
    font-size: var(--text-xs);
  }

  .s-checkout__addr-hours {
    font-size: var(--text-xs);
  }

  .s-checkout__hours {
    font-size: 0.65rem;
  }

  .s-checkout__express-badge {
    font-size: 0.65rem;
  }

  .s-checkout__express-note {
    font-size: 0.6rem;
  }

  .s-checkout__grid-2 {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .s-checkout__field {
    height: 40px;
    font-size: var(--text-base);  /* 16px — verhindert iOS Safari Auto-Zoom */
  }

  .s-checkout__address-hint {
    font-size: var(--text-xs);
  }

  .s-checkout__actions {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--space-2);
  }

  .s-checkout__btn-primary,
  .s-checkout__btn-ghost {
    flex: none;
    width: 100%;
    justify-content: center;
  }

  .s-checkout__btn-primary {
    height: 48px;
    font-size: var(--text-sm);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }

  .s-checkout__btn-ghost {
    height: 36px;
    font-size: var(--text-sm);
    opacity: 0.5;
  }

  .s-checkout__countdown {
    font-size: 0.55rem;
  }

  /* ── Panel 3: Bestätigung — Mobile ── */
  .s-checkout__actions--cta {
    flex-direction: column-reverse;
    gap: var(--space-3);
    padding-top: var(--space-2);
  }

  .s-checkout__btn-primary--cta {
    height: 52px;
    font-size: var(--text-base);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 4px;
  }

  .s-checkout__btn-ghost--back {
    height: 40px;
    font-size: var(--text-sm);
    opacity: 0.5;
  }

  .c-order-summary {
    gap: var(--space-1);
  }

  .c-order-summary__row {
    font-size: var(--text-xs);
    gap: var(--space-2);
  }
}


/* ══════════════════════════════════════════════════════
   Admin Posteingang (Inbox)
   ══════════════════════════════════════════════════════ */

/* Two-panel layout on desktop */
.s-admin-inbox {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: var(--space-4);
  align-items: start;
  min-height: 600px;
}

@media (max-width: 900px) {
  .s-admin-inbox {
    grid-template-columns: 1fr;
  }
}

.s-admin-inbox__loading {
  text-align: center;
  padding: var(--space-8);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* ── E-Mail-Liste ── */
.s-admin-inbox__list {
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.s-admin-inbox__row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 12px var(--space-4);
  cursor: pointer;
  transition: background 150ms ease, box-shadow 150ms ease;
  border-bottom: 1px solid var(--color-border);
  position: relative;
}
.s-admin-inbox__row:last-child {
  border-bottom: none;
}
.s-admin-inbox__row:hover {
  background: var(--color-surface-raised);
}
.s-admin-inbox__row--unread {
  background: var(--color-accent-subtle);
}
.s-admin-inbox__row--unread:hover {
  background: color-mix(in srgb, var(--color-accent-subtle) 80%, var(--color-surface-raised));
}
.s-admin-inbox__row--active {
  background: var(--color-accent-subtle);
  box-shadow: inset 3px 0 0 var(--color-primary);
}
.s-admin-inbox__row--active:hover {
  background: var(--color-accent-subtle);
}

/* Initials-Avatar */
.s-admin-inbox__avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  letter-spacing: 0.5px;
}

.s-admin-inbox__row-content {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.s-admin-inbox__sender {
  font-size: var(--text-sm);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--color-text);
}
.s-admin-inbox__row--unread .s-admin-inbox__sender {
  font-weight: 700;
}
.s-admin-inbox__subject {
  font-size: var(--text-xs);
  color: var(--color-text-subtle);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.s-admin-inbox__row--unread .s-admin-inbox__subject {
  color: var(--color-text);
  font-weight: 500;
}
.s-admin-inbox__date {
  font-size: 11px;
  color: var(--color-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Unread dot */
.s-admin-inbox__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-primary);
  flex-shrink: 0;
}

.s-admin-inbox__empty {
  text-align: center;
  padding: var(--space-8);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

/* ── E-Mail-Detail ── */
.s-admin-inbox__detail {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: sticky;
  top: var(--space-4);
}
.s-admin-inbox__detail-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px var(--space-4);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface-raised);
}
.s-admin-inbox__detail-actions {
  display: flex;
  gap: var(--space-2);
}
.s-admin-inbox__detail-meta {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px var(--space-3);
  align-items: baseline;
  background: var(--color-bg);
}
.s-admin-inbox__detail-meta-label {
  color: var(--color-text-muted);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}
.s-admin-inbox__detail-body {
  padding: var(--space-4) var(--space-5);
  font-size: var(--text-sm);
  line-height: 1.75;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 40vh;
  overflow-y: auto;
  color: var(--color-text);
}

/* ── Schnellantwort-Panel ── */
.s-admin-inbox__reply {
  border-top: 1px solid var(--color-border);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  background: var(--color-surface-raised);
}
.s-admin-inbox__reply-title {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin: 0;
}
.s-admin-inbox__reply-select {
  font-size: var(--text-sm);
  padding: 8px var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  width: 100%;
  transition: border-color 150ms ease, box-shadow 150ms ease;
  font-family: inherit;
}
.s-admin-inbox__reply-select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}
.s-admin-inbox__reply-kz {
  font-size: var(--text-sm);
  padding: 8px var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  width: 100%;
  box-sizing: border-box;
  font-family: inherit;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.s-admin-inbox__reply-kz:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}
.s-admin-inbox__reply-textarea {
  font-size: var(--text-sm);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  width: 100%;
  min-height: 110px;
  resize: vertical;
  line-height: 1.6;
  box-sizing: border-box;
  font-family: inherit;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.s-admin-inbox__reply-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}
.s-admin-inbox__reply-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.s-admin-inbox__reply-hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* Empty state für Detail-Panel */
.s-admin-inbox__detail-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-8);
  color: var(--color-text-muted);
  text-align: center;
  min-height: 320px;
}
.s-admin-inbox__detail-empty-icon {
  font-size: 2.5rem;
  opacity: 0.25;
}

/* Badge für Sidebar */
.c-badge--small {
  font-size: 10px;
  padding: 1px 5px;
  border-radius: 8px;
  margin-left: var(--space-2);
  vertical-align: middle;
}

/* ── E-Mail Vorschau Hub ──────────────────────────────────────────────────── */

/* Dashboard: Kategorieabschnitte */
.s-ev-section {
  margin-bottom: var(--space-8);
}

.s-ev-section__header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.09em;
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-3);
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.s-ev-section__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.s-ev-section[data-cat="support"] .s-ev-section__dot {
  background: var(--color-warning);
  box-shadow: 0 0 5px var(--color-warning);
}

.s-ev-section[data-cat="transaktional"] .s-ev-section__dot {
  background: var(--marine-300);
  box-shadow: 0 0 5px var(--marine-300);
}

.s-ev-section[data-cat="browser"] .s-ev-section__dot {
  background: var(--color-success);
  box-shadow: 0 0 5px var(--color-success);
}

.s-ev-section__grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Dashboard-Karte — horizontal */
.s-ev-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: var(--radius-lg);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.12s, background 0.12s;
  width: 100%;
}

.s-ev-card:hover {
  background: rgba(255,255,255,0.025);
}

/* Category accent on hover — nur border-left */
.s-ev-section[data-cat="support"] .s-ev-card:hover {
  border-left-color: var(--color-warning);
}
.s-ev-section[data-cat="transaktional"] .s-ev-card:hover {
  border-left-color: var(--marine-300);
}
.s-ev-section[data-cat="browser"] .s-ev-card:hover {
  border-left-color: var(--color-success);
}

/* Icon-Box */
.s-ev-card__icon-wrap {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.15s;
}

.s-ev-section[data-cat="support"] .s-ev-card__icon-wrap {
  background: rgba(217,119,6,0.12);
}
.s-ev-section[data-cat="transaktional"] .s-ev-card__icon-wrap {
  background: rgba(102,146,216,0.12);
}
.s-ev-section[data-cat="browser"] .s-ev-card__icon-wrap {
  background: rgba(22,163,74,0.12);
}

.s-ev-card__icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.s-ev-section[data-cat="support"] .s-ev-card__icon {
  color: var(--color-warning);
}
.s-ev-section[data-cat="transaktional"] .s-ev-card__icon {
  color: var(--marine-300);
}
.s-ev-section[data-cat="browser"] .s-ev-card__icon {
  color: var(--color-success);
}

/* Text-Body */
.s-ev-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.s-ev-card__name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
  line-height: 1.3;
}

.s-ev-card__desc {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.4;
}

/* Pfeil-Chevron rechts */
.s-ev-card__arrow {
  width: 14px;
  height: 14px;
  color: var(--text-subtle, var(--text-muted));
  opacity: 0.4;
  flex-shrink: 0;
  transition: opacity 0.15s, transform 0.15s;
}

.s-ev-card:hover .s-ev-card__arrow {
  opacity: 0.85;
  transform: translateX(2px);
}

/* Preview-Toolbar */
.s-ev-preview__toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.s-ev-preview__back {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-3);
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--text-muted);
  transition: color 0.15s, border-color 0.15s;
}

.s-ev-preview__back:hover {
  color: var(--text);
  border-color: var(--marine-300);
}

.s-ev-preview__back svg {
  width: 14px;
  height: 14px;
}

.s-ev-preview__tpl-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
}

/* Frame-Wrapper */
.s-ev-preview__frame-wrap {
  position: relative;
  height: calc(100vh - 220px);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
}

.s-ev-preview__loader {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  color: var(--text-muted);
  font-size: var(--text-sm);
}

.s-ev-preview__loader svg {
  width: 20px;
  height: 20px;
  animation: spin 0.8s linear infinite;
}

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

/* ── E-Mail Vorschau ─────────────────────────────────── */
.s-email-vorschau {
  height: calc(100vh - 140px);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* Category group */
.s-email-vorschau__group {
  padding: 0;
}

.s-email-vorschau__group + .s-email-vorschau__group {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* Category label — small caps with colored dot */
.s-email-vorschau__group-label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 10px;
  font-weight: 700;
  color: rgba(255,255,255,0.35);
  text-transform: uppercase;
  letter-spacing: 0.09em;
  padding: 0 var(--space-4) var(--space-2);
}

.s-email-vorschau__group-label::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.s-email-vorschau__group[data-category="support"] .s-email-vorschau__group-label::before {
  background: var(--color-warning);
  box-shadow: 0 0 6px var(--color-warning);
}

.s-email-vorschau__group[data-category="transaktional"] .s-email-vorschau__group-label::before {
  background: var(--marine-300);
  box-shadow: 0 0 6px var(--marine-300);
}

.s-email-vorschau__group[data-category="browser"] .s-email-vorschau__group-label::before {
  background: var(--color-success);
  box-shadow: 0 0 6px var(--color-success);
}

/* Item button */
.s-email-vorschau__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  text-align: left;
  padding: 9px var(--space-4);
  background: none;
  border: none;
  border-left: 2px solid transparent;
  cursor: pointer;
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.55);
  transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.s-email-vorschau__item:hover {
  background: rgba(255,255,255,0.05);
  color: rgba(255,255,255,0.85);
}

.s-email-vorschau__item--active {
  border-left-color: var(--marine-300);
  background: rgba(255,255,255,0.07);
  color: #fff;
  font-weight: 500;
}

/* Item icon */
.s-email-vorschau__item-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  opacity: 0.7;
  transition: opacity 0.15s;
}

.s-email-vorschau__item:hover .s-email-vorschau__item-icon,
.s-email-vorschau__item--active .s-email-vorschau__item-icon {
  opacity: 1;
}

/* Preview pane */
.s-email-vorschau__preview {
  background: var(--surface);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.s-email-vorschau__iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* Placeholder */
.s-email-vorschau__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  color: var(--text-muted);
  font-size: var(--text-sm);
}

.s-email-vorschau__placeholder-icon {
  width: 48px;
  height: 48px;
  opacity: 0.3;
}



/* ── s-home__intro (H1 + Subheading) ───────────────── */
.s-home__intro {
  width: 100%;
  max-width: 660px;
  text-align: center;
  padding: var(--space-3) var(--space-3) 0;
  pointer-events: none;
}

.s-home__heading {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 var(--space-1);
  color: var(--color-on-surface);
}

.s-home__subheading {
  font-size: 0.875rem;
  color: var(--color-on-surface-muted, #666);
  margin: 0;
  line-height: 1.5;
}

@media (max-width: 609px) {
  .s-home__intro {
    padding: var(--space-2) var(--space-3) 0;
  }
  .s-home__heading {
    font-size: 1.1rem;
  }
}


/* ── s-home__map (Google Maps Einbettung) ───────────── */
.s-home__map {
  width: 100%;
  padding: var(--space-5) var(--space-4) var(--space-4);
  border-top: 1px solid var(--color-border, #e5e7eb);
  margin-top: var(--space-4);
}

.s-home__map-heading {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 var(--space-3);
  color: var(--color-on-surface);
}

.s-home__map-frame {
  border-radius: var(--radius-md, 8px);
  overflow: hidden;
  line-height: 0;
}

.s-home__map-frame iframe {
  display: block;
  width: 100%;
  height: 260px;
  border: 0;
}

.s-home__map-address {
  font-size: 0.875rem;
  color: var(--color-on-surface-muted, #666);
  margin: var(--space-2) 0 0;
  line-height: 1.5;
}

.s-home__map-address a {
  color: var(--color-primary, #1a56db);
  text-decoration: none;
}

.s-home__map-address a:hover {
  text-decoration: underline;
}


/* ── s-faq (FAQ-Seite) ───────────────────────────────── */
.s-faq {
  padding: var(--space-6, 2rem) var(--space-4, 1rem);
  max-width: 760px;
  margin: 0 auto;
}

.s-faq__inner {
  width: 100%;
}

.s-faq__breadcrumb {
  font-size: 0.8125rem;
  color: var(--color-on-surface-muted, #666);
  margin-bottom: var(--space-5, 1.5rem);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.s-faq__breadcrumb-link {
  color: var(--color-primary, #1a56db);
  text-decoration: none;
}

.s-faq__breadcrumb-link:hover {
  text-decoration: underline;
}

.s-faq__breadcrumb-sep {
  color: var(--color-on-surface-muted, #999);
}

.s-faq__title {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 var(--space-3, 0.75rem);
  color: var(--color-on-surface);
  line-height: 1.3;
}

.s-faq__intro {
  font-size: 0.9375rem;
  color: var(--color-on-surface-muted, #555);
  margin: 0 0 var(--space-6, 2rem);
  line-height: 1.6;
}

.s-faq__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.s-faq__item {
  border-top: 1px solid var(--color-border, #e5e7eb);
  padding: var(--space-4, 1rem) 0;
}

.s-faq__item:last-child {
  border-bottom: 1px solid var(--color-border, #e5e7eb);
}

.s-faq__question {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 var(--space-2, 0.5rem);
  color: var(--color-on-surface);
  line-height: 1.4;
}

.s-faq__answer {
  font-size: 0.9375rem;
  color: var(--color-on-surface-muted, #444);
  margin: 0;
  line-height: 1.65;
}

.s-faq__answer strong {
  color: var(--color-on-surface);
  font-weight: 600;
}

.s-faq__cta {
  margin-top: var(--space-7, 2.5rem);
  text-align: center;
}

.s-faq__cta-btn {
  display: inline-block;
  background: var(--color-primary, #1a56db);
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
  padding: 0.75rem 2rem;
  border-radius: var(--radius-md, 8px);
  text-decoration: none;
  transition: background 0.15s;
}

.s-faq__cta-btn:hover {
  background: var(--color-primary-hover, #1648c2);
}

@media (max-width: 480px) {
  .s-faq {
    padding: var(--space-4, 1rem) var(--space-3, 0.75rem);
  }
  .s-faq__title {
    font-size: 1.25rem;
  }
}

/* ── Lauftext-Footer in .s-home__scroll ── */
.s-home__ticker{position:sticky;bottom:0;left:0;right:0;height:30px;background:#0F2F7A;display:flex;align-items:center;flex-shrink:0;z-index:10}
.s-home__ticker-overflow{overflow:hidden;flex:1;height:100%;display:flex;align-items:center;cursor:pointer;text-decoration:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none;outline:none}
.s-home__ticker-link{flex-shrink:0;white-space:nowrap;color:#fff;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;padding:0 10px;height:100%;display:flex;align-items:center;background:#FFD700;color:#0F2F7A;border-left:2px solid rgba(255,255,255,.3)}
.s-home__ticker-track{display:flex;flex-shrink:0;width:max-content;will-change:transform}
.s-home__ticker-track span{color:#fff;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}


/* ── Mobil-Ticker (fixed unter Header) ── */
#mobile-ticker{display:none;border:none;outline:none;-webkit-tap-highlight-color:transparent;text-decoration:none}
@media (max-width: 609px){
  #mobile-ticker{position:fixed;top:var(--header-height);left:0;right:0;height:30px;background:#0F2F7A;display:flex;align-items:center;overflow:hidden;z-index:99;border:none;outline:none;-webkit-tap-highlight-color:transparent;text-decoration:none;touch-action:manipulation}
  #mobile-ticker .s-home__ticker-overflow{flex:1;overflow:hidden;height:100%;display:flex;align-items:center;pointer-events:none}
  .s-home__ticker{display:none}
  main{padding-top:30px}
}
