/* ==========================================================
   OMmatic 2026 — main.css | Konzept 6 "Brutalist Clean"
   Version: 1.0.0 | Build: 2026-03-18
   ========================================================== */

/* ==========================================================
   DESIGN TOKENS
   ========================================================== */
:root {
  --bg:           #0B1120;
  --bg-2:         #111827;
  --bg-3:         #1E293B;
  --bg-card:      rgba(17,24,39,0.7);
  --border:       rgba(0,194,255,0.18);
  --border-s:     rgba(255,255,255,0.07);
  --text:         #F1F5F9;
  --text-2:       #94A3B8;
  --text-3:       #4B5563;
  --primary:      #00C2FF;
  --primary-dim:  rgba(0,194,255,0.11);
  --primary-glow: rgba(0,194,255,0.22);
  --indigo:       #7C73E6;
  --indigo-dim:   rgba(124,115,230,0.11);
  --teal:         #00D4AA;
  --teal-dim:     rgba(0,212,170,0.11);
  --header-bg:    rgba(11,17,32,0.85);
  --grad:         linear-gradient(135deg, #00C2FF 0%, #7C73E6 55%, #00D4AA 100%);
  --grad-line:    linear-gradient(90deg, #00C2FF 0%, #7C73E6 50%, #00D4AA 100%);
  --shadow-card:  0 4px 32px rgba(0,0,0,0.4);
  --shadow-glow:  0 0 60px rgba(0,194,255,0.1);
  --radius-s:     8px;
  --radius:       16px;
  --radius-l:     24px;
  --radius-xl:    32px;
  --font-h:       'Outfit', sans-serif;
  --font-b:       'Manrope', sans-serif;
  --max-w:        1280px;
  --py:           clamp(64px, 8vw, 104px);
}
[data-theme="light"] {
  --bg:           #F8FAFC;
  --bg-2:         #F1F5F9;
  --bg-3:         #E2E8F0;
  --bg-card:      rgba(255,255,255,0.95);
  --border:       rgba(0,153,204,0.22);
  --border-s:     rgba(0,0,0,0.07);
  --text:         #0B1120;
  --text-2:       #475569;
  --text-3:       #94A3B8;
  --primary:      #0099CC;
  --primary-dim:  rgba(0,153,204,0.09);
  --primary-glow: rgba(0,153,204,0.18);
  --indigo:       #6056CC;
  --indigo-dim:   rgba(96,86,204,0.09);
  --teal:         #00A888;
  --teal-dim:     rgba(0,168,136,0.09);
  --header-bg:    rgba(248,250,252,0.92);
  --grad:         linear-gradient(135deg, #0099CC 0%, #6056CC 55%, #00A888 100%);
  --grad-line:    linear-gradient(90deg, #0099CC 0%, #6056CC 50%, #00A888 100%);
  --shadow-card:  0 4px 24px rgba(0,0,0,0.06);
  --shadow-glow:  0 4px 40px rgba(0,0,0,0.06);
}

/* ==========================================================
   BASE
   ========================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-b);
  background: var(--bg);
  color: var(--text);
  transition: background 0.35s, color 0.35s;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, textarea, select { font-family: inherit; }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 64px);
}

/* ==========================================================
   UTILITIES
   ========================================================== */
.gradient-text {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-h);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--primary);
  background: var(--primary-dim);
  border: 1px solid var(--border);
  padding: 6px 16px 6px 10px;
  border-radius: 100px;
}
.tag-chip::before {
  content: '';
  width: 7px; height: 7px;
  background: var(--primary);
  border-radius: 50%;
  animation: pulse-dot 2.2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:.45; transform:scale(.65); }
}

/* Buttons */
.btn {
  font-family: var(--font-h);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  border-radius: 100px;
  transition: all 0.22s ease;
  white-space: nowrap;
  cursor: pointer;
  border: none;
  font-size: 15px;
}
.btn-primary {
  background: var(--grad);
  color: #fff;
  box-shadow: 0 4px 24px var(--primary-glow);
}
.btn-primary:hover { opacity: .88; transform: translateY(-2px); box-shadow: 0 8px 36px var(--primary-glow); }
.btn-ghost {
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border-s);
}
.btn-ghost:hover { background: var(--bg-3); border-color: var(--border); transform: translateY(-2px); }
.btn-lg { font-size: 17px; padding: 16px 36px; }

/* Section header */
/* ── Section Header (.sh legacy + .section-header neu) ──────── */
.sh { text-align: center; max-width: 700px; margin: 0 auto clamp(48px,6vw,72px); }
.sh .tag-chip { margin-bottom: 14px; }
.sh-title {
  font-family: var(--font-h);
  font-size: clamp(26px,3.2vw,40px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--text);
  margin-bottom: 12px;
}
.sh-sub { font-size: clamp(15px,1.6vw,17px); color: var(--text-2); line-height: 1.7; }

/* Neue zentrale Komponente: om_section_header() */
.section-header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto clamp(40px,5vw,64px);
}
.section-header.sh-left { text-align: left; margin-left: 0; }
.section-header .tag-chip { margin-bottom: 20px; }
/* Globaler Abstand: Pill direkt vor H2 – gilt für alle Seiten */

.section-header h2 {
  font-family: var(--font-h);
  font-size: clamp(24px,3vw,38px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--text);
  margin: 0 0 12px;
}
.section-sub {
  font-size: clamp(15px,1.6vw,17px);
  color: var(--text-2);
  line-height: 1.7;
  margin: 0;
}

/* ── Section-Überschrift: global für JEDES h2 nach einer Pill ─── */
/* Gilt seitenübergreifend automatisch – keine Klasse nötig       */
.tag-chip + h2,
.section-h2 {
  font-family: var(--font-h);
  font-size: clamp(28px,3.5vw,44px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: var(--text);
  margin: 20px 0 12px;
}
/* Ausnahme: CTA-Banner hat eigenes Styling */
.cta-banner-title { font-size: clamp(28px,4vw,48px); margin: 12px 0 16px; }



/* Scroll reveal */
.sr { opacity:0; transform:translateY(28px); transition: opacity .65s cubic-bezier(.16,1,.3,1), transform .65s cubic-bezier(.16,1,.3,1); }
.sr.in { opacity:1; transform:none; }
.sr-d1 { transition-delay:.08s; }
.sr-d2 { transition-delay:.16s; }
.sr-d3 { transition-delay:.24s; }
.sr-d4 { transition-delay:.32s; }

/* SVG icon base */
.icon { display:block; flex-shrink:0; }

/* ==========================================================
   HEADER
   ========================================================== */
.header {
  position: fixed;
  top:0; left:0; right:0;
  z-index: 1000;
  background: var(--header-bg);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid var(--border-s);
  transition: background .3s, border-color .3s;
}
.header.scrolled { border-bottom-color: var(--border); }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:68px; }

.logo {
  font-family: var(--font-h);
  font-size: 26px;
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--text);
  line-height:1;
  transition: opacity .2s;
}
.logo:hover { opacity:.8; }
.logo .dot { color: var(--primary); }

.nav-desktop { display:flex; align-items:center; gap:2px; }
.nav-link {
  font-family: var(--font-h);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-2);
  padding: 8px 14px;
  border-radius: var(--radius-s);
  transition: color .2s, background .2s;
}
.nav-link:hover, .nav-link.active { color:var(--text); background:var(--bg-3); }

.header-right { display:flex; align-items:center; gap:10px; }

