/* ═══════════════════════════════════════════════
   VA PRIME CLEAN — Main Stylesheet
   Modern, minimal, with subtle texture & asymmetry
   ═══════════════════════════════════════════════ */

/* ─── Custom Properties ─── */
:root {
  /* Color system */
  --c-blue-50:  #f0f6ff;
  --c-blue-100: #dfeafc;
  --c-blue-200: #bad3fa;
  --c-blue-300: #7db2f5;
  --c-blue-400: #4a94ef;
  --c-blue-500: #1a6bde;
  --c-blue-600: #1257bb;
  --c-blue-700: #0e4494;
  --c-blue-800: #0a2f69;
  --c-blue-900: #061b3d;

  --c-white:    #ffffff;
  --c-off-white:#f8f9fb;
  --c-gray-50:  #f4f5f7;
  --c-gray-100: #e8eaed;
  --c-gray-200: #d1d4da;
  --c-gray-300: #a8adb6;
  --c-gray-400: #7d8390;
  --c-gray-500: #5a606c;
  --c-gray-600: #3d424d;
  --c-gray-700: #2a2e37;
  --c-gray-800: #1a1d24;
  --c-gray-900: #0d0f13;

  /* Functional tokens */
  --color-primary:    var(--c-blue-500);
  --color-primary-h:  var(--c-blue-600);
  --color-surface:    var(--c-white);
  --color-surface-alt:var(--c-off-white);
  --color-text:       var(--c-gray-800);
  --color-text-muted: var(--c-gray-400);
  --color-border:     var(--c-gray-100);

  /* Typography scale — modular (1.25 ratio) */
  --font-heading: 'Plus Jakarta Sans', system-ui, sans-serif;
  --font-body:    'Plus Jakarta Sans', system-ui, sans-serif;

  --text-xs:   0.875rem;
  --text-sm:   0.875rem;
  --text-base: 1rem;
  --text-lg:   1.125rem;
  --text-xl:   1.25rem;
  --text-2xl:  1.563rem;
  --text-3xl:  1.953rem;
  --text-4xl:  2.441rem;
  --text-5xl:  3.052rem;
  --text-6xl:  3.815rem;

  /* Spacing */
  --space-xs:  0.25rem;
  --space-sm:  0.5rem;
  --space-md:  1rem;
  --space-lg:  1.5rem;
  --space-xl:  2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;
  --space-5xl: 8rem;

  /* Layout */
  --container-max: 1200px;
  --container-pad: clamp(1rem, 4vw, 2rem);
  --header-h: 72px;

  /* Radius */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(10,47,105,0.06);
  --shadow-md: 0 4px 16px rgba(10,47,105,0.08);
  --shadow-lg: 0 8px 32px rgba(10,47,105,0.12);
  --shadow-xl: 0 16px 48px rgba(10,47,105,0.16);

  /* Transitions */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --duration-fast: 150ms;
  --duration-base: 300ms;
  --duration-slow: 500ms;

  /* Grain overlay (subtle texture) */
  --grain: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
}

/* ─── Reset & Base ─── */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  scroll-padding-top: calc(var(--header-h) + 1rem);
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-surface);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

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

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

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

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: 1.15;
  color: var(--c-gray-900);
  letter-spacing: -0.02em;
}

/* Screen reader only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* Focus styles */
:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* ─── Container ─── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* ─── Prose (WYSIWYG content) ─── */
.prose p { margin-bottom: 1em; }
.prose ul, .prose ol { padding-left: 1.5em; margin-bottom: 1em; }
.prose strong { font-weight: 600; }

/* ═══════════════════════════════════════
   PROMO BAR
   ═══════════════════════════════════════ */
.promo-bar {
  background: var(--c-blue-600);
  color: var(--c-white);
  font-size: var(--text-xs);
  font-weight: 500;
  overflow: hidden;
  white-space: nowrap;
  padding: 5px 0;
  letter-spacing: 0.04em;
}

.promo-bar__track {
  display: inline-flex;
  animation: marquee 20s linear infinite;
}

.promo-bar__item {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
}

.promo-bar__item::after {
  content: '\2605';
  opacity: 0.35;
  font-size: 0.5em;
  margin: 0 var(--space-2xl);
}

@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ═══════════════════════════════════════
   HEADER
   ═══════════════════════════════════════ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  height: var(--header-h);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border-bottom: 1px solid var(--color-border);
  transition: background var(--duration-base) var(--ease-out),
              box-shadow var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
}

.site-header.is-scrolled {
  box-shadow: var(--shadow-md);
}


.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: var(--space-lg);
}

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

.site-logo img {
  height: 76px;
  width: auto;
}

/* Nav */
.nav-menu {
  display: flex;
  list-style: none;
  gap: var(--space-xs);
}

.nav-menu a {
  display: block;
  padding: var(--space-sm) var(--space-md);
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--c-gray-600);
  letter-spacing: 0.01em;
  border-radius: var(--radius-full);
  transition: all var(--duration-fast) var(--ease-out);
}

.nav-menu a:hover,
.nav-menu a[aria-current="page"] {
  color: var(--color-primary);
  background: var(--c-blue-50);
}

/* Mobile nav toggle */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1001;
}

.nav-toggle__line {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--c-gray-700);
  border-radius: 2px;
  transition: all var(--duration-base) var(--ease-out);
  transform-origin: center;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__line:nth-child(2) {
  opacity: 0;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ═══════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: 0.65em 1.4em;
  border-radius: var(--radius-full);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--duration-base) var(--ease-out);
  white-space: nowrap;
  text-decoration: none;
  line-height: 1.2;
}

.btn .icon {
  flex-shrink: 0;
}

.btn--primary {
  background: var(--color-primary);
  color: var(--c-white);
  border-color: var(--color-primary);
}

.btn--primary:hover {
  background: var(--color-primary-h);
  border-color: var(--color-primary-h);
  color: var(--c-white);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn--outline {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn--outline:hover {
  background: var(--color-primary);
  color: var(--c-white);
  transform: translateY(-1px);
}

.btn--white {
  background: var(--c-white);
  color: var(--color-primary);
  border-color: var(--c-white);
}

.btn--white:hover {
  background: var(--c-blue-50);
  border-color: var(--c-blue-50);
  color: var(--color-primary-h);
  transform: translateY(-1px);
}

.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.btn--header {
  background: var(--color-primary);
  color: var(--c-white);
  border-color: var(--color-primary);
  font-size: var(--text-xs);
  padding: 0.5em 1.2em;
}

.btn--header:hover {
  background: var(--color-primary-h);
  color: var(--c-white);
}

.btn--header-quote {
  background: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
}

.btn--header-quote:hover {
  background: var(--color-primary);
  color: var(--c-white);
}

.btn--lg {
  font-size: var(--text-base);
  padding: 0.8em 1.8em;
}

.btn--full {
  width: 100%;
}

.btn__loading { display: none; }
.btn.is-loading .btn__text { display: none; }
.btn.is-loading .btn__loading { display: inline; }

/* ═══════════════════════════════════════
   SECTION COMMON
   ═══════════════════════════════════════ */
.section {
  padding: var(--space-4xl) 0;
  position: relative;
}

.section--centered {
  text-align: center;
}

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

.section-header--left {
  text-align: left;
}

.section-tag {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-primary);
  background: var(--c-blue-50);
  padding: 0.3em 0.9em;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-md);
}

