/* =============================================
   DORIVNEX LAB - BIENENWACHS KURS
   Design: Layered Depth
   ============================================= */

/* ---- BASE COLOR SYSTEM ---- */
:root {
  --base-amber: oklch(68% 0.18 60);
  --base-dark: oklch(18% 0.04 55);
  --base-cream: oklch(97% 0.03 80);

  --primary: var(--base-amber);
  --primary-light: color-mix(in oklch, var(--base-amber), white 35%);
  --primary-lighter: color-mix(in oklch, var(--base-amber), white 65%);
  --primary-dark: color-mix(in oklch, var(--base-amber), black 25%);
  --primary-darker: color-mix(in oklch, var(--base-amber), black 45%);
  --primary-subtle: color-mix(in oklch, var(--base-amber), white 85%);

  --dark: var(--base-dark);
  --dark-mid: color-mix(in oklch, var(--base-dark), white 20%);
  --dark-soft: color-mix(in oklch, var(--base-dark), white 45%);
  --dark-muted: color-mix(in oklch, var(--base-dark), white 65%);

  --surface: var(--base-cream);
  --surface-warm: color-mix(in oklch, var(--base-cream), var(--base-amber) 8%);
  --surface-card: color-mix(in oklch, var(--base-cream), white 60%);
  --surface-dark: color-mix(in oklch, var(--base-dark), white 6%);

  --accent: oklch(55% 0.22 30);
  --accent-light: color-mix(in oklch, oklch(55% 0.22 30), white 40%);
  --accent-subtle: color-mix(in oklch, oklch(55% 0.22 30), white 82%);

  --text-primary: color-mix(in oklch, var(--base-dark), white 5%);
  --text-secondary: color-mix(in oklch, var(--base-dark), white 40%);
  --text-muted: color-mix(in oklch, var(--base-dark), white 58%);
  --text-on-dark: color-mix(in oklch, var(--base-cream), white 20%);
  --text-on-primary: color-mix(in oklch, var(--base-dark), white 5%);

  --border: color-mix(in oklch, var(--base-amber), white 72%);
  --border-soft: color-mix(in oklch, var(--base-amber), white 85%);

  /* SHADOWS - Layered Depth System */
  --shadow-xs: 0 1px 3px color-mix(in oklch, var(--base-dark), transparent 88%),
               0 1px 2px color-mix(in oklch, var(--base-dark), transparent 94%);
  --shadow-sm: 0 2px 6px color-mix(in oklch, var(--base-dark), transparent 84%),
               0 1px 3px color-mix(in oklch, var(--base-dark), transparent 90%);
  --shadow-md: 0 4px 16px color-mix(in oklch, var(--base-dark), transparent 82%),
               0 2px 6px color-mix(in oklch, var(--base-dark), transparent 88%),
               0 0 0 1px color-mix(in oklch, var(--base-amber), transparent 90%);
  --shadow-lg: 0 8px 32px color-mix(in oklch, var(--base-dark), transparent 78%),
               0 4px 12px color-mix(in oklch, var(--base-dark), transparent 86%),
               0 0 0 1px color-mix(in oklch, var(--base-amber), transparent 88%);
  --shadow-xl: 0 16px 48px color-mix(in oklch, var(--base-dark), transparent 72%),
               0 8px 24px color-mix(in oklch, var(--base-dark), transparent 82%),
               0 2px 8px color-mix(in oklch, var(--base-amber), transparent 80%);
  --shadow-glow: 0 0 24px color-mix(in oklch, var(--base-amber), transparent 60%),
                 0 4px 16px color-mix(in oklch, var(--base-amber), transparent 72%);

  /* SPACING */
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: 6rem;
  --space-3xl: 9rem;

  /* RADIUS */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 32px;
  --radius-full: 9999px;

  /* TRANSITIONS */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 250ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 400ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-spring: 350ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ---- RESET & BASE ---- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
}

body {
  font-family: 'Sora', sans-serif;
  font-size: 1rem;
  line-height: 1.65;
  color: var(--text-primary);
  background-color: var(--surface);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

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

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

ul { list-style: none; }
address { font-style: normal; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
input, textarea, select { font-family: inherit; }

/* ---- SITE WRAPPER (for mobile push) ---- */
.siteWrapper {
  min-height: 100vh;
  transition: transform var(--transition-slow), scale var(--transition-slow);
  transform-origin: left center;
  position: relative;
  background-color: var(--surface);
}

.siteWrapper.menuOpen {
  transform: translateX(-300px) scale(0.95);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

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

/* ---- TYPOGRAPHY UTILITIES ---- */
.sectionLabel {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--primary-dark);
  background: var(--primary-subtle);
  border: 1px solid var(--border);
  padding: 0.35rem 0.9rem;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-sm);
}

.sectionTitle {
  font-size: clamp(1.75rem, 3.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

.sectionSubtitle {
  font-size: clamp(0.95rem, 1.8vw, 1.1rem);
  color: var(--text-secondary);
  max-width: 60ch;
  line-height: 1.7;
  margin-bottom: var(--space-lg);
}

/* ---- BUTTONS ---- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.75rem;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 600;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
  min-height: 48px;
  white-space: nowrap;
}

.btn--primary {
  background: var(--primary);
  color: var(--text-on-primary);
  box-shadow: var(--shadow-sm), 0 0 0 0 color-mix(in oklch, var(--primary), transparent 70%);
}

.btn--primary:hover {
  background: var(--primary-dark);
  box-shadow: var(--shadow-lg), var(--shadow-glow);
  transform: translateY(-2px);
}

.btn--primary:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.btn--ghost {
  background: transparent;
  color: var(--text-primary);
  border: 1.5px solid var(--border);
}

.btn--ghost:hover {
  background: var(--primary-subtle);
  border-color: var(--primary-light);
  color: var(--primary-darker);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn--full {
  width: 100%;
  justify-content: center;
}

/* ---- NAVIGATION ---- */
.siteHeader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  background: color-mix(in oklch, var(--surface), transparent 4%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-soft);
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--transition-base);
}

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

.siteHeader_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-md);
  height: 72px;
}

