/* ══════════════════════════════════════════
   OVER ONS — page styles
   Prefix: oo-
═══════════════════════════════════════════ */

/* ── SCROLL ANIMATIONS ── */
[data-animate] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}
[data-animate].is-visible     { opacity: 1; transform: translateY(0); }
[data-animate][data-delay="1"] { transition-delay: 0.08s; }
[data-animate][data-delay="2"] { transition-delay: 0.18s; }
[data-animate][data-delay="3"] { transition-delay: 0.28s; }
[data-animate][data-delay="4"] { transition-delay: 0.38s; }
[data-animate][data-delay="5"] { transition-delay: 0.48s; }


/* ── SECTION BASE ── */
.oo-section {
  padding: clamp(4rem, 8vw, 7rem) 0;
}
.oo-section--tinted {
  background: oklch(98% 0.008 265);
}
.oo-section-head {
  max-width: 600px;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.oo-section-head .section-sub { max-width: 520px; }


/* ══════════════════════════════════════════
   HERO
═══════════════════════════════════════════ */
.oo-hero {
  background: linear-gradient(160deg, oklch(26% 0.17 272) 0%, oklch(18% 0.14 282) 60%, oklch(22% 0.10 260) 100%);
  position: relative;
  overflow: hidden;
  padding-bottom: 0;
}

.oo-hero-glow {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.oo-hero-glow.g1 {
  top: -120px; right: -80px;
  width: 520px; height: 520px;
  background: radial-gradient(circle, oklch(100% 0 0 / 0.055) 0%, transparent 65%);
}
.oo-hero-glow.g2 {
  bottom: 60px; left: -100px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, oklch(62% 0.18 28 / 0.12) 0%, transparent 65%);
}

.oo-hero-inner {
  padding-top: clamp(5rem, 10vw, 8rem);
  padding-bottom: clamp(3rem, 6vw, 5rem);
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 0;
}

/* Badge */
.oo-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: oklch(100% 0 0 / 0.1);
  border: 1px solid oklch(100% 0 0 / 0.14);
  color: oklch(80% 0.08 265);
  padding: 6px 14px 6px 9px;
  border-radius: 100px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 0.78rem; font-weight: 600;
  margin-bottom: 1.5rem;
  backdrop-filter: blur(8px);
}
.oo-badge-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: oklch(72% 0.18 28);
  box-shadow: 0 0 8px oklch(72% 0.18 28 / 0.6);
  animation: pulse 2.5s ease-in-out infinite;
}

/* H1 */
.oo-hero h1 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800;
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  line-height: 1.1; letter-spacing: -0.04em;
  color: #fff; text-wrap: balance;
  margin: 0 0 1.4rem;
}
.oo-hero h1 em {
  font-style: normal;
  background: linear-gradient(135deg, oklch(78% 0.16 55), oklch(72% 0.20 28));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

.oo-hero-sub {
  font-size: clamp(1rem, 1.5vw, 1.1rem); line-height: 1.7;
  color: oklch(74% 0.05 265);
  max-width: 520px;
  margin: 0 0 2rem;
}

/* Buttons */
.oo-hero-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }

.oo-btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #fff;
  padding: 13px 24px; border-radius: 100px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700; font-size: 0.95rem;
  text-decoration: none;
  box-shadow: 0 4px 20px oklch(62% 0.18 28 / 0.36);
  transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
}
.oo-btn-primary:hover {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px oklch(62% 0.18 28 / 0.46);
}

.oo-btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; color: oklch(80% 0.06 265);
  padding: 13px 20px; border-radius: 100px;
  border: 1.5px solid oklch(100% 0 0 / 0.18);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600; font-size: 0.95rem;
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.oo-btn-ghost:hover {
  border-color: oklch(100% 0 0 / 0.38);
  background: oklch(100% 0 0 / 0.06);
  color: #fff;
}

/* Trust band */
.oo-trust-band {
  position: relative; z-index: 1;
  border-top: 1px solid oklch(100% 0 0 / 0.1);
  background: oklch(100% 0 0 / 0.04);
  backdrop-filter: blur(12px);
}
.oo-trust-inner {
  display: flex; align-items: center;
  gap: 2rem; flex-wrap: wrap;
  padding-top: 1.5rem; padding-bottom: 1.5rem;
}
.oo-trust-stat { display: flex; flex-direction: column; gap: 2px; }
.oo-trust-val {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800; font-size: 1.4rem;
  color: #fff; letter-spacing: -0.04em;
}
.oo-trust-lbl {
  font-size: 0.74rem; font-weight: 500;
  color: oklch(65% 0.06 265);
}
.oo-trust-div {
  width: 1px; height: 32px;
  background: oklch(100% 0 0 / 0.12);
  flex-shrink: 0;
}