.section-title {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-md);
}

.section-desc {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 600px;
  margin-inline: auto;
}

.section-header--left .section-desc {
  margin-inline: 0;
}

.section-footer {
  text-align: center;
  margin-top: var(--space-2xl);
}

/* Alternating sections with subtle grain texture */
.section:nth-child(even),
.service-block--alt {
  background: var(--color-surface-alt);
  background-image: var(--grain);
  background-size: 200px;
}

/* ═══════════════════════════════════════
   HERO
   ═══════════════════════════════════════ */
.hero {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--c-blue-900) var(--hero-desktop-bg, url('../img/hero-bg.webp')) center / cover no-repeat;
  color: var(--c-white);
  isolation: isolate;
  background-position: top;
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(6, 27, 61, 0.85) 0%,
    rgba(6, 27, 61, 0.6) 50%,
    rgba(6, 27, 61, 0.3) 100%
  );
  z-index: 0;
}

.hero__grid {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: calc(100vh - var(--header-h));
  min-height: calc(100dvh - var(--header-h));
  padding-top: var(--space-3xl);
  padding-bottom: var(--space-3xl);
  z-index: 1;
}

.hero__content {
  position: relative;
  z-index: 1;
  max-width: 620px;
}

.hero__tagline {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--c-blue-200);
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.12);
  padding: 0.4em 1.1em;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-xl);
  animation: heroFadeUp 0.7s var(--ease-out) both;
}

.hero__tagline svg {
  flex-shrink: 0;
  opacity: 0.7;
}

/* Title accent span — inherits gradient from parent */

.hero__subtitle strong {
  color: var(--c-white);
  font-weight: 600;
}

.hero__highlight {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--c-blue-200);
  margin-bottom: var(--space-xl);
  animation: heroFadeUp 0.7s var(--ease-out) both;
  animation-delay: 0.3s;
}

.hero__highlight svg {
  flex-shrink: 0;
  color: var(--c-blue-300);
}

.hero__trust {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-xl);
  animation: heroFadeUp 0.7s var(--ease-out) both;
  animation-delay: 0.55s;
}

.hero__trust li {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 0.35em 0.9em;
  border-radius: var(--radius-full);
  backdrop-filter: blur(4px);
}

.hero__trust svg {
  color: var(--c-blue-300);
  flex-shrink: 0;
}

/* Hero entrance animations */
@keyframes heroFadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes heroFadeIn {
  from { opacity: 0; transform: translateX(32px) scale(0.97); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}

@keyframes heroSecondaryIn {
  from { opacity: 0; transform: translate(56px, 48px) scale(0.92); }
  to   { opacity: 1; transform: translate(24px, 48px) scale(1); }
}

@keyframes heroBadgePop {
  from { opacity: 0; transform: scale(0.8); }
  to   { opacity: 1; transform: scale(1); }
}

.hero__title {
  font-size: clamp(var(--text-4xl), 6vw, 4.5rem);
  font-weight: 800;
  margin-bottom: var(--space-md);
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--c-white);
  animation: heroFadeUp 0.7s var(--ease-out) both;
  animation-delay: 0.1s;
}

.hero__subtitle {
  font-size: clamp(var(--text-lg), 2.2vw, var(--text-xl));
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: var(--space-md);
  line-height: 1.5;
  max-width: 520px;
  animation: heroFadeUp 0.7s var(--ease-out) both;
  animation-delay: 0.2s;
}

.hero__actions {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  animation: heroFadeUp 0.7s var(--ease-out) both;
  animation-delay: 0.4s;
}

.hero__btn-mobile-only {
  display: none;
}

/* Hero visuals — hidden (desktop uses background image) */
.hero__visuals {
  display: none;
}

.hero__image {
  overflow: hidden;
  box-shadow: var(--shadow-xl);
}

.hero__image--main {
  grid-column: 1 / -1;
  grid-row: 1;
  border-radius: var(--radius-xl);
  z-index: 1;
  animation: heroFadeIn 0.8s var(--ease-out) both;
  animation-delay: 0.3s;
}

.hero__image--secondary {
  grid-column: 2;
  grid-row: 1;
  align-self: end;
  border-radius: var(--radius-lg);
  border: 4px solid var(--c-white);
  box-shadow: var(--shadow-xl), 0 0 0 1px rgba(0,0,0,0.04);
  transform: translate(24px, 48px);
  z-index: 2;
  max-width: 220px;
  animation: heroSecondaryIn 0.8s var(--ease-out) both;
  animation-delay: 0.55s;
}

.hero__image--secondary .hero__img {
  aspect-ratio: 3 / 4;
}

.hero__img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.hero__image--main .hero__img {
  aspect-ratio: 16 / 10;
}

/* Floating badge on the hero images */
.hero__float-badge {
  position: absolute;
  top: var(--space-lg);
  left: calc(-1 * var(--space-lg));
  z-index: 3;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--c-white);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--c-gray-700);
  white-space: nowrap;
  animation: heroBadgePop 0.5s var(--ease-out) both;
  animation-delay: 0.8s;
}

.hero__float-badge svg {
  color: var(--color-primary);
  flex-shrink: 0;
}

/* Outline button variant for dark hero */
.btn--outline-dark {
  border: 2px solid rgba(255, 255, 255, 0.35);
  color: var(--c-white);
  background: transparent;
}

.btn--outline-dark:hover {
  border-color: var(--c-white);
  color: var(--c-white);
  background: rgba(255, 255, 255, 0.1);
  transform: translateY(-1px);
}

/* Trust badge strip at bottom of hero */
.hero__badges {
  padding: var(--space-lg) 0;
  background: rgba(255, 255, 255, 0.06);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position: relative;
  z-index: 1;
}

.badge-strip {
  display: flex;
  list-style: none;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-lg) var(--space-2xl);
}

.badge-strip__item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.9);
  white-space: nowrap;
}

.badge-strip__item svg {
  opacity: 0.8;
  color: var(--c-blue-200);
}

/* ═══════════════════════════════════════
   SERVICES OVERVIEW (Home)
   ═══════════════════════════════════════ */
.services-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-lg);
  justify-content: center;
}

.services-grid .service-card {
  flex: 0 1 calc(25% - var(--space-lg) * 0.75);
  min-width: 220px;
}