.toggle-theme {
  width:40px; height:40px;
  border-radius:50%;
  background:var(--bg-3);
  border:1px solid var(--border-s);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-2);
  cursor:pointer;
  transition: all .2s;
}
.toggle-theme:hover { background:var(--primary-dim); border-color:var(--border); color:var(--primary); transform:rotate(20deg); }
.toggle-theme svg { width:18px; height:18px; pointer-events:none; }
.i-moon { display:block; }
.i-sun  { display:none; }
[data-theme="light"] .i-moon { display:none; }
[data-theme="light"] .i-sun  { display:block; }
[data-theme="light"] .mesh-blob { opacity: 0.04; }
[data-theme="light"] .hero-grid-bg { opacity: 0.3; }
[data-theme="light"] .svc-card { background: #fff; }
[data-theme="light"] .feature-card { background: #fff; }
[data-theme="light"] .why-card { background: #fff; }
[data-theme="light"] .hs-card { background: #fff; }
[data-theme="light"] .blog-card { background: #fff; }
[data-theme="light"] .contact-info-card { background: #fff; }
/* process-step: kein separates Background – transparent wie Section */
[data-theme="light"] .cta-banner { background: linear-gradient(135deg, #E8F4FF 0%, #EEF2FF 50%, #E6FFF9 100%); }
[data-theme="light"] .topbar { background: #EBF5FF; border-bottom: 1px solid rgba(0,153,204,0.15); }
[data-theme="light"] .nav-dropdown-menu { background: #fff; border-color: rgba(0,0,0,0.1); }

.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:var(--bg-3); border:1px solid var(--border-s);
  border-radius:var(--radius-s); padding:10px; cursor:pointer;
}
.hamburger span { display:block; width:20px; height:2px; background:var(--text); border-radius:2px; transition:all .3s; }

/* ── Mobile Drawer Overlay ─────────────────────────────── */
.mobile-overlay {
  position:fixed; inset:0; z-index:1098;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  opacity:0; pointer-events:none;
  transition:opacity .32s ease;
}
.mobile-overlay.open { opacity:1; pointer-events:auto; }

/* ── Mobile Drawer Panel ────────────────────────────────── */
.mobile-nav {
  position:fixed; top:0; right:0; bottom:0;
  width:min(340px, 90vw);
  background:var(--bg-2);
  border-left:1px solid var(--border);
  z-index:1099;
  display:flex; flex-direction:column;
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  visibility:hidden;
}
.mobile-nav.open { transform:translateX(0); visibility:visible; }

/* Drawer: Header bar */
.mobile-nav-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:0 20px; height:64px; flex-shrink:0;
  border-bottom:1px solid var(--border-s);
}
.mobile-nav-close {
  width:40px; height:40px; border-radius:50%;
  background:var(--bg-3); border:1px solid var(--border-s);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-2); cursor:pointer;
  transition:background .2s, color .2s;
}
.mobile-nav-close:hover { background:var(--primary-dim); color:var(--primary); }

/* Drawer: Scrollable body */
.mobile-nav-body {
  flex:1; min-height:0; overflow-y:auto; padding:8px 0 16px;
  -webkit-overflow-scrolling:touch;
}
.mobile-nav-section { padding:12px 0 4px; }
.mobile-nav-label {
  font-family:var(--font-h); font-size:11px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-3); padding:0 20px 6px;
}
.mobile-nav-link {
  display:flex; align-items:center; gap:8px;
  padding:10px 20px; font-family:var(--font-h);
  font-size:15px; font-weight:500; color:var(--text-2);
  transition:color .15s, background .15s;
  text-decoration:none;
}
.mobile-nav-link:hover,
.mobile-nav-link:active { color:var(--text); background:var(--bg-3); }
.mnl-badge {
  font-size:10px; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; border-radius:4px;
  padding:2px 6px; background:var(--bg-3); color:var(--text-3);
}
.mnl-badge--event {
  background:linear-gradient(135deg,#8B5CF6,#6D28D9); color:#fff;
}

/* Drawer: Footer (always visible at bottom) */
.mobile-nav-foot {
  flex-shrink:0; padding:16px 20px;
  padding-bottom:max(24px, env(safe-area-inset-bottom, 24px));
  border-top:1px solid var(--border-s);
  display:flex; flex-direction:column; gap:10px;
}
.mobile-nav-cta { width:100%; justify-content:center; }
.mobile-nav-theme-btn {
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:var(--radius-s);
  background:var(--bg-3); border:1px solid var(--border-s);
  cursor:pointer; color:var(--text-2);
  font-family:var(--font-h); font-size:14px; font-weight:500;
  transition:color .2s, background .2s; width:100%;
}
.mobile-nav-theme-btn:hover { color:var(--text); background:var(--bg); }
.mobile-nav-theme-btn svg { flex-shrink:0; }

/* ==========================================================
   HERO
   ========================================================== */
.hero {
  position:relative; min-height:100dvh;
  display:flex; align-items:center;
  padding-top:68px; overflow:hidden;
}
.hero-mesh { position:absolute; inset:0; pointer-events:none; }
.mesh-blob { position:absolute; border-radius:50%; filter:blur(80px); }
.mesh-1 { top:-10%; left:-5%; width:min(700px,70vw); height:min(700px,70vw); background:radial-gradient(circle, rgba(0,194,255,.10) 0%, transparent 70%); animation:float-a 10s ease-in-out infinite; }
.mesh-2 { bottom:-15%; right:-5%; width:min(600px,60vw); height:min(600px,60vw); background:radial-gradient(circle, rgba(124,115,230,.09) 0%, transparent 70%); animation:float-b 13s ease-in-out infinite; }
.mesh-3 { top:40%; left:40%; width:min(400px,40vw); height:min(400px,40vw); background:radial-gradient(circle, rgba(0,212,170,.07) 0%, transparent 70%); animation:float-c 15s ease-in-out infinite; }
@keyframes float-a { 0%,100%{transform:translate(0,0)} 50%{transform:translate(40px,-30px)} }
@keyframes float-b { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-30px,40px)} }
@keyframes float-c { 0%,100%{transform:translate(0,0)} 50%{transform:translate(20px,-20px)} }

.hero-grid-bg {
  position:absolute; inset:0;
  background-image: linear-gradient(var(--border-s) 1px, transparent 1px), linear-gradient(90deg, var(--border-s) 1px, transparent 1px);
  background-size:64px 64px;
}

.hero-content { position:relative; z-index:1; padding-top:clamp(72px,10vw,120px); padding-bottom:clamp(72px,10vw,120px); width:100%; }
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }

.hero-left .tag-chip { margin-bottom:28px; }
.hero-title {
  font-family:var(--font-h);
  font-size:clamp(44px,5.5vw,80px);
  font-weight:900;
  letter-spacing:-0.035em;
  line-height:1.0;
  color:var(--text);
  margin-bottom:24px;
}
.hero-title .line-sub {
  display:block; font-size:.82em;
  font-weight:300; letter-spacing:-0.02em;
  opacity:.5; margin-top:4px;
}
.hero-sub { font-size:clamp(16px,1.8vw,18px); color:var(--text-2); max-width:500px; line-height:1.7; margin-bottom:40px; }
.hero-ctas { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:56px; }

/* Hero stats */
.hero-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.hs-card {
  background:var(--bg-card); border:1px solid var(--border-s);
  border-radius:var(--radius); padding:20px 22px;
  backdrop-filter:blur(12px);
  transition:border-color .3s, transform .3s, box-shadow .3s;
}
.hs-card:hover { border-color:var(--border); transform:translateY(-3px); box-shadow:var(--shadow-glow); }
.hs-card:nth-child(1) .hs-num { color:var(--primary); }
.hs-card:nth-child(2) .hs-num { color:var(--indigo); }
.hs-card:nth-child(3) .hs-num { color:var(--teal); }
.hs-num { font-family:var(--font-h); font-size:clamp(28px,3.5vw,40px); font-weight:800; letter-spacing:-0.03em; line-height:1; margin-bottom:5px; }
.hs-label { font-size:13px; font-weight:500; color:var(--text-2); line-height:1.4; }

/* Hero right dashboard */
.hero-right { position:relative; }
.hero-visual {
  position:relative; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius-xl);
  padding:36px; backdrop-filter:blur(16px); overflow:hidden;
}
.hero-visual::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad-line); }

.hv-top { display:flex; align-items:center; gap:10px; margin-bottom:28px; }
.hv-dot { width:10px; height:10px; border-radius:50%; }
.hv-title { font-family:var(--font-h); font-size:13px; font-weight:600; color:var(--text-2); letter-spacing:.08em; text-transform:uppercase; }

.hv-kpi-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:24px; }
.hv-kpi { background:var(--bg-3); border-radius:var(--radius); padding:18px; border:1px solid var(--border-s); }
.hv-kpi-label { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.1em; color:var(--text-3); margin-bottom:6px; }
.hv-kpi-value { font-family:var(--font-h); font-size:26px; font-weight:800; letter-spacing:-0.03em; }
.hv-kpi:nth-child(1) .hv-kpi-value { color:var(--primary); }
.hv-kpi:nth-child(2) .hv-kpi-value { color:var(--teal); }
.hv-kpi:nth-child(3) .hv-kpi-value { color:var(--indigo); }
.hv-kpi:nth-child(4) .hv-kpi-value { color:var(--primary); }

.hv-chart { display:flex; align-items:flex-end; gap:6px; height:64px; margin-bottom:16px; }
.bar { flex:1; border-radius:4px 4px 0 0; min-width:8px; transition:height 1.2s cubic-bezier(.16,1,.3,1); }
.bar:nth-child(odd)  { background:var(--primary-dim); border:1px solid var(--primary); }
.bar:nth-child(even) { background:var(--indigo-dim);  border:1px solid var(--indigo); }
.bar:last-child      { background:var(--teal-dim);    border:1px solid var(--teal); }

.hv-footer {
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-h); font-size:13px; font-weight:600; color:var(--teal);
}

.hero-badge {
  position:absolute; top:-18px; right:-18px;
  z-index: 10;
  background:var(--grad); color:#fff;
  border-radius:var(--radius-l); padding:14px 20px;
  text-align:center; font-family:var(--font-h);
  box-shadow:0 8px 32px var(--primary-glow);
  animation:float-badge 4s ease-in-out infinite;
}
.hero-badge-num { font-size:28px; font-weight:900; letter-spacing:-0.03em; line-height:1; }
.hero-badge-label { font-size:11px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; opacity:.85; }
@keyframes float-badge { 0%,100%{transform:translateY(0) rotate(-2deg)} 50%{transform:translateY(-8px) rotate(1deg)} }

