/* meet-your-team-page.css — Phase 4 extraction 2026-04-17. */

/* §1 */
/* ── SKIP LINK ─────────────────────────────────────── */
    .skip-link {
      position: absolute; top: -100%; left: 16px; z-index: 9999;
      background: #07192E; color: #fff;
      padding: 12px 24px; border-radius: 0 0 8px 8px;
      font-family: "Inter", system-ui, sans-serif; font-size: 14px; font-weight: 600;
      text-decoration: none; transition: top .15s;
    }
    .skip-link:focus { top: 0; }

    /* -- 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;
    }

    /* ── RESET ─────────────────────────────────────────── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :focus-visible { outline: 2px solid #1779B8; outline-offset: 3px; border-radius: 6px; }
    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
      }
      .reveal { opacity: 1 !important; transform: none !important; }
    }

    /* ── PAGE-UNIQUE TOKENS ─────────────────────────────── */
    /* Removed redundant tokens already defined in site.css (verified 2026-05-05). */
    :root {
      --glow-blue:  0 0 0 1px rgba(41,171,226,.18), 0 8px 32px rgba(41,171,226,.14);
      --glow-orange: 0 0 0 1px rgba(249,115,22,.12), 0 8px 24px rgba(249,115,22,.20);
      --glass-shadow:
        0 0 0 0.5px rgba(255,255,255,.6),
        0 0 0 1px rgba(0,0,0,.02),
        0 1px 2px rgba(7,25,46,.03),
        0 4px 12px rgba(7,25,46,.04),
        0 16px 48px rgba(7,25,46,.07),
        0 32px 80px rgba(7,25,46,.04);
      --glass-shadow-hover:
        0 0 0 0.5px rgba(255,255,255,.8),
        0 0 0 1px rgba(41,171,226,.08),
        0 2px 4px rgba(7,25,46,.04),
        0 8px 24px rgba(7,25,46,.06),
        0 24px 64px rgba(7,25,46,.10),
        0 40px 96px rgba(7,25,46,.05);
    }

    /* ── BASE ───────────────────────────────────────────── */
    html { scroll-behavior: smooth; font-size: 16px; }
    body { font-family: var(--font-b); background: var(--white); color: var(--text); -webkit-font-smoothing: antialiased; line-height: 1.6; }
    a { text-decoration: none; }

    /* ── HEADER ─────────────────────────────────────────── */
    header {
      position: sticky; top: 0; z-index: 300;
      background: linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.88) 100%);
      backdrop-filter: blur(28px) saturate(1.8) brightness(1.02);
      -webkit-backdrop-filter: blur(28px) saturate(1.8) brightness(1.02);
      border-bottom: 1px solid rgba(226,236,244,.5);
      box-shadow: 0 1px 0 rgba(226,236,244,.5), 0 0 0 0.5px rgba(255,255,255,.8), 0 2px 12px rgba(7,25,46,.04), 0 4px 24px rgba(7,25,46,.03), 0 8px 32px rgba(7,25,46,.04);
      overflow: visible;
    }
    header::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 1px;
      background: rgba(255,255,255,.95);
      pointer-events: none;
      z-index: 1;
    }
    header::after {
      content: '';
      position: absolute;
      bottom: -8px; left: 0; right: 0;
      height: 8px;
      background: linear-gradient(180deg, rgba(7,25,46,.04) 0%, transparent 100%);
      pointer-events: none;
      z-index: -1;
    }