/* ══════════════════════════════════════════
   ONS VERHAAL
═══════════════════════════════════════════ */
.oo-story-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(3rem, 6vw, 6rem);
  align-items: center;
}
.oo-story-content .section-title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--indigo-mid), var(--accent));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.oo-story-p {
  font-size: 0.97rem; line-height: 1.8;
  color: var(--muted);
  margin-top: 1.1rem;
}
.oo-story-p:first-of-type { margin-top: 1.4rem; }

.oo-story-founded {
  display: inline-flex; align-items: center; gap: 0.6rem;
  margin-top: 2rem;
  padding: 0.6rem 1rem;
  background: var(--indigo-light);
  border: 1px solid oklch(87% 0.06 265);
  border-radius: 100px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 0.8rem;
}
.oo-founded-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}
.oo-founded-date {
  font-weight: 700; color: var(--indigo);
}
.oo-founded-label {
  color: var(--muted); font-weight: 500;
}

/* Team visual card */
.oo-story-visual { position: relative; }

.oo-team-card {
  background: linear-gradient(150deg, oklch(30% 0.16 268) 0%, oklch(22% 0.12 280) 100%);
  border: 1px solid oklch(100% 0 0 / 0.1);
  border-radius: 24px;
  padding: 2rem;
  box-shadow: 0 24px 64px oklch(25% 0.15 270 / 0.30);
}

.oo-team-header {
  display: flex; align-items: center; gap: 1rem;
  margin-bottom: 1.25rem;
}
.oo-team-avatars {
  display: flex;
}
.oo-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800; font-size: 1rem; color: #fff;
  border: 2.5px solid oklch(22% 0.12 280);
  flex-shrink: 0;
}
.oo-avatar + .oo-avatar { margin-left: -12px; }
.oo-avatar-plus {
  background: oklch(100% 0 0 / 0.12);
  color: oklch(75% 0.06 265);
  font-size: 0.85rem;
}
.oo-team-meta {
  display: flex; flex-direction: column; gap: 3px;
}
.oo-team-meta strong {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700; font-size: 0.92rem; color: #fff;
}
.oo-team-meta span {
  font-size: 0.74rem; color: oklch(65% 0.06 265);
}

.oo-team-quote {
  font-size: 0.9rem; line-height: 1.7;
  color: oklch(78% 0.05 265);
  font-style: italic;
  padding: 1rem 0;
  border-top: 1px solid oklch(100% 0 0 / 0.08);
  border-bottom: 1px solid oklch(100% 0 0 / 0.08);
  margin-bottom: 1.25rem;
}

.oo-team-stats {
  display: flex; gap: 1.5rem;
}
.oo-team-stat { display: flex; flex-direction: column; gap: 2px; }
.oo-team-stat-val {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800; font-size: 1.3rem;
  color: #fff; letter-spacing: -0.04em;
}
.oo-team-stat-lbl {
  font-size: 0.7rem; color: oklch(60% 0.06 265); font-weight: 500;
}

/* Floating chips */
.oo-float-chip {
  position: absolute;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 7px 12px;
  box-shadow: 0 4px 24px oklch(0% 0 0 / 0.12);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 0.74rem; font-weight: 600;
  display: flex; align-items: center; gap: 6px;
  white-space: nowrap;
}
.oo-float-chip.c1 {
  top: -14px; right: 24px;
  color: var(--indigo);
  animation: float1 4.2s ease-in-out infinite;
}
.oo-float-chip.c1 svg { color: var(--accent); }
.oo-float-chip.c2 {
  bottom: 18px; left: -20px;
  color: oklch(42% 0.16 145);
  animation: float2 5s ease-in-out infinite;
}
.oo-float-chip.c2 svg { color: oklch(52% 0.18 145); }


/* ══════════════════════════════════════════
   DIENSTEN
═══════════════════════════════════════════ */
.oo-diensten-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

/* Last two cards centered */
.oo-dienst-card:nth-child(4) { grid-column: 1 / span 1; margin-left: calc(50% + 0.625rem); }
.oo-dienst-card:nth-child(5) { grid-column: 2 / span 1; margin-left: 0; }