.hero-bottom-line { position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--grad-line); }

/* ==========================================================
   SERVICES STRIP
   ========================================================== */
.services-strip {
  padding: 20px 0;
  background: var(--bg-2);
  border-top: 1px solid var(--border-s);
  border-bottom: 1px solid var(--border-s);
  overflow: hidden;
}
.services-strip-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  justify-content: center;
}
.sstrip-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-h);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--text-2);
  background: var(--bg-card);
  border: 1px solid var(--border-s);
  border-radius: 100px;
  padding: 8px 18px;
  white-space: nowrap;
  transition: color .2s, border-color .2s, background .2s;
}
.sstrip-item:hover { color: var(--primary); border-color: var(--border); background: var(--primary-dim); }
.sstrip-item svg { width: 14px; height: 14px; flex-shrink: 0; }
.sstrip-item:nth-child(2) svg { color: var(--indigo); }
.sstrip-item:nth-child(3) svg { color: var(--primary); }
.sstrip-item:nth-child(4) svg { color: var(--teal); }
.sstrip-item:nth-child(5) svg { color: var(--indigo); }
.sstrip-item:nth-child(6) svg { color: var(--teal); }
.sstrip-item:nth-child(7) svg { color: var(--primary); }
.sstrip-sep {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--border-s);
  flex-shrink: 0;
}

/* ==========================================================
   SERVICES — 3×2 Raster
   ========================================================== */
.services-section { padding:var(--py) 0; }
.services-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.svc-card {
  background:var(--bg-card);
  border:1px solid var(--border-s);
  border-radius:var(--radius-l);
  padding:clamp(28px,3vw,36px);
  backdrop-filter:blur(14px);
  position:relative; overflow:hidden;
  transition:border-color .3s, transform .28s cubic-bezier(.16,1,.3,1), box-shadow .3s;
  display:flex; flex-direction:column;
}
.svc-card:hover { border-color:var(--border); transform:translateY(-5px); box-shadow:var(--shadow-card); }
.svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad-line); opacity:0; transition:opacity .3s;
}
.svc-card:hover::before { opacity:1; }

.svc-icon-wrap {
  width:52px; height:52px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:22px; flex-shrink:0;
}
.svc-icon-wrap svg { width:24px; height:24px; }
.ic-cyan   { background:var(--primary-dim); color:var(--primary); border:1px solid rgba(0,194,255,.15); }
.ic-indigo { background:var(--indigo-dim);  color:var(--indigo);  border:1px solid rgba(124,115,230,.15); }
.ic-teal   { background:var(--teal-dim);    color:var(--teal);    border:1px solid rgba(0,212,170,.15); }

.svc-label {
  font-family:var(--font-h); font-size:11px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase; margin-bottom:10px;
}
.svc-card:nth-child(1) .svc-label,
.svc-card:nth-child(4) .svc-label { color:var(--primary); }
.svc-card:nth-child(2) .svc-label,
.svc-card:nth-child(5) .svc-label { color:var(--indigo); }
.svc-card:nth-child(3) .svc-label,
.svc-card:nth-child(6) .svc-label { color:var(--teal); }

.svc-title {
  font-family:var(--font-h); font-size:clamp(19px,2vw,23px);
  font-weight:700; letter-spacing:-0.02em; line-height:1.2;
  color:var(--text); margin-bottom:12px;
}
.svc-text { font-size:14px; line-height:1.72; color:var(--text-2); margin-bottom:22px; flex:1; }
.svc-features { display:flex; flex-direction:column; gap:9px; margin-top:auto; }
.svc-feat {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:var(--text-2); line-height:1.45;
}
.svc-feat-check {
  width:16px; height:16px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; margin-top:2px;
}
.svc-feat-check svg { width:16px; height:16px; stroke-width:2.5; }
.svc-card:nth-child(1) .svc-feat-check,
.svc-card:nth-child(4) .svc-feat-check { color:var(--primary); }
.svc-card:nth-child(2) .svc-feat-check,
.svc-card:nth-child(5) .svc-feat-check { color:var(--indigo); }
.svc-card:nth-child(3) .svc-feat-check,
.svc-card:nth-child(6) .svc-feat-check { color:var(--teal); }

/* ==========================================================
   SERVICE DETAILS GRID (Leistungen im Detail)
   ========================================================== */
.service-details-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
  margin-top:48px;
}
.service-detail-block {
  background:var(--bg-card);
  border:1px solid var(--border-s);
  border-radius:var(--radius-l);
  padding:32px 28px 28px;
  display:flex;
  flex-direction:column;
  transition:border-color .25s, box-shadow .25s, transform .25s;
  position:relative;
}
.service-detail-block::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad-line); opacity:0; transition:opacity .3s; border-radius:var(--radius-l) var(--radius-l) 0 0;
}
.service-detail-block:hover { border-color:var(--border); transform:translateY(-4px); box-shadow:var(--shadow-card); }
.service-detail-block:hover::before { opacity:1; }

.service-detail-icon {
  width:44px; height:44px;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px; flex-shrink:0;
}
.service-detail-icon svg { width:22px; height:22px; }
.service-detail-icon.ic-cyan   { background:var(--primary-dim); color:var(--primary); }
.service-detail-icon.ic-indigo { background:var(--indigo-dim);  color:var(--indigo); }
.service-detail-icon.ic-teal   { background:var(--teal-dim);    color:var(--teal); }

.service-detail-block h3 {
  font-family:var(--font-h);
  font-size:clamp(1rem,1.8vw,1.15rem);
  font-weight:700;
  line-height:1.35;
  color:var(--fg);
  margin:0 0 14px;
}
.service-detail-block p {
  font-size:.925rem;
  color:var(--fg-2);
  line-height:1.7;
  margin:0 0 10px;
}
.service-detail-block p:last-of-type { margin-bottom:0; }
.service-detail-block .btn { margin-top:auto; align-self:flex-start; }

/* STATS ROW */
.stats-row {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border:1px solid var(--border-s);
  border-radius:var(--radius-l);
  overflow:hidden;
  margin-top:48px;
}
.stat-block {
  padding:clamp(28px,4vw,48px) 28px;
  text-align:center;
  border-right:1px solid var(--border-s);
  transition:background .25s;
}
.stat-block:last-child { border-right:none; }
.stat-block:hover { background:var(--primary-dim); }
.stat-number {
  font-family:var(--font-h);
  font-size:clamp(1.6rem,3vw,2.25rem);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.1;
  margin-bottom:6px;
}
.stat-label {
  font-size:.85rem;
  font-weight:700;
  color:var(--fg);
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:8px;
}
.stat-desc {
  font-size:.8rem;
  color:var(--fg-3);
  line-height:1.5;
}

/* ==========================================================
   STATS
   ========================================================== */
.stats-section {
  padding:var(--py) 0; background:var(--bg-2); position:relative; overflow:hidden;
}
.stats-section::before, .stats-section::after {
  content:''; position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--border) 30%,var(--border) 70%,transparent 100%);
}
.stats-section::before { top:0; }
.stats-section::after  { bottom:0; }
.stats-bg-glow { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:800px; height:400px; background:radial-gradient(ellipse,rgba(0,194,255,.04) 0%,transparent 70%); pointer-events:none; }

