/* ==========================================================================
   Gefyra — Bridging Vision to Value
   Mobile-first · System color scheme · Navy blue + champagne gold
   ========================================================================== */

/* --- Light mode (default) --- */
:root {
  --color-bg:           #F5F3EE;
  --color-bg-subtle:    #EDEAE2;
  --color-bg-raised:    #FAF9F6;

  --color-primary:      #0F2347;
  --color-primary-mid:  #1B3A6B;
  --color-primary-light:#4A6FA5;
  --color-primary-tint: #E2EAF4;

  --color-accent:       #B5883A;
  --color-accent-warm:  #D4A853;
  --color-accent-muted: #E8D5A3;

  --color-text:         #1A1A18;
  --color-text-muted:   #5C5849;
  --color-text-faint:   #9E9589;

  --color-border:       rgba(15, 35, 71, 0.15);
  --color-border-gold:  rgba(181, 136, 58, 0.30);

  --color-success:      #1B3A6B;
  --color-error:        #9B2335;

  --gradient-hero: radial-gradient(ellipse at 70% 50%, var(--color-primary-tint) 0%, transparent 60%);
  --gradient-gold: linear-gradient(135deg, var(--color-accent-muted), var(--color-accent), var(--color-accent-muted));
  --gradient-fade: linear-gradient(to bottom, var(--color-bg), var(--color-bg-subtle));

  --font-display: 'Fraunces', 'Georgia', serif;
  --font-body: 'Literata', 'Georgia', serif;
  --font-ui: 'Fraunces', 'Georgia', serif;

  --radius-ui: 14px;
  --radius-card: 22px;
  --shadow-soft: 0 16px 48px rgba(15, 35, 71, 0.08);
  --shadow-lift: 0 24px 64px rgba(0, 0, 0, 0.06);

  --text-xs: clamp(0.75rem, 0.7rem + 0.2vw, 0.85rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.3vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.4vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.7vw, 1.5rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.5vw, 2.5rem);
  --text-hero: clamp(2.25rem, 1.5rem + 4.5vw, 5.5rem);

  --space-xs: clamp(0.5rem, 0.4rem + 0.5vw, 0.75rem);
  --space-sm: clamp(0.75rem, 0.6rem + 0.8vw, 1rem);
  --space-md: clamp(1rem, 0.8rem + 1.2vw, 1.5rem);
  --space-lg: clamp(1.5rem, 1rem + 2vw, 3rem);
  --space-xl: clamp(2rem, 1.5rem + 4vw, 6rem);

  /* Floating nav shell: top offset + pill height (logo + padding) */
  --nav-shell-offset: max(0.75rem, env(safe-area-inset-top, 0px));
  --nav-pill-height: 4.65rem;
  --nav-clearance: calc(var(--nav-shell-offset) + var(--nav-pill-height));
  --hero-below-nav: clamp(1.5rem, 4.5vw, 2.5rem);
  --nav-height: var(--nav-clearance);
  --nav-radius: 999px;
  --transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);

  /* logo.png — dark strokes on transparent */
  --brand-logo-filter: brightness(0);

  --hero-gutter: clamp(1.25rem, 4vw, 2.5rem);
  --hero-max: 72rem;
}

@media (min-width: 768px) {
  :root {
    /* 4.5rem logo + ~1rem nav vertical padding */
    --nav-pill-height: 5.75rem;
    --hero-below-nav: clamp(1.25rem, 3vw, 2rem);
  }
}

@media (prefers-color-scheme: dark) {
  :root {
    --color-bg:           #0E1117;
    --color-bg-subtle:    #141B26;
    --color-bg-raised:    #1A2433;

    --color-primary:      #7BA7D9;
    --color-primary-mid:  #94B8E0;
    --color-primary-light:#B3CCEC;
    --color-primary-tint: rgba(123, 167, 217, 0.12);

    --color-accent:       #D4A853;
    --color-accent-warm:  #E8C47A;
    --color-accent-muted: rgba(212, 168, 83, 0.18);

    --color-text:         #F0EDE6;
    --color-text-muted:   #A09A8E;
    --color-text-faint:   #6B6560;

    --color-border:       rgba(123, 167, 217, 0.14);
    --color-border-gold:  rgba(212, 168, 83, 0.25);

    --color-success:      #94B8E0;
    --color-error:        #E07070;

    --brand-logo-filter: brightness(0) invert(1);
  }
}

/* --- Reset & base --- */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  width: 100%;
  overflow-x: hidden;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--nav-clearance) + 1.5rem);
}

html.no-preloader #preloader {
  display: none !important;
}

body {
  width: 100%;
  min-height: 100dvh;
  margin: 0;
  overflow-x: hidden;
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 400;
  line-height: 1.65;
  color: var(--color-text);
  background-color: var(--color-bg);
  background-image:
    radial-gradient(ellipse 120% 80% at 100% 0%, color-mix(in srgb, var(--color-accent-muted) 35%, transparent), transparent 50%),
    radial-gradient(ellipse 90% 60% at 0% 100%, var(--color-primary-tint), transparent 45%);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.22;
  background-image:
    repeating-linear-gradient(105deg, transparent 0, transparent 31px, var(--color-border) 31px, var(--color-border) 32px),
    repeating-linear-gradient(-15deg, transparent 0, transparent 47px, var(--color-border) 47px, var(--color-border) 48px);
  mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, black 20%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, black 20%, transparent 75%);
}

body.preloader-active {
  overflow: hidden;
}

/* --- Ambient flying graphics (decorative, non-interactive) --- */
.ambient-fx {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  contain: strict;
}

body > main,
body > .footer {
  position: relative;
  z-index: 1;
}

.ambient-fx__piece {
  position: absolute;
  margin: -1px 0 0 -1px;
  opacity: 0.32;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  transform: translate3d(0, 0, 0);
}

.ambient-fx__piece--rev {
  animation-direction: reverse;
}

.ambient-fx__track--1 {
  animation-name: ambient-track-1;
}

.ambient-fx__track--2 {
  animation-name: ambient-track-2;
}

.ambient-fx__track--3 {
  animation-name: ambient-track-3;
}

.ambient-fx__track--4 {
  animation-name: ambient-track-4;
}

@keyframes ambient-track-1 {
  0% { transform: translate3d(0, 0, 0) rotate(0deg); }
  100% { transform: translate3d(38vw, -52vh, 0) rotate(1turn); }
}

@keyframes ambient-track-2 {
  0% { transform: translate3d(0, 0, 0) rotate(0deg); }
  100% { transform: translate3d(-44vw, 36vh, 0) rotate(-1turn); }
}

@keyframes ambient-track-3 {
  0% { transform: translate3d(0, 0, 0) rotate(0deg); }
  100% { transform: translate3d(26vw, 44vh, 0) rotate(0.5turn); }
}

@keyframes ambient-track-4 {
  0% { transform: translate3d(0, 0, 0) rotate(0deg); }
  100% { transform: translate3d(-32vw, -40vh, 0) rotate(-0.75turn); }
}

.ambient-fx__piece--ring {
  width: 1.125rem;
  height: 1.125rem;
  border: 1px solid color-mix(in srgb, var(--color-accent) 55%, transparent);
  border-radius: 50%;
  background: transparent;
}

.ambient-fx__piece--square {
  width: 0.55rem;
  height: 0.55rem;
  border: 1px solid color-mix(in srgb, var(--color-primary-mid) 45%, transparent);
  border-radius: 2px;
  background: color-mix(in srgb, var(--color-primary-tint) 35%, transparent);
}

.ambient-fx__piece--diamond {
  width: 0.5rem;
  height: 0.5rem;
  border: 1px solid color-mix(in srgb, var(--color-accent-warm) 50%, transparent);
  border-radius: 1px;
  background: transparent;
}

/* Diamond: keep 45° orientation while drifting (higher specificity than .ambient-fx__track--n) */
.ambient-fx__piece--diamond.ambient-fx__track--1 {
  animation-name: ambient-diamond-1;
}

.ambient-fx__piece--diamond.ambient-fx__track--2 {
  animation-name: ambient-diamond-2;
}

.ambient-fx__piece--diamond.ambient-fx__track--3 {
  animation-name: ambient-diamond-3;
}

.ambient-fx__piece--diamond.ambient-fx__track--4 {
  animation-name: ambient-diamond-4;
}

@keyframes ambient-diamond-1 {
  0% { transform: translate3d(0, 0, 0) rotate(45deg); }
  100% { transform: translate3d(38vw, -52vh, 0) rotate(calc(45deg + 1turn)); }
}

@keyframes ambient-diamond-2 {
  0% { transform: translate3d(0, 0, 0) rotate(45deg); }
  100% { transform: translate3d(-44vw, 36vh, 0) rotate(calc(45deg - 1turn)); }
}

@keyframes ambient-diamond-3 {
  0% { transform: translate3d(0, 0, 0) rotate(45deg); }
  100% { transform: translate3d(26vw, 44vh, 0) rotate(calc(45deg + 0.5turn)); }
}

@keyframes ambient-diamond-4 {
  0% { transform: translate3d(0, 0, 0) rotate(45deg); }
  100% { transform: translate3d(-32vw, -40vh, 0) rotate(calc(45deg - 0.75turn)); }
}

.ambient-fx__piece--dash {
  width: 1.35rem;
  height: 3px;
  border-radius: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in srgb, var(--color-accent) 40%, transparent),
    transparent
  );
}