.oo-dienst-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  padding: 1.75rem;
  display: flex; flex-direction: column;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
  position: relative; overflow: hidden;
}
.oo-dienst-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, oklch(97% 0.01 265) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}
.oo-dienst-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 52px oklch(40% 0.18 265 / 0.10);
  border-color: oklch(85% 0.06 265);
}
.oo-dienst-card:hover::before { opacity: 1; }

.oo-dienst-icon {
  width: 52px; height: 52px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem; flex-shrink: 0;
}
.oo-di--indigo { background: var(--indigo-light); color: var(--indigo-mid); }
.oo-di--amber  { background: oklch(95% 0.05 55);  color: oklch(55% 0.16 50); }
.oo-di--blue   { background: oklch(93% 0.05 230);  color: oklch(48% 0.18 230); }
.oo-di--green  { background: oklch(93% 0.05 145);  color: oklch(45% 0.16 145); }
.oo-di--rose   { background: oklch(95% 0.04 5);    color: oklch(52% 0.18 5); }

.oo-dienst-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800; font-size: 1.05rem;
  color: var(--text); letter-spacing: -0.02em;
  margin-bottom: 0.65rem;
}
.oo-dienst-desc {
  font-size: 0.875rem; line-height: 1.7;
  color: var(--muted);
  flex: 1;
  margin-bottom: 1.25rem;
}
.oo-dienst-link {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600; font-size: 0.82rem;
  color: var(--indigo-mid);
  text-decoration: none;
  transition: gap 0.18s, color 0.18s;
  margin-top: auto;
}
.oo-dienst-link:hover { gap: 8px; color: var(--indigo); }


/* ══════════════════════════════════════════
   WAAROM FLOWADVICE
═══════════════════════════════════════════ */
.oo-waarom-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.oo-waarom-card {
  padding: 1.75rem;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  background: #fff;
  position: relative; overflow: hidden;
  transition: transform 0.22s, box-shadow 0.22s, border-color 0.22s;
}
.oo-waarom-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 44px oklch(40% 0.18 265 / 0.08);
  border-color: var(--indigo-mid);
}
.oo-waarom-card::after {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--indigo-mid), var(--accent));
  border-radius: 2px 2px 0 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
.oo-waarom-card:hover::after { transform: scaleX(1); }

.oo-wk-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800; font-size: 0.72rem;
  letter-spacing: 0.08em;
  color: var(--accent);
  margin-bottom: 0.9rem;
  opacity: 0.8;
}
.oo-wk-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700; font-size: 0.97rem;
  color: var(--text); letter-spacing: -0.02em;
  margin-bottom: 0.6rem;
}
.oo-wk-desc {
  font-size: 0.85rem; line-height: 1.7;
  color: var(--muted);
}


/* ══════════════════════════════════════════
   WERKWIJZE / PROCESS
═══════════════════════════════════════════ */
.oo-process {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  margin-top: clamp(2rem, 4vw, 3.5rem);
  position: relative;
}

/* Continuous connecting line */
.oo-process::before {
  content: '';
  position: absolute;
  top: 38px; left: calc(10% + 1rem); right: calc(10% + 1rem);
  height: 1.5px;
  background: linear-gradient(90deg, var(--indigo-mid), var(--accent));
  opacity: 0.25;
  pointer-events: none;
}

.oo-process-step {
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  padding: 0 1rem;
  position: relative;
}

.oo-ps-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--indigo-light);
  border: 2px solid oklch(88% 0.06 265);
  color: var(--indigo-mid);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1rem;
  flex-shrink: 0;
  position: relative; z-index: 1;
  transition: background 0.25s, border-color 0.25s, color 0.25s, box-shadow 0.25s;
}
.oo-process-step:hover .oo-ps-icon {
  background: var(--indigo);
  border-color: var(--indigo);
  color: #fff;
  box-shadow: 0 8px 24px oklch(40% 0.18 265 / 0.22);
}

.oo-ps-icon--accent {
  background: oklch(95% 0.05 28);
  border-color: oklch(88% 0.08 28);
  color: var(--accent);
}
.oo-process-step:hover .oo-ps-icon--accent {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  box-shadow: 0 8px 24px oklch(62% 0.18 28 / 0.28);
}

.oo-ps-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800; font-size: 0.7rem;
  color: var(--muted);
  letter-spacing: 0.06em;
  margin-bottom: 0.5rem;
}
.oo-ps-num--accent { color: var(--accent); }