.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; position:relative; z-index:1; }
.stat-item {
  padding:clamp(40px,5vw,64px) 32px; text-align:center;
  border-right:1px solid var(--border-s); transition:background .3s; cursor:default;
}
.stat-item:last-child { border-right:none; }
.stat-item:hover { background:var(--primary-dim); }
.stat-num {
  font-family:var(--font-h);
  font-size:clamp(44px,5.5vw,68px);
  font-weight:900; letter-spacing:-0.035em; line-height:1; margin-bottom:12px;
}
.stat-item:nth-child(1) .stat-num { color:var(--primary); }
.stat-item:nth-child(2) .stat-num { color:var(--indigo); }
.stat-item:nth-child(3) .stat-num { color:var(--teal); }
.stat-item:nth-child(4) .stat-num { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.stat-label { font-size:14px; font-weight:500; color:var(--text-2); line-height:1.5; max-width:160px; margin:0 auto; }

/* ==========================================================
   WHY OMMATIC
   ========================================================== */
.why-section { padding:var(--py) 0; }
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.why-card {
  background:var(--bg-card); border:1px solid var(--border-s);
  border-radius:var(--radius-l); padding:clamp(32px,4vw,44px);
  backdrop-filter:blur(14px); position:relative; overflow:hidden;
  transition:border-color .3s, transform .3s, box-shadow .3s;
}
.why-card:hover { border-color:var(--border); transform:translateY(-6px); box-shadow:var(--shadow-glow); }
.why-card::after {
  content:''; position:absolute; bottom:-60px; right:-60px;
  width:160px; height:160px; border-radius:50%; opacity:.06;
  transition:opacity .3s, transform .3s;
}
.why-card:nth-child(1)::after { background:var(--primary); }
.why-card:nth-child(2)::after { background:var(--indigo); }
.why-card:nth-child(3)::after { background:var(--teal); }
.why-card:hover::after { opacity:.14; transform:scale(1.6); }
.why-num { font-family:var(--font-h); font-size:80px; font-weight:900; letter-spacing:-0.04em; line-height:1; opacity:.06; position:absolute; top:18px; right:24px; user-select:none; transition:opacity .3s; }
.why-card:hover .why-num { opacity:.12; }
.why-icon-wrap { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:22px; }
.why-icon-wrap svg { width:24px; height:24px; }
.why-card:nth-child(1) .why-icon-wrap { background:var(--primary-dim); color:var(--primary); }
.why-card:nth-child(2) .why-icon-wrap { background:var(--indigo-dim);  color:var(--indigo); }
.why-card:nth-child(3) .why-icon-wrap { background:var(--teal-dim);    color:var(--teal); }
.why-title { font-family:var(--font-h); font-size:clamp(19px,2vw,22px); font-weight:700; letter-spacing:-0.02em; line-height:1.2; color:var(--text); margin-bottom:14px; }
.why-text  { font-size:15px; line-height:1.72; color:var(--text-2); }

/* ==========================================================
   PROCESS
   ========================================================== */
.process-section { padding:var(--py) 0; background:var(--bg-2); }
.process-track { display:grid; grid-template-columns:repeat(4,1fr); position:relative; }
.process-track::before {
  content:''; position:absolute; top:56px;
  left:calc(12.5% + 28px); right:calc(12.5% + 28px);
  height:2px; background:var(--grad-line); z-index:0;
}
.process-step { position:relative; z-index:1; text-align:center; padding:0 16px 40px; }
.proc-circle {
  width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-h); font-size:17px; font-weight:800;
  margin:0 auto 24px; transition:transform .3s;
}
.process-step:hover .proc-circle { transform:scale(1.12); }
.process-step:nth-child(1) .proc-circle { background:var(--primary-dim); color:var(--primary); border:2px solid var(--primary); }
.process-step:nth-child(2) .proc-circle { background:var(--indigo-dim);  color:var(--indigo);  border:2px solid var(--indigo); }
.process-step:nth-child(3) .proc-circle { background:var(--teal-dim);    color:var(--teal);    border:2px solid var(--teal); }
.process-step:nth-child(4) .proc-circle { background:var(--primary-dim); color:var(--primary); border:2px solid var(--primary); }
.proc-title { font-family:var(--font-h); font-size:18px; font-weight:700; color:var(--text); margin-bottom:10px; }
.proc-text  { font-size:14px; color:var(--text-2); line-height:1.65; }

/* ==========================================================
   REVIEWS
   ========================================================== */
.reviews-section { padding:var(--py) 0; }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.review-card {
  background:var(--bg-card); border:1px solid var(--border-s);
  border-radius:var(--radius-l); padding:32px; backdrop-filter:blur(14px);
  transition:border-color .3s, transform .3s;
  display:flex; flex-direction:column;
}
.review-card:hover { border-color:var(--border); transform:translateY(-4px); }
.review-stars { display:flex; gap:3px; margin-bottom:16px; }
.star { color:#F59E0B; font-size:15px; }
.review-quote { font-size:15px; line-height:1.72; color:var(--text-2); font-style:italic; flex:1; margin-bottom:24px; }
.review-author { display:flex; align-items:center; gap:14px; }
.review-avatar { width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-h); font-size:15px; font-weight:700; flex-shrink:0; }
.av-cyan   { background:var(--primary-dim); color:var(--primary); }
.av-indigo { background:var(--indigo-dim);  color:var(--indigo); }
.av-teal   { background:var(--teal-dim);    color:var(--teal); }
.review-name { font-family:var(--font-h); font-size:15px; font-weight:600; color:var(--text); margin-bottom:2px; }
.review-role { font-size:13px; color:var(--text-3); }

/* ==========================================================
   KONTAKTFORMULAR
   ========================================================== */
.contact-section {
  padding:var(--py) 0;
  background:var(--bg-2);
  position:relative;
}
.contact-section::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad-line);
}
/* Kontakt page grid (new 2-col layout: form | info+map) */
.contact-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,64px);
  align-items:start;
}

/* Contact info cards (used in kontakt/index.php) */
.contact-info-cards { display:flex; flex-direction:column; gap:12px; }
.contact-info-card {
  display:flex; align-items:center; gap:16px;
  background:var(--bg-card); border:1px solid var(--border-s);
  border-radius:var(--radius); padding:16px 20px;
  transition:border-color .2s, background .2s;
  text-decoration:none;
  color:inherit;
}
a.contact-info-card:hover { border-color:var(--border); background:var(--bg-3); }
.contact-info-icon {
  width:44px; height:44px; border-radius:10px;
  background:var(--bg-3); border:1px solid var(--border-s);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:var(--primary);
}
.contact-info-label { font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--text-3); margin-bottom:2px; }
.contact-info-value { font-size:15px; font-weight:600; color:var(--text); }
.contact-info .tag-chip { margin-bottom:20px; }
.contact-info-title {
  font-family:var(--font-h);
  font-size:clamp(30px,4vw,46px);
  font-weight:800;
  letter-spacing:-0.025em;
  line-height:1.1;
  color:var(--text);
  margin-bottom:18px;
}
.contact-info-sub { font-size:clamp(15px,1.6vw,17px); color:var(--text-2); line-height:1.7; margin-bottom:36px; }

.contact-details { display:flex; flex-direction:column; gap:14px; margin-bottom:36px; }
.contact-detail-item {
  display:flex; align-items:center; gap:14px;
  font-size:15px; color:var(--text-2);
  transition:color .2s;
}
.contact-detail-item:hover { color:var(--primary); }
.contact-detail-icon {
  width:40px; height:40px; border-radius:10px;
  background:var(--bg-3); border:1px solid var(--border-s);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:var(--primary);
  transition:background .2s, border-color .2s;
}
.contact-detail-icon svg { width:18px; height:18px; }
.contact-detail-item:hover .contact-detail-icon { background:var(--primary-dim); border-color:var(--border); }

.contact-trust {
  display:flex; align-items:center; gap:12px;
  padding:16px 20px;
  background:var(--bg-card); border:1px solid var(--border-s);
  border-radius:var(--radius); backdrop-filter:blur(12px);
}
.contact-trust-icon { width:36px; height:36px; border-radius:10px; background:var(--teal-dim); color:var(--teal); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.contact-trust-icon svg { width:18px; height:18px; }
.contact-trust-text { font-size:14px; color:var(--text-2); line-height:1.5; }
.contact-trust-text strong { color:var(--text); font-weight:600; }

.contact-form-wrap {
  background:var(--bg-card);
  border:1px solid var(--border-s);
  border-radius:var(--radius-l);
  padding:clamp(28px,4vw,44px);
  backdrop-filter:blur(14px);
  position:relative; overflow:hidden;
}
.contact-form-wrap::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad-line); }
.form-label { font-family:var(--font-h); font-size:13px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--text-3); }
.form-input { width:100%; background:var(--bg-3); border:1px solid var(--border-s); border-radius:var(--radius-s); color:var(--text); font-size:15px; font-weight:400; padding:13px 16px; outline:none; transition:border-color .2s,background .2s,box-shadow .2s; appearance:none; -webkit-appearance:none; }
.form-input:focus { border-color:var(--primary); background:var(--bg-2); box-shadow:0 0 0 3px var(--primary-dim); }
.contact-item-row:hover { border-color:var(--primary) !important; }

.form-title {
  font-family:var(--font-h);
  font-size:22px; font-weight:700;
  letter-spacing:-0.02em; color:var(--text);
  margin-bottom:6px;
}
.form-sub { font-size:14px; color:var(--text-2); margin-bottom:28px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:7px; margin-bottom:16px; }
.form-group:last-of-type { margin-bottom:0; }

label {
  font-family:var(--font-h); font-size:13px; font-weight:600;
  letter-spacing:.04em; text-transform:uppercase;
  color:var(--text-3);
}
label span.req { color:var(--primary); margin-left:2px; }

input[type="text"],
input[type="email"],
input[type="tel"],
select,
textarea {
  width:100%; background:var(--bg-3);
  border:1px solid var(--border-s);
  border-radius:var(--radius-s);
  color:var(--text);
  font-size:15px; font-weight:400;
  padding:13px 16px;
  outline:none;
  transition:border-color .2s, background .2s, box-shadow .2s;
  appearance:none; -webkit-appearance:none;
}
input:focus, select:focus, textarea:focus {
  border-color:var(--primary);
  background:var(--bg-2);
  box-shadow:0 0 0 3px var(--primary-dim);
}
input::placeholder, textarea::placeholder { color:var(--text-3); }
select { cursor:pointer; }
textarea { resize:vertical; min-height:120px; line-height:1.6; }

