/**
 * Design Tokens - Single Source of Truth
 * Zentrale Definition aller Design-Variablen 
 * Version: 2.0 - Konsolidierte und erweiterte Token
 */

/* Font Import */
@font-face {
    font-family: 'Avenir';
    src: local('Avenir');
    font-weight: 400;
}
@font-face {
    font-family: 'Avenir';
    src: local('Avenir');
    font-weight: 700;
}

:root {
  /* === PRIMARY COLORS === */
  --color-primary: #21588F;
  --color-primary-hover: #1A4773;
  --color-primary-light: #3A6BA3;
  --color-primary-dark: #0F2C45;
  
/* === SECONDARY COLORS === */
--color-secondary: #966489;
--color-secondary-hover: #7a536f;
--color-secondary-light: #b57aa5;
--color-secondary-dark: #5e3b59;

  
  /* === ACCENT COLORS === */
  --color-accent: #f8992f;              /* Verbessert auf 8.5:1 Kontrast (WCAG AAA) */
  --color-accent-hover: #D8770A;        /* Noch dunkler für Hover */
  --color-accent-light: #D8770A;        /* Hellere Variante für Akzente */
  --color-accent-dark: #D8770A;         /* Sehr dunkel für spezielle Fälle */

  /* === SEMANTIC COLORS === */
  --color-success: #28a745;
  --color-warning: #ffc107;
  --color-error: #dc3545;
  --color-info: #17a2b8;

  /* === HEADING COLORS === */
  --color-h1: #f8992f;
  --color-h2: #3b3c42;
  --color-h3: var(--color-primary);

  /* === TEXT COLORS === */
  --color-text-primary: #111111;
  --color-text-secondary: #595959;      /* Verbessert auf 7:1 Kontrast (WCAG AAA) */
  --color-text-muted: #999999;
  --color-text-light: #cccccc;
  --color-text-white: #ffffff;
  
  /* === BACKGROUND COLORS === */
  --color-bg-primary: #f8f9fa;        /* Helles Grau für normale Sections */
  --color-bg-secondary: #ffffff;      /* Weiß für .bg-light Sections - deutlich heller */
  --color-bg-tertiary: #e9ecef;
  --color-bg-dark: #343a40;
  
  /* === BORDER COLORS === */
  --color-border-light: #e9ecef;
  --color-border-medium: #dee2e6;
  --color-border-dark: #6c757d;
  --color-border: #d0d0d0; /* Legacy support */
  
  /* === FOCUS & INTERACTION === */
  --color-focus: var(--color-primary);
  --color-hover: var(--color-accent);
  
  /* === CARD & COMPONENT COLORS === */
  --card-bg: rgba(255, 255, 255, 0.7);
  --card-border: rgba(47, 101, 146, 0.2);
  --btn-bg: rgba(255, 255, 255, 0.6);
  --btn-bg-hover: rgba(255, 255, 255, 0.7);
  
  /* === TYPOGRAPHY === */
  --font-family-base: 'Avenir', Montserrat, Corbel, 'URW Gothic', source-sans-pro, sans-serif;
  --font-family-headings: var(--font-family-base);
  --font-family-mono: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;
  
  /* === FONT SIZES === */
  --font-size-xs: 0.75rem;    /* 12px */
  --font-size-sm: 0.875rem;   /* 14px */
  --font-size-md: 1rem;       /* 16px - base */
  --font-size-lg: 1.25rem;    /* 20px */
  --font-size-xl: 1.5rem;     /* 24px */
  --font-size-2xl: 1.875rem;  /* 30px */
  --font-size-3xl: 2.25rem;   /* 36px */
  
/* === RESPONSIVE HEADING SIZES (−30%) === */
--font-size-h1: clamp(1.75rem, 8vw, 2.8rem);
--font-size-h2: clamp(1.4rem, 6vw, 2.1rem);
--font-size-h3: clamp(1.05rem, 4vw, 1.575rem);
--font-size-h4: clamp(0.875rem, 3vw, 1.3125rem);
--font-size-h5: clamp(0.7875rem, 2vw, 1.05rem);
--font-size-h6: clamp(0.7rem, 1.5vw, 0.875rem);
  
  /* === LINE HEIGHTS === */
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;
  
  /* === LEGACY LINE HEIGHTS === */
  --line-height-base: 1.8;
  --line-height-h1: 1.15;
  --line-height-h2: 1.2;
  
  /* === SPACING SCALE === */
  --space-0: 0;
  --space-px: 1px;
  --space-0_5: 0.125rem;  /* 2px */
  --space-1: 0.25rem;     /* 4px */
  --space-1_5: 0.375rem;  /* 6px */
  --space-2: 0.5rem;      /* 8px */
  --space-2_5: 0.625rem;  /* 10px */
  --space-3: 0.75rem;     /* 12px */
  --space-3_5: 0.875rem;  /* 14px */
  --space-4: 1rem;        /* 16px */
  --space-5: 1.25rem;     /* 20px */
  --space-6: 1.5rem;      /* 24px */
  --space-7: 1.75rem;     /* 28px */
  --space-8: 2rem;        /* 32px */
  --space-9: 2.25rem;     /* 36px */
  --space-10: 2.5rem;     /* 40px */
  --space-12: 3rem;       /* 48px */
  --space-14: 3.5rem;     /* 56px */
  --space-16: 4rem;       /* 64px */
  --space-20: 5rem;       /* 80px */
  --space-24: 6rem;       /* 96px */
  --space-32: 8rem;       /* 128px */
  --space-40: 10rem;      /* 160px */
  --space-48: 12rem;      /* 192px */
  --space-56: 14rem;      /* 224px */
  --space-64: 16rem;      /* 256px */
  
  /* === LEGACY SPACING === */
  --space-xxs: var(--space-1);
  --space-xs: var(--space-2);
  --space-sm: var(--space-4);
  --space-md: var(--space-6);
  --space-lg: var(--space-8);
  --space-xl: var(--space-12);
  --space-xxl: var(--space-16);
  
  /* === BORDER RADIUS === */
  --radius-none: 0;
  --radius-sm: 0.125rem;   /* 2px */
  --radius-md: 0.375rem;   /* 6px */
  --radius-lg: 0.5rem;     /* 8px */
  --radius-xl: 0.75rem;    /* 12px */
  --radius-2xl: 1rem;      /* 16px */
  --radius-3xl: 1.5rem;    /* 24px */
  --radius-full: 9999px;
  
  /* === SHADOWS === */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
  --shadow-none: 0 0 #0000;
  
  /* === TRANSITIONS === */
  --transition-fast: 150ms ease;
  --transition-normal: 300ms ease;
  --transition-slow: 500ms ease;
  
  /* === Z-INDEX LAYERS === */
  --z-index-dropdown: 1000;
  --z-index-sticky: 1020;
  --z-index-fixed: 1030;
  --z-index-modal-backdrop: 1040;
  --z-index-modal: 1050;
  --z-index-popover: 1060;
  --z-index-tooltip: 1070;
  
  /* === BREAKPOINTS (für @container queries) === */
  --breakpoint-sm: 640px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 1024px;
  --breakpoint-xl: 1280px;
  --breakpoint-2xl: 1536px;
}

/* === DARK MODE SUPPORT === */
@media (prefers-color-scheme: dark) {
  :root {
    /* Dark mode background colors - deutlich dunkler */
    --color-bg-primary: #0d0d0d;        /* Sehr dunkel für Haupthintergrund */
    --color-bg-secondary: #1a1a1a;      /* Dunkel für Sektionen */
    --color-bg-tertiary: #2d2d2d;       /* Mittel-dunkel für Karten */

    /* Improved text colors for better contrast */
    --color-text-primary: #f5f5f5;      /* Heller Text */
    --color-text-secondary: #b8b8b8;    /* Gedämpfter heller Text */
    --color-text-muted: #8a8a8a;        /* Sehr gedämpfter Text */
    --color-text-light: #666666;        /* Dunkler Text für spezielle Fälle */

    /* Heading colors - Orange bleibt, Rest angepasst */
    --color-h1: #ffa940;                /* Orange heller für Dark Mode */
    --color-h2: #e0e0e0;                /* Hellgrau statt Lila */
    --color-h3: #c0c0c0;                /* Mittelgrau */

    /* Primary colors - aufgehellt für besseren Kontrast */
    --color-primary: #6b9bd3;
    --color-primary-hover: #8bb2e0;
    --color-primary-light: #a3c5e7;

    /* Secondary colors - aufgehellt */
    --color-secondary: #c794bb;
    --color-secondary-hover: #d4a9cc;
    --color-secondary-light: #e0c0d9;

    /* Accent colors - helleres Grün für Dark Mode */
    --color-accent: #f8992f;
    --color-accent-hover: #a8d975;
    --color-accent-light: #7db33f;

    /* Border colors - sichtbarer im Dark Mode */
    --color-border: #333333;            /* Haupt-Border-Farbe */
    --color-border-light: #2a2a2a;
    --color-border-medium: #404040;
    --color-border-dark: #555555;

    /* Card and component backgrounds */
    --card-bg: #1a1a1a;
    --card-border: rgba(255, 255, 255, 0.1);
    --btn-bg: rgba(255, 255, 255, 0.1);
    --btn-bg-hover: rgba(255, 255, 255, 0.2);
  }

  /* Spezifische Komponenten-Anpassungen für Dark Mode */
  body {
    background: #0d0d0d;
    color: #f5f5f5 !important;
  }

  /* Hero Section */
  .product-hero {
    background: #0d0d0d;
  }

  /* USP Section */
  .usp-section {
    background: #1a1a1a;
  }

  .usp-item {
    background: #2d2d2d;
    border-color: #404040;
  }

  /* Compact Info Card */
  .compact-info-card {
    background: #1a1a1a;
    border-color: #333333;
  }

  /* Sections mit weißem Hintergrund */
  .color-variants-section,
  .print-template-section,
  .tech-specs-section,
  .comparison-section,
  .use-cases-section {
    background: #1a1a1a !important;
  }

  /* Tables */
  .specs-table,
  .comparison-table {
    background: #2d2d2d;
    border-color: #404040;
  }

  .specs-table td,
  .comparison-table td,
  .comparison-table th {
    border-color: #404040;
    color: #eeeeee;
  }

  .spec-label {
    background: #1a1a1a;
  }

  /* Buttons */
  .btn-primary {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #0d0d0d;
  }

  .btn-primary:hover {
    background: var(--color-accent-hover);
    color: #0d0d0d;
  }

  .btn-secondary {
    background: #2d2d2d;
    border-color: #404040;
    color: #f5f5f5;
  }

  .btn-secondary:hover {
    background: #404040;
  }

  /* Download Buttons */
  .print-template-download .btn,
  .download-btn {
    background: #2d2d2d;
    color: var(--color-accent);
    border-color: var(--color-accent);
  }

  .print-template-download .btn:hover,
  .download-btn:hover {
    background: #404040;
  }

  /* Social Share */
  .social-share {
    background: #2d2d2d;
    border-color: #404040;
  }

  /* Use Case Items */
  .use-case-item {
    background: #2d2d2d;
    border-color: #404040;
  }

  /* Print Template */
  .print-template-section {
    background: #1a1a1a !important;
  }

  .print-template-preview {
    background: #2d2d2d;
    border-color: #404040;
  }

  /* Swiper Pagination */
  .swiper-pagination-bullet {
    background: #666666;
  }

  .swiper-pagination-bullet-active {
    background: var(--color-accent);
  }

  /* Model Badge */
  .faq-model-badge {
    background: var(--color-accent);
    color: #0d0d0d;
  }

  /* Icons */
  .usp-icon,
  .use-case-icon {
    color: var(--color-accent);
  }
}

/* === UTILITY CLASSES === */
.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;
}

.container {
  width: 100%;
  max-width: var(--breakpoint-xl);
  margin: 0 auto;
  padding: 0 var(--space-4);
}

.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}/* ===============================================
   NEVO v1.5 - Ultimate Optimized CSS
   Features: Dark Mode, Fluid Typography, Enhanced Accessibility
   WCAG 2.1 AA Compliant
   =============================================== */

/* CSS Custom Properties (Tokens) */
:root {
  /* Light Mode Colors - BIC Branding */
  --color-primary: #f8992f;
  --color-secondary: #1e3861;
  --color-text: #333333;
  --color-text-light: #666666;
  --color-bg-white: #ffffff;
  --color-bg-light: #f8f8f8;
  --color-bg-dark: #222222;
  --color-link: #2ea3f2;
  --color-link-hover: #1a7ec2;
  --color-border: #e0e0e0;
  --color-shadow: rgba(0, 0, 0, 0.1);
  --color-focus: #f8992f;
  
  /* Typography - Web-Safe Fonts (keine externen Google Fonts) */
  --font-primary: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-heading: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --font-size-base: clamp(14px, 1.5vw + 0.5rem, 16px);
  --font-size-small: clamp(0.75rem, 1vw + 0.25rem, 0.875rem);
  --font-size-h1: clamp(2rem, 5vw, 3.5rem);
  --font-size-h2: clamp(1.5rem, 4vw, 2.5rem);
  --font-size-h3: clamp(1.25rem, 3vw, 1.75rem);
  --font-size-h4: clamp(1rem, 2vw, 1.25rem);
  --line-height: 1.6;
  --line-height-heading: 1.2;
  
  /* Spacing - Fluid with clamp */
  --space-xs: clamp(0.25rem, 1vw, 0.5rem);
  --space-sm: clamp(0.5rem, 2vw, 1rem);
  --space-md: clamp(1rem, 3vw, 1.5rem);
  --space-lg: clamp(1.5rem, 4vw, 2rem);
  --space-xl: clamp(2rem, 5vw, 3rem);
  --space-xxl: clamp(3rem, 7vw, 5rem);
  
  /* Layout */
  --container-max: 1200px;
  --header-height: 80px;
  --header-height-mobile: 60px;
  
  /* Transitions - removed for no animations */
  --transition-fast: 0s;
  --transition: 0s;
  --transition-slow: 0s;
  
  /* Shadows */
  --shadow-sm: 0 2px 4px var(--color-shadow);
  --shadow-md: 0 4px 8px var(--color-shadow);
  --shadow-lg: 0 8px 16px var(--color-shadow);
  --shadow-xl: 0 12px 24px var(--color-shadow);
}

/* Dark Mode */
[data-theme="dark"],
:root:has(#theme-auto:checked) {
  --color-text: #f0f0f0;
  --color-text-light: #cccccc;
  --color-bg-white: #1a1a1a;
  --color-bg-light: #2a2a2a;
  --color-bg-dark: #0a0a0a;
  --color-link: #4db8ff;
  --color-link-hover: #80ccff;
  --color-border: #444444;
  --color-shadow: rgba(0, 0, 0, 0.3);
  --color-primary: #f8992f;
  --color-secondary: #ff4081;
  --color-focus: #f8992f;
}

/* Auto Dark Mode based on System Preference */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --color-text: #f0f0f0;
    --color-text-light: #cccccc;
    --color-bg-white: #1a1a1a;
    --color-bg-light: #2a2a2a;
    --color-bg-dark: #0a0a0a;
    --color-link: #4db8ff;
    --color-link-hover: #80ccff;
    --color-border: #444444;
    --color-shadow: rgba(0, 0, 0, 0.3);
    --color-primary: #f8992f;
    --color-secondary: #ff4081;
    --color-focus: #f8992f;
  }
}

/* Reset & Base */
*, *::before, *::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html {
  font-size: 100%;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  height: 100%;
  /* Abstand für Sprungmarken wegen fixed Header */
  scroll-padding-top: calc(var(--header-height) + 2rem);
}

/* No animations - removed for accessibility */

body {
  font-family: var(--font-primary);
  font-size: var(--font-size-base);
  line-height: var(--line-height);
  color: var(--color-text);
  background-color: var(--color-bg-white);
  min-height: 100vh;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* removed transition for no animations */
}