.siteHeader_logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.siteHeader_navList {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.siteHeader_navLink {
  padding: 0.5rem 0.85rem;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-secondary);
  transition: all var(--transition-fast);
  position: relative;
}

.siteHeader_navLink:hover {
  color: var(--primary-darker);
  background: var(--primary-subtle);
}

.siteHeader_navLink--cta {
  background: var(--primary);
  color: var(--text-on-primary);
  font-weight: 600;
  padding: 0.55rem 1.1rem;
  box-shadow: var(--shadow-sm);
}

.siteHeader_navLink--cta:hover {
  background: var(--primary-dark);
  color: var(--text-on-primary);
  box-shadow: var(--shadow-md), var(--shadow-glow);
  transform: translateY(-1px);
}

.siteHeader_menuBtn {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 10px;
  min-width: 44px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
}

.siteHeader_menuBtn:hover {
  background: var(--primary-subtle);
}

.siteHeader_menuBtn_bar {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px;
  transition: all var(--transition-base);
}

/* ---- MOBILE MENU ---- */
.mobileMenu {
  position: fixed;
  top: 0;
  right: 0;
  width: 300px;
  height: 100vh;
  background: var(--surface-dark);
  z-index: 950;
  transform: translateX(100%);
  transition: transform var(--transition-slow);
  display: flex;
  flex-direction: column;
  padding: var(--space-md);
  box-shadow: var(--shadow-xl);
}

.mobileMenu.isOpen {
  transform: translateX(0);
}

.mobileMenu_header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: var(--space-md);
  border-bottom: 1px solid color-mix(in oklch, var(--primary), transparent 75%);
  margin-bottom: var(--space-md);
}

.mobileMenu_closeBtn {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  color: var(--text-on-dark);
  font-size: 1.2rem;
  transition: background var(--transition-fast);
}

.mobileMenu_closeBtn:hover {
  background: color-mix(in oklch, var(--primary), transparent 80%);
}

.mobileMenu_navList {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  flex: 1;
}

.mobileMenu_navLink {
  display: block;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-sm);
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-on-dark);
  transition: all var(--transition-fast);
}

.mobileMenu_navLink:hover {
  background: color-mix(in oklch, var(--primary), transparent 80%);
  color: var(--primary-light);
  padding-left: 1.4rem;
}

.mobileMenu_navLink--cta {
  background: var(--primary);
  color: var(--text-on-primary);
  font-weight: 600;
  text-align: center;
  margin-top: var(--space-sm);
}

.mobileMenu_navLink--cta:hover {
  background: var(--primary-dark);
  color: var(--text-on-primary);
  padding-left: 1rem;
}

.mobileMenu_footer {
  padding-top: var(--space-md);
  border-top: 1px solid color-mix(in oklch, var(--primary), transparent 75%);
  font-size: 0.85rem;
  color: var(--dark-muted);
}

.mobileMenu_footer a {
  color: var(--primary-light);
  display: block;
  margin-top: 0.35rem;
}

.mobileMenu_overlay {
  position: fixed;
  inset: 0;
  background: transparent;
  z-index: 940;
  display: none;
}

.mobileMenu_overlay.isVisible {
  display: block;
}

/* ---- HERO ---- */
.mainHero {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding-top: 72px;
  position: relative;
  overflow: hidden;
}

.mainHero_content {
  display: flex;
  align-items: center;
  padding: var(--space-3xl) var(--space-xl) var(--space-3xl) calc((100vw - 1200px) / 2 + var(--space-md));
  background: var(--surface-warm);
  position: relative;
  z-index: 2;
}

.mainHero_textBlock {
  max-width: 560px;
}

.mainHero_badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--primary-subtle);
  border: 1px solid var(--border);
  color: var(--primary-darker);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.4rem 1rem;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-md);
  box-shadow: var(--shadow-xs);
}

.mainHero_title {
  font-size: clamp(2.5rem, 5.5vw, 4.5rem);
  font-weight: 800;
  line-height: 1.05;
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  letter-spacing: -0.02em;
}

.mainHero_title--accent {
  color: var(--primary-dark);
  position: relative;
  display: inline-block;
}

.mainHero_title--accent::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--primary);
  border-radius: 2px;
  opacity: 0.6;
}

.mainHero_lead {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  color: var(--text-secondary);
  line-height: 1.75;
  margin-bottom: var(--space-lg);
  max-width: 50ch;
}

