/* ============================================
   AeroVista Media — Stylesheet
   Professionele dronebeelden voor industrie,
   bouw en techniek | aerovistamedia.nl
   ============================================ */

/* ============================================
   1. CUSTOM PROPERTIES
   ============================================ */

:root {
  /* Color palette — dark blue / anthracite / white */
  --navy-900: #0a1628;
  --navy-800: #0e1f3a;
  --navy-700: #142e52;
  --navy-600: #1a3d6b;
  --navy-500: #1e4d8c;
  --blue-600: #2563eb;
  --blue-500: #3b82f6;
  --blue-400: #60a5fa;
  --blue-300: #93c5fd;
  --anthracite: #2d3748;
  --gray-800: #1f2937;
  --gray-700: #374151;
  --gray-600: #4b5563;
  --gray-500: #6b7280;
  --gray-400: #9ca3af;
  --gray-300: #d1d5db;
  --gray-200: #e5e7eb;
  --gray-100: #f3f4f6;
  --gray-50:  #f9fafb;
  --white:    #ffffff;
  --green-500: #10b981;

  /* Semantic */
  --color-bg:        var(--white);
  --color-bg-alt:    var(--gray-50);
  --color-bg-dark:   var(--navy-900);
  --color-text:      var(--gray-800);
  --color-text-muted:var(--gray-600);
  --color-heading:   var(--navy-900);
  --color-accent:    var(--blue-600);
  --color-border:    var(--gray-200);

  /* Typography */
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-heading: 'Poppins', 'Inter', -apple-system, sans-serif;

  /* Spacing */
  --section-padding: 5rem 0;
  --container-max:   1200px;
  --container-px:    1.5rem;

  /* Radii */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  /* Shadows */
  --shadow-sm:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --shadow-md:   0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:   0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.05);
  --shadow-xl:   0 20px 30px rgba(0,0,0,.12), 0 8px 10px rgba(0,0,0,.07);
  --shadow-card: 0 4px 20px rgba(0,0,0,.08);
  --shadow-hover:0 12px 32px rgba(0,0,0,.16);

  /* Transitions */
  --t-fast:   .15s ease;
  --t:        .3s ease;
  --t-slow:   .5s ease;

  /* Header */
  --header-h: 72px;
}

/* ============================================
   2. RESET & BASE
   ============================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--header-h);
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

img, video { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; transition: color var(--t-fast); }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; }

/* ============================================
   3. TYPOGRAPHY
   ============================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-heading);
}

h1 { font-size: clamp(2rem,   5vw,   3.5rem);  letter-spacing: -.025em; }
h2 { font-size: clamp(1.75rem,4vw,   2.5rem);  letter-spacing: -.015em; }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.55rem); }
h4 { font-size: 1.1rem; }

p { color: var(--color-text-muted); line-height: 1.8; }

/* Dark section text overrides */
.section-dark h1,
.section-dark h2,
.section-dark h3,
.section-dark h4 { color: var(--white); }
.section-dark p   { color: rgba(255,255,255,.65); }

/* Visually hidden — accessible but not visible */
.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ============================================
   4. LAYOUT
   ============================================ */

.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-px);
}

.section     { padding: var(--section-padding); }
.section-alt { background: var(--color-bg-alt); }
.section-dark{ background: var(--navy-900); }

/* Section header */
.section-header {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 3.5rem;
}
.section-header h2 { margin-bottom: .85rem; }
.section-header p  { font-size: 1.05rem; }

/* Tag badge */
.section-tag {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: rgba(37,99,235,.1);
  color: var(--blue-600);
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: .3rem .9rem;
  border-radius: 100px;
  margin-bottom: .9rem;
}
.section-dark .section-tag {
  background: rgba(96,165,250,.15);
  color: var(--blue-300);
}

/* Grid helpers */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }

/* ============================================
   5. BUTTONS
   ============================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 1.75rem;
  border-radius: var(--radius-md);
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--t);
  white-space: nowrap;
  text-decoration: none;
  line-height: 1;
}
.btn-sm  { padding: .55rem 1.2rem;  font-size: .85rem; }
.btn-lg  { padding: .9rem  2.25rem; font-size: 1.05rem; }

/* Primary */
.btn-primary {
  background: var(--blue-600);
  color: var(--white);
  border-color: var(--blue-600);
}
.btn-primary:hover {
  background: var(--navy-500);
  border-color: var(--navy-500);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(37,99,235,.35);
}

/* Secondary / dark */
.btn-secondary {
  background: var(--navy-800);
  color: var(--white);
  border-color: var(--navy-800);
}
.btn-secondary:hover {
  background: var(--navy-700);
  border-color: var(--navy-700);
  transform: translateY(-2px);
}

/* Outline (for dark backgrounds) */
.btn-outline {
  background: transparent;
  color: var(--white);
  border-color: rgba(255,255,255,.45);
}
.btn-outline:hover {
  background: rgba(255,255,255,.1);
  border-color: var(--white);
  transform: translateY(-2px);
}

/* Outline dark (for light backgrounds) */
.btn-outline-dark {
  background: transparent;
  color: var(--blue-600);
  border-color: var(--blue-600);
}
.btn-outline-dark:hover {
  background: var(--blue-600);
  color: var(--white);
  transform: translateY(-2px);
}

/* ============================================
   6. HEADER & NAVIGATION
   ============================================ */

.header {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  height: var(--header-h);
  z-index: 1000;
  background: rgba(10,22,40,.96);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  transition: box-shadow var(--t);
}
.header.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,.35); }

.nav {
  display: flex;
  align-items: center;
  height: var(--header-h);
  gap: 1.5rem;
}

/* Logo */
.nav-logo {
  display: flex;
  align-items: center;
  gap: .55rem;
  flex-shrink: 0;
}
.nav-logo-img {
  height: 40px;
  width: auto;
  display: block;
  /* logo heeft witte achtergrond: kleine padding zodat het netjes staat */
  border-radius: 4px;
}
.logo-badge {
  display: none; /* niet meer in gebruik */
}

/* Menu */
.nav-menu {
  display: flex;
  align-items: center;
  gap: .1rem;
  margin-left: auto;
}
.nav-link {
  display: inline-flex;
  align-items: center;
  color: rgba(255,255,255,.72);
  font-size: .875rem;
  font-weight: 500;
  padding: .5rem .8rem;
  line-height: 1;
  white-space: nowrap;
  border-radius: var(--radius-sm);
  transition: all var(--t-fast);
  position: relative;
}
.nav-link:hover,
.nav-link.active { color: var(--white); background: rgba(255,255,255,.08); }
.nav-link.active::after {
  content: '';
  position: absolute;
  bottom: 2px; left: 50%;
  transform: translateX(-50%);
  width: 18px; height: 2px;
  background: var(--blue-500);
  border-radius: 2px;
}

/* CTA in nav */
.nav-cta { margin-left: .75rem; flex-shrink: 0; font-size: .82rem; padding: .5rem 1rem; }

/* Mobile nav CTA is hidden on desktop by default */
.nav-mobile-cta { display: none; }