.oo-ps-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700; font-size: 0.92rem;
  color: var(--text); letter-spacing: -0.02em;
  margin-bottom: 0.5rem;
}
.oo-ps-desc {
  font-size: 0.78rem; line-height: 1.65;
  color: var(--muted);
}

.oo-ps-connector { display: none; }


/* ══════════════════════════════════════════
   CLOSING CTA
═══════════════════════════════════════════ */
.oo-cta {
  background: linear-gradient(150deg, oklch(27% 0.17 270) 0%, oklch(20% 0.13 282) 55%, oklch(24% 0.10 260) 100%);
  position: relative;
  overflow: hidden;
  padding: clamp(5rem, 10vw, 8rem) 0;
}
.oo-cta-glow {
  position: absolute;
  top: -80px; right: -80px;
  width: 480px; height: 480px; border-radius: 50%;
  background: radial-gradient(circle, oklch(100% 0 0 / 0.055) 0%, transparent 65%);
  pointer-events: none;
}

.oo-cta-inner {
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  gap: 0;
}

.oo-cta-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700; font-size: 0.72rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: oklch(72% 0.18 28);
  margin-bottom: 1rem;
}

.oo-cta-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1.12; letter-spacing: -0.04em;
  color: #fff; text-wrap: balance;
  margin: 0 0 1.2rem;
}
.oo-cta-title em {
  font-style: normal;
  background: linear-gradient(135deg, oklch(78% 0.16 55), oklch(72% 0.20 28));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

.oo-cta-sub {
  font-size: 1rem; line-height: 1.7;
  color: oklch(72% 0.05 265);
  max-width: 480px;
  margin: 0 0 2.25rem;
}

.oo-cta-actions {
  display: flex; gap: 0.75rem; flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 1.25rem;
}

.oo-btn-cta-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #fff;
  padding: 14px 28px; border-radius: 100px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700; font-size: 1rem;
  text-decoration: none;
  box-shadow: 0 4px 24px oklch(62% 0.18 28 / 0.38);
  transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
}
.oo-btn-cta-primary:hover {
  background: var(--accent-hover);
  transform: translateY(-2px);
  box-shadow: 0 10px 32px oklch(62% 0.18 28 / 0.5);
}

.oo-btn-cta-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; color: oklch(80% 0.06 265);
  padding: 14px 24px; border-radius: 100px;
  border: 1.5px solid oklch(100% 0 0 / 0.2);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600; font-size: 1rem;
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.oo-btn-cta-ghost:hover {
  border-color: oklch(100% 0 0 / 0.42);
  background: oklch(100% 0 0 / 0.07);
  color: #fff;
}

.oo-cta-disclaimer {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font-size: 0.78rem; color: oklch(58% 0.05 265);
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 500;
}
.oo-cta-disclaimer svg { color: oklch(62% 0.12 145); }


/* ══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */

/* Tablet (≤ 1024px) */
@media (max-width: 1024px) {
  .oo-diensten-grid { grid-template-columns: repeat(2, 1fr); }
  .oo-dienst-card:nth-child(4) { grid-column: auto; margin-left: 0; }
  .oo-dienst-card:nth-child(5) { grid-column: auto; margin-left: 0; }

  .oo-process { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
  .oo-process::before { display: none; }
  .oo-process-step { align-items: flex-start; text-align: left; }
  .oo-ps-icon { width: 48px; height: 48px; }
}

/* Tablet small (≤ 860px) */
@media (max-width: 860px) {
  .oo-story-grid { grid-template-columns: 1fr; }
  .oo-story-visual { display: none; }
  .oo-waarom-grid { grid-template-columns: 1fr 1fr; }
  .oo-trust-inner { gap: 1.25rem; }
  .oo-trust-div { display: none; }
}

/* Mobile (≤ 640px) */
@media (max-width: 640px) {
  .oo-hero h1 { font-size: 2rem; }
  .oo-hero-actions { flex-direction: column; align-items: flex-start; }
  .oo-btn-primary, .oo-btn-ghost { width: 100%; justify-content: center; }
  .oo-diensten-grid { grid-template-columns: 1fr; }
  .oo-waarom-grid { grid-template-columns: 1fr; }
  .oo-process { grid-template-columns: 1fr; }
  .oo-trust-inner { gap: 1rem; flex-wrap: wrap; }
  .oo-cta-actions { flex-direction: column; align-items: stretch; }
  .oo-btn-cta-primary,
  .oo-btn-cta-ghost { width: 100%; justify-content: center; }
}