.form-divider { height:1px; background:var(--border-s); margin:20px 0; }
.form-check { display:flex; align-items:flex-start; gap:12px; }
.form-check input[type="checkbox"] {
  width:18px; height:18px; border-radius:5px;
  border:1px solid var(--border-s); background:var(--bg-3);
  cursor:pointer; flex-shrink:0; margin-top:2px;
  accent-color:var(--primary);
}
.form-check-label { font-size:13px; color:var(--text-2); line-height:1.55; }
.form-check-label a { color:var(--primary); text-decoration:underline; }

.form-submit {
  width:100%; margin-top:20px;
  font-size:16px; padding:16px 32px;
  justify-content:center;
}
.form-note { font-size:12px; color:var(--text-3); text-align:center; margin-top:12px; }

/* ==========================================================
   FOOTER
   ========================================================== */
.footer { background:var(--bg); border-top:1px solid var(--border-s); padding:clamp(48px,7vw,80px) 0 40px; }
.footer-grid {
  display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr;
  gap:clamp(32px,5vw,64px);
  padding-bottom:48px; border-bottom:1px solid var(--border-s); margin-bottom:32px;
}
.footer-grid--5col {
  grid-template-columns: 2fr 1.2fr 1fr 1.2fr 0.8fr;
}
.f-logo { display:block; margin-bottom:16px; }
.f-tagline { font-size:14px; color:var(--text-2); line-height:1.7; max-width:270px; margin-bottom:24px; }
.f-contact { display:flex; flex-direction:column; gap:10px; }
.f-contact-item { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text-2); transition:color .2s; }
.f-contact-item:hover { color:var(--primary); }
.f-contact-icon { width:32px; height:32px; border-radius:8px; background:var(--bg-3); border:1px solid var(--border-s); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--primary); }
.f-contact-icon svg { width:14px; height:14px; }
.f-col-title { font-family:var(--font-h); font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text-3); margin-bottom:18px; }
.f-links { display:flex; flex-direction:column; gap:10px; }
.f-link { font-size:14px; color:var(--text-2); transition:color .2s; }
.f-link:hover { color:var(--primary); }

/* Footer social icons */
.f-social { display:flex; gap:10px; margin-top:24px; }
.f-social-link {
  width:36px; height:36px; border-radius:9px;
  background:var(--bg-3); border:1px solid var(--border-s);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-2); transition:color .2s, border-color .2s, background .2s;
}
.f-social-link:hover { color:var(--primary); border-color:var(--border); background:var(--primary-dim); }

.footer-bottom { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:16px; }
.f-copy { font-size:13px; color:var(--text-3); }
.f-legal { display:flex; flex-wrap:wrap; gap:24px; }
.f-legal a { font-size:13px; color:var(--text-3); transition:color .2s; }
.f-legal a:hover { color:var(--text-2); }
.f-bottom-link { font-size:13px; color:var(--text-3); transition:color .2s; }
.f-bottom-link:hover { color:var(--text-2); }

/* Scroll to top */
.scroll-top {
  position:fixed; bottom:32px; right:32px; z-index:900;
  width:44px; height:44px; border-radius:50%;
  background:var(--grad); color:#fff; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 24px var(--primary-glow);
  opacity:0; transform:translateY(16px);
  transition:opacity .3s, transform .3s;
}
.scroll-top.show { opacity:1; transform:none; }
.scroll-top:hover { transform:translateY(-3px); }
.scroll-top svg { width:18px; height:18px; }

/* ==========================================================
   PAGE HERO (inner pages)
   ========================================================== */
.page-hero {
  padding: calc(68px + clamp(48px,8vw,96px)) 0 clamp(48px,8vw,96px);
  position:relative; overflow:hidden;
  background: var(--bg);
}
.page-hero::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--grad-line); }
.page-hero-inner { position:relative; z-index:1; }
.page-hero .tag-chip { margin-bottom:20px; }
.page-hero-title {
  font-family:var(--font-h);
  font-size:clamp(38px,5vw,72px);
  font-weight:900;
  letter-spacing:-0.035em;
  line-height:1.0;
  color:var(--text);
  margin-bottom:20px;
  max-width:820px;
}
.page-hero-sub { font-size:clamp(16px,1.8vw,20px); color:var(--text-2); line-height:1.7; max-width:620px; margin-bottom:40px; }
.page-hero-ctas { display:flex; flex-wrap:wrap; gap:14px; }

/* Breadcrumb */
.breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-h); font-size:13px; color:var(--text-3);
  margin-bottom:28px;
}
.breadcrumb a { color:var(--text-3); transition:color .2s; }
.breadcrumb a:hover { color:var(--primary); }
.breadcrumb-sep { opacity:.4; }

/* ==========================================================
   CONTENT SECTIONS (inner pages)
   ========================================================== */
.content-section { padding:var(--py) 0; }
.content-section.alt { background:var(--bg-2); }

.prose { max-width:780px; }
.prose h2 {
  font-family:var(--font-h); font-size:clamp(24px,3vw,36px); font-weight:800;
  letter-spacing:-0.025em; color:var(--text); margin-bottom:16px; margin-top:48px;
}
.prose h2:first-child { margin-top:0; }
.prose h3 {
  font-family:var(--font-h); font-size:clamp(18px,2vw,24px); font-weight:700;
  color:var(--text); margin-bottom:12px; margin-top:32px;
}
.prose p { font-size:16px; line-height:1.8; color:var(--text-2); margin-bottom:20px; }
.prose ul { list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:24px; }
.prose ul li {
  display:flex; align-items:flex-start; gap:12px;
  font-size:15px; color:var(--text-2); line-height:1.6;
}
.prose ul li::before {
  content:''; width:20px; height:20px; border-radius:50%;
  background:var(--primary-dim); border:1px solid rgba(0,194,255,.2);
  flex-shrink:0; margin-top:2px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2300C2FF' stroke-width='2.5'%3E%3Cpolyline points='20 6 9 17 4 12' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size:12px; background-repeat:no-repeat; background-position:center;
}

/* ── Globale Aufzählungsliste – gilt auf ALLEN Seiten ─────────── */
/* Ausnahmen: nav, footer, .toc-list, .svc-features bleiben unberührt */
.content-section ul,
.page-hero ul,
.prose ul,
main > section ul {
  list-style: none;
  padding-left: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 24px;
}
.content-section ul li,
.page-hero ul li,
.prose ul li,
main > section ul li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--text-2);
}
.content-section ul li::before,
.page-hero ul li::before,
.prose ul li::before,
main > section ul li::before {
  content: '';
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--primary-dim);
  border: 1px solid rgba(0,194,255,.2);
  flex-shrink: 0;
  margin-top: 2px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2300C2FF' stroke-width='2.5'%3E%3Cpolyline points='20 6 9 17 4 12' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: 12px;
  background-repeat: no-repeat;
  background-position: center;
}

/* ── Feature-Card / Service-Block Bullets: Häkchen ohne Kreis ───── */
/* Überschreibt den globalen Kreis-Stil für Karten mit kompakten Listen */
.feature-card ul li::before,
.service-detail-block ul li::before,
.why-card ul li::before {
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  width: 18px !important;
  height: 18px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2300C2FF' stroke-width='2.8'%3E%3Cpolyline points='20 6 9 17 4 12' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
  background-size: 100% !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  flex-shrink: 0;
  margin-top: 3px !important;
}
.feature-card ul li,
.service-detail-block ul li,
.why-card ul li {
  font-size: 14px;
  gap: 10px;
}

/* Two-col layout */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:start; }
.two-col.reverse { direction:rtl; }
.two-col.reverse > * { direction:ltr; }

/* Feature grid */
.feature-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
/* ── Universeller Gradient-Border-Hover für ALLE Karten ─────── */
.feature-card, .why-card, .team-card, .hs-card,
.service-detail-block, .review-card, .blog-card {
  position: relative;
  overflow: hidden;
}
.feature-card::before, .why-card::before, .team-card::before,
.hs-card::before, .service-detail-block::before, .review-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--grad-line);
  border-radius: var(--radius-l) var(--radius-l) 0 0;
  opacity: 0; transition: opacity .3s;
}
.feature-card:hover::before, .why-card:hover::before, .team-card:hover::before,
.hs-card:hover::before, .service-detail-block:hover::before, .review-card:hover::before {
  opacity: 1;
}

.feature-card {
  background:var(--bg-card); border:1px solid var(--border-s);
  border-radius:var(--radius-l); padding:28px;
  backdrop-filter:blur(14px);
  transition:border-color .3s, transform .3s, box-shadow .3s;
}
.feature-card:hover { border-color:var(--border); transform:translateY(-4px); box-shadow:var(--shadow-card); }
.feature-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.feature-icon svg { width:20px; height:20px; }
.feature-title { font-family:var(--font-h); font-size:17px; font-weight:700; color:var(--text); margin-bottom:8px; }
.feature-text { font-size:14px; color:var(--text-2); line-height:1.65; }

