/*
Theme Name: GEO-Optimaliseren
Theme URI: https://geo-optimaliseren.nl
Author: Tijm de Jong
Author URI: https://geo-optimaliseren.nl
Description: Custom theme voor GEO-Optimaliseren.nl
Version: 1.0.0
License: Proprietary
Text Domain: geo-optimaliseren
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
*/

/* ═══════════════════════════════════════
   TOKENS
═══════════════════════════════════════ */
:root {
  --navy-950: #020c1b;
  --navy-900: #061526;
  --navy-800: #0b1e3d;
  --navy-700: #0f2757;
  --accent:        #2b7fff;
  --accent-2:      #0ea5e9;
  --accent-light:  #5aaeff;
  --teal:          #06b6d4;
  --mint:          #34d399;
  --amber:         #f59e0b;
  --rose:          #f87171;
  --text-1: #e9f0fb;
  --text-2: #8aa3c4;
  --text-3: #4a6080;
  --text-4: #2e4160;
  --border:    rgba(70,120,200,0.09);
  --border-md: rgba(70,120,200,0.16);
  --border-lg: rgba(70,120,200,0.26);
  --card-bg:   rgba(7,17,36,0.82);
  --grad: linear-gradient(90deg, #00c6ff 0%, #0072ff 100%);
  --r:    14px;
  --r-sm:  8px;
  --r-lg: 20px;
  --t: 0.22s ease;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Cabinet Grotesk', sans-serif;
  background: var(--navy-950);
  color: var(--text-1);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ═══════════════════════════════════════
   ANIMATED BACKGROUND
═══════════════════════════════════════ */
.bg-canvas {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden;
}
.bg-canvas::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(43,127,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(43,127,255,0.022) 1px, transparent 1px);
  background-size: 54px 54px;
}
.orb { position: absolute; border-radius: 50%; filter: blur(90px); will-change: transform; }
.orb-1 { width:900px;height:900px;top:-300px;left:-200px;
  background:radial-gradient(circle,rgba(43,127,255,0.11) 0%,transparent 60%);
  animation:drift-1 28s ease-in-out infinite; }
.orb-2 { width:700px;height:700px;bottom:0;right:-150px;
  background:radial-gradient(circle,rgba(6,182,212,0.09) 0%,transparent 60%);
  animation:drift-2 34s ease-in-out infinite; }
.orb-3 { width:500px;height:500px;top:42%;left:38%;
  background:radial-gradient(circle,rgba(43,127,255,0.05) 0%,transparent 65%);
  animation:drift-3 22s ease-in-out infinite; }
.orb-4 { width:340px;height:340px;top:20%;right:10%;
  background:radial-gradient(circle,rgba(6,182,212,0.06) 0%,transparent 65%);
  animation:drift-4 40s ease-in-out infinite; }
@keyframes drift-1 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(40px,60px) scale(1.04)} 66%{transform:translate(-30px,30px) scale(0.97)} }
@keyframes drift-2 { 0%,100%{transform:translate(0,0) scale(1)} 40%{transform:translate(-50px,-40px) scale(1.06)} 70%{transform:translate(30px,20px) scale(0.96)} }
@keyframes drift-3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-60px,40px)} }
@keyframes drift-4 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(40px,-50px) scale(1.08)} }

/* ═══════════════════════════════════════
   LAYOUT
═══════════════════════════════════════ */
section { position: relative; z-index: 1; }
.container    { max-width:1140px; margin:0 auto; padding:0 28px; }
.container-md { max-width: 900px; margin:0 auto; padding:0 28px; }
.container-sm { max-width: 720px; margin:0 auto; padding:0 28px; }