/* Hamburger */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px; height: 40px;
  padding: .5rem;
  border-radius: var(--radius-sm);
  margin-left: auto;
  transition: background var(--t-fast);
}
.nav-toggle:hover { background: rgba(255,255,255,.1); }
.bar {
  display: block;
  width: 22px; height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: all var(--t-fast);
}
.nav-toggle.active .bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.active .bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle.active .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================
   7. HERO — HOMEPAGE
   ============================================ */

.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: var(--navy-900);
  position: relative;
  overflow: hidden;
  padding-top: var(--header-h);
}

/* Radial gradient backdrop */
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 18% 60%, rgba(37,99,235,.18) 0%, transparent 55%),
    radial-gradient(ellipse at 82% 20%, rgba(26,61,107,.55) 0%, transparent 50%),
    linear-gradient(155deg, var(--navy-900) 0%, var(--navy-800) 55%, var(--navy-700) 100%);
  pointer-events: none;
}
/* Tech grid overlay */
.hero::after {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(37,99,235,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.06) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

.hero .container {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  padding-top: 3rem;
  padding-bottom: 3rem;
}

/* Hero video visual */
.hero-visual { display:flex; align-items:center; justify-content:center; }
.hero-video { position: relative; width:100%; height:400px; max-height:60vh; border-radius:var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); }
.hero-video video { width:100%; height:100%; object-fit:cover; display:block; filter: saturate(.9) contrast(.95); }
.hero-video .hero-overlay { position:absolute; inset:0; background: linear-gradient(180deg, rgba(6,12,24,.25), rgba(6,12,24,.5)); mix-blend-mode: multiply; }
.hero-video-caption { position:absolute; left:1rem; bottom:1rem; color:var(--white); background: rgba(0,0,0,.35); padding:.5rem .75rem; border-radius:6px; font-weight:600; font-size:.95rem; backdrop-filter: blur(4px); }

/* Trust bar */
.trust-bar { background: linear-gradient(90deg, rgba(255,255,255,.02), rgba(255,255,255,.01)); padding: .9rem 0; border-top: 1px solid rgba(255,255,255,.03); border-bottom: 1px solid rgba(255,255,255,.03); }
.trust-list { display:flex; gap:1.25rem; align-items:center; justify-content:space-between; max-width:var(--container-max); margin:0 auto; padding:0 var(--container-px); }
.trust-item { display:flex; gap:.65rem; align-items:center; color: rgba(255,255,255,.9); font-weight:600; font-size:.95rem; }
.trust-item i { color: var(--blue-300); font-size:1.1rem; }

/* Responsive adjustments */
@media (max-width: 900px) {
  .hero .container { grid-template-columns: 1fr; gap:2rem; }
  .trust-list { flex-direction: column; align-items:flex-start; gap:.65rem; }
  .hero-video { height: 300px; }
}

.hero-content { max-width: 620px; }

/* Tag line above H1 */
.hero-tag {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(96,165,250,.12);
  border: 1px solid rgba(96,165,250,.28);
  color: var(--blue-300);
  font-size: .78rem;
  font-weight: 500;
  letter-spacing: .05em;
  padding: .4rem 1rem;
  border-radius: 100px;
  margin-bottom: 1.5rem;
}
.tag-dot {
  width: 6px; height: 6px;
  background: var(--blue-400);
  border-radius: 50%;
  animation: blink 2s ease-in-out infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: .35; }
}

.hero-title {
  font-size: clamp(2.25rem, 5vw, 3.6rem);
  color: var(--white);
  line-height: 1.1;
  margin-bottom: 1.5rem;
  letter-spacing: -.025em;
}
.hero-title-accent { color: var(--blue-400); }

.hero-subtitle {
  font-size: 1.1rem;
  color: rgba(255,255,255,.68);
  line-height: 1.8;
  margin-bottom: 2.5rem;
  max-width: 520px;
}

.hero-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 3rem;
}

/* Stat strip */
.hero-stats {
  display: flex;
  align-items: center;
  gap: 2rem;
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 2rem;
}
.stat { display: flex; flex-direction: column; gap: .2rem; }
.stat-number {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--white);
  line-height: 1;
}
.stat-label {
  font-size: .72rem;
  color: rgba(255,255,255,.45);
  white-space: nowrap;
}
.stat-divider {
  width: 1px; height: 36px;
  background: rgba(255,255,255,.12);
  flex-shrink: 0;
}

/* Hero visual — drone HUD mockup */
.hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}
.drone-hud {
  width: 100%;
  max-width: 440px;
  aspect-ratio: 4/3;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(96,165,250,.22);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
}
.drone-hud::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(96,165,250,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(96,165,250,.07) 1px, transparent 1px);
  background-size: 38px 38px;
}
/* Corner brackets */
.hud-corner {
  position: absolute;
  width: 22px; height: 22px;
  border-color: rgba(96,165,250,.55);
  border-style: solid;
}
.hud-tl { top: 14px; left: 14px;  border-width: 2px 0 0 2px; border-radius: 2px 0 0 0; }
.hud-tr { top: 14px; right: 14px; border-width: 2px 2px 0 0; border-radius: 0 2px 0 0; }
.hud-bl { bottom: 14px; left: 14px;  border-width: 0 0 2px 2px; border-radius: 0 0 0 2px; }
.hud-br { bottom: 14px; right: 14px; border-width: 0 2px 2px 0; border-radius: 0 0 2px 0; }

.hud-crosshair {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 64px; height: 64px;
  border: 1px solid rgba(96,165,250,.3);
  border-radius: 50%;
}
.hud-crosshair::before,
.hud-crosshair::after {
  content: '';
  position: absolute;
  background: rgba(96,165,250,.3);
}
.hud-crosshair::before { width: 1px; height: 100%; left: 50%; top: 0; }
.hud-crosshair::after  { height: 1px; width: 100%; top: 50%; left: 0; }

.hud-label-top {
  position: absolute;
  top: 18px; left: 50%;
  transform: translateX(-50%);
  background: rgba(37,99,235,.2);
  border: 1px solid rgba(96,165,250,.35);
  color: var(--blue-300);
  font-size: .62rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: .25rem .75rem;
  border-radius: 100px;
  white-space: nowrap;
  z-index: 2;
}
.hud-center-text {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 2;
  pointer-events: none;
}
.hud-main-icon {
  font-size: 2.6rem;
  color: rgba(96,165,250,.55);
  display: block;
  margin-bottom: .5rem;
}
.hud-info {
  font-family: monospace;
  font-size: .62rem;
  color: rgba(96,165,250,.5);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.hud-footer {
  position: absolute;
  bottom: 14px; left: 0; right: 0;
  display: flex;
  justify-content: space-between;
  padding: 0 18px;
  z-index: 2;
}
.hud-data {
  font-family: monospace;
  font-size: .6rem;
  color: rgba(96,165,250,.45);
  letter-spacing: .08em;
}

/* ============================================
   8. PAGE HERO (inner pages)
   ============================================ */

.page-hero {
  background: var(--navy-900);
  padding: calc(var(--header-h) + 3.5rem) 0 3.5rem;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 25% 70%, rgba(37,99,235,.13) 0%, transparent 52%),
    linear-gradient(155deg, var(--navy-900) 0%, var(--navy-800) 100%);
  pointer-events: none;
}
.page-hero::after {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.05) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.page-hero-content {
  position: relative; z-index: 1;
  max-width: 720px;
}
.page-hero-content h1 { color: var(--white); margin-bottom: 1rem; }
.page-hero-content p  { color: rgba(255,255,255,.68); font-size: 1.1rem; }