.mainHero_actions {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-bottom: var(--space-lg);
}

.mainHero_meta {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.mainHero_metaItem {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
}

.mainHero_metaItem i {
  color: var(--primary-dark);
  width: 16px;
  flex-shrink: 0;
}

/* HERO VISUAL */
.mainHero_visual {
  background: linear-gradient(
    135deg,
    var(--primary-dark) 0%,
    var(--dark) 60%,
    color-mix(in oklch, var(--dark), var(--accent) 20%) 100%
  );
  position: relative;
  overflow: hidden;
}

.mainHero_visualInner {
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mainHero_orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
}

.mainHero_orb--1 {
  width: 400px;
  height: 400px;
  background: color-mix(in oklch, var(--primary), transparent 55%);
  top: -10%;
  right: -10%;
}

.mainHero_orb--2 {
  width: 300px;
  height: 300px;
  background: color-mix(in oklch, var(--accent), transparent 60%);
  bottom: 5%;
  left: 10%;
}

.mainHero_hexGrid {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 1rem;
  padding: 3rem;
  pointer-events: none;
}

.mainHero_hex {
  border-radius: var(--radius-md);
  opacity: 0.06;
  background: var(--primary-light);
  animation: hexPulse 4s ease-in-out infinite;
}

.mainHero_hex--1 { animation-delay: 0s; }
.mainHero_hex--2 { animation-delay: 0.5s; opacity: 0.04; }
.mainHero_hex--3 { animation-delay: 1s; opacity: 0.08; }
.mainHero_hex--4 { animation-delay: 1.5s; opacity: 0.03; }
.mainHero_hex--5 { animation-delay: 2s; opacity: 0.07; }
.mainHero_hex--6 { animation-delay: 2.5s; opacity: 0.05; }

@keyframes hexPulse {
  0%, 100% { opacity: 0.04; transform: scale(1); }
  50% { opacity: 0.12; transform: scale(1.02); }
}

.mainHero_centralIcon {
  position: relative;
  z-index: 5;
  width: 120px;
  height: 120px;
  background: color-mix(in oklch, var(--primary), transparent 15%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 60px color-mix(in oklch, var(--primary), transparent 40%),
              0 0 120px color-mix(in oklch, var(--primary), transparent 70%),
              var(--shadow-xl);
  border: 2px solid color-mix(in oklch, var(--primary-light), transparent 50%);
}

.mainHero_centralIcon i {
  font-size: 3rem;
  color: var(--primary-light);
}

.mainHero_floatCard {
  position: absolute;
  z-index: 6;
  background: color-mix(in oklch, var(--surface-dark), transparent 10%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid color-mix(in oklch, var(--primary-light), transparent 65%);
  border-radius: var(--radius-md);
  padding: 0.75rem 1.1rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--text-on-dark);
  font-size: 0.85rem;
  font-weight: 600;
  box-shadow: var(--shadow-lg);
  animation: floatDrift 6s ease-in-out infinite;
}

.mainHero_floatCard i {
  color: var(--primary);
  font-size: 1rem;
}

.mainHero_floatCard--1 {
  top: 20%;
  left: 8%;
  animation-delay: 0s;
}

.mainHero_floatCard--2 {
  top: 55%;
  right: 6%;
  animation-delay: 2s;
}

.mainHero_floatCard--3 {
  bottom: 18%;
  left: 12%;
  animation-delay: 4s;
}

@keyframes floatDrift {
  0%, 100% { transform: translateY(0px); }
  33% { transform: translateY(-8px); }
  66% { transform: translateY(4px); }
}

/* ---- ABOUT SECTION ---- */
.aboutSection {
  padding: var(--space-3xl) 0;
  position: relative;
  overflow: hidden;
}

.aboutSection_bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    var(--surface-warm) 0%,
    var(--surface) 50%,
    var(--primary-subtle) 100%
  );
  z-index: 0;
}

.aboutSection > .container {
  position: relative;
  z-index: 1;
}

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

.aboutSection_iconStack {
  position: relative;
  height: 420px;
}

.aboutSection_iconCard {
  position: absolute;
  background: var(--surface-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  transition: all var(--transition-base);
}

.aboutSection_iconCard i {
  font-size: 1.75rem;
  color: var(--primary-dark);
  flex-shrink: 0;
}

.aboutSection_iconCard p {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--text-primary);
}

.aboutSection_iconCard--1 {
  top: 0;
  left: 5%;
  box-shadow: var(--shadow-lg);
  z-index: 4;
}

.aboutSection_iconCard--2 {
  top: 22%;
  right: 0;
  box-shadow: var(--shadow-md);
  z-index: 3;
}

.aboutSection_iconCard--3 {
  top: 48%;
  left: 10%;
  box-shadow: var(--shadow-xl);
  z-index: 5;
}

.aboutSection_iconCard--4 {
  bottom: 5%;
  right: 8%;
  box-shadow: var(--shadow-sm);
  z-index: 2;
}

.aboutSection_iconCard:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.aboutSection_orb {
  position: absolute;
  width: 280px;
  height: 280px;
  background: color-mix(in oklch, var(--primary), transparent 75%);
  border-radius: 50%;
  filter: blur(50px);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}