/* ═══════════════════════════════════════
   TYPOGRAPHY HELPERS
═══════════════════════════════════════ */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--accent-light);
  border:1px solid rgba(43,127,255,0.22);
  background:rgba(43,127,255,0.07);
  padding:5px 14px; border-radius:20px;
}
.eyebrow-dot { width:5px;height:5px;border-radius:50%;background:var(--accent-light);animation:blink-dot 2.4s ease-in-out infinite; }
@keyframes blink-dot { 0%,100%{opacity:1} 50%{opacity:0.25} }
.display-title {
  font-family:'Cabinet Grotesk',sans-serif;
  font-size:clamp(32px,5vw,52px); line-height:1.06; letter-spacing:-1.8px; color:var(--text-1); font-weight:600;
}
.display-title em { font-style:normal; font-weight:600; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sec-header { text-align:center; margin-bottom:52px; }
.sec-header .eyebrow { margin-bottom:20px; }
.sec-header p { font-size:16px; color:var(--text-2); max-width:520px; margin:14px auto 0; line-height:1.7; }

/* ═══════════════════════════════════════
   BUTTONS
═══════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:'Cabinet Grotesk',sans-serif; font-weight:600;
  border-radius:var(--r-sm); cursor:pointer; text-decoration:none;
  transition:all var(--t); white-space:nowrap; border:none;
}
.btn-primary {
  background:linear-gradient(90deg,#00c6ff 0%,#0072ff 100%);
  color:#fff; font-size:15px; padding:14px 30px;
  box-shadow:0 4px 22px rgba(0,114,255,0.32); position:relative; overflow:hidden;
}
.btn-primary::after { content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.10),transparent);pointer-events:none; }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 36px rgba(0,114,255,0.50),0 0 0 1px rgba(0,198,255,0.25); }
.btn-primary:active { transform:translateY(0); }
.btn-secondary {
  background:transparent; border:1px solid var(--border-lg)!important;
  color:var(--text-2); font-size:14px; padding:13px 24px;
}
.btn-secondary:hover { border-color:rgba(90,174,255,0.4)!important; color:var(--text-1); background:rgba(43,127,255,0.05); }
.btn-lg { font-size:16px; padding:17px 36px; }
.btn-sm { font-size:13px; padding:10px 20px; }

/* ═══════════════════════════════════════
   NAV
═══════════════════════════════════════ */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:70px; display:flex; align-items:center;
  background:rgba(2,12,27,0.82);
  backdrop-filter:blur(22px) saturate(1.4);
  border-bottom:1px solid var(--border);
  transition:background var(--t);
}
.nav-inner {
  max-width:1140px; margin:0 auto; padding:0 28px;
  width:100%; display:flex; align-items:center; justify-content:space-between;
}
.nav-logo { display:flex; align-items:center; text-decoration:none; flex-shrink:0; }
.nav-links { display:flex; align-items:center; gap:4px; list-style:none; }
.nav-links a { font-size:13px; font-weight:500; color:var(--text-2); text-decoration:none; padding:6px 12px; border-radius:6px; transition:all var(--t); }
.nav-links a:hover { color:var(--text-1); background:rgba(255,255,255,0.04); }
.nav-right { display:flex; align-items:center; gap:10px; }
.nav-scan-btn { font-size:12px; padding:8px 16px; background:rgba(43,127,255,0.09); border:1px solid rgba(43,127,255,0.20)!important; color:var(--accent-light); }
.nav-scan-btn:hover { background:rgba(43,127,255,0.16); color:var(--text-1); }
.nav-hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.nav-hamburger span { width:22px; height:2px; background:var(--text-2); border-radius:2px; display:block; transition:all 0.2s; }
.mobile-menu {
  display:none; position:fixed; top:70px; left:0; right:0; z-index:199;
  background:rgba(2,12,27,0.97); border-bottom:1px solid var(--border);
  backdrop-filter:blur(22px); padding:20px 28px 28px;
  flex-direction:column; gap:4px;
}
.mobile-menu.open { display:flex; }
.mobile-menu a { font-size:15px; color:var(--text-2); text-decoration:none; padding:11px 0; border-bottom:1px solid var(--border); transition:color var(--t); }
.mobile-menu a:hover { color:var(--text-1); }
.mobile-ctas { display:flex; flex-direction:column; gap:10px; margin-top:16px; }

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
#hero { padding:152px 28px 100px; min-height:100vh; display:flex; align-items:center; }
.hero-layout {
  max-width:1140px; margin:0 auto; width:100%;
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.hero-title { font-family:'Cabinet Grotesk',sans-serif; font-size:clamp(48px,7vw,84px); line-height:1.00; letter-spacing:-3px; margin-bottom:20px; font-weight:600; }
.hero-title em { font-style:normal; font-weight:600; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-sub { font-size:17px; line-height:1.72; color:var(--text-2); max-width:500px; margin-bottom:14px; }
.hero-hook { font-size:14px; color:var(--accent-light); font-weight:500; margin-bottom:38px; padding-left:14px; border-left:2px solid rgba(43,127,255,0.35); line-height:1.6; }
.hero-ctas { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:28px; align-items:center; }
.hero-ctas .btn-secondary { font-size:13px; padding:11px 20px; opacity:0.8; }
.hero-ctas .btn-secondary:hover { opacity:1; }
.trust-row { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:7px; font-size:12px; color:var(--text-3); }
.trust-check { color:var(--mint); font-size:10px; font-weight:700; }

/* AI Mockup */
.hero-right { display:flex; justify-content:flex-end; }
.ai-mock {
  width:100%; max-width:500px;
  background:rgba(7,17,36,0.92); border:1px solid var(--border-md);
  border-radius:18px; overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,0.45),0 0 0 1px rgba(255,255,255,0.025);
  backdrop-filter:blur(20px);
}
.mock-titlebar { padding:13px 18px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:10px; background:rgba(0,0,0,0.15); }
.mock-dots { display:flex; gap:6px; }
.mock-dots span { width:10px;height:10px;border-radius:50%; }
.mock-dots span:nth-child(1){background:rgba(255,100,100,0.22);}
.mock-dots span:nth-child(2){background:rgba(255,190,60,0.18);}
.mock-dots span:nth-child(3){background:rgba(80,200,120,0.18);}
.mock-app { font-family:'JetBrains Mono',monospace; font-size:10px; color:var(--text-3); letter-spacing:1.5px; text-transform:uppercase; margin-left:4px; }
.mock-body { padding:22px 22px 26px; }
.mock-q { background:rgba(43,127,255,0.07); border:1px solid rgba(43,127,255,0.13); border-radius:10px; padding:13px 16px; margin-bottom:18px; display:flex; gap:10px; align-items:flex-start; }
.mock-q-icon { font-size:13px; flex-shrink:0; padding-top:2px; }
.mock-q-text { font-size:13px; color:var(--text-2); line-height:1.55; }
.mock-a { font-size:13px; color:var(--text-2); line-height:1.75; }
.mock-a strong { color:var(--text-1); }
.mock-mention { display:inline-block; background:rgba(43,127,255,0.13); border:1px solid rgba(43,127,255,0.28); color:var(--accent-light); padding:1px 8px; border-radius:5px; font-weight:600; font-size:12px; }
.mock-absent { color:var(--text-4); font-size:12px; font-style:normal; }
.mock-cursor { display:inline-block; width:2px; height:13px; background:var(--accent-light); margin-left:2px; vertical-align:middle; animation:cur 1s steps(1) infinite; }
@keyframes cur { 0%,100%{opacity:1} 50%{opacity:0} }
.mock-footer { padding:12px 18px; border-top:1px solid var(--border); display:flex; align-items:center; gap:8px; background:rgba(0,0,0,0.10); }
.mock-footer-input { flex:1; background:rgba(255,255,255,0.04); border:1px solid var(--border-md); border-radius:6px; padding:7px 12px; font-family:'Cabinet Grotesk',sans-serif; font-size:12px; color:var(--text-3); }
.mock-footer-btn { width:30px; height:30px; background:linear-gradient(90deg,#00c6ff 0%,#0072ff 100%); border:none; border-radius:6px; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:13px; }

/* ═══════════════════════════════════════
   PROBLEM
═══════════════════════════════════════ */
#problem { padding:90px 28px; background:rgba(5,13,28,0.6); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.problem-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.prob-card { background:var(--card-bg); border:1px solid var(--border); border-top:3px solid rgba(248,113,113,0.40); border-radius:var(--r); padding:26px 22px; backdrop-filter:blur(12px); transition:border-color var(--t),transform var(--t); }
.prob-card:hover { border-top-color:rgba(248,113,113,0.80); transform:translateY(-3px); }
.prob-icon { font-size:22px; margin-bottom:14px; }
.prob-title { font-size:15px; font-weight:600; letter-spacing:-0.1px; color:var(--text-1); margin-bottom:8px; line-height:1.4; }
.prob-body { font-size:13px; color:var(--text-2); line-height:1.65; }

/* ═══════════════════════════════════════
   GEO
═══════════════════════════════════════ */
#geo { padding:100px 28px; }
.geo-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.geo-not-seo { background:linear-gradient(135deg,rgba(8,22,52,0.95),rgba(10,20,46,0.85)); border:1px solid rgba(43,127,255,0.22); border-radius:var(--r-lg); padding:28px 28px 24px; margin-bottom:28px; position:relative; overflow:hidden; }
.geo-not-seo::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); }
.geo-not-seo-title { font-family:'Cabinet Grotesk',sans-serif; font-size:22px; letter-spacing:-0.8px; color:var(--text-1); margin-bottom:18px; font-weight:600; }
.geo-not-seo-title em { font-style:normal; font-weight:600; background:linear-gradient(90deg,#00c6ff 0%,#0072ff 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.geo-vs-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.geo-vs-item { border-radius:var(--r-sm); padding:14px 16px; border:1px solid var(--border-md); }
.geo-vs-item.old { background:rgba(248,113,113,0.04); border-color:rgba(248,113,113,0.14); }
.geo-vs-item.new { background:rgba(43,127,255,0.06); border-color:rgba(43,127,255,0.20); }
.geo-vs-label { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; margin-bottom:7px; display:block; }
.geo-vs-item.old .geo-vs-label { color:rgba(248,113,113,0.7); }
.geo-vs-item.new .geo-vs-label { color:var(--accent-light); }
.geo-vs-value { font-size:15px; font-weight:600; color:var(--text-1); margin-bottom:4px; }
.geo-vs-sub { font-size:12px; color:var(--text-2); line-height:1.5; }
.geo-body-text { font-size:15px; line-height:1.72; color:var(--text-2); margin-bottom:20px; }
.geo-cd-row { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.cd-card { border-radius:var(--r-sm); padding:13px 15px; border:1px solid var(--border-md); }
.cd-card.old { background:rgba(248,113,113,0.03); border-color:rgba(248,113,113,0.12); }
.cd-card.new { background:rgba(43,127,255,0.05); border-color:rgba(43,127,255,0.16); }
.cd-label { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; margin-bottom:8px; }
.cd-card.old .cd-label { color:rgba(248,113,113,0.65); }
.cd-card.new .cd-label { color:var(--accent-light); }
.cd-items { display:flex; flex-direction:column; gap:5px; }
.cd-item { font-size:12px; color:var(--text-2); display:flex; gap:7px; align-items:flex-start; }
.cd-card.old .cd-item::before { content:'✕'; color:var(--rose); font-size:10px; flex-shrink:0; margin-top:2px; }
.cd-card.new .cd-item::before { content:'✓'; color:var(--mint); font-size:10px; flex-shrink:0; margin-top:2px; }
.geo-visual { background:var(--card-bg); border:1px solid var(--border-md); border-radius:var(--r-lg); padding:32px; backdrop-filter:blur(16px); position:relative; }
.geo-visual::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); border-radius:var(--r-lg) var(--r-lg) 0 0; }
.geo-stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:24px; }
.geo-stat { background:rgba(255,255,255,0.02); border:1px solid var(--border); border-radius:var(--r-sm); padding:18px; text-align:center; }
.geo-stat-num { font-family:'Cabinet Grotesk',sans-serif; font-size:34px; color:var(--accent-light); line-height:1; display:block; margin-bottom:5px; font-weight:600; letter-spacing:-1px; }
.geo-stat-label { font-size:11px; color:var(--text-3); line-height:1.4; }
.geo-insight { background:rgba(43,127,255,0.06); border:1px solid rgba(43,127,255,0.15); border-radius:var(--r-sm); padding:16px; font-size:13px; color:var(--text-2); line-height:1.65; }
.geo-insight strong { color:var(--text-1); }

/* ═══════════════════════════════════════
   HOW
═══════════════════════════════════════ */
#how { padding:100px 28px; background:rgba(4,11,24,0.55); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.step-col { padding:0 22px; position:relative; z-index:1; }
.step-col:not(:last-child)::after { content:'→'; position:absolute; right:-10px; top:24px; font-size:20px; color:var(--text-4); }
.step-num-wrap { display:flex; align-items:center; gap:14px; margin-bottom:24px; }
.step-circle { width:52px; height:52px; border-radius:50%; background:rgba(43,127,255,0.10); border:1px solid rgba(43,127,255,0.22); display:flex; align-items:center; justify-content:center; font-family:'JetBrains Mono',monospace; font-size:14px; color:var(--accent-light); flex-shrink:0; }
.step-label { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); }
.step-title { font-size:20px; font-weight:600; letter-spacing:-0.3px; color:var(--text-1); margin-bottom:12px; }
.step-body { font-size:14px; color:var(--text-2); line-height:1.70; margin-bottom:18px; }
.step-tags { display:flex; flex-wrap:wrap; gap:6px; }
.step-tag { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:0.5px; background:rgba(43,127,255,0.08); border:1px solid rgba(43,127,255,0.15); color:var(--accent-light); padding:3px 9px; border-radius:4px; }

