/* ══════════════════════════════════════════════════════════
   CAPTIV — GLOBAL STYLESHEET
   Structure:
     1. Reset & Root Variables
     2. Base / Typography
     3. Navigation
     4. Footer
     5. Marquee Bar
     6. Shared Section Utilities
     7. Buttons
     8. Image Utilities
     9. Client / Partner Grid
    10. CTA Band
    11. Stats Bar
    12. Responsive
   ══════════════════════════════════════════════════════════ */

/* ── 1. RESET & ROOT ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --teal:        #0B6B54;
  --teal-dark:   #084D3B;
  --teal-mid:    #1A9E75;
  --teal-light:  #E6F4EF;
  --teal-xlight: #F2FAF7;
  --navy:        #0C1B2E;
  --navy-mid:    #162840;
  --white:       #FFFFFF;
  --off-white:   #F9F8F5;
  --cream:       #F3F1EC;
  --border:      #E4E0D8;
  --border-light:#EDE9E2;
  --text-primary:   #0C1B2E;
  --text-secondary: #4B5563;
  --text-muted:     #8B97A4;
  --font-display: 'Cormorant Garamond', serif;
  --font-body:    'Figtree', sans-serif;
}

html { scroll-behavior: smooth; }

body {
  padding-top: 62px;
  background: var(--white);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
}

/* ── 2. BASE / TYPOGRAPHY ── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  color: var(--navy);
}

a { color: inherit; text-decoration: none; }

/* ── 3. NAVIGATION ── */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.85rem 4rem;
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(11, 107, 84, 0.1);
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.05);
}

.nav-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}

.nav-logo img { display: block; }

.nav-links {
  display: flex;
  gap: 1.75rem;
  list-style: none;
  align-items: center;
  margin: 0;
  padding: 0;
}

.nav-links a {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 0.81rem;
  font-weight: 400;
  transition: color 0.2s;
  white-space: nowrap;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--teal);
  font-weight: 600;
}

.nav-dropdown { position: relative; }

/*
 * Invisible pseudo-element that extends the hover zone of each dropdown
 * trigger downward, bridging the gap between the nav link and the visible
 * menu. Without this, moving the cursor even 1px below the trigger exits
 * the hover state before reaching .nav-sub.
 */
.nav-dropdown::after {
  content: '';
  position: absolute;
  top: 100%;
  left: -1rem;
  right: -1rem;
  height: 1rem;          /* matches the gap below the nav bar */
  background: transparent;
}

.nav-sub {
  /* Use visibility+opacity instead of display:none so the element stays
     in the hover zone even while invisible. display:none removes it from
     the layout entirely, making the bridge useless. */
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: calc(100% + 0.6rem);
  left: 0;
  background: var(--white);
  border: 1px solid var(--border-light);
  border-top: 2px solid var(--teal);
  min-width: 220px;
  list-style: none;
  z-index: 500;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
  transition: opacity 0.15s ease, visibility 0.15s ease;
}

.nav-sub li a {
  display: block;
  padding: 0.68rem 1.35rem;
  font-size: 0.78rem;
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-light);
  transition: all 0.15s;
  background: var(--white);
}

.nav-sub li:last-child a { border-bottom: none; }

.nav-sub li a:hover {
  background: var(--teal-xlight);
  color: var(--teal);
  padding-left: 1.65rem;
}

.nav-dropdown:hover .nav-sub {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.nav-cta {
  background: var(--teal);
  color: var(--white) !important;
  padding: 0.55rem 1.35rem;
  font-size: 0.77rem;
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.07em;
  transition: all 0.2s;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}

.nav-cta:hover {
  background: var(--teal-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(11, 107, 84, 0.28);
}

.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
  background: none;
  border: none;
}

.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--navy);
  transition: all 0.25s;
}

.hamburger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── 4. FOOTER ── */
footer {
  background: var(--navy);
  padding: 5rem 4rem 2rem;
  border-top: 3px solid var(--teal);
}

.footer-top {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.6fr 1.2fr 1fr 1fr 1fr;
  gap: 4rem;
  padding-bottom: 3.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.footer-brand { display: flex; flex-direction: column; }
.footer-brand img { display: block; margin-bottom: 1.25rem; }

.footer-desc {
  font-size: 0.77rem;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.3);
  line-height: 1.9;
  max-width: 252px;
  margin-bottom: 1.25rem;
}

.footer-tag {
  font-size: 0.59rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--teal-mid);
}

.footer-col h4 {
  font-family: var(--font-body);
  font-size: 0.57rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.2);
  margin-bottom: 1.35rem;
}

.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: 0.65rem; }

.footer-col a {
  font-size: 0.79rem;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.4);
  text-decoration: none;
  transition: color 0.2s;
}

.footer-col a:hover { color: var(--white); }
.footer-col--contact h4 {
  font-family: var(--font-body);
  font-size: 0.57rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--teal-mid);
  margin-bottom: 1rem;
}
.footer-contact-addr {
  font-size: 0.76rem;
  font-weight: 300;
  color: rgba(255,255,255,0.35);
  line-height: 1.85;
  margin-bottom: 0.65rem;
}
.footer-contact-line {
  font-size: 0.76rem;
  font-weight: 300;
  color: rgba(255,255,255,0.35);
  margin-bottom: 0.25rem;
}
.footer-contact-line a {
  color: rgba(255,255,255,0.35);
  text-decoration: none;
  transition: color 0.2s;
}
.footer-contact-line a:hover { color: var(--white); }


.footer-bottom {
  max-width: 1280px;
  margin: 0 auto;
  padding-top: 1.75rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}

.footer-bottom p {
  font-size: 0.65rem;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.14);
}

/* ── 5. MARQUEE BAR ── */
.marquee-bar {
  background: var(--teal);
  padding: 0.85rem 0;
  overflow: hidden;
}

.marquee-inner {
  display: flex;
  animation: scroll 32s linear infinite;
  white-space: nowrap;
}

.marquee-inner:hover { animation-play-state: paused; }

.m-item {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
  padding: 0 2.5rem;
  border-right: 1px solid rgba(255, 255, 255, 0.15);
  flex-shrink: 0;
  transition: color 0.2s;
}

.m-item:hover { color: var(--white); }

@keyframes scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── 6. SHARED SECTION UTILITIES ── */
.sec { padding: 7rem 4rem; }

.sec-inner {
  max-width: 1280px;
  margin: 0 auto;
}

.sec-kicker {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--teal);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.1rem;
}

.sec-kicker::before {
  content: '';
  width: 1.75rem;
  height: 2px;
  background: var(--teal);
}

.sec-heading {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 3.8vw, 4rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--navy);
}

.sec-heading em {
  font-style: italic;
  font-weight: 400;
  color: var(--teal);
}

/* ── 7. BUTTONS ── */
.btn-solid {
  background: var(--teal);
  color: var(--white);
  padding: 0.9rem 2rem;
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  letter-spacing: 0.03em;
  transition: all 0.2s;
  display: inline-block;
}

.btn-solid:hover {
  background: var(--teal-dark);
  transform: translateY(-1px);
}

.btn-border {
  border: 1.5px solid var(--navy);
  color: var(--navy);
  padding: 0.9rem 2rem;
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  letter-spacing: 0.03em;
  transition: all 0.2s;
  display: inline-block;
}