.aboutSection_text {
  padding: var(--space-sm);
}

.aboutSection_text p {
  color: var(--text-secondary);
  margin-bottom: var(--space-sm);
  line-height: 1.75;
}

.aboutSection_highlights {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: var(--space-md);
  padding: var(--space-md);
  background: var(--surface-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-soft);
  box-shadow: var(--shadow-md);
}

.aboutSection_highlight {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.92rem;
  color: var(--text-secondary);
}

.aboutSection_highlight i {
  color: var(--primary-dark);
  margin-top: 0.1rem;
  flex-shrink: 0;
}

/* ---- TABBED SECTION ---- */
.tabbedSection {
  padding: var(--space-3xl) 0;
  background: var(--dark);
  position: relative;
  overflow: hidden;
}

.tabbedSection::before {
  content: '';
  position: absolute;
  top: -100px;
  left: -100px;
  width: 500px;
  height: 500px;
  background: color-mix(in oklch, var(--primary), transparent 85%);
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}

.tabbedSection::after {
  content: '';
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 400px;
  height: 400px;
  background: color-mix(in oklch, var(--accent), transparent 88%);
  border-radius: 50%;
  filter: blur(70px);
  pointer-events: none;
}

.tabbedSection_header {
  text-align: center;
  margin-bottom: var(--space-xl);
  position: relative;
  z-index: 1;
}

.tabbedSection_header .sectionTitle {
  color: var(--text-on-dark);
}

.tabbedSection_header .sectionSubtitle {
  color: var(--dark-muted);
  margin: 0 auto var(--space-lg);
}

.tabbedSection_tabs {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-xl);
  position: relative;
  z-index: 1;
}

.tabbedSection_tab {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.7rem 1.4rem;
  border-radius: var(--radius-full);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--dark-muted);
  background: color-mix(in oklch, var(--dark), white 8%);
  border: 1px solid color-mix(in oklch, var(--primary), transparent 80%);
  transition: all var(--transition-base);
  min-height: 44px;
}

.tabbedSection_tab:hover {
  color: var(--primary-light);
  background: color-mix(in oklch, var(--dark), white 14%);
  border-color: color-mix(in oklch, var(--primary), transparent 55%);
}

.tabbedSection_tab--active {
  background: var(--primary);
  color: var(--text-on-primary);
  border-color: var(--primary);
  box-shadow: var(--shadow-glow);
}

.tabbedSection_tab--active:hover {
  background: var(--primary-dark);
  color: var(--text-on-primary);
}

.tabbedSection_panels {
  position: relative;
  z-index: 1;
}

.tabbedSection_panel {
  display: none;
  animation: panelFadeIn var(--transition-slow) ease forwards;
}

.tabbedSection_panel--active {
  display: block;
}

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

.tabbedSection_panelGrid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-xl);
  align-items: start;
  background: color-mix(in oklch, var(--dark), white 6%);
  border: 1px solid color-mix(in oklch, var(--primary), transparent 75%);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  box-shadow: var(--shadow-xl);
}

.tabbedSection_panelText h3 {
  font-size: clamp(1.3rem, 2.5vw, 1.75rem);
  font-weight: 700;
  color: var(--text-on-dark);
  margin-bottom: var(--space-sm);
}

.tabbedSection_panelText p {
  color: var(--dark-muted);
  line-height: 1.75;
  margin-bottom: var(--space-sm);
}

.tabbedSection_list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: var(--space-md);
}

.tabbedSection_list li {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  font-size: 0.92rem;
  color: var(--dark-muted);
}

.tabbedSection_list li i {
  color: var(--primary);
  font-size: 0.6rem;
  margin-top: 0.4rem;
  flex-shrink: 0;
}

.tabbedSection_panelVisual {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  min-width: 140px;
}

.tabbedSection_panelIcon {
  width: 100px;
  height: 100px;
  background: color-mix(in oklch, var(--primary), transparent 20%);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-glow);
  border: 1px solid color-mix(in oklch, var(--primary-light), transparent 60%);
}

.tabbedSection_panelIcon i {
  font-size: 2.5rem;
  color: var(--primary-light);
}

.tabbedSection_panelStat {
  text-align: center;
}

.tabbedSection_panelStat_label {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--dark-muted);
  margin-bottom: 0.2rem;
}

.tabbedSection_panelStat_value {
  display: block;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--primary-light);
}

/* ---- ABLAUF SECTION ---- */
.ablaufSection {
  padding: var(--space-3xl) 0;
  position: relative;
  overflow: hidden;
}

.ablaufSection_bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    var(--surface) 0%,
    var(--surface-warm) 50%,
    var(--surface) 100%
  );
  z-index: 0;
}

.ablaufSection > .container {
  position: relative;
  z-index: 1;
}

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

.ablaufSection_timeline {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
}

.ablaufSection_timeline::before {
  content: '';
  position: absolute;
  left: 32px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    to bottom,
    transparent,
    var(--border) 10%,
    var(--primary-light) 50%,
    var(--border) 90%,
    transparent
  );
}

.ablaufSection_timelineItem {
  display: flex;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
  position: relative;
}

.ablaufSection_timelineIcon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  background: var(--surface-card);
  border: 2px solid var(--border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
  position: relative;
  z-index: 1;
  transition: all var(--transition-base);
}