.service-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--space-xl);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: all var(--duration-base) var(--ease-out);
  text-decoration: none;
  color: var(--color-text);
  overflow: hidden;
}

.service-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-blue-400), var(--c-blue-600));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--duration-base) var(--ease-out);
}

.service-card:hover {
  color: var(--color-text);
}

.service-card:hover::before {
  transform: scaleX(0);
}

.service-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  background: var(--c-blue-50);
  border-radius: var(--radius-md);
  color: var(--color-primary);
  margin-bottom: 0;
  transition: all var(--duration-base) var(--ease-out);
}

.service-card:hover .service-card__icon {
  background: var(--c-blue-50);
  color: var(--color-primary);
}

.services-grid .service-card__title {
  font-size: var(--text-base);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-xs);
}

.service-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
  margin: 0;
}

.service-card__price {
  font-size: var(--text-sm);
  color: var(--color-primary);
  font-weight: 600;
}

.service-card__badge {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  background: #ef4444;
  color: var(--c-white);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 0.15em 0.6em;
  border-radius: var(--radius-full);
  letter-spacing: 0.05em;
}

.service-card__arrow {
  margin-top: auto;
  padding-top: var(--space-md);
  font-size: var(--text-xl);
  color: var(--color-text-muted);
  transition: all var(--duration-fast) var(--ease-out);
}

.service-card:hover .service-card__arrow {
  color: var(--c-gray-300);
  transform: none;
}

/* ═══════════════════════════════════════
   BEFORE / AFTER SLIDER
   ═══════════════════════════════════════ */
.ba-carousel {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-xl);
}

.ba-slider {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--c-gray-100);
}

.ba-slider__wrapper {
  position: relative;
  overflow: hidden;
  cursor: ew-resize;
  aspect-ratio: 4/3;
}

.ba-slider__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ba-slider__before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  clip-path: inset(0 50% 0 0);
}

.ba-slider__handle {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 4px;
  transform: translateX(-50%);
  cursor: ew-resize;
  z-index: 2;
}

.ba-slider__handle-line {
  position: absolute;
  inset: 0;
  background: var(--c-white);
  box-shadow: 0 0 8px rgba(0,0,0,0.3);
}

.ba-slider__handle-circle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--c-white);
  box-shadow: var(--shadow-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
}

.ba-slider__caption {
  padding: var(--space-md) var(--space-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-muted);
}

/* Labels */
.ba-slider__wrapper::before,
.ba-slider__wrapper::after {
  position: absolute;
  top: var(--space-md);
  z-index: 3;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.3em 0.7em;
  border-radius: var(--radius-full);
  pointer-events: none;
}

.ba-slider__wrapper::before {
  content: 'Before';
  left: var(--space-md);
  background: rgba(0,0,0,0.6);
  color: var(--c-white);
}

.ba-slider__wrapper::after {
  content: 'After';
  right: var(--space-md);
  background: var(--color-primary);
  color: var(--c-white);
}

/* Combined before/after photo */
.ba-combined {
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.ba-combined__img {
  width: 100%;
  height: auto;
  transition: transform var(--duration-slow) var(--ease-out);
}

.ba-combined:hover .ba-combined__img {
  transform: scale(1.03);
}

.ba-combined__caption {
  padding: var(--space-md) var(--space-lg);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  background: var(--color-surface);
}

/* ═══════════════════════════════════════
   WHY CHOOSE US
   ═══════════════════════════════════════ */
.why-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-xl);
}

.why-card {
  padding: var(--space-2xl) var(--space-xl);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  transition: all var(--duration-base) var(--ease-out);
  /* Asymmetric visual: offset border accent */
  border-left: 3px solid transparent;
}

.why-card:hover {
  border-left-color: var(--color-primary);
  box-shadow: var(--shadow-md);
  transform: translateX(4px);
}

.why-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: var(--c-blue-50);
  color: var(--color-primary);
  margin-bottom: var(--space-lg);
}

.why-card__title {
  font-size: var(--text-lg);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-sm);
}

.why-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* ═══════════════════════════════════════
   OUR PROCESS
   ═══════════════════════════════════════ */
.process-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2xl);
  position: relative;
  counter-reset: process;
}

/* Dashed connector line between steps (desktop) */
.process-steps::before {
  content: '';
  position: absolute;
  top: 24px;
  left: calc(16.667% + 24px);
  right: calc(16.667% + 24px);
  height: 2px;
  border-top: 2px dashed var(--color-border);
}

.process-step {
  text-align: center;
  position: relative;
}

.process-step__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--c-white);
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--space-lg);
  position: relative;
  z-index: 1;
}

.process-step__title {
  font-size: var(--text-lg);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-sm);
}

.process-step__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
  max-width: 280px;
  margin-inline: auto;
}

/* ═══════════════════════════════════════
   VIDEO SECTION
   ═══════════════════════════════════════ */
/* Video slider */
.video-slider {
  position: relative;
}

.video-slider__track {
  display: flex;
  gap: var(--space-lg);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: var(--space-sm);
}

.video-slider__track::-webkit-scrollbar {
  display: none;
}

.video-slider__track .video-card {
  flex: 0 0 280px;
  scroll-snap-align: start;
}

.video-slider__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-70%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: var(--c-white);
  box-shadow: var(--shadow-lg);
  color: var(--c-gray-700);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--duration-fast) var(--ease-out);
  z-index: 2;
}

.video-slider__btn:hover {
  background: var(--color-primary);
  color: var(--c-white);
  box-shadow: var(--shadow-xl);
}

.video-slider__btn--prev { left: -22px; }
.video-slider__btn--next { right: -22px; }

.video-slider__btn:disabled {
  opacity: 0.3;
  cursor: default;
  pointer-events: none;
}

.video-card__wrapper {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--c-gray-900);
  aspect-ratio: 9/16;
}

.video-card__player {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: cover;
  object-position: center;
}

.video-card__play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  color: var(--c-white);
  border: none;
  cursor: pointer;
  transition: all var(--duration-base) var(--ease-out);
}

.video-card__play:hover {
  background: rgba(0, 0, 0, 0.15);
}

.video-card__play svg {
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.4));
  transition: transform var(--duration-base) var(--ease-out);
}

.video-card__play:hover svg {
  transform: scale(1.15);
}

.video-card.is-playing .video-card__play {
  opacity: 0;
  pointer-events: none;
}

.video-card__title {
  padding: var(--space-md) 0;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-muted);
}

/* ═══════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════ */
.section.testimonials-section {
  background: var(--c-blue-800);
  background-image: var(--grain);
  background-size: 200px;
  color: var(--c-white);
}

.testimonials-section .section-tag {
  background: rgba(255,255,255,0.12);
  color: var(--c-blue-200);
}

.testimonials-section .section-title {
  color: var(--c-white);
}