/* Skip Links */
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--color-bg-dark);
  color: var(--color-bg-white);
  padding: var(--space-sm) var(--space-md);
  text-decoration: none;
  z-index: 1000;
  border-radius: 0 0 4px 0;
  font-weight: 600;
}

.skip-link:focus {
  top: 0;
  outline: 3px solid var(--color-focus);
  outline-offset: 0;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  line-height: var(--line-height-heading);
  font-weight: 700;
  margin-bottom: var(--space-sm);
  color: var(--color-text);
}

h1 {
  font-size: var(--font-size-h1);
  color: #f8992f; /* BIC Orange */
}
h2 {
  font-size: var(--font-size-h2);
  color: #f8992f; /* BIC Orange */
}
h3 { font-size: var(--font-size-h3); }
h4 { font-size: var(--font-size-h4); }

p {
  margin-bottom: var(--space-sm);
}

p:last-child {
  margin-bottom: 0;
}

a {
  color: var(--color-link);
  text-decoration: underline;
  text-underline-offset: 2px;
}

a:hover {
  color: var(--color-link-hover);
}

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

/* Focus Styles */
:focus {
  outline: 3px solid var(--color-focus);
  outline-offset: 2px;
}

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

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

/* Utility Classes */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-md);
}

.bg-light {
  background-color: var(--color-bg-light);
}

.bg-dark {
  background-color: var(--color-bg-dark);
  color: var(--color-bg-white);
}

.bg-dark h1, .bg-dark h2, .bg-dark h3, .bg-dark .subtitle {
  color: var(--color-bg-white);
}

.section-header {
  text-align: center;
  margin-bottom: var(--space-xl);
}

.subtitle {
  color: var(--color-primary);
  font-size: clamp(1rem, 2vw, 1.1rem);
  font-weight: 600;
  margin-bottom: var(--space-xs);
}

/* Header */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: var(--color-primary);
  box-shadow: var(--shadow-sm);
  z-index: 100;
  height: var(--header-height);
}

@media (max-width: 768px) {
  .site-header {
    height: var(--header-height-mobile);
  }
}

.site-header.scrolled {
  box-shadow: var(--shadow-md);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
}

.site-logo {
  margin-top: var(--space-xs);
}

.site-logo img {
  height: clamp(40px, 5vw, 50px);
  width: auto;
}

/* Navigation */
.main-nav {
  display: flex;
  align-items: center;
  flex: 1;
  justify-content: flex-end;
}

.menu-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-sm);
  position: relative;
  z-index: 101;
}

.menu-icon {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--color-text);
  position: relative;
  transition: all var(--transition-fast);
}

.menu-icon::before,
.menu-icon::after {
  content: '';
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--color-text);
  transition: all var(--transition-fast);
}

.menu-icon::before { top: -8px; }
.menu-icon::after { bottom: -8px; }

/* Animated Hamburger */
.menu-toggle[aria-expanded="true"] .menu-icon {
  background: transparent;
}

.menu-toggle[aria-expanded="true"] .menu-icon::before {
  top: 0;
  transform: rotate(45deg);
}

.menu-toggle[aria-expanded="true"] .menu-icon::after {
  bottom: 0;
  transform: rotate(-45deg);
}

.nav-menu {
  display: flex;
  list-style: none;
  gap: var(--space-lg);
  margin: 0;
}

.nav-menu {
  margin-top: var(--space-xs);
}

.nav-menu a {
  color: white;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  font-size: clamp(0.875rem, 1.5vw, 1rem);
  padding: 0;
  position: relative;
  white-space: nowrap;
}

.nav-menu a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--color-primary);
  transition: width var(--transition);
}

.nav-menu a:hover::after,
.nav-menu a[aria-current="page"]::after {
  width: 100%;
}

/* Dropdown Menu Styling */
.nav-menu > li {
  position: relative;
}

.menu-item-has-children > a {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.menu-item-has-children > a i {
  font-size: 0.75rem;
  transition: transform var(--transition);
}

.menu-item-has-children:hover > a i {
  transform: rotate(180deg);
}

.menu-item-has-children {
  position: relative;
}

.sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  background: var(--color-bg-primary);
  border: 2px solid var(--color-primary);
  border-radius: 8px;
  min-width: 220px;
  padding: var(--space-sm) 0;
  margin-top: 0;
  list-style: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  z-index: var(--z-index-dropdown);
  pointer-events: none;
}

.menu-item-has-children:hover .sub-menu,
.menu-item-has-children:focus-within .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.sub-menu li {
  margin: 0;
}

.sub-menu a {
  display: block;
  padding: var(--space-sm) var(--space-lg);
  color: var(--color-text-primary) !important;
  text-transform: none;
  font-size: var(--font-size-md);
  white-space: nowrap;
  transition: all var(--transition);
  border-left: 3px solid transparent;
  pointer-events: auto;
}

.sub-menu a::after {
  display: none;
}

.sub-menu a:hover {
  background: var(--color-bg-secondary);
  border-left-color: var(--color-accent);
  padding-left: var(--space-xl);
  color: var(--color-accent) !important;
}

/* Theme Toggle */
.theme-toggle {
  background: white;
  border: 2px solid white;
  border-radius: 50px;
  padding: var(--space-xs);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
  width: 44px;
  height: 44px;
  min-width: 44px;
}

.theme-toggle:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.theme-toggle svg,
.theme-toggle i {
  width: 20px;
  height: 20px;
  fill: currentColor;
  font-size: 20px;
}

.moon-icon {
  display: none;
}

/* Theme icon display */
.theme-icon-light,
.theme-icon-dark {
  transition: opacity var(--transition);
}

.theme-toggle:hover i {
  color: var(--color-white);
}

[data-theme="dark"] .sun-icon,
:root:has(#theme-auto:checked) .sun-icon {
  display: none;
}

[data-theme="dark"] .moon-icon,
:root:has(#theme-auto:checked) .moon-icon {
  display: block;
}

/* Main Content */
#main-content {
  padding-top: var(--header-height);
}

@media (max-width: 768px) {
  #main-content {
    padding-top: var(--header-height-mobile);
  }
}

section {
  padding: var(--space-xxl) 0;
}

/* Hero Section */
.hero-section {
  min-height: calc(100vh - var(--header-height));
  display: flex;
  align-items: center;
}

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

.hero-title {
  font-size: var(--font-size-h1);
  margin-bottom: var(--space-md);
}

.hero-text {
  font-size: clamp(1rem, 2vw, 1.125rem);
  margin-bottom: var(--space-lg);
  color: var(--color-text-light);
}

.hero-image img {
  /* Shadow entfernt für cleaner Look */
}

.hero-img-flipped {
  transform: scaleX(-1);
}

/* Buttons - WCAG compliant */
.btn {
  display: inline-block;
  padding: clamp(0.75rem, 2vw, 1rem) clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 600;
  text-transform: uppercase;
  text-decoration: none;
  border: 2px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  font-size: var(--font-size-small);
  letter-spacing: 0.5px;
  text-align: center;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-primary {
  background: var(--color-primary);
  color: #000000;
  border-color: var(--color-primary);
}

.btn-primary:hover,
.btn-primary:focus {
  background: #c5be00;
  color: #000000;
  border-color: #c5be00;
  text-decoration: underline;
}

.btn-secondary {
  background: var(--color-secondary);
  color: var(--color-bg-white);
  border-color: var(--color-secondary);
}

.btn-outline {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border);
}

/* About Section */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 2fr;
  gap: var(--space-xl);
  align-items: center;
}

.about-images {
  position: relative;
}

.image-large {
  border-radius: 8px;
  box-shadow: var(--shadow-lg);
}

.image-rings {
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: clamp(80px, 10vw, 120px);
  z-index: -1;
}

.about-quote {
  text-align: center;
}

.about-quote img {
  border-radius: 8px;
  margin-bottom: var(--space-md);
}

.about-quote blockquote {
  font-style: italic;
  color: var(--color-secondary);
  font-size: clamp(1rem, 2vw, 1.125rem);
}

/* Intro Section */
.intro-section {
  padding: var(--space-xl) 0;
  background: var(--color-bg-white);
}

.intro-content {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.intro-text {
  font-size: clamp(1.125rem, 2vw, 1.25rem);
  line-height: 1.8;
  color: var(--color-text-light);
}

/* Features Section */
.features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-lg);
}

.feature-card {
  background: var(--color-bg-white);
  padding: var(--space-xl) var(--space-lg);
  text-align: center;
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
}

.feature-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--color-primary);
}

.feature-card:hover {
  box-shadow: var(--shadow-xl);
}

.feature-link {
  text-decoration: none;
  color: inherit;
  display: block;
}

.feature-card .feature-link:hover {
  text-decoration: none;
}

.feature-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-md);
  background: var(--color-primary);
  color: var(--color-bg-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
}

/* Services Section */
.service-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  align-items: center;
  margin-bottom: var(--space-xxl);
}

.service-item:last-child {
  margin-bottom: 0;
}

.service-reverse {
  direction: rtl;
}

.service-reverse .service-content {
  direction: ltr;
}

.service-image img {
  border-radius: 12px;
  box-shadow: var(--shadow-lg);
}

/* Partners Section */
.partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-xl);
  align-items: center;
  justify-items: center;
}

.partners-grid img {
  opacity: 0.6;
  filter: grayscale(100%);
}

.partners-grid img:hover {
  opacity: 1;
  filter: grayscale(0%);
}

/* Dark mode logo adjustments */
[data-theme="dark"] .partners-grid img {
  filter: grayscale(100%) invert(1);
}

[data-theme="dark"] .partners-grid img:hover {
  filter: grayscale(0%) invert(1);
}

/* Testimonials Section */
.testimonial-item {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.testimonial-item img {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  margin: 0 auto var(--space-lg);
  border: 4px solid var(--color-primary);
  object-fit: cover;
}

.testimonial-item blockquote {
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  line-height: 1.8;
  margin-bottom: var(--space-md);
  font-style: italic;
}

.testimonial-item cite {
  color: var(--color-primary);
  font-style: normal;
  font-weight: 600;
}

/* Team Section */
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-xl);
}

.team-member {
  background: var(--color-bg-white);
  border-radius: 12px;
  overflow: hidden;
  text-align: center;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
}

.team-member:hover {
  box-shadow: var(--shadow-xl);
}

.team-member img {
  width: 100%;
  height: 300px;
  object-fit: cover;
}

.team-member h3 {
  color: var(--color-secondary);
  margin: var(--space-md) 0 var(--space-xs);
}

.team-role {
  color: var(--color-primary);
  font-weight: 600;
  margin-bottom: var(--space-sm);
}

.team-member p {
  padding: 0 var(--space-md);
  margin-bottom: var(--space-sm);
}

.team-expertise {
  padding: 0 var(--space-md);
  margin: var(--space-sm) 0;
  text-align: left;
}

.team-expertise ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.team-expertise li {
  font-size: var(--font-size-small);
  color: var(--color-text-light);
  margin-bottom: var(--space-xs);
  padding-left: 1.5rem;
  position: relative;
}

.team-expertise li::before {
  content: "•";
  position: absolute;
  left: 0.5rem;
  color: var(--color-primary);
}

.team-email {
  display: inline-block;
  margin: var(--space-sm) 0 var(--space-md);
  color: var(--color-link);
  font-weight: 500;
  text-decoration: none;
  font-size: var(--font-size-small);
}

.team-email:hover {
  color: var(--color-link-hover);
  text-decoration: underline;
}

.team-placeholder {
  width: 100%;
  height: 300px;
  background: var(--color-bg-light);
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--color-border);
}

.placeholder-icon {
  font-size: 4rem;
  color: var(--color-border);
}

.team-grid-secondary {
  margin-top: var(--space-xl);
}

.team-link {
  display: inline-block;
  margin-bottom: var(--space-md);
  color: var(--color-secondary);
  font-weight: 600;
  text-decoration: none;
}

/* Blog Section */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-lg);
}

.blog-card {
  background: var(--color-bg-white);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: all var(--transition);
  border: 1px solid var(--color-border);
}

.blog-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl);
}

.blog-card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

.blog-content {
  padding: var(--space-lg);
}

.blog-content h3 {
  margin-bottom: var(--space-sm);
}

.read-more {
  color: var(--color-secondary);
  font-weight: 600;
  text-decoration: none;
}

/* Contact Section */
.contact-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-light);
}

.contact-cards .feature-card {
  min-height: 250px;
}

.contact-detail {
  font-size: var(--font-size-h4);
  font-weight: 600;
  color: var(--color-secondary);
  margin: var(--space-xs) 0;
}

.contact-address {
  font-style: normal;
  line-height: 1.8;
  font-size: var(--font-size-small);
}

.contact-footer {
  text-align: center;
  margin-top: var(--space-xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--color-border);
  color: var(--color-text-light);
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-xl);
}

/* Forms - removed as contact form is no longer used */

/* Footer */
.site-footer {
  background: var(--color-bg-dark);
  color: var(--color-bg-white);
  padding: var(--space-xl) 0 var(--space-lg);
  margin-top: var(--space-xxl);
}

.footer-content {
  text-align: center;
}

.footer-logo {
  margin-bottom: var(--space-lg);
}

.footer-logo img {
  height: clamp(50px, 7vw, 60px);
  margin: 0 auto;
  opacity: 0.9;
}

/* Footer Columns */
.footer-columns {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-xl);
  margin: var(--space-xl) 0;
  text-align: left;
}

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

@media (max-width: 768px) {
  .footer-columns {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }
}

.footer-column h4 {
  color: var(--color-text-light);
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-md);
  font-weight: 600;
}

.footer-column p {
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.8;
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-sm);
}

.footer-column a {
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-column a:hover {
  color: var(--color-primary);
}

.footer-partner-logo {
  margin-top: var(--space-md);
}

.footer-partner-logo img {
  max-width: 200px;
  height: auto;
  opacity: 0.9;
  transition: opacity var(--transition-fast);
}

.footer-partner-logo a:hover img {
  opacity: 1;
}

.footer-copyright {
  text-align: center;
  padding-top: var(--space-md);
  margin-top: var(--space-lg);
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.7);
  font-size: var(--font-size-sm);
}

.footer-text {
  margin-bottom: var(--space-lg);
}

.footer-social {
  display: flex;
  justify-content: center;
  gap: var(--space-lg);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}

.footer-social a,
.footer-nav a {
  color: var(--color-bg-white);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-social a:hover,
.footer-nav a:hover {
  color: var(--color-primary);
}

.footer-nav {
  display: flex;
  justify-content: center;
  gap: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  flex-wrap: wrap;
}

/* Back to Top */
.back-to-top {
  position: fixed;
  bottom: var(--space-lg);
  right: var(--space-lg);
  width: 50px;
  height: 50px;
  background: var(--color-primary);
  color: var(--color-bg-dark);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  box-shadow: var(--shadow-lg);
  z-index: 90;
}

.back-to-top.visible {
  opacity: 1;
  visibility: visible;
}

.back-to-top:hover {
  background: var(--color-secondary);
  color: var(--color-bg-white);
  box-shadow: var(--shadow-xl);
}

/* Cookie Banner */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--color-bg-white);
  border-top: 1px solid var(--color-border);
  padding: var(--space-lg);
  box-shadow: 0 -4px 12px var(--color-shadow);
  z-index: 1000;
  display: none;
}

.cookie-banner:not([hidden]) {
  display: block;
}

.cookie-content {
  max-width: var(--container-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-lg);
  align-items: center;
}

.cookie-actions {
  display: flex;
  gap: var(--space-md);
  align-items: center;
}

.cookie-link {
  color: var(--color-primary);
  text-decoration: underline;
  font-size: var(--font-size-small);
}

/* Loading States - animation removed */
.skeleton {
  background: var(--color-bg-light);
}