.ablaufSection_timelineIcon i {
  font-size: 1.3rem;
  color: var(--primary-dark);
}

.ablaufSection_timelineItem:hover .ablaufSection_timelineIcon {
  background: var(--primary-subtle);
  border-color: var(--primary);
  box-shadow: var(--shadow-lg), var(--shadow-glow);
}

.ablaufSection_timelineContent {
  flex: 1;
  background: var(--surface-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
  margin-top: 0.5rem;
}

.ablaufSection_timelineItem:hover .ablaufSection_timelineContent {
  box-shadow: var(--shadow-lg);
  transform: translateX(4px);
  border-color: var(--border);
}

.ablaufSection_time {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--primary-darker);
  background: var(--primary-subtle);
  padding: 0.25rem 0.7rem;
  border-radius: var(--radius-full);
  margin-bottom: 0.5rem;
}

.ablaufSection_timelineContent h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.4rem;
}

.ablaufSection_timelineContent p {
  font-size: 0.92rem;
  color: var(--text-secondary);
  line-height: 1.65;
}

/* ---- PRODUKTE CAROUSEL ---- */
.produkteSection {
  padding: var(--space-3xl) 0;
  background: var(--surface-dark);
  position: relative;
  overflow: hidden;
}

.produkteSection::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--primary-light), transparent);
}

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

.produkteSection_header .sectionTitle {
  color: var(--text-on-dark);
}

.produkteSection_header .sectionSubtitle {
  color: var(--dark-muted);
  margin: 0 auto;
}

.produkteSection_splide {
  position: relative;
}

.produktCard {
  background: color-mix(in oklch, var(--surface-dark), white 8%);
  border: 1px solid color-mix(in oklch, var(--primary), transparent 75%);
  border-radius: var(--radius-xl);
  padding: var(--space-lg);
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.produktCard::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  opacity: 0;
  transition: opacity var(--transition-base);
}

.produktCard:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
  border-color: color-mix(in oklch, var(--primary), transparent 50%);
}

.produktCard:hover::before {
  opacity: 1;
}

.produktCard_icon {
  width: 60px;
  height: 60px;
  background: color-mix(in oklch, var(--primary), transparent 20%);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-md);
  box-shadow: var(--shadow-sm);
}

.produktCard_icon i {
  font-size: 1.5rem;
  color: var(--primary-light);
}

.produktCard_title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-on-dark);
  margin-bottom: 0.6rem;
}

.produktCard_text {
  font-size: 0.9rem;
  color: var(--dark-muted);
  line-height: 1.65;
  flex: 1;
  margin-bottom: var(--space-sm);
}

.produktCard_tag {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--primary);
  background: color-mix(in oklch, var(--primary), transparent 88%);
  border: 1px solid color-mix(in oklch, var(--primary), transparent 70%);
  padding: 0.25rem 0.7rem;
  border-radius: var(--radius-full);
  align-self: flex-start;
}

/* Splide custom styles */
.splide__pagination__page {
  background: color-mix(in oklch, var(--primary), transparent 65%) !important;
}

.splide__pagination__page.is-active {
  background: var(--primary) !important;
  transform: scale(1.2);
}

.splide__arrow {
  background: color-mix(in oklch, var(--surface-dark), white 12%) !important;
  border: 1px solid color-mix(in oklch, var(--primary), transparent 70%) !important;
  box-shadow: var(--shadow-md) !important;
}

.splide__arrow svg {
  fill: var(--primary-light) !important;
}

.splide__arrow:hover {
  background: var(--primary) !important;
}

.splide__arrow:hover svg {
  fill: var(--text-on-primary) !important;
}

/* ---- MATERIAL SECTION ---- */
.materialSection {
  padding: var(--space-3xl) 0;
  position: relative;
  overflow: hidden;
}

.materialSection_bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    var(--surface-warm) 0%,
    var(--surface) 40%,
    var(--primary-subtle) 100%
  );
  z-index: 0;
}

.materialSection > .container {
  position: relative;
  z-index: 1;
}

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

.materialSection_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}

.materialCard {
  background: var(--surface-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.materialCard::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--primary), transparent);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.materialCard:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--border);
}

.materialCard:hover::after {
  opacity: 1;
}

.materialCard_iconWrap {
  width: 52px;
  height: 52px;
  background: var(--primary-subtle);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-sm);
  transition: all var(--transition-base);
}

.materialCard_iconWrap i {
  font-size: 1.3rem;
  color: var(--primary-dark);
}

.materialCard:hover .materialCard_iconWrap {
  background: var(--primary);
  border-color: var(--primary);
}

.materialCard:hover .materialCard_iconWrap i {
  color: var(--text-on-primary);
}

.materialCard h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.5rem;
}

.materialCard p {
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.65;
}

/* ---- FAQ SECTION ---- */
.faqSection {
  padding: var(--space-3xl) 0;
  background: var(--dark);
  position: relative;
}

.faqSection::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse at 70% 50%,
    color-mix(in oklch, var(--primary), transparent 88%) 0%,
    transparent 60%
  );
  pointer-events: none;
}

.faqSection_header {
  text-align: center;
  margin-bottom: var(--space-2xl);
  position: relative;
  z-index: 1;
}