.ambient-fx__piece--dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-primary-light) 55%, transparent);
}

.ambient-fx__piece--arc {
  width: 1.25rem;
  height: 0.65rem;
  border: 1px solid color-mix(in srgb, var(--color-primary-mid) 42%, transparent);
  border-bottom: none;
  border-radius: 999px 999px 0 0;
  background: transparent;
}

.ambient-fx__piece--bridge {
  display: grid;
  place-items: center;
}

.ambient-fx__piece--bridge .ambient-fx__svg {
  width: 1.45rem;
}

.ambient-fx__svg {
  display: block;
  width: 1.25rem;
  height: auto;
  color: color-mix(in srgb, var(--color-accent) 50%, transparent);
}

@media (max-width: 767px) {
  .ambient-fx {
    display: none !important;
  }
}

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

svg:not(.icon-svg):not(.mobile-nav-icon):not(.btn__chev):not(.ambient-fx__svg) {
  max-width: 100%;
  height: auto;
  display: block;
}

.mobile-nav-icon {
  width: 22px;
  height: 22px;
  display: block;
  flex-shrink: 0;
}

.icon-svg {
  flex-shrink: 0;
  display: block;
  color: var(--color-accent);
}

button, a, input, textarea, select {
  font: inherit;
}

button, a {
  -webkit-tap-highlight-color: transparent;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.1;
  color: var(--color-text);
  text-wrap: balance;
  font-optical-sizing: auto;
}

h1 em, h2 em, h3 em {
  font-style: italic;
  padding-inline: 0.02em;
  margin-inline: -0.02em;
  background-image: linear-gradient(
    100deg,
    var(--color-primary) 0%,
    var(--color-primary-mid) 18%,
    var(--color-primary-light) 38%,
    var(--color-primary) 52%,
    var(--color-primary-light) 68%,
    var(--color-primary-mid) 85%,
    var(--color-primary) 100%
  );
  background-size: 260% 100%;
  background-position: 0% 50%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  animation: textEmGradientFlow 9s linear infinite;
}

@supports not ((-webkit-background-clip: text) or (background-clip: text)) {
  h1 em, h2 em, h3 em {
    color: var(--color-primary);
    -webkit-text-fill-color: unset;
    background: none;
    animation: none;
  }
}

@keyframes textEmGradientFlow {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}

p {
  text-wrap: pretty;
}

a {
  color: var(--color-primary-mid);
  text-decoration: none;
  transition: color var(--transition);
}

a:hover {
  color: var(--color-accent-warm);
}

::selection {
  background: var(--color-primary-tint);
  color: var(--color-primary);
}

address {
  font-style: normal;
}

/* --- Layout --- */
.container {
  width: min(100% - 2rem, 1200px);
  margin-inline: auto;
}

.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;
}

section {
  padding-block: var(--space-xl);
  padding-inline: var(--space-md);
}

section.hero,
header.page-hero {
  padding-inline: 0;
}

/* Beat generic `section { padding-block }` — clearance below fixed nav */
section.hero.hero,
header.page-hero.page-hero {
  padding-block-start: calc(var(--nav-clearance) + var(--hero-below-nav));
}

section.hero.hero {
  padding-block-end: clamp(2rem, 6vw, 4rem);
}

header.page-hero.page-hero {
  padding-block-end: clamp(2rem, 6vw, var(--space-xl));
}

.section-alt {
  background: var(--color-bg-subtle);
}

.section-label,
.eyebrow {
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}

.section-intro {
  color: var(--color-text-muted);
  max-width: 42rem;
  margin-bottom: var(--space-lg);
}

.responsive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: var(--space-md);
}

.feature-layout {
  display: grid;
  gap: var(--space-lg);
}

@media (min-width: 768px) {
  .feature-layout {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}

/* --- Preloader --- */
.preloader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background: var(--color-bg);
  transition: opacity 0.6s ease, visibility 0.6s ease;
}

.preloader.is-done {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

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

.preloader__logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(11rem, 62vw);
  aspect-ratio: 1;
  opacity: 0;
  animation: brandLogoIn 0.9s var(--ease-out-smooth, ease) forwards 0.15s;
}

.preloader__logo-wrap .brand-logo {
  width: 100%;
  height: 100%;
  max-height: min(11rem, 42vh);
}

.preloader__tagline {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  letter-spacing: 0.08em;
  opacity: 0;
  animation: fadeUp 0.8s ease forwards 0.65s;
}