/* CTA Banner */
.cta-banner {
  padding:var(--py) 0;
  background:var(--bg-2);
  position:relative; overflow:hidden;
}
.cta-banner::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad-line); }
.cta-banner-inner { text-align:center; max-width:680px; margin:0 auto; }
.cta-banner-title { font-family:var(--font-h); font-size:clamp(28px,4vw,48px); font-weight:800; letter-spacing:-0.025em; color:var(--text); margin-bottom:18px; }
.cta-banner-sub { font-size:clamp(15px,1.8vw,18px); color:var(--text-2); line-height:1.7; margin-bottom:36px; }
.cta-banner-btns { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }

/* ==========================================================
   UEBER UNS — Team grid
   ========================================================== */
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.team-card {
  background:var(--bg-card); border:1px solid var(--border-s);
  border-radius:var(--radius-l); padding:32px; text-align:center;
  backdrop-filter:blur(14px); transition:border-color .3s, transform .3s;
}
.team-card:hover { border-color:var(--border); transform:translateY(-4px); }

/* Foto-Wrapper: zentriertes Kreisbild oben in der Karte */
.team-photo-wrap {
  width: 130px; height: 130px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 20px;
  border: 3px solid var(--border-s);
  background: var(--bg-2);
  flex-shrink: 0;
}
.team-photo-wrap img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }

/* Horizontale Variante: Foto links, Text rechts – für 2-Spalten-Grid */
.team-card--wide {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 24px;
  text-align: left;
}
.team-card--wide .team-card-img {
  flex-shrink: 0;
  width: 100px !important;
  height: 100px !important;
}
.team-card--wide .team-card-body { text-align: left; flex: 1; }
.team-card--wide .team-card-name { font-size: 19px; }
.team-card--wide .team-card-bio { font-size: 14px; line-height: 1.7; }
.team-avatar {
  width:80px; height:80px; border-radius:50%;
  margin:0 auto 20px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-h); font-size:28px; font-weight:800;
}
.team-name { font-family:var(--font-h); font-size:18px; font-weight:700; color:var(--text); margin-bottom:4px; }
.team-role { font-size:14px; color:var(--text-3); margin-bottom:16px; }
.team-bio  { font-size:14px; color:var(--text-2); line-height:1.65; }

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media (max-width:1100px) {
  .nav-desktop { display:none; }
  .hamburger { display:flex; }
  .header-right .btn { display:none; }
  .header-right .toggle-theme { display:none; }
  .hero-grid { grid-template-columns:1fr; gap:48px; }
  .hero-right { display:none; }
  .hero-stats { grid-template-columns:repeat(3,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .footer-grid--5col { grid-template-columns:1fr 1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .contact-info { max-width:600px; }
  .two-col { grid-template-columns:1fr; }
  .two-col.reverse { direction:ltr; }
  .team-grid { grid-template-columns:repeat(2,1fr) !important; }
  .service-details-grid { grid-template-columns:1fr 1fr; }
  .stats-row { grid-template-columns:1fr 1fr; }
  .stats-row .stat-block:nth-child(2) { border-right:none; }
  .stats-row .stat-block:nth-child(3),
  .stats-row .stat-block:nth-child(4) { border-top:1px solid var(--border-s); }
}
@media (max-width:800px) {
  .services-grid { grid-template-columns:1fr 1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .stat-item:nth-child(2) { border-right:none; }
  .stat-item:nth-child(3), .stat-item:nth-child(4) { border-top:1px solid var(--border-s); }
  .why-grid { grid-template-columns:1fr; }
  .reviews-grid { grid-template-columns:1fr; }
  .process-track { grid-template-columns:1fr 1fr; gap:32px; }
  .process-track::before { display:none; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-grid--5col { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .feature-grid { grid-template-columns:1fr; }
}
@media (max-width:540px) {
  .services-grid { grid-template-columns:1fr; }
  .service-details-grid { grid-template-columns:1fr; }
  .stats-row { grid-template-columns:1fr; }
  .stats-row .stat-block { border-right:none !important; border-top:1px solid var(--border-s); }
  .stats-row .stat-block:first-child { border-top:none; }
  .hero-stats { grid-template-columns:1fr 1fr; }
  .hero-stats .hs-card:last-child { grid-column:span 2; }
  .hero-ctas { flex-direction:column; }
  .hero-ctas .btn { width:100%; justify-content:center; }
  .stats-grid { grid-template-columns:1fr; }
  .stat-item { border-right:none !important; border-top:1px solid var(--border-s); }
  .stat-item:first-child { border-top:none; }
  .process-track { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr !important; }
  .page-hero-ctas { flex-direction:column; align-items:flex-start; }
  .blog-hero .container { padding-left: 20px; padding-right: 20px; }
  .cta-banner-inner { padding: 32px 20px; }
  .hero-stats .hs-card { padding: 20px 14px; }
  .contact-info-cards { gap: 8px; }
  .contact-info-card { padding: 12px 16px; }
}

::selection { background:var(--primary-dim); color:var(--primary); }
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--bg-3); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--text-3); }

/* ==========================================================
   TOP BAR
   ========================================================== */
.topbar {
  background: var(--bg-2);
  border-bottom: 1px solid var(--border-s);
  font-size: 12px;
}
.topbar-inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 24px;
  height: 36px;
}
.topbar-link {
  color: var(--text-2);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: color 0.2s;
}
.topbar-link:hover { color: var(--primary); }
@media (max-width:1100px) { .topbar { display:none; } }

/* ==========================================================
   NAV DROPDOWNS
   ========================================================== */
.nav-dropdown { position: relative; }

/* Toggle: extends .nav-link — only add flex for chevron */
.nav-dropdown-toggle {
  display: flex !important;
  align-items: center;
  gap: 5px;
  text-decoration: none;
  /* Reset button defaults (when used as <button>) */
  background: none;
  border: none;
  cursor: pointer;
}
.nav-dropdown-toggle svg {
  transition: transform 0.2s;
  flex-shrink: 0;
  opacity: 0.6;
}
.nav-dropdown:hover .nav-dropdown-toggle svg,
.nav-dropdown-toggle.active svg { transform: rotate(180deg); opacity: 1; }

/* Dropdown panel */
.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-2);
  border: 1px solid var(--border-s);
  border-radius: 12px;
  min-width: 210px;
  padding: 10px 6px 6px;
  list-style: none;
  margin: 0;
  box-shadow: 0 12px 40px rgba(0,0,0,0.25);
  z-index: 1000;
}
/* Invisible bridge so mouse can move from nav-link into dropdown without gap closing it */
.nav-dropdown-menu::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 0;
  right: 0;
  height: 12px;
}
.nav-dropdown-menu.open { display: block; }

/* Dropdown items — same visual language as nav-link */
.nav-dropdown-item {
  display: block;
  padding: 8px 12px;
  border-radius: 8px;
  color: var(--text-2);
  text-decoration: none;
  font-family: var(--font-h);
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.nav-dropdown-item:hover {
  background: var(--primary-dim);
  color: var(--text);
}

/* Wide 2-column dropdown for Leistungen (10 items) */
.nav-dropdown-menu--wide {
  min-width: 440px;
  display: none;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
}
.nav-dropdown-menu--wide.open { display: grid; }

/* ==========================================================
   BLOG INDEX
   ========================================================== */
.blog-hero {
  padding: calc(68px + clamp(48px,8vw,96px)) 0 clamp(48px,7vw,80px);
  position: relative;
  overflow: hidden;
  text-align: left;
  background: var(--bg);
}
.blog-hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-line);
}
.blog-hero .tag-chip { margin-bottom: 20px; }
.blog-hero-title {
  font-family: var(--font-h);
  font-size: clamp(38px,5.5vw,72px);
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 1.05;
  color: var(--text);
  margin-bottom: 18px;
}
.blog-hero-sub {
  font-size: clamp(16px,1.8vw,19px);
  color: var(--text-2);
  max-width: 600px;
  margin: 0 0 40px;
  line-height: 1.7;
}

/* Category filter bar */
.blog-filter-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: clamp(40px,5vw,64px);
  justify-content: center;
}
.blog-filter-btn {
  font-family: var(--font-h);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 8px 20px;
  border-radius: 100px;
  border: 1px solid var(--border-s);
  background: var(--bg-card);
  color: var(--text-2);
  cursor: pointer;
  transition: all 0.2s;
}
.blog-filter-btn:hover,
.blog-filter-btn.active {
  background: var(--primary-dim);
  border-color: var(--border);
  color: var(--primary);
}

.blog-index-section { padding: clamp(48px,7vw,80px) 0; }

/* Grid */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* Featured first card spans 2 cols */
.blog-grid .blog-card:first-child {
  grid-column: span 2;
  flex-direction: row;
}
.blog-grid .blog-card:first-child .blog-card-img {
  flex: 0 0 52%;
  aspect-ratio: unset;
  min-height: 280px;
}
.blog-grid .blog-card:first-child .blog-card-body {
  padding: 36px 32px;
}
.blog-grid .blog-card:first-child .blog-card-title {
  font-size: clamp(20px,2.2vw,28px);
}