.faqSection_header .sectionTitle {
  color: var(--text-on-dark);
}

.faqSection_list {
  max-width: 820px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  position: relative;
  z-index: 1;
}

.faqItem {
  background: color-mix(in oklch, var(--dark), white 7%);
  border: 1px solid color-mix(in oklch, var(--primary), transparent 78%);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), border-color var(--transition-base);
}

.faqItem.isOpen {
  border-color: color-mix(in oklch, var(--primary), transparent 50%);
  box-shadow: var(--shadow-lg);
}

.faqItem_question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  text-align: left;
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--text-on-dark);
  transition: all var(--transition-fast);
  min-height: 64px;
}

.faqItem_question:hover {
  background: color-mix(in oklch, var(--dark), white 10%);
  color: var(--primary-light);
}

.faqItem_icon {
  flex-shrink: 0;
  color: var(--primary);
  font-size: 0.85rem;
  transition: transform var(--transition-base);
}

.faqItem.isOpen .faqItem_icon {
  transform: rotate(180deg);
}

.faqItem_answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow) ease;
}

.faqItem.isOpen .faqItem_answer {
  max-height: 400px;
}

.faqItem_answerInner {
  padding: 0 var(--space-lg) var(--space-md);
  border-top: 1px solid color-mix(in oklch, var(--primary), transparent 80%);
}

.faqItem_answerInner p {
  font-size: 0.92rem;
  color: var(--dark-muted);
  line-height: 1.75;
  padding-top: var(--space-sm);
}

/* ---- KONTAKT SECTION ---- */
.kontaktSection {
  padding: var(--space-3xl) 0;
  position: relative;
  overflow: hidden;
}

.kontaktSection_bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    var(--primary-subtle) 0%,
    var(--surface-warm) 40%,
    var(--surface) 100%
  );
  z-index: 0;
}

.kontaktSection > .container {
  position: relative;
  z-index: 1;
}

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

.kontaktSection_grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-xl);
  align-items: start;
  margin-bottom: var(--space-2xl);
}

.kontaktSection_cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.kontaktCard {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  background: var(--surface-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

.kontaktCard:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-xl);
  border-color: var(--border);
}

.kontaktCard_icon {
  width: 52px;
  height: 52px;
  background: var(--primary-subtle);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.kontaktCard_icon i {
  font-size: 1.2rem;
  color: var(--primary-dark);
}

.kontaktCard_body h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}

.kontaktCard_body p {
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-bottom: 0.35rem;
}

.kontaktCard_link {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--primary-darker);
  transition: color var(--transition-fast);
}

.kontaktCard_link:hover {
  color: var(--accent);
}

.kontaktCard_address {
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* CONTACT FORM */
.kontaktForm_card {
  background: var(--surface-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  box-shadow: var(--shadow-xl);
}

.kontaktForm_stepTitle {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}

.kontaktForm_stepHint {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-bottom: var(--space-lg);
}

.formGroup {
  margin-bottom: var(--space-md);
}

.formLabel {
  display: block;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 0.4rem;
}

.formLabel span {
  color: var(--accent);
}

.formInput, .formTextarea {
  width: 100%;
  padding: 0.85rem 1.1rem;
  background: var(--surface-warm);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  color: var(--text-primary);
  transition: all var(--transition-fast);
  outline: none;
}

.formInput:focus, .formTextarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--primary), transparent 80%);
  background: var(--surface-card);
}

.formInput::placeholder, .formTextarea::placeholder {
  color: var(--text-muted);
}

.formTextarea {
  resize: vertical;
  min-height: 140px;
}

.formGroup--checkbox {
  display: flex;
  align-items: flex-start;
}

.formCheckLabel {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  cursor: pointer;
  font-size: 0.85rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.formCheckbox {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.formCheckCustom {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  background: var(--surface-warm);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  margin-top: 1px;
}

.formCheckbox:checked + .formCheckCustom {
  background: var(--primary);
  border-color: var(--primary);
}

.formCheckbox:checked + .formCheckCustom::after {
  content: '';
  width: 6px;
  height: 10px;
  border: 2px solid var(--text-on-primary);
  border-top: none;
  border-left: none;
  transform: rotate(45deg) translateY(-2px);
}

.formCheckbox:focus + .formCheckCustom {
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--primary), transparent 78%);
}

.formLink {
  color: var(--primary-darker);
  text-decoration: underline;
  text-decoration-color: var(--border);
  transition: all var(--transition-fast);
}

.formLink:hover {
  color: var(--accent);
  text-decoration-color: var(--accent);
}

.kontaktForm_stepActions {
  display: flex;
  gap: var(--space-sm);
  justify-content: space-between;
  align-items: center;
  margin-top: var(--space-md);
}

.kontaktSection_map {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--border-soft);
}

/* ---- FOOTER ---- */
.pageFooter {
  background: var(--surface-dark);
  color: var(--text-on-dark);
  position: relative;
}

.pageFooter::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--primary-light), transparent);
}

.pageFooter_top {
  padding: var(--space-2xl) 0 var(--space-xl);
}

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

.pageFooter_tagline {
  font-size: 0.9rem;
  color: var(--dark-muted);
  margin: var(--space-sm) 0 var(--space-md);
  line-height: 1.6;
}