@keyframes brandLogoIn {
  from {
    opacity: 0;
    transform: scale(0.94) translateY(10px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* Company logo (logo.png) — dark strokes, transparent; theme via filter */
.brand-logo-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  line-height: 0;
}

.brand-logo {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  flex-shrink: 0;
  filter: var(--brand-logo-filter);
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* --- Navigation --- */
.nav-wrapper {
  position: fixed;
  top: max(0.75rem, env(safe-area-inset-top));
  left: 0;
  right: 0;
  z-index: 100;
  padding-inline: max(1rem, env(safe-area-inset-left)) max(1rem, env(safe-area-inset-right));
  pointer-events: none;
  transition: top var(--transition);
}

.nav-wrapper.is-scrolled {
  top: max(0.5rem, env(safe-area-inset-top));
}

.nav {
  pointer-events: auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  max-width: 900px;
  margin-inline: auto;
  padding: 0.5rem 0.85rem 0.5rem 0.85rem;
  border-radius: var(--nav-radius);
  background: color-mix(in srgb, var(--color-bg) 82%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--color-border);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
  transition:
    padding 0.38s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.38s cubic-bezier(0.22, 1, 0.36, 1),
    border-radius 0.42s cubic-bezier(0.22, 1, 0.36, 1),
    background 0.35s ease;
}

.nav-backdrop {
  position: fixed;
  inset: 0;
  z-index: 90;
  margin: 0;
  padding: 0;
  border: none;
  background: color-mix(in srgb, var(--color-primary) 12%, transparent);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  cursor: pointer;
  transition:
    opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    visibility 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    backdrop-filter 0.45s ease;
  -webkit-tap-highlight-color: transparent;
}

.nav-backdrop.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.nav-wrapper.is-scrolled .nav {
  padding-block: 0.4rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

@media (min-width: 768px) {
  .nav-wrapper.is-scrolled .nav__logo-wrap {
    --nav-logo-size: 4.15rem;
  }
}

@media (max-width: 767px) {
  .nav-wrapper.is-scrolled .nav__logo-wrap {
    --nav-logo-size: 3.25rem;
  }
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  align-self: center;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
  text-decoration: none;
  line-height: 0;
}

.nav__brand:hover .brand-logo {
  opacity: 0.88;
}

.nav__logo-wrap {
  --nav-logo-size: 3.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--nav-logo-size);
  height: var(--nav-logo-size);
  flex-shrink: 0;
}

.nav__logo-wrap .brand-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  transition: opacity var(--transition);
}

@media (min-width: 768px) {
  .nav__logo-wrap {
    --nav-logo-size: 4.5rem;
  }

  .nav__brand {
    margin-right: var(--space-md);
  }

  .nav {
    padding: 0.45rem 1rem 0.45rem 1rem;
    align-items: center;
  }
}

.nav__toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 48px;
  height: 48px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
  color: var(--color-primary);
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.nav__toggle:hover,
.nav__toggle:focus-visible {
  background: var(--color-primary-tint);
  outline: none;
}

.nav__toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transform-origin: center;
  transition:
    transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.28s ease,
    width 0.28s ease;
}

.nav__toggle[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav__toggle[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}

.nav__toggle[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.nav__menu {
  display: none;
}

@media (min-width: 768px) {
  .nav-backdrop {
    display: none !important;
  }

  .nav__toggle {
    display: none;
  }

  .nav {
    flex-wrap: nowrap;
  }

  .nav__menu {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    flex: 1 1 auto;
    justify-content: flex-end;
  }

  .nav__menu-inner {
    display: contents;
  }

  .nav__menu-tagline,
  .nav__menu-label,
  .nav__menu-divider,
  .nav__menu-quick,
  .nav__menu-email {
    display: none;
  }

  .nav__menu-foot {
    display: contents;
  }

  .nav__links {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .nav__links li + li {
    margin-top: 0;
  }

  .nav-link {
    position: relative;
    padding: 0.4rem 0.75rem;
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text-muted);
    border-radius: 999px;
    transition: color var(--transition), background var(--transition);
  }

  .nav-link:hover,
  .nav-link.active {
    color: var(--color-primary);
    background: var(--color-primary-tint);
  }

  .nav-cta {
    min-width: 200px;
    text-align: center;
  }
}

/* Mobile menu — expands from the nav shell (fixed radius, no shape jump) */
@media (max-width: 767px) {
  .nav-wrapper {
    z-index: 110;
  }

  .nav-wrapper.is-scrolled .nav {
    padding-block: 0.45rem;
    box-shadow: var(--nav-mobile-shadow);
  }

  .nav {
    --nav-mobile-radius: 1.35rem;
    --nav-mobile-shadow:
      0 6px 28px color-mix(in srgb, var(--color-primary) 10%, transparent),
      0 0 0 1px var(--color-border);
    position: relative;
    z-index: 100;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    align-items: center;
    column-gap: var(--space-sm);
    row-gap: 0;
    padding: 0.45rem 0.65rem 0.45rem 0.75rem;
    border-radius: var(--nav-mobile-radius);
    overflow: hidden;
    isolation: isolate;
    background: color-mix(in srgb, var(--color-bg) 94%, transparent);
    box-shadow: var(--nav-mobile-shadow);
    /* Only animate padding — never border-radius or box-shadow */
    transition: padding 0.48s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .nav.nav--menu-open,
  .nav.nav--menu-closing {
    border-radius: var(--nav-mobile-radius);
    box-shadow: var(--nav-mobile-shadow);
  }

  .nav.nav--menu-open {
    padding-bottom: 0.85rem;
  }

  .nav__brand {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    align-self: center;
  }

  .nav__logo-wrap {
    --nav-logo-size: 3.75rem;
  }

  .nav__toggle {
    position: relative;
    z-index: 2;
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    align-self: center;
    margin-left: 0;
  }

  .nav__toggle:focus:not(:focus-visible) {
    background: transparent;
  }

  .nav__menu {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100%;
    min-width: 0;
    display: block;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    transition:
      max-height 0.48s cubic-bezier(0.22, 1, 0.36, 1),
      opacity 0.38s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .nav__menu.is-open {
    max-height: min(72vh, 34rem);
    opacity: 1;
    pointer-events: auto;
  }

  .nav__menu-inner {
    padding-top: 0;
    border-top: 1px solid transparent;
    opacity: 0;
    transition:
      opacity 0.32s cubic-bezier(0.22, 1, 0.36, 1) 0.06s,
      padding-top 0.4s cubic-bezier(0.22, 1, 0.36, 1),
      border-color 0.35s ease;
  }

  .nav__menu.is-open .nav__menu-inner {
    padding-top: var(--space-sm);
    border-top-color: var(--color-border);
    opacity: 1;
  }

  .nav__menu:not(.is-open) .nav__menu-inner {
    transition:
      opacity 0.22s ease,
      padding-top 0.38s cubic-bezier(0.22, 1, 0.36, 1),
      border-color 0.3s ease;
  }

  .nav__menu-tagline {
    margin: 0 0 var(--space-sm);
    font-size: max(0.9375rem, 15px);
    line-height: 1.5;
    font-style: italic;
    color: var(--color-text-muted);
    letter-spacing: 0.02em;
  }

  .nav__links {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .nav__links li + li {
    margin-top: 0.15rem;
  }

  .nav-link {
    display: flex;
    align-items: center;
    min-height: 3rem;
    padding: 0.55rem 0.65rem;
    font-family: var(--font-display);
    font-size: clamp(1.1875rem, 1.05rem + 1vw, 1.4rem);
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
    border-radius: calc(var(--radius-ui) + 2px);
    transition: color var(--transition), background var(--transition);
  }

  .nav-link:hover,
  .nav-link:focus-visible {
    background: var(--color-primary-tint);
    color: var(--color-primary);
  }

  .nav-link.active {
    color: var(--color-primary);
    background: color-mix(in srgb, var(--color-primary-tint) 65%, transparent);
  }

  .nav__menu-divider {
    height: 1px;
    margin: var(--space-sm) 0;
    background: var(--color-border);
  }

  .nav__menu-label {
    margin: 0 0 0.35rem;
    font-size: max(0.75rem, 12px);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent);
  }

  .nav__menu-quick {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.4rem;
    list-style: none;
    margin: 0 0 var(--space-sm);
    padding: 0;
  }

  .nav__menu-quick-link {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    padding: 0.55rem 0.65rem;
    font-size: max(0.9375rem, 15px);
    font-weight: 500;
    color: var(--color-text-muted);
    text-decoration: none;
    text-align: center;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-bg);
    transition: color var(--transition), border-color var(--transition), background var(--transition);
  }

  .nav__menu-quick-link:hover,
  .nav__menu-quick-link:focus-visible {
    color: var(--color-primary);
    border-color: color-mix(in srgb, var(--color-primary-light) 40%, var(--color-border));
    background: var(--color-primary-tint);
  }

  .nav__menu-foot {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    padding-top: 0.15rem;
  }

  .nav__menu-foot .nav-cta {
    width: 100%;
    min-height: 3.25rem;
    justify-content: center;
    font-size: max(1rem, 16px);
  }

  .nav__menu-email {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    text-align: center;
    font-size: max(0.9375rem, 15px);
    color: var(--color-text-faint);
    text-decoration: none;
    padding: 0.5rem;
  }

  .nav__menu-email:hover,
  .nav__menu-email:focus-visible {
    color: var(--color-primary);
  }
}

@media (max-width: 767px) and (prefers-reduced-motion: reduce) {
  .nav,
  .nav__menu,
  .nav__menu-inner,
  .nav-backdrop,
  .nav__toggle span {
    transition: none !important;
  }

  .nav__menu.is-open {
    max-height: min(72vh, 34rem);
    opacity: 1;
  }

  .nav__menu.is-open .nav__menu-inner {
    opacity: 1;
  }
}

/* Mobile bottom nav */
.mobile-bottom-nav {
  position: fixed;
  left: 1rem;
  right: 1rem;
  bottom: max(1rem, env(safe-area-inset-bottom));
  z-index: 50;
  display: flex;
  justify-content: space-around;
  align-items: center;
  min-height: 64px;
  padding: 0.5rem;
  border-radius: var(--nav-radius);
  background: color-mix(in srgb, var(--color-bg) 88%, transparent);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--color-border);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}

@media (min-width: 768px) {
  .mobile-bottom-nav {
    display: none;
  }
}

.mobile-nav-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 0.35rem 0.5rem;
  font-size: 0.65rem;
  font-weight: 500;
  color: var(--color-text-faint);
  text-decoration: none;
  border-radius: 12px;
  transition: color var(--transition);
  min-width: 44px;
  min-height: 44px;
  justify-content: center;
}

.mobile-nav-link .mobile-nav-icon {
  width: 22px;
  height: 22px;
}

.mobile-nav-link.active,
.mobile-nav-link:hover {
  color: var(--color-primary);
}

/* --- Buttons --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 48px;
  min-width: 44px;
  padding: 0.8rem 1.35rem;
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  border-radius: var(--radius-ui);
  border: none;
  cursor: pointer;
  touch-action: manipulation;
  transition: background var(--transition), color var(--transition), transform 0.15s ease, box-shadow var(--transition), border-color var(--transition);
  text-decoration: none;
  box-shadow: 0 1px 0 color-mix(in srgb, var(--color-primary) 12%, transparent);
}

.btn .btn__chev {
  width: 1em;
  height: 1em;
  opacity: 0.85;
  transition: transform 0.25s ease;
}

.btn:hover .btn__chev {
  transform: translateX(3px);
}

.btn:active {
  transform: scale(0.98);
}

.btn-primary {
  background: var(--color-primary);
  color: var(--color-bg-raised);
  box-shadow: 0 4px 20px color-mix(in srgb, var(--color-primary) 35%, transparent);
}

.btn-primary:hover {
  background: var(--color-primary-mid);
  color: var(--color-bg-raised);
  box-shadow: 0 6px 28px color-mix(in srgb, var(--color-primary) 40%, transparent);
}

.btn-ghost {
  background: transparent;
  color: var(--color-accent);
  border: 1px solid var(--color-border-gold);
}

.btn-ghost:hover {
  background: var(--color-accent-muted);
  color: var(--color-primary);
}

.nav .nav-cta.btn-ghost {
  min-height: 44px;
  padding-inline: 1.25rem;
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: var(--nav-radius);
}

.nav-cta.btn-ghost:hover {
  background: var(--color-accent);
  color: var(--color-bg);
}

.btn-full {
  width: 100%;
}

/* --- Standalone / section CTAs (full width mobile, generous desktop) --- */
.section-cta,
.detail-band__footer,
.contact-page__hours-foot {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-sm);
  margin-top: var(--space-xl);
  margin-bottom: 0;
}

.section-cta > .btn,
.section-cta > a.btn,
.detail-band__footer > .btn,
.detail-band__footer > a.btn,
.contact-page__hours-foot > .btn,
.contact-page__hours-foot > a.btn,
p:has(> a.btn:only-child),
p:has(> .btn:only-child) {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

p > a.btn:only-child,
p > .btn:only-child {
  width: 100%;
  max-width: 100%;
  justify-content: center;
  min-height: 52px;
  padding-inline: 1.5rem;
  font-size: var(--text-base);
}

.section-cta > .btn,
.section-cta > a.btn,
.detail-band__footer > .btn,
.detail-band__footer > a.btn,
.contact-page__hours-foot > .btn,
.contact-page__hours-foot > a.btn {
  width: 100%;
  max-width: 100%;
  justify-content: center;
  min-height: 52px;
  padding-inline: 1.5rem;
  font-size: var(--text-base);
}

.about-tease__main > .btn,
.contact-tease__grid > div > .btn {
  display: flex;
  width: 100%;
  max-width: 100%;
  justify-content: center;
  min-height: 52px;
  padding-inline: 1.5rem;
  font-size: var(--text-base);
  margin-top: var(--space-sm);
}

.home-service-row__cta {
  width: 100%;
  max-width: 100%;
  min-height: 52px;
  font-size: var(--text-base);
}

.site-engage__faqs > .btn {
  display: flex;
  width: 100%;
  max-width: 100%;
  justify-content: center;
  min-height: 52px;
  margin-top: var(--space-xs);
  font-size: var(--text-base);
}

@media (min-width: 640px) {
  .section-cta,
  .detail-band__footer,
  .contact-page__hours-foot {
    align-items: flex-start;
    max-width: 36rem;
  }

  .section-cta > .btn,
  .section-cta > a.btn,
  .detail-band__footer > .btn,
  .detail-band__footer > a.btn,
  .contact-page__hours-foot > .btn,
  .contact-page__hours-foot > a.btn,
  p > a.btn:only-child,
  p > .btn:only-child {
    max-width: 32rem;
  }

  .about-tease__main > .btn,
  .contact-tease__grid > div > .btn {
    max-width: 22rem;
  }

  .site-engage__faqs > .btn {
    max-width: 22rem;
  }
}

@media (min-width: 900px) {
  .section-cta {
    max-width: 40rem;
  }
}

/* --- Cards --- */
.card {
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: var(--space-md);
}

.glass-card {
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: var(--shadow-lift);
}

.soft-card {
  box-shadow: var(--shadow-soft);
}

.card-featured {
  background: var(--color-primary);
  color: var(--color-bg-raised);
  border: none;
}

.card-featured h3,
.card-featured p,
.card-featured .timeline-code,
.card-featured .timeline-category {
  color: var(--color-bg-raised);
}

.card-featured .timeline-code {
  opacity: 0.85;
}

.card-featured .tag {
  background: rgba(255, 255, 255, 0.15);
  color: var(--color-bg-raised);
  border-color: rgba(255, 255, 255, 0.25);
}

.card-gold {
  border-left: 3px solid var(--color-accent);
}

.card:active {
  transform: scale(0.995);
}

/* --- Hero --- */
.hero {
  position: relative;
  min-height: min(100dvh, 56rem);
  display: flex;
  align-items: flex-start;
  padding-block-start: calc(var(--nav-clearance) + var(--hero-below-nav));
  padding-block-end: clamp(2rem, 6vw, 4rem);
  padding-inline: 0;
  text-align: center;
  overflow: hidden;
}

.hero > .container,
.hero__content {
  box-sizing: border-box;
  width: 100%;
  max-width: var(--hero-max);
  margin-inline: auto;
  padding-inline:
    max(var(--hero-gutter), env(safe-area-inset-left, 0px))
    max(var(--hero-gutter), env(safe-area-inset-right, 0px));
}

.hero__mesh {
  position: absolute;
  inset: 0;
  background: var(--gradient-hero);
  pointer-events: none;
}

.hero__mesh::before {
  content: '';
  position: absolute;
  top: -20%;
  right: -30%;
  width: 80%;
  height: 80%;
  background: radial-gradient(circle, var(--color-accent-muted) 0%, transparent 55%);
  opacity: 0.35;
  animation: meshFloat 12s ease-in-out infinite alternate;
}

.hero__mesh::after {
  content: '';
  position: absolute;
  bottom: 10%;
  left: -20%;
  width: 60%;
  height: 50%;
  background: radial-gradient(circle, var(--color-primary-tint) 0%, transparent 60%);
  opacity: 0.5;
}

@keyframes meshFloat {
  from { transform: translate(0, 0) scale(1); }
  to { transform: translate(-5%, 5%) scale(1.05); }
}

.hero__content {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.hero .eyebrow {
  margin: 0 0 var(--space-sm);
}

.hero h1 {
  font-size: var(--text-hero);
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 0 0 var(--space-md);
  max-width: 16ch;
}

.hero__location {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0 0 var(--space-sm);
}

.hero__lead {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  max-width: 38rem;
  margin: 0 auto;
  line-height: 1.65;
}

.hero__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-sm);
  justify-content: center;
  margin-top: clamp(var(--space-md), 3vw, var(--space-lg));
  width: 100%;
  max-width: 28rem;
  margin-inline: auto;
}

.hero__actions .btn {
  width: 100%;
  justify-content: center;
  min-height: 52px;
  font-size: var(--text-base);
}

@media (min-width: 768px) {
  .hero {
    text-align: left;
    padding-block-end: clamp(2.5rem, 7vw, 4.5rem);
  }

  .hero h1 {
    max-width: 14ch;
  }

  .hero__lead {
    margin-inline: 0;
  }

  .hero__actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    max-width: none;
    margin-inline: 0;
  }

  .hero__actions .btn {
    width: auto;
    flex: 1 1 11.5rem;
    max-width: 16rem;
  }
}