.btn-border:hover {
  background: var(--navy);
  color: var(--white);
}

.btn-white {
  background: var(--white);
  color: var(--teal);
  padding: 1.1rem 2.75rem;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.05em;
  transition: all 0.2s;
  display: inline-block;
  text-transform: uppercase;
}

.btn-white:hover {
  background: var(--off-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.btn-ghost {
  border: 1.5px solid rgba(255,255,255,0.35);
  color: rgba(255,255,255,0.8);
  padding: 1.1rem 2.75rem;
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  letter-spacing: 0.05em;
  transition: all 0.2s;
  display: inline-block;
  text-transform: uppercase;
}

.btn-ghost:hover {
  border-color: var(--white);
  color: var(--white);
}

/* ── 8. IMAGE UTILITIES ── */
.img-full    { width: 100%; height: 480px; object-fit: cover; display: block; }
.img-half    { width: 100%; height: 100%; min-height: 380px; object-fit: cover; display: block; }
.img-card    { width: 100%; height: 220px; object-fit: cover; display: block; }
.img-section { position: relative; overflow: hidden; }

.img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(12,27,46,0.92) 0%, rgba(12,27,46,0.5) 60%, rgba(12,27,46,0.1) 100%);
}

.img-overlay-dark {
  position: absolute; inset: 0;
  background: rgba(12, 27, 46, 0.75);
}

.img-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 420px;
}

.img-split-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 5rem 4rem;
}

.img-feature-wrap { position: relative; overflow: hidden; }

.img-feature-wrap img {
  width: 100%; height: 400px;
  object-fit: cover; display: block;
  transition: transform 0.6s ease;
}

.img-feature-wrap:hover img { transform: scale(1.04); }

.section-image-banner {
  width: 100%; height: 360px;
  object-fit: cover; display: block;
  filter: brightness(0.85);
}

.img-mosaic {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 3px;
  height: 420px;
}

.img-mosaic img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 0.5s;
}

.img-mosaic img:hover { transform: scale(1.03); }
.img-mosaic .img-tall { grid-row: span 2; }

/* ── 9. CLIENT LOGOS ── */
.client-logos-row {
  display: flex;
  align-items: center;
  gap: 3rem;
  flex-wrap: wrap;
  padding: 2.5rem 0;
  border-top: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
  margin: 3rem 0;
  overflow: hidden;
}

.client-logo-pill {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0.5rem 1.25rem;
  border: 1px solid var(--border);
  white-space: nowrap;
  transition: all 0.2s;
}

.client-logo-pill:hover {
  border-color: var(--teal);
  color: var(--teal);
}

/* ── 10. CTA BAND ── */
.cta-band {
  background: var(--teal);
  padding: 8rem 4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cta-band-bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 32px 32px;
  z-index: 0;
}

.cta-inner {
  max-width: 700px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.cta-kicker {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 1.75rem;
  display: block;
}

.cta-heading {
  font-family: var(--font-display);
  font-size: clamp(3rem, 5.5vw, 4.5rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1.05;
  margin-bottom: 1rem;
  letter-spacing: -0.015em;
}

.cta-heading em { font-style: italic; font-weight: 400; }

.cta-sub {
  font-size: 0.92rem;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.8;
  margin-bottom: 2.75rem;
}

.cta-btn-row {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── 11. STATS BAR ── */
.stats-bar { background: var(--navy); }

.stats-row {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}

.stat-cell {
  padding: 2.25rem 2rem;
  border-right: 1px solid rgba(255,255,255,0.06);
  transition: background 0.2s;
  position: relative;
}

.stat-cell::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: transparent;
  transition: background 0.25s;
}

.stat-cell:hover { background: rgba(255,255,255,0.03); }
.stat-cell:hover::after { background: var(--teal-mid); }
.stat-cell:last-child { border-right: none; }

.stat-n {
  font-family: var(--font-display);
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--white);
  line-height: 1;
  display: block;
  margin-bottom: 0.4rem;
}

.stat-n sup { font-size: 1rem; color: var(--teal-mid); font-family: var(--font-body); }

.stat-n.sm {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  padding-top: 0.9rem;
  letter-spacing: 0.04em;
}

.stat-l {
  font-size: 0.65rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.28);
}

.stat-trust { display: flex; flex-direction: column; gap: 0.2rem; padding-top: 0.4rem; }

.trust-b {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--teal-mid);
}

/* ── 12. PAGE HERO (INNER PAGES) ── */
.pg-hero {
  background: var(--navy);
  padding: 8rem 4rem 5.5rem;
  position: relative;
  overflow: hidden;
}

.pg-hero-bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(26,158,117,0.05) 1px, transparent 1px);
  background-size: 30px 30px;
}

.pg-hero-inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.pg-hero-kicker {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--teal-mid);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.pg-hero-kicker::before {
  content: '';
  width: 1.75rem;
  height: 2px;
  background: var(--teal-mid);
}

.pg-hero-headline {
  font-family: var(--font-display);
  font-size: clamp(3rem, 5vw, 5.2rem);
  font-weight: 700;
  line-height: 1.03;
  color: var(--white);
  margin-bottom: 1.5rem;
  letter-spacing: -0.015em;
}

.pg-hero-headline em {
  font-style: italic;
  font-weight: 400;
  color: var(--teal-mid);
}

.pg-hero-sub {
  font-size: 1rem;
  font-weight: 300;
  color: rgba(255,255,255,0.45);
  line-height: 1.85;
  max-width: 600px;
}

/* ── ANIMATIONS ── */
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.4; transform: scale(0.7); }
}

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


/* ── 13. RESPONSIVE ── */
@media (max-width: 1100px) {
  nav { padding: 0.85rem 1.5rem; }

  .nav-links { display: none; }

  .nav-links.open {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 60px; left: 0; right: 0;
    background: var(--white);
    border-bottom: 1px solid var(--border-light);
    z-index: 999;
    padding: 0.5rem 0;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: 0 8px 28px rgba(0,0,0,0.12);
  }

  .nav-links.open > li > a {
    display: block;
    padding: 0.85rem 1.75rem;
    font-size: 0.9rem;
    border-bottom: 1px solid var(--border-light);
  }

  .nav-links.open .nav-sub {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    position: static;
    box-shadow: none;
    border: none;
    background: var(--off-white);
    padding-left: 1rem;
    border-top: none;
    transition: none;
  }
  .nav-dropdown::after { display: none; }

  .nav-links.open .nav-sub li a { font-size: 0.84rem; }

  .hamburger { display: flex; }
  .nav-cta   { display: none; }

  footer { padding: 4rem 1.5rem 2rem; }

  .footer-top {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }

  .sec { padding: 5rem 1.5rem; }

  .pg-hero { padding: 6rem 1.5rem 4rem; }

  .img-split { grid-template-columns: 1fr; }
  .img-split-text { padding: 3rem 1.5rem; }

  .img-mosaic {
    grid-template-columns: 1fr;
    height: 280px;
  }

  .img-mosaic .img-tall { grid-row: span 1; }
  .img-full    { height: 280px; }
  .img-card    { height: 180px; }
  .section-image-banner { height: 220px; }

  .stats-row { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 600px) {
  .footer-top { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════
   ENGINE PAGE SHARED STYLES
   Used across: aion, skyverse, optima360, soniclynk,
                qlens, proaug and any future engine pages
   ══════════════════════════════════════════════════════════ */

/* ── EXTENDED HERO (engine pages) ── */
.pg-hero-img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.12; z-index: 0;
}
.pg-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(105deg, rgba(12,27,46,0.97) 50%, rgba(12,27,46,0.7));
  z-index: 1;
}
.pg-hero-inner {
  max-width: 1280px; margin: 0 auto; width: 100%;
  display: grid; grid-template-columns: 55% 45%;
  gap: 4rem; align-items: center;
  position: relative; z-index: 2;
}
.pg-hero-tag {
  font-size: 0.62rem; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--teal-mid); margin-bottom: 1.5rem;
  display: flex; align-items: center; gap: 0.6rem;
}
.pg-hero-tag::before {
  content: ""; display: block;
  width: 2rem; height: 2px; background: var(--teal-mid);
}
.pg-hero-headline {
  font-family: var(--font-display);
  font-size: clamp(3rem, 5vw, 5.2rem);
  font-weight: 700; line-height: 1.03;
  color: var(--white); margin-bottom: 1.5rem;
  letter-spacing: -0.015em;
}
.pg-hero-headline em { font-style: italic; font-weight: 400; color: var(--teal-mid); }
.pg-hero-rule { width: 3rem; height: 2px; background: var(--teal-mid); margin-bottom: 1.5rem; }
.pg-hero-sub {
  font-size: 1rem; font-weight: 300;
  color: rgba(255,255,255,0.5); line-height: 1.9;
  margin-bottom: 2rem; max-width: 520px;
}
.pg-hero-btns { display: flex; gap: 1.25rem; flex-wrap: wrap; }