.pageFooter_address {
  font-size: 0.88rem;
  color: var(--dark-muted);
  line-height: 1.8;
}

.pageFooter_address a {
  color: var(--primary-light);
  transition: color var(--transition-fast);
}

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

.pageFooter_links h4,
.pageFooter_legal h4 {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-on-dark);
  margin-bottom: var(--space-md);
}

.pageFooter_links ul,
.pageFooter_legal ul {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.pageFooter_links a,
.pageFooter_legal a {
  font-size: 0.88rem;
  color: var(--dark-muted);
  transition: all var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.pageFooter_links a:hover,
.pageFooter_legal a:hover {
  color: var(--primary-light);
  padding-left: 4px;
}

.pageFooter_bottom {
  border-top: 1px solid color-mix(in oklch, var(--primary), transparent 82%);
  padding: var(--space-md) 0;
}

.pageFooter_bottom .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.pageFooter_bottom p {
  font-size: 0.82rem;
  color: var(--dark-muted);
}

/* ---- LEGAL PAGE LAYOUT ---- */
.legalPage {
  min-height: 100vh;
  padding-top: 72px;
  display: flex;
  flex-direction: column;
}

.legalPage_hero {
  background: var(--dark);
  padding: var(--space-2xl) 0 var(--space-xl);
  position: relative;
  overflow: hidden;
}

.legalPage_hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 30% 50%, color-mix(in oklch, var(--primary), transparent 85%) 0%, transparent 60%);
}

.legalPage_hero .container {
  position: relative;
  z-index: 1;
}

.legalPage_heroTitle {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  color: var(--text-on-dark);
  margin-bottom: 0.5rem;
}

.legalPage_heroMeta {
  font-size: 0.88rem;
  color: var(--dark-muted);
}

.legalPage_body {
  flex: 1;
  padding: var(--space-2xl) 0;
  background: var(--surface);
}

.legalPage_content {
  max-width: 820px;
  margin: 0 auto;
}

.legalPage_content h2 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: var(--space-xl) 0 var(--space-sm);
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--border-soft);
}

.legalPage_content h2:first-child {
  margin-top: 0;
}

.legalPage_content h3 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin: var(--space-md) 0 var(--space-xs);
}

.legalPage_content p {
  color: var(--text-secondary);
  line-height: 1.75;
  margin-bottom: var(--space-sm);
  font-size: 0.95rem;
}

.legalPage_content ul, .legalPage_content ol {
  padding-left: 1.5rem;
  margin-bottom: var(--space-sm);
}

.legalPage_content li {
  color: var(--text-secondary);
  line-height: 1.75;
  margin-bottom: 0.4rem;
  font-size: 0.95rem;
}

.legalPage_content a {
  color: var(--primary-darker);
  text-decoration: underline;
  text-decoration-color: var(--border);
}

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

.legalPage_content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-md);
  font-size: 0.9rem;
}

.legalPage_content th {
  background: var(--primary-subtle);
  color: var(--text-primary);
  font-weight: 600;
  padding: 0.65rem 1rem;
  text-align: left;
  border: 1px solid var(--border);
}

.legalPage_content td {
  padding: 0.6rem 1rem;
  border: 1px solid var(--border-soft);
  color: var(--text-secondary);
  vertical-align: top;
}

.legalPage_content tr:nth-child(even) td {
  background: var(--surface-warm);
}

/* ---- THANKS PAGE ---- */
.thanksPage {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--dark);
}

.thanksPage_main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2xl) var(--space-md);
  position: relative;
  overflow: hidden;
}

.thanksPage_main::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 40%, color-mix(in oklch, var(--primary), transparent 75%) 0%, transparent 60%);
}

.thanksCard {
  position: relative;
  z-index: 1;
  background: color-mix(in oklch, var(--dark), white 7%);
  border: 1px solid color-mix(in oklch, var(--primary), transparent 65%);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl) var(--space-2xl);
  max-width: 540px;
  width: 100%;
  text-align: center;
  box-shadow: var(--shadow-xl);
}

.thanksCard_icon {
  width: 88px;
  height: 88px;
  background: color-mix(in oklch, var(--primary), transparent 20%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-lg);
  box-shadow: var(--shadow-glow);
}

.thanksCard_icon i {
  font-size: 2.5rem;
  color: var(--primary-light);
}

.thanksCard h1 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 800;
  color: var(--text-on-dark);
  margin-bottom: var(--space-sm);
}

.thanksCard p {
  font-size: 1rem;
  color: var(--dark-muted);
  line-height: 1.7;
  margin-bottom: var(--space-xl);
}

/* ---- RESPONSIVE ---- */
@media (max-width: 1024px) {
  .mainHero {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .mainHero_content {
    padding: calc(var(--space-3xl) + 72px) var(--space-md) var(--space-2xl);
  }

  .mainHero_visual {
    min-height: 50vw;
    max-height: 500px;
  }

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

  .aboutSection_iconStack {
    height: 320px;
  }

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

  .kontaktSection_grid {
    grid-template-columns: 1fr;
  }

  .pageFooter_grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-lg);
  }

  .pageFooter_brand {
    grid-column: 1 / -1;
  }

  .tabbedSection_panelGrid {
    grid-template-columns: 1fr;
  }

  .tabbedSection_panelVisual {
    flex-direction: row;
    justify-content: flex-start;
    min-width: auto;
  }
}