.testimonial-track {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-xl);
}

.testimonial-card {
  padding: var(--space-xl);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(4px);
}

.testimonial-card__stars {
  display: flex;
  gap: 2px;
  margin-bottom: var(--space-md);
  color: #facc15;
}

.star { opacity: 0.3; }
.star--filled { opacity: 1; }

.testimonial-card__text {
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.7;
  margin-bottom: var(--space-sm);
  font-style: italic;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.testimonial-card__text.is-expanded {
  display: block;
  -webkit-line-clamp: unset;
}

.testimonial-card__toggle {
  background: none;
  border: none;
  color: var(--c-blue-300);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  margin-bottom: var(--space-lg);
  transition: color var(--duration-fast) var(--ease-out);
  display: none;
}

.testimonial-card__toggle.is-visible {
  display: inline-block;
}

.testimonial-card__toggle:hover {
  color: var(--c-white);
}

.testimonial-card__footer {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.testimonial-card__name {
  font-style: normal;
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--c-white);
}

.testimonial-card__service {
  font-size: var(--text-xs);
  color: var(--c-blue-300);
}

/* ═══════════════════════════════════════
   REVIEW BUTTON & MODAL
   ═══════════════════════════════════════ */
.btn--review {
  background: rgba(255, 255, 255, 0.12);
  color: var(--c-white);
  border: 1.5px solid rgba(255, 255, 255, 0.25);
  margin-top: var(--space-md);
}

.btn--review:hover {
  background: rgba(255, 255, 255, 0.2);
  color: var(--c-white);
  border-color: rgba(255, 255, 255, 0.4);
  transform: translateY(-1px);
}

.btn--review .icon {
  color: #facc15;
}

/* Modal overlay */
.review-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--duration-base) var(--ease-out),
              visibility var(--duration-base);
}

.review-modal.is-open {
  opacity: 1;
  visibility: visible;
}

.review-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}

.review-modal__panel {
  position: relative;
  width: 90%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--c-white);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-xl);
  transform: translateY(20px) scale(0.97);
  transition: transform var(--duration-base) var(--ease-out);
}

.review-modal.is-open .review-modal__panel {
  transform: translateY(0) scale(1);
}

.review-modal__close {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-gray-50);
  border: none;
  border-radius: var(--radius-full);
  color: var(--c-gray-500);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}

.review-modal__close:hover {
  background: var(--c-gray-100);
  color: var(--c-gray-800);
}

.review-form__title {
  font-size: var(--text-2xl);
  color: var(--c-gray-900);
  margin-bottom: var(--space-xs);
}

.review-form__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-xl);
}

/* Star picker */
.star-picker {
  display: flex;
  gap: var(--space-xs);
}

.star-picker__star {
  background: none;
  border: none;
  padding: 2px;
  cursor: pointer;
  color: var(--c-gray-200);
  transition: color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}

.star-picker__star:hover {
  transform: scale(1.15);
}

.star-picker__star.is-active svg {
  fill: #facc15;
  stroke: #facc15;
  color: #facc15;
}

.star-picker__star.is-hovered svg {
  fill: #fde68a;
  stroke: #fde68a;
  color: #fde68a;
}

/* ═══════════════════════════════════════
   SERVICE AREAS (with map)
   ═══════════════════════════════════════ */
.service-areas__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--space-2xl);
  align-items: start;
}

.service-areas__map iframe {
  width: 100%;
  height: 400px;
  border: 0;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.service-areas__group {
  margin-bottom: var(--space-xl);
}

.service-areas__group:last-child {
  margin-bottom: 0;
}

.service-areas__group-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--space-md);
  color: var(--c-gray-800);
}

.service-areas__group-title svg {
  color: var(--color-primary);
  flex-shrink: 0;
}

.service-areas__cities {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm) var(--space-lg);
}

.service-areas__cities li {
  font-size: var(--text-sm);
  color: var(--c-gray-600);
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.service-areas__cities li::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary);
  opacity: 0.5;
  flex-shrink: 0;
}

.vpc-map-pin {
  background: none !important;
  border: none !important;
}

#vpc-service-map {
  box-shadow: var(--shadow-md);
}

#vpc-service-map .leaflet-control-attribution {
  display: none !important;
}

/* ═══════════════════════════════════════
   FAQ SECTION
   ═══════════════════════════════════════ */
.faq-list {
  max-width: 800px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.faq-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  overflow: hidden;
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}

.faq-item:hover {
  border-color: var(--c-blue-200);
}

.faq-item.is-open {
  border-color: var(--c-blue-200);
  box-shadow: var(--shadow-sm);
}

.faq-item__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-lg) var(--space-xl);
  background: none;
  border: none;
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--c-gray-800);
  text-align: left;
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-out);
}

.faq-item__question:hover {
  color: var(--color-primary);
}

.faq-item__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  transition: transform var(--duration-base) var(--ease-out);
}

.faq-item.is-open .faq-item__icon {
  transform: rotate(45deg);
}

.faq-item__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--duration-base) var(--ease-out);
}

.faq-item__answer-inner {
  padding: 0 var(--space-xl) var(--space-lg);
  font-size: var(--text-sm);
  color: var(--c-gray-500);
  line-height: 1.7;
}

/* ═══════════════════════════════════════
   INFO NOTICE
   ═══════════════════════════════════════ */
.info-notice {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-xl);
  background: var(--c-blue-50);
  border: 1px solid var(--c-blue-200);
  border-radius: var(--radius-md);
  margin: var(--space-xl) auto;
  max-width: max-content;
  white-space: nowrap;
}

.info-notice__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
}

.info-notice__icon {
  flex-shrink: 0;
  color: #f59e0b;
}

.info-notice__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--c-blue-800);
}

.info-notice__text {
  font-size: var(--text-sm);
  color: var(--c-blue-800);
  line-height: 1.6;
}

.info-notice__text .mobile-br {
  display: none;
}

/* ═══════════════════════════════════════
   CTA SECTION
   ═══════════════════════════════════════ */
.section.cta-section {
  background: linear-gradient(135deg, var(--c-blue-600) 0%, var(--c-blue-800) 100%), var(--grain);
  background-size: auto, 200px;
  color: var(--c-white);
  padding: var(--space-4xl) 0;
}

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

.cta-title {
  font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--c-white);
  margin-bottom: var(--space-md);
}

.cta-text {
  color: rgba(255, 255, 255, 0.8);
  font-size: var(--text-lg);
  margin-bottom: var(--space-xl);
  line-height: 1.6;
}

.cta-section--compact {
  text-align: center;
}

.cta-section--compact .cta-title {
  margin-bottom: var(--space-sm);
}

.cta-section--compact .cta-text {
  max-width: 520px;
  margin-inline: auto;
  margin-bottom: var(--space-xl);
}

/* ═══════════════════════════════════════
   QUOTE FORM
   ═══════════════════════════════════════ */