@media (min-width: 1024px) {
  .hero > .container,
  .hero__content {
    --hero-gutter: clamp(1.5rem, 5vw, 3rem);
  }

  .hero__lead {
    max-width: 42rem;
  }

  .hero__panel {
    margin-top: clamp(var(--space-lg), 4vw, var(--space-xl));
  }
}

/* --- Section titles (consistent placement) --- */
.why h2,
.coverage h2,
.services h2,
.about h2,
.contact h2,
section .container > h2,
section .container > .feature-page-h2,
.page-hero h1 {
  margin-top: 0;
}

.why h2,
.coverage h2,
.services h2,
.about h2,
.contact h2,
section .container > h2,
section .container > .feature-page-h2 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-md);
  line-height: 1.15;
}

section .container > .section-label:first-child {
  margin-bottom: var(--space-xs);
}

section .container > .section-label + h2,
section .container > .section-label + .feature-page-h2 {
  margin-top: 0;
}

.stat-card__label {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-xs);
}

.stat-card__value {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  line-height: 1.3;
  margin: 0;
  color: var(--color-text);
}

/* --- Coverage --- */
.coverage-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-sm);
}

@media (min-width: 480px) {
  .coverage-list {
    grid-template-columns: 1fr 1fr;
  }
}

.coverage-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  font-weight: 500;
  transition: border-color var(--transition), transform 0.15s ease;
}

.coverage-list li:active {
  transform: scale(0.98);
}

.coverage-diamond {
  color: var(--color-accent);
  flex-shrink: 0;
}

/* --- Timeline / Services --- */
.timeline {
  position: relative;
  display: grid;
  gap: var(--space-lg);
  padding-left: var(--space-md);
}

.timeline::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--color-accent), transparent);
}

.timeline-item {
  position: relative;
  padding: var(--space-md) var(--space-md) var(--space-md) var(--space-lg);
}

.timeline-dot {
  position: absolute;
  left: calc(-1 * var(--space-md) - 5px);
  top: var(--space-md);
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid var(--color-accent);
  background: var(--color-bg);
  transition: background var(--transition), transform var(--transition);
}

.timeline-item:hover .timeline-dot {
  background: var(--color-accent);
  transform: scale(1.2);
}

.timeline-code {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--color-accent);
}

.timeline-category {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  margin-bottom: var(--space-xs);
}

.timeline-item h3 {
  font-size: var(--text-lg);
  margin: var(--space-xs) 0 var(--space-sm);
}

.timeline-item p,
.timeline-item ul {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.timeline-item ul {
  padding-left: 1.25rem;
  margin: var(--space-sm) 0;
}

.tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: var(--space-md);
}

.tag {
  font-size: var(--text-xs);
  font-weight: 500;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  background: var(--color-primary-tint);
  color: var(--color-primary);
  border: 1px solid var(--color-border);
}

/* --- About --- */
.profile-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.profile-table th,
.profile-table td {
  padding: 0.65rem 0;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}

.profile-table th {
  font-weight: 600;
  color: var(--color-text-muted);
  width: 38%;
  padding-right: 1rem;
}

.profile-table tr:last-child th,
.profile-table tr:last-child td {
  border-bottom: none;
}

.profile-table__title,
.about-story h3,
.apart-section h3 {
  font-size: var(--text-lg);
  margin-top: 0;
  margin-bottom: var(--space-md);
}

.about-story p {
  color: var(--color-text-muted);
}

.values-grid {
  margin-top: var(--space-xl);
}

.value-icon {
  display: block;
  font-size: 1.5rem;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}

.value-card h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-xs);
}

.value-card p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
}

.apart-section {
  margin-top: var(--space-xl);
  padding: var(--space-lg);
  background: var(--color-bg-raised);
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
}

.apart-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: var(--space-md);
}

.apart-list li {
  padding-left: 1rem;
  border-left: 2px solid var(--color-accent);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.apart-list strong {
  color: var(--color-text);
}

/* --- Contact --- */
.contact-grid {
  display: grid;
  gap: var(--space-lg);
}

@media (min-width: 1024px) {
  .contact-grid {
    grid-template-columns: 1fr 1.1fr;
    align-items: start;
  }
}

.contact-details {
  display: grid;
  gap: var(--space-md);
}

@media (min-width: 480px) {
  .contact-details {
    grid-template-columns: 1fr 1fr;
  }
}

.contact-card h3 {
  font-size: var(--text-base);
  margin: var(--space-xs) 0;
  font-family: var(--font-display);
}

.contact-card a {
  font-weight: 600;
  word-break: break-all;
}

.contact-card p,
.contact-card address {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: var(--space-xs) 0 0;
}

.contact-muted {
  color: var(--color-text-faint);
}

.contact-form h3 {
  margin-top: 0;
}

.form-note {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-md);
}

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

.form-group label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  margin-bottom: 0.4rem;
  color: var(--color-text);
}

input,
textarea,
select {
  width: 100%;
  min-height: 48px;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-ui);
  font-size: 16px;
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border);
  color: var(--color-text);
  transition: border-color var(--transition), box-shadow var(--transition);
}

textarea {
  min-height: 120px;
  resize: vertical;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--color-primary-light);
  outline: none;
  box-shadow: 0 0 0 3px var(--color-primary-tint);
}