/* ═══════════════════════════════════════
   OFFER
═══════════════════════════════════════ */
#offer { padding:100px 28px; }
.offer-prog-track { display:inline-flex; align-items:center; gap:0; background:rgba(255,255,255,0.02); border:1px solid var(--border-md); border-radius:30px; padding:6px 8px; font-size:12px; color:var(--text-3); }
.prog-step { padding:5px 14px; border-radius:20px; }
.prog-step.active { background:rgba(43,127,255,0.12); color:var(--accent-light); border:1px solid rgba(43,127,255,0.22); }
.prog-arrow { color:var(--text-4); padding:0 4px; font-size:11px; }
.offer-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:start; }
.offer-card { background:var(--card-bg); border:1px solid var(--border-md); border-radius:var(--r-lg); padding:32px 28px; backdrop-filter:blur(16px); transition:all var(--t); position:relative; overflow:hidden; }
.offer-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--border-lg),transparent); }
.offer-card:hover { transform:translateY(-5px); border-color:var(--border-lg); }
.offer-card.featured { border-color:rgba(43,127,255,0.32); background:linear-gradient(160deg,rgba(9,22,52,0.96),rgba(10,18,42,0.92)); box-shadow:0 0 60px rgba(43,127,255,0.12),0 20px 60px rgba(0,0,0,0.3); }
.offer-card.featured::before { background:linear-gradient(90deg,#00c6ff 0%,#0072ff 100%); }
.offer-badge { position:absolute; top:18px; right:18px; font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:1px; text-transform:uppercase; background:rgba(43,127,255,0.16); border:1px solid rgba(43,127,255,0.30); color:var(--accent-light); padding:4px 10px; border-radius:4px; }
.offer-icon { font-size:26px; margin-bottom:14px; }
.offer-num { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); margin-bottom:8px; }
.offer-title { font-size:22px; font-weight:600; letter-spacing:-0.4px; color:var(--text-1); margin-bottom:8px; }
.offer-price { font-family:'Cabinet Grotesk',sans-serif; font-size:28px; color:var(--accent-light); margin-bottom:4px; font-weight:600; letter-spacing:-0.8px; }
.offer-price-note { font-size:12px; color:var(--text-3); margin-bottom:6px; }
.offer-for { font-size:13px; color:var(--text-2); font-style:normal; margin-bottom:18px; padding:8px 12px; background:rgba(255,255,255,0.02); border-radius:var(--r-sm); border-left:2px solid rgba(43,127,255,0.25); line-height:1.5; }
.offer-divider { height:1px; background:var(--border); margin-bottom:18px; }
.offer-desc { font-size:14px; color:var(--text-2); line-height:1.65; margin-bottom:18px; }
.offer-features { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:26px; }
.offer-features li { font-size:13px; color:var(--text-2); display:flex; align-items:flex-start; gap:9px; line-height:1.5; }
.offer-features li::before { content:'✓'; color:var(--mint); font-size:11px; font-weight:700; flex-shrink:0; margin-top:2px; }
.offer-cta { width:100%; }

/* ═══════════════════════════════════════
   FOR WHOM
═══════════════════════════════════════ */
#forwhom { padding:100px 28px; background:rgba(4,11,24,0.55); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.forwhom-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.forwhom-card { background:var(--card-bg); border:1px solid var(--border); border-radius:var(--r); padding:28px; display:flex; gap:20px; align-items:flex-start; backdrop-filter:blur(12px); transition:all var(--t); }
.forwhom-card:hover { border-color:var(--border-lg); transform:translateY(-2px); }
.forwhom-icon-wrap { width:48px; height:48px; flex-shrink:0; border-radius:12px; background:rgba(43,127,255,0.10); border:1px solid rgba(43,127,255,0.18); display:flex; align-items:center; justify-content:center; font-size:20px; }
.forwhom-title { font-size:16px; font-weight:600; letter-spacing:-0.2px; color:var(--text-1); margin-bottom:7px; }
.forwhom-text { font-size:13px; color:var(--text-2); line-height:1.65; }

/* ═══════════════════════════════════════
   CASES
═══════════════════════════════════════ */
#cases { padding:100px 28px; }
.cases-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:48px; flex-wrap:wrap; gap:20px; }
.cases-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.case-card { background:var(--card-bg); border:1px solid var(--border-md); border-radius:var(--r); overflow:hidden; backdrop-filter:blur(12px); transition:all var(--t); display:flex; flex-direction:column; }
.case-card:hover { transform:translateY(-4px); border-color:var(--border-lg); }
.case-top { padding:24px 24px 20px; border-bottom:1px solid var(--border); }
.case-logo-area { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.case-logo-mock { width:40px; height:40px; border-radius:10px; background:linear-gradient(135deg,var(--navy-700),var(--navy-800)); border:1px solid var(--border-md); display:flex; align-items:center; justify-content:center; font-size:16px; }
.case-client { font-size:15px; font-weight:600; letter-spacing:-0.2px; color:var(--text-1); }
.case-sector { font-size:11px; color:var(--text-3); }
.case-situation { font-size:13px; color:var(--text-2); line-height:1.65; }
.case-body { padding:18px 24px; display:flex; flex-direction:column; gap:12px; flex:1; }
.case-row { display:flex; gap:10px; align-items:flex-start; }
.case-row-label { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-3); flex-shrink:0; padding-top:2px; min-width:72px; }
.case-row-text { font-size:13px; color:var(--text-2); line-height:1.55; }
.case-result { margin:0 20px 20px; background:rgba(52,211,153,0.07); border:1px solid rgba(52,211,153,0.18); border-left:3px solid rgba(52,211,153,0.60); border-radius:0 var(--r-sm) var(--r-sm) 0; padding:12px 14px; font-size:13px; color:var(--mint); font-weight:500; display:flex; align-items:flex-start; gap:8px; line-height:1.5; }