.cta-form-wrapper {
  background: var(--c-white);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-xl);
}

.quote-form .btn--full {
  padding-top: 1em;
  padding-bottom: 1em;
}

.quote-form__title {
  font-size: var(--text-2xl);
  color: var(--c-gray-900);
  margin-bottom: var(--space-xl);
}

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

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}

.form-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--c-gray-600);
  margin-bottom: var(--space-xs);
}

.form-label span { color: var(--color-primary); }

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: 0.7em 1em;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--c-gray-50);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: all var(--duration-fast) var(--ease-out);
  appearance: none;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--c-blue-100);
  background: var(--c-white);
}

.form-select {
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237d8390' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1em center;
  padding-right: 2.5em;
}

.form-textarea {
  resize: vertical;
  min-height: 80px;
}

.form-status {
  margin-top: var(--space-md);
  font-size: var(--text-sm);
  font-weight: 500;
}

.form-status--success { color: #16a34a; }
.form-status--error { color: #dc2626; }

/* ═══════════════════════════════════════
   PAGE HERO (inner pages)
   ═══════════════════════════════════════ */
.page-hero {
  position: relative;
  padding: 60px 0;
  background: linear-gradient(135deg, var(--c-blue-900) 0%, var(--c-blue-800) 40%, var(--c-blue-700) 100%);
  color: var(--c-white);
  text-align: center;
  overflow: hidden;
  isolation: isolate;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 20% 100%, rgba(26, 107, 222, 0.25) 0%, transparent 70%),
    radial-gradient(ellipse 50% 60% at 80% 0%, rgba(74, 148, 239, 0.2) 0%, transparent 70%),
    var(--grain);
  background-size: auto, auto, 200px;
  z-index: -1;
}

.page-hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.12) 50%, transparent 100%);
}

.page-hero .container {
  position: relative;
}

.page-hero__tag {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--c-blue-200);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 0.35em 1em;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-lg);
}

.page-hero__title {
  font-size: clamp(var(--text-3xl), 6vw, var(--text-5xl));
  font-weight: 800;
  color: var(--c-white);
  margin-bottom: var(--space-md);
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.page-hero__desc {
  font-size: var(--text-lg);
  color: var(--c-blue-200);
  max-width: 580px;
  margin-inline: auto;
  line-height: 1.7;
}

.page-hero__divider {
  width: 48px;
  height: 3px;
  background: linear-gradient(90deg, var(--c-blue-400), var(--c-blue-300));
  border: none;
  border-radius: var(--radius-full);
  margin: var(--space-lg) auto 0;
}

/* ═══════════════════════════════════════
   SERVICE NAV (sticky nav on services page)
   ═══════════════════════════════════════ */
.service-nav {
  position: sticky;
  top: var(--header-h);
  z-index: 100;
  background: var(--c-white);
  border-bottom: 1px solid var(--color-border);
  box-shadow: 0 2px 8px rgba(10, 47, 105, 0.04);
  padding: var(--space-md) 0;
}

.service-nav__list {
  display: flex;
  list-style: none;
  gap: var(--space-sm);
  flex-wrap: wrap;
  justify-content: center;
}

.service-nav__link {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 0.5em 1.1em;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--c-gray-500);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background: var(--c-white);
  transition: all var(--duration-fast) var(--ease-out);
  text-decoration: none;
  white-space: nowrap;
}

.service-nav__link svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.service-nav__link:hover {
  color: var(--color-primary);
  border-color: var(--c-blue-200);
  background: var(--c-blue-50);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.service-nav__link.is-active {
  color: var(--c-white);
  background: var(--color-primary);
  border-color: var(--color-primary);
  box-shadow: var(--shadow-sm);
}

.service-nav__link.is-active svg {
  color: var(--c-white);
}

/* ═══════════════════════════════════════
   SERVICE BLOCKS (Services page)
   ═══════════════════════════════════════ */
.services-list {
  padding: 0 0 var(--space-3xl);
}

.service-block {
  padding: var(--space-3xl) 0;
  scroll-margin-top: calc(var(--header-h) + 20px);
  background: none !important;
  background-image: none !important;
  border-top: 1px solid var(--c-gray-200);
}

.service-block:first-child {
  border-top: none;
}

/* Service Card — minimal section layout */
.service-block .service-card {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  overflow: visible;
}


/* Row 1: intro full width */
.service-block .service-card__intro {
  grid-column: 1;
  grid-row: 1;
  padding: 0 0 var(--space-xl);
}

/* Row 2: 3-column — image | features+pricing */
.service-block .service-card__visual,
.service-block .service-card__details {
  grid-column: 1;
  grid-row: 2;
}

/* Use a sub-grid wrapper via CSS — visual + details share row 2 */
.service-block .service-card {
  grid-template-columns: 1fr 1fr 1fr;
}

.service-block .service-card__intro {
  grid-column: 1 / -1;
}

.service-block .service-card__visual {
  grid-column: 1;
  grid-row: 2;
  overflow: hidden;
  position: relative;
  border-radius: var(--radius-lg);
  aspect-ratio: 1 / 1;
}

.service-block .service-card__details {
  grid-column: 2 / -1;
  grid-row: 2;
  padding: 0 0 0 var(--space-2xl);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* No alternating on minimal layout */
.service-block--alt .service-card {
  grid-template-columns: 1fr 1fr 1fr;
}

.service-block--alt .service-card__visual {
  grid-column: 1;
}

.service-block--alt .service-card__intro {
  grid-column: 1 / -1;
}

.service-block--alt .service-card__details {
  grid-column: 2 / -1;
}

/* Image — fills the visual container */
.service-block .service-card__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: cover;
  object-position: center;
  display: block;
  border-radius: var(--radius-lg);
}

.service-card__visual .emergency-badge {
  position: absolute;
  top: var(--space-lg);
  left: var(--space-lg);
  background: #dc2626;
  color: var(--c-white);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 0.4em 1em;
  border-radius: var(--radius-full);
  letter-spacing: 0.03em;
  animation: pulse-badge 2s infinite;
  z-index: 1;
}

.service-block--alt .service-card__visual .emergency-badge {
  left: auto;
  right: var(--space-lg);
}

@keyframes pulse-badge {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

.service-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.service-card__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-blue-50);
  color: var(--color-primary);
  border-radius: var(--radius-md);
  flex-shrink: 0;
}

.service-card__icon svg {
  width: 22px;
  height: 22px;
}

.service-card__title {
  font-size: var(--text-2xl);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--c-gray-900);
}

.service-card__desc {
  color: var(--c-gray-500);
  line-height: 1.7;
  font-size: var(--text-sm);
}

/* Feature list */
.service-card__features {
  list-style: none;
  margin-bottom: var(--space-xl);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xs) var(--space-md);
}