/* ── STAT CARD (hero right panel) ── */
.stat-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 2.5rem; position: relative;
}
.stat-card::before {
  content: ""; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: var(--teal-mid);
}
.stat-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px; background: rgba(255,255,255,0.06);
  margin-bottom: 1.5rem;
}
.stat-cell { background: rgba(255,255,255,0.02); padding: 1.5rem 1.25rem; }
.stat-n {
  font-family: var(--font-display); font-size: 2.4rem;
  font-weight: 700; color: var(--teal-mid);
  line-height: 1; margin-bottom: 0.3rem;
}
.stat-l {
  font-size: 0.65rem; font-weight: 400;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.25);
}
.stat-note {
  font-size: 0.75rem; font-weight: 300;
  color: rgba(255,255,255,0.35); line-height: 1.75;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.stat-note strong { color: rgba(255,255,255,0.6); font-weight: 500; }

/* ── PAGE-LEVEL MARQUEE (engine pages use .mq-bar) ── */
.mq-bar { background: var(--teal); overflow: hidden; }
.mq-inner {
  display: flex;
  animation: mqScroll 32s linear infinite;
  white-space: nowrap;
}
.mq-inner:hover { animation-play-state: paused; }
.mq-item {
  font-size: 0.65rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  padding: 0.85rem 2.5rem;
  border-right: 1px solid rgba(255,255,255,0.15);
  flex-shrink: 0;
}
@keyframes mqScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── GENERIC GRID LAYOUTS ── */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--border); }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--border); }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--border); }

/* ── CARD VARIANTS ── */
.card-w { background: var(--white); padding: 2.25rem 2rem; border-top: 2px solid transparent; transition: all 0.25s; }
.card-w:hover { border-top-color: var(--teal); background: var(--teal-xlight); }
.card-n { background: var(--navy); padding: 2.25rem 2rem; border-top: 2px solid transparent; transition: all 0.25s; }
.card-n:hover { border-top-color: var(--teal-mid); background: var(--navy-mid); }
.card-num { font-size: 0.58rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 0.75rem; }
.card-n .card-num { color: rgba(255,255,255,0.2); }
.card-title { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; color: var(--navy); line-height: 1.15; margin-bottom: 0.6rem; }
.card-n .card-title { color: var(--white); }
.card-title em { font-style: italic; font-weight: 400; color: var(--teal); }
.card-n .card-title em { color: var(--teal-mid); }
.card-desc { font-size: 0.82rem; font-weight: 300; color: var(--text-secondary); line-height: 1.8; }
.card-n .card-desc { color: rgba(255,255,255,0.38); }
.card-punch { font-size: 0.78rem; font-style: italic; color: var(--teal-dark); border-left: 2px solid var(--teal-light); padding-left: 0.75rem; margin-top: 1rem; line-height: 1.6; }
.card-n .card-punch { color: var(--teal-mid); border-left-color: rgba(26,158,117,0.25); }

/* ── DARK SECTION ── */
.dark-sec { background: var(--navy); position: relative; overflow: hidden; }
.dark-sec-bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(26,158,117,0.06) 1px, transparent 1px);
  background-size: 32px 32px;
}

/* ── EXTRA BUTTON VARIANTS ── */
.btn-navy {
  border: 1.5px solid var(--navy); color: var(--navy);
  padding: 0.9rem 2rem; font-size: 0.875rem; font-weight: 500;
  text-decoration: none; letter-spacing: 0.03em;
  transition: all 0.2s; display: inline-block;
}
.btn-navy:hover { background: var(--navy); color: var(--white); }

/* ── SOL (SOLUTION) SECTION — engine solution cards ── */
.sol-sec {
  background: var(--navy); color: var(--white);
  position: relative; overflow: hidden;
  padding: 7rem 4rem;
}
.sol-sec::before {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(26,158,117,0.05) 1px, transparent 1px);
  background-size: 36px 36px; pointer-events: none;
}
.sol-inner { position: relative; z-index: 1; max-width: 1280px; margin: 0 auto; }
.sol-head { display: grid; grid-template-columns: 1.1fr 1fr; gap: 4rem; align-items: end; margin-bottom: 3.5rem; }
.sol-head .sec-kicker { color: var(--teal-mid); }
.sol-head .sec-kicker::before { background: var(--teal-mid); }
.sol-head .sec-heading { color: var(--white); }
.sol-head .sec-heading em { color: var(--teal-mid); }
.sol-head-sub { font-size: 0.95rem; font-weight: 300; color: rgba(255,255,255,0.5); line-height: 1.9; max-width: 48ch; }
.sol-head-sub em { font-family: var(--font-display); font-style: italic; color: var(--teal-mid); font-weight: 400; }
.sol-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.08); }
.sol-grid-2 { grid-template-columns: repeat(2,1fr); }
.sol-card { background: var(--navy); padding: 2rem 1.85rem; border-top: 2px solid transparent; transition: all 0.3s; display: flex; flex-direction: column; gap: 0.9rem; position: relative; }
.sol-card:hover { background: var(--navy-mid); border-top-color: var(--teal-mid); }
.sol-card-head { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; padding-bottom: 0.9rem; border-bottom: 1px solid rgba(255,255,255,0.08); }
.sol-card-code { font-size: 0.58rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.35); }
.sol-card-badge { font-family: var(--font-body); font-size: 0.58rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-mid); border: 1px solid rgba(26,158,117,0.35); padding: 0.2rem 0.55rem; white-space: nowrap; }
.sol-card-title { font-family: var(--font-display); font-size: 1.55rem; font-weight: 700; line-height: 1.15; color: var(--white); }
.sol-card-title em { font-style: italic; font-weight: 400; color: var(--teal-mid); }
.sol-card-who { font-size: 0.78rem; font-weight: 500; color: var(--teal-mid); line-height: 1.45; }
.sol-card-desc { font-size: 0.82rem; font-weight: 300; color: rgba(255,255,255,0.55); line-height: 1.75; }
.sol-card-feats { list-style: none; display: flex; flex-direction: column; gap: 0.35rem; margin-top: 0.25rem; padding-top: 0.75rem; border-top: 1px solid rgba(255,255,255,0.06); }
.sol-card-feats li { font-size: 0.74rem; color: rgba(255,255,255,0.5); line-height: 1.5; display: flex; gap: 0.5rem; align-items: flex-start; }
.sol-card-feats li::before { content: "→"; color: var(--teal-mid); font-weight: 600; flex-shrink: 0; opacity: 0.7; }
.sol-card-value { margin-top: auto; padding-top: 0.9rem; border-top: 1px dashed rgba(255,255,255,0.1); font-family: var(--font-display); font-size: 0.88rem; font-style: italic; color: var(--teal-mid); line-height: 1.5; }