/* Responsive Design */

/* Tablets - Landscape */
@media (max-width: 1024px) {
  :root {
    --header-height: 70px;
  }
  
  .hero-grid {
    gap: var(--space-lg);
  }
  
  .features-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .service-item {
    gap: var(--space-lg);
  }
}

/* Tablets - Portrait */
@media (max-width: 768px) {
  /* Scroll padding für mobile Header-Höhe */
  html {
    scroll-padding-top: calc(var(--header-height-mobile) + 2rem);
  }
  
  /* Navigation */
  .menu-toggle {
    display: block;
  }
  
  .nav-menu {
    position: fixed;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100vh;
    background: var(--color-bg-white);
    flex-direction: column;
    padding: calc(var(--header-height-mobile) + var(--space-xl)) var(--space-lg) var(--space-lg);
    box-shadow: var(--shadow-xl);
    transition: left var(--transition);
    overflow-y: auto;
    gap: var(--space-md);
    z-index: 99;
  }
  
  .nav-menu.active {
    left: 0;
  }
  
  .nav-menu a {
    display: block;
    padding: var(--space-sm) 0;
    font-size: 1.125rem;
    border-bottom: 1px solid var(--color-border);
  }
  
  .nav-menu a:last-child {
    border-bottom: none;
  }

  /* Mobile Dropdown Menu */
  .sub-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    background: var(--color-bg-secondary);
    border: none;
    border-radius: 0;
    box-shadow: none;
    margin: var(--space-xs) 0;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
  }

  .menu-item-has-children.active .sub-menu {
    max-height: 300px;
  }

  .sub-menu a {
    padding: var(--space-sm) var(--space-lg);
    font-size: 1rem;
    border-bottom: 1px solid var(--color-border-light);
    border-left: none !important;
  }

  .sub-menu a:hover {
    padding-left: var(--space-lg);
  }

  .menu-item-has-children > a i {
    margin-left: auto;
  }

  .menu-item-has-children.active > a i {
    transform: rotate(180deg);
  }

  /* Layout adjustments */
  .hero-section {
    min-height: auto;
    padding: var(--space-xl) 0;
  }
  
  .hero-grid,
  .about-grid,
  .service-item,
  .contact-grid {
    grid-template-columns: 1fr;
    text-align: center;
  }
  
  /* Hide hero image on mobile */
  .hero-image {
    display: none;
  }
  
  .service-reverse {
    direction: ltr;
  }
  
  .service-content {
    order: 2;
  }
  
  .service-image {
    order: 1;
  }
  
  .about-images {
    max-width: 400px;
    margin: 0 auto;
  }
  
  .image-rings {
    display: none;
  }
  
  /* Cookie Banner */
  .cookie-content {
    grid-template-columns: 1fr;
    text-align: center;
  }
  
  .cookie-actions {
    justify-content: center;
    flex-wrap: wrap;
  }
}

/* Mobile */
@media (max-width: 480px) {
  /* Typography */
  :root {
    --font-size-base: 14px;
  }
  
  /* Sections */
  section {
    padding: var(--space-xl) 0;
  }
  
  /* Features */
  .features-grid {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }
  
  /* Team */
  .team-grid {
    grid-template-columns: 1fr;
  }
  
  /* Blog */
  .blog-grid {
    grid-template-columns: 1fr;
  }
  
  /* Partners */
  .partners-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
  }
  
  /* Footer */
  .footer-social,
  .footer-nav {
    flex-direction: column;
    gap: var(--space-sm);
  }
  
  /* Buttons */
  .btn {
    width: 100%;
  }
  
  /* Back to top */
  .back-to-top {
    bottom: var(--space-md);
    right: var(--space-md);
    width: 44px;
    height: 44px;
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  :root {
    --color-primary: #ffff00;
    --color-secondary: #ff0080;
    --color-text: #000000;
    --color-bg-white: #ffffff;
    --color-border: #000000;
    --color-shadow: rgba(0, 0, 0, 0.3);
  }
  
  [data-theme="dark"] {
    --color-text: #ffffff;
    --color-bg-white: #000000;
    --color-border: #ffffff;
  }
  
  * {
    text-shadow: none !important;
  }
}

/* Print Styles */
@media print {
  /* Hide non-essential elements */
  .site-header,
  .back-to-top,
  .menu-toggle,
  .theme-toggle,
  .footer-social,
  .footer-nav,
  .cookie-banner,
  .skip-link {
    display: none !important;
  }
  
  /* Reset layout */
  #main-content {
    padding-top: 0;
  }
  
  /* Optimize for print */
  * {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  
  a {
    text-decoration: underline;
  }
  
  a[href^="http"]:after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
  }
  
  section {
    page-break-inside: avoid;
  }
  
  img {
    max-width: 100% !important;
    page-break-inside: avoid;
  }
  
  h2, h3 {
    page-break-after: avoid;
  }
}

/* ===============================================
   Font Awesome Icons (Optimized Subset)
   =============================================== */
@font-face {
  font-family: 'FontAwesome';
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url('data:application/font-woff2;base64,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') format('woff2');
}

/* Icon Font Class */
.fa {
  font-family: 'FontAwesome';
  font-style: normal;
  font-weight: normal;
  text-decoration: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Icons for Features Section - Using Font Awesome 6 */
.feature-icon {
  font-size: 28px;
}

/* Fix 1: Footer Logo Aspect Ratio */
.footer-logo img {
  height: auto;
  max-height: 60px;
  width: auto;
  margin: 0 auto;
  opacity: 0.9;
  object-fit: contain; /* Prevents distortion */
}

/* Fix 2: Features Section with Font Awesome Icons */
.features-section .feature-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-md);
  background: var(--color-primary);
  color: var(--color-bg-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  transition: all var(--transition);
}


/* Dark mode icon adjustments */
[data-theme="dark"] .feature-icon {
  background: var(--color-primary);
  color: var(--color-bg-dark);
}

.feature-card:hover .feature-icon {
  transform: scale(1.1);
  box-shadow: 0 8px 16px rgba(224, 215, 0, 0.3);
}

/* Fix 3: Testimonials Dark Mode */
.testimonials-section {
  background: var(--color-bg-dark);
  color: var(--color-bg-white);
}

[data-theme="dark"] .testimonials-section {
  background: #0a0a0a;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

.testimonials-section h2,
.testimonials-section .subtitle {
  color: var(--color-bg-white);
}

[data-theme="dark"] .testimonials-section h2,
[data-theme="dark"] .testimonials-section .subtitle {
  color: var(--color-text-light);
}

.testimonial-item blockquote {
  color: var(--color-text-light);
  opacity: 0.95;
}

.testimonial-item cite {
  color: var(--color-primary);
}

/* Fix 4: Team Section Title Colors */
.team-section h2 {
  color: var(--color-text);
}

.team-section .subtitle {
  color: var(--color-primary);
  opacity: 0.8;
}

[data-theme="dark"] .team-section h2 {
  color: var(--color-text);
}

[data-theme="dark"] .team-section .subtitle {
  color: var(--color-primary);
  opacity: 0.9;
}

/* Softer team member colors */
.team-member h3 {
  color: var(--color-text);
  font-weight: 600;
}

.team-role {
  color: var(--color-secondary);
  opacity: 0.8;
  font-weight: 500;
}

[data-theme="dark"] .team-member h3 {
  color: var(--color-text);
}

[data-theme="dark"] .team-role {
  color: var(--color-secondary);
  opacity: 0.9;
}

/* Fix 5: Footer Dark Mode */
.site-footer {
  background: var(--color-bg-dark);
  color: var(--color-bg-white);
}

[data-theme="dark"] .site-footer {
  background: #0a0a0a;
  border-top: 1px solid var(--color-border);
}

.footer-text,
.footer-text p {
  color: var(--color-bg-white);
  opacity: 0.8;
}

[data-theme="dark"] .footer-text,
[data-theme="dark"] .footer-text p {
  color: var(--color-bg-white);
  opacity: 0.9;
}

.footer-social a,
.footer-nav a {
  color: var(--color-bg-white);
  opacity: 0.8;
  text-decoration: none;
  transition: all var(--transition-fast);
}

.footer-social a:hover,
.footer-nav a:hover {
  color: var(--color-primary);
  opacity: 1;
}

[data-theme="dark"] .footer-social a,
[data-theme="dark"] .footer-nav a {
  color: var(--color-text-light);
  opacity: 0.9;
}

[data-theme="dark"] .footer-social a:hover,
[data-theme="dark"] .footer-nav a:hover {
  color: var(--color-primary);
  opacity: 1;
}

.footer-nav {
  border-top-color: rgba(255, 255, 255, 0.2);
}

[data-theme="dark"] .footer-nav {
  border-top-color: var(--color-border);
}

/* Additional Dark Mode Improvements */
[data-theme="dark"] .site-logo img,
[data-theme="dark"] .footer-logo img {
  filter: brightness(0.9);
}

/* Ensure all sections have proper contrast in dark mode */
[data-theme="dark"] .bg-light {
  background-color: #1a1a1a;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

[data-theme="dark"] .feature-card,
[data-theme="dark"] .team-member,
[data-theme="dark"] .blog-card {
  background: var(--color-bg-light);
  border-color: var(--color-border);
}

/* Light Mode: Sections zwischen content-section bg-light und testimonials sollen hell sein */
/* Standard Light Mode (ohne data-theme oder mit data-theme="light") */
:root:not([data-theme="dark"]) .products-section,
:root:not([data-theme="dark"]) .benefits-section,
:root:not([data-theme="dark"]) .printing-section,
:root:not([data-theme="dark"]) .service-section,
:root:not([data-theme="dark"]) .faq-section {
  background: #f8f9fa !important;
  color: #111111;
}

:root:not([data-theme="dark"]) .content-section.bg-light,
:root:not([data-theme="dark"]) .benefits-section.bg-light,
:root:not([data-theme="dark"]) .service-section.bg-light {
  background: #ffffff !important;
}

/* Light Mode: Textfarben für bessere Lesbarkeit */
:root:not([data-theme="dark"]) .products-section h2,
:root:not([data-theme="dark"]) .products-section h3,
:root:not([data-theme="dark"]) .products-section p,
:root:not([data-theme="dark"]) .benefits-section h2,
:root:not([data-theme="dark"]) .benefits-section h3,
:root:not([data-theme="dark"]) .benefits-section p,
:root:not([data-theme="dark"]) .printing-section h2,
:root:not([data-theme="dark"]) .printing-section h3,
:root:not([data-theme="dark"]) .printing-section p,
:root:not([data-theme="dark"]) .service-section h2,
:root:not([data-theme="dark"]) .service-section h3,
:root:not([data-theme="dark"]) .service-section p,
:root:not([data-theme="dark"]) .faq-section h2,
:root:not([data-theme="dark"]) .faq-section h3,
:root:not([data-theme="dark"]) .faq-section p {
  color: #111111 !important;
}

:root:not([data-theme="dark"]) .content-section.bg-light h2,
:root:not([data-theme="dark"]) .content-section.bg-light p {
  color: #111111 !important;
}

:root:not([data-theme="dark"]) .features-grid h3,
:root:not([data-theme="dark"]) .features-grid p,
:root:not([data-theme="dark"]) .contact-cards h3,
:root:not([data-theme="dark"]) .contact-cards p,
:root:not([data-theme="dark"]) .feature-card h3,
:root:not([data-theme="dark"]) .feature-card p,
:root:not([data-theme="dark"]) .contact-card h3,
:root:not([data-theme="dark"]) .contact-card p {
  color: #111111 !important;
}

:root:not([data-theme="dark"]) .feature-card,
:root:not([data-theme="dark"]) .contact-card {
  background: #ffffff !important;
  border-color: #dee2e6 !important;
}

:root:not([data-theme="dark"]) .product-card,
:root:not([data-theme="dark"]) .benefit-box,
:root:not([data-theme="dark"]) .printing-method,
:root:not([data-theme="dark"]) .faq-item {
  background: #ffffff !important;
  border-color: #dee2e6 !important;
  color: #111111 !important;
}

:root:not([data-theme="dark"]) .product-card h3,
:root:not([data-theme="dark"]) .benefit-box h3,
:root:not([data-theme="dark"]) .printing-method h3,
:root:not([data-theme="dark"]) .faq-item h3 {
  color: #111111 !important;
}

:root:not([data-theme="dark"]) .product-description,
:root:not([data-theme="dark"]) .benefit-box p,
:root:not([data-theme="dark"]) .printing-method p,
:root:not([data-theme="dark"]) .faq-item p {
  color: #595959 !important;
}

/* BIC Feuerzeug Konfigurator Styles */

/* === NEUE GESTALTUNGSOPTIONEN === */

/* Radio Button Groups */
.bic-radio-group {
  display: flex;
  gap: 1rem;
  margin-top: 0.5rem;
}

.bic-radio-option {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  padding: 0.5rem;
  border: 1px solid var(--bic-input-border);
  border-radius: 4px;
  transition: background-color 0.2s;
}

.bic-radio-option:hover {
  background-color: var(--bic-hover-bg);
}

.bic-radio-option input[type="radio"] {
  margin: 0;
}

/* Checkbox Labels */
.bic-checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  cursor: pointer;
  padding: 0.5rem 0;
  user-select: none;
}

.bic-checkbox-label input[type="checkbox"] {
  margin-top: 0.25rem;
  cursor: pointer;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.bic-checkbox-label span {
  line-height: 1.5;
  color: var(--bic-card-text);
}

.bic-checkbox-label a {
  color: var(--color-primary);
  text-decoration: underline;
}

.bic-checkbox-label a:hover {
  color: var(--color-primary-dark);
}

/* Design Areas */
.bic-design-area {
  margin: 1rem 0;
  padding: 1rem;
  border: 1px solid var(--bic-card-border);
  border-radius: 8px;
  background-color: var(--bic-card-bg);
}

.bic-design-area h4 {
  margin: 0 0 1rem 0;
  font-size: 1.1rem;
  color: var(--bic-card-text);
}

/* Text Input Areas */
.bic-text-input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid var(--bic-input-border);
  border-radius: 4px;
  background-color: var(--bic-input-bg);
  color: var(--bic-card-text);
  font-size: 1.1rem;
  box-sizing: border-box;
}

/* Multi-Line Text Input */
.bic-text-line-group {
  margin-bottom: 1rem;
  padding: 0.75rem;
  background-color: var(--bic-card-bg);
  border: 1px solid var(--bic-card-border);
  border-radius: 6px;
}

.bic-text-line-label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--bic-card-text);
  font-size: 0.95rem;
}

.bic-text-line-input {
  width: 100%;
  padding: 0.5rem;
  border: 1px solid var(--bic-input-border);
  border-radius: 4px;
  background-color: var(--bic-input-bg);
  color: var(--bic-card-text);
  font-size: 1rem;
  box-sizing: border-box;
  margin-bottom: 0.5rem;
}