.service-card__features li {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--c-gray-600);
}

.service-card__features .icon {
  color: #16a34a;
  flex-shrink: 0;
  width: 14px;
  height: 14px;
}

/* Pricing Table */
.pricing-table {
  background: var(--c-gray-50);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-xl);
}

.pricing-table__header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-lg);
  background: var(--c-blue-900);
  font-family: var(--font-heading);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--c-white);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pricing-table__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-lg);
  border-top: 1px solid var(--c-gray-100);
  transition: background var(--duration-fast);
  align-items: center;
}

.pricing-table__row:hover {
  background: var(--c-white);
}

.pricing-table__label {
  font-size: var(--text-xs);
  color: var(--c-gray-600);
  font-weight: 500;
}

.pricing-table__price {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 800;
  color: var(--color-primary);
  white-space: nowrap;
}

/* CTA button in card */
.service-card__details .btn {
  align-self: flex-start;
  margin-top: var(--space-md);
}

/* Pricing notes */
.services-footer {
  text-align: center;
}

.promo-callout {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  padding: var(--space-lg) var(--space-xl);
  background: var(--c-blue-50);
  border: 1px solid var(--c-blue-200);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-xl);
  color: var(--color-primary);
  font-weight: 600;
}

.promo-callout--inline {
  justify-content: flex-start;
}

.promo-callout .icon {
  flex-shrink: 0;
  color: #facc15;
}

.promo-callout p { margin: 0; }

.pricing-note {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-xl);
  font-style: italic;
}

.service-block .pricing-note {
  padding-top: 5px;
  margin-bottom: 0;
}

.services-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
}

.services-cta p {
  font-size: var(--text-lg);
  font-weight: 500;
}

/* ═══════════════════════════════════════
   GALLERY PAGE
   ═══════════════════════════════════════ */
.gallery-filter {
  padding: var(--space-lg) 0;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: var(--header-h);
  z-index: 100;
}

.filter-bar {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
  justify-content: center;
}

.filter-btn {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: 500;
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  color: var(--c-gray-500);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}

.filter-btn:hover {
  border-color: var(--c-blue-200);
  color: var(--color-primary);
}

.filter-btn.is-active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--c-white);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: var(--space-xl);
}

.gallery-grid--photos {
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.gallery-section__title {
  font-size: var(--text-2xl);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-xl);
}

.gallery-item {
  transition: opacity var(--duration-base) var(--ease-out);
}

.gallery-item.is-hidden {
  display: none;
}

/* ═══════════════════════════════════════
   ABOUT PAGE
   ═══════════════════════════════════════ */
.about-intro {
  padding: var(--space-5xl) 0;
  overflow: hidden;
}

.about-intro__grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: var(--space-4xl);
  align-items: center;
}

.about-intro__photo {
  order: 2;
}

.about-intro__content {
  order: 1;
}

/* Photo side */
.about-intro__photo {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.about-intro__photo img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: var(--radius-xl);
}

.about-intro__badge {
  position: absolute;
  bottom: var(--space-lg);
  left: var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-full);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.about-intro__badge svg {
  color: var(--color-primary);
  flex-shrink: 0;
}

.about-intro__badge span {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--c-gray-800);
  white-space: nowrap;
}

/* Content side */
.about-intro__content .section-tag {
  margin-bottom: var(--space-md);
}

.about-intro__content .section-title {
  font-size: clamp(var(--text-3xl), 4vw, var(--text-4xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-xl);
  line-height: 1.2;
}

.about-intro__text {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--c-gray-500);
  margin-bottom: var(--space-sm);
}

.about-intro__text:last-of-type {
  margin-bottom: var(--space-2xl);
}

/* Feature cards */
.about-intro__features {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.about-intro__feature {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
}

.about-intro__feature-icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-blue-50);
  color: var(--color-primary);
  border-radius: var(--radius-md);
  flex-shrink: 0;
}

.about-intro__feature strong {
  display: block;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--c-gray-800);
  margin-bottom: 1px;
}

.about-intro__feature span {
  font-size: var(--text-xs);
  color: var(--c-gray-400);
}

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

.about-location__van img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}

#vpc-about-map {
  box-shadow: var(--shadow-md);
}

#vpc-about-map .leaflet-control-attribution {
  display: none !important;
}

.about-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--space-3xl);
  align-items: start;
}

.about-img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}


/* Certifications */
.certs-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xl);
  justify-content: center;
}

.cert-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}

.cert-item__img {
  width: 80px;
  height: 80px;
  object-fit: contain;
}

.cert-item__title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--c-gray-600);
}

/* ═══════════════════════════════════════
   404 PAGE
   ═══════════════════════════════════════ */
.error-404 {
  text-align: center;
  padding: var(--space-3xl) 0;
}

.error-404__code {
  display: block;
  font-family: var(--font-heading);
  font-size: clamp(6rem, 15vw, 12rem);
  font-weight: 700;
  color: var(--c-blue-100);
  line-height: 1;
  margin-bottom: var(--space-lg);
}

.error-404__text {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2xl);
  max-width: 420px;
  margin-inline: auto;
}

.error-404__actions {
  display: flex;
  justify-content: center;
  gap: var(--space-md);
}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.site-footer {
  background: var(--c-gray-900);
  color: var(--c-gray-300);
  padding: var(--space-4xl) 0 var(--space-xl);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-2xl);
  margin-bottom: var(--space-3xl);
}

.footer-logo {
  display: inline-block;
  margin-bottom: var(--space-md);
}

.footer-logo img {
  height: 84px;
  width: auto;
}

.footer-tagline {
  font-size: var(--text-sm);
  color: var(--c-gray-400);
  line-height: 1.6;
  margin-bottom: var(--space-lg);
  max-width: 280px;
}

.footer-social {
  display: flex;
  gap: var(--space-md);
}

.footer-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.06);
  color: var(--c-gray-400);
  transition: all var(--duration-fast) var(--ease-out);
}

.footer-social a:hover {
  background: var(--color-primary);
  color: var(--c-white);
}

.footer-heading {
  font-size: var(--text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-gray-100);
  margin-bottom: var(--space-lg);
}

.footer-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.footer-links a {
  font-size: var(--text-sm);
  color: var(--c-gray-400);
  transition: color var(--duration-fast);
}

.footer-links a:hover {
  color: var(--c-white);
}

.footer-contact {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.footer-contact li {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
}

.footer-contact .icon {
  flex-shrink: 0;
  color: var(--color-primary);
}

.footer-contact a {
  color: var(--c-gray-400);
}

.footer-contact a:hover {
  color: var(--c-white);
}

/* Footer bottom */
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: var(--space-xl);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.footer-badges {
  display: flex;
  gap: var(--space-lg);
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--c-gray-400);
}

.badge .icon {
  color: var(--color-primary);
}