.breadcrumb {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1.5rem;
  color: rgba(255,255,255,.38);
  font-size: .85rem;
}
.breadcrumb a        { color: rgba(255,255,255,.38); transition: color var(--t-fast); }
.breadcrumb a:hover  { color: var(--blue-300); }
.breadcrumb-sep      { opacity: .4; }

/* Legal pages */
.legal-hero .page-hero-content { max-width: 860px; }
.legal-updated {
  font-size: .85rem !important;
  color: rgba(255,255,255,.54) !important;
  margin-top: .9rem;
}

.legal-layout {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 2rem;
  align-items: start;
}
.legal-layout-single {
  max-width: 900px;
  margin: 0 auto;
}

.legal-toc-card,
.legal-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.legal-toc-card {
  position: sticky;
  top: calc(var(--header-h) + 1.5rem);
  padding: 1.4rem 1.25rem;
}
.legal-toc-card h2 {
  font-size: 1rem;
  margin-bottom: 1rem;
}

.legal-toc-list {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  list-style: none;
  counter-reset: toc;
}
.legal-toc-list li { counter-increment: toc; }
.legal-toc-list a {
  display: block;
  font-size: .88rem;
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
  padding: .4rem .55rem;
  border: 1px solid transparent;
  transition: all var(--t-fast);
}
.legal-toc-list a:hover {
  color: var(--blue-600);
  border-color: rgba(37,99,235,.2);
  background: rgba(37,99,235,.04);
}

.legal-card {
  padding: 2rem;
}

.legal-callout {
  background: rgba(37,99,235,.05);
  border: 1px solid rgba(37,99,235,.18);
  border-left: 4px solid var(--blue-600);
  border-radius: var(--radius-md);
  padding: 1rem 1.2rem;
  margin-bottom: 1.4rem;
}
.legal-callout strong {
  display: block;
  color: var(--color-heading);
  margin-bottom: .25rem;
}
.legal-callout p { margin: 0; }

.legal-section {
  padding: 1.15rem 0;
  border-bottom: 1px solid var(--color-border);
}
.legal-section h2 {
  font-size: 1.2rem;
  margin-bottom: .7rem;
}
.legal-section p { margin-bottom: .75rem; }
.legal-section p:last-child { margin-bottom: 0; }
.legal-section-last { border-bottom: 0; padding-bottom: 0; }

.legal-list {
  list-style: disc;
  margin: .35rem 0 .7rem 1.35rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.legal-list li {
  color: var(--color-text-muted);
  font-size: .95rem;
}

.legal-contact-link {
  color: var(--blue-600);
  font-weight: 600;
}
.legal-contact-link:hover { color: var(--navy-600); }

.legal-compliance-highlight {
  border: 1px solid rgba(37,99,235,.22);
  box-shadow: 0 16px 36px rgba(10,22,40,.08);
  background:
    linear-gradient(180deg, rgba(37,99,235,.04) 0%, rgba(37,99,235,.01) 40%, var(--white) 100%);
}

.legal-compliance-head {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin-bottom: .95rem;
}

.legal-compliance-icon {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(37,99,235,.12);
  color: var(--blue-600);
  border: 1px solid rgba(37,99,235,.2);
  flex-shrink: 0;
}

.legal-compliance-head h3 {
  margin: 0;
  font-size: 1.03rem;
}

.legal-placeholder-card h2 {
  margin-bottom: .75rem;
}

/* ============================================
   9. FEATURE CARDS
   ============================================ */

.feature-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  transition: all var(--t);
  box-shadow: var(--shadow-sm);
}
.feature-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.feature-icon {
  width: 52px; height: 52px;
  background: rgba(37,99,235,.09);
  color: var(--blue-600);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  margin-bottom: 1.25rem;
  transition: all var(--t);
}
.feature-card:hover .feature-icon {
  background: var(--blue-600);
  color: var(--white);
}
.feature-card h3 { font-size: 1.1rem; margin-bottom: .6rem; }
.feature-card p  { font-size: .9rem; }

/* ============================================
   10. BENEFIT CARDS
   ============================================ */

.benefit-card {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
}
.benefit-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.18);
}
.benefit-icon {
  width: 48px; height: 48px;
  background: var(--navy-900);
  color: var(--blue-400);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.benefit-text h4  { font-size: 1rem; margin-bottom: .35rem; }
.benefit-text p   { font-size: .88rem; }

/* ============================================
   11. SERVICE OVERVIEW CARDS (homepage)
   ============================================ */

.service-overview-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
  text-decoration: none;
}
.service-overview-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.svc-icon {
  width: 54px; height: 54px;
  background: var(--navy-900);
  color: var(--blue-400);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  margin-bottom: 1.25rem;
}
.service-overview-card h3 { font-size: 1.1rem; margin-bottom: .65rem; }
.service-overview-card p  { font-size: .9rem; flex: 1; margin-bottom: 1.25rem; }
.card-cta {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: var(--blue-600);
  font-size: .875rem;
  font-weight: 600;
  transition: gap var(--t-fast);
}
.service-overview-card:hover .card-cta { gap: .7rem; }

/* ============================================
   12. USP SECTION (Why AeroVista Media)
   ============================================ */

.usp-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.usp-list { display: flex; flex-direction: column; gap: 1.5rem; }
.usp-item {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.usp-dot {
  width: 44px; height: 44px;
  background: rgba(37,99,235,.1);
  color: var(--blue-600);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
  flex-shrink: 0;
}
.usp-body h4 { font-size: 1rem; margin-bottom: .3rem; }
.usp-body p  { font-size: .88rem; }

.usp-panel {
  background: var(--navy-900);
  border-radius: var(--radius-xl);
  padding: 3rem 2.5rem;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.usp-panel::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(37,99,235,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.06) 1px, transparent 1px);
  background-size: 28px 28px;
}
.usp-panel-inner { position: relative; z-index: 1; }
.usp-panel-icon  { font-size: 3.8rem; color: var(--blue-400); opacity: .65; margin-bottom: 1.5rem; }
.usp-panel h3    { color: var(--white); font-size: 1.25rem; margin-bottom: .75rem; }
.usp-panel p     { color: rgba(255,255,255,.5); font-size: .9rem; }

/* ============================================
   13. SECTORS GRID
   ============================================ */