.bic-text-line-controls {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.bic-font-select {
  flex: 1 1 120px;
  min-width: 120px;
  padding: 0.4rem;
  border: 1px solid var(--bic-input-border);
  border-radius: 4px;
  background-color: var(--bic-input-bg);
  color: var(--bic-card-text);
  font-size: 0.9rem;
  cursor: pointer;
}

.bic-font-size-wrapper {
  position: relative;
  display: inline-block;
}

.bic-font-size-input {
  width: 60px;
  padding: 0.4rem 1.5rem 0.4rem 0.4rem;
  border: 1px solid var(--bic-input-border);
  border-radius: 4px;
  background-color: var(--bic-input-bg);
  color: var(--bic-card-text);
  font-size: 0.9rem;
  text-align: center;
}

.bic-font-size-unit {
  position: absolute;
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.85rem;
  color: var(--bic-card-text);
  pointer-events: none;
}

.bic-text-color-inline {
  display: flex;
  gap: 0.4rem;
  align-items: center;
}

.bic-text-color-inline .bic-text-color-swatch {
  width: 28px;
  height: 28px;
  border-radius: 4px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color 0.2s, transform 0.2s;
}

.bic-text-color-inline .bic-text-color-swatch:hover {
  transform: scale(1.1);
}

.bic-text-color-inline .bic-text-color-swatch.active {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(248, 153, 47, 0.3);
}

.bic-text-color-custom-inline {
  width: 28px;
  height: 28px;
  border-radius: 4px;
  border: 1px solid var(--bic-input-border);
  cursor: pointer;
  padding: 0;
  position: relative;
  background: conic-gradient(
    #ff0000 0deg,
    #ffff00 60deg,
    #00ff00 120deg,
    #00ffff 180deg,
    #0000ff 240deg,
    #ff00ff 300deg,
    #ff0000 360deg
  );
}

.bic-text-color-custom-inline::-webkit-color-swatch-wrapper {
  padding: 0;
}

.bic-text-color-custom-inline::-webkit-color-swatch {
  border: none;
  border-radius: 3px;
  opacity: 0;
}

.bic-text-color-custom-inline::-moz-color-swatch {
  border: none;
  border-radius: 3px;
  opacity: 0;
}

.bic-text-color-custom-inline.used {
  background: none;
}

.bic-text-color-custom-inline.used::-webkit-color-swatch {
  opacity: 1;
}

.bic-text-color-custom-inline.used::-moz-color-swatch {
  opacity: 1;
}

/* Wrapper für Custom-Color-Button und Label */
.bic-custom-color-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

/* Pantone Label unter Custom-Color-Button */
.bic-pantone-custom-label {
  font-size: 0.65rem;
  color: var(--color-text-light, #666);
  font-weight: 600;
  text-align: center;
  white-space: nowrap;
  display: none;
  max-width: 60px;
  overflow: hidden;
  text-overflow: ellipsis;
}

[data-theme="dark"] .bic-pantone-custom-label {
  color: var(--color-text-light, #ccc);
}

/* Wrapper für Text-Color-Swatches (Weiß/Schwarz) */
.bic-swatch-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

/* Pantone Label unter Text-Color-Swatches */
.bic-pantone-swatch-label {
  font-size: 0.65rem;
  color: var(--color-text-light, #666);
  font-weight: 600;
  text-align: center;
  white-space: nowrap;
  max-width: 60px;
  overflow: hidden;
  text-overflow: ellipsis;
}

[data-theme="dark"] .bic-pantone-swatch-label {
  color: var(--color-text-light, #ccc);
}

/* Progressive Line Display Styles */
.bic-text-line-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5rem;
}

.bic-remove-line-btn {
  background: none;
  border: none;
  color: #dc3545;
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  font-size: 1.1rem;
  transition: transform 0.2s, color 0.2s;
  border-radius: 4px;
}

.bic-remove-line-btn:hover {
  color: #c82333;
  background-color: rgba(220, 53, 69, 0.1);
  transform: scale(1.1);
}

.bic-add-line-btn {
  width: 100%;
  padding: 0.75rem;
  margin-top: 1rem;
  background: linear-gradient(135deg, var(--color-primary) 0%, #e68a2e 100%);
  color: white;
  border: none;
  border-radius: 6px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.bic-add-line-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(248, 153, 47, 0.3);
}

.bic-add-line-btn:active {
  transform: translateY(0);
}

.bic-add-line-btn[style*="display: none"] {
  display: none !important;
}

.bic-text-preview {
  margin-top: 0.5rem;
  padding: 0.5rem;
  background-color: var(--bic-upload-bg);
  border-radius: 4px;
  font-size: 0.9rem;
}

/* === BEIDSEITIGE VORSCHAU === */

/* Doppelte Vorschau Layout */
.bic-double-preview {
  width: 100%;
}

.bic-preview-row {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: space-between;
}

.bic-preview-side {
  flex: 1;
  text-align: center;
}

.bic-preview-side h4 {
  margin: 0 0 0.5rem 0;
  font-size: 0.9rem;
  color: var(--bic-card-text);
}

/* Gespiegelte Rückseite - nur Feuerzeug-Bild spiegeln, nicht die Overlays */
.bic-mirrored .bic-main-image {
  transform: scaleX(-1);
}

/* Logo und Text Overlays in gespiegeltem Container NICHT spiegeln */
.bic-mirrored .bic-logo-overlay {
  transform: scaleX(1); /* Spiegelung aufheben */
}

.bic-mirrored .bic-text-overlay {
  transform: translate(-50%, -50%) rotate(90deg) scaleX(1); /* 90° Rotation + Spiegelung aufheben */
}

/* Text Overlays mit 90 Grad Rotation */
.bic-text-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
  font-family: Arial, sans-serif;
  font-weight: bold;
  font-size: 16px;
  color: #FFF;

  cursor: move;
  user-select: none;
  z-index: 10;
}

/* Text-Overlay bei Kombination mit Logo - nach unten verschieben */
.bic-preview-container.bic-combined .bic-text-overlay {
  top: 70%;
}

/* Responsive Anpassungen */
@media (max-width: 768px) {
  .bic-radio-group {
    flex-direction: column;
    gap: 0.5rem;
  }
  
  .bic-preview-row {
    flex-direction: column;
    gap: 1rem;
  }
  
  .bic-preview-side h4 {
    font-size: 1.1rem;
  }
}

/* Light Mode Variables */
:root {
  --bic-card-bg: #ffffff;
  --bic-card-text: var(--color-text);
  --bic-card-border: #e0e0e0;
  --bic-input-bg: #ffffff;
  --bic-input-border: #ddd;
  --bic-upload-border: #ddd;
  --bic-upload-bg: rgba(248, 153, 47, 0.05);
  --bic-price-bg: rgba(248, 153, 47, 0.1);
  --bic-shadow: rgba(0, 0, 0, 0.1);
  --bic-hover-bg: rgba(248, 153, 47, 0.1);
}

/* Dark Mode Overrides */
[data-theme="dark"],
:root:has(#theme-auto:checked) {
  --bic-card-bg: var(--color-bg-light);
  --bic-card-text: var(--color-text);
  --bic-card-border: var(--color-border);
  --bic-input-bg: var(--color-bg-dark);
  --bic-input-border: var(--color-border);
  --bic-upload-border: var(--color-border);
  --bic-upload-bg: rgba(248, 153, 47, 0.1);
  --bic-price-bg: rgba(248, 153, 47, 0.15);
  --bic-shadow: rgba(0, 0, 0, 0.3);
  --bic-hover-bg: rgba(248, 153, 47, 0.15);
}

/* Auto Dark Mode based on System Preference */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bic-card-bg: var(--color-bg-light);
    --bic-card-text: var(--color-text);
    --bic-card-border: var(--color-border);
    --bic-input-bg: var(--color-bg-dark);
    --bic-input-border: var(--color-border);
    --bic-upload-border: var(--color-border);
    --bic-upload-bg: rgba(248, 153, 47, 0.1);
    --bic-price-bg: rgba(248, 153, 47, 0.15);
    --bic-shadow: rgba(0, 0, 0, 0.3);
  }
}

/* 3-Spalten Grid Layout - Mittlere Spalte 50% breiter */
.bic-configurator-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 2rem;
  margin-top: 2rem;
}

.bic-column {
  min-height: 100%;
}

/* Card Design */
.bic-card {
  background: var(--bic-card-bg);
  color: var(--bic-card-text);
  border: 1px solid var(--bic-card-border);
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: 0 4px 6px var(--bic-shadow);
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: background-color 0.3s, border-color 0.3s, box-shadow 0.3s;
}

.bic-card-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 1.5rem 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary);
  border-bottom: 2px solid var(--color-primary);
  padding-bottom: 0.5rem;
}

.bic-card-title i {
  font-size: 1.5rem;
}

.bic-card-title-logo {
  height: 1.5rem;
  width: auto;
  object-fit: contain;
}

/* === SPALTE 1: LOGO UPLOAD === */
.bic-logo-upload {
  margin-top: 1rem;
  justify-content: center;
}

.bic-upload-area {
  border: 2px dashed var(--bic-upload-border);
  border-radius: 8px;
  padding: 2rem 1rem;
  text-align: center;
  cursor: pointer;
  background: var(--bic-card-bg);
  transition: border-color 0.3s, background-color 0.3s;
}

.bic-upload-area:hover {
  border-color: var(--color-primary);
  background-color: var(--bic-upload-bg);
}

.bic-upload-content i {
  font-size: 3rem;
  color: var(--bic-upload-border);
  margin-top: 1rem;
  justify-content: center;
  display: block;
  transition: color 0.3s;
}

.bic-upload-content p {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 0.5rem 0;
  color: var(--bic-card-text);
}

.bic-upload-hint {
  font-size: 0.875rem;
  color: var(--color-text-light);
}

/* === TOOLTIP FÜR PIXELGRAFIK === */
.bic-tooltip-trigger {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  margin-left: 0.5rem;
  cursor: help;
  color: #ff9800;
  font-size: 1rem;
  vertical-align: middle;
}

.bic-tooltip-trigger:hover,
.bic-tooltip-trigger:focus {
  color: #f57c00;
}

.bic-tooltip-trigger:hover::after,
.bic-tooltip-trigger:focus::after {
  content: attr(data-tooltip-text);
  position: absolute;
  left: 0;
  top: 100%;
  margin-top: 8px;
  background: #fff3cd;
  border: 2px solid #ffc107;
  border-radius: 8px;
  padding: 1rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  width: 350px;
  z-index: 1000;
  color: #664d03;
  font-size: 0.85rem;
  line-height: 1.5;
  white-space: normal;
  pointer-events: none;
}

/* Fallback: Tooltip-Box falls data-tooltip-text zu kompliziert ist */
.bic-tooltip {
  position: fixed;
  z-index: 1000;
  background: #fff3cd;
  border: 2px solid #ffc107;
  border-radius: 8px;
  padding: 1rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  min-width: 300px;
  max-width: 400px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity 0.2s, visibility 0.2s, transform 0.2s;
  pointer-events: none;
}

.bic-tooltip.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.bic-tooltip-content strong {
  display: block;
  color: #8b5a00;
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
}

.bic-tooltip-content ul {
  margin: 0;
  padding-left: 1.25rem;
  color: #664d03;
  list-style-type: disc;
}

.bic-tooltip-content ul li {
  margin-bottom: 0.5rem;
  font-size: 0.85rem;
  line-height: 1.5;
}

.bic-tooltip-content ul li:last-child {
  margin-bottom: 0;
}

/* === MANUELLE FARBANZAHL === */
.bic-manual-colors {
  margin: 1rem 0;
  padding: 1rem;
  background: var(--bic-card-bg);
  border: 1px solid var(--bic-card-border);
  border-radius: 6px;
  position: relative;
}

.bic-manual-colors label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--bic-card-text);
  font-size: 0.95rem;
  position: relative;
}

.bic-manual-colors .bic-color-input {
  width: 100px;
  padding: 0.5rem;
  font-size: 1rem;
  text-align: center;
  margin-bottom: 0.5rem;
}

.bic-manual-colors small {
  display: block;
  color: var(--color-text-light);
  font-size: 0.85rem;
  line-height: 1.5;
  margin-top: 0.5rem;
}

.bic-manual-colors small strong {
  color: #8b5a00;
  display: block;
  margin-bottom: 0.25rem;
}

.bic-logo-preview {
  position: relative;
  text-align: center;
  border: 2px solid var(--color-primary);
  border-radius: 8px;
  padding: 1rem;
  background: var(--bic-upload-bg);
}

.bic-logo-preview img {
  max-width: 100%;
  max-height: 150px;
  border-radius: 4px;
}

.bic-btn-remove {
  position: absolute;
  top: -8px;
  right: -8px;
  background: #e74c3c;
  color: white;
  border: none;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
}

.bic-btn-remove:hover {
  background: #c0392b;
}

/* === EXTRACTED COLORS DISPLAY === */
.bic-extracted-colors {
  margin-top: 1rem;
  padding: 0.75rem;
  background: var(--bic-card-bg);
  border: 1px solid var(--bic-card-border);
  border-radius: 6px;
}

.bic-colors-label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--bic-card-text);
  font-size: 0.9rem;
}

.bic-color-swatches {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.bic-color-swatch-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  position: relative;
  cursor: pointer;
}

.bic-pantone-color-circle {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid var(--bic-card-border);
  transition: transform 0.2s, box-shadow 0.2s;
  position: relative;
}

.bic-color-swatch-item:hover .bic-pantone-color-circle {
  transform: scale(1.1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.bic-pantone-label {
  font-size: 0.7rem;
  color: var(--bic-text-color);
  text-align: center;
  white-space: nowrap;
  max-width: 80px;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}

.bic-color-swatch-remove {
  position: absolute;
  top: -6px;
  right: -6px;
  background: #e74c3c;
  color: white;
  border: 2px solid white;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: bold;
  opacity: 0;
  transition: opacity 0.2s, transform 0.2s, background 0.2s;
  z-index: 10;
}

.bic-color-swatch-item:hover .bic-color-swatch-remove {
  opacity: 1;
}

.bic-color-swatch-remove:hover {
  background: #c0392b;
  transform: scale(1.1);
}

/* Merge-Button (⋮) */
.bic-color-swatch-merge {
  position: absolute;
  top: -6px;
  left: -6px;
  background: #3498db;
  color: white;
  border: 2px solid white;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: bold;
  opacity: 0;
  transition: opacity 0.2s, transform 0.2s, background 0.2s;
  z-index: 10;
  line-height: 1;
}

.bic-color-swatch-item:hover .bic-color-swatch-merge {
  opacity: 1;
}

.bic-color-swatch-merge:hover {
  background: #2980b9;
  transform: scale(1.1);
}

/* Dropdown-Menu */
.bic-color-merge-dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-top: 8px;
  background: white;
  border: 1px solid var(--bic-card-border);
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  min-width: 180px;
  z-index: 1000;
  overflow: hidden;
}

/* Dropdown-Header */
.bic-merge-dropdown-header {
  padding: 8px 12px;
  background: #f8f9fa;
  border-bottom: 1px solid var(--bic-card-border);
  font-size: 0.75rem;
  font-weight: 600;
  color: #666;
  text-transform: uppercase;
}

/* Dropdown-Option */
.bic-merge-dropdown-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  cursor: pointer;
  transition: background 0.2s;
}

.bic-merge-dropdown-option:hover {
  background: #f0f0f0;
}

.bic-merge-dropdown-option:not(:last-child) {
  border-bottom: 1px solid #eee;
}

/* Farb-Preview in Dropdown */
.bic-merge-option-preview {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid var(--bic-card-border);
  flex-shrink: 0;
}

/* Farb-Label */
.bic-merge-option-label {
  font-size: 0.85rem;
  color: #333;
  font-family: 'Courier New', monospace;
}

/* Fade-out-Animation */
.bic-swatch-fade-out {
  animation: swatchFadeOut 0.3s ease-out forwards;
}

@keyframes swatchFadeOut {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 0;
    transform: scale(0.5);
  }
}

.bic-color-swatch-item::after {
  content: attr(data-hex);
  position: absolute;
  bottom: -24px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.8);
  color: white;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 0.7rem;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
  z-index: 5;
}

.bic-color-swatch-item:hover::after {
  opacity: 1;
}

/* === PANTONE PICKER MODAL === */

/* Overlay */
.bic-pantone-picker-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  animation: fadeIn 0.2s ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Modal Container */
.bic-pantone-picker-modal {
  background: white;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  width: 90%;
  max-width: 900px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  animation: slideUp 0.3s ease-out;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Header */
.bic-pantone-picker-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid #e0e0e0;
}

.bic-pantone-picker-header h3 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  color: #333;
}