input:invalid:not(:placeholder-shown),
textarea:invalid:not(:placeholder-shown) {
  border-color: var(--color-error);
}

.find-us {
  margin-top: var(--space-lg);
}

.find-us__note {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-sm);
}

/* --- Footer --- */
.footer {
  position: relative;
  margin-top: var(--space-lg);
  padding: var(--space-xl) var(--space-md) calc(var(--space-xl) + 5.5rem);
  background: var(--color-bg-subtle);
  border-top: 1px solid var(--color-border);
  overflow: hidden;
}

@media (min-width: 768px) {
  .footer {
    padding-bottom: var(--space-xl);
  }
}

.footer__mesh {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 55% at 12% 0%, color-mix(in srgb, var(--color-primary-tint) 65%, transparent), transparent 58%),
    radial-gradient(ellipse 55% 50% at 95% 100%, color-mix(in srgb, var(--color-accent-muted) 45%, transparent), transparent 52%);
  opacity: 0.85;
}

.footer__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.footer__top {
  display: grid;
  gap: var(--space-xl);
  align-items: start;
}

@media (min-width: 900px) {
  .footer__top {
    grid-template-columns: minmax(240px, 0.95fr) minmax(0, 2.05fr);
    gap: var(--space-xl) var(--space-lg);
  }
}

.footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  max-width: 22rem;
}

.footer__brand-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: var(--color-text);
  width: fit-content;
  line-height: 0;
}

.footer__brand-link:hover .brand-logo {
  opacity: 0.88;
}

.footer__logo-wrap {
  height: 4.25rem;
  width: 4.25rem;
  justify-content: flex-start;
}

.footer__logo-wrap .brand-logo {
  object-position: left center;
  transition: opacity var(--transition);
}

@media (max-width: 767px) {
  .footer__logo-wrap {
    height: 3.75rem;
    width: 3.75rem;
  }
}

.footer__tagline {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-style: italic;
  color: var(--color-accent);
}

.footer__entity,
.footer__address,
.footer__contact-line {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--color-text-muted);
}

.footer__address {
  font-style: normal;
}

.footer__link--email {
  font-weight: 600;
  color: var(--color-primary-mid);
}

.footer__sitemap {
  display: grid;
  gap: var(--space-lg);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 640px) {
  .footer__sitemap {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.footer__col-title {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent);
}

.footer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.footer__link {
  display: inline-block;
  font-size: var(--text-sm);
  line-height: 1.45;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--transition), transform 0.22s ease;
}

.footer__link:hover,
.footer__link:focus-visible {
  color: var(--color-primary);
}

.footer__link--current {
  color: var(--color-primary);
  font-weight: 600;
}

.footer__cta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-radius: var(--radius-card);
  border: 1px solid color-mix(in srgb, var(--color-accent) 25%, var(--color-border));
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--color-primary-tint) 50%, var(--color-bg-raised)), var(--color-bg-raised));
  box-shadow: var(--shadow-soft);
}

@media (min-width: 768px) {
  .footer__cta {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-lg);
  }

  .footer__cta .btn {
    flex-shrink: 0;
    min-width: 14rem;
    min-height: 52px;
    padding-inline: 1.5rem;
    font-size: var(--text-base);
  }
}

.footer__cta-text {
  margin: 0;
  max-width: 36rem;
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--color-text);
}

.footer__bottom {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--color-border);
  text-align: center;
}

@media (min-width: 768px) {
  .footer__bottom {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    text-align: left;
  }
}

.footer__copy,
.footer__licence {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  line-height: 1.5;
}

.footer__legal {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.35rem 0.85rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

@media (min-width: 768px) {
  .footer__legal {
    justify-content: flex-end;
  }
}

.footer__legal .footer__link {
  font-size: var(--text-xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* --- Back to top --- */
.back-to-top {
  position: fixed;
  right: max(1rem, env(safe-area-inset-right));
  bottom: max(5.5rem, calc(env(safe-area-inset-bottom) + 5rem));
  z-index: 60;
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border: 1px solid var(--color-border-gold);
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-bg) 90%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--color-accent);
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: opacity var(--transition), visibility var(--transition), transform var(--transition), background var(--transition), color var(--transition);
}

@media (min-width: 768px) {
  .back-to-top {
    bottom: max(1.5rem, env(safe-area-inset-bottom));
  }
}

.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--color-accent);
  color: var(--color-bg);
}

.back-to-top svg {
  width: 22px;
  height: 22px;
}

/* --- Inner page hero --- */
.page-hero {
  position: relative;
  min-height: min(52dvh, 28rem);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-block-start: calc(var(--nav-clearance) + var(--hero-below-nav));
  padding-block-end: clamp(2rem, 6vw, var(--space-xl));
  padding-inline: 0;
  text-align: left;
  overflow: hidden;
}

.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-hero);
  pointer-events: none;
  z-index: 0;
}

.page-hero .container {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  width: 100%;
  max-width: var(--hero-max);
  margin-inline: auto;
  padding-inline:
    max(var(--hero-gutter), env(safe-area-inset-left, 0px))
    max(var(--hero-gutter), env(safe-area-inset-right, 0px));
}

.page-hero h1 {
  font-size: clamp(2rem, 1.2rem + 4vw, 3.75rem);
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin: 0 0 var(--space-sm);
}

.page-hero__lead {
  max-width: 36rem;
  color: var(--color-text-muted);
  font-size: var(--text-base);
  margin: 0;
}

/* --- Homepage explore gateways --- */
.explore {
  padding-block: var(--space-xl);
}

.explore-grid {
  display: grid;
  gap: var(--space-md);
}

@media (min-width: 768px) {
  .explore-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.explore-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding: var(--space-lg);
  min-height: 100%;
  text-decoration: none;
  color: inherit;
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  transition: border-color var(--transition), transform 0.2s ease, box-shadow var(--transition);
}

.explore-card::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 8rem;
  height: 8rem;
  background: radial-gradient(circle at 100% 0%, var(--color-primary-tint), transparent 70%);
  opacity: 0.9;
  pointer-events: none;
}

.explore-card:hover {
  border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border));
  transform: translateY(-4px);
  box-shadow: var(--shadow-lift);
}

.explore-card__icon {
  width: 3rem;
  height: 3rem;
  padding: 0.65rem;
  border-radius: 14px;
  background: var(--color-primary-tint);
  color: var(--color-primary);
  border: 1px solid var(--color-border);
}

.explore-card__icon svg {
  width: 100%;
  height: 100%;
  max-width: none;
}

.explore-card__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  line-height: 1.15;
  margin: 0;
  position: relative;
  z-index: 1;
}

.explore-card p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
  flex-grow: 1;
  position: relative;
  z-index: 1;
}

.explore-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-top: var(--space-xs);
  position: relative;
  z-index: 1;
}

.explore-card__cta svg {
  width: 1rem;
  height: 1rem;
  max-width: none;
  transition: transform 0.25s ease;
}

.explore-card:hover .explore-card__cta svg {
  transform: translateX(4px);
}

/* --- Homepage: hero panel (stats + navigation) --- */
.hero__panel {
  margin-top: clamp(var(--space-lg), 5vw, var(--space-xl));
  padding: clamp(var(--space-md), 3vw, var(--space-lg));
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  background:
    linear-gradient(
      165deg,
      color-mix(in srgb, var(--color-bg-raised) 96%, var(--color-primary-tint)) 0%,
      var(--color-bg-raised) 55%
    );
  box-shadow: var(--shadow-soft);
  text-align: left;
}

.hero__panel-heading {
  margin: 0 0 var(--space-md);
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent);
}

.hero__highlights {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-sm);
  margin: 0 0 var(--space-md);
  padding: 0 0 var(--space-md);
  border-bottom: 1px solid var(--color-border);
  list-style: none;
}

.hero-highlight {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: var(--space-md);
  min-height: 100%;
  border-radius: calc(var(--radius-ui) + 2px);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 55%, transparent);
}

.hero-highlight__value {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.1rem + 2vw, 2.25rem);
  font-weight: 600;
  color: var(--color-primary);
  line-height: 1.05;
}

.hero-highlight__label {
  display: block;
  font-size: var(--text-sm);
  line-height: 1.45;
  color: var(--color-text-muted);
}

.hero__navigator {
  display: grid;
  gap: var(--space-sm);
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.hero__navigator-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.25rem var(--space-sm);
}

.hero__navigator-label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
}

.hero__navigator-hint {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--color-text-faint);
}

.hero__jump-select {
  width: 100%;
  min-height: 3rem;
}

.hero__quick-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hero__quick-nav a {
  display: inline-flex;
  align-items: center;
  min-height: 2.5rem;
  padding: 0.4rem 0.95rem;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-muted);
  text-decoration: none;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-bg);
  transition:
    color var(--transition),
    border-color var(--transition),
    background var(--transition),
    transform 0.15s ease;
}

.hero__quick-nav a:hover,
.hero__quick-nav a:focus-visible {
  color: var(--color-primary);
  border-color: color-mix(in srgb, var(--color-primary-light) 45%, var(--color-border));
  background: var(--color-primary-tint);
}