/* ═══════════════════════════════════════
   AI SCAN SECTION
═══════════════════════════════════════ */
#scan { padding:100px 28px; background:rgba(4,11,24,0.55); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.scan-card {
  max-width:760px; margin:0 auto;
  background:linear-gradient(160deg,rgba(8,20,48,0.96),rgba(10,18,42,0.90));
  border:1px solid rgba(43,127,255,0.22); border-radius:var(--r-lg);
  padding:48px; position:relative; overflow:hidden;
}
.scan-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); }
.scan-form { display:flex; flex-direction:column; gap:18px; margin:32px 0 0; }
.scan-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.scan-field { display:flex; flex-direction:column; gap:7px; }
.scan-field label { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); }
.scan-input, .scan-select {
  background:rgba(255,255,255,0.04); border:1px solid var(--border-md);
  border-radius:var(--r-sm); color:var(--text-1);
  font-family:'Cabinet Grotesk',sans-serif; font-size:14px; padding:12px 16px;
  outline:none; transition:border-color var(--t),box-shadow var(--t);
  width:100%; -webkit-appearance:none;
}
.scan-input::placeholder { color:var(--text-3); }
.scan-input:focus, .scan-select:focus { border-color:rgba(43,127,255,0.50); box-shadow:0 0 0 3px rgba(43,127,255,0.08); background:rgba(255,255,255,0.06); }
.scan-select option { background:#071426; }
.scan-btn { background:linear-gradient(90deg,#00c6ff 0%,#0072ff 100%); border:none; border-radius:var(--r-sm); color:#fff; font-family:'Cabinet Grotesk',sans-serif; font-size:15px; font-weight:600; padding:16px 28px; cursor:pointer; transition:all var(--t); box-shadow:0 4px 22px rgba(43,127,255,0.30); display:flex; align-items:center; justify-content:center; gap:10px; width:100%; position:relative; overflow:hidden; }
.scan-btn::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,0.10),transparent); }
.scan-btn:hover { transform:translateY(-2px); box-shadow:0 8px 36px rgba(43,127,255,0.50); }
.scan-btn:disabled { opacity:0.6; cursor:not-allowed; transform:none; }