/* Card base */
.blog-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--border-s);
  border-radius: var(--radius-l);
  overflow: hidden;
  backdrop-filter: blur(14px);
  transition: border-color 0.3s, transform 0.28s cubic-bezier(.16,1,.3,1), box-shadow 0.3s;
  position: relative;
  text-decoration: none;
  color: inherit;
}
.blog-card:hover {
  border-color: var(--border);
  transform: translateY(-5px);
  box-shadow: var(--shadow-card);
}
.blog-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-line);
  opacity: 0;
  transition: opacity 0.3s;
}
.blog-card:hover::before { opacity: 1; }

.blog-card-img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  flex-shrink: 0;
}
.blog-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.blog-card:hover .blog-card-img img { transform: scale(1.04); }

.blog-card-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.blog-card-body .tag-chip {
  margin-bottom: 14px;
  align-self: flex-start;
  font-size: 10px;
}
/* Category color variants */
.tag-chip--seo   { color: var(--teal);   background: var(--teal-dim);   border-color: rgba(0,212,170,.2); }
.tag-chip--seo::before   { background: var(--teal); }
.tag-chip--ads   { color: var(--indigo); background: var(--indigo-dim); border-color: rgba(124,115,230,.2); }
.tag-chip--ads::before   { background: var(--indigo); }

.blog-card-title {
  font-family: var(--font-h);
  font-size: clamp(16px,1.6vw,19px) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.3 !important;
  color: var(--text);
  margin-top: 0 !important;
  margin-bottom: 12px !important;
  transition: color 0.2s;
}
.blog-card:hover .blog-card-title { color: var(--primary); }

.blog-card-excerpt {
  font-size: 14px;
  line-height: 1.72;
  color: var(--text-2);
  margin-bottom: 20px;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 16px;
  border-top: 1px solid var(--border-s);
  margin-top: auto;
}
.blog-card-date {
  font-family: var(--font-h);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-3);
  letter-spacing: 0.04em;
}
.blog-card-read {
  font-family: var(--font-h);
  font-size: 13px;
  font-weight: 600;
  color: var(--primary);
  display: flex;
  align-items: center;
  gap: 4px;
  transition: gap 0.2s;
}
.blog-card:hover .blog-card-read { gap: 8px; }

/* CTA section */
.cta-section {
  padding: var(--py) 0;
  background: var(--bg-2);
  position: relative;
  overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-line);
}
.cta-section h2 {
  font-family: var(--font-h);
  font-size: clamp(28px,4vw,48px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--text);
  margin-bottom: 14px;
}
.cta-section .text-muted {
  font-size: clamp(15px,1.8vw,18px);
  color: var(--text-2);
  line-height: 1.7;
  margin-bottom: 32px;
}

/* ==========================================================
   BLOG SINGLE POST
   ========================================================== */
.blog-post-hero {
  padding: calc(68px + clamp(40px,7vw,80px)) 0 0;
  position: relative;
  background: var(--bg);
}

.blog-post-hero-inner {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 clamp(20px,5vw,64px);
  padding-bottom: clamp(40px,6vw,64px);
}

.blog-post-hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-line);
}

.blog-post-category {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-h);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--primary);
  background: var(--primary-dim);
  border: 1px solid var(--border);
  padding: 6px 16px 6px 10px;
  border-radius: 100px;
  margin-bottom: 24px;
}
.blog-post-category::before {
  content: '';
  width: 7px; height: 7px;
  background: var(--primary);
  border-radius: 50%;
}

.blog-post-title {
  font-family: var(--font-h);
  font-size: clamp(30px,4.5vw,56px);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--text);
  margin-bottom: 20px;
}

.blog-post-meta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-family: var(--font-h);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-3);
  padding-bottom: 32px;
}
.blog-meta-sep { opacity: 0.4; }
.blog-post-meta-row .meta-author {
  display: flex;
  align-items: center;
  gap: 8px;
}
.meta-author-avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--grad);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; color: #fff;
  flex-shrink: 0;
}

/* Hero image */
.blog-post-hero-img {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  border-radius: var(--radius-l) var(--radius-l) 0 0;
  overflow: hidden;
}
.blog-post-hero-img img {
  width: 100%;
  height: auto;
  max-height: 520px;
  object-fit: cover;
  display: block;
}

/* Article body */
.blog-post-section {
  padding: clamp(48px,7vw,80px) 0;
}
.blog-post-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 clamp(20px,5vw,64px);
}

/* Article content */
.blog-article-content {
  max-width: 100%;
}

.blog-article-content h2 {
  font-family: var(--font-h);
  font-size: clamp(22px,2.8vw,32px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--text);
  margin-top: 48px;
  margin-bottom: 16px;
  padding-left: 16px;
  border-left: 3px solid var(--primary);
}
.blog-article-content h2:first-child { margin-top: 0; }

.blog-article-content h3 {
  font-family: var(--font-h);
  font-size: clamp(17px,2vw,22px);
  font-weight: 700;
  color: var(--text);
  margin-top: 32px;
  margin-bottom: 12px;
}

.blog-article-content p {
  font-size: 16px;
  line-height: 1.82;
  color: var(--text-2);
  margin-bottom: 22px;
}

.blog-article-content ul,
.blog-article-content ol {
  margin-bottom: 24px;
  padding-left: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.blog-article-content ul li,
.blog-article-content ol li {
  font-size: 15px;
  line-height: 1.7;
  color: var(--text-2);
  padding-left: 32px;
  position: relative;
}
.blog-article-content ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 4px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--primary-dim);
  border: 1px solid rgba(0,194,255,.2);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2300C2FF' stroke-width='2.5'%3E%3Cpolyline points='20 6 9 17 4 12' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: 10px;
  background-repeat: no-repeat;
  background-position: center;
}

.blog-article-content a {
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.2s;
}
.blog-article-content a:hover { opacity: 0.75; }

.blog-article-content strong { color: var(--text); font-weight: 600; }

.blog-article-content figure,
.blog-figure {
  margin: 32px 0;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border-s);
}
.blog-article-content figure img,
.blog-figure img {
  width: 100%;
  height: auto;
  display: block;
}

/* Tables */
.blog-article-content .table-responsive {
  overflow-x: auto;
  margin-bottom: 24px;
  border-radius: var(--radius-s);
  border: 1px solid var(--border-s);
}
.blog-article-content table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  min-width: 480px;
}
.blog-article-content table td,
.blog-article-content table th {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-s);
  color: var(--text-2);
  vertical-align: top;
  line-height: 1.5;
}
.blog-article-content table tr:last-child td { border-bottom: none; }
.blog-article-content table tr:nth-child(even) td { background: var(--bg-3); }
.blog-article-content table td:first-child { font-weight: 600; color: var(--text); }

/* Highlight / CTA box inside article */
.blog-highlight-box {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-l);
  padding: clamp(28px,4vw,40px);
  margin: 36px 0;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(14px);
}
.blog-highlight-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-line);
}
.blog-highlight-box h2,
.blog-highlight-box h3 {
  font-family: var(--font-h);
  font-size: clamp(18px,2vw,24px);
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
  margin-top: 0 !important;
  padding-left: 0 !important;
  border-left: none !important;
}
.blog-highlight-box p {
  font-size: 15px;
  color: var(--text-2);
  margin-bottom: 20px;
}
.blog-highlight-box .btn { margin-top: 4px; }

/* FAQ accordion style */
.blog-article-content .aioseo-faq-block-question {
  font-family: var(--font-h);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin-top: 20px;
  margin-bottom: 8px;
}
.blog-article-content .aioseo-faq-block-answer p {
  font-size: 15px;
  margin-bottom: 12px;
}

/* Sidebar */
.blog-sidebar { position: sticky; top: 88px; }

.sidebar-card {
  background: var(--bg-card);
  border: 1px solid var(--border-s);
  border-radius: var(--radius-l);
  padding: 28px;
  backdrop-filter: blur(14px);
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
}
.sidebar-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-line);
  opacity: 0;
  transition: opacity 0.3s;
}
.sidebar-card:hover::before { opacity: 1; }

.sidebar-card-title {
  font-family: var(--font-h);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 18px;
}

/* Table of contents */
.toc-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
  counter-reset: toc;
}
.toc-list li { counter-increment: toc; }
.toc-list a {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-2);
  padding: 6px 8px;
  border-radius: var(--radius-s);
  transition: background 0.2s, color 0.2s;
  text-decoration: none;
}
.toc-list a::before {
  content: counter(toc);
  font-family: var(--font-h);
  font-size: 10px;
  font-weight: 700;
  min-width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--bg-3);
  color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background 0.2s;
}
.toc-list a:hover {
  background: var(--primary-dim);
  color: var(--primary);
}
.toc-list a:hover::before { background: var(--primary-dim); }