.sectors-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.sector-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1.4rem 1.25rem;
  display: flex;
  align-items: center;
  gap: .85rem;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
}
.sector-card:hover {
  border-color: rgba(37,99,235,.25);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.sector-icon {
  width: 42px; height: 42px;
  background: rgba(37,99,235,.08);
  color: var(--blue-600);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem;
  flex-shrink: 0;
}
.sector-name { font-weight: 600; font-size: .88rem; color: var(--color-heading); }

/* Enhanced final CTA */
.cta-final {
  background: linear-gradient(135deg, var(--navy-900) 0%, var(--navy-700) 50%, var(--navy-600) 100%);
  padding: 6rem 0;
}
.cta-final h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); }

/* ============================================
   14. CTA BANNER
   ============================================ */

.cta-banner {
  background: linear-gradient(135deg, var(--navy-600) 0%, var(--blue-600) 100%);
  padding: 5rem 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-banner::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 50px 50px;
  pointer-events: none;
}
.cta-banner .container { position: relative; z-index: 1; }
.cta-banner h2 { color: var(--white); margin-bottom: 1rem; }
.cta-banner p  {
  color: rgba(255,255,255,.82);
  font-size: 1.1rem;
  max-width: 520px;
  margin: 0 auto 2.5rem;
}
.cta-banner .btn-cta { display: inline-flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }

/* ============================================
   15. DIENSTEN PAGE — Service detail cards
   ============================================ */

.services-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
.service-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
}
.service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.service-card-header { margin-bottom: 1.25rem; }
.service-card-icon {
  width: 56px; height: 56px;
  background: var(--navy-900);
  color: var(--blue-400);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 1.25rem;
}
.service-card h3 { font-size: 1.2rem; margin-bottom: .65rem; }
.service-card > p { font-size: .93rem; margin-bottom: 1.5rem; }

.service-meta { margin-bottom: 1.75rem; display: flex; flex-direction: column; gap: 1.25rem; flex: 1; }
.meta-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--color-heading);
  margin-bottom: .45rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.meta-label i { color: var(--blue-600); font-size: .8rem; }
.meta-list { display: flex; flex-direction: column; gap: .3rem; }
.meta-list li {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  font-size: .875rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}
.meta-list li::before {
  content: '→';
  color: var(--blue-600);
  font-size: .75rem;
  flex-shrink: 0;
  margin-top: .2em;
}
.meta-list.check li::before {
  content: '✓';
  color: var(--green-500);
  font-weight: 700;
}