/* Scan results */
.scan-results { margin-top:32px; display:none; }
.scan-results.visible { display:block; animation:fadeUp 0.5s ease; }
@keyframes fadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }
.scan-score-row { display:flex; align-items:center; gap:24px; background:rgba(7,17,40,0.8); border:1px solid var(--border-md); border-radius:var(--r); padding:22px 24px; margin-bottom:16px; }
.score-ring-wrap { position:relative; width:80px; height:80px; flex-shrink:0; }
.score-ring-wrap svg { transform:rotate(-90deg); }
.score-ring-text { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; font-family:'Cabinet Grotesk',sans-serif; font-size:24px; line-height:1; }
.score-ring-text span { font-size:11px; font-family:'Cabinet Grotesk',sans-serif; color:var(--text-3); font-weight:400; }
.score-details { flex:1; }
.score-label { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); margin-bottom:5px; }
.score-verdict { font-size:18px; font-weight:600; color:var(--text-1); margin-bottom:5px; }
.score-desc { font-size:13px; color:var(--text-2); line-height:1.55; }
.score-pill { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:600; padding:3px 10px; border-radius:20px; margin-top:8px; }
.pill-low { background:rgba(248,113,113,0.10); color:var(--rose); border:1px solid rgba(248,113,113,0.20); }
.pill-mid { background:rgba(245,158,11,0.10); color:var(--amber); border:1px solid rgba(245,158,11,0.20); }
.pill-high { background:rgba(52,211,153,0.10); color:var(--mint); border:1px solid rgba(52,211,153,0.20); }

.scan-q-list { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.scan-q-item { background:rgba(255,255,255,0.02); border:1px solid var(--border); border-radius:var(--r-sm); padding:13px 16px; display:flex; align-items:flex-start; gap:12px; }
.sq-icon { font-size:13px; flex-shrink:0; margin-top:1px; }
.sq-text { font-size:13px; color:var(--text-2); line-height:1.5; flex:1; }
.sq-status { flex-shrink:0; padding:3px 9px; border-radius:20px; font-size:11px; font-weight:600; }
.st-no { background:rgba(248,113,113,0.10); color:var(--rose); border:1px solid rgba(248,113,113,0.15); }
.st-yes { background:rgba(52,211,153,0.10); color:var(--mint); border:1px solid rgba(52,211,153,0.15); }
.st-part { background:rgba(245,158,11,0.10); color:var(--amber); border:1px solid rgba(245,158,11,0.15); }

.scan-insights { display:flex; flex-direction:column; gap:10px; }
.scan-insight { background:rgba(255,255,255,0.02); border:1px solid var(--border); border-left:3px solid transparent; border-radius:0 var(--r-sm) var(--r-sm) 0; padding:14px 16px; }
.scan-insight.info { border-left-color:var(--accent); }
.scan-insight.warn { border-left-color:var(--amber); }
.scan-insight.opp { border-left-color:var(--mint); background:rgba(52,211,153,0.03); }
.insight-tag { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:5px; }
.insight-tag.t-info { color:var(--accent-light); }
.insight-tag.t-warn { color:var(--amber); }
.insight-tag.t-opp { color:var(--mint); }
.insight-text { font-size:13px; color:var(--text-2); line-height:1.6; }
.insight-text strong { color:var(--text-1); }
.scan-cta-row { display:flex; gap:12px; margin-top:22px; flex-wrap:wrap; }

/* Blur overlay inzichten */
.scan-inzicht-blur-wrap { position:relative; }
.scan-inzicht-blur-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(8,17,40,0.82),rgba(10,20,50,0.90)); border:1px solid rgba(43,127,255,0.20); border-radius:0 var(--r-sm) var(--r-sm) 0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; text-align:center; padding:12px; }
.blur-unlock-tekst { font-size:13px; font-weight:600; color:var(--text-1); letter-spacing:-0.2px; }
.blur-pijl { font-size:11px; color:var(--accent-light); font-family:'JetBrains Mono',monospace; }