.bic-pantone-picker-close {
  background: none;
  border: none;
  font-size: 2rem;
  line-height: 1;
  color: #999;
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: background 0.2s, color 0.2s;
}

.bic-pantone-picker-close:hover {
  background: #f0f0f0;
  color: #333;
}

/* Current Color Info */
.bic-pantone-current-color {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  background: #f8f9fa;
  border-bottom: 1px solid #e0e0e0;
}

.bic-pantone-current-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #666;
}

.bic-pantone-current-preview {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid #ddd;
}

.bic-pantone-current-name {
  font-size: 1rem;
  font-weight: 600;
  color: #333;
}

/* Action Container (Ersetzen/Zusammenführen) */
.bic-pantone-action-container {
  padding: 16px 24px;
  background: #f8f9fa;
  border-bottom: 1px solid #e0e0e0;
}

.bic-pantone-action-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #666;
  margin-bottom: 10px;
}

.bic-pantone-action-options {
  display: flex;
  gap: 20px;
  margin-bottom: 12px;
}

.bic-pantone-action-option {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 0.95rem;
  color: #333;
}

.bic-pantone-action-option input[type="radio"] {
  cursor: pointer;
  width: 18px;
  height: 18px;
}

.bic-pantone-merge-target {
  margin-top: 12px;
  padding: 12px;
  background: white;
  border: 1px solid #ddd;
  border-radius: 6px;
}

.bic-pantone-merge-target-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: #666;
  margin-bottom: 12px;
}

.bic-pantone-merge-target-grid {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.bic-pantone-merge-color-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  padding: 8px;
  border: 2px solid transparent;
  border-radius: 8px;
  transition: all 0.2s;
}

.bic-pantone-merge-color-item:hover {
  background: #f8f9fa;
  border-color: #ddd;
}