/* CTA sidebar box */
.sidebar-cta-box {
  background: var(--grad);
  border-radius: var(--radius-l);
  padding: 28px;
  text-align: center;
  margin-bottom: 24px;
}
.sidebar-cta-box h3 {
  font-family: var(--font-h);
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
}
.sidebar-cta-box p {
  font-size: 13px;
  color: rgba(255,255,255,0.85);
  line-height: 1.6;
  margin-bottom: 18px;
}
.sidebar-cta-box .btn {
  background: rgba(255,255,255,0.15);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.3);
  width: 100%;
  justify-content: center;
  backdrop-filter: blur(8px);
}
.sidebar-cta-box .btn:hover {
  background: rgba(255,255,255,0.25);
  transform: translateY(-2px);
}

/* Related posts */
.related-post-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-s);
  text-decoration: none;
  color: inherit;
  transition: color 0.2s;
}
.related-post-item:last-child { border-bottom: none; padding-bottom: 0; }
.related-post-item:first-child { padding-top: 0; }
.related-post-thumb {
  width: 56px; height: 56px;
  border-radius: var(--radius-s);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--bg-3);
}
.related-post-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.related-post-info {}
.related-post-title {
  font-family: var(--font-h);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.4;
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color 0.2s;
}
.related-post-item:hover .related-post-title { color: var(--primary); }
.related-post-date {
  font-family: var(--font-h);
  font-size: 11px;
  color: var(--text-3);
}

/* Post CTA section */
.blog-post-cta {
  padding: var(--py) 0;
  background: var(--bg-2);
  position: relative;
  overflow: hidden;
  text-align: center;
}
.blog-post-cta::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--grad-line);
}
.blog-post-cta h2 {
  font-family: var(--font-h);
  font-size: clamp(26px,4vw,44px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--text);
  margin-bottom: 14px;
}
.blog-post-cta p {
  font-size: clamp(15px,1.8vw,18px);
  color: var(--text-2);
  max-width: 540px;
  margin: 0 auto 32px;
  line-height: 1.7;
}
.blog-post-cta .cta-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}

/* ==========================================================
   BLOG RESPONSIVE
   ========================================================== */
@media (max-width: 1100px) {
  .blog-post-layout {
    grid-template-columns: 1fr;
  }
  .blog-sidebar { position: static; }
}
@media (max-width: 900px) {
  .blog-grid { grid-template-columns: 1fr 1fr; }
  .blog-grid .blog-card:first-child {
    grid-column: span 2;
    flex-direction: column;
  }
  .blog-grid .blog-card:first-child .blog-card-img {
    min-height: unset;
    aspect-ratio: 16/9;
  }
}
@media (max-width: 600px) {
  .blog-grid { grid-template-columns: 1fr; }
  .blog-grid .blog-card:first-child { grid-column: span 1; }
}

/* ==========================================================
   NAV DROPDOWN — HOVER SUPPORT (Desktop)
   ========================================================== */
@media (min-width: 1101px) {
  .nav-dropdown:hover > .nav-dropdown-menu { display: block; }
  .nav-dropdown:hover > .nav-dropdown-menu--wide { display: grid; }
  .nav-dropdown:hover > .nav-dropdown-toggle { color: var(--text); }
}

/* ==========================================================
   TEAM — Übersichtsseite Cards
   ========================================================== */
.team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 56px;
}
.team-card {
  background: var(--bg-card);
  border: 1px solid var(--border-s);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
  display: flex;
  flex-direction: column;
}
.team-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.5);
  border-color: var(--border);
}
/* Horizontale Variante – Override nach dem zweiten .team-card-Block */
.team-card.team-card--wide {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start;
  gap: 20px;
  padding: 24px;
  text-align: left;
  overflow: visible;
}
.team-card.team-card--wide .team-card-img {
  flex-shrink: 0;
  width: 88px !important;
  height: 88px !important;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}
.team-card.team-card--wide .team-card-body {
  padding: 0;
  text-align: left;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.team-card.team-card--wide .team-card-name { font-size: 17px; }
.team-card.team-card--wide .team-card-bio  { font-size: 13.5px; line-height: 1.65; }
.team-card-img {
  width: 100%;
  height: 300px;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.team-card-body {
  padding: 28px 28px 32px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.team-card-name {
  font-family: var(--font-h);
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}
.team-card-role {
  font-family: var(--font-h);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 16px;
}
.team-card-bio {
  font-size: 15px;
  color: var(--text-2);
  line-height: 1.7;
  flex: 1;
  margin-bottom: 24px;
}
.team-card-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.team-card-actions .btn {
  font-size: 13px;
  padding: 10px 20px;
}

/* ==========================================================
   TEAM — Detailseite Hero
   ========================================================== */
.team-detail-hero {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 64px;
  align-items: center;
  padding: var(--py) 0;
}
.team-detail-img-wrap {
  position: relative;
}
.team-detail-img {
  width: 100%;
  border-radius: var(--radius-l);
  object-fit: cover;
  object-position: center top;
  aspect-ratio: 3/4;
  display: block;
  box-shadow: var(--shadow-card);
}
.team-detail-img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-l);
  border: 1px solid var(--border);
  pointer-events: none;
}
.team-detail-info {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.team-detail-role {
  font-family: var(--font-h);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--primary);
}
.team-detail-name {
  font-family: var(--font-h);
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 800;
  line-height: 1.1;
  color: var(--text);
}
.team-detail-quote {
  font-family: var(--font-h);
  font-size: clamp(17px, 2.2vw, 22px);
  font-style: italic;
  color: var(--text-2);
  border-left: 3px solid var(--primary);
  padding-left: 20px;
  line-height: 1.55;
}
.team-detail-bio {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.team-detail-bio p {
  font-size: clamp(15px, 1.6vw, 17px);
  color: var(--text-2);
  line-height: 1.8;
}
.team-detail-contact {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
  background: var(--bg-card);
  border: 1px solid var(--border-s);
  border-radius: var(--radius);
  margin-top: 8px;
}
.team-detail-contact-title {
  font-family: var(--font-h);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 4px;
}
.team-contact-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  color: var(--text-2);
}
.team-contact-item svg {
  flex-shrink: 0;
  color: var(--primary);
}
.team-contact-item a {
  color: var(--primary);
  transition: opacity 0.2s;
}
.team-contact-item a:hover { opacity: 0.75; }
.team-cta-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.team-section-bio {
  padding: clamp(48px, 7vw, 88px) 0;
  background: var(--bg-2);
}
.team-section-bio .container {
  max-width: 820px;
}
.team-section-bio h2 {
  font-family: var(--font-h);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 700;
  color: var(--text);
  margin-bottom: 28px;
}
.team-section-bio p {
  font-size: clamp(15px, 1.7vw, 17px);
  color: var(--text-2);
  line-height: 1.85;
  margin-bottom: 20px;
}

/* Expertise-Tags */
.team-expertise {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 32px;
}
.team-expertise-tag {
  font-family: var(--font-h);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-2);
  background: var(--bg-3);
  border: 1px solid var(--border-s);
  border-radius: 100px;
  padding: 6px 16px;
}

/* ==========================================================
   TEAM RESPONSIVE
   ========================================================== */
@media (max-width: 1100px) {
  .team-grid { grid-template-columns: 1fr 1fr; }
  .team-detail-hero { grid-template-columns: 320px 1fr; gap: 40px; }
}
@media (max-width: 800px) {
  .team-grid { grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
  .team-detail-hero { grid-template-columns: 1fr; gap: 32px; padding: 48px 0 32px; }
  .team-detail-img { aspect-ratio: 4/3; }
}


/* ==========================================================
   CALENDLY MODAL
   ========================================================== */
.cal-modal {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.cal-modal.open {
  opacity: 1;
  pointer-events: all;
}
.cal-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  cursor: pointer;
}
.cal-modal-dialog {
  position: relative;
  z-index: 1;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-l);
  width: 100%;
  max-width: 1000px;
  max-height: calc(100vh - 24px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.6);
  transform: translateY(24px) scale(.97);
  transition: transform 0.25s ease;
}
.cal-modal.open .cal-modal-dialog {
  transform: translateY(0) scale(1);
}
.cal-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border-s);
  flex-shrink: 0;
}
.cal-modal-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-h);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.cal-modal-close {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--border-s);
  background: transparent;
  color: var(--text-2);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, color .15s;
  flex-shrink: 0;
}
.cal-modal-close:hover {
  background: var(--bg-2);
  color: var(--text);
}
.cal-modal-body {
  flex: 1;
  overflow: hidden;
  min-height: 750px;
}
#cal-iframe {
  width: 100%;
  height: 100%;
  min-height: 750px;
  border: none;
  display: block;
}
@media (max-width: 600px) {
  .cal-modal-dialog { border-radius: var(--radius); max-height: calc(100vh - 16px); }
  .cal-modal-body, #cal-iframe { min-height: calc(100vh - 80px); }
}