/* E-mail kaart in scan resultaten */
.scan-email-kaart { margin-top:20px; background:linear-gradient(160deg,rgba(0,114,255,0.07),rgba(0,198,255,0.04)); border:1px solid rgba(43,127,255,0.28); border-radius:var(--r-sm); padding:22px 20px; }
.scan-email-titel { font-size:14px; font-weight:600; color:var(--text-1); margin-bottom:14px; letter-spacing:-0.2px; }
.scan-email-rij { display:flex; gap:10px; }
.scan-email-rij .scan-input { flex:1; }
.scan-email-btn { background:linear-gradient(90deg,#00c6ff,#0072ff); border:none; border-radius:var(--r-sm); color:#fff; font-family:'Cabinet Grotesk',sans-serif; font-size:14px; font-weight:600; padding:12px 20px; cursor:pointer; white-space:nowrap; transition:all .2s; box-shadow:0 4px 16px rgba(0,114,255,0.25); }
.scan-email-btn:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(0,114,255,0.40); }
.scan-email-btn:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.scan-email-feedback { margin-top:10px; font-size:12px; font-family:'JetBrains Mono',monospace; }
.scan-email-feedback.ok { color:var(--mint); }
.scan-email-feedback.err { color:var(--rose); }

/* Spinner rings */
.scan-loading-header { display:flex; align-items:center; gap:20px; margin-bottom:28px; }
.scan-loading-spinner { position:relative; width:52px; height:52px; flex-shrink:0; }
.spinner-ring { position:absolute; inset:0; border-radius:50%; border:2px solid rgba(43,127,255,0.12); border-top-color:var(--accent); animation:spin 1s linear infinite; }
.spinner-ring-2 { position:absolute; top:8px; left:8px; right:8px; bottom:8px; border-radius:50%; border:2px solid rgba(6,182,212,0.10); border-bottom-color:var(--teal); animation:spin 1.6s linear infinite reverse; }
.spinner-dot { position:absolute; top:50%; left:50%; width:6px; height:6px; background:var(--accent); border-radius:50%; transform:translate(-50%,-50%); box-shadow:0 0 8px var(--accent); }
.scan-loading-titel { font-size:17px; font-weight:600; color:var(--text-1); margin-bottom:4px; }
.scan-loading-domain { font-size:13px; color:var(--text-3); font-family:'JetBrains Mono',monospace; }

/* Loading steps */
.scan-loading { display:none; margin-top:24px; }
.scan-loading.visible { display:block; animation:fadeUp 0.4s ease; }
.loading-steps { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.l-step { display:flex; align-items:center; gap:12px; padding:11px 14px; border-radius:var(--r-sm); border:1px solid transparent; font-size:13px; color:var(--text-3); transition:all 0.3s; }
.l-step.active { background:rgba(43,127,255,0.07); border-color:rgba(43,127,255,0.18); color:var(--text-1); }
.l-step.done { color:var(--mint); }
.l-icon { width:20px; height:20px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.l-spinner { width:14px; height:14px; border-radius:50%; border:2px solid rgba(43,127,255,0.2); border-top-color:var(--accent); animation:spin 0.8s linear infinite; }
.l-check { font-size:13px; color:var(--mint); }
.l-idle { width:5px; height:5px; border-radius:50%; background:var(--text-4); }
@keyframes spin { to{transform:rotate(360deg)} }
.progress-bar-wrap { height:3px; background:rgba(43,127,255,0.10); border-radius:2px; overflow:hidden; }
.progress-bar { height:100%; background:var(--grad); border-radius:2px; width:0%; transition:width 0.6s ease; box-shadow:0 0 8px rgba(43,127,255,0.5); }
.progress-pct { font-family:'JetBrains Mono',monospace; font-size:10px; color:var(--text-3); text-align:right; margin-top:5px; }

/* ═══════════════════════════════════════
   KENNISBANK PREVIEW
═══════════════════════════════════════ */
#kennisbank { padding:100px 28px; }
.kb-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.kb-card {
  background:var(--card-bg); border:1px solid var(--border-md);
  border-radius:var(--r); overflow:hidden;
  backdrop-filter:blur(12px); transition:all var(--t);
  text-decoration:none; display:flex; flex-direction:column;
}
.kb-card:hover { transform:translateY(-4px); border-color:var(--border-lg); }
.kb-card-top { padding:24px 24px 0; }
.kb-tag { display:inline-block; font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; background:rgba(43,127,255,0.10); border:1px solid rgba(43,127,255,0.18); color:var(--accent-light); padding:3px 9px; border-radius:4px; margin-bottom:14px; }
.kb-title { font-size:16px; font-weight:600; letter-spacing:-0.2px; color:var(--text-1); line-height:1.4; margin-bottom:10px; }
.kb-excerpt { font-size:13px; color:var(--text-2); line-height:1.65; padding-bottom:20px; }
.kb-footer { margin-top:auto; padding:14px 24px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.kb-meta { font-size:11px; color:var(--text-3); }
.kb-arrow { font-size:14px; color:var(--accent-light); transition:transform var(--t); }
.kb-card:hover .kb-arrow { transform:translateX(4px); }

/* ═══════════════════════════════════════
   FAQ
═══════════════════════════════════════ */
#faq { padding:100px 28px; background:rgba(4,11,24,0.55); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.faq-list { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:10px; }
.faq-item { background:var(--card-bg); border:1px solid var(--border-md); border-radius:var(--r); overflow:hidden; backdrop-filter:blur(12px); transition:border-color var(--t); }
.faq-item.open { border-color:rgba(43,127,255,0.25); }
.faq-q {
  padding:20px 24px; display:flex; align-items:center; justify-content:space-between;
  cursor:pointer; gap:16px;
  font-size:15px; font-weight:600; color:var(--text-1); line-height:1.4;
  transition:color var(--t); user-select:none;
}
.faq-q:hover { color:var(--accent-light); }
.faq-icon { width:22px; height:22px; border-radius:50%; border:1px solid var(--border-md); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:14px; color:var(--text-2); transition:all var(--t); }
.faq-item.open .faq-icon { transform:rotate(45deg); border-color:rgba(43,127,255,0.35); color:var(--accent-light); }
.faq-a { max-height:0; overflow:hidden; transition:max-height 0.35s ease, padding 0.35s ease; }
.faq-item.open .faq-a { max-height:300px; }
.faq-a-inner { padding:0 24px 20px; font-size:14px; color:var(--text-2); line-height:1.75; border-top:1px solid var(--border); padding-top:16px; }
.faq-a-inner strong { color:var(--text-1); }
.faq-a-inner a { color:var(--accent-light); text-decoration:none; }
.faq-a-inner a:hover { text-decoration:underline; }

/* ═══════════════════════════════════════
   ABOUT
═══════════════════════════════════════ */
#about { padding:100px 28px; }
.about-layout { display:grid; grid-template-columns:320px 1fr; gap:60px; align-items:center; max-width:900px; margin:0 auto; }
.about-portrait { width:100%; aspect-ratio:3/4; border-radius:var(--r-lg); border:1px solid var(--border-md); overflow:hidden; }
.about-portrait img { width:100%; height:100%; object-fit:cover; object-position:center top; display:block; }
.about-tag { font-family:'JetBrains Mono',monospace; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--accent-light); margin-bottom:18px; display:block; }
.about-name { font-family:'Cabinet Grotesk',sans-serif; font-size:32px; letter-spacing:-1.5px; font-weight:600; margin-bottom:5px; }
.about-role { font-size:14px; color:var(--text-3); margin-bottom:14px; }
.about-focus { font-size:16px; font-weight:500; color:var(--text-1); background:rgba(43,127,255,0.06); border:1px solid rgba(43,127,255,0.16); border-left:3px solid rgba(43,127,255,0.50); border-radius:0 var(--r-sm) var(--r-sm) 0; padding:13px 16px; margin-bottom:22px; line-height:1.55; }
.about-bio { font-size:15px; color:var(--text-2); line-height:1.75; margin-bottom:22px; }
.about-quals { display:flex; flex-direction:column; gap:8px; }
.about-qual { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--text-2); }
.about-qual::before { content:'◎'; color:var(--accent-light); font-size:11px; flex-shrink:0; }

/* ═══════════════════════════════════════
   FINAL CTA
═══════════════════════════════════════ */
#finalcta { padding:120px 28px; }
.finalcta-card { max-width:860px; margin:0 auto; background:linear-gradient(160deg,rgba(9,22,50,0.96),rgba(6,15,35,0.90)); border:1px solid rgba(43,127,255,0.22); border-radius:24px; padding:72px 60px; text-align:center; position:relative; overflow:hidden; box-shadow:0 0 100px rgba(43,127,255,0.10); }
.finalcta-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,#00c6ff 0%,#0072ff 100%); }
.finalcta-card::after { content:''; position:absolute; bottom:-100px; left:50%; transform:translateX(-50%); width:500px; height:300px; background:radial-gradient(ellipse,rgba(43,127,255,0.13) 0%,transparent 65%); pointer-events:none; animation:pulse-glow 6s ease-in-out infinite; }
@keyframes pulse-glow { 0%,100%{opacity:0.7;transform:translateX(-50%) scale(1)} 50%{opacity:1;transform:translateX(-50%) scale(1.1)} }
.finalcta-inner { position:relative; z-index:1; }
.finalcta-urgency { font-size:14px; color:var(--amber); background:rgba(245,158,11,0.07); border:1px solid rgba(245,158,11,0.18); padding:10px 20px; border-radius:20px; margin-bottom:20px; display:inline-block; font-style:normal; }
.finalcta-sub { font-size:17px; color:var(--text-2); line-height:1.70; margin-bottom:40px; max-width:580px; margin-left:auto; margin-right:auto; }
.finalcta-ctas { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.finalcta-note { margin-top:20px; font-size:12px; color:var(--text-3); }

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
#footer { border-top:1px solid var(--border); padding:56px 28px 32px; position:relative; z-index:1; }
.footer-top { max-width:1140px; margin:0 auto; display:grid; grid-template-columns:260px 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-logo { display:flex; align-items:center; margin-bottom:14px; text-decoration:none; }
.footer-tagline { font-size:13px; color:var(--text-3); line-height:1.65; margin-bottom:20px; }
.footer-contact { font-size:12px; color:var(--text-3); line-height:1.8; }
.footer-contact a { color:var(--accent-light); text-decoration:none; }
.footer-col-title { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--text-3); margin-bottom:16px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-links a { font-size:13px; color:var(--text-2); text-decoration:none; transition:color var(--t); }
.footer-links a:hover { color:var(--text-1); }
.footer-bottom { max-width:1140px; margin:0 auto; padding-top:24px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:12px; color:var(--text-3); }
.footer-socials { display:flex; gap:14px; }
.footer-social { width:32px; height:32px; border-radius:8px; background:rgba(255,255,255,0.04); border:1px solid var(--border-md); display:flex; align-items:center; justify-content:center; font-size:14px; text-decoration:none; color:var(--text-2); transition:all var(--t); }
.footer-social:hover { background:rgba(43,127,255,0.10); border-color:rgba(43,127,255,0.25); }

/* ═══════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(20px); transition:opacity 0.60s ease, transform 0.60s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.d1{transition-delay:0.08s} .d2{transition-delay:0.16s} .d3{transition-delay:0.24s} .d4{transition-delay:0.32s}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:1024px){
  .hero-layout{grid-template-columns:1fr;gap:48px}
  .hero-right{justify-content:center}
  .ai-mock{max-width:100%}
  .geo-layout{grid-template-columns:1fr;gap:48px}
  .problem-grid{grid-template-columns:repeat(2,1fr)}
  .offer-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .cases-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .kb-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand-col{grid-column:1 / -1}
  .steps-grid{grid-template-columns:1fr;gap:32px}
  .step-col::after{display:none}
  .scan-row{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-right .btn-secondary{display:none}
  .nav-hamburger{display:flex}
  #hero{padding:130px 20px 70px}
  section{padding-left:20px;padding-right:20px}
  .hero-title{letter-spacing:-2px;font-weight:600}
  .problem-grid{grid-template-columns:1fr}
  .forwhom-grid{grid-template-columns:1fr}
  .about-layout{grid-template-columns:1fr}
  .about-portrait{aspect-ratio:4/3}
  .cases-header{flex-direction:column;align-items:flex-start}
  .finalcta-card{padding:40px 24px}
  .footer-top{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column;align-items:flex-start}
  .hero-ctas .btn{width:100%;justify-content:center}
  .geo-vs-row{grid-template-columns:1fr}
  .geo-cd-row{grid-template-columns:1fr}
  .scan-cta-row{flex-direction:column}
  .scan-cta-row .btn{width:100%;justify-content:center}
  .finalcta-ctas{flex-direction:column;align-items:center}
  .finalcta-ctas .btn{width:100%;max-width:340px}
}
@media(max-width:480px){
  .scan-card{padding:28px 20px}
  .scan-score-row{flex-direction:column;align-items:flex-start;gap:16px}
  .hero-title{font-size:42px}
}

/* ═══════════════════════════════════════
   MOCK TABS
═══════════════════════════════════════ */
.mock-tabs {
  display:flex; overflow-x:auto; border-bottom:1px solid var(--border);
  scrollbar-width:none; background:rgba(0,0,0,0.12);
}
.mock-tabs::-webkit-scrollbar { display:none; }
.mock-tab {
  background:none; border:none; cursor:pointer;
  font-family:'Cabinet Grotesk',sans-serif;
  font-size:11px; font-weight:500; color:var(--text-3);
  padding:9px 14px; border-bottom:2px solid transparent;
  transition:all .2s; white-space:nowrap; flex-shrink:0;
}
.mock-tab:hover { color:var(--text-2); }
.mock-tab.active { color:var(--accent-light); border-bottom-color:var(--accent-light); }

/* ═══════════════════════════════════════
   MOCK VRAAG — lichtgrijs, geen icoon
═══════════════════════════════════════ */
.mock-body .mock-q {
  background:rgba(43,127,255,0.06);
  border:1px solid rgba(43,127,255,0.10);
  border-radius:8px; padding:11px 14px; margin-bottom:14px;
}
.mock-body .mock-q .mock-q-text {
  font-size:12px;
  color:var(--text-3);
  line-height:1.5;
  font-weight:400;
  font-style:italic;
  display:block;
}

/* ═══════════════════════════════════════
   MOCK RESULTATEN
═══════════════════════════════════════ */
.mock-resultaat { display:flex; flex-direction:column; gap:7px; margin-bottom:12px; }
.mock-res-label {
  font-family:'JetBrains Mono',monospace;
  font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:var(--text-4); margin-bottom:2px;
}
.mock-res-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:8px; border:1px solid var(--border);
}
.mock-res-yes { border-color:rgba(52,211,153,0.20); background:rgba(52,211,153,0.04); }
.mock-res-no  { border-color:rgba(248,113,113,0.15); background:rgba(248,113,113,0.03); }
.mock-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.mock-dot-yes { background:var(--mint); }
.mock-dot-no  { background:var(--rose); opacity:.6; }
.mock-res-name { font-size:13px; font-weight:600; color:var(--text-1); flex:1; }
.mock-res-status { font-size:11px; font-weight:500; }
.mock-status-yes { color:var(--mint); }
.mock-status-no  { color:var(--rose); opacity:.8; }
.mock-conclusion {
  padding:11px 14px; background:rgba(0,114,255,0.08);
  border:1px solid rgba(0,114,255,0.18); border-radius:8px;
  font-size:12px; color:var(--accent-light); font-weight:500; line-height:1.55;
}

/* ═══════════════════════════════════════
   MAC DOTS — elk apart oplichten
═══════════════════════════════════════ */
.mock-dots { display:flex; gap:6px; }
.dot-r, .dot-y, .dot-g {
  width:10px; height:10px; border-radius:50%;
  display:inline-block;
  transition:background .2s, transform .15s;
  cursor:default;
}
.dot-r { background:rgba(255,95,87,0.28); }
.dot-y { background:rgba(255,189,46,0.28); }
.dot-g { background:rgba(39,201,63,0.28); }
.dot-r:hover { background:#ff5f57; transform:scale(1.25); }
.dot-y:hover { background:#ffbd2e; transform:scale(1.25); }
.dot-g:hover { background:#27c93f; transform:scale(1.25); }

/* ═══════════════════════════════════════
   MOCK FADE
═══════════════════════════════════════ */
.mock-fade { animation:mockFade .3s ease; }
@keyframes mockFade { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════
   CASES LOGO BALK
═══════════════════════════════════════ */
.cases-logos { text-align:center; margin-bottom:40px; }
.cases-logo-row-label {
  font-family:'JetBrains Mono',monospace;
  font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:var(--text-4); margin-bottom:16px;
}
.cases-logo-row {
  display:flex; align-items:center; justify-content:center;
  gap:28px; flex-wrap:wrap;
}
.cases-logo-item {
  height:32px; opacity:.45;
  filter:grayscale(1) brightness(2);
  transition:opacity .2s, filter .2s; display:flex; align-items:center;
}
.cases-logo-item:hover { opacity:.85; filter:grayscale(0) brightness(1.1); }
.cases-logo-item img { height:100%; width:auto; max-width:110px; object-fit:contain; }
.cases-logo-dark  { background:#0a1428; padding:5px; border-radius:4px; height:40px; }
.cases-logo-light { background:#f0f0f0; padding:5px; border-radius:4px; height:40px; }

/* ═══════════════════════════════════════
   CASE BADGE
═══════════════════════════════════════ */
.case-badge {
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:9px; letter-spacing:1.5px; text-transform:uppercase;
  background:rgba(43,127,255,0.10); border:1px solid rgba(43,127,255,0.20);
  color:var(--accent-light); padding:3px 9px; border-radius:4px; margin-bottom:10px;
}

/* ═══════════════════════════════════════
   OFFER LI HIGHLIGHT (gratis maand)
═══════════════════════════════════════ */
.offer-li-highlight {
  color:var(--mint) !important;
  font-weight:600 !important;
}
.offer-li-highlight::before {
  content:'✓';
  color:var(--mint) !important;
}

/* ═══════════════════════════════════════
   HERO MOBIEL FIX
═══════════════════════════════════════ */
@media(max-width:768px) {
  .hero-sub,
  .hero-hook,
  .hero-title,
  .display-title {
    max-width:100%;
    word-break:break-word;
    overflow-wrap:break-word;
  }
  .hero-layout {
    grid-template-columns:1fr;
    gap:32px;
    overflow:hidden;
  }
  .hero-left {
    width:100%;
    max-width:100%;
    overflow:hidden;
  }
  .hero-right {
    width:100%;
    max-width:100%;
    overflow:hidden;
    justify-content:center;
  }
  .ai-mock {
    width:100%;
    max-width:100%;
  }
  .hero-ctas {
    width:100%;
  }
  .hero-ctas .btn {
    width:100%;
    max-width:100%;
    white-space:normal;
    text-align:center;
    box-sizing:border-box;
  }
  #hero {
    overflow:hidden;
  }
  .hero-hook {
    font-size:13px;
  }
}