@media (max-width: 768px) {
  :root {
    --space-3xl: 5rem;
    --space-2xl: 4rem;
    --space-xl: 3rem;
  }

  .siteHeader_nav {
    display: none;
  }

  .siteHeader_menuBtn {
    display: flex;
  }

  .mainHero_actions {
    flex-direction: column;
  }

  .mainHero_actions .btn {
    width: 100%;
    justify-content: center;
  }

  .materialSection_grid {
    grid-template-columns: 1fr;
  }

  .pageFooter_grid {
    grid-template-columns: 1fr;
  }

  .pageFooter_brand {
    grid-column: auto;
  }

  .pageFooter_bottom .container {
    flex-direction: column;
    text-align: center;
  }

  .kontaktForm_stepActions {
    flex-direction: column;
  }

  .kontaktForm_stepActions .btn {
    width: 100%;
    justify-content: center;
  }

  .ablaufSection_timeline::before {
    left: 24px;
  }

  .ablaufSection_timelineIcon {
    width: 48px;
    height: 48px;
    min-width: 48px;
  }

  .ablaufSection_timelineIcon i {
    font-size: 1rem;
  }

  .ablaufSection_timelineContent {
    padding: var(--space-sm) var(--space-md);
  }

  .tabbedSection_tabs {
    gap: 0.4rem;
  }

  .tabbedSection_tab span {
    display: none;
  }

  .tabbedSection_tab {
    padding: 0.7rem;
    border-radius: var(--radius-md);
  }

  .tabbedSection_panelGrid {
    padding: var(--space-md);
  }

  .mainHero_floatCard--2 {
    right: 2%;
  }
}

@media (max-width: 480px) {
  .mainHero_content {
    padding: calc(var(--space-2xl) + 72px) var(--space-sm) var(--space-xl);
  }

  .container {
    padding: 0 var(--space-sm);
  }

  .kontaktForm_card {
    padding: var(--space-md);
  }

  .thanksCard {
    padding: var(--space-xl) var(--space-md);
  }

  .legalPage_content {
    padding: 0 var(--space-sm);
  }
}

/* ---- COOKIE CONSENT ---- */
.cookieConsent {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  width: calc(100% - 48px);
  max-width: 480px;
  transition: all var(--transition-slow);
}

.cookieConsent_card {
  background: var(--surface-dark);
  border: 1px solid color-mix(in oklch, var(--primary), transparent 65%);
  border-radius: var(--radius-xl);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-xl);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

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

.cookieConsent_compact p {
  flex: 1;
  font-size: 0.88rem;
  color: var(--dark-muted);
  line-height: 1.5;
  min-width: 200px;
}

.cookieConsent_compact p a {
  color: var(--primary-light);
  text-decoration: underline;
}

.cookieConsent_compactActions {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
}

.cookieConsent_expanded {
  display: none;
}

.cookieConsent.isExpanded .cookieConsent_compact {
  display: none;
}

.cookieConsent.isExpanded .cookieConsent_expanded {
  display: block;
}

.cookieConsent.isExpanded .cookieConsent_card {
  max-width: 100%;
}

.cookieConsent.isExpanded {
  max-width: 600px;
}

.cookieConsent_expandedTitle {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-on-dark);
  margin-bottom: var(--space-sm);
}

.cookieConsent_category {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-sm);
  padding: 0.75rem 0;
  border-bottom: 1px solid color-mix(in oklch, var(--primary), transparent 82%);
}

.cookieConsent_category:last-of-type {
  border-bottom: none;
}

.cookieConsent_categoryInfo h4 {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-on-dark);
  margin-bottom: 0.2rem;
}

.cookieConsent_categoryInfo p {
  font-size: 0.8rem;
  color: var(--dark-muted);
  line-height: 1.4;
}

.cookieConsent_toggle {
  flex-shrink: 0;
  position: relative;
  width: 44px;
  height: 24px;
}

.cookieConsent_toggle input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}

.cookieConsent_toggleSlider {
  position: absolute;
  inset: 0;
  background: color-mix(in oklch, var(--dark), white 20%);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.cookieConsent_toggleSlider::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  background: white;
  border-radius: 50%;
  top: 3px;
  left: 3px;
  transition: transform var(--transition-fast);
}

.cookieConsent_toggle input:checked + .cookieConsent_toggleSlider {
  background: var(--primary);
}

.cookieConsent_toggle input:checked + .cookieConsent_toggleSlider::before {
  transform: translateX(20px);
}

.cookieConsent_toggle input:disabled + .cookieConsent_toggleSlider {
  opacity: 0.5;
  cursor: not-allowed;
}

.cookieConsent_expandedActions {
  display: flex;
  gap: 0.5rem;
  margin-top: var(--space-md);
  flex-wrap: wrap;
}

.cookieConsent_expandedActions .btn {
  flex: 1;
  justify-content: center;
  min-width: 120px;
}

.btn--sm {
  padding: 0.55rem 1.1rem;
  font-size: 0.85rem;
  min-height: 40px;
}