/* ── SHARED CAPABILITIES STRIP ── */
.shared-sec { background: var(--off-white); padding: 5rem 4rem; }
.shared-inner { max-width: 1280px; margin: 0 auto; }
.shared-head { margin-bottom: 2.5rem; max-width: 760px; }
.shared-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); }
.shared-card { background: var(--white); padding: 2rem 1.85rem; border-top: 2px solid var(--teal); transition: all 0.25s; }
.shared-card:hover { background: var(--teal-xlight); }
.shared-card-tag { font-size: 0.58rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--teal); margin-bottom: 0.75rem; }
.shared-card-h { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; color: var(--navy); margin-bottom: 0.55rem; line-height: 1.2; }
.shared-card-h em { font-style: italic; font-weight: 400; color: var(--teal); }
.shared-card-d { font-size: 0.82rem; font-weight: 300; color: var(--text-secondary); line-height: 1.75; margin-bottom: 0.8rem; }
.shared-card-list { list-style: none; display: flex; flex-wrap: wrap; gap: 0.3rem; }
.shared-card-list li { font-size: 0.66rem; font-weight: 500; color: var(--text-secondary); background: var(--off-white); border: 1px solid var(--border); padding: 0.22rem 0.55rem; }

/* ── COMPARISON TABLE ── */
.compare-sec { background: var(--off-white); padding: 5rem 4rem; position: relative; }
.compare-inner { max-width: 1280px; margin: 0 auto; }
.compare-head { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: end; margin-bottom: 3.5rem; }
.compare-head p { font-size: 0.92rem; font-weight: 300; color: var(--text-secondary); line-height: 1.9; max-width: 46ch; margin-top: 1rem; }
.compare-table-wrap { overflow-x: auto; background: var(--white); border: 1px solid var(--border); }
.compare-table { width: 100%; border-collapse: collapse; min-width: 1100px; table-layout: fixed; }
.compare-table thead { background: var(--white); border-bottom: 1px solid var(--border); }
.compare-table thead th { padding: 1.5rem 1rem; text-align: left; vertical-align: bottom; border-right: 1px solid var(--border-light); }
.compare-table thead th:last-child { border-right: none; }
.compare-table thead th.col-dim { width: 180px; background: var(--off-white); }
.compare-table thead th.col-aion { background: var(--navy); color: var(--white); position: relative; }
.compare-table thead th.col-aion::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--teal-mid); }
.compare-dim { font-size: 0.6rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-muted); display: block; }
.compare-table thead .col-aion .compare-dim { color: var(--teal-mid); }
.compare-brand { font-family: var(--font-display); font-size: 1.45rem; font-weight: 700; letter-spacing: -0.01em; margin-top: 0.35rem; display: block; line-height: 1.1; color: var(--navy); }
.compare-brand-a { color: var(--teal-mid); }
.compare-tagline { font-size: 0.7rem; font-weight: 400; color: var(--text-muted); margin-top: 0.3rem; display: block; line-height: 1.4; }
.compare-vendor-origin { font-size: 0.62rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); margin-top: 0.35rem; display: block; }
.compare-table thead .col-aion .compare-vendor-origin { color: var(--teal-mid); }
.compare-table tbody tr { border-bottom: 1px solid var(--border-light); }
.compare-table tbody tr:last-child { border-bottom: none; }
.compare-table tbody td { padding: 1.1rem 1rem; vertical-align: top; font-size: 0.8rem; line-height: 1.6; color: var(--text-primary); font-weight: 300; border-right: 1px solid var(--border-light); }
.compare-table tbody td:last-child { border-right: none; }
.compare-table tbody td.cell-dim { font-size: 0.66rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-secondary); background: var(--off-white); }
.compare-table tbody td.cell-aion { background: var(--teal-xlight); color: var(--navy); font-weight: 400; }
.compare-table tbody tr:hover td:not(.cell-dim):not(.cell-aion) { background: rgba(11,107,84,0.02); }
.compare-note { margin-top: 2rem; padding: 1.75rem 2rem; background: var(--white); border-left: 3px solid var(--teal); font-size: 0.88rem; color: var(--text-secondary); line-height: 1.8; font-weight: 300; }
.compare-note strong.compare-note-label { color: var(--navy); font-weight: 600; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; display: block; margin-bottom: 0.75rem; }
.compare-note em { font-family: var(--font-display); font-style: italic; color: var(--teal); }