.footer-copy {
  font-size: var(--text-xs);
  color: var(--c-gray-500);
}

/* ═══════════════════════════════════════
   MOBILE CTA (Sticky Bottom Bar)
   ═══════════════════════════════════════ */
.mobile-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 999;
  padding: var(--space-sm);
  background: var(--c-white);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -4px 16px rgba(0,0,0,0.08);
  gap: var(--space-sm);
}

.mobile-cta__btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-md);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: 600;
  border-radius: var(--radius-md);
  text-decoration: none;
}

.mobile-cta__btn--call {
  background: var(--color-primary);
  color: var(--c-white);
}

.mobile-cta__btn--quote {
  background: var(--c-gray-100);
  color: var(--c-gray-700);
}

/* ═══════════════════════════════════════
   SCROLL ANIMATIONS (CSS-only with IntersectionObserver trigger)
   ═══════════════════════════════════════ */
[data-aos] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--duration-slow) var(--ease-out),
              transform var(--duration-slow) var(--ease-out);
}

[data-aos].is-visible {
  opacity: 1;
  transform: translateY(0);
}

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

/* Tablet */
@media (max-width: 1024px) {
  .cta-grid {
    grid-template-columns: 1fr;
  }

  .service-block {
    padding: var(--space-xl) 0;
    border-top: none;
  }

  .service-block .service-card {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    background: var(--c-white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06), 0 1px 3px rgba(0, 0, 0, 0.04);
    border: 1px solid var(--c-gray-100);
  }

  .service-block--alt .service-card {
    grid-template-columns: 1fr;
  }

  /* Mobile order: intro → image → details */
  .service-block .service-card__intro,
  .service-block--alt .service-card__intro {
    grid-column: 1;
    grid-row: auto;
    padding: 20px 20px 12px;
  }

  .service-block .service-card__visual,
  .service-block--alt .service-card__visual {
    grid-column: 1;
    grid-row: auto;
    position: relative;
    height: 300px;
    aspect-ratio: auto;
    border-radius: 0;
  }

  .service-block .service-card__image {
    position: relative;
    height: 100%;
    overflow: hidden;
  }

  .service-block .service-card__img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    border-radius: 0;
  }

  .service-block .service-card__icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--c-blue-50);
    color: var(--color-primary);
    border-radius: var(--radius-md);
    flex-shrink: 0;
    margin-bottom: 0;
  }

  .service-block .service-card__details,
  .service-block--alt .service-card__details {
    grid-column: 1;
    grid-row: auto;
    padding: 20px;
  }

  .service-card__features {
    grid-template-columns: 1fr;
  }

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

  .about-intro__grid,
  .about-location__grid,
  .about-grid {
    grid-template-columns: 1fr;
  }

  .about-intro__photo {
    order: -1 !important;
  }

  .about-intro__content {
    order: unset;
  }

  .about-intro__badge {
    bottom: var(--space-md);
    left: var(--space-md);
  }

  .service-areas__grid {
    grid-template-columns: 1fr;
  }
}

/* Mobile */
@media (max-width: 768px) {
  :root {
    --header-h: 75px;
    --space-4xl: 4rem;
    --space-5xl: 5rem;
  }

  /* Header mobile — solid white, no backdrop-filter
     (backdrop-filter creates a containing block that traps
      position:fixed children inside the header) */
  .site-header {
    background: var(--c-white);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .nav-toggle {
    display: flex;
    position: relative;
    z-index: 1002;
  }

  .nav-toggle__line {
    background: var(--c-blue-800) !important;
  }

  .nav-menu {
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    background: var(--c-white);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease, visibility 0.25s;
    z-index: 1001;
  }

  .nav-menu.is-open {
    opacity: 1;
    visibility: visible;
  }

  .nav-menu a {
    font-size: var(--text-3xl);
    font-weight: 700;
    padding: var(--space-md) var(--space-2xl);
    color: var(--c-gray-800);
    border-radius: var(--radius-lg);
    transition: all 0.2s ease;
    letter-spacing: -0.01em;
  }

  .nav-menu a:hover,
  .nav-menu a[aria-current="page"] {
    color: var(--color-primary);
    background: var(--c-blue-50);
  }

  .site-header.site-header--home {
    padding: 10px 0;
  }

  .site-logo img {
    height: 79px;
  }

  .header-actions {
    display: none;
  }

  .nav-toggle[aria-expanded="true"] .nav-toggle__line {
    background: var(--c-blue-800) !important;
  }

  /* Hero — mobile: use ACF mobile bg, bottom-aligned content */
  @keyframes heroMobileBgIn {
    from { opacity: 0; }
    to   { opacity: 1; }
  }

  .hero {
    background-image: none;
  }

  .hero.has-mobile-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--hero-mobile-bg, url('../img/hero-bg-mobile.webp')) center top / cover no-repeat;
    z-index: -1;
    animation: heroMobileBgIn 0.8s ease both;
    animation-delay: 0.1s;
  }

  .hero:not(.has-mobile-bg)::after {
    content: '';
    position: absolute;
    inset: 0;
    background: url('../img/hero-bg-mobile.webp') center top / cover no-repeat;
    z-index: -1;
  }

  .hero__grid {
    min-height: 100svh;
    padding-top: var(--header-h);
    padding-bottom: 30%;
    justify-content: flex-end;
    align-items: center;
  }

  .hero::before {
    background: linear-gradient(
      180deg,
      rgba(6, 27, 61, 0.8) 0%,
      rgba(6, 27, 61, 0.65) 50%,
      rgba(6, 27, 61, 0.85) 100%
    );
  }

  .hero__subtitle {
    width: 80%;
    margin-inline: auto;
  }

  .hero__content {
    padding-bottom: 0;
    max-width: none;
    text-align: center;
    align-items: center;
    padding-top: 90px;
  }

  .hero__title {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }

  .hero__actions {
    flex-direction: column;
    align-items: center;
    width: 100%;
  }

  .hero__actions .btn {
    text-align: center;
    width: 100%;
  }

  .hero__btn-mobile-only {
    display: inline-flex;
  }

  .hero__trust {
    justify-content: center;
  }

  .hero .btn--outline-dark {
    display: none;
  }

  .hero__title {
    font-size: 48px;
  }


  /* Grids */
  .services-grid {
    gap: var(--space-md);
  }

  .services-grid .service-card {
    flex: 0 1 calc(50% - var(--space-md) * 0.5);
    min-width: 140px;
  }

  .service-card {
    padding: var(--space-lg);
  }

  .ba-carousel,
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .testimonial-track {
    grid-template-columns: 1fr;
  }

  .video-slider__track .video-card {
    flex: 0 0 220px;
  }

  .video-slider__btn {
    display: none;
  }

  /* Service nav — horizontal scroll on mobile */
  .service-nav {
    padding: var(--space-sm) 0;
  }

  .service-nav__list {
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: var(--space-sm);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: var(--space-xs) var(--container-pad);
  }

  .service-nav__list::-webkit-scrollbar {
    display: none;
  }

  .service-nav__list li {
    scroll-snap-align: start;
    flex-shrink: 0;
  }

  .service-nav__link {
    padding: 0.6em 1em;
    font-size: var(--text-xs);
  }

  /* Fade edge + scroll arrow hint */
  .service-nav .container {
    position: relative;
    padding: 0;
  }

  .service-nav .container::after {
    content: '\276F\276F';
    position: absolute;
    top: -2px;
    right: 0;
    bottom: 0;
    width: 52px;
    background: linear-gradient(90deg, transparent, var(--c-white) 40%);
    pointer-events: none;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding-right: 8px;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.3em;
    color: var(--color-primary);
    opacity: 0.6;
    animation: swipeHint 1s ease-in-out 1s 3;
  }

  @keyframes swipeHint {
    0%, 100% { transform: translateX(0); opacity: 0.6; }
    50% { transform: translateX(-6px); opacity: 1; }
  }

  /* Nudge the list on load to show it scrolls */
  .service-nav__list {
    animation: scrollNudge 0.6s ease-in-out 1.2s 1;
  }

  @keyframes scrollNudge {
    0%   { transform: translateX(0); }
    40%  { transform: translateX(-30px); }
    100% { transform: translateX(0); }
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .cta-form-wrapper {
    padding: var(--space-2xl) var(--space-lg);
  }

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

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }

  .mobile-cta {
    display: flex;
  }

  .home .mobile-cta {
    transform: translateY(100%);
    opacity: 0;
    pointer-events: none;
    transition: transform var(--duration-base) var(--ease-out),
                opacity var(--duration-base) var(--ease-out);
  }

  .home .mobile-cta.is-visible {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* Add bottom padding for sticky CTA */
  .site-footer {
    padding-bottom: 80px;
  }

  .service-areas__grid {
    grid-template-columns: 1fr;
  }

  .service-areas__list {
    text-align: center;
  }

  .service-areas__group-title {
    justify-content: center;
  }

  .service-areas__cities {
    justify-content: center;
  }

  .service-areas__map iframe {
    height: 250px;
  }

  .page-hero {
    padding: 40px 0;
  }

  .why-card {
    border-left-color: var(--color-primary);
    box-shadow: var(--shadow-md);
    background: linear-gradient(135deg, var(--c-blue-50) 0%, var(--color-surface) 60%);
  }

  .why-card__icon {
    background: var(--color-primary);
    color: var(--c-white);
  }

  .info-notice {
    flex-direction: column;
    white-space: normal;
    text-align: center;
    max-width: max-content;
    padding: var(--space-md) var(--space-lg);
    margin: var(--space-xl) auto 0;
  }

  .info-notice__text .mobile-br {
    display: inline;
  }

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

  .process-steps::before {
    display: none;
  }
}