@media (min-width: 900px) {
  .hero-nav-dock {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, auto);
    grid-template-rows: auto;
    align-items: center;
    column-gap: var(--space-lg);
    row-gap: var(--space-sm);
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .hero-nav-dock .services-dock__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto auto;
    gap: var(--space-sm);
    grid-column: 1;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
  }

  .hero-nav-dock .services-dock__label {
    flex: none;
    margin: 0;
    padding: 0;
    border: none;
    font-family: var(--font-ui);
    font-size: var(--text-sm);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: none;
    color: var(--color-text);
  }

  .hero-nav-dock .service-nav-select {
    grid-row: 2;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    min-height: 3rem;
    border-radius: var(--radius-ui);
    border-color: color-mix(in srgb, var(--color-border) 70%, var(--color-primary) 18%);
    background-color: var(--color-bg-raised);
    box-shadow:
      inset 0 1px 0 color-mix(in srgb, #fff 55%, transparent),
      0 1px 2px color-mix(in srgb, var(--color-primary) 5%, transparent);
  }

  .hero-nav-dock__quick {
    grid-column: 2;
    grid-row: 1;
    justify-content: flex-end;
    align-content: center;
    max-width: 20rem;
  }
}

.home-statement {
  position: relative;
  padding-block: clamp(3rem, 8vw, 6rem);
  padding-inline: var(--space-md);
  background: linear-gradient(135deg, var(--color-bg-subtle) 0%, var(--color-bg) 50%, var(--color-primary-tint) 100%);
  border-block: 1px solid var(--color-border);
  overflow: hidden;
}

.home-statement::before {
  content: '';
  position: absolute;
  inset: -20%;
  background: radial-gradient(circle at 20% 50%, color-mix(in srgb, var(--color-accent-muted) 40%, transparent), transparent 55%);
  pointer-events: none;
}

.home-statement .container {
  position: relative;
  z-index: 1;
  max-width: 52rem;
}

.home-statement blockquote {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 1rem + 2vw, 2.25rem);
  font-weight: 500;
  line-height: 1.35;
  color: var(--color-text);
}

.home-statement cite {
  display: block;
  margin-top: var(--space-md);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-style: normal;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
}

.home-bento .section-intro {
  margin-bottom: var(--space-md);
}

/* Services overview — horizontal rows (stack on small screens) */
.home-service-rail {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin: 0;
  padding: 0;
}

.home-service-row {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  min-width: 0;
  padding: var(--space-md);
  padding-left: calc(var(--space-md) + 6px);
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-ui);
  box-shadow: var(--shadow-soft);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.home-service-row__accent {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  border-radius: var(--radius-ui) 0 0 var(--radius-ui);
  background: linear-gradient(180deg, var(--color-accent), var(--color-primary-light));
}

.home-service-row--lead {
  border-color: color-mix(in srgb, var(--color-accent) 38%, var(--color-border));
  background: linear-gradient(
    100deg,
    color-mix(in srgb, var(--color-primary-tint) 55%, var(--color-bg-raised)),
    var(--color-bg-raised) 55%
  );
}

.home-service-row__code {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--color-accent);
}

.home-service-row__core {
  min-width: 0;
}

.home-service-row__core h3 {
  margin: 0 0 0.4rem;
  font-size: var(--text-lg);
  line-height: 1.25;
  color: var(--color-text);
}

.home-service-row__core p {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.65;
  color: var(--color-text-muted);
}

.home-service-row__cta {
  align-self: stretch;
  justify-content: center;
  margin-top: var(--space-xs);
  box-sizing: border-box;
}

@media (min-width: 720px) {
  .home-service-row {
    display: grid;
    grid-template-columns: 5.25rem minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    align-items: center;
    column-gap: var(--space-md);
    row-gap: 0.35rem;
    padding: var(--space-md) var(--space-md);
    padding-left: calc(var(--space-md) + 6px);
  }

  .home-service-row__code {
    grid-column: 1;
    grid-row: 1 / -1;
    align-self: center;
  }

  .home-service-row__core {
    grid-column: 2;
    grid-row: 1 / -1;
  }

  .home-service-row__core h3 {
    margin-bottom: 0.25rem;
  }

  .home-service-row__cta {
    grid-column: 3;
    grid-row: 1 / -1;
    align-self: center;
    margin-top: 0;
    width: auto;
    justify-content: center;
    white-space: nowrap;
  }
}

.about-tease {
  padding-block: var(--space-xl);
}

.about-tease__grid {
  display: grid;
  gap: var(--space-lg);
  align-items: start;
}

@media (min-width: 900px) {
  .about-tease__grid {
    grid-template-columns: 1.15fr 0.85fr;
  }
}

.about-tease__main h2 {
  margin-bottom: var(--space-md);
}

.about-tease__main p {
  color: var(--color-text-muted);
  margin-bottom: var(--space-md);
}

.about-tease__aside .card {
  height: 100%;
}

.about-tease__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.about-tease__list li {
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.about-tease__list li:last-child {
  border-bottom: none;
}

.about-tease__list strong {
  color: var(--color-text);
}

.contact-tease {
  padding-block: var(--space-xl);
  background: var(--color-bg-subtle);
  border-block: 1px solid var(--color-border);
}

.contact-tease__grid {
  display: grid;
  gap: var(--space-lg);
  align-items: center;
}

@media (min-width: 768px) {
  .contact-tease__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.contact-tease__mail {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1rem + 2.5vw, 2.5rem);
  font-weight: 600;
  word-break: break-all;
  line-height: 1.2;
}

.contact-tease__mail a {
  color: var(--color-primary);
}

.contact-tease__mail a:hover {
  color: var(--color-accent-warm);
}

.contact-tease__note {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-sm);
}

.pillar-section {
  padding-block: var(--space-xl);
}

.pillar-grid {
  display: grid;
  gap: var(--space-md);
}

@media (min-width: 768px) {
  .pillar-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.pillar-card {
  padding: var(--space-lg);
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  background: var(--color-bg-raised);
  position: relative;
  overflow: hidden;
}

.pillar-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-gold);
  opacity: 0.85;
}

.pillar-card h3 {
  margin: 0 0 var(--space-sm);
  font-size: var(--text-lg);
}

.pillar-card p {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.home-process {
  padding-block: var(--space-xl);
  background: var(--color-bg-subtle);
}

.home-process__grid {
  display: grid;
  gap: var(--space-md);
}

@media (min-width: 768px) {
  .home-process__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.home-process__step {
  position: relative;
  padding: var(--space-md);
  padding-top: var(--space-lg);
  border-radius: var(--radius-card);
  border: 1px solid var(--color-border);
  background: var(--color-bg-raised);
}

.home-process__num {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-sm);
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-primary-tint);
  line-height: 1;
  opacity: 0.9;
}

.home-process__step h3 {
  font-size: var(--text-base);
  margin: 0 0 var(--space-xs);
}

.home-process__step p {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.home-cta-dual {
  padding-block: var(--space-xl);
}

.home-cta-dual__row {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-md);
  width: 100%;
}

.home-cta-dual__row .btn {
  width: 100%;
  max-width: 100%;
  justify-content: center;
  min-height: 52px;
  font-size: var(--text-base);
}

@media (min-width: 640px) {
  .home-cta-dual__row {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: stretch;
    align-items: stretch;
  }

  .home-cta-dual__row .btn {
    flex: 1 1 calc(33.333% - var(--space-md));
    min-width: 10.5rem;
    max-width: none;
  }
}

.service-depth {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}

.service-depth h4 {
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin: var(--space-md) 0 var(--space-xs);
}

.service-depth h4:first-child {
  margin-top: 0;
}

.service-depth p,
.service-depth li {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.service-depth ul {
  margin: 0;
  padding-left: 1.1rem;
}

.detail-band {
  padding-block: var(--space-xl);
  background: var(--color-bg-subtle);
  border-block: 1px solid var(--color-border);
}

.detail-band h2 {
  margin-bottom: var(--space-md);
}

.detail-columns {
  display: grid;
  gap: var(--space-lg);
}

@media (min-width: 768px) {
  .detail-columns {
    grid-template-columns: 1fr 1fr;
  }
}

.detail-columns p {
  color: var(--color-text-muted);
  margin: 0 0 var(--space-sm);
}

.faq-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.faq-list li {
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-border);
}

.faq-list li:last-child {
  border-bottom: none;
}

.faq-list strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-base);
  margin-bottom: var(--space-xs);
  color: var(--color-text);
}

.faq-list p {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.map-embed {
  margin-top: var(--space-md);
  border-radius: var(--radius-card);
  overflow: hidden;
  border: 1px solid var(--color-border);
  min-height: 200px;
  background: var(--color-bg-subtle);
}

.map-embed a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  padding: var(--space-lg);
  text-align: center;
  font-weight: 500;
  color: var(--color-primary-mid);
}

.map-embed a:hover {
  background: var(--color-primary-tint);
}

.contact-tease__lede {
  margin-bottom: var(--space-sm);
}

.home-cta-dual__intro {
  text-align: center;
  max-width: 40rem;
  margin-inline: auto;
}

.card-featured .service-depth {
  border-top-color: rgba(255, 255, 255, 0.2);
}

.card-featured .service-depth h4 {
  color: var(--color-accent-warm);
}

.card-featured .service-depth p,
.card-featured .service-depth li {
  color: rgba(250, 249, 246, 0.88);
}

section[id],
.timeline-item[id],
.contact-page__find,
.contact-page__faq,
#site-engage {
  scroll-margin-top: calc(var(--nav-clearance) + 1.25rem);
}