/* ── ENGINE PAGE RESPONSIVE ── */
@media (max-width: 1024px) {
  .pg-hero-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .sol-head, .compare-head { grid-template-columns: 1fr; gap: 2rem; }
  .sol-grid, .sol-grid-2, .shared-grid { grid-template-columns: 1fr; }
  .sol-sec, .shared-sec, .compare-sec { padding: 4rem 1.5rem; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}


/* ══════════════════════════════════════════════════════════
   ABOUT PAGE & SHARED COMPONENT STYLES
   (carousel, imgbreak, timeline, value cards, engine stack,
    proof numbers, case study cards, presence grid, reveal)
   ══════════════════════════════════════════════════════════ */

/* HERO */
.pg-hero{min-height:88vh;display:flex;align-items:center;padding:9rem 4rem 5rem;position:relative;overflow:hidden;background:var(--navy);}
.pg-hero-bg{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(26,158,117,0.07) 1px,transparent 1px);background-size:36px 36px;z-index:0;}
.pg-hero-img-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0.11;z-index:0;}
.pg-hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(12,27,46,0.97) 50%,rgba(12,27,46,0.72));z-index:1;}
.pg-hero-inner{max-width:1280px;margin:0 auto;width:100%;display:grid;grid-template-columns:55% 45%;gap:4rem;align-items:center;position:relative;z-index:2;}
.pg-hero-tag{font-size:0.62rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--teal-mid);margin-bottom:1.5rem;display:flex;align-items:center;gap:0.6rem;}
.pg-hero-tag::before{content:"";display:block;width:2rem;height:2px;background:var(--teal-mid);}
.pg-hero-headline{font-family:var(--font-display);font-size:clamp(3rem,5vw,5.2rem);font-weight:700;line-height:1.03;color:var(--white);margin-bottom:1.5rem;letter-spacing:-0.015em;}
.pg-hero-headline em{font-style:italic;font-weight:400;color:var(--teal-mid);}
.pg-hero-rule{width:3rem;height:2px;background:var(--teal-mid);margin-bottom:1.5rem;}
.pg-hero-sub{font-size:1rem;font-weight:300;color:rgba(255,255,255,0.5);line-height:1.9;margin-bottom:2rem;max-width:520px;}
.pg-hero-btns{display:flex;gap:1.25rem;flex-wrap:wrap;}
/* STAT CARD */
.stat-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);padding:2.5rem;position:relative;}
.stat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal-mid);}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,0.06);margin-bottom:1.5rem;}
.stat-cell{background:rgba(255,255,255,0.02);padding:1.5rem 1.25rem;cursor:default;}
.stat-n{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:var(--teal-mid);line-height:1;margin-bottom:0.3rem;}
.stat-l{font-size:0.65rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.25);}
.stat-note{font-size:0.75rem;font-weight:300;color:rgba(255,255,255,0.35);line-height:1.75;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,0.06);}
.stat-note strong{color:rgba(255,255,255,0.6);font-weight:500;}
/* MARQUEE */
.mq-bar{background:var(--teal);overflow:hidden;}
.mq-inner{display:flex;animation:mqScroll 34s linear infinite;white-space:nowrap;}
.mq-inner:hover{animation-play-state:paused;}
.mq-item{font-size:0.65rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.65);padding:0.85rem 2.5rem;border-right:1px solid rgba(255,255,255,0.15);flex-shrink:0;transition:color 0.2s;}
.mq-item:hover{color:var(--white);}
@keyframes mqScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
/* CARDS */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);}
.card-w{background:var(--white);padding:2.25rem 2rem;border-top:2px solid transparent;transition:all 0.25s;cursor:default;}
.card-w:hover{border-top-color:var(--teal);background:var(--teal-xlight);transform:translateY(-3px);}
.card-n{background:var(--navy);padding:2.25rem 2rem;border-top:2px solid transparent;transition:all 0.25s;cursor:default;}
.card-n:hover{border-top-color:var(--teal-mid);background:var(--navy-mid);transform:translateY(-3px);}
.card-num{font-size:0.58rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted);margin-bottom:0.75rem;}
.card-n .card-num{color:rgba(255,255,255,0.2);}
.card-title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--navy);line-height:1.15;margin-bottom:0.6rem;}
.card-n .card-title{color:var(--white);}
.card-title em{font-style:italic;font-weight:400;color:var(--teal);}
.card-n .card-title em{color:var(--teal-mid);}
.card-desc{font-size:0.82rem;font-weight:300;color:var(--text-secondary);line-height:1.8;}
.card-n .card-desc{color:rgba(255,255,255,0.38);}
.card-punch{font-size:0.78rem;font-style:italic;color:var(--teal-dark);border-left:2px solid var(--teal-light);padding-left:0.75rem;margin-top:1rem;line-height:1.6;}
.card-n .card-punch{color:var(--teal-mid);border-left-color:rgba(26,158,117,0.25);}
/* IMAGE BREAK */
.imgbreak{position:relative;overflow:hidden;}
.imgbreak img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.8s ease;}
.imgbreak:hover img{transform:scale(1.03);}
.imgbreak-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(12,27,46,0.92) 40%,rgba(12,27,46,0.25));}
.imgbreak-content{position:absolute;top:50%;left:4rem;transform:translateY(-50%);max-width:580px;}
.imgbreak-kicker{font-size:0.62rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--teal-mid);margin-bottom:1rem;display:flex;align-items:center;gap:0.6rem;}
.imgbreak-kicker::before{content:"";display:block;width:1.75rem;height:2px;background:var(--teal-mid);}
.imgbreak-headline{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,3.2rem);font-weight:700;color:var(--white);line-height:1.1;margin-bottom:1rem;}
.imgbreak-headline em{font-style:italic;font-weight:400;color:var(--teal-mid);}
.imgbreak-sub{font-size:0.9rem;font-weight:300;color:rgba(255,255,255,0.58);line-height:1.85;}
/* DARK SECTION */
.dark-sec{background:var(--navy);position:relative;overflow:hidden;}
.dark-sec-bg{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(26,158,117,0.06) 1px,transparent 1px);background-size:32px 32px;}
/* PROB ITEMS */
.prob-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;}
.prob-right{display:flex;flex-direction:column;gap:1px;background:var(--border-light);}
.prob-item{background:var(--white);padding:1.75rem 2rem;display:flex;align-items:flex-start;gap:1.5rem;transition:all 0.2s;border-left:3px solid transparent;cursor:default;}
.prob-item:hover{background:var(--teal-xlight);border-left-color:var(--teal);}
.prob-icon{font-size:1.3rem;margin-top:0.1rem;flex-shrink:0;}
.prob-title{font-size:0.9rem;font-weight:600;color:var(--navy);margin-bottom:0.3rem;}
.prob-desc{font-size:0.8rem;font-weight:300;color:var(--text-secondary);line-height:1.7;}
/* WORK ITEMS */
.work-list{display:flex;flex-direction:column;gap:1px;background:var(--border);}
.work-item{background:var(--white);display:grid;grid-template-columns:160px 1fr auto;gap:2rem;align-items:start;padding:2rem 2.5rem;border-left:3px solid transparent;transition:all 0.3s;cursor:default;}
.work-item:hover{background:var(--teal-xlight);border-left-color:var(--teal);transform:translateX(4px);}
.work-geo{font-size:0.6rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);padding-top:0.2rem;}
.work-title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:0.3rem;line-height:1.2;}
.work-punch{font-size:0.8rem;font-style:italic;color:var(--teal-dark);margin-bottom:0.5rem;line-height:1.5;}
.work-desc{font-size:0.79rem;font-weight:300;color:var(--text-secondary);line-height:1.75;}
.work-tags{display:flex;flex-wrap:wrap;gap:0.3rem;margin-top:0.75rem;}
.wtag{font-size:0.57rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;padding:0.2rem 0.55rem;border:1px solid var(--border-light);color:var(--text-muted);}
.work-arrow{font-size:1.1rem;color:var(--teal);opacity:0;transition:all 0.3s;align-self:center;}
.work-item:hover .work-arrow{opacity:1;transform:translateX(4px);}
/* PROOF NUMBERS */
.proof-nums{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border-light);margin-bottom:4rem;}
.pn-cell{background:var(--off-white);padding:1.75rem 1.5rem;cursor:default;transition:background 0.25s;position:relative;overflow:hidden;}
.pn-cell::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform 0.4s;}
.pn-cell:hover{background:var(--cream);}
.pn-cell:hover::after{transform:scaleX(1);}
.pn-n{font-family:var(--font-display);font-size:2.8rem;font-weight:700;color:var(--teal);line-height:1;margin-bottom:0.35rem;}
.pn-l{font-size:0.62rem;font-weight:400;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted);line-height:1.5;}
/* CASE STUDY CARDS */
.cs-card{background:var(--white);overflow:hidden;transition:all 0.3s;cursor:default;}
.cs-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(11,107,84,0.1);}
.cs-img{width:100%;height:200px;object-fit:cover;display:block;transition:transform 0.5s;}
.cs-card:hover .cs-img{transform:scale(1.04);}
.cs-body{padding:2rem;}
.cs-geo{font-size:0.6rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);display:flex;align-items:center;gap:0.45rem;margin-bottom:0.65rem;}
.cs-geo::before{content:"";width:10px;height:2px;background:var(--teal);}
.cs-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:0.4rem;line-height:1.2;}
.cs-punch{font-size:0.8rem;font-style:italic;color:var(--teal-dark);margin-bottom:0.6rem;line-height:1.55;}
.cs-desc{font-size:0.79rem;font-weight:300;color:var(--text-secondary);line-height:1.75;}
.cs-tag{display:inline-block;margin-top:0.85rem;font-size:0.6rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--teal);background:var(--teal-light);padding:0.25rem 0.65rem;}
.cs-card.dark .cs-body{background:var(--navy);}
.cs-card.dark .cs-title{color:var(--white);}
.cs-card.dark .cs-punch{color:var(--teal-mid);}
.cs-card.dark .cs-desc{color:rgba(255,255,255,0.45);}
.cs-card.dark .cs-geo{color:var(--teal-mid);}
.cs-card.dark .cs-geo::before{background:var(--teal-mid);}
.cs-card.dark .cs-tag{background:rgba(26,158,117,0.15);color:var(--teal-mid);}
/* TIMELINE */
.timeline{display:flex;flex-direction:column;}
.tl-item{display:grid;grid-template-columns:120px 1fr;gap:2rem;padding:1.75rem 0;border-bottom:1px solid var(--border-light);transition:background 0.2s;}
.tl-item:last-child{border-bottom:none;}
.tl-year{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--teal);line-height:1;}
.tl-title{font-size:0.9rem;font-weight:600;color:var(--navy);margin-bottom:0.3rem;}
.tl-desc{font-size:0.82rem;font-weight:300;color:var(--text-secondary);line-height:1.75;}
/* VALUES */
.value-card{padding:2.5rem;background:var(--white);border:1px solid var(--border-light);border-top:3px solid var(--teal);transition:all 0.3s;cursor:default;}
.value-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(11,107,84,0.1);}
.value-num{font-size:0.58rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--teal);margin-bottom:0.75rem;}
.value-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--navy);margin-bottom:0.75rem;}
.value-title em{font-style:italic;color:var(--teal);font-weight:400;}
.value-desc{font-size:0.85rem;font-weight:300;color:var(--text-secondary);line-height:1.85;}
/* INSIGHT CARDS */
.insight-card{background:var(--white);padding:2.5rem 2rem;border-top:3px solid transparent;transition:all 0.3s;cursor:default;}
.insight-card:hover{background:var(--off-white);border-top-color:var(--teal);transform:translateY(-3px);box-shadow:0 12px 32px rgba(11,107,84,0.08);}
.insight-type{font-size:0.58rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;padding:0.2rem 0.65rem;display:inline-block;margin-bottom:1rem;}
.insight-type.report{background:#EEF4FF;color:#1E40AF;}
.insight-type.whitepaper{background:var(--teal-light);color:var(--teal);}
.insight-type.research{background:#FFF8E6;color:#B45309;}
.insight-source{font-size:0.6rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:0.5rem;}
.insight-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--navy);line-height:1.25;margin-bottom:0.6rem;}
.insight-stat{font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--teal);line-height:1;margin-bottom:0.2rem;}
.insight-stat-l{font-size:0.65rem;font-weight:400;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted);}
.insight-excerpt{font-size:0.8rem;font-weight:300;color:var(--text-secondary);line-height:1.75;margin-top:0.75rem;margin-bottom:0.85rem;}
.insight-link{font-size:0.72rem;font-weight:600;color:var(--teal);text-decoration:none;letter-spacing:0.04em;display:inline-flex;align-items:center;gap:0.3rem;transition:gap 0.2s;}
.insight-link:hover{gap:0.55rem;}
/* PRESENCE */
.presence-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin-top:3.5rem;}
.region-card{background:var(--white);padding:2.5rem 2rem;border-top:2px solid transparent;transition:all 0.3s;cursor:default;}
.region-card:hover{background:var(--teal-xlight);border-top-color:var(--teal);transform:translateY(-4px);}
.region-name{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--navy);margin-bottom:0.75rem;}
.region-markets{font-size:0.78rem;font-weight:300;color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem;}
.region-stat{font-family:var(--font-display);font-size:2.4rem;font-weight:700;color:var(--teal);line-height:1;display:block;}
.region-stat-l{font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted);display:block;margin-top:0.3rem;}
/* ENGINE STACK */
.engine-stack{display:flex;flex-direction:column;gap:2px;margin-top:3.5rem;}
.engine-row{display:grid;grid-template-columns:180px 1fr;background:var(--off-white);border-left:3px solid var(--border);transition:all 0.25s;cursor:default;}
.engine-row:hover{border-left-color:var(--teal);background:var(--teal-xlight);}
.engine-row-left{padding:1.75rem 2rem;border-right:1px solid var(--border-light);display:flex;flex-direction:column;justify-content:center;}
.engine-name{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--teal);}
.engine-layer{font-size:0.58rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);margin-top:0.25rem;}
.engine-row-right{padding:1.75rem 2rem;}
.engine-title{font-size:0.88rem;font-weight:600;color:var(--navy);margin-bottom:0.35rem;}
.engine-desc{font-size:0.79rem;font-weight:300;color:var(--text-secondary);line-height:1.75;}