/* Small mobile */
@media (max-width: 480px) {
  .services-grid .service-card {
    flex: 0 1 calc(50% - var(--space-md) * 0.5);
  }

  .video-slider__track .video-card {
    flex: 0 0 200px;
  }

  .gallery-grid--photos {
    grid-template-columns: 1fr;
  }
}

/* Extra-small mobile */
@media (max-width: 398px) {
  .hero__tagline {
    font-size: 0.65rem;
    padding: 0.3em 0.8em;
  }

  .hero__title {
    font-size: clamp(1.6rem, 8vw, var(--text-4xl));
  }

  .hero__subtitle {
    font-size: var(--text-base);
    width: 95%;
  }

  .hero__highlight {
    font-size: var(--text-xs);
  }

  .hero__actions .btn {
    font-size: var(--text-sm);
    padding: 0.7em 1.2em;
  }

  .hero__trust {
    font-size: var(--text-xs);
    gap: var(--space-sm);
  }
}

/* ═══════════════════════════════════════
   LEGAL PAGES (Privacy Policy, Terms)
   ═══════════════════════════════════════ */
.legal-content {
  padding: var(--space-3xl) 0;
}

.legal-content__body {
  max-width: 780px;
  margin-inline: auto;
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--c-gray-700);
}

.legal-content__body h2 {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--c-gray-900);
  margin: var(--space-2xl) 0 var(--space-md);
}

.legal-content__body h3 {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--c-gray-800);
  margin: var(--space-xl) 0 var(--space-sm);
}

.legal-content__body p {
  margin-bottom: var(--space-md);
}

.legal-content__body ul,
.legal-content__body ol {
  margin-bottom: var(--space-md);
  padding-left: var(--space-xl);
}

.legal-content__body li {
  margin-bottom: var(--space-xs);
}

.legal-content__body a {
  color: var(--c-blue-600);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.legal-content__body a:hover {
  color: var(--c-blue-700);
}

/* ═══════════════════════════════════════
   PREFERS REDUCED MOTION
   ═══════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  [data-aos] {
    opacity: 1;
    transform: none;
  }
}

/* ═══════════════════════════════════════
   THANK YOU PAGE
   ═══════════════════════════════════════ */
.thank-you-section {
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.thank-you {
  text-align: center;
  max-width: 520px;
  margin: 0 auto;
  padding: var(--space-3xl) var(--space-xl);
}

.thank-you__icon {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: var(--c-green-50, #ecfdf5);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-xl);
  color: var(--c-green-600, #16a34a);
}

.thank-you__title {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--c-blue-700);
  margin-bottom: var(--space-md);
}

.thank-you__text {
  font-size: var(--text-lg);
  color: var(--c-gray-600);
  line-height: 1.6;
  margin-bottom: var(--space-sm);
}

.thank-you__subtext {
  font-size: var(--text-base);
  color: var(--c-gray-500);
  margin-bottom: var(--space-xl);
}

.thank-you__call {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-md);
}

.thank-you .btn--outline {
  border-color: var(--c-gray-300);
  color: var(--c-gray-600);
}

.thank-you .btn--outline:hover {
  border-color: var(--c-blue-600);
  color: var(--c-blue-600);
}

@media (max-width: 768px) {
  .thank-you-section {
    min-height: 60vh;
  }
  .thank-you {
    padding: var(--space-2xl) var(--space-md);
  }
  .thank-you__icon {
    width: 80px;
    height: 80px;
  }
  .thank-you__icon svg {
    width: 56px;
    height: 56px;
  }
  .thank-you__call,
  .thank-you .btn--outline {
    width: 100%;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════
   PRINT
   ═══════════════════════════════════════ */
@media print {
  .site-header,
  .mobile-cta,
  .promo-bar,
  .video-section,
  .video-grid { display: none; }

  .hero { min-height: auto; color: #000; }
  .hero::before { display: none; }
  body { font-size: 12pt; }
}