/* NAV CSS extracted to assets/site.css — see _scripts/extract_nav_css.py */

    /* ── SECTION DEFAULTS ─────────────────────────────────── */
    .sec { padding: 100px 32px; }
    .sec-inner { max-width: 1200px; margin: 0 auto; }
    .sec-label {
      font-family: var(--font-b); font-size: 13px; font-weight: 600;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--orange); text-align: center; margin-bottom: 16px;
    }
    .sec-headline {
      font-family: var(--font-h); font-weight: 700;
      font-size: 40px; line-height: 1.15; letter-spacing: -.5px;
      text-align: center; margin-bottom: 20px;
    }
    .sec-subtext {
      font-family: var(--font-b); font-size: 18px; font-weight: 400;
      text-align: center; max-width: 600px; margin: 0 auto 48px;
      line-height: 1.65;
    }

    /* ── GRADIENT SECTION DIVIDER ──────────────────────── */
    .sec-divider {
      height: 1px;
      background: linear-gradient(90deg, transparent 0%, var(--border) 15%, var(--border) 85%, transparent 100%);
      margin: 0 auto;
      max-width: 1200px;
    }

    /* ── HERO ─────────────────────────────────────────────── */
    .page-hero {
      background: linear-gradient(160deg, var(--navy) 0%, var(--navy-2) 100%);
      position: relative;
      overflow: hidden;
      padding: 48px 32px 48px;
    }
    /* Ken Burns parallax hero background (2026-04-21: opacity bumped 0.12 → 0.68
       to match .svc-hero-bg service-page pattern. Scrim ::after added for
       directional legibility over photography. Mirrors ind-hero-bg spec.) */
    .team-hero-bg {
      position: absolute; inset: 0;
      background: image-set(url('/generated-images/hero-team.avif') type('image/avif'), url('/generated-images/hero-team.webp') type('image/webp'), url('/generated-images/hero-team.jpeg') type('image/jpeg')) center/cover no-repeat;
      opacity: 0.68;
      animation: kenBurnsTeam 22s ease-in-out infinite alternate;
      z-index: 0;
      will-change: transform;
    }
    .team-hero-bg::after {
      content: '';
      position: absolute; inset: 0;
      background:
        linear-gradient(90deg, rgba(7, 25, 46, 0.82) 0%, rgba(7, 25, 46, 0.42) 55%, rgba(7, 25, 46, 0.15) 100%),
        linear-gradient(180deg, rgba(7, 25, 46, 0.00) 0%, rgba(7, 25, 46, 0.30) 80%);
      pointer-events: none;
    }
    @keyframes kenBurnsTeam {
      0% { transform: scale(1) translate(0, 0); }
      100% { transform: scale(1.08) translate(-1%, -1%); }
    }
    @media (prefers-reduced-motion: reduce) {
      .team-hero-bg { animation: none; }
    }
    /* Dot-grid pattern overlay */
    .team-dot-grid {
      position: absolute; inset: 0;
      background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
      background-size: 32px 32px;
      z-index: 1;
      pointer-events: none;
    }
    /* Floating gradient orbs */
    .team-hero-orbs {
      position: absolute; inset: 0;
      z-index: 1;
      pointer-events: none;
      overflow: hidden;
    }
    .team-orb {
      position: absolute;
      border-radius: 9999px;
      animation: orbDriftTeam var(--orb-dur, 14s) ease-in-out infinite;
      animation-delay: var(--orb-delay, 0s);
      filter: blur(2px);
    }
    @keyframes orbDriftTeam {
      0%, 100% { transform: translateY(0) translateX(0); }
      33% { transform: translateY(-18px) translateX(8px); }
      66% { transform: translateY(10px) translateX(-6px); }
    }
    @media (prefers-reduced-motion: reduce) {
      .team-orb { animation: none; }
    }
    .page-hero::before {
      content: '';
      position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 70% 80% at 10% 80%, rgba(249,115,22,.06) 0%, transparent 60%),
        radial-gradient(ellipse 60% 70% at 90% 20%, rgba(41,171,226,.08) 0%, transparent 55%),
        radial-gradient(ellipse 50% 50% at 50% 50%, rgba(41,171,226,.04) 0%, transparent 60%);
      pointer-events: none;
      z-index: 1;
    }
    /* Image divider between sections */
    .team-img-divider {
      width: 100%;
      height: 320px;
      background: image-set(url('/generated-images/team-divider-collab.avif') type('image/avif'), url('/generated-images/team-divider-collab.webp') type('image/webp'), url('/generated-images/team-divider-collab.jpeg') type('image/jpeg')) center 30% / cover no-repeat;
      position: relative;
    }
    .team-img-divider::after {
      content: '';
      position: absolute; inset: 0;
      background: linear-gradient(180deg, rgba(7,25,46,.25) 0%, rgba(7,25,46,.55) 100%);
    }
    @media (max-width: 1024px) {
      .team-img-divider { height: 200px; }
    }
    .hero-content {
      max-width: 1200px; margin: 0 auto;
      display: grid; grid-template-columns: 1.1fr 1fr;
      gap: 48px; align-items: center;
      position: relative; z-index: 2;
    }
    .hero-text {}
    .hero-h1 {
      font-family: var(--font-h);
      font-size: 28px;
      font-size: clamp(28px, 4.5vw, 52px);
      font-weight: 900;
      line-height: 1.22;
      padding-bottom: 0.05em;
      letter-spacing: -0.02em;
      color: var(--white);
      margin-bottom: 16px;
      max-width: 800px;
    }
    .hero-sub {
      font-family: var(--font-b); font-size: 20px; font-weight: 400;
      color: rgba(255,255,255,.75); line-height: 1.65;
      max-width: 640px; margin-bottom: 24px;
    }
    .hero-ctas { display: flex; gap: 16px; flex-wrap: wrap; }
    .btn-blue, .btn-secondary {
      font-family: var(--font-b); font-size: 16px; font-weight: 600;
      color: #fff; background: var(--blue);
      padding: 16px 32px; border-radius: 12px; text-decoration: none;
      transition: all .2s var(--ease); min-height: 52px;
      display: inline-flex; align-items: center; gap: 8px; cursor: pointer; border: none;
      box-shadow: 0 4px 16px rgba(41,171,226,.25);
    }
    .btn-blue:hover, .btn-secondary:hover { background: #1E96CC; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(41,171,226,.3); }
    .btn-orange {
      font-family: var(--font-b); font-size: 16px; font-weight: 600;
      color: #fff; background: var(--orange);
      padding: 16px 32px; border-radius: 12px; text-decoration: none;
      transition: all .2s var(--ease); min-height: 52px;
      display: inline-flex; align-items: center; gap: 8px; cursor: pointer; border: none;
      box-shadow: 0 4px 14px rgba(249,115,22,.18);
    }
    .btn-orange:hover { background: #EA6C10; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(249,115,22,.35); }

    /* Hero right visual */
    .hero-visual {
      display: flex; align-items: center; justify-content: center;
      position: relative;
    }
    .hero-abstract {
      width: 380px; height: 380px; position: relative;
    }
    .hero-circle {
      position: absolute; border-radius: 50%;
      opacity: .7;
    }
    .hero-circle-1 {
      width: 280px; height: 280px; top: 20px; left: 50px;
      background: radial-gradient(circle, rgba(41,171,226,.2) 0%, rgba(41,171,226,.05) 70%);
      border: 1px solid rgba(41,171,226,.15);
    }
    .hero-circle-2 {
      width: 200px; height: 200px; top: 100px; left: 140px;
      background: radial-gradient(circle, rgba(249,115,22,.15) 0%, rgba(249,115,22,.03) 70%);
      border: 1px solid rgba(249,115,22,.1);
    }
    .hero-circle-3 {
      width: 160px; height: 160px; top: 40px; left: 180px;
      background: radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%);
      border: 1px solid rgba(255,255,255,.08);
    }
    .hero-icon-float {
      position: absolute;
      width: 64px; height: 64px;
      border-radius: 16px;
      background: rgba(255,255,255,.07);
      border: 1px solid rgba(255,255,255,.1);
      backdrop-filter: blur(12px);
      display: flex; align-items: center; justify-content: center;
      animation: floaty 6s ease-in-out infinite;
    }
    .hero-icon-float:nth-child(4) { top: 30px; left: 0; animation-delay: 0s; }
    .hero-icon-float:nth-child(5) { top: 170px; right: 0; animation-delay: -2s; }
    .hero-icon-float:nth-child(6) { bottom: 20px; left: 80px; animation-delay: -4s; }
    .hero-icon-float svg { width: 28px; height: 28px; stroke: var(--blue); fill: none; stroke-width: 1.5; }

    @keyframes floaty {
      0%, 100% { transform: translateY(0); }
      50% { transform: translateY(-12px); }
    }

    /* ── SECTION 2: THREE PROMISES ──────────────────────── */
    .promises-sec { background: #F8F9FA; }
    .promises-grid {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 24px; margin-top: 48px;
    }
    .promise-card {
      background: rgba(255,255,255,.7);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      border: 1px solid rgba(7,25,46,.08);
      border-radius: 20px;
      padding: 40px 32px;
      box-shadow: 0 4px 24px rgba(7,25,46,.06);
      transition: all .3s ease;
    }
    .promise-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 40px rgba(7,25,46,.1);
    }
    .promise-icon {
      width: 56px; height: 56px;
      border-radius: 14px;
      background: rgba(41,171,226,.08);
      display: flex; align-items: center; justify-content: center;
      margin-bottom: 24px;
    }
    .promise-icon svg { width: 28px; height: 28px; stroke: var(--blue); fill: none; stroke-width: 1.5; }
    .promise-title {
      font-family: var(--font-h); font-weight: 700;
      font-size: 22px; color: var(--navy);
      margin-bottom: 14px; line-height: 1.25;
    }
    .promise-body {
      font-family: var(--font-b); font-size: 16px; font-weight: 400;
      color: #4A5568; line-height: 1.6; margin-bottom: 20px;
    }
    .promise-proof {
      font-family: var(--font-b); font-size: 14px; font-weight: 600;
      color: var(--orange);
    }

    /* ── SECTION 3: MEET YOUR TEAM ─────────────────────── */
    .team-sec { background: var(--navy); }
    .team-sec .sec-headline { color: var(--white); }
    .team-sec .sec-subtext { color: rgba(255,255,255,.7); }

    .team-grid {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 32px; max-width: 1100px; margin: 0 auto;
    }
    .team-grid .team-card:last-child:nth-child(3n - 2) {
      grid-column: 2;
    }
    /* ─── .team-card — dark-variant polish (Phase 4 2026-04-09) ───
       Glass frost preserved for the dark team-sec context. Adds a
       BOTTOM-edge accent rule (not left — would clash with the full-
       width photo crop), a top-right ghost glow, and a blue/orange/
       green per-card color cycle. Tighter hairline border. */
    .team-card {
      position: relative;
      background: rgba(255,255,255,.055);
      backdrop-filter: blur(16px) saturate(1.1);
      -webkit-backdrop-filter: blur(16px) saturate(1.1);
      border: 1px solid rgba(255,255,255,.09);
      border-radius: 14px;
      overflow: hidden;
      isolation: isolate;
      transition:
        transform .5s cubic-bezier(0.34,1.56,0.64,1),
        box-shadow .4s ease,
        border-color .3s ease;
      --card-color:#1479A3;
      --card-rgb: 41,171,226;
    }
    .team-card:nth-child(3n+1){--card-color:#1479A3;--card-rgb:41,171,226}  /* blue */
    .team-card:nth-child(3n+2){--card-color:#F97316;--card-rgb:249,115,22}  /* orange */
    .team-card:nth-child(3n+3){--card-color:#10B981;--card-rgb:16,185,129}  /* green */
    .team-card::before {
      content: '';
      position: absolute;
      left: 22px; right: 22px; bottom: 0;
      height: 3px;
      background: linear-gradient(90deg,
        transparent 0%,
        var(--card-color) 18%,
        var(--card-color) 82%,
        transparent 100%);
      border-radius: 3px 3px 0 0;
      transition: left 240ms ease-out, right 240ms ease-out, height 240ms ease-out;
      z-index: 3;
      pointer-events: none;
    }
    .team-card::after {
      content: '';
      position: absolute;
      top: -120px; right: -120px;
      width: 320px; height: 320px;
      background: radial-gradient(circle,
        rgba(var(--card-rgb),.16) 0%,
        transparent 65%);
      pointer-events: none;
      z-index: 0;
      opacity: .45;
      transition: opacity 240ms ease-out;
    }
    .team-card > * { position: relative; z-index: 1; }
    .team-card:hover {
      transform: translateY(-8px);
      box-shadow:
        0 20px 40px rgba(7,25,46,.22),
        0 0 0 1.5px rgba(var(--card-rgb),.28);
      border-color: rgba(var(--card-rgb),.35);
    }
    .team-card:hover::before { left: 14px; right: 14px; height: 4px; }
    .team-card:hover::after { opacity: 1; }
    @media (prefers-reduced-motion: reduce) {
      .team-card,.team-card::before,.team-card::after {
        transition: none !important;
        animation: none !important;
      }
    }
    .team-photo {
      width: 100%; height: 280px;
      position: relative; overflow: hidden;
      display: flex; align-items: center; justify-content: center;
    }
    .team-photo-placeholder {
      width: 100%; height: 100%;
      background-size: cover;
      background-position: center;
      border: 3px solid rgba(255,255,255,.2);
      filter: grayscale(20%) brightness(.95);
      transition: filter .5s ease, transform .3s ease;
    }
    .team-card:hover .team-photo-placeholder {
      filter: grayscale(0%) brightness(1);
      transform: scale(1.05);
    }
    /* Initials-fallback avatars: keep full saturation (not photos, no grayscale).
       2026-05-24: was being dimmed by the photo filter and looked washed out. */
    .team-photo-placeholder.team-avatar-initials {
      filter: none;
      border: none;
    }
    .team-card:hover .team-photo-placeholder.team-avatar-initials {
      filter: none;
    }

    .team-info { padding: 28px 28px 24px; }
    .team-name {
      font-family: var(--font-h); font-weight: 700;
      font-size: 22px; color: var(--white);
      margin-bottom: 4px;
    }
    .team-title {
      font-family: var(--font-b); font-weight: 500;
      font-size: 15px; color: var(--blue);
      margin-bottom: 10px;
    }
    .team-bio {
      font-family: var(--font-b); font-size: 14px; font-weight: 400;
      color: rgba(255,255,255,.7); line-height: 1.6;
      margin-bottom: 16px;
    }
    .team-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
    .team-tag {
      /* High-contrast team-skill pill (2026-05-20). Old pale-blue/pale-blue
         combo was failing WCAG. Deeper background + darker text now read
         cleanly. */
      background: rgba(20, 121, 163, 0.10);
      color: #0F66A6;
      border: 1px solid rgba(20, 121, 163, 0.28);
      border-radius: 100px;
      padding: 4px 12px;
      font-family: var(--font-b); font-size: 12px; font-weight: 600;
    }
    .team-tag-years {
      background: rgba(249, 115, 22, 0.10);
      color: #9A330A;  /* AA-compliant deep orange, not the banned burnt-orange */
      border-color: rgba(249, 115, 22, 0.30);
    }
    .team-cta {
      display: inline-flex; align-items: center; gap: 6px;
      font-family: var(--font-b); font-size: 14px; font-weight: 600;
      color: var(--orange); text-decoration: none;
      transition: gap .2s, color .2s;
      /* S3 audit fix (2026-05-13): was 27px tall (sub-44 WCAG tap
         target) on 12 instances at 375. min-height + padding gives a
         real tap area without changing the visual ink. */
      min-height: 44px;
      padding: 8px 4px;
      margin: -8px -4px;
    }
    .team-cta:hover { gap: 10px; color: #FDBA74; }
    .team-cta svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2.5; }

    /* Row alignment: bottom-anchor the "Talk to" CTA so all three cards'
       links sit on the same floor even when a longer credential pill
       (e.g. "Client Partnerships") wraps the tag row to a second line. */
    .team-card { display: flex; flex-direction: column; }
    .team-info { display: flex; flex-direction: column; flex: 1 1 auto; }
    .team-info .team-cta { margin-top: auto; align-self: flex-start; }

    /* ── SECTION 4: HOW WE WORK TIMELINE ──────────────── */
    .timeline-sec { background: #F8F9FA; }
    .timeline {
      display: grid; grid-template-columns: repeat(4, 1fr);
      gap: 0; position: relative;
      margin-top: 56px; max-width: 1100px; margin-left: auto; margin-right: auto;
    }
    /* Connecting line */
    .timeline::before {
      content: '';
      position: absolute;
      top: 24px; left: 24px; right: 24px;
      height: 2px;
      background: linear-gradient(90deg, var(--blue), rgba(41,171,226,.3));
      z-index: 0;
    }
    .tl-node {
      display: flex; flex-direction: column; align-items: center;
      position: relative; z-index: 1; padding: 0 16px;
    }
    .tl-dot {
      width: 48px; height: 48px;
      border-radius: 50%;
      background: var(--blue);
      display: flex; align-items: center; justify-content: center;
      margin-bottom: 24px;
      box-shadow: 0 4px 16px rgba(41,171,226,.25);
      flex-shrink: 0;
    }
    .tl-dot svg { width: 22px; height: 22px; stroke: #fff; fill: none; stroke-width: 2; }
    .tl-title {
      font-family: var(--font-h); font-weight: 600;
      font-size: 18px; color: var(--navy);
      text-align: center; margin-bottom: 12px;
      line-height: 1.3;
    }
    .tl-body {
      font-family: var(--font-b); font-size: 15px; font-weight: 400;
      color: #4A5568; line-height: 1.6;
      text-align: center; margin-bottom: 16px;
    }
    .tl-contrast {
      font-family: var(--font-b); font-size: 13px; font-weight: 400;
      font-style: italic; color: #94A3B8;
      text-align: center; line-height: 1.5;
      padding-top: 12px;
      border-top: 1px solid rgba(7,25,46,.06);
    }

    /* ── SECTION 5: STATS STRIP ──────────────────────────── */
    .stats-sec {
      background: var(--navy);
      padding: 80px 32px;
      position: relative; overflow: hidden;
    }
    .stats-sec::before {
      content: '';
      position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 40% 50% at 20% 50%, rgba(41,171,226,.08) 0%, transparent 60%),
        radial-gradient(ellipse 40% 50% at 80% 50%, rgba(41,171,226,.08) 0%, transparent 60%);
      pointer-events: none;
    }
    .stats-grid {
      display: grid; grid-template-columns: repeat(4, 1fr);
      gap: 0; max-width: 1100px; margin: 0 auto;
      position: relative; z-index: 1;
    }
    .stat-item {
      text-align: center; padding: 0 24px;
      border-right: 1px solid rgba(255,255,255,.08);
    }
    .stat-item:last-child { border-right: none; }
    .stat-number {
      font-family: var(--font-h); font-weight: 800;
      font-size: 56px; color: var(--white);
      margin-bottom: 8px; line-height: 1;
    }
    .stat-number .sfx { font-size: .65em; }
    .stat-divider {
      width: 40px; height: 2px; background: var(--orange);
      margin: 12px auto;
    }
    .stat-label {
      font-family: var(--font-b); font-weight: 500;
      font-size: 15px; color: rgba(255,255,255,.6);
    }

    /* ── SECTION 6: TESTIMONIALS ─────────────────────────── */
    .testi-sec-page { background: #0A1628; }
    .testi-sec-page .sec-headline { color: var(--white); }
    .testi-cards {
      display: grid; grid-template-columns: repeat(2, 1fr);
      gap: 32px; max-width: 1000px; margin: 0 auto;
    }
    .testi-card-page {
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.08);
      border-radius: 16px;
      padding: 40px;
      transition: all .3s ease;
    }
    .testi-card-page:hover {
      border-color: rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
    }
    .testi-mark {
      font-family: var(--font-h); font-weight: 800;
      font-size: 64px; color: var(--orange);
      opacity: .4; line-height: 1; margin-bottom: -8px;
    }
    .testi-quote {
      font-family: var(--font-b); font-size: 17px; font-weight: 400;
      color: rgba(255,255,255,.9); line-height: 1.7;
      margin-bottom: 24px;
    }
    .testi-quote .advisor-name { color: var(--blue); font-weight: 700; }
    .testi-attribution {
      display: flex; flex-direction: column; gap: 2px;
    }
    .testi-client-name {
      font-family: var(--font-b); font-size: 14px; font-weight: 600;
      color: var(--white);
    }
    .testi-client-title {
      font-family: var(--font-b); font-size: 14px; font-weight: 400;
      color: rgba(255,255,255,.76);
    }
    .testi-advisor-line {
      font-family: var(--font-b); font-size: 13px; font-weight: 500;
      color: var(--blue); margin-top: 8px;
    }

    /* ── SECTION 7: FINAL CTA ────────────────────────────── */
    .final-cta {
      display: grid; grid-template-columns: 1fr 1fr;
      min-height: 400px;
    }
    .final-cta-left {
      background: var(--navy);
      padding: 100px 48px;
      display: flex; align-items: center; justify-content: flex-end;
    }
    .final-cta-left-inner { max-width: 520px; }
    .final-cta-left h2 {
      font-family: var(--font-h); font-weight: 700;
      font-size: 40px; color: var(--white);
      line-height: 1.15; margin-bottom: 20px;
    }
    .final-cta-left p {
      font-family: var(--font-b); font-size: 17px; font-weight: 400;
      color: rgba(255,255,255,.75); line-height: 1.7;
      margin-bottom: 20px; max-width: 480px;
    }
    .final-cta-trust {
      font-family: var(--font-b); font-size: 14px; font-weight: 400;
      color: rgba(255,255,255,.76);
    }
    .final-cta-right {
      background: linear-gradient(135deg, #F97316 0%, #EA6C10 100%);
      padding: 100px 48px;
      display: flex; flex-direction: column;
      align-items: center; justify-content: center;
      text-align: center;
    }
    .btn-cta-white, .btn-ghost {
      font-family: var(--font-b); font-size: 18px; font-weight: 700;
      color: var(--orange); background: var(--white);
      padding: 20px 48px; border-radius: 14px;
      text-decoration: none; transition: all .2s var(--ease);
      display: inline-flex; align-items: center; gap: 8px;
      box-shadow: 0 4px 16px rgba(0,0,0,.1);
    }
    .btn-cta-white:hover, .btn-ghost:hover {
      transform: translateY(-2px);
      box-shadow: 0 12px 40px rgba(0,0,0,.2);
    }
    .final-cta-phone {
      font-family: var(--font-b); font-size: 16px; font-weight: 500;
      color: var(--white); margin-top: 16px;
    }
    .final-cta-phone a { color: var(--white); text-decoration: underline; text-underline-offset: 3px; }
    .final-cta-email {
      font-family: var(--font-b); font-size: 14px; font-weight: 400;
      color: rgba(255,255,255,.8); margin-top: 8px;
    }
    .final-cta-email a { color: rgba(255,255,255,.8); }

    /* ── FOOTER ──────────────────────────────────────────── */
    footer { background: #040E1A; padding: 64px 32px 32px; color: rgba(255,255,255,.72); }
    .ft { max-width: 1200px; margin: 0 auto; }
    .ft-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
    .ft-logo img { height: 36px; width: auto; display: block; margin-bottom: 14px; }
    .ft-tagline { font-family: var(--font-b); font-size: 13.5px; color: rgba(255,255,255,.30); line-height: 1.65; margin-bottom: 20px; }
    .ft-phone {
      display: inline-flex; align-items: center; gap: 7px;
      font-family: var(--font-b); font-size: 14.5px; font-weight: 700;
      color: var(--blue); text-decoration: none; transition: color .15s;
    }
    .ft-phone:hover { color: #7DD4F5; }
    .ft-col h3 {
      font-family: var(--font-b); font-size: 11px; font-weight: 700;
      letter-spacing: 1.4px; text-transform: uppercase;
      color: rgba(255,255,255,.70); margin-bottom: 16px;
    }
    .ft-col a {
      display: block; font-family: var(--font-b); font-size: 14px;
      color: rgba(255,255,255,.88); text-decoration: none;
      margin-bottom: 10px; transition: color .15s;
    }
    .ft-col a:hover { color: #fff; }
    .ft-bottom {
      border-top: 1px solid rgba(255,255,255,.06);
      padding-top: 28px; display: flex;
      justify-content: space-between; align-items: center;
      flex-wrap: wrap; gap: 12px;
      font-family: var(--font-b); font-size: 12.5px;
    }
    .ft-legal { display: flex; gap: 20px; }
    .ft-legal a { color: rgba(255,255,255,.26); text-decoration: none; transition: color .15s; }
    .ft-legal a:hover { color: #fff; }

    /* ── SCROLL REVEAL ───────────────────────────────────── */
    .reveal {
      opacity: 0; transform: translateY(28px);
      transition: opacity .65s var(--ease), transform .65s var(--ease);
    }
    .reveal.revealed { opacity: 1; transform: translateY(0); }
    /* Hero content always visible */
    .page-hero .reveal { opacity: 1; transform: translateY(0); }
    .reveal-d1 { transition-delay: .08s; }
    .reveal-d2 { transition-delay: .18s; }
    .reveal-d3 { transition-delay: .28s; }
    .reveal-d4 { transition-delay: .38s; }
    .reveal-d5 { transition-delay: .48s; }

    /* ── RESPONSIVE ──────────────────────────────────────── */
    @media (max-width: 1100px) {
      /* S3 audit fix (2026-05-13): single-col grid needs minmax(0, 1fr)
         so children with implicit min-width:auto can't push the column
         past the viewport (29px overflow at 375). */
      .hero-content { grid-template-columns: minmax(0, 1fr); }
      .hero-text { min-width: 0; text-align: center; }
      .hero-visual { display: none; }
      .hero-ctas { justify-content: center; }
      .hero-sub { margin-left: auto; margin-right: auto; }
      .promises-grid { grid-template-columns: 1fr 1fr; }
      .timeline { grid-template-columns: 1fr 1fr; gap: 32px; }
      .timeline::before { display: none; }
      .testi-cards { grid-template-columns: 1fr; }
    }

    @media (max-width: 1024px) {
      nav { display: none; }
      .btn-nav-ghost { display: none; }
      .ham { display: flex; }
      .mob-overlay { display: block; }

      .sec { padding: 72px 24px; }
      .sec-headline { font-size: 32px; }
      .sec-subtext { font-size: 16px; }

      .page-hero { padding: 40px 24px 40px; }
      .hero-h1 { font-size: 28px; letter-spacing: -0.01em; }
      .hero-sub { font-size: 16px; }
      .hero-ctas { flex-direction: column; }
      .hero-ctas a { width: 100%; justify-content: center; min-height: 48px; }

      .promises-grid { grid-template-columns: 1fr; gap: 16px; }
      .promise-card { padding: 32px 24px; }

      .team-grid { grid-template-columns: 1fr 1fr; }
      .team-grid .team-card:last-child:nth-child(3n - 2) { grid-column: auto; }
      .team-photo { height: 240px; }
      .team-info { padding: 24px; }

      .timeline { grid-template-columns: 1fr; gap: 24px; }
      .timeline::before { display: none; }
      .tl-node { align-items: flex-start; flex-direction: row; gap: 16px; padding: 0; }
      .tl-dot { flex-shrink: 0; }
      .tl-text { text-align: left; }
      .tl-title { text-align: left; }
      .tl-body { text-align: left; }
      .tl-contrast { text-align: left; }

      .stats-sec { padding: 60px 24px; }
      .stats-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
      .stat-item { border-right: none; padding: 16px 0; }
      .stat-number { font-size: 40px; }
      .stat-label { font-size: 13px; }

      .testi-cards { grid-template-columns: 1fr; }
      .testi-card-page { padding: 32px 24px; }
      .testi-quote { font-size: 16px; }

      .final-cta { grid-template-columns: 1fr; }
      .final-cta-left { padding: 60px 24px; justify-content: center; }
      .final-cta-left h2 { font-size: 32px; }
      .final-cta-right { padding: 60px 24px; }
      .btn-cta-white, .btn-ghost { width: 100%; justify-content: center; min-height: 56px; }

      .ft-top { grid-template-columns: 1fr 1fr 1fr; gap: 32px; }
    }

    @media (max-width: 480px) {
      .ft-top { grid-template-columns: 1fr; }
      .stats-grid { grid-template-columns: 1fr 1fr; }
      .final-cta-left h2 { font-size: 28px; }
      .team-grid { grid-template-columns: 1fr; }
    }

    /* ── PREMIUM ENHANCEMENT: TEAM CARD PHOTO EFFECTS ──────── */
    .team-photo-placeholder {
      position: relative;
    }
    .team-photo::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 50%, rgba(7,25,46,.4) 100%);
      opacity: 0;
      transition: opacity .4s ease;
      pointer-events: none;
      z-index: 1;
    }
    .team-card:hover .team-photo::after {
      opacity: 1;
    }
    .team-card:hover {
      transform: translateY(-8px);
    }
    .team-card:hover .team-photo-placeholder {
      filter: grayscale(0%) brightness(1) saturate(1.1);
      transform: scale(1.05);
    }
    /* Initials avatars stay un-filtered on hover too (2026-05-24). */
    .team-card:hover .team-photo-placeholder.team-avatar-initials {
      filter: none;
      transform: scale(1.05);
    }

    /* Specialty tag pill colored backgrounds */
    .team-tag {
      background: rgba(41,171,226,.12);
      color: #7DD4F5;
      border: 1px solid rgba(41,171,226,.2);
      transition: all .25s ease;
    }
    .team-tag-years {
      background: rgba(249,115,22,.12);
      color: #FDBA74;
      border: 1px solid rgba(249,115,22,.2);
    }
    .team-card:hover .team-tag {
      background: rgba(41,171,226,.2);
      border-color: rgba(41,171,226,.35);
    }
    .team-card:hover .team-tag-years {
      background: rgba(249,115,22,.2);
      border-color: rgba(249,115,22,.35);
    }

    /* ── PREMIUM ENHANCEMENT: TIMELINE DRAW LINE ──────────── */
    .timeline::before {
      background: linear-gradient(90deg, var(--blue), rgba(41,171,226,.3));
      transform-origin: left;
      transform: scaleX(0);
      transition: transform 1.5s cubic-bezier(.22,1,.36,1);
    }
    .timeline.line-drawn::before {
      transform: scaleX(1);
    }

    .tl-dot {
      transition: transform .35s var(--spring), box-shadow .35s ease;
    }
    .tl-node:hover .tl-dot {
      transform: scale(1.1);
      box-shadow: 0 6px 24px rgba(41,171,226,.35);
    }

    /* ── PREMIUM ENHANCEMENT: STAT GRADIENT TEXT + GLOW ──── */
    .stat-number {
      background: linear-gradient(135deg, #29ABE2 0%, #7DD4F5 50%, #29ABE2 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      position: relative;
    }
    .stat-number::before {
      content: '';
      position: absolute;
      inset: -8px -16px;
      background: radial-gradient(ellipse at center, rgba(41,171,226,.15) 0%, transparent 70%);
      border-radius: 50%;
      z-index: -1;
      pointer-events: none;
      animation: statGlow 3s ease-in-out infinite alternate;
    }
    @keyframes statGlow {
      0% { opacity: .5; transform: scale(.95); }
      100% { opacity: 1; transform: scale(1.05); }
    }
    .stat-number .sfx {
      -webkit-text-fill-color: transparent;
    }

    /* ── PREMIUM ENHANCEMENT: TESTIMONIAL GLASSMORPHISM ──── */
    .testi-card-page {
      background: rgba(255,255,255,.04);
      backdrop-filter: blur(12px) saturate(1.2);
      -webkit-backdrop-filter: blur(12px) saturate(1.2);
      border: 1px solid rgba(255,255,255,.08);
      position: relative;
      overflow: hidden;
    }
    .testi-card-page::before {
      content: '';
      position: absolute; top: 0; left: 0; right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
      pointer-events: none;
    }
    .testi-card-page:hover {
      background: rgba(255,255,255,.07);
      border-color: rgba(255,255,255,.16);
      box-shadow: 0 8px 32px rgba(0,0,0,.15);
    }

    /* Animated quote marks */
    .testi-mark {
      transition: transform .5s var(--spring), opacity .5s ease;
      transform: scale(0.7);
      opacity: .2;
    }
    .testi-card-page.revealed .testi-mark,
    .revealed .testi-card-page .testi-mark {
      transform: scale(1);
      opacity: .4;
    }
    /* Ensure marks animate when parent is revealed */
    .reveal.revealed .testi-mark {
      transform: scale(1);
      opacity: .4;
    }

    /* Advisor name highlight */
    .testi-quote .advisor-name {
      color: var(--blue);
      font-weight: 700;
      text-shadow: 0 0 20px rgba(41,171,226,.3);
    }
    .testi-headshot-page {
      width: 48px; height: 48px; border-radius: 50%;
      object-fit: cover; flex-shrink: 0;
      border: 2px solid rgba(255,255,255,.15);
    }
    .testi-metric-badge {
      display: inline-block;
      background: rgba(41,171,226,.12);
      border: 1px solid rgba(41,171,226,.22);
      border-radius: 10px; padding: 6px 14px;
      font-family: var(--font-h); font-size: 12px; font-weight: 700;
      color: var(--blue); margin-bottom: 12px;
    }
    .testi-attribution {
      display: flex; align-items: center; gap: 12px;
    }

    /* ── PREMIUM ENHANCEMENT: HERO FLOAT ANIMATION ────────── */
    @keyframes float {
      0%, 100% { transform: translateY(0); }
      50% { transform: translateY(-8px); }
    }
    .hero-icon-float {
      animation: float 3s ease-in-out infinite;
    }
    .hero-icon-float:nth-child(4) { animation-delay: 0s; }
    .hero-icon-float:nth-child(5) { animation-delay: -1s; }
    .hero-icon-float:nth-child(6) { animation-delay: -2s; }

    /* ── PREMIUM ENHANCEMENT: CTA ANIMATED GRADIENT BORDER ─ */
    @keyframes borderGradient {
      0% { background-position: 0% 50%; }
      50% { background-position: 100% 50%; }
      100% { background-position: 0% 50%; }
    }

    .btn-cta-white, .btn-ghost {
      position: relative;
      z-index: 1;
    }
    .btn-cta-white::before, .btn-ghost::before {
      content: '';
      position: absolute;
      inset: -3px;
      border-radius: 17px;
      background: linear-gradient(135deg, var(--blue), var(--orange), var(--blue), var(--orange));
      background-size: 300% 300%;
      animation: borderGradient 4s ease infinite;
      z-index: -1;
      opacity: 0;
      transition: opacity .35s ease;
    }
    .btn-cta-white:hover::before, .btn-ghost:hover::before {
      opacity: 1;
    }

    /* .btn-blue / .btn-secondary hover treatment now in buttons-v2.css
       (sitewide VSHR gradient reveal + shimmer sweep). Removed legacy
       infinite border-gradient animation that violated the
       no-continuous-animation rule (memory 2026-04-21). --- */

    .btn-orange {
      position: relative;
      z-index: 1;
    }
    .btn-orange::before {
      content: '';
      position: absolute;
      inset: -2px;
      border-radius: 14px;
      background: linear-gradient(135deg, #F97316, #29ABE2, #F97316, #29ABE2);
      background-size: 300% 300%;
      animation: borderGradient 4s ease infinite;
      z-index: -1;
      opacity: 0;
      transition: opacity .35s ease;
    }
    .btn-orange:hover::before {
      opacity: 1;
    }

    /* CTA section CSS-only decorative dots */
    .final-cta-right {
      position: relative;
      overflow: hidden;
    }
    .final-cta-right::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image:
        radial-gradient(circle 2px, rgba(255,255,255,.15) 50%, transparent 50%),
        radial-gradient(circle 1.5px, rgba(255,255,255,.1) 50%, transparent 50%);
      background-size: 40px 40px, 60px 60px;
      background-position: 0 0, 20px 30px;
      pointer-events: none;
      animation: dotsDrift 20s linear infinite;
    }
    @keyframes dotsDrift {
      0% { background-position: 0 0, 20px 30px; }
      100% { background-position: 40px 80px, 60px 110px; }
    }

    .final-cta-left {
      position: relative;
      overflow: hidden;
    }
    .final-cta-left::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image:
        radial-gradient(circle 1.5px, rgba(41,171,226,.08) 50%, transparent 50%);
      background-size: 48px 48px;
      pointer-events: none;
    }

    /* ── WP COLOR OVERRIDES ──────────────────────────────── */
    a.btn-blue,
a.btn-secondary,
a.btn-orange,
a.btn-cta-white,
a.btn-ghost,
a.btn-nav-primary,
a.mob-cta-primary { color: #fff !important; text-decoration: none !important; }
    a.btn-cta-white, a.btn-ghost { color: var(--orange) !important; }

    /* ── 21ST.DEV TEXT CYCLE ─────────────────────────────── */
    .hero-cycle-wrap {
      display: inline-block;
      position: relative;
      min-width: 140px;
      text-align: left;
      overflow: hidden;
      vertical-align: bottom;
    }
    .hero-cycle-word {
      display: inline-block;
      white-space: nowrap;
      background: linear-gradient(90deg, #F97316 0%, #9333EA 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
    .hero-cycle-word.cycle-exit {
      animation: heroCycleOut .35s cubic-bezier(.4, 0, .2, 1) forwards;
    }
    .hero-cycle-word.cycle-enter {
      animation: heroCycleIn .45s cubic-bezier(.16, 1, .3, 1) forwards;
    }
    @keyframes heroCycleOut {
      0%   { opacity: 1; filter: blur(0px); transform: translateY(0) scale(1); }
      100% { opacity: 0; filter: blur(12px); transform: translateY(18px) scale(0.95); }
    }
    @keyframes heroCycleIn {
      0%   { opacity: 0; filter: blur(12px); transform: translateY(-18px) scale(0.95); }
      100% { opacity: 1; filter: blur(0px); transform: translateY(0) scale(1); }
    }
    @media (prefers-reduced-motion: reduce) {
      .hero-cycle-word.cycle-exit,
      .hero-cycle-word.cycle-enter {
        animation: none !important;
        opacity: 1 !important;
        filter: none !important;
        transform: none !important;
      }
    }

    /* ── Phase 3.3: Mobile shadow reduction ──────────── */
    @media (max-width: 1024px) {
      :root {
        --glass-shadow: 0 2px 8px rgba(7,25,46,.04), 0 4px 16px rgba(7,25,46,.03);
        --shadow-md: 0 2px 12px rgba(7,25,46,.06);
        --shadow-sm: 0 1px 6px rgba(7,25,46,.04);
      }
    }

    /* ── Phase 3.4: CTA button press-state ───────────── */
    .btn-orange:active,
.btn-cta-white:active,
.btn-ghost:active,
.btn-nav-primary:active {
      transform: scale(0.97) translateY(1px);
      transition: transform 0.1s ease;
    }

    /* ── Phase 3.6: Nav link bottom-border slide-in ──── */
    nav a { position: relative; }
    nav a::after {
      content: '';
      position: absolute;
      bottom: -2px; left: 50%;
      width: 0; height: 2px;
      background: var(--blue);
      transition: width 0.25s ease, left 0.25s ease;
    }
    nav a:hover::after {
      width: 100%; left: 0;
    }

    /* ── Phase 3.7: Footer gradient transition ───────── */
    footer { position: relative; }
    footer::before {
      content: '';
      position: absolute;
      top: -120px; left: 0; right: 0;
      height: 120px;
      background: linear-gradient(180deg, transparent 0%, #040E1A 100%);
      pointer-events: none;
    }
  
    /* -- CALLBACK WIDGET -- */
    .callback-widget {
      position: fixed; bottom: 24px; right: 24px; z-index: 500;
    }
    .callback-trigger {
      width: 56px; height: 56px; border-radius: 50%;
      background: var(--orange);
      border: none; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      box-shadow: 0 4px 14px rgba(249,115,22,.3);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }
    .callback-trigger:hover {
      transform: scale(1.08);
      box-shadow: 0 6px 20px rgba(249,115,22,.4);
    }
    .callback-trigger svg { width: 24px; height: 24px; stroke: #fff; fill: none; }
    .callback-panel {
      display: none; position: absolute; bottom: 70px; right: 0;
      width: 320px; background: #fff; border-radius: 16px;
      box-shadow: 0 12px 40px rgba(7,25,46,.15);
      padding: 24px; transform-origin: bottom right;
    }
    .callback-panel.open {
      display: block;
      animation: cbSlideUp 0.3s ease forwards;
    }
    @keyframes cbSlideUp {
      from { opacity: 0; transform: translateY(10px) scale(0.95); }
      to { opacity: 1; transform: translateY(0) scale(1); }
    }
    .callback-panel h3 {
      font-family: var(--font-h); font-size: 18px; font-weight: 700;
      color: var(--navy); margin-bottom: 4px;
    }
    .callback-panel p {
      font-size: 14px; color: var(--muted); margin-bottom: 16px;
    }
    .callback-panel input {
      width: 100%; padding: 12px 16px; border: 1.5px solid var(--border);
      border-radius: 10px; font-size: 15px; margin-bottom: 12px;
      font-family: var(--font-b);
    }
    .callback-panel input:focus {
      border-color: var(--blue);
      box-shadow: 0 0 0 3px rgba(41,171,226,.15);
      outline: none;
    }
    .callback-submit {
      width: 100%; padding: 12px; border: none; border-radius: 10px;
      background: var(--orange); color: #fff; font-weight: 600;
      font-size: 15px; cursor: pointer;
      box-shadow: 0 4px 14px rgba(249,115,22,.18);
    }
    .callback-success { text-align: center; padding: 20px 0; }
    .callback-success svg { width: 48px; height: 48px; stroke: #10B981; margin-bottom: 12px; }
    /* ── MOBILE STICKY CTA BAR ─────────────────────────── */
    .mob-sticky-cta {
      display: none;
      position: fixed; bottom: 0; left: 0; right: 0;
      z-index: 400;
      background: rgba(255,255,255,.95);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      border-top: 1px solid var(--border);
      padding: 12px 16px;
      box-shadow: 0 -4px 20px rgba(7,25,46,.08);
    }
    @media (max-width: 1024px) {
      .mob-sticky-cta { display: flex; gap: 10px; align-items: center; }
      body { padding-bottom: 72px; }
    }
    .mob-sticky-cta .mob-cta-btn {
      flex: 1; padding: 14px 20px; border-radius: 12px;
      font-family: var(--font-h); font-size: 15px; font-weight: 700;
      text-align: center; text-decoration: none;
      transition: transform 0.15s ease;
    }
    .mob-sticky-cta .mob-cta-btn:active { transform: scale(0.97); }
    .mob-sticky-cta .mob-cta-primary {
      background: var(--orange); color: #fff;
      box-shadow: 0 4px 14px rgba(249,115,22,.18);
    }
    .mob-sticky-cta .mob-cta-secondary {
      background: transparent; color: var(--navy);
      border: 1.5px solid var(--border);
    }

    /* ── HERO LINE-GRID OVERLAY ────────────────────────── */
    .hero-line-grid {
      position: absolute; inset: 0;
      background-image:
        linear-gradient(rgba(41,171,226,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(41,171,226,.05) 1px, transparent 1px);
      background-size: 60px 60px;
      -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 40%, transparent 100%);
      mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 40%, transparent 100%);
      z-index: 1;
      pointer-events: none;
    }

    /* ── YOUR TEAM INTRO SECTION ──────────────────── */
    .specialist-led-intro {
      background: linear-gradient(160deg, #F0F7FD 0%, #FEFBF7 60%, #F4F8FC 100%);
      padding: 72px 32px;
      position: relative;
      overflow: hidden;
    }
    .specialist-led-intro::before {
      content: '';
      position: absolute; inset: 0;
      background:
        radial-gradient(ellipse 50% 60% at 10% 50%, rgba(41,171,226,.06) 0%, transparent 65%),
        radial-gradient(ellipse 40% 50% at 90% 50%, rgba(249,115,22,.04) 0%, transparent 60%);
      pointer-events: none;
    }
    .specialist-led-inner {
      max-width: 960px;
      margin: 0 auto;
      text-align: center;
      position: relative;
      z-index: 1;
    }
    .specialist-led-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(41,171,226,.08);
      border: 1px solid rgba(41,171,226,.18);
      border-radius: 100px;
      padding: 6px 16px;
      font-family: var(--font-b);
      font-size: 12px;
      font-weight: 700;
      color: var(--blue-dark);
      text-transform: uppercase;
      letter-spacing: 0.8px;
      margin-bottom: 20px;
    }
    .specialist-led-heading {
      font-family: var(--font-h);
      font-size: 36px;
      font-weight: 700;
      color: var(--navy);
      line-height: 1.2;
      letter-spacing: -0.8px;
      margin-bottom: 16px;
    }
    .specialist-led-heading .highlight {
      background: linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }
    .specialist-led-sub {
      font-family: var(--font-b);
      font-size: 18px;
      color: var(--muted);
      line-height: 1.65;
      max-width: 620px;
      margin: 0 auto 40px;
    }
    .specialist-led-pillars {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
      text-align: left;
    }
    .named-pillar {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: 16px;
      padding: 28px 24px;
      box-shadow: 0 2px 12px rgba(7,25,46,.04), 0 1px 4px rgba(7,25,46,.03);
      transition: transform .4s cubic-bezier(0.34,1.56,0.64,1), box-shadow .35s ease;
    }
    .named-pillar:hover {
      transform: translateY(-6px);
      box-shadow: 0 16px 40px rgba(7,25,46,.08), 0 0 0 1.5px rgba(41,171,226,.15);
    }
    .named-pillar-icon {
      width: 48px;
      height: 48px;
      border-radius: 12px;
      background: linear-gradient(135deg, rgba(41,171,226,.12) 0%, rgba(41,171,226,.06) 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 16px;
    }
    .named-pillar-icon svg { width: 22px; height: 22px; stroke: var(--blue); fill: none; stroke-width: 2; }
    .named-pillar-title {
      font-family: var(--font-h);
      font-size: 16px;
      font-weight: 700;
      color: var(--navy);
      margin-bottom: 8px;
    }
    .named-pillar-desc {
      font-family: var(--font-b);
      font-size: 14px;
      color: var(--muted);
      line-height: 1.6;
    }
    @media (max-width: 1024px) {
      .specialist-led-pillars { grid-template-columns: 1fr; }
      .specialist-led-heading { font-size: 28px; }
      .specialist-led-intro { padding: 56px 20px; }
    }
  /*callback-widget-mobile-hide-v1*/
@media (max-width: 767px) {
  .callback-widget { display: none !important; }
  .mob-sticky-cta { display: flex !important; }
}
/* reduced-motion-v1 */
@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}}
/* mobile-qa-v1 */
@media (max-width: 767px) {
  .btn, button, .btn-primary, .btn-secondary, .btn-outline, .cta, [class*="btn-"], a.button, input[type="submit"], input[type="button"] {
    min-height: 44px !important;
    min-width: 44px !important;
    padding: 12px 18px !important;
  }
  p, li, span, a, td, th, label, input, select, textarea, button, .small, .tag, .badge, .meta, .label, .desc, [class*="-desc"], [class*="-meta"], [class*="-label"], [class*="-tag"], [class*="-badge"], [class*="-time"], [class*="-name"], [class*="-val"], [class*="-num"], [class*="-txt"], [class*="-trend"], [class*="-sub"], [class*="-item"], [class*="-sep"] {
    font-size: max(14px, 1em) !important;
  }
  body, main, section, div, table, .container, .wrap, [class*="-wrap"], [class*="-grid"] {
    max-width: 100% !important;
  }
  img, video, iframe, svg { max-width: 100% !important; height: auto; }
  table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .mob-drawer, [class*="drawer"], .nav-drawer { width: 88vw !important; max-width: 320px !important; }
  html { overflow-x: hidden !important; }
}
@media (max-width: 359px) {
  .mob-drawer, [class*="drawer"], .nav-drawer { width: 96vw !important; max-width: 100vw !important; }
}
/* scroll-margin-anchor-v2 */
[id], section[id], h1[id], h2[id], h3[id], h4[id] { scroll-margin-top: 130px; }

    /* GOLDEN-CARD-ABOUT-PATCH v1 */
    /* Shell-only golden-card overrides for the about section.
       Covers: background, border, radius, shadow, left accent rule,
       ghost watermark, hover state. Does NOT touch typography,
       icons, badges, or internal layouts — those are per-page. */
    
    /* .promise-card — golden-card shell */
    .promise-card {
      position: relative !important;
      background: #FFFFFF !important;
      border: 1px solid rgba(13,24,41,.09) !important;
      border-radius: 10px !important;
      padding: 36px 32px 32px 42px !important;
      box-shadow:
        0 1px 2px rgba(13,24,41,.04),
        0 8px 24px -12px rgba(13,24,41,.18),
        0 16px 40px -20px rgba(13,24,41,.12) !important;
      transition:
        border-color 180ms ease-out,
        box-shadow 180ms ease-out,
        transform 180ms ease-out !important;
      overflow: hidden !important;
      isolation: isolate !important;
      --card-color:#1366A0;
      --card-rgb: 23,121,184;
    }
    .promise-card:nth-child(3n+1){--card-color:#1366A0;--card-rgb:23,121,184}
    .promise-card:nth-child(3n+2){--card-color:#F97316;--card-rgb:249,115,22}
    .promise-card:nth-child(3n+3){--card-color:#10B981;--card-rgb:16,185,129}
    .promise-card::before {
      content: '';
      position: absolute;
      left: 0;
      top: 22px;
      bottom: 22px;
      width: 3px;
      background: linear-gradient(180deg,
        transparent 0%,
        var(--card-color) 15%,
        var(--card-color) 85%,
        transparent 100%);
      border-radius: 0 3px 3px 0;
      transition: width 180ms ease-out, top 180ms ease-out, bottom 180ms ease-out;
      z-index: 2;
      pointer-events: none;
    }
    .promise-card::after {
      content: '';
      position: absolute;
      top: -80px;
      left: -80px;
      width: 240px;
      height: 240px;
      background: radial-gradient(circle,
        rgba(var(--card-rgb), .12) 0%,
        transparent 65%);
      pointer-events: none;
      z-index: 0;
      opacity: .55;
      transition: opacity 180ms ease-out;
    }
    .promise-card:hover {
      transform: translateY(-2px) !important;
      border-color: rgba(var(--card-rgb), .42) !important;
      box-shadow:
        0 1px 2px rgba(13,24,41,.05),
        0 14px 32px -14px rgba(var(--card-rgb), .22),
        0 18px 36px -18px rgba(13,24,41,.18) !important;
    }
    .promise-card:hover::before {
      width: 4px;
      top: 14px;
      bottom: 14px;
    }
    .promise-card:hover::after {
      opacity: 1;
    }
    .promise-card > * {
      position: relative;
      z-index: 1;
    }
    
    @media (prefers-reduced-motion: reduce) {
      .promise-card {
        transition: none !important;
        animation: none !important;
      }
      .promise-card::before {
        transition: none !important;
      }
      .promise-card::after {
        transition: none !important;
      }
    }
    /* END GOLDEN-CARD-ABOUT-PATCH v1 */

    /* Row alignment: reserve 2 title lines so bodies share a baseline across
       the 3-up row, and pin the proof footnote to the card bottom so the
       orange proof lines align regardless of body length. */
    .promise-card { display: flex; flex-direction: column; }
    .promise-title { min-height: calc(1.25em * 2); }
    .promise-proof { margin-top: auto; }

/* §2 */
@media (max-width: 1024px) {
  .cb-fab, .callback-trigger { bottom: calc(90px + env(safe-area-inset-bottom, 0px)) !important; }
  .cb-panel, .callback-panel { bottom: calc(160px + env(safe-area-inset-bottom, 0px)) !important; width: min(320px, 90vw) !important; }
  body { padding-bottom: calc(70px + env(safe-area-inset-bottom, 0px)); }
  .mob-sticky-cta { padding-bottom: env(safe-area-inset-bottom, 0px); }
}

/* §3 mobile-text-fixes-v1 — meet-your-team
   Raises testimonial attribution text to readable 16px floor.
   testimonial-simple__name (15px) and __title (14px) are set in
   svc-components.css (shared, do not edit); these overrides are
   scoped to 767.98px so desktop is untouched. */
@media (max-width: 767.98px) {
  .testimonial-simple__name {
    font-size: 16px !important;
  }
  .testimonial-simple__title {
    font-size: 16px !important;
  }
}