/* ============================================
   16. PORTFOLIO PAGE
   ============================================ */

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 1.75rem;
}
.portfolio-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  background: var(--white);
  border: 1px solid var(--color-border);
  transition: all var(--t);
}
.portfolio-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}
.pf-thumb {
  height: 230px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
/* Individual thumb colors */
.pf-1 { background: linear-gradient(135deg, #0a1628, #1a3d6b); }
.pf-2 { background: linear-gradient(135deg, #064e3b, #065f46); }
.pf-3 { background: linear-gradient(135deg, #1e1b4b, #3730a3); }
.pf-4 { background: linear-gradient(135deg, #4a1d96, #6d28d9); }
.pf-5 { background: linear-gradient(135deg, #7c2d12, #b45309); }
.pf-6 { background: linear-gradient(135deg, #0f172a, #334155); }
.pf-7 { background: linear-gradient(135deg, #134e4a, #0f766e); }
.pf-8 { background: linear-gradient(135deg, #1d4ed8, #0e7490); }
.pf-9 { background: linear-gradient(135deg, #14532d, #3f6212); }
.pf-10 { background: linear-gradient(135deg, #365314, #854d0e); }

.pf-thumb-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 28px 28px;
}
.pf-thumb-icon {
  font-size: 2.8rem;
  color: rgba(255,255,255,.35);
  position: relative; z-index: 1;
}
.pf-badge {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(10,22,40,.72);
  color: var(--blue-300);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .28rem .7rem;
  border-radius: 100px;
  border: 1px solid rgba(96,165,250,.25);
  backdrop-filter: blur(6px);
  z-index: 2;
}
.pf-body { padding: 1.4rem 1.5rem; }
.pf-body h3 { font-size: 1.05rem; margin-bottom: .4rem; }
.pf-body p  { font-size: .875rem; }

.portfolio-notice {
  margin-top: 2.5rem;
  padding: 2.5rem;
  background: var(--gray-50);
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-lg);
  text-align: center;
}
.portfolio-notice i { font-size: 2rem; color: var(--blue-400); margin-bottom: .75rem; }
.portfolio-notice p { font-size: .95rem; }

/* ============================================
   17. OVER MIJ PAGE
   ============================================ */

.about-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 4rem;
  align-items: start;
}
.about-sidebar {
  background: var(--navy-900);
  border-radius: var(--radius-xl);
  padding: 2.5rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  position: sticky;
  top: calc(var(--header-h) + 2rem);
}
.about-sidebar::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(37,99,235,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.06) 1px, transparent 1px);
  background-size: 28px 28px;
}
.avatar-ring {
  width: 96px; height: 96px;
  background: rgba(37,99,235,.14);
  border: 2px solid rgba(96,165,250,.28);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.5rem;
  position: relative; z-index: 1;
}
.avatar-ring i { font-size: 2.5rem; color: var(--blue-400); }

.profile-name  { color: var(--white); font-size: 1.3rem; margin-bottom: .25rem; position: relative; z-index: 1; }
.profile-role  { color: var(--blue-300); font-size: .85rem; margin-bottom: 2rem; position: relative; z-index: 1; }

.skill-tags {
  display: flex; flex-wrap: wrap; gap: .45rem;
  justify-content: center;
  position: relative; z-index: 1;
}
.skill-tag {
  background: rgba(37,99,235,.12);
  border: 1px solid rgba(96,165,250,.2);
  color: var(--blue-300);
  font-size: .72rem;
  padding: .28rem .7rem;
  border-radius: 100px;
}

.about-body h2 { margin-bottom: 1.5rem; }
.about-body p  { margin-bottom: 1.25rem; font-size: .98rem; line-height: 1.85; }
.about-body p:last-of-type { margin-bottom: 0; }

.expertise-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .75rem;
  margin-top: 2rem;
}
.expertise-item {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .85rem 1rem;
  background: var(--gray-50);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: .875rem;
  color: var(--color-text-muted);
  transition: all var(--t);
}
.expertise-item:hover {
  border-color: rgba(37,99,235,.2);
  background: rgba(37,99,235,.04);
}
.expertise-item i { color: var(--blue-600); font-size: .875rem; flex-shrink: 0; }

/* ============================================
   18. WERKWIJZE PAGE
   ============================================ */

.timeline {
  position: relative;
  max-width: 860px;
  margin: 0 auto;
}
.timeline::before {
  content: '';
  position: absolute;
  left: 27px; top: 28px; bottom: 28px;
  width: 2px;
  background: linear-gradient(to bottom, var(--blue-600), rgba(37,99,235,.1));
}
.step-row {
  display: flex;
  gap: 2rem;
  margin-bottom: 2.5rem;
  position: relative;
  align-items: flex-start;
}
.step-row:last-child { margin-bottom: 0; }

.step-num {
  width: 56px; height: 56px;
  background: var(--navy-900);
  border: 2px solid var(--blue-600);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1rem;
  color: var(--blue-400);
  flex-shrink: 0;
  position: relative; z-index: 1;
}
.step-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1.75rem 2rem;
  flex: 1;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
}
.step-card:hover {
  transform: translateX(5px);
  box-shadow: var(--shadow-md);
  border-color: rgba(37,99,235,.2);
}
.step-card h3 { font-size: 1.1rem; margin-bottom: .45rem; }
.step-card p  { font-size: .9rem; }

.process-note {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  background: rgba(37,99,235,.05);
  border: 1px solid rgba(37,99,235,.14);
  border-left: 4px solid var(--blue-600);
  border-radius: var(--radius-md);
  padding: 1.5rem 2rem;
  margin-top: 3rem;
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}
.process-note i { color: var(--blue-600); font-size: 1.2rem; flex-shrink: 0; margin-top: .1rem; }
.process-note p { font-size: .93rem; color: var(--color-text); margin: 0; }

/* ============================================
   19. CONTACT PAGE
   ============================================ */

.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 4.5rem;
  align-items: start;
}
.contact-sidebar { display: flex; flex-direction: column; gap: 2rem; }
.contact-sidebar > h2  { margin-bottom: .25rem; }
.contact-sidebar > p   { font-size: 1rem; }

.contact-detail {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.contact-detail-icon {
  width: 44px; height: 44px;
  background: rgba(37,99,235,.08);
  color: var(--blue-600);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
  flex-shrink: 0;
}
.contact-detail-text strong {
  display: block;
  font-size: .82rem;
  color: var(--color-heading);
  margin-bottom: .2rem;
}
.contact-detail-text a,
.contact-detail-text span { font-size: .93rem; color: var(--color-text-muted); }
.contact-detail-text a:hover { color: var(--blue-600); }

/* Form card */
.form-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 2.5rem;
  box-shadow: var(--shadow-lg);
}
.form-card-title    { font-size: 1.25rem; margin-bottom: .3rem; }
.form-card-subtitle { font-size: .88rem; color: var(--color-text-muted); margin-bottom: 2rem; }

.contact-form { display: flex; flex-direction: column; gap: 1.2rem; }
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
}
.form-group { display: flex; flex-direction: column; gap: .35rem; }
.form-group label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--color-heading);
}
.form-group label .req { color: var(--blue-600); margin-left: 2px; }

.form-control {
  width: 100%;
  padding: .72rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: .93rem;
  color: var(--color-text);
  background: var(--white);
  transition: all var(--t-fast);
  outline: none;
}
.form-control:focus {
  border-color: var(--blue-600);
  box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}
.form-control.error {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,.1);
}
textarea.form-control { resize: vertical; min-height: 130px; }
select.form-control {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
  background-position: right .75rem center;
  background-repeat: no-repeat;
  background-size: 1.2rem;
  padding-right: 2.5rem;
}

.field-error { font-size: .78rem; color: #ef4444; display: none; }
.field-error.show { display: block; }

.form-submit { margin-top: .5rem; }
.form-submit .btn { width: 100%; padding: 1rem; font-size: 1rem; }

/* Success state */
.form-success {
  display: none;
  text-align: center;
  padding: 2rem 1rem;
}
.form-success.show { display: block; }
.success-icon { font-size: 3rem; color: var(--green-500); margin-bottom: 1rem; }
.form-success h3 { margin-bottom: .75rem; }
.form-success p  { font-size: .95rem; }

/* ============================================
   20. FOOTER
   ============================================ */

.footer {
  background: var(--navy-900);
  color: var(--white);
  padding: 4.5rem 0 0;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr 1.35fr;
  gap: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.footer-logo {
  display: flex;
  align-items: center;
  margin-bottom: .9rem;
}
.footer-logo-img {
  height: 48px;
  width: auto;
  display: block;
  border-radius: 4px;
}
.footer-tagline { color: var(--blue-300); font-size: .875rem; font-weight: 500; margin-bottom: .7rem; }
.footer-desc    { color: rgba(255,255,255,.4); font-size: .85rem; line-height: 1.7; }

.footer-col-title {
  color: var(--white);
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  margin-bottom: 1.2rem;
}
.footer-links { display: flex; flex-direction: column; gap: .55rem; }
.footer-links a { color: rgba(255,255,255,.5); font-size: .875rem; transition: color var(--t-fast); }
.footer-links a:hover { color: var(--blue-300); }

.footer-contact-list { display: flex; flex-direction: column; gap: .85rem; }
.footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  color: rgba(255,255,255,.5);
  font-size: .875rem;
}
.footer-contact-list i { color: var(--blue-400); font-size: .82rem; margin-top: .17em; flex-shrink: 0; }
.footer-contact-list a { color: rgba(255,255,255,.5); transition: color var(--t-fast); }
.footer-contact-list a:hover { color: var(--blue-300); }

.footer-bottom {
  padding: 1.5rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
}
.footer-bottom p { font-size: .78rem; color: rgba(255,255,255,.28); margin: 0; }
.footer-seo      { font-size: .72rem; color: rgba(255,255,255,.18); }

.footer-legal-inline {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .45rem;
  font-size: .8rem !important;
  color: rgba(255,255,255,.32) !important;
}
.footer-legal-inline a {
  color: rgba(255,255,255,.5);
  transition: color var(--t-fast);
}
.footer-legal-inline a:hover { color: var(--blue-300); }
.footer-legal-label {
  color: rgba(255,255,255,.65);
  font-weight: 600;
}

/* ============================================
   21. SCROLL ANIMATIONS
   ============================================ */

.fade-up {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
}
.fade-up.visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: .1s; }
.delay-2 { transition-delay: .2s; }
.delay-3 { transition-delay: .3s; }
.delay-4 { transition-delay: .4s; }
.delay-5 { transition-delay: .5s; }

/* ============================================
   22. RESPONSIVE
   ============================================ */

/* --- Medium desktop / large tablet --- */
@media (max-width: 1100px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

/* --- Tablet --- */
@media (max-width: 900px) {
  :root { --section-padding: 3.5rem 0; }

  .hero .container   { grid-template-columns: 1fr; }
  .hero-visual       { display: none; }
  .hero-content      { max-width: 100%; }

  .usp-wrapper       { grid-template-columns: 1fr; }
  .usp-panel         { display: none; }

  .about-layout      { grid-template-columns: 1fr; }
  .about-sidebar     { position: static; }

  .contact-layout    { grid-template-columns: 1fr; }

  .services-grid     { grid-template-columns: 1fr; }
  .grid-3            { grid-template-columns: repeat(2,1fr); }
  .grid-4            { grid-template-columns: repeat(2,1fr); }
  .sectors-grid      { grid-template-columns: repeat(2,1fr); }
  .expertise-grid    { grid-template-columns: repeat(2,1fr); }

  .timeline::before  { display: none; }

  .legal-layout {
    grid-template-columns: 1fr;
  }
  .legal-toc-card {
    position: static;
    top: auto;
  }
}

/* --- Mobile --- */
@media (max-width: 700px) {
  :root {
    --section-padding: 2.5rem 0;
    --header-h: 64px;
  }

  /* Mobile nav drawer */
  .nav-menu {
    position: fixed;
    top: var(--header-h); left: 0; right: 0; bottom: 0;
    background: var(--navy-900);
    flex-direction: column;
    align-items: stretch;
    padding: 1.5rem;
    gap: .2rem;
    transform: translateX(100%);
    transition: transform var(--t);
    z-index: 999;
    overflow-y: auto;
  }
  .nav-menu.open   { transform: translateX(0); }
  .nav-link        { font-size: 1rem; padding: .9rem 1rem; border-radius: var(--radius-md); }
  .nav-cta         { display: none; }
  .nav-toggle      { display: flex; }

  /* Show mobile nav CTA inside drawer */
  .nav-mobile-cta {
    display: block;
    margin-top: 1rem;
    text-align: center;
  }

  .hero-stats      { flex-wrap: wrap; gap: 1rem; }
  .stat-divider    { display: none; }
  .hero-actions    { flex-direction: column; }
  .hero-actions .btn { width: 100%; justify-content: center; }

  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .sectors-grid   { grid-template-columns: 1fr; }
  .expertise-grid { grid-template-columns: 1fr; }
  .form-row       { grid-template-columns: 1fr; }
  .footer-grid    { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom  { flex-direction: column; text-align: center; }

  .services-grid  { grid-template-columns: 1fr; }
  .portfolio-grid { grid-template-columns: 1fr; }
}

/* Show hamburger only on mobile */
@media (min-width: 701px) { .nav-toggle { display: none; } }

/* Hide nav CTA on mid-range screens */
@media (max-width: 980px) and (min-width: 701px) { .nav-cta { display: none; } }

/* ============================================
   23. WHY COMPANIES CARDS
   ============================================ */

.why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.why-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem 1.75rem;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
  position: relative;
  overflow: hidden;
}
.why-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--blue-600), var(--blue-400));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t);
}
.why-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.why-card:hover::before { transform: scaleX(1); }
.why-icon {
  width: 54px; height: 54px;
  background: rgba(37,99,235,.1);
  color: var(--blue-600);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.35rem;
  margin-bottom: 1.25rem;
  transition: all var(--t);
}
.why-card:hover .why-icon {
  background: var(--navy-900);
  color: var(--blue-400);
  transform: scale(1.08);
}
.why-card h3 { font-size: 1.05rem; margin-bottom: .55rem; }
.why-card p  { font-size: .88rem; }

/* ============================================
   24. USE CASE CARDS
   ============================================ */

.usecase-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.usecase-card {
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  text-decoration: none;
  transition: all var(--t);
  border: 1px solid var(--color-border);
}
.usecase-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}
.usecase-thumb {
  height: 200px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.uc-1 { background: linear-gradient(135deg, #0a1628, #1a3d6b); }
.uc-2 { background: linear-gradient(135deg, #064e3b, #0f766e); }
.uc-3 { background: linear-gradient(135deg, #1e1b4b, #3730a3); }
.uc-4 { background: linear-gradient(135deg, #4a1d96, #7c3aed); }
.uc-5 { background: linear-gradient(135deg, #7c2d12, #c2410c); }
.uc-6 { background: linear-gradient(135deg, #134e4a, #0d9488); }
.uc-grid-bg {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 28px 28px;
}
.uc-icon {
  font-size: 2.8rem;
  color: rgba(255,255,255,.4);
  position: relative; z-index: 1;
  transition: transform var(--t), color var(--t);
}
.usecase-card:hover .uc-icon { transform: scale(1.15); color: rgba(255,255,255,.7); }
.usecase-overlay {
  position: absolute; inset: 0;
  background: rgba(6,12,24,.68);
  display: flex; align-items: flex-end; justify-content: flex-start;
  padding: 1rem 1.25rem;
  opacity: 0;
  transition: opacity var(--t);
}
.usecase-card:hover .usecase-overlay { opacity: 1; }
.usecase-cta {
  color: var(--white);
  font-weight: 600;
  font-size: .875rem;
  display: flex; align-items: center; gap: .4rem;
}
.usecase-body {
  background: var(--white);
  padding: 1.25rem 1.5rem;
  flex: 1;
}
.usecase-body h3 { font-size: 1rem; margin-bottom: .35rem; }
.usecase-body p  { font-size: .85rem; }

/* ============================================
   25. HOME TIMELINE (HORIZONTAL)
   ============================================ */

.home-timeline {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
}
.home-timeline::before {
  content: '';
  position: absolute;
  top: 28px; left: 14%; right: 14%;
  height: 2px;
  background: linear-gradient(90deg, var(--blue-600), rgba(37,99,235,.2));
  z-index: 0;
}
.ht-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}
.ht-num {
  width: 56px; height: 56px;
  background: var(--navy-900);
  border: 2px solid var(--blue-600);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--blue-400);
  margin-bottom: 1.5rem;
  flex-shrink: 0;
  transition: all var(--t);
}
.ht-step:hover .ht-num {
  background: var(--blue-600);
  color: var(--white);
  transform: scale(1.1);
  box-shadow: 0 0 0 6px rgba(37,99,235,.15);
}
.ht-connector { display: none; }
.ht-body {
  padding: 0 .75rem;
}
.ht-icon {
  font-size: 1.35rem;
  color: var(--blue-600);
  margin-bottom: .65rem;
  display: block;
}
.ht-body h4 { font-size: .95rem; margin-bottom: .3rem; }
.ht-body p  { font-size: .82rem; color: var(--color-text-muted); line-height: 1.6; }

/* ============================================
   26. PORTFOLIO PREVIEW (HOMEPAGE)
   ============================================ */

.pf-filters {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
  justify-content: center;
}
.pf-filter {
  padding: .5rem 1.25rem;
  border-radius: 100px;
  border: 1.5px solid var(--color-border);
  background: var(--white);
  color: var(--gray-600);
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--t-fast);
}
.pf-filter:hover {
  border-color: var(--blue-600);
  color: var(--blue-600);
}
.pf-filter.active {
  background: var(--blue-600);
  border-color: var(--blue-600);
  color: var(--white);
}
.pf-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.pf-preview-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  cursor: pointer;
  transition: all var(--t);
}
.pf-preview-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); }
.pf-preview-card.hidden { display: none; }
.pf-preview-thumb {
  height: 220px;
  position: relative;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.pf-preview-thumb .pf-thumb-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 28px 28px;
}
.pf-thumb-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(6,12,24,.88) 0%, rgba(6,12,24,.2) 60%, transparent 100%);
  display: flex; flex-direction: column;
  justify-content: flex-end;
  padding: 1.25rem 1.5rem;
  transform: translateY(8px);
  transition: transform var(--t);
}
.pf-preview-card:hover .pf-thumb-overlay { transform: translateY(0); }
.pf-thumb-overlay h3 { color: var(--white); font-size: 1rem; margin-bottom: .2rem; }
.pf-thumb-overlay p  { color: rgba(255,255,255,.65); font-size: .8rem; margin: 0; }
/* 6th portfolio card gradient */
.pf-6 { background: linear-gradient(135deg, #052e16, #166534); }
/* Zoom effect on hover */
.pf-preview-card:hover .pf-thumb-icon { transform: scale(1.15); transition: transform var(--t); }

/* ============================================
   27. ABOUT PREVIEW SECTION
   ============================================ */

.about-preview-layout {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 5rem;
  align-items: center;
}
.about-preview-photo {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.about-preview-placeholder {
  aspect-ratio: 3/4;
  background: linear-gradient(135deg, var(--navy-800), var(--navy-600));
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  border-radius: var(--radius-xl);
}
.about-preview-placeholder i { font-size: 4rem; color: rgba(96,165,250,.4); }
.about-preview-placeholder span { color: rgba(255,255,255,.3); font-size: .85rem; }
.about-preview-badge {
  position: absolute;
  bottom: 1.5rem; left: 50%;
  transform: translateX(-50%);
  background: rgba(10,22,40,.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(96,165,250,.25);
  color: var(--blue-300);
  padding: .5rem 1.25rem;
  border-radius: 100px;
  font-size: .82rem;
  font-weight: 600;
  white-space: nowrap;
  display: flex; align-items: center; gap: .5rem;
}
.about-preview-content .section-tag { margin-bottom: 1rem; }
.about-preview-content h2 { margin-bottom: 1.25rem; }
.about-preview-content p  { margin-bottom: 1.5rem; }
.about-preview-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .65rem;
  margin-bottom: 2rem;
}
.about-preview-list li {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  font-size: .93rem;
  color: var(--color-text-muted);
}
.about-preview-list li i { color: var(--green-500); font-size: 1rem; flex-shrink: 0; margin-top: .1em; }

/* ============================================
   28. TESTIMONIALS
   ============================================ */

.testimonial-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
  position: relative;
}
.testimonial-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.testimonial-stars {
  font-size: 1rem;
  color: #f59e0b;
  margin-bottom: 1rem;
  letter-spacing: .05em;
}
.testimonial-card > p {
  font-size: .95rem;
  font-style: italic;
  color: var(--color-text);
  margin-bottom: 1.5rem;
  line-height: 1.75;
}
.testimonial-author {
  display: flex;
  align-items: center;
  gap: .85rem;
  border-top: 1px solid var(--color-border);
  padding-top: 1rem;
}
.testimonial-avatar {
  width: 42px; height: 42px;
  background: rgba(37,99,235,.1);
  color: var(--blue-600);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.testimonial-author strong { display: block; font-size: .875rem; color: var(--color-heading); }
.testimonial-author span   { font-size: .8rem; color: var(--color-text-muted); }

/* ============================================
   29. CONTACT PAGE EXTRAS (WhatsApp / LinkedIn)
   ============================================ */

.contact-social-links {
  display: flex;
  flex-direction: column;
  gap: .65rem;
}
.contact-social-btn {
  display: flex;
  align-items: center;
  gap: .85rem;
  padding: .8rem 1.25rem;
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: .9rem;
  text-decoration: none;
  transition: all var(--t-fast);
}
.contact-social-btn.whatsapp {
  background: #dcfce7;
  color: #166534;
  border: 1px solid #bbf7d0;
}
.contact-social-btn.whatsapp:hover {
  background: #16a34a;
  color: var(--white);
  border-color: #16a34a;
  transform: translateY(-2px);
}
.contact-social-btn.linkedin {
  background: #dbeafe;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
}
.contact-social-btn.linkedin:hover {
  background: #2563eb;
  color: var(--white);
  border-color: #2563eb;
  transform: translateY(-2px);
}

/* ============================================
   30. MODAL (PORTFOLIO)
   ============================================ */

.pf-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.88);
  z-index: 9000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t);
  padding: 2rem;
}
.pf-modal-backdrop.open { opacity: 1; pointer-events: all; }
.pf-modal {
  background: var(--white);
  border-radius: var(--radius-xl);
  max-width: 700px;
  width: 100%;
  overflow: hidden;
  transform: scale(.9);
  transition: transform var(--t);
}
.pf-modal-backdrop.open .pf-modal { transform: scale(1); }
.pf-modal-thumb {
  height: 320px;
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.pf-modal-thumb .pf-thumb-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 28px 28px; }
.pf-modal-thumb-icon { font-size: 4rem; color: rgba(255,255,255,.45); position: relative; z-index: 1; }
.pf-modal-body { padding: 2rem 2.25rem; }
.pf-modal-body h3 { font-size: 1.3rem; margin-bottom: .5rem; }
.pf-modal-body p  { font-size: .93rem; margin-bottom: 1.5rem; }
.pf-modal-close {
  position: absolute;
  top: 1rem; right: 1rem;
  width: 38px; height: 38px;
  background: rgba(0,0,0,.5);
  color: var(--white);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  cursor: pointer;
  border: none;
  z-index: 2;
  transition: background var(--t-fast);
}
.pf-modal-close:hover { background: rgba(0,0,0,.8); }

/* ============================================
   31. TRUST BAR (DARK BG)
   ============================================ */

.trust-bar {
  background: var(--navy-800);
  padding: 1.1rem 0;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

/* ============================================
   32. RESPONSIVE — NEW COMPONENTS
   ============================================ */

/* ============================================
   32A. PRICING PAGE
   ============================================ */

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.pricing-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  position: relative;
  transition: all var(--t);
}
.pricing-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.pricing-card-featured {
  border: 2px solid var(--blue-600);
  box-shadow: 0 16px 40px rgba(37,99,235,.18);
}
.pricing-badge {
  position: absolute;
  top: -12px;
  right: 1rem;
  background: var(--blue-600);
  color: var(--white);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .35rem .75rem;
  border-radius: 100px;
}
.pricing-head h3 {
  font-size: 1.15rem;
  margin-bottom: .45rem;
}
.pricing-price {
  font-family: var(--font-heading);
  font-size: 1.8rem;
  line-height: 1.2;
  color: var(--color-heading);
  margin: 0;
}
.pricing-price span {
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--color-text-muted);
  font-weight: 500;
}
.pricing-list {
  display: flex;
  flex-direction: column;
  gap: .45rem;
  margin: 0;
  padding: 0;
}
.pricing-list li {
  display: flex;
  align-items: flex-start;
  gap: .55rem;
  font-size: .9rem;
  color: var(--color-text-muted);
  line-height: 1.55;
}
.pricing-list li::before {
  content: '✓';
  color: var(--green-500);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: .05em;
}
.pricing-custom {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.pricing-custom h2 {
  font-size: 1.55rem;
  margin-bottom: .5rem;
}
.pricing-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
.pricing-chip-list li {
  background: rgba(37,99,235,.08);
  color: var(--blue-600);
  border: 1px solid rgba(37,99,235,.2);
  border-radius: 100px;
  padding: .38rem .8rem;
  font-size: .82rem;
  font-weight: 600;
}
.addons-table-wrap {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.addons-table {
  width: 100%;
  border-collapse: collapse;
}
.addons-table thead th {
  text-align: left;
  background: var(--navy-900);
  color: var(--white);
  font-size: .85rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: .95rem 1.1rem;
}
.addons-table tbody td {
  padding: .9rem 1.1rem;
  border-top: 1px solid var(--color-border);
  font-size: .92rem;
  color: var(--color-text-muted);
}
.addons-table tbody tr:hover td {
  background: var(--gray-50);
}

@media (max-width: 1100px) {
  .pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
  .about-preview-layout { gap: 3rem; }
}
@media (max-width: 900px) {
  .pricing-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
  .usecase-grid { grid-template-columns: repeat(2, 1fr); }
  .home-timeline { grid-template-columns: 1fr; gap: 1.5rem; }
  .home-timeline::before { display: none; }
  .ht-step { flex-direction: row; text-align: left; align-items: flex-start; }
  .ht-num { margin-bottom: 0; margin-right: 1rem; flex-shrink: 0; }
  .pf-preview-grid { grid-template-columns: repeat(2, 1fr); }
  .about-preview-layout { grid-template-columns: 1fr; gap: 2rem; }
  .about-preview-visual { order: -1; max-width: 340px; margin: 0 auto; }
  .about-preview-placeholder { aspect-ratio: 16/9; }
}
@media (max-width: 700px) {
  .pricing-card,
  .pricing-custom { padding: 1.4rem; }
  .pricing-price { font-size: 1.55rem; }
  .addons-table thead th,
  .addons-table tbody td { padding: .75rem .8rem; }
  .why-grid { grid-template-columns: 1fr; }
  .usecase-grid { grid-template-columns: 1fr; }
  .pf-preview-grid { grid-template-columns: 1fr; }
  .home-timeline { grid-template-columns: 1fr; }
  .pf-filters { justify-content: flex-start; }
}

/* ============================================
   33. WHATSAPP BUTTON & HERO CTA EXTRAS
   ============================================ */

.btn-whatsapp {
  background: #16a34a;
  color: var(--white);
  border-color: #16a34a;
}
.btn-whatsapp:hover {
  background: #15803d;
  border-color: #15803d;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(22,163,74,.35);
}

.hero-secondary-actions {
  margin-top: -1.5rem;
  margin-bottom: 2rem;
}
.hero-call-link {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: rgba(255,255,255,.58);
  font-size: .88rem;
  transition: color var(--t-fast);
  text-decoration: none;
}
.hero-call-link:hover { color: var(--blue-300); }
.hero-call-link i { color: var(--blue-400); }

/* ============================================
   34. TRUST BADGE CARDS
   ============================================ */

.trust-badges-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.trust-badge-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem 1.75rem;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
  text-align: center;
}
.trust-badge-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.trust-badge-icon {
  width: 60px; height: 60px;
  background: linear-gradient(135deg, rgba(37,99,235,.12), rgba(37,99,235,.06));
  color: var(--blue-600);
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  margin: 0 auto 1.25rem;
  transition: all var(--t);
}
.trust-badge-card:hover .trust-badge-icon {
  background: var(--navy-900);
  color: var(--blue-400);
}
.trust-badge-card h3 { font-size: 1rem; margin-bottom: .55rem; }
.trust-badge-card p  { font-size: .875rem; }

/* ============================================
   35. SERVICE AREAS GRID
   ============================================ */

.areas-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.area-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: .65rem;
  text-decoration: none;
  transition: all var(--t);
  box-shadow: var(--shadow-sm);
}
.area-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.25);
}
.area-card-cta { background: var(--gray-50); border-style: dashed; }
.area-card-cta:hover { background: var(--white); }
.area-icon {
  width: 48px; height: 48px;
  background: rgba(37,99,235,.1);
  color: var(--blue-600);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem;
  transition: all var(--t);
}
.area-card:hover .area-icon {
  background: var(--blue-600);
  color: var(--white);
}
.area-card h3 { font-size: 1.05rem; color: var(--color-heading); margin: 0; }
.area-card p  { font-size: .875rem; color: var(--color-text-muted); flex: 1; margin: 0; }
.area-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: var(--blue-600);
  font-size: .875rem;
  font-weight: 600;
  margin-top: .25rem;
}

/* ============================================
   36. LOCAL SEO PAGE STYLES
   ============================================ */

.local-intro-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 4rem;
  align-items: start;
}
.local-benefits-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .65rem;
  margin: 1.5rem 0;
}
.local-benefits-list li {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  font-size: .95rem;
  color: var(--color-text-muted);
}
.local-benefits-list li i { color: var(--green-500); flex-shrink: 0; margin-top: .15em; }
.local-cta-sidebar {
  background: var(--navy-900);
  border-radius: var(--radius-xl);
  padding: 2.5rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.local-cta-sidebar::before {
  content: '';
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(37,99,235,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.06) 1px, transparent 1px);
  background-size: 28px 28px;
}
.local-cta-sidebar-inner { position: relative; z-index: 1; }
.local-cta-sidebar h3 { color: var(--white); font-size: 1.25rem; margin-bottom: .75rem; }
.local-cta-sidebar p  { color: rgba(255,255,255,.55); font-size: .9rem; margin-bottom: 1.5rem; }
.local-cta-sidebar .btn { width: 100%; justify-content: center; margin-bottom: .75rem; }
.local-cta-sidebar .btn:last-child { margin-bottom: 0; }
.local-cta-icon { font-size: 3rem; color: var(--blue-400); opacity: .6; margin-bottom: 1.25rem; }

.local-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.local-service-card {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow-sm);
  transition: all var(--t);
}
.local-service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(37,99,235,.2);
}
.local-service-card .feature-icon { margin-bottom: 1rem; }
.local-service-card h3 { font-size: 1rem; margin-bottom: .45rem; }
.local-service-card p  { font-size: .875rem; }

.faq-list { display: flex; flex-direction: column; gap: 1rem; max-width: 820px; margin: 0 auto; }
.faq-item {
  background: var(--white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 1.5rem;
  cursor: pointer;
  gap: 1rem;
  font-weight: 600;
  font-size: .95rem;
  color: var(--color-heading);
  user-select: none;
  list-style: none;
}
.faq-question::marker,
.faq-question::-webkit-details-marker { display: none; }
.faq-question i { color: var(--blue-600); transition: transform var(--t-fast); flex-shrink: 0; }
details[open] .faq-question i { transform: rotate(180deg); }
.faq-answer { padding: 0 1.5rem 1.25rem; font-size: .93rem; color: var(--color-text-muted); line-height: 1.8; }

/* Responsive for new sections */
@media (max-width: 1100px) {
  .trust-badges-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .trust-badges-grid { grid-template-columns: repeat(2, 1fr); }
  .areas-grid { grid-template-columns: repeat(2, 1fr); }
  .local-intro-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .local-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .trust-badges-grid { grid-template-columns: 1fr; }
  .areas-grid { grid-template-columns: 1fr; }
  .local-services-grid { grid-template-columns: 1fr; }
  .hero-secondary-actions { margin-top: -1rem; }
}