.bic-pantone-merge-color-item.selected {
  background: rgba(52, 152, 219, 0.1);
  border-color: var(--bic-primary-color, #3498db);
}

.bic-pantone-merge-color-circle {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid #ddd;
}

.bic-pantone-merge-color-label {
  font-size: 0.7rem;
  font-weight: 600;
  color: #333;
  text-align: center;
  max-width: 60px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Search Container */
.bic-pantone-search-container {
  padding: 16px 24px;
  border-bottom: 1px solid #e0e0e0;
}

.bic-pantone-search-input {
  width: 100%;
  padding: 10px 16px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 1rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.bic-pantone-search-input:focus {
  outline: none;
  border-color: var(--bic-primary-color, #3498db);
  box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

/* Grid Container */
.bic-pantone-grid-container {
  flex: 1;
  overflow-y: auto;
  padding: 20px 24px;
  background: #fafafa;
}

.bic-pantone-color-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 16px;
}

/* Grid Item */
.bic-pantone-grid-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 12px;
  background: white;
  border: 2px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
}

.bic-pantone-grid-item:hover {
  border-color: #ddd;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
}

.bic-pantone-grid-item.selected {
  border-color: var(--bic-primary-color, #3498db);
  background: rgba(52, 152, 219, 0.05);
  box-shadow: 0 4px 12px rgba(52, 152, 219, 0.2);
}

.bic-pantone-grid-circle {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 2px solid #ddd;
}

.bic-pantone-grid-name {
  font-size: 0.75rem;
  font-weight: 600;
  color: #333;
  text-align: center;
  word-break: break-word;
}

/* Footer */
.bic-pantone-picker-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding: 16px 24px;
  border-top: 1px solid #e0e0e0;
  background: white;
}

.bic-pantone-picker-btn {
  padding: 10px 24px;
  border: none;
  border-radius: 6px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.bic-pantone-picker-btn-cancel {
  background: #e0e0e0;
  color: #666;
}

.bic-pantone-picker-btn-cancel:hover {
  background: #d0d0d0;
}

.bic-pantone-picker-btn-apply {
  background: var(--bic-primary-color, #3498db);
  color: white;
}

.bic-pantone-picker-btn-apply:hover {
  background: #2980b9;
  box-shadow: 0 4px 12px rgba(52, 152, 219, 0.3);
}

/* === ALLE FARBEN SEKTION === */
.bic-pantone-all-colors-section {
  padding: 16px 24px;
  background: #f8f9fa;
  border-bottom: 1px solid #e0e0e0;
}

.bic-pantone-all-colors-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.bic-pantone-all-colors-label i {
  color: var(--color-primary);
}

.bic-pantone-all-colors-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 12px;
}

.bic-pantone-all-color-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 8px;
  background: white;
  border-radius: 8px;
  border: 2px solid transparent;
  transition: all 0.2s ease;
}

.bic-pantone-all-color-item.current {
  border-color: var(--color-primary);
  background: rgba(248, 153, 47, 0.1);
  box-shadow: 0 2px 8px rgba(248, 153, 47, 0.2);
}

/* Merge-Modus: Items werden klickbar */
.bic-pantone-all-colors-grid.merge-mode .bic-pantone-all-color-item:not(.current) {
  cursor: pointer;
}

.bic-pantone-all-colors-grid.merge-mode .bic-pantone-all-color-item:not(.current):hover {
  border-color: #52c41a;
  background: rgba(82, 196, 26, 0.05);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(82, 196, 26, 0.2);
}

.bic-pantone-all-color-item.merge-selected {
  border-color: #52c41a !important;
  background: rgba(82, 196, 26, 0.15) !important;
  box-shadow: 0 4px 12px rgba(82, 196, 26, 0.3) !important;
}

.bic-pantone-all-color-circle {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 2px solid #ddd;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.bic-pantone-all-color-label {
  font-size: 0.7rem;
  font-weight: 600;
  color: #555;
  text-align: center;
  word-break: break-word;
  line-height: 1.2;
}

/* === PANTONE PICKER DARKMODE === */
[data-theme="dark"] .bic-pantone-picker-overlay {
  background: rgba(0, 0, 0, 0.85);
}

[data-theme="dark"] .bic-pantone-picker-modal {
  background: var(--color-bg-light, #2a2a2a);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
}

[data-theme="dark"] .bic-pantone-picker-header {
  border-bottom-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-picker-header h3 {
  color: var(--color-text, #f0f0f0);
}

[data-theme="dark"] .bic-pantone-picker-close {
  color: #999;
}

[data-theme="dark"] .bic-pantone-picker-close:hover {
  background: var(--color-bg-dark, #0a0a0a);
  color: var(--color-text, #f0f0f0);
}

[data-theme="dark"] .bic-pantone-current-color {
  background: var(--color-bg-dark, #0a0a0a);
  border-bottom-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-current-label,
[data-theme="dark"] .bic-pantone-action-label,
[data-theme="dark"] .bic-pantone-merge-target-label {
  color: var(--color-text-light, #ccc);
}

[data-theme="dark"] .bic-pantone-current-name,
[data-theme="dark"] .bic-pantone-action-option,
[data-theme="dark"] .bic-pantone-merge-color-label,
[data-theme="dark"] .bic-pantone-grid-name {
  color: var(--color-text, #f0f0f0);
}

[data-theme="dark"] .bic-pantone-current-preview,
[data-theme="dark"] .bic-pantone-grid-circle,
[data-theme="dark"] .bic-pantone-merge-color-circle {
  border-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-action-container {
  background: var(--color-bg-dark, #0a0a0a);
  border-bottom-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-merge-target {
  background: var(--color-bg-light, #2a2a2a);
  border-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-merge-color-item:hover {
  background: var(--color-bg-dark, #0a0a0a);
  border-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-merge-color-item.selected {
  background: rgba(248, 153, 47, 0.15);
  border-color: var(--color-primary, #f8992f);
}

[data-theme="dark"] .bic-pantone-search-container {
  border-bottom-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-search-input {
  background: var(--color-bg-dark, #0a0a0a);
  border-color: var(--color-border, #444);
  color: var(--color-text, #f0f0f0);
}

[data-theme="dark"] .bic-pantone-search-input:focus {
  border-color: var(--color-primary, #f8992f);
  box-shadow: 0 0 0 3px rgba(248, 153, 47, 0.2);
}

[data-theme="dark"] .bic-pantone-grid-container {
  background: var(--color-bg-dark, #0a0a0a);
}

[data-theme="dark"] .bic-pantone-grid-item {
  background: var(--color-bg-light, #2a2a2a);
  border-color: transparent;
}

[data-theme="dark"] .bic-pantone-grid-item:hover {
  border-color: var(--color-border, #444);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .bic-pantone-grid-item.selected {
  border-color: var(--color-primary, #f8992f);
  background: rgba(248, 153, 47, 0.1);
  box-shadow: 0 4px 12px rgba(248, 153, 47, 0.3);
}

[data-theme="dark"] .bic-pantone-picker-footer {
  border-top-color: var(--color-border, #444);
  background: var(--color-bg-light, #2a2a2a);
}

[data-theme="dark"] .bic-pantone-picker-btn-cancel {
  background: var(--color-bg-dark, #0a0a0a);
  color: var(--color-text-light, #ccc);
}

[data-theme="dark"] .bic-pantone-picker-btn-cancel:hover {
  background: #333;
}

[data-theme="dark"] .bic-pantone-picker-btn-apply {
  background: var(--color-primary, #f8992f);
  color: #000;
}

[data-theme="dark"] .bic-pantone-picker-btn-apply:hover {
  background: #ffa940;
  box-shadow: 0 4px 12px rgba(248, 153, 47, 0.4);
}

/* Dark Mode: Alle Farben Sektion */
[data-theme="dark"] .bic-pantone-all-colors-section {
  background: var(--color-bg-dark, #0a0a0a);
  border-bottom-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-all-colors-label {
  color: var(--color-text-light, #ccc);
}

[data-theme="dark"] .bic-pantone-all-color-item {
  background: var(--color-bg-light, #2a2a2a);
  border-color: transparent;
}

[data-theme="dark"] .bic-pantone-all-color-item.current {
  border-color: var(--color-primary, #f8992f);
  background: rgba(248, 153, 47, 0.15);
  box-shadow: 0 2px 8px rgba(248, 153, 47, 0.3);
}

[data-theme="dark"] .bic-pantone-all-color-circle {
  border-color: var(--color-border, #444);
}

[data-theme="dark"] .bic-pantone-all-color-label {
  color: var(--color-text-light, #ccc);
}

/* Dark Mode: Merge-Modus Hover */
[data-theme="dark"] .bic-pantone-all-colors-grid.merge-mode .bic-pantone-all-color-item:not(.current):hover {
  border-color: #52c41a;
  background: rgba(82, 196, 26, 0.15);
  box-shadow: 0 4px 12px rgba(82, 196, 26, 0.3);
}

[data-theme="dark"] .bic-pantone-all-color-item.merge-selected {
  border-color: #52c41a !important;
  background: rgba(82, 196, 26, 0.2) !important;
  box-shadow: 0 4px 12px rgba(82, 196, 26, 0.4) !important;
}

/* === REMOVE BACKGROUND OPTION === */
.bic-remove-bg-option {
  margin-top: 1rem;
  padding: 0.75rem;
  background: var(--bic-card-bg);
  border: 1px solid var(--bic-card-border);
  border-radius: 6px;
}

.bic-checkbox-label {
  display: flex;
  align-items: center;
  cursor: pointer;
  user-select: none;
  font-size: 0.9rem;
  color: var(--bic-card-text);
}

.bic-checkbox-label input[type="checkbox"] {
  margin-right: 0.5rem;
  cursor: pointer;
  width: 18px;
  height: 18px;
}

.bic-checkbox-label span {
  font-weight: 500;
}

.bic-logo-controls {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* === SPALTE 2: PRODUKT AUSWAHL === */
.bic-color-section {
  margin: 1.5rem 0;
}

.bic-color-section h4 {
  margin: 0 0 1rem 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--bic-card-text);
}

.bic-product-info {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--bic-card-border);
}

/* === SPALTE 3: BESTELLUNG === */
.bic-order-form {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.bic-form-group {
  margin-top: 1rem;
  justify-content: center;
}

/* === COLOR COUNT DISPLAY === */
.bic-color-count-display {
  margin-top: 1rem;
  padding: 0.75rem;
  background: var(--bic-card-bg);
  border: 1px solid var(--bic-card-border);
  border-radius: 6px;
}

.bic-color-count-info {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  font-size: 0.95rem;
  color: var(--bic-card-text);
}

.bic-color-count-item {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  background: rgba(248, 153, 47, 0.1);
  border-radius: 4px;
  font-weight: 500;
}

.bic-color-count-value {
  font-weight: 700;
  color: var(--color-primary);
  margin-left: 0.25rem;
}

.bic-color-count-warning {
  margin-top: 0.75rem;
  padding: 0.75rem;
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 6px;
  color: #856404;
  font-size: 0.9rem;
  line-height: 1.5;
}

.bic-color-count-warning strong {
  color: #d39e00;
}

.bic-color-count-item.bic-color-count-exceeded .bic-color-count-value {
  color: #e74c3c;
  font-weight: 900;
}

.bic-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.bic-form-group label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
  color: var(--bic-card-text);
}

.bic-input,
.bic-select,
.bic-textarea {
  width: 100%;
  padding: 0.75rem;
  border: 2px solid var(--bic-input-border);
  border-radius: 6px;
  font-size: 1.1rem;
  background: var(--bic-input-bg);
  color: var(--bic-card-text);
  transition: border-color 0.3s, background-color 0.3s;
}

.bic-input:focus,
.bic-select:focus,
.bic-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  background: var(--bic-card-bg);
}

.bic-textarea {
  resize: vertical;
  min-height: 80px;
}

.bic-price-display {
  background: var(--bic-price-bg, #f0fdf4);
  border-radius: 8px;
  padding: 1rem;
  margin: 1.5rem 0;
}

.bic-price-row {
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.bic-price-row:last-child {
  margin-bottom: 0;
}

.bic-total-row {
  font-size: 1.1rem;
  font-weight: bold;
  border-top: 1px solid var(--color-primary);
  opacity: 0.7;
  padding-top: 0.5rem;
  margin-top: 0.5rem;
}

/* Versandkosten-Container */
.bic-shipping-info {
  margin-top: 1rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(0,0,0,0.1);
}

/* Versandkosten-Zeile */
.bic-shipping-row {
  font-size: 0.95rem;
  color: var(--color-text-secondary, #666);
  margin-bottom: 0.5rem;
}

/* Versandkosten-Hinweistext */
.bic-shipping-note {
  font-size: 0.75rem;
  color: #999;
  margin-top: 0.25rem;
  font-style: italic;
}

[data-theme="dark"] .bic-shipping-row {
  color: var(--color-text-light, #ccc);
}

[data-theme="dark"] .bic-shipping-note {
  color: #888;
}

.bic-price-disclaimer {
  font-size: 0.75rem;
  color: #666;
  margin-top: 0.75rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(0,0,0,0.1);
}

.bic-customer-data {
  margin: 1.5rem 0;
}

.bic-customer-data h4 {
  margin: 0 0 1rem 0;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--bic-card-text);
  border-bottom: 1px solid var(--bic-card-border);
  padding-bottom: 0.5rem;
}

/* Buttons */
.bic-btn-primary {
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: 8px;
  padding: 1rem 1.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  transition: background-color 0.3s;
  margin-top: auto;
}

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

.bic-btn-secondary {
  background: var(--bic-card-bg);
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  border-radius: 6px;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s;
}

.bic-btn-secondary:hover {
  background: var(--color-primary);
  color: var(--bic-card-bg);
}

.bic-form-note {
  font-size: 0.875rem;
  color: var(--color-text-light);
  text-align: center;
  margin: 1rem 0 0 0;
  line-height: 1.4;
}

/* Thumbnails nebeneinander, runde Ecken */
.bic-thumbnails {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
  flex-wrap: nowrap;
  justify-content: center;
}

.bic-thumb {
  width: 80px;
  height: 80px;
  border: 1px solid #ccc;
  cursor: pointer;
  overflow: hidden;
  border-radius: 10px;
  transition: border 0.2s;
  background: white;
}

/* Aktives Thumbnail: BIC orange, dicker Rahmen */
.bic-thumb.active { 
  border: 3px solid var(--color-primary); 
  box-shadow: 0 0 8px var(--color-primary);
}

/* Hover-Thumbnail: hellblauer, dicker Rahmen */
.bic-thumb.hovered { 
  border: 3px solid var(--color-link);
  box-shadow: 0 0 8px var(--color-link);
}

.bic-thumb img { 
  width: 100%; 
  height: 100%; 
  object-fit: cover; 
}

/* Hauptvorschau */
.bic-preview { 
  text-align: center; 
  margin-bottom: 20px; 
}

/* Container für Feuerzeugbild und Logo */
.bic-preview-container {
  position: relative;
  display: inline-block;
  max-width: 300px;
  margin: 0 auto;
  padding: 1rem;
  border-radius: 8px;
  background: var(--bic-card-bg);
  border: 1px solid var(--bic-card-border);
}

.bic-main-image {
  max-width: 100%;
  max-height: 300px;
  display: block;
  margin: 0 auto;
}

/* Logo-Overlay: zunächst versteckt */
.bic-logo-overlay {
  position: absolute;
  top: 58%;
  left: 50%;
  cursor: move;
  transform: translate(-50%, -50%) scale(1) rotate(-90deg);
  transform-origin: center;
  box-shadow: none;
  border: none;
  display: none;
  z-index: 10;
}

/* Logo-Overlay bei Kombination mit Text - nach oben verschieben */
.bic-preview-container.bic-combined .bic-logo-overlay {
  top: 45%;
}

/* Druckbereich-Guide: visueller Indikator für druckbare Fläche */
.bic-print-area-guide {
  position: absolute;
  top: 58%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg) scale(0.65);
  border: 4px dashed rgba(248, 153, 47, 0.9);
  pointer-events: none;
  z-index: 5;
  display: none;
  border-radius: 4px;
}

.bic-print-area-label {
  position: absolute;
  background: rgba(100, 100, 100, 0.75);
  color: rgba(255, 255, 255, 0.9);
  padding: 2px 6px;
  border-radius: 2px;
  font-size: 10px;
  font-weight: 500;
  white-space: nowrap;
  pointer-events: none;
  z-index: 6;
  letter-spacing: 0.3px;
}

/* Breite-Label: horizontal unten */
.bic-print-area-label-breite {
  bottom: -50px;
  left: 50%;
  transform: translateX(-50%) rotate(-90deg);
}

/* Höhe-Label: vertikal rechts */
.bic-print-area-label-hoehe {
  right: -62px;
  top: 50%;
  transform: translateY(-50%) rotate(-90deg);
}

/* Modellspezifische Anpassungen werden jetzt dynamisch via JavaScript aus der Datenbank geladen */

.bic-name {
  font-size: 1.1em;
  margin-top: 10px;
  margin-bottom: 10px;
  font-weight: bold;
  text-align: center;
  color: var(--color-text);
}

.bic-preview .bic-name {
  font-size: 1.1em;
  margin-top: 10px;
  font-weight: bold;
  color: var(--color-text);
}

/* Farben nebeneinander */
.bic-color-row {
  display: flex;
  gap: 10px;
  margin: 20px 0;
  justify-content: center;
  flex-wrap: wrap;
}

.bic-color-swatch {
  width: 50px;
  height: 50px;
  border: 2px solid #ccc;
  cursor: pointer;
  background-color: white;
  background-size: cover;
  background-position: center;
  border-radius: 8px;
  transition: border-color 0.2s, transform 0.2s;
}

.bic-color-swatch:hover {
  border-color: var(--color-primary);
  transform: scale(1.05);
}

.bic-color-swatch.active {
  border-color: var(--color-primary);
  border-width: 3px;
}

/* Beschreibung & Preis */
.bic-description { 
  margin: 15px 0; 
  font-size: 1.1rem;
  color: var(--color-text-light);
}

.bic-price { 
  font-weight: bold; 
  margin-bottom: 15px; 
  font-size: 1.2rem;
  color: var(--color-primary);
}

/* Steuerungsknöpfe */
.bic-control-buttons { 
  margin-bottom: 20px; 
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

.bic-control-buttons button { 
  padding: 8px 16px; 
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-weight: 600;
  transition: background-color 0.2s;
}

.bic-control-buttons button:hover {
  background: var(--color-secondary);
}

.bic-control-buttons button:disabled {
  background: #ccc;
  cursor: not-allowed;
}

/* Menge & Gesamtpreis */
.bic-quantity-control { 
  margin-bottom: 15px; 
  text-align: center;
}

.bic-quantity-control label { 
  margin-right: 10px; 
  font-weight: 600;
}

.bic-quantity-control input {
  width: 80px;
  padding: 8px;
  border: 2px solid #ddd;
  border-radius: 4px;
  text-align: center;
  font-size: 1.1rem;
}

.bic-total-price {
  font-size: 1.4rem;
  font-weight: bold;
  color: var(--color-primary);
  text-align: center;
  margin: 20px 0;
  padding: 15px;
  background: rgba(248, 153, 47, 0.1);
  border-radius: 8px;
  border-left: 4px solid var(--color-primary);
}

/* Thank You Popup Modal */
.bic-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}

.bic-modal-overlay.active {
  display: flex;
}

.bic-modal {
  background: var(--bic-card-bg);
  border-radius: 12px;
  padding: 2rem;
  max-width: 500px;
  width: 90%;
  box-shadow: 0 8px 24px var(--bic-shadow);
  text-align: center;
  position: relative;
  color: var(--bic-card-text);
}

.bic-modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  font-size: 1.5rem;
  color: var(--color-text-light);
  cursor: pointer;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.3s;
}

.bic-modal-close:hover {
  background: var(--bic-hover-bg);
}

.bic-modal-icon {
  font-size: 3rem;
  color: var(--color-primary);
  margin-top: 1rem;
  justify-content: center;
}

.bic-modal h3 {
  margin: 0 0 1rem 0;
  color: var(--color-primary);
  font-size: 1.5rem;
}

.bic-modal p {
  margin: 0 0 1.5rem 0;
  line-height: 1.6;
  color: var(--bic-card-text);
}

.bic-modal-buttons {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.bic-modal-button {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 8px;
  font-size: 1.1rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s;
  min-width: 120px;
}

.bic-modal-button.primary {
  background: var(--color-primary);
  color: white;
}

.bic-modal-button.primary:hover {
  background: var(--color-secondary);
}

.bic-modal-button.secondary {
  background: var(--bic-card-bg);
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
}

.bic-modal-button.secondary:hover {
  background: var(--color-primary);
  color: var(--bic-card-bg);
}

/* Responsive Design */
@media (max-width: 1024px) {
  .bic-configurator-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  
  .bic-card {
    padding: 1.25rem;
  }
}

@media (max-width: 768px) {
  .bic-configurator-grid {
    gap: 1rem;
  }
  
  .bic-card {
    padding: 1rem;
  }
  
  .bic-form-row {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
  
  .bic-thumbnails {
    justify-content: center;
  }
  
  .bic-thumb {
    width: 70px;
    height: 70px;
  }
  
  .bic-color-swatch {
    width: 45px;
    height: 45px;
  }
  
  .bic-preview .bic-name {
    font-size: 1em;
  }
  
  .bic-logo-controls {
    flex-direction: column;
  }
  
  .bic-btn-secondary,
  .bic-btn-primary {
    width: 100%;
    justify-content: center;
  }
  
  .bic-upload-area {
    padding: 1.5rem 1rem;
  }
  
  .bic-upload-content i {
    font-size: 2rem;
  }
}

/* Overlay Controls Leiste */
.bic-overlay-controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 1rem;
  gap: 0.5rem;
  max-width: 140px;
  margin-left: auto;
  margin-right: auto;
}

.bic-control-btn {
  background: var(--color-primary);
  color: white;
  border: none;
  border-radius: 4px;
  width: 40px;
  height: 40px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  transition: background-color 0.2s;
}

.bic-control-btn:hover {
  background: var(--color-secondary);
}

.bic-control-btn:active {
  transform: scale(0.95);
}

/* Text Color Picker */
.bic-text-color-picker {
  margin: 1rem 0;
}

.bic-text-color-picker label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--bic-card-text);
}

.bic-color-swatches {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.bic-text-color-swatch {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.2s;
  position: relative;
}

.bic-text-color-swatch:hover {
  transform: scale(1.1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.bic-text-color-swatch.active {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(248, 153, 47, 0.3);
}

.bic-text-color-swatch.custom {
  background: linear-gradient(135deg, #ff0000 0%, #ff7f00 17%, #ffff00 33%, #00ff00 50%, #0000ff 67%, #4b0082 83%, #9400d3 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 1.2rem;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}

.bic-text-color-swatch.custom input[type="color"] {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.bic-text-color-swatch.custom:hover {
  transform: scale(1.15);
}


/* ========================================
   NEW CONTENT SECTIONS STYLING
   ======================================== */

/* Content Section - Intro Text */
.content-section {
  padding: var(--space-xxl) 0;
}

.content-section.bg-light {
  background: var(--color-bg-secondary);
}

.content-row {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px;
}

.content-col-2 {
  flex: 0 0 16.666667%;
  max-width: 16.666667%;
  padding: 0 15px;
}

.content-col-8 {
  flex: 0 0 66.666667%;
  max-width: 66.666667%;
  padding: 0 15px;
}

.content-col-8 h2 {
  color: var(--color-h2);
  margin-bottom: var(--space-lg);
  font-size: var(--font-size-h2);
}

.content-col-8 p {
  margin-bottom: var(--space-md);
  line-height: 1.8;
  color: var(--color-text-primary);
}

@media (max-width: 768px) {
  .content-col-2 {
    display: none;
  }
  .content-col-8 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}

/* Products Section */
.products-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-primary);
}

.products-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

@media (max-width: 1400px) {
  .products-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

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

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

.product-card {
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border-light);
  border-radius: 12px;
  padding: var(--space-sm);
  text-align: center;
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
}

.product-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border-color: var(--color-primary);
}

.product-banner {
  position: absolute;
  top: 15px;
  right: 15px;
  background: var(--color-accent);
  color: var(--color-text-white);
  padding: 5px 15px;
  border-radius: 20px;
  font-size: var(--font-size-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  z-index: 10;
}

.product-banner-new {
  background: #f8992f; /* BIC Orange für "Neu" */
}

.product-image {
  margin-bottom: var(--space-md);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
}

.product-image img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
  transition: transform var(--transition);
}

.product-card:hover .product-image img {
  transform: scale(1.05);
}

.product-content h3 {
  color: var(--color-h3);
  font-size: var(--font-size-h3);
  margin-bottom: var(--space-sm);
}

.product-description {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  line-height: 1.6;
}

/* Benefits Section */
.benefits-section {
  padding: var(--space-xxl) 0;
}

.benefits-section.bg-light {
  background: var(--color-bg-secondary);
}

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}

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

.benefit-box {
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border-light);
  border-radius: 12px;
  padding: var(--space-xl);
  text-align: center;
  transition: all var(--transition);
}

.benefit-box:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
  border-color: var(--color-primary);
}

.benefit-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto var(--space-lg);
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
  color: var(--color-text-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  transition: all var(--transition);
}

.benefit-box:hover .benefit-icon {
  transform: scale(1.1) rotate(5deg);
  box-shadow: 0 8px 20px rgba(33, 88, 143, 0.3);
}

.benefit-box h3 {
  color: var(--color-h3);
  font-size: var(--font-size-h3);
  margin-bottom: var(--space-md);
}

.benefit-box p {
  color: var(--color-text-secondary);
  line-height: 1.7;
}

.benefits-text {
  margin-top: var(--space-xl);
}

.benefits-text p {
  font-size: var(--font-size-md);
  line-height: 1.8;
  color: var(--color-text-primary);
}

/* Printing Section */
.printing-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-primary);
}

.printing-methods {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}

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

.printing-method {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-light);
  border-radius: 12px;
  padding: var(--space-xl);
  text-align: center;
  transition: all var(--transition);
}

.printing-method:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  border-color: var(--color-accent);
}

.printing-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto var(--space-lg);
  background: var(--color-accent);
  color: var(--color-text-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  transition: all var(--transition);
}

.printing-method:hover .printing-icon {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(61, 105, 17, 0.3);
}

.printing-method h3 {
  color: var(--color-h3);
  font-size: var(--font-size-h3);
  margin-bottom: var(--space-md);
}

.printing-method p {
  color: var(--color-text-secondary);
  line-height: 1.7;
}

/* Service Section */
.service-section {
  padding: var(--space-xxl) 0;
}

.service-section.bg-light {
  background: var(--color-bg-secondary);
}

.service-content {
  max-width: 900px;
  margin: var(--space-xl) auto 0;
}

.service-content p {
  font-size: var(--font-size-md);
  line-height: 1.8;
  color: var(--color-text-primary);
}

/* FAQ Section */
.faq-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-primary);
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

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

.faq-item {
  background: var(--color-bg-secondary);
  border-left: 4px solid var(--color-primary);
  border-radius: 8px;
  padding: var(--space-lg);
  transition: all var(--transition);
}

.faq-item:hover {
  transform: translateX(5px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  border-left-color: var(--color-accent);
}

.faq-item h3 {
  color: var(--color-h3);
  font-size: var(--font-size-h4);
  margin-bottom: var(--space-sm);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.faq-item h3 i {
  color: var(--color-primary);
  font-size: var(--font-size-lg);
}

.faq-item p {
  color: var(--color-text-secondary);
  line-height: 1.7;
  margin: 0;
}

/* Section Header Global Styling */
.section-header {
  text-align: center;
  margin-bottom: var(--space-xl);
}

.section-header h2 {
  font-size: var(--font-size-h2);
  margin-bottom: var(--space-md);
}

.section-header p {
  color: var(--color-text-secondary);
  font-size: var(--font-size-md);
  line-height: 1.7;
  max-width: 800px;
  margin: 0 auto;
}

.section-header .subtitle {
  color: var(--color-primary);
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: var(--space-sm);
}

/* ==================================
   PRODUCT PAGES STYLING
   ================================== */

/* Product Hero Section */
.product-hero {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-primary);
}

.product-hero-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xxl);
  align-items: center;
}

@media (max-width: 992px) {
  .product-hero-row {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }
}

.product-hero-image {
  text-align: center;
}

.product-hero-image img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
}

.product-hero-content h1 {
  color: var(--color-h1);
  font-size: var(--font-size-h1);
  line-height: 1.2;
  margin-bottom: var(--space-lg);
}

.product-hero-content h1 .color-accent {
  color: var(--color-accent);
  display: block;
  font-size: var(--font-size-h2);
  margin-top: var(--space-sm);
}

.product-intro {
  font-size: var(--font-size-lg);
  color: var(--color-text-primary);
  margin-bottom: var(--space-xl);
  line-height: 1.6;
}

.product-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-xl) 0;
}

.product-features li {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: var(--font-size-md);
  color: var(--color-text-primary);
  margin-bottom: var(--space-md);
  padding: var(--space-sm) 0;
}

.product-features li i {
  color: var(--color-primary);
  font-size: var(--font-size-lg);
  flex-shrink: 0;
}

/* Color Variants Section */
.color-variants-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-secondary);
}

.color-variants-section .section-title {
  text-align: center;
  color: var(--color-h2);
  font-size: var(--font-size-h2);
  margin-bottom: var(--space-xl);
}

.swiper-container {
  position: relative;
  padding-bottom: var(--space-xl);
}

.swiper-slide {
  text-align: center;
  padding: var(--space-lg);
}

.swiper-slide img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  transition: transform var(--transition);
}

.swiper-slide:hover img {
  transform: scale(1.05);
}

.variant-name {
  margin-top: var(--space-md);
  font-size: var(--font-size-md);
  color: var(--color-text-primary);
  font-weight: 600;
}

.swiper-pagination {
  bottom: 0 !important;
}

.swiper-pagination-bullet {
  background: var(--color-primary);
  opacity: 0.3;
  width: 10px;
  height: 10px;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--color-accent);
}

/* Print Template Section */
.print-template-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-primary);
}

.print-template-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xxl);
  align-items: center;
}

@media (max-width: 992px) {
  .print-template-row {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }
}

.print-template-download h2 {
  color: var(--color-h2);
  font-size: var(--font-size-h2);
  margin-bottom: var(--space-lg);
}

.print-template-download p {
  font-size: var(--font-size-md);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-xl);
  line-height: 1.7;
}

.download-buttons {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.download-buttons .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  width: fit-content;
}

.print-template-preview img {
  max-width: 100%;
  height: auto;
  border: 1px solid var(--color-border-light);
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

/* Product Description Section */
.product-description-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-secondary);
}

.product-description-content {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.product-description-content h2 {
  color: var(--color-h2);
  font-size: var(--font-size-h2);
  margin-bottom: var(--space-xl);
}

.description-text {
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border-light);
  border-radius: 12px;
  padding: var(--space-xl);
  margin-bottom: var(--space-xl);
  text-align: left;
}

.description-text p {
  font-size: var(--font-size-md);
  color: var(--color-text-primary);
  line-height: 1.8;
  margin-bottom: var(--space-lg);
}

.description-text p:last-child {
  margin-bottom: 0;
}

.contact-line {
  font-size: var(--font-size-lg);
  color: var(--color-text-primary);
  margin-bottom: var(--space-lg);
}

.contact-line a {
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: none;
  transition: color var(--transition);
}

.contact-line a:hover {
  color: var(--color-accent);
}

/* Price Examples Section */
.price-examples-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-primary);
}

.price-examples-section .section-title {
  text-align: center;
  color: var(--color-h2);
  font-size: var(--font-size-h2);
  margin-bottom: var(--space-lg);
}

.price-divider {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.price-divider span {
  height: 3px;
  background: var(--color-primary);
  border-radius: 2px;
}

.price-divider .divider-one {
  width: 60px;
}

.price-divider .divider-two {
  width: 40px;
  background: var(--color-accent);
}

.price-divider .divider-three {
  width: 20px;
}

.price-note {
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-xxl);
  font-style: italic;
}

.price-example-row {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-xxl);
  align-items: center;
  max-width: 1000px;
  margin: 0 auto;
}

@media (max-width: 992px) {
  .price-example-row {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }
}

.price-example-image {
  text-align: center;
}

.price-example-image img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
}

/* Price Card */
.price-card {
  background: var(--color-bg-primary);
  border: 2px solid var(--color-primary);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  transition: all var(--transition);
}

.price-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  border-color: var(--color-accent);
}

.price-card-header {
  background: var(--color-primary);
  color: var(--color-text-white);
  padding: var(--space-lg);
  text-align: center;
}

.price-card-quantity {
  font-size: var(--font-size-lg);
  font-weight: 600;
  margin-bottom: var(--space-sm);
}

.price-card-price {
  font-size: 48px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: var(--space-xs);
}

.price-card-unit {
  font-size: var(--font-size-sm);
  opacity: 0.9;
}

.price-card-body {
  padding: var(--space-xl);
}

.price-card-details {
  list-style: none;
  padding: 0;
  margin: 0;
}

.price-card-details li {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: var(--font-size-md);
  color: var(--color-text-primary);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-border-light);
}

.price-card-details li:last-child {
  border-bottom: none;
  font-size: var(--font-size-lg);
  padding-top: var(--space-md);
}

.price-card-details li i {
  color: var(--color-primary);
  font-size: var(--font-size-sm);
}

.price-card-footer {
  padding: 0 var(--space-xl) var(--space-xl);
}

.btn-block {
  width: 100%;
  display: block;
  text-align: center;
}

/* Branding Section */
.branding-section {
  padding: var(--space-xxl) 0;
  background: var(--color-bg-secondary);
}

.branding-section .section-title {
  text-align: center;
  color: var(--color-h2);
  font-size: var(--font-size-h2);
  margin-bottom: var(--space-xxl);
}

.branding-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xxl);
  align-items: center;
  margin-bottom: var(--space-xxl);
}

@media (max-width: 992px) {
  .branding-row {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }
}

.branding-text h3 {
  color: var(--color-h3);
  font-size: var(--font-size-h3);
  margin-bottom: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.branding-text h3 i {
  color: var(--color-accent);
  font-size: var(--font-size-lg);
}

.branding-text p {
  font-size: var(--font-size-md);
  color: var(--color-text-secondary);
  line-height: 1.7;
  margin-bottom: var(--space-xl);
}

.branding-text .link-animated {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-primary);
  text-decoration: none;
  font-weight: 600;
  transition: all var(--transition);
}

.branding-text .link-animated:hover {
  color: var(--color-accent);
  gap: var(--space-md);
}

.branding-image img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

/* Branding Gallery */
.branding-gallery {
  margin-top: var(--space-xxl);
  padding-top: var(--space-xxl);
  border-top: 2px solid var(--color-border-light);
}

.gallery-title {
  text-align: center;
  color: var(--color-h3);
  font-size: var(--font-size-h3);
  margin-bottom: var(--space-xl);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-lg);
}

@media (max-width: 1200px) {
  .gallery-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 992px) {
  .gallery-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

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

.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  cursor: pointer;
  aspect-ratio: 4/3;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition);
}

.gallery-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(61, 105, 17, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--transition);
}

.gallery-overlay i {
  color: var(--color-text-white);
  font-size: 32px;
}

.gallery-item:hover img {
  transform: scale(1.1);
}

.gallery-item:hover .gallery-overlay {
  opacity: 1;
}

/* ========================================
   J26 Product Page - Phase 1 Content
   ======================================== */

/* === USP Section === */
.usp-section {
  padding: 4rem 0;
  background: var(--color-bg-secondary);
}

.usp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 2rem;
  margin-top: 2rem;
}

.usp-item {
  text-align: center;
  padding: 1.5rem;
  background: var(--color-bg-primary);
  border-radius: 8px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.usp-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.usp-icon {
  font-size: 3rem;
  color: var(--color-accent);
  margin-bottom: 1rem;
}

.usp-item h3 {
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
  color: var(--color-text-primary);
}

.usp-item p {
  font-size: 0.9rem;
  color: var(--color-text-secondary);
  margin: 0;
}

/* === Order Info Box === */
.order-info-box {
  margin-top: 2rem;
  padding: 1.5rem;
  background: var(--color-bg-secondary);
  border-radius: 8px;
  border: 1px solid var(--color-border);
}

.order-info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 0.75rem 0;
}

.order-info-item:not(:last-child) {
  border-bottom: 1px solid var(--color-border);
}

.order-info-item i {
  font-size: 1.5rem;
  color: var(--color-accent);
  margin-top: 0.25rem;
  min-width: 24px;
}

.order-info-content {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.order-info-content strong {
  font-size: 0.95rem;
  color: var(--color-text-primary);
}

.order-info-content span {
  font-size: 0.85rem;
  color: var(--color-text-secondary);
}

/* === Compact Info Card (Product Pages) === */
.compact-info-card {
  margin-top: 2rem;
  padding: 2rem;
  background: #ffffff;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  max-width: fit-content;
  text-align: left;
}

/* Dark Mode für compact-info-card wird im Haupt Dark Mode Block behandelt */

.compact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
  text-align: left;
}

.compact-info-item:last-child {
  margin-bottom: 0;
}

.compact-info-item i {
  font-size: 1.75rem;
  color: var(--color-accent);
  margin-top: 0.1rem;
  min-width: 28px;
}

.compact-info-content {
  flex: 1;
  text-align: left;
}

.compact-info-content strong {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 1rem;
  font-weight: 700;
  color: #1f2937;
  line-height: 1.3;
  text-align: left;
}

.compact-info-content span {
  display: block;
  font-size: 0.9rem;
  color: #6b7280;
  line-height: 1.5;
  text-align: left;
}

/* Price Highlight */
.price-highlight {
  margin-bottom: 1.5rem;
}

.price-highlight i {
  font-size: 1.75rem;
  color: var(--color-accent);
}

.price-highlight .compact-info-content strong {
  font-size: 1rem;
  color: #1f2937;
  font-weight: 700;
}

/* Produktseiten-Link */
.bic-product-detail-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.75rem;
  font-size: 0.9rem;
  color: var(--color-primary, #3d6911);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s, gap 0.2s;
}

.bic-product-detail-link:hover {
  color: #2d4f09;
  gap: 0.65rem;
}

.bic-product-detail-link i {
  font-size: 0.8rem;
  opacity: 0.7;
}

[data-theme="dark"] .bic-product-detail-link {
  color: #7cb342;
}

[data-theme="dark"] .bic-product-detail-link:hover {
  color: #8bc34a;
}

/* Dezentere Variante für Startseite */
.compact-info-card-subtle {
  margin-top: 1.25rem;
  padding: 1rem 1.25rem;
  background: rgba(0, 0, 0, 0.02);
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.compact-info-card-subtle .compact-info-item {
  gap: 1rem;
  margin-bottom: 1rem;
}

.compact-info-card-subtle .compact-info-item:last-child {
  margin-bottom: 0;
}

.compact-info-card-subtle .compact-info-item i {
  font-size: 1.25rem;
  opacity: 0.7;
}

.compact-info-card-subtle .compact-info-content strong {
  font-size: 0.9rem;
  font-weight: 600;
  color: #374151;
}

.compact-info-card-subtle .compact-info-content span {
  font-size: 0.8rem;
  color: #9ca3af;
}

.compact-info-card-subtle .price-highlight .compact-info-content strong {
  font-size: 0.95rem;
}

[data-theme="dark"] .compact-info-card-subtle {
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .compact-info-card-subtle .compact-info-content strong {
  color: #d1d5db;
}

[data-theme="dark"] .compact-info-card-subtle .compact-info-content span {
  color: #6b7280;
}

/* Mobile Optimization */
@media (max-width: 992px) {
  .compact-info-card {
    margin-top: 1.5rem;
    padding: 1.5rem;
    max-width: 100%;
  }

  .compact-info-item {
    gap: 1.25rem;
    margin-bottom: 1.25rem;
  }

  .compact-info-item i {
    font-size: 1.5rem;
    min-width: 24px;
  }

  .compact-info-content strong {
    font-size: 0.95rem;
  }

  .compact-info-content span {
    font-size: 0.85rem;
  }
}

/* === Technical Specifications === */
.tech-specs-section {
  padding: 4rem 0;
  background: var(--color-bg-primary);
}

.specs-table-wrapper {
  margin-top: 2rem;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  overflow-x: auto;
}

.specs-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
}

.specs-table tr {
  border-bottom: 1px solid var(--color-border);
}

.specs-table tr:last-child {
  border-bottom: none;
}

.specs-table td {
  padding: 1rem 1.5rem;
}

.spec-label {
  font-weight: 600;
  color: var(--color-text-primary);
  width: 40%;
  background: var(--color-bg-secondary);
}

.spec-value {
  color: var(--color-text-secondary);
  width: 60%;
}

.spec-value i {
  margin-right: 0.5rem;
}

/* === FAQ Section === */
.faq-section {
  padding: 4rem 0;
  background: var(--color-bg-secondary);
}

.faq-grid {
  display: grid;
  gap: 1.5rem;
  margin-top: 2rem;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}

.faq-item {
  background: var(--color-bg-primary);
  padding: 1.5rem;
  border-radius: 8px;
  border: 1px solid var(--color-border);
  transition: box-shadow 0.3s ease;
}

.faq-item:hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.faq-question {
  font-size: 1.1rem;
  margin: 0 0 1rem 0;
  color: var(--color-text-primary);
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.faq-question i {
  color: var(--color-accent);
  margin-top: 0.25rem;
  flex-shrink: 0;
}

.faq-answer {
  color: var(--color-text-secondary);
  line-height: 1.6;
}

.faq-answer p {
  margin: 0;
}

.faq-answer strong {
  color: var(--color-text-primary);
}

.faq-answer a {
  color: var(--color-accent);
  text-decoration: none;
  font-weight: 600;
}

.faq-answer a:hover {
  text-decoration: underline;
}

/* === Responsive === */
@media (max-width: 768px) {
  .usp-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
  }

  .usp-item {
    padding: 1rem;
  }

  .usp-icon {
    font-size: 2.5rem;
  }

  .order-info-box {
    padding: 1rem;
  }

  .order-info-item {
    gap: 0.75rem;
  }

  .specs-table td {
    padding: 0.75rem 1rem;
  }

  .spec-label {
    width: 45%;
  }

  .spec-value {
    width: 55%;
  }

  .faq-item {
    padding: 1rem;
  }

  .faq-question {
    font-size: 1rem;
  }
}

/* ===============================================
   J26 Product Page - Phase 2 Content
   =============================================== */

/* === Comparison Table Section === */
.comparison-section {
  padding: 4rem 0;
  background: var(--color-bg-secondary);
  overflow-x: auto;
}

/* Desktop/Mobile Toggle */
.desktop-only {
  display: block;
}

.mobile-only {
  display: none;
}

.comparison-section .section-title {
  text-align: center;
  margin-bottom: 3rem;
  color: var(--color-text-primary);
}

.comparison-section .section-subtitle {
  text-align: center;
  max-width: 800px;
  margin: 0 auto 3rem;
  color: var(--color-text-secondary);
  font-size: 1.125rem;
}

.comparison-table-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.comparison-table {
  width: 100%;
  background: var(--color-bg-primary);
  border-collapse: collapse;
  border-spacing: 0;
  min-width: 700px;
  table-layout: fixed;
}

.comparison-table thead {
  background: var(--color-bg-dark);
  color: var(--color-bg-white);
}

[data-theme="dark"] .comparison-table thead {
  background: #1a1a1a;
  border-bottom: 2px solid var(--color-border);
}

.comparison-table th {
  padding: 1.5rem 1rem;
  text-align: center;
  font-weight: 600;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .comparison-table th {
  border-right-color: var(--color-border);
}

.comparison-table th:last-child {
  border-right: none;
}

.comparison-feature {
  text-align: left !important;
  width: 20%;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.comparison-model {
  width: auto;
}

.comparison-highlight {
  background: var(--color-primary) !important;
  color: var(--color-bg-dark) !important;
}

[data-theme="dark"] .comparison-highlight {
  background: var(--color-primary) !important;
  color: var(--color-bg-dark) !important;
}

.model-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  min-height: 240px;
}

.model-header img {
  width: 150px;
  height: auto;
  max-height: 200px;
  object-fit: contain;
  object-position: bottom;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
  margin-top: auto;
}

.model-header strong {
  display: block;
  font-size: 1.1rem;
  margin-bottom: 0.25rem;
}

.model-badge {
  display: inline-block;
  padding: 0.25rem 0.75rem;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.comparison-highlight .model-badge {
  background: rgba(0, 0, 0, 0.15);
}

.comparison-table tbody tr {
  border-bottom: 1px solid var(--color-border);
  transition: background-color 0.2s ease;
}

.comparison-table tbody tr:hover {
  background: rgba(224, 215, 0, 0.05);
}

[data-theme="dark"] .comparison-table tbody tr:hover {
  background: rgba(224, 215, 0, 0.1);
}

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

.comparison-table td {
  padding: 1.25rem 1rem;
  text-align: center;
  vertical-align: middle;
  border-right: 1px solid var(--color-border);
}

.comparison-table td:first-child {
  text-align: left;
  font-weight: 600;
  color: var(--color-text-primary);
}

.comparison-table td:last-child {
  border-right: none;
}

.comparison-highlight-cell {
  background: rgba(224, 215, 0, 0.08);
  font-weight: 600;
  color: var(--color-text-primary);
}

[data-theme="dark"] .comparison-highlight-cell {
  background: rgba(224, 215, 0, 0.12);
}

.comparison-value {
  display: block;
  font-size: 1rem;
  color: var(--color-text-primary);
}

.comparison-cta {
  display: inline-block;
  padding: 0.5rem 1.5rem;
  margin-top: 0.5rem;
  background: var(--color-primary);
  color: var(--color-bg-dark);
  text-decoration: none;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.9rem;
  transition: all 0.3s ease;
  border: 2px solid var(--color-primary);
}

.comparison-cta:hover {
  background: transparent;
  color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(224, 215, 0, 0.3);
}

.comparison-cta-secondary {
  background: transparent;
  color: var(--color-text-primary);
  border: 2px solid var(--color-border);
}

.comparison-cta-secondary:hover {
  background: var(--color-bg-secondary);
  border-color: var(--color-text-secondary);
  color: var(--color-text-primary);
}

/* === Trust Elements Section === */
.trust-section {
  padding: 4rem 0;
  background: var(--color-bg-primary);
}

.trust-section .section-title {
  text-align: center;
  margin-bottom: 3rem;
  color: var(--color-text-primary);
}

.trust-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  margin-top: 2rem;
}

.trust-item {
  text-align: center;
  padding: 2rem 1.5rem;
  background: var(--color-bg-secondary);
  border-radius: 12px;
  border: 2px solid var(--color-border);
  transition: all 0.3s ease;
}

.trust-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border-color: var(--color-primary);
}

[data-theme="dark"] .trust-item:hover {
  box-shadow: 0 8px 24px rgba(224, 215, 0, 0.2);
}

.trust-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto 1.5rem;
  background: var(--color-primary);
  color: var(--color-bg-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  transition: all 0.3s ease;
}

.trust-item:hover .trust-icon {
  transform: scale(1.1) rotate(5deg);
  box-shadow: 0 8px 16px rgba(224, 215, 0, 0.4);
}

.trust-item h3 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: 0.75rem;
}

.trust-item p {
  font-size: 0.95rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin: 0;
}

/* === Use Cases Section === */
.use-cases-section {
  padding: 4rem 0;
  background: var(--color-bg-secondary);
}

.use-cases-section .section-title {
  text-align: center;
  margin-bottom: 3rem;
  color: var(--color-text-primary);
}

.use-cases-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
  margin-top: 2rem;
}

.use-case-item {
  background: var(--color-bg-primary);
  padding: 2rem;
  border-radius: 12px;
  border: 2px solid var(--color-border);
  transition: all 0.3s ease;
}

.use-case-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  border-color: var(--color-primary);
}

[data-theme="dark"] .use-case-item:hover {
  box-shadow: 0 8px 24px rgba(224, 215, 0, 0.2);
}

.use-case-icon {
  width: 56px;
  height: 56px;
  background: var(--color-primary);
  color: var(--color-bg-dark);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin-bottom: 1.5rem;
  transition: all 0.3s ease;
}

.use-case-item:hover .use-case-icon {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(224, 215, 0, 0.4);
}

.use-case-item h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: 1rem;
}

.use-case-item > p {
  font-size: 1rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin-bottom: 1.5rem;
}

.use-case-benefits {
  list-style: none;
  padding: 0;
  margin: 0;
}

.use-case-benefits li {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.95rem;
  color: var(--color-text-primary);
  margin-bottom: 0.75rem;
  padding-left: 0.5rem;
}

.use-case-benefits li:last-child {
  margin-bottom: 0;
}

.use-case-benefits li i {
  color: var(--color-primary);
  font-size: 1rem;
  flex-shrink: 0;
}

/* Mobile Responsiveness - Phase 2 */
@media (max-width: 768px) {
  /* Comparison Table */
  .comparison-section {
    padding: 2rem 0;
  }

  .comparison-section .section-intro {
    font-size: 0.95rem;
    margin-bottom: 1rem;
  }

  .comparison-table-wrapper {
    margin: 0 -1rem;
    border-radius: 0;
    position: relative;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--color-primary) rgba(0, 0, 0, 0.1);
  }

  /* Scroll-Hinweis */
  .comparison-table-wrapper::after {
    content: '→';
    position: sticky;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 100%;
    background: linear-gradient(to right, transparent, rgba(255, 255, 255, 0.95));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--color-primary);
    pointer-events: none;
    opacity: 0.8;
  }

  [data-theme="dark"] .comparison-table-wrapper::after {
    background: linear-gradient(to right, transparent, rgba(26, 26, 26, 0.95));
  }

  .comparison-table {
    min-width: 1000px;
  }

  .comparison-table th,
  .comparison-table td {
    padding: 0.75rem 0.5rem;
    font-size: 0.8rem;
  }

  .comparison-feature {
    width: 25%;
    font-size: 0.75rem;
    padding-left: 0.75rem !important;
    position: sticky;
    left: 0;
    background: var(--color-bg-primary);
    z-index: 1;
  }

  [data-theme="dark"] .comparison-feature {
    background: var(--color-bg-dark);
  }

  .comparison-table thead .comparison-feature {
    background: var(--color-bg-dark);
  }

  [data-theme="dark"] .comparison-table thead .comparison-feature {
    background: #1a1a1a;
  }

  .model-header {
    min-height: 160px;
    gap: 0.5rem;
  }

  .model-header img {
    width: 80px;
    height: auto;
    max-height: 100px;
  }

  .model-header strong {
    font-size: 0.85rem;
  }

  .model-badge {
    font-size: 0.6rem;
    padding: 0.15rem 0.4rem;
  }

  .comparison-table tbody tr td:first-child {
    font-size: 0.75rem;
  }

  .comparison-table tbody tr td {
    font-size: 0.75rem;
  }

  .comparison-highlight-cell {
    position: sticky;
    left: 0;
    z-index: 0;
  }

  .comparison-cta {
    font-size: 0.75rem;
    padding: 0.5rem 0.75rem;
    white-space: nowrap;
  }

  .comparison-table tbody tr td small {
    font-size: 0.65rem;
    display: block;
    margin-top: 0.25rem;
  }

  /* Trust Elements */
  .trust-section {
    padding: 2rem 0;
  }

  .trust-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .trust-item {
    padding: 1.5rem 1rem;
  }

  .trust-icon {
    width: 56px;
    height: 56px;
    font-size: 24px;
    margin-bottom: 1rem;
  }

  .trust-item h3 {
    font-size: 1rem;
  }

  .trust-item p {
    font-size: 0.9rem;
  }

  /* Use Cases */
  .use-cases-section {
    padding: 2rem 0;
  }

  .use-cases-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .use-case-item {
    padding: 1.5rem;
  }

  .use-case-icon {
    width: 48px;
    height: 48px;
    font-size: 20px;
    margin-bottom: 1rem;
  }

  .use-case-item h3 {
    font-size: 1.1rem;
  }

  .use-case-item > p {
    font-size: 0.95rem;
  }

  .use-case-benefits li {
    font-size: 0.9rem;
  }
}

/* ===============================================
   FAQ Page Styles
   =============================================== */

/* Hero Section */
.hero-section.hero-small {
  background: linear-gradient(135deg, var(--color-h2, #2c5f2d) 0%, var(--color-h1, #57762a) 100%);
  color: white;
  padding: 4rem 0;
  text-align: center;
}

.hero-title {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  font-weight: 700;
}

.hero-subtitle {
  font-size: 1.2rem;
  opacity: 0.95;
  color: rgba(255, 255, 255, 0.9);
}

/* FAQ Page Section */
.faq-page-section {
  padding: 4rem 0;
  background: var(--color-bg-secondary, #f8f9fa);
}

/* Category Navigation */
.faq-category-nav {
  background: var(--color-bg-primary, #ffffff);
  padding: 2rem;
  border-radius: 12px;
  margin-bottom: 3rem;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  border: 1px solid var(--color-border, #e9ecef);
}

.faq-category-nav h2 {
  margin-bottom: 1.5rem;
  color: var(--color-text-primary, #2c3e50);
  font-size: 1.75rem;
}

.faq-nav-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
}

.faq-nav-item {
  display: flex;
  align-items: center;
  padding: 1rem 1.25rem;
  background: var(--color-bg-secondary, #f8f9fa);
  border-radius: 8px;
  text-decoration: none;
  color: var(--color-text-primary, #2c3e50);
  transition: all 0.3s ease;
  border-left: 3px solid var(--color-accent, #f8992f);
  font-weight: 500;
}

.faq-nav-item:hover {
  background: var(--color-accent, #f8992f);
  color: white;
  transform: translateX(5px);
  box-shadow: 0 2px 8px rgba(248, 153, 47, 0.3);
}

.faq-nav-item i {
  margin-right: 0.75rem;
  font-size: 0.9rem;
}

.faq-count {
  margin-left: auto;
  font-size: 0.875rem;
  opacity: 0.7;
  font-weight: 400;
}

/* Category Sections */
.faq-category-section {
  background: var(--color-bg-primary, #ffffff);
  padding: 2.5rem;
  border-radius: 12px;
  margin-bottom: 2rem;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  border: 1px solid var(--color-border, #e9ecef);
}

.faq-category-title {
  color: var(--color-text-primary, #2c3e50);
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid var(--color-border, #e9ecef);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 1.75rem;
  font-weight: 700;
}

.faq-category-title i {
  color: var(--color-accent, #f8992f);
  font-size: 1.5rem;
}

/* Model Badge */
.faq-model-badge {
  display: inline-block;
  background: var(--color-accent, #f8992f);
  color: white;
  padding: 0.25rem 0.75rem;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  margin-left: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Contact Section */
.faq-contact-section {
  margin-top: 3rem;
}

.faq-contact-box {
  background: linear-gradient(135deg, var(--color-accent, #f8992f) 0%, var(--color-h1, #d77622) 100%);
  color: white;
  padding: 3rem 2rem;
  border-radius: 12px;
  text-align: center;
  box-shadow: 0 4px 16px rgba(248, 153, 47, 0.2);
}

.faq-contact-box h3 {
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  font-size: 1.5rem;
  font-weight: 700;
}

.faq-contact-box p {
  margin-bottom: 1.75rem;
  opacity: 0.95;
  font-size: 1.1rem;
}

.faq-contact-methods {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

.faq-contact-methods .btn {
  padding: 0.875rem 1.75rem;
  text-decoration: none;
  border-radius: 8px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: all 0.3s ease;
  font-size: 1rem;
}

.faq-contact-methods .btn-primary {
  background: white;
  color: var(--color-accent, #f8992f);
  border: 2px solid white;
}

.faq-contact-methods .btn-primary:hover {
  background: var(--color-bg-secondary, #f8f9fa);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.faq-contact-methods .btn-secondary {
  background: rgba(255, 255, 255, 0.15);
  color: white;
  border: 2px solid white;
}

.faq-contact-methods .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.25);
  transform: translateY(-2px);
}

/* Empty State */
.faq-empty-state {
  text-align: center;
  padding: 4rem 2rem;
  background: var(--color-bg-primary, #ffffff);
  border-radius: 12px;
  border: 1px solid var(--color-border, #e9ecef);
}

.faq-empty-state i {
  font-size: 4rem;
  color: var(--color-text-secondary, #6c757d);
  margin-bottom: 1.5rem;
  opacity: 0.5;
}

.faq-empty-state h3 {
  color: var(--color-text-primary, #2c3e50);
  margin-bottom: 1rem;
  font-size: 1.5rem;
}

.faq-empty-state p {
  color: var(--color-text-secondary, #6c757d);
  font-size: 1.1rem;
}

.faq-empty-state a {
  color: var(--color-accent, #f8992f);
  font-weight: 600;
  text-decoration: none;
}

.faq-empty-state a:hover {
  text-decoration: underline;
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
  .hero-section.hero-small {
    background: linear-gradient(135deg, #1a1a1a 0%, #0d0d0d 100%);
  }

  .faq-page-section {
    background: #1a1a1a;
  }

  .faq-category-nav,
  .faq-category-section,
  .faq-empty-state {
    background: #2d2d2d;
    border-color: #404040;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
  }

  .faq-category-nav h2,
  .faq-category-title,
  .faq-empty-state h3 {
    color: #f5f5f5;
  }

  .faq-empty-state p {
    color: #b8b8b8;
  }

  .faq-nav-item {
    background: #1a1a1a;
    color: #f5f5f5;
    border-left-color: var(--color-accent);
  }

  .faq-nav-item:hover {
    background: var(--color-accent);
    color: #0d0d0d;
  }

  .faq-contact-box {
    background: linear-gradient(135deg, var(--color-accent) 0%, #6fa030 100%);
  }

  .faq-contact-methods .btn-primary {
    background: #0d0d0d;
    color: var(--color-accent);
    border-color: var(--color-accent);
  }

  .faq-contact-methods .btn-primary:hover {
    background: #1a1a1a;
  }
}

/* Responsive FAQ Page */
@media (max-width: 768px) {
  .hero-title {
    font-size: 2rem;
  }

  .hero-subtitle {
    font-size: 1rem;
  }

  .faq-nav-grid {
    grid-template-columns: 1fr;
  }

  .faq-category-nav,
  .faq-category-section {
    padding: 1.5rem;
  }

  .faq-category-title {
    font-size: 1.5rem;
  }

  .faq-contact-box {
    padding: 2rem 1.5rem;
  }

  .faq-contact-box h3 {
    font-size: 1.25rem;
  }

  .faq-contact-methods {
    flex-direction: column;
  }

  .faq-contact-methods .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ===============================================
   Scroll-to-Top Button
   =============================================== */

.scroll-to-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, #f8992f 0%, #d77622 100%);
  color: white;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 12px rgba(248, 153, 47, 0.3);
  z-index: 9999;
  font-size: 1.5rem;
}

.scroll-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.scroll-to-top:hover {
  transform: translateY(-5px) scale(1.05);
  box-shadow: 0 6px 20px rgba(248, 153, 47, 0.5);
  background: linear-gradient(135deg, #ffa940 0%, #e68829 100%);
}

.scroll-to-top:active {
  transform: translateY(-3px) scale(1.02);
}

.scroll-to-top:focus {
  outline: 3px solid rgba(248, 153, 47, 0.5);
  outline-offset: 3px;
}

.scroll-to-top i {
  transition: transform 0.3s ease;
}

.scroll-to-top:hover i {
  transform: translateY(-3px);
  animation: bounce-up 0.6s ease infinite;
}

@keyframes bounce-up {
  0%, 100% {
    transform: translateY(-3px);
  }
  50% {
    transform: translateY(-8px);
  }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
  .scroll-to-top {
    background: linear-gradient(135deg, var(--color-accent) 0%, #D8770A 100%);
    box-shadow: 0 4px 12px rgba(100, 69, 34, 0.4);
    color: #0d0d0d;
  }

  .scroll-to-top:hover {
    box-shadow: 0 6px 20px rgba(100, 69, 34, 0.6);
    background: linear-gradient(135deg, var(--color-accent-hover) 0%, #8ac045 100%);
  }

  .scroll-to-top:focus {
    outline: 3px solid rgba(100, 69, 34, 0.5);
  }
}

/* Mobile Optimierung */
@media (max-width: 768px) {
  .scroll-to-top {
    bottom: 20px;
    right: 20px;
    width: 48px;
    height: 48px;
    font-size: 1.25rem;
  }
}

/* Tablet */
@media (max-width: 1024px) and (min-width: 769px) {
  .scroll-to-top {
    bottom: 25px;
    right: 25px;
  }
}