@media (max-width: 767px) {
  section[id],
  .timeline-item[id],
  .contact-page__find,
  .contact-page__faq,
  #site-engage {
    scroll-margin-top: calc(var(--nav-clearance) + 0.65rem);
  }
}

.about-regulatory-grid {
  margin-top: var(--space-xl);
}

.about-values-spaced {
  margin-top: var(--space-xl);
}

.about-apart-spaced {
  margin-top: var(--space-xl);
}

.about-milestones {
  margin-top: var(--space-xl);
}

.contact-find-spaced {
  margin-top: var(--space-xl);
}

.contact-faq-spaced {
  margin-top: var(--space-xl);
}

.coverage-icon {
  width: 1.15rem;
  height: 1.15rem;
  margin-top: 0.15rem;
}

.value-card__mark {
  width: 2.25rem;
  height: 2.25rem;
  margin-bottom: var(--space-sm);
  color: var(--color-accent);
}

.contact-card__icon {
  width: 2.75rem;
  height: 2.75rem;
  padding: 0.55rem;
  margin-bottom: var(--space-xs);
  border-radius: 12px;
  background: var(--color-primary-tint);
  color: var(--color-primary);
  border: 1px solid var(--color-border);
}

.contact-card__icon svg {
  width: 100%;
  height: 100%;
  max-width: none;
}

.coverage-diamond {
  display: none;
}

/* --- Section reveal (base; enhanced in motion.css when html.motion-on) --- */
.section-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.section-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.section-reveal.is-exiting {
  opacity: 0;
  transform: translateY(-16px);
}

/* Stagger children in grids */
.section-reveal.is-visible .stat-card,
.section-reveal.is-visible .coverage-list li,
.section-reveal.is-visible .timeline-item,
.section-reveal.is-visible .value-card {
  animation: revealChild 0.6s ease forwards;
}

.section-reveal.is-visible .stat-card:nth-child(1),
.section-reveal.is-visible .coverage-list li:nth-child(1),
.section-reveal.is-visible .timeline-item:nth-child(1),
.section-reveal.is-visible .value-card:nth-child(1) { animation-delay: 0.05s; }
.section-reveal.is-visible .stat-card:nth-child(2),
.section-reveal.is-visible .coverage-list li:nth-child(2),
.section-reveal.is-visible .timeline-item:nth-child(2),
.section-reveal.is-visible .value-card:nth-child(2) { animation-delay: 0.12s; }
.section-reveal.is-visible .stat-card:nth-child(3),
.section-reveal.is-visible .coverage-list li:nth-child(3),
.section-reveal.is-visible .timeline-item:nth-child(3),
.section-reveal.is-visible .value-card:nth-child(3) { animation-delay: 0.19s; }
.section-reveal.is-visible .stat-card:nth-child(4),
.section-reveal.is-visible .coverage-list li:nth-child(4),
.section-reveal.is-visible .timeline-item:nth-child(4) { animation-delay: 0.26s; }
.section-reveal.is-visible .coverage-list li:nth-child(5) { animation-delay: 0.33s; }
.section-reveal.is-visible .coverage-list li:nth-child(6) { animation-delay: 0.4s; }
.section-reveal.is-visible .coverage-list li:nth-child(7) { animation-delay: 0.47s; }
.section-reveal.is-visible .timeline-item:nth-child(5) { animation-delay: 0.33s; }
.section-reveal.is-visible .timeline-item:nth-child(6) { animation-delay: 0.4s; }
.section-reveal.is-visible .timeline-item:nth-child(7) { animation-delay: 0.47s; }

.section-reveal.is-visible .home-service-row,
.section-reveal.is-visible .hero-stat-item,
.section-reveal.is-visible .home-process__step,
.section-reveal.is-visible .pillar-card {
  animation: revealChild 0.6s ease forwards;
}

.section-reveal.is-visible .home-service-row:nth-child(1) { animation-delay: 0.03s; }
.section-reveal.is-visible .home-service-row:nth-child(2) { animation-delay: 0.06s; }
.section-reveal.is-visible .home-service-row:nth-child(3) { animation-delay: 0.09s; }
.section-reveal.is-visible .home-service-row:nth-child(4) { animation-delay: 0.12s; }
.section-reveal.is-visible .home-service-row:nth-child(5) { animation-delay: 0.15s; }
.section-reveal.is-visible .home-service-row:nth-child(6) { animation-delay: 0.18s; }
.section-reveal.is-visible .home-service-row:nth-child(7) { animation-delay: 0.21s; }
.section-reveal.is-visible .hero-stat-item:nth-child(1) { animation-delay: 0.05s; }
.section-reveal.is-visible .hero-stat-item:nth-child(2) { animation-delay: 0.1s; }
.section-reveal.is-visible .hero-stat-item:nth-child(3) { animation-delay: 0.15s; }
.section-reveal.is-visible .home-process__step:nth-child(1) { animation-delay: 0.04s; }
.section-reveal.is-visible .home-process__step:nth-child(2) { animation-delay: 0.1s; }
.section-reveal.is-visible .home-process__step:nth-child(3) { animation-delay: 0.16s; }
.section-reveal.is-visible .home-process__step:nth-child(4) { animation-delay: 0.22s; }
.section-reveal.is-visible .pillar-card:nth-child(1) { animation-delay: 0.06s; }
.section-reveal.is-visible .pillar-card:nth-child(2) { animation-delay: 0.12s; }
.section-reveal.is-visible .pillar-card:nth-child(3) { animation-delay: 0.18s; }

@keyframes revealChild {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* --- Cursor follower (mouse / fine pointer only) --- */
.cursor-follower,
.cursor-follower * {
  pointer-events: none !important;
}

.cursor-follower {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 9990;
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.cursor-follower.is-visible {
  opacity: 1;
}

.cursor-follower.is-hidden {
  opacity: 0;
  transition-duration: 0.2s;
}

.cursor-follower__glow-wrap {
  position: absolute;
  left: 0;
  top: 0;
  width: 140px;
  height: 140px;
  margin-left: -70px;
  margin-top: -70px;
  will-change: transform;
  opacity: 0.5;
  transition: opacity 0.35s ease;
}

.cursor-follower--moving .cursor-follower__glow-wrap {
  opacity: 0.72;
}

.cursor-follower--hover .cursor-follower__glow-wrap {
  opacity: 0.88;
}

.cursor-follower__glow {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 32% 28%,
      color-mix(in srgb, var(--color-accent-warm) 42%, transparent) 0%,
      color-mix(in srgb, var(--color-primary-light) 18%, transparent) 38%,
      transparent 68%
    );
  filter: blur(14px);
  transform: scale(1.05);
}

.cursor-follower__ring-wrap {
  position: absolute;
  left: 0;
  top: 0;
  width: 46px;
  height: 46px;
  margin-left: -23px;
  margin-top: -23px;
  will-change: transform;
}

.cursor-follower__ring-vel {
  position: relative;
  width: 100%;
  height: 100%;
  will-change: transform;
  transform-origin: 50% 50%;
}

.cursor-follower__ring-highlight {
  position: absolute;
  inset: -1px;
  border-radius: 50%;
  z-index: 0;
  background: conic-gradient(
    from 200deg,
    transparent 0deg,
    color-mix(in srgb, var(--color-accent-warm) 70%, transparent) 42deg,
    color-mix(in srgb, var(--color-primary-light) 50%, transparent) 78deg,
    transparent 130deg,
    transparent 360deg
  );
  opacity: 0.35;
  animation: cursorFollowerShine 5.5s linear infinite;
  mix-blend-mode: overlay;
  pointer-events: none;
}

@keyframes cursorFollowerShine {
  to {
    transform: rotate(360deg);
  }
}

.cursor-follower__ring {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 1.5px solid color-mix(in srgb, var(--color-border-gold) 88%, var(--color-accent-warm));
  background: color-mix(in srgb, var(--color-bg) 38%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--color-primary) 12%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent),
    0 14px 44px color-mix(in srgb, var(--color-accent) 22%, transparent);
  transition:
    transform 0.28s cubic-bezier(0.34, 1.4, 0.64, 1),
    border-color 0.3s ease,
    box-shadow 0.35s ease,
    background 0.3s ease;
}

.cursor-follower__dot-wrap {
  position: absolute;
  left: 0;
  top: 0;
  width: 6px;
  height: 6px;
  margin-left: -3px;
  margin-top: -3px;
  will-change: transform;
}

.cursor-follower__dot {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: radial-gradient(
    circle at 30% 28%,
    color-mix(in srgb, #fff 55%, var(--color-primary-light)) 0%,
    var(--color-primary) 55%
  );
  box-shadow:
    0 0 10px color-mix(in srgb, var(--color-primary-light) 55%, transparent),
    0 0 22px color-mix(in srgb, var(--color-accent) 25%, transparent);
  transition:
    transform 0.22s cubic-bezier(0.34, 1.4, 0.64, 1),
    box-shadow 0.3s ease;
}

.cursor-follower--hover .cursor-follower__ring {
  transform: scale(1.22);
  border-color: color-mix(in srgb, var(--color-accent-warm) 75%, var(--color-border-gold));
  background: color-mix(in srgb, var(--color-bg) 28%, transparent);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--color-accent) 22%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 18%, transparent),
    0 18px 52px color-mix(in srgb, var(--color-accent) 32%, transparent);
}

.cursor-follower--hover .cursor-follower__ring-highlight {
  opacity: 0.52;
}