/* ── SCROLL REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.75s cubic-bezier(0.16,1,0.3,1),transform 0.75s cubic-bezier(0.16,1,0.3,1);}
.reveal.in{opacity:1;transform:translateY(0);}
.delay-1{transition-delay:0.08s;}.delay-2{transition-delay:0.16s;}.delay-3{transition-delay:0.24s;}

/* ── HERO CAROUSEL (about page + future pages) ── */
/* ═══════════════════════════════════════════════════════════════
   CAPTIV HERO CAROUSEL — shared across all pages
   ═══════════════════════════════════════════════════════════════ */
.c-hero{position:relative;width:100%;min-height:92vh;overflow:hidden;background:#0C1B2E;}
.c-track{display:flex;width:100%;height:100%;transition:none;}
.c-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s cubic-bezier(0.4,0,0.2,1);pointer-events:none;display:flex;align-items:center;}
.c-slide.active{opacity:1;pointer-events:auto;z-index:2;}
.c-slide.prev{opacity:0;z-index:1;}
.c-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.06);transition:transform 8s ease-out;}
.c-slide.active .c-slide-bg{transform:scale(1);}
.c-slide-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(11,27,46,0.92) 0%,rgba(11,27,46,0.72) 55%,rgba(11,27,46,0.38) 100%);}
.c-slide-content{position:relative;z-index:3;max-width:1280px;margin:0 auto;padding:0 4rem;width:100%;display:grid;grid-template-columns:58% 42%;gap:4rem;align-items:center;}
.c-tag{font-size:0.6rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:#1A9E75;display:flex;align-items:center;gap:0.6rem;margin-bottom:1.4rem;opacity:0;transform:translateY(18px);transition:opacity 0.7s 0.1s ease,transform 0.7s 0.1s ease;}
.c-slide.active .c-tag{opacity:1;transform:translateY(0);}
.c-tag::before{content:"";display:block;width:2rem;height:2px;background:#1A9E75;flex-shrink:0;}
.c-headline{font-family:"Cormorant Garamond",serif;font-size:clamp(3rem,5.2vw,5.4rem);font-weight:700;line-height:1.03;color:#fff;letter-spacing:-0.015em;margin-bottom:1.4rem;opacity:0;transform:translateY(22px);transition:opacity 0.7s 0.22s ease,transform 0.7s 0.22s ease;}
.c-slide.active .c-headline{opacity:1;transform:translateY(0);}
.c-headline em{font-style:italic;font-weight:400;color:#1A9E75;}
.c-rule{width:3rem;height:2px;background:#1A9E75;margin-bottom:1.4rem;opacity:0;transition:opacity 0.7s 0.35s ease;}
.c-slide.active .c-rule{opacity:1;}
.c-sub{font-size:0.98rem;font-weight:300;color:rgba(255,255,255,0.55);line-height:1.9;max-width:500px;margin-bottom:1.8rem;opacity:0;transform:translateY(14px);transition:opacity 0.7s 0.42s ease,transform 0.7s 0.42s ease;}
.c-slide.active .c-sub{opacity:1;transform:translateY(0);}
.c-punch{font-family:"Cormorant Garamond",serif;font-size:1.15rem;font-style:italic;color:#1A9E75;line-height:1.5;margin-bottom:2rem;opacity:0;transition:opacity 0.7s 0.52s ease;}
.c-slide.active .c-punch{opacity:1;}
.c-btns{display:flex;gap:1.2rem;flex-wrap:wrap;opacity:0;transform:translateY(10px);transition:opacity 0.7s 0.6s ease,transform 0.7s 0.6s ease;}
.c-slide.active .c-btns{opacity:1;transform:translateY(0);}
.c-btn-solid{background:#0B6B54;color:#fff;padding:0.9rem 2rem;font-size:0.85rem;font-weight:600;text-decoration:none;letter-spacing:0.05em;transition:all 0.2s;display:inline-block;text-transform:uppercase;}
.c-btn-solid:hover{background:#084D3B;transform:translateY(-2px);}
.c-btn-ghost{border:1.5px solid rgba(255,255,255,0.3);color:#fff;padding:0.9rem 2rem;font-size:0.85rem;font-weight:500;text-decoration:none;letter-spacing:0.03em;transition:all 0.2s;display:inline-block;}
.c-btn-ghost:hover{border-color:#1A9E75;background:rgba(26,158,117,0.12);}
/* stat card in carousel */
.c-stat-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);padding:2.2rem;position:relative;opacity:0;transform:translateX(20px);transition:opacity 0.8s 0.5s ease,transform 0.8s 0.5s ease;}
.c-slide.active .c-stat-card{opacity:1;transform:translateX(0);}
.c-stat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:#1A9E75;}
.c-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,0.06);margin-bottom:1.4rem;}
.c-stat-cell{background:rgba(255,255,255,0.02);padding:1.4rem 1.1rem;}
.c-stat-n{font-family:"Cormorant Garamond",serif;font-size:2.4rem;font-weight:700;color:#1A9E75;line-height:1;margin-bottom:0.25rem;}
.c-stat-l{font-size:0.62rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.22);}
.c-stat-note{font-size:0.72rem;font-weight:300;color:rgba(255,255,255,0.32);line-height:1.75;}
/* nav dots */
.c-nav{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;gap:0.7rem;z-index:10;}
.c-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.25);border:none;cursor:pointer;transition:all 0.3s;padding:0;}
.c-dot.active{background:#1A9E75;width:28px;border-radius:4px;}
/* arrow buttons */
.c-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);color:#fff;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;font-size:1.2rem;}
.c-arrow:hover{background:rgba(26,158,117,0.25);border-color:#1A9E75;}
.c-arrow.prev{left:2rem;}
.c-arrow.next{right:2rem;}
/* progress bar */
.c-progress{position:absolute;bottom:0;left:0;height:2px;background:#1A9E75;z-index:10;width:0%;transition:width linear;}
/* ambient dot pattern overlay */
.c-dots-bg{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(26,158,117,0.07) 1px,transparent 1px);background-size:36px 36px;z-index:1;pointer-events:none;}
@media(max-width:1024px){
  .c-slide-content{grid-template-columns:1fr;padding:0 1.5rem;}
  .c-stat-card{display:none;}
  .c-hero{min-height:80vh;}
  .c-arrow{display:none;}
}
@media(max-width:768px){
  .c-hero{min-height:75vh;}
  .c-slide-content{padding:0 1.25rem !important;}
  .c-headline{font-size:clamp(2rem,7vw,3rem) !important;line-height:1.1;}
  .c-tag{font-size:0.58rem;}
  .c-sub{font-size:0.85rem !important;line-height:1.7;}
  .c-punch{font-size:0.9rem !important;}
  .c-btn-solid,.c-btn-ghost{padding:0.75rem 1.25rem;font-size:0.78rem;}
  .c-btns{gap:0.75rem;flex-wrap:wrap;}
  .c-nav{bottom:1rem;}
  .c-progress{display:none;}
}
@media(max-width:480px){
  .c-hero{min-height:70vh;}
  .c-headline{font-size:clamp(1.7rem,7vw,2.4rem) !important;}
  .c-sub{font-size:0.8rem !important;}
  .c-btns{flex-direction:column;gap:0.5rem;}
  .c-btn-solid,.c-btn-ghost{width:100%;text-align:center;}
}

/* ── LIGHT MODIFIER (headings/kickers on dark backgrounds) ── */
.sec-kicker.light { color: var(--teal-mid); }
.sec-kicker.light::before { background: var(--teal-mid); }
.sec-heading.light { color: var(--white); }
.sec-heading.light em { color: var(--teal-mid); }

/* ══════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE RESPONSIVE — 480px & 768px
   ══════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  /* ── Prevent horizontal scroll globally ── */
  html, body { overflow-x: hidden; max-width: 100%; }
  img, video, iframe, table { max-width: 100%; }

  /* ── Base ── */
  body { font-size: 15px; }
  .sec { padding: 3.5rem 1.25rem !important; }
  .sec-inner { padding-left: 0; padding-right: 0; }

  /* ── Section headings ── */
  .sec-heading { font-size: clamp(2rem, 6vw, 2.8rem); }

  /* ── Shared grids → single column ── */
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }

  /* ── Engine page hero ── */
  .pg-hero { padding: 5rem 1.25rem 3rem !important; min-height: auto; }
  .pg-hero-headline { font-size: clamp(2rem, 7vw, 3.2rem) !important; }
  .pg-hero-sub { font-size: 0.88rem; max-width: 100%; }
  .pg-hero-inner { grid-template-columns: 1fr; gap: 2rem; }
  .pg-hero-headline { font-size: clamp(2.2rem, 7vw, 3.2rem); }

  /* ── Stat card ── */
  .stat-card { padding: 1.5rem; }
  .stat-grid { grid-template-columns: 1fr 1fr; }

  /* ── Sol section ── */
  .sol-sec { padding: 4rem 1.25rem; }
  .sol-head { grid-template-columns: 1fr; gap: 1.5rem; }
  .sol-grid, .sol-grid-2 { grid-template-columns: 1fr; }
  .sol-card { padding: 1.75rem 1.5rem; }

  /* ── Shared capabilities ── */
  .shared-sec { padding: 4rem 1.25rem; }
  .shared-grid { grid-template-columns: 1fr; }

  /* ── Compare table ── */
  .compare-sec { padding: 4rem 1.25rem; }
  .compare-head { grid-template-columns: 1fr; gap: 1.5rem; }
  .compare-table { min-width: 600px; }

  /* ── Cards ── */
  .card-w, .card-n { padding: 1.75rem 1.25rem; }

  /* ── imgbreak ── */
  .imgbreak { height: 280px !important; }
  .imgbreak-content { left: 1.25rem; right: 1.25rem; max-width: 100%; }
  .imgbreak-headline { font-size: clamp(1.6rem, 5vw, 2.2rem); }

  /* ── Timeline ── */
  .tl-item { grid-template-columns: 80px 1fr; gap: 1rem; }
  .tl-year { font-size: 1.4rem; }

  /* ── Value cards ── */
  .value-card { padding: 2rem 1.5rem; }

  /* ── Engine stack ── */
  .engine-row { grid-template-columns: 1fr; }
  .engine-row-left { border-right: none; border-bottom: 1px solid var(--border-light); }

  /* ── Proof numbers ── */
  .proof-nums { grid-template-columns: 1fr 1fr; }

  /* ── Case study cards ── */
  .cs-img { height: 160px; }
  .cs-body { padding: 1.5rem; }

  /* ── Presence grid ── */
  .presence-grid { grid-template-columns: 1fr 1fr; gap: 1px; }
  .region-card { padding: 1.75rem 1.25rem; }

  /* ── Insight cards ── */
  .insight-card { padding: 1.75rem 1.25rem; }

  /* ── Work list ── */
  .work-item { grid-template-columns: 1fr; gap: 0.5rem; padding: 1.5rem; }
  .work-arrow { display: none; }

  /* ── Prob grid ── */
  .prob-grid { grid-template-columns: 1fr; gap: 2rem; }

  /* ── Stats bar ── */
  .stats-row { grid-template-columns: 1fr 1fr; }
  .stat-cell { padding: 1.5rem 1rem; }

  /* ── Footer ── */
  .footer-top { grid-template-columns: 1fr; gap: 2rem; }

  /* ── CTA band ── */
  .cta-band { padding: 5rem 1.25rem; }
  .cta-heading { font-size: clamp(2.2rem, 7vw, 3.5rem); }

  /* ── Marquee ── */
  .mq-item { padding: 0.7rem 1.5rem; font-size: 0.6rem; }

  /* ── Logo ribbon ── */
  .logo-slot { width: 200px; height: 100px; }
  .logo-slot img { max-width: 100px; max-height: 50px; }

  /* ── Ind CTA ── */
  .ind-cta-inner { grid-template-columns: 1fr; padding: 4rem 1.25rem; gap: 2.5rem; }
  .ind-cta-headline { font-size: clamp(2rem, 6vw, 3rem); }

  /* ── Dark section ── */
  .dark-sec.sec { padding: 4rem 1.25rem; }
}

@media (max-width: 480px) {

  /* ── Tighter padding on very small screens ── */
  .sec { padding: 3rem 1rem; }
  .pg-hero { padding: 4.5rem 1rem 2.5rem; }

  /* ── Single column everything ── */
  .stat-grid { grid-template-columns: 1fr; }
  .proof-nums { grid-template-columns: 1fr; }
  .presence-grid { grid-template-columns: 1fr; }
  .stats-row { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }

  /* ── Headings ── */
  .sec-heading { font-size: clamp(1.8rem, 7vw, 2.4rem); }
  .pg-hero-headline { font-size: clamp(1.9rem, 8vw, 2.8rem); }
  .cta-heading { font-size: clamp(1.9rem, 8vw, 2.8rem); }

  /* ── Logo ribbon ── */
  .logo-slot { width: 160px; height: 80px; }
  .logo-slot img { max-width: 80px; max-height: 40px; }

  /* ── Stat card ── */
  .stat-card { padding: 1.25rem; }
  .stat-n { font-size: 2rem; }

  /* ── Tables ── */
  .compare-table-wrap { font-size: 0.72rem; }
}

/* ══════════════════════════════════════════════════════════
   UNIVERSAL MOBILE FIX — applied after all other rules
   Targets all screen widths ≤ 768px
   ══════════════════════════════════════════════════════════ */

@media screen and (max-width: 768px) {

  /* ── Hard overflow lock ── */
  html, body {
    overflow-x: hidden !important;
    max-width: 100vw !important;
  }

  /* ── All images respect viewport ── */
  img, video, iframe, svg {
    max-width: 100% !important;
    height: auto;
  }

  /* ── All sections get safe padding ── */
  section, .sec, footer, nav {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
    box-sizing: border-box;
  }

  /* ── All max-width wrappers go full width ── */
  [style*="max-width: 1280px"],
  [style*="max-width:1280px"],
  [style*="max-width: 1200px"],
  .sec-inner, .sol-inner, .compare-inner, .shared-inner,
  .footer-top, .footer-bottom, .stats-row {
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* ── All inline grids collapse ── */
  [style*="display:grid"],
  [style*="display: grid"],
  [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  /* ── Hero sections ── */
  .hero { padding: 5rem 1.25rem 3rem !important; }
  .hero-inner,
  .pg-hero-inner { grid-template-columns: 1fr !important; gap: 2rem !important; }
  .hero-card, .stat-card { display: none !important; }
  .hero-diagonal, .hero-dots, .hero-teal-rule { display: none !important; }
  .hero-headline,
  .pg-hero-headline,
  .c-headline,
  .sec-heading {
    font-size: clamp(1.8rem, 6.5vw, 2.8rem) !important;
    line-height: 1.15 !important;
  }

  /* ── Carousel ── */
  .c-slide-content {
    grid-template-columns: 1fr !important;
    padding: 2rem 1.25rem !important;
  }
  .c-stat-card { display: none !important; }
  .c-sub { font-size: 0.85rem !important; }
  .c-btns { flex-wrap: wrap; gap: 0.75rem; }

  /* ── Engine sol grid ── */
  .sol-grid { grid-template-columns: 1fr !important; }
  .sol-head { grid-template-columns: 1fr !important; }

  /* ── Shared caps ── */
  .shared-grid { grid-template-columns: 1fr !important; }

  /* ── Comparison ── */
  .compare-head { grid-template-columns: 1fr !important; }
  .compare-table-wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* ── Stats bar ── */
  .stats-row { grid-template-columns: 1fr 1fr !important; }

  /* ── Footer ── */
  .footer-top { grid-template-columns: 1fr !important; gap: 2rem !important; }

  /* ── Tables ── */
  table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* ── Remove fixed heights ── */
  [style*="height: 420px"], [style*="height:420px"],
  [style*="height: 400px"], [style*="height:400px"],
  [style*="height: 360px"], [style*="height:360px"] {
    height: 220px !important;
  }

  /* ── Industry CTA ── */
  .ind-cta-inner {
    grid-template-columns: 1fr !important;
    padding: 3rem 1.25rem !important;
  }
}

@media screen and (max-width: 480px) {

  section, .sec {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .sec-heading,
  .hero-headline,
  .pg-hero-headline,
  .c-headline {
    font-size: clamp(1.6rem, 7vw, 2.2rem) !important;
  }

  .stats-row { grid-template-columns: 1fr !important; }
  .stat-grid { grid-template-columns: 1fr !important; }
  .c-btns { flex-direction: column; }
  .c-btn-solid, .c-btn-ghost { width: 100%; text-align: center; }
}