.cursor-follower--hover .cursor-follower__dot {
  transform: scale(1.35);
  background: radial-gradient(
    circle at 28% 26%,
    color-mix(in srgb, #fff 48%, var(--color-accent-warm)) 0%,
    var(--color-accent) 58%
  );
  box-shadow:
    0 0 14px color-mix(in srgb, var(--color-accent-warm) 65%, transparent),
    0 0 28px color-mix(in srgb, var(--color-accent) 35%, transparent);
}

.cursor-follower--moving:not(.cursor-follower--hover) .cursor-follower__dot {
  box-shadow:
    0 0 12px color-mix(in srgb, var(--color-primary-light) 45%, transparent),
    0 0 26px color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.cursor-follower--press .cursor-follower__ring {
  transform: scale(0.88);
}

.cursor-follower--press.cursor-follower--hover .cursor-follower__ring {
  transform: scale(0.92);
}

.cursor-follower--press .cursor-follower__ring-highlight {
  opacity: 0.22;
}

.cursor-follower--press .cursor-follower__dot {
  transform: scale(0.78);
}

.cursor-follower--press.cursor-follower--hover .cursor-follower__dot {
  transform: scale(0.85);
}

/* --- Mobile: readable type, touch targets, safe insets --- */
@media (max-width: 767px) {
  :root {
    --touch-min: 3rem;
    --touch-comfort: 3.25rem;
  }

  html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }

  body {
    font-size: 1.0625rem;
    line-height: 1.65;
  }

  .container {
    width: min(100% - max(1.5rem, env(safe-area-inset-left) + env(safe-area-inset-right)), 1200px);
  }

  section:not(.hero):not(.page-hero) {
    padding-inline: max(1rem, env(safe-area-inset-left)) max(1rem, env(safe-area-inset-right));
    padding-block: clamp(1.75rem, 5vw, var(--space-xl));
  }

  .hero,
  header.page-hero {
    padding-inline: 0;
  }

  .hero > .container,
  .hero__content {
    --hero-gutter: max(1.25rem, 4vw, 1.5rem);
  }

  body > main {
    padding-bottom: max(5.5rem, calc(env(safe-area-inset-bottom) + 4.5rem));
  }

  .hero {
    min-height: auto;
    padding-block-start: calc(var(--nav-clearance) + var(--hero-below-nav));
    padding-block-end: clamp(2rem, 6vw, 3rem);
    text-align: left;
    overflow: clip;
    isolation: isolate;
  }

  .page-hero,
  .page-hero.page-hero--animated {
    min-height: auto;
    padding-block-start: calc(var(--nav-clearance) + var(--hero-below-nav));
    padding-block-end: clamp(1.75rem, 5vw, 2.5rem);
    justify-content: flex-start;
  }

  .page-hero .container {
    --hero-gutter: max(1.25rem, 4vw, 1.5rem);
  }

  .hero__content {
    text-align: left;
  }

  .hero h1 {
    max-width: none;
  }

  .hero__lead {
    margin-inline: 0;
    max-width: none;
  }

  .hero__actions {
    max-width: none;
    margin-inline: 0;
  }

  .hero__mesh::before {
    opacity: 0.18;
  }

  .hero__panel {
    margin-top: var(--space-lg);
    padding: var(--space-md);
  }

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

  .hero-highlight {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    align-items: center;
    column-gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
  }

  .hero-highlight__value {
    grid-column: 1;
    grid-row: 1 / -1;
    font-size: clamp(1.35rem, 1.1rem + 2vw, 1.75rem);
    min-width: 2.5rem;
    text-align: center;
  }

  .hero-highlight__label {
    grid-column: 2;
    font-size: max(1rem, 16px);
    line-height: 1.45;
  }

  .hero-nav-dock {
    gap: 0;
  }

  #home-why {
    padding-top: var(--space-lg);
  }

  h1 {
    font-size: clamp(2.125rem, 1.4rem + 5.5vw, 2.75rem);
    line-height: 1.1;
  }

  h2,
  .feature-page-h2 {
    font-size: clamp(1.625rem, 1.2rem + 3.5vw, 2rem);
    line-height: 1.15;
  }

  h3 {
    font-size: max(1.125rem, 18px);
    line-height: 1.25;
  }

  .hero__lead,
  .page-hero__lead,
  .section-intro,
  .home-service-row__core p,
  .stat-card__value,
  .coverage-list li,
  .footer p,
  .accordion__panel p,
  .metric-card__label {
    font-size: max(1.0625rem, 17px);
    line-height: 1.65;
  }

  .section-label,
  .eyebrow {
    font-size: max(0.875rem, 14px);
    line-height: 1.45;
  }

  .hero__location {
    font-size: max(0.9375rem, 15px);
    line-height: 1.5;
  }

  .stat-card__label {
    font-size: max(0.875rem, 14px);
    letter-spacing: 0.08em;
  }

  .accordion__trigger {
    min-height: var(--touch-comfort);
    padding-block: 1rem;
    font-size: max(1.0625rem, 17px);
    line-height: 1.4;
  }

  .service-nav-select {
    min-height: var(--touch-comfort);
    font-size: max(1.0625rem, 17px);
  }

  .stat-card__value {
    font-size: max(1.125rem, 18px);
    line-height: 1.4;
  }

  .stat-card,
  .card,
  .glass-card {
    padding: max(var(--space-md), 1.125rem);
  }

  .home-service-row__core h3 {
    font-size: max(1.125rem, 18px);
  }

  .home-service-row__cta {
    min-height: var(--touch-comfort);
    font-size: max(1rem, 16px);
  }

  .hero__actions .btn {
    min-height: var(--touch-comfort);
    font-size: max(1.0625rem, 17px);
  }

  .section-cta > .btn,
  .section-cta > a.btn,
  .home-cta-dual__row .btn,
  .footer__cta .btn {
    min-height: var(--touch-comfort);
    font-size: max(1.0625rem, 17px);
  }

  .btn {
    min-height: var(--touch-min);
    font-size: max(1rem, 16px);
    padding-inline: 1.35rem;
  }

  .coverage-list li {
    min-height: var(--touch-min);
    padding: 0.85rem 1rem;
    font-size: max(1rem, 16px);
    align-items: center;
  }

  .explore-card,
  .contact-tease a,
  .about-tease a {
    min-height: var(--touch-min);
  }

  input,
  textarea,
  select {
    min-height: var(--touch-min);
    font-size: max(1.0625rem, 17px);
  }

  textarea {
    min-height: 8rem;
  }

  .nav__toggle {
    width: var(--touch-min);
    height: var(--touch-min);
  }

  .nav-link {
    min-height: var(--touch-min);
    padding: 0.55rem 0.65rem;
    font-size: max(1.125rem, 18px);
  }

  .nav__menu-quick-link {
    min-height: var(--touch-min);
    font-size: max(0.9375rem, 15px);
    padding: 0.55rem 0.65rem;
  }

  .nav__menu-foot .nav-cta {
    min-height: var(--touch-comfort);
    font-size: max(1rem, 16px);
  }

  .mobile-nav-link {
    min-width: 3.75rem;
    min-height: var(--touch-min);
    padding: 0.45rem 0.6rem;
  }

  .mobile-nav-link span {
    font-size: max(0.8125rem, 13px);
    line-height: 1.25;
    font-weight: 600;
  }

  .mobile-nav-link .mobile-nav-icon {
    width: 26px;
    height: 26px;
  }

  .mobile-bottom-nav {
    min-height: 4.5rem;
    padding: 0.6rem 0.5rem max(0.5rem, env(safe-area-inset-bottom));
    left: max(0.75rem, env(safe-area-inset-left));
    right: max(0.75rem, env(safe-area-inset-right));
  }

  .footer__link {
    min-height: var(--touch-min);
    padding-block: 0.4rem;
    font-size: max(1rem, 16px);
  }

  .back-to-top {
    width: var(--touch-min);
    height: var(--touch-min);
    bottom: max(5.75rem, calc(env(safe-area-inset-bottom) + 4.75rem));
  }

  .back-to-top svg {
    width: 24px;
    height: 24px;
  }

  a,
  button,
  [role="button"],
  label,
  .btn,
  .nav-link,
  .mobile-nav-link,
  .footer__link,
  .coverage-list li,
  .accordion__trigger,
  .service-nav-select,
  input,
  select,
  textarea {
    touch-action: manipulation;
  }

  .explore-card p,
  .about-tease__main p,
  .contact-tease p {
    line-height: 1.65;
  }

  .home-statement blockquote {
    font-size: clamp(1.2rem, 1rem + 2vw, 1.65rem);
    line-height: 1.45;
  }

  .footer__sitemap {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md) var(--space-sm);
  }

  .footer__link {
    display: inline-flex;
    align-items: center;
    min-height: var(--touch-min);
  }

  .footer__cta .btn {
    width: 100%;
    justify-content: center;
  }

  .stat-card__value,
  .coverage-list li,
  .home-service-row__core h3,
  .timeline-item h3,
  p,
  li,
  blockquote {
    overflow-wrap: break-word;
    word-wrap: break-word;
  }

}

/* --- Reduced motion --- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }

  .section-reveal {
    opacity: 1;
    transform: none;
  }

  .cursor-follower {
    display: none !important;
  }

  .ambient-fx {
    display: none !important;
  }

  h1 em, h2 em, h3 em {
    animation: none !important;
    color: var(--color-primary) !important;
    -webkit-text-fill-color: var(--color-primary) !important;
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
  }
}
