/* ============================================================
   WEIGEAUX MOBILITY TECHNOLOGIES — Master Stylesheet
   Light Metro Theme · Brand: Teal #0DAFAA + Lime #A8E055
   ============================================================ */

/* ── 1. Design Tokens ─────────────────────────────────────── */
:root {
  /* Brand colors (from logo) */
  --c-teal:        #0DAFAA;
  --c-teal-dark:   #088A86;
  --c-teal-light:  #5FCFCB;
  --c-lime:        #A8E055;
  --c-lime-dark:   #7CB832;
  --c-lime-light:  #C8EC8C;

  /* Neutrals (light theme) */
  --c-ink:         #0A1628;   /* primary headings */
  --c-charcoal:    #1F2937;   /* body text */
  --c-slate:       #475569;   /* secondary text */
  --c-muted:       #6B7280;   /* tertiary */
  --c-line:        #E5E7EB;   /* borders */
  --c-tint:        #F1F5F9;   /* light surface */
  --c-cream:       #F8FAFC;   /* page bg alt */
  --c-white:       #FFFFFF;

  /* Metro tile palette */
  --tile-1: var(--c-teal);
  --tile-2: var(--c-lime);
  --tile-3: var(--c-ink);
  --tile-4: #F4A261;          /* warm accent (heavy truck) */
  --tile-5: #6366F1;          /* indigo (aerospace) */
  --tile-6: #EC4899;          /* magenta (innovation) */

  /* Typography */
  --font-display: 'Jura', 'Archivo', system-ui, sans-serif;
  --font-body:    'DM Sans', 'Helvetica Neue', sans-serif;
  --font-mono:    'JetBrains Mono', 'SF Mono', monospace;

  /* Type scale (clamp = fluid) — sized down ~10-15% */
  --fs-xs:   0.75rem;
  --fs-sm:   0.875rem;
  --fs-base: 1rem;
  --fs-lg:   1.125rem;
  --fs-xl:   1.25rem;
  --fs-2xl:  clamp(1.25rem, 1.05rem + 1.1vw, 1.625rem);
  --fs-3xl:  clamp(1.5rem, 1.2rem + 1.6vw, 2.125rem);
  --fs-4xl:  clamp(2rem, 1.4rem + 3.2vw, 3.125rem);
  --fs-5xl:  clamp(2.5rem, 1.5rem + 4.8vw, 4.25rem);

  /* Spacing */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-7: 1.75rem;
  --sp-8: 2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;
  --sp-32: 8rem;

  /* Aliases for legacy variable names used across components */
  --ff-display: var(--font-display);
  --ff-body:    var(--font-body);
  --ff-mono:    var(--font-mono);
  --c-ink-soft: var(--c-slate);
  --c-border:   var(--c-line);
  --c-warm:     var(--tile-4);
  --c-indigo:   var(--tile-5);
  --c-magenta:  var(--tile-6);
  --radius:     2px;
  --radius-sm:  2px;
  --radius-md:  4px;
  --radius-lg:  6px;

  /* Layout */
  --container: 1320px;
  --container-narrow: 960px;
  --header-h: 92px;

  /* Shadows (subtle, metro-appropriate) */
  --shadow-sm: 0 1px 3px rgba(10, 22, 40, 0.06);
  --shadow-md: 0 6px 18px rgba(10, 22, 40, 0.08);
  --shadow-lg: 0 18px 40px rgba(10, 22, 40, 0.12);
  --shadow-tile: 0 12px 32px rgba(13, 175, 170, 0.18);

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast: 180ms;
  --dur:      320ms;
  --dur-slow: 600ms;
}

/* ── 2. Reset + Base ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--c-charcoal);
  background: var(--c-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--c-teal-dark); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
a:hover { color: var(--c-teal); }
button { font-family: inherit; cursor: pointer; border: 0; background: none; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  margin: 0 0 var(--sp-4);
}
h1 { font-size: var(--fs-5xl); letter-spacing: -0.035em; }
h2 { font-size: var(--fs-4xl); letter-spacing: -0.03em; }
h3 { font-size: var(--fs-3xl); }
h4 { font-size: var(--fs-2xl); }
h5 { font-size: var(--fs-xl); }
h6 { font-size: var(--fs-lg); text-transform: uppercase; letter-spacing: 0.08em; }

p { margin: 0 0 var(--sp-4); }
.lead { font-size: var(--fs-lg); color: var(--c-slate); line-height: 1.7; }

/* ── 3. Layout primitives ─────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 2.5rem);
}
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 clamp(1rem, 4vw, 2.5rem); }

section { padding: clamp(4rem, 8vw, 7rem) 0; position: relative; }
section.tight { padding: clamp(3rem, 5vw, 4rem) 0; }

/* ── 4. Eyebrow + Section Heading kit ─────────────────────── */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-teal-dark);
  margin-bottom: var(--sp-4);
}
.eyebrow::before {
  content: '';
  width: 32px; height: 2px;
  background: var(--c-lime);
}
.section-head { max-width: 780px; margin-bottom: var(--sp-12); }
.section-head.center { text-align: center; margin-left: auto; margin-right: auto; }

/* ── 5. Buttons ───────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0.95rem 1.6rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-base);
  letter-spacing: 0.01em;
  border-radius: 2px;
  transition: all var(--dur) var(--ease);
  position: relative;
  overflow: hidden;
}
.btn-primary {
  background: var(--c-ink);
  color: var(--c-white);
}
.btn-primary:hover {
  background: var(--c-teal);
  color: var(--c-white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-tile);
}
.btn-accent {
  background: var(--c-lime);
  color: var(--c-ink);
}
.btn-accent:hover {
  background: var(--c-lime-dark);
  color: var(--c-white);
  transform: translateY(-2px);
}
.btn-outline {
  background: transparent;
  color: var(--c-ink);
  border: 2px solid var(--c-ink);
}
.btn-outline:hover {
  background: var(--c-ink);
  color: var(--c-white);
}
.btn-ghost {
  color: var(--c-ink);
  padding: 0.5rem 0;
}
.btn-ghost::after {
  content: '→';
  transition: transform var(--dur) var(--ease);
}
.btn-ghost:hover::after { transform: translateX(6px); }

/* ── 6. Header / Nav ──────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,0.95);
  backdrop-filter: saturate(150%) blur(12px);
  -webkit-backdrop-filter: saturate(150%) blur(12px);
  border-bottom: 1px solid var(--c-line);
}
.header-topbar {
  background: var(--c-ink);
  color: var(--c-white);
  font-size: var(--fs-xs);
  padding: 0.6rem 0;
  letter-spacing: 0.04em;
}
.header-topbar .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-6);
  flex-wrap: wrap;
}
.header-topbar a { color: var(--c-lime); }
.header-topbar a:hover { color: var(--c-white); }
.topbar-meta { display: flex; gap: var(--sp-6); flex-wrap: wrap; }
.topbar-meta span { display: inline-flex; align-items: center; gap: var(--sp-2); }

.header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
  gap: var(--sp-8);
}
.brand {
  display: flex; align-items: center; gap: var(--sp-3);
  flex-shrink: 0;
}
.brand img { height: 65px; width: auto; }
.brand-tile {
 /* background: var(--c-ink); */
  padding: 8px 12px;
  border-radius: 2px;
  display: inline-flex;
  align-items: center;
}

.nav-list {
  display: flex;
  list-style: none;
  margin: 0; padding: 0;
  gap: 0;
}
.nav-list > li { position: relative; }
.nav-list > li > a {
  display: block;
  padding: 1.6rem 1rem;
  font-weight: 500;
  font-size: var(--fs-sm);
  color: var(--c-ink);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  position: relative;
}
.nav-list > li > a::after {
  content: '';
  position: absolute;
  bottom: 1.2rem; left: 1rem; right: 1rem;
  height: 2px;
  background: var(--c-lime);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur) var(--ease);
}
.nav-list > li:hover > a::after,
.nav-list > li > a.is-active::after { transform: scaleX(1); }

.submenu {
  position: absolute; top: 100%; left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 260px;
  background: var(--c-white);
  box-shadow: var(--shadow-lg);
  border-top: 3px solid var(--c-lime);
  list-style: none;
  margin: 0; padding: var(--sp-2) 0;
  opacity: 0; visibility: hidden;
  transition: all var(--dur) var(--ease);
}
.nav-list > li:hover > .submenu {
  opacity: 1; visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.submenu li a {
  display: block;
  padding: 0.85rem 1.4rem;
  font-size: var(--fs-sm);
  color: var(--c-charcoal);
  border-left: 3px solid transparent;
  transition: all var(--dur-fast) var(--ease);
}
.submenu li a:hover {
  background: var(--c-cream);
  border-left-color: var(--c-teal);
  color: var(--c-teal-dark);
  padding-left: 1.6rem;
}

.nav-cta {
  display: flex; align-items: center; gap: var(--sp-3);
  flex-shrink: 0;
}
.menu-toggle { display: none; }

/* Close button & mobile-only CTA — hidden by default (desktop) */
.nav-close { display: none; }
.nav-mobile-cta { display: none; }
.nav-backdrop { display: none; }

/* Mobile nav */
@media (max-width: 1024px) {
  .menu-toggle {
    display: flex; flex-direction: column; gap: 5px;
    width: 44px; height: 44px;
    align-items: center; justify-content: center;
    background: var(--c-ink);
    border-radius: 2px;
    position: relative;
    z-index: 1001;
  }
  .menu-toggle span {
    width: 22px; height: 2px; background: var(--c-white);
    transition: all var(--dur) var(--ease);
  }
  .menu-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle.is-open span:nth-child(2) { opacity: 0; }
  .menu-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* Hide the desktop "Partner With Us" button on mobile — it shows inside the drawer instead */
  .nav-cta .btn-primary { display: none; }

  .primary-nav {
    position: fixed; top: 0; right: 0;
    width: min(360px, 90vw); height: 100vh; height: 100dvh;
    background: var(--c-white);
    box-shadow: var(--shadow-lg);
    transform: translateX(100%);
    transition: transform var(--dur-slow) var(--ease);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 5rem 1.5rem 2rem;
    z-index: 1100;
  }
  .primary-nav.is-open { transform: translateX(0); }

  /* Close button inside drawer */
  .nav-close {
    display: flex;
    position: absolute;
    top: 1rem; right: 1rem;
    width: 44px; height: 44px;
    align-items: center; justify-content: center;
    background: var(--c-ink);
    color: var(--c-white);
    border-radius: 2px;
    z-index: 2;
    transition: background var(--dur-fast) var(--ease);
  }
  .nav-close:hover, .nav-close:focus-visible { background: var(--c-teal); }

  .nav-list { flex-direction: column; }
  .nav-list > li > a {
    padding: 1rem 0;
    border-bottom: 1px solid var(--c-line);
    font-size: 0.95rem;
  }
  .nav-list > li > a::after { display: none; }
  .submenu {
    position: static; transform: none; box-shadow: none;
    opacity: 1; visibility: visible;
    border-top: 0; padding-left: var(--sp-4);
    min-width: 0;
    max-height: 0; overflow: hidden;
    transition: max-height var(--dur) var(--ease);
  }
  .nav-list > li.is-expanded .submenu { max-height: 500px; }

  /* Mobile-only "Partner With Us" CTA inside the drawer */
  .nav-mobile-cta {
    display: inline-flex;
    margin-top: var(--sp-6);
    width: 100%;
    justify-content: center;
  }

  /* Backdrop overlay behind the drawer */
  .nav-backdrop {
    display: block;
    position: fixed; inset: 0;
    background: rgba(10, 22, 40, 0.55);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    opacity: 0; visibility: hidden;
    transition: opacity var(--dur) var(--ease), visibility var(--dur) var(--ease);
    z-index: 1050;
  }
  .nav-backdrop.is-open {
    opacity: 1; visibility: visible;
  }

  /* When drawer open, ensure nothing else is interactive on top */
  body.nav-locked { overflow: hidden; }
}

/* ── 7. Hero Slider ───────────────────────────────────────── */
.hero {
  position: relative;
  background: var(--c-cream);
  overflow: hidden;
  min-height: clamp(520px, 72vh, 680px);
  display: flex;
  align-items: stretch;
  padding: var(--sp-8) 0;
}
.hero-slides {
  position: relative;
  width: 100%;
  min-height: clamp(440px, 60vh, 580px);
}
.hero-slide {
  position: absolute; inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 900ms var(--ease);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  align-items: center;
  gap: var(--sp-8);
}
.hero-slide.is-active { opacity: 1; visibility: visible; }
@media (max-width: 900px) {
  .hero-slide { grid-template-columns: 1fr; padding: var(--sp-6) 0; gap: var(--sp-6); }
}

.hero-content {
  padding: var(--sp-6) 0 var(--sp-6) clamp(1rem, 3vw, 3rem);
  position: relative;
  z-index: 2;
}
.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--c-teal-dark);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.hero-eyebrow::before {
  content: ''; width: 48px; height: 3px; background: var(--c-lime);
}
.hero-title {
  font-size: clamp(2.25rem, 1.4rem + 4vw, 3.75rem);
  margin-bottom: var(--sp-5);
  line-height: 1.05;
}
.hero-title .accent { color: var(--c-teal); }
.hero-title .underline {
  background-image: linear-gradient(transparent 75%, var(--c-lime) 75%);
  background-size: 100% 100%;
  padding: 0 0.15em;
}
.hero-lead {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  color: var(--c-slate);
  max-width: 540px;
  margin-bottom: var(--sp-8);
  line-height: 1.7;
}
.hero-actions { display: flex; gap: var(--sp-4); flex-wrap: wrap; }

.hero-visual {
  position: relative;
  height: 100%;
  min-height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 900px) {
  .hero-visual { min-height: 320px; padding: 0 1rem; }
}

/* Hero metro tile composition — visual side */
.hero-tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, 1fr);
  gap: 8px;
  width: min(100%, 540px);
  aspect-ratio: 1 / 1;
  padding: var(--sp-4);
}
.hero-tile {
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  font-family: var(--font-display);
  color: var(--c-white);
  font-weight: 600;
  letter-spacing: -0.02em;
  transition: transform var(--dur-slow) var(--ease);
}
.hero-tile:hover { transform: scale(1.04); z-index: 2; box-shadow: var(--shadow-lg); }
.hero-tile.t-1 { background: var(--c-teal); grid-column: 1 / 3; grid-row: 1; }
.hero-tile.t-2 { background: var(--c-ink); grid-column: 3; grid-row: 1 / 3; }
.hero-tile.t-3 { background: var(--c-lime); color: var(--c-ink); grid-column: 1; grid-row: 2; }
.hero-tile.t-4 { background: var(--c-cream); color: var(--c-ink); grid-column: 2; grid-row: 2; border: 2px solid var(--c-ink); }
.hero-tile.t-5 { background: var(--c-ink); color: var(--c-lime); grid-column: 1 / 3; grid-row: 3; }
.hero-tile.t-6 { background: var(--c-teal-dark); grid-column: 3; grid-row: 3; }
.hero-tile .num {
  font-size: clamp(2rem, 5vw, 3.5rem);
  line-height: 1;
}
.hero-tile .lbl {
  position: absolute; bottom: 1rem; left: 1rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 400;
  opacity: 0.8;
}
.hero-tile.icon-tile { padding: 1.5rem; }
.hero-tile.icon-tile svg { width: 50%; height: 50%; opacity: 0.95; }

/* Slider dots + arrows */
.slider-dots {
  position: absolute;
  bottom: 2rem; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: var(--sp-3);
  z-index: 5;
}
.slider-dot {
  width: 36px; height: 4px;
  background: rgba(10,22,40,0.2);
  border-radius: 0;
  transition: all var(--dur) var(--ease);
}
.slider-dot.is-active { background: var(--c-teal); width: 56px; }
.slider-arrows {
  position: absolute;
  bottom: 2rem; right: 2rem;
  display: flex; gap: var(--sp-2);
  z-index: 5;
}
.slider-arrow {
  width: 48px; height: 48px;
  background: var(--c-white);
  border: 1px solid var(--c-line);
  display: flex; align-items: center; justify-content: center;
  transition: all var(--dur) var(--ease);
}
.slider-arrow:hover {
  background: var(--c-ink);
  color: var(--c-white);
  border-color: var(--c-ink);
}
.slider-arrow svg { width: 18px; height: 18px; }

/* ── 8. Stats strip ───────────────────────────────────────── */
.stats-strip {
  background: var(--c-ink);
  color: var(--c-white);
  padding: 3rem 0;
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255,255,255,0.08);
}
@media (max-width: 768px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }
.stat-cell {
  background: var(--c-ink);
  padding: var(--sp-6) var(--sp-4);
  text-align: center;
}
.stat-value {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4vw, 3.5rem);
  font-weight: 700;
  line-height: 1;
  color: var(--c-lime);
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-2);
}
.stat-label {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.7);
}

/* ── 9. Metro Tile Grid (capabilities/feature) ────────────── */
.metro-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: minmax(180px, auto);
  gap: 14px;
}
@media (max-width: 900px) {
  .metro-grid { grid-template-columns: repeat(6, 1fr); }
}
@media (max-width: 600px) {
  .metro-grid { grid-template-columns: repeat(2, 1fr); }
}

.tile {
  background: var(--c-tint);
  padding: var(--sp-8);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: all var(--dur) var(--ease);
  text-decoration: none;
  color: inherit;
}
.tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.tile h3, .tile h4 { color: inherit; margin-bottom: var(--sp-3); }
.tile-icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.15);
  margin-bottom: var(--sp-6);
}
.tile-icon svg { width: 28px; height: 28px; }
.tile-tag {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  opacity: 0.7;
  margin-bottom: var(--sp-3);
}
.tile p { line-height: 1.6; opacity: 0.9; }

/* Tile size variants */
.tile-1x1 { grid-column: span 3; }
.tile-1x2 { grid-column: span 3; grid-row: span 2; }
.tile-2x1 { grid-column: span 6; }
.tile-2x2 { grid-column: span 6; grid-row: span 2; }
.tile-3x1 { grid-column: span 9; }
.tile-4x1 { grid-column: span 12; }
@media (max-width: 900px) {
  .tile-1x1, .tile-1x2 { grid-column: span 3; }
  .tile-2x1, .tile-2x2 { grid-column: span 6; }
  .tile-3x1, .tile-4x1 { grid-column: span 6; }
}
@media (max-width: 600px) {
  .tile-1x1, .tile-1x2, .tile-2x1, .tile-2x2, .tile-3x1, .tile-4x1 { grid-column: span 2; grid-row: auto; }
}

/* Tile color variants */
.tile-teal  { background: var(--c-teal);     color: var(--c-white); }
.tile-ink   { background: var(--c-ink);      color: var(--c-white); }
.tile-lime  { background: var(--c-lime);     color: var(--c-ink); }
.tile-cream { background: var(--c-cream);    color: var(--c-ink); border: 1px solid var(--c-line); }
.tile-warm  { background: var(--tile-4);     color: var(--c-ink); }
.tile-indigo{ background: var(--tile-5);     color: var(--c-white); }
.tile-magenta{ background: var(--tile-6);    color: var(--c-white); }

.tile-num {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 700;
  line-height: 0.85;
  letter-spacing: -0.04em;
  margin-bottom: var(--sp-4);
}

/* ── 10. Flip Boxes ───────────────────────────────────────── */
.flipgrid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--sp-6);
}
.flipbox {
  perspective: 1200px;
  height: 320px;
}
.flipbox-inner {
  position: relative;
  width: 100%; height: 100%;
  transform-style: preserve-3d;
  transition: transform 700ms var(--ease);
}
.flipbox:hover .flipbox-inner { transform: rotateY(180deg); }
.flipbox-face {
  position: absolute; inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  display: flex; flex-direction: column;
  justify-content: center;
  padding: var(--sp-8);
}
.flipbox-front {
  background: var(--c-cream);
  border: 1px solid var(--c-line);
  align-items: flex-start;
}
.flipbox-front .icon {
  width: 64px; height: 64px;
  background: var(--c-teal);
  color: var(--c-white);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--sp-6);
}
.flipbox-front h4 { margin: 0; }
.flipbox-back {
  background: var(--c-ink);
  color: var(--c-white);
  transform: rotateY(180deg);
}
.flipbox-back h4 { color: var(--c-lime); margin-bottom: var(--sp-3); }
.flipbox-back p { color: rgba(255,255,255,0.85); }

/* ── 11. Roadmap (Interactive Tabs) ───────────────────────── */
.roadmap {
  background: var(--c-cream);
}
.roadmap-tabs {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--sp-12);
  align-items: stretch;
}
@media (max-width: 900px) { .roadmap-tabs { grid-template-columns: 1fr; } }

.tab-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column;
  gap: 4px;
}
.tab-btn {
  width: 100%;
  text-align: left;
  padding: var(--sp-6);
  background: var(--c-white);
  border-left: 4px solid transparent;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 600;
  color: var(--c-ink);
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  transition: all var(--dur) var(--ease);
}
.tab-btn:hover { background: var(--c-tint); }
.tab-btn.is-active {
  background: var(--c-ink);
  color: var(--c-white);
  border-left-color: var(--c-lime);
}
.tab-btn .phase-num {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  background: var(--c-lime);
  color: var(--c-ink);
  padding: 4px 10px;
  letter-spacing: 0.06em;
  font-weight: 500;
}
.tab-panel {
  display: none;
  background: var(--c-white);
  padding: clamp(2rem, 4vw, 3.5rem);
  border-top: 6px solid var(--c-teal);
}
.tab-panel.is-active { display: block; animation: fadeUp 500ms var(--ease); }
.tab-panel h3 { margin-bottom: var(--sp-4); }
.tab-panel ul { list-style: none; padding: 0; margin: var(--sp-6) 0 0; }
.tab-panel li {
  padding: var(--sp-3) 0;
  padding-left: var(--sp-8);
  border-bottom: 1px dashed var(--c-line);
  position: relative;
}
.tab-panel li::before {
  content: '';
  position: absolute;
  left: 0; top: 1.1rem;
  width: 20px; height: 2px;
  background: var(--c-teal);
}

@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

/* ── 12. Image + Content Box ─────────────────────────────── */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.split.reverse { direction: rtl; }
.split.reverse > * { direction: ltr; }
@media (max-width: 900px) { .split { grid-template-columns: 1fr; } }

.split-visual {
  position: relative;
  aspect-ratio: 4 / 5;
  background: var(--c-cream);
  overflow: hidden;
}
.split-visual::before {
  content: '';
  position: absolute;
  bottom: -30px; right: -30px;
  width: 120px; height: 120px;
  background: var(--c-lime);
  z-index: 1;
}
.split-visual::after {
  content: '';
  position: absolute;
  top: -20px; left: -20px;
  width: 80px; height: 80px;
  background: var(--c-teal);
  z-index: 1;
}
.split-visual .visual-stack {
  position: relative;
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--c-ink) 0%, #1a2a44 100%);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
}
.split-visual .visual-stack svg {
  width: 60%; max-width: 280px;
  color: var(--c-lime);
}

/* ── 13. Solutions / Industry cards ──────────────────────── */
.solution-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-6);
}
.solution-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  padding: var(--sp-8);
  position: relative;
  transition: all var(--dur) var(--ease);
  overflow: hidden;
}
.solution-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 4px;
  background: var(--c-teal);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-slow) var(--ease);
}
.solution-card:hover {
  border-color: var(--c-ink);
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}
.solution-card:hover::before { transform: scaleX(1); }
.solution-card .badge {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-teal-dark);
  margin-bottom: var(--sp-4);
}
.solution-card h4 { margin-bottom: var(--sp-3); }
.solution-card .arrow {
  margin-top: var(--sp-6);
  color: var(--c-ink);
  font-weight: 600;
  display: inline-flex; align-items: center; gap: var(--sp-2);
}

/* ── 14. Testimonials ────────────────────────────────────── */
.testimonial-track {
  position: relative;
  overflow: hidden;
  padding: var(--sp-4) 0;
}
.testimonial-rail {
  display: flex;
  gap: var(--sp-6);
  transition: transform var(--dur-slow) var(--ease);
}
.testimonial-card {
  flex: 0 0 calc((100% - var(--sp-6)) / 2);
  background: var(--c-white);
  border-left: 4px solid var(--c-lime);
  padding: var(--sp-8);
  box-shadow: var(--shadow-sm);
}
@media (max-width: 768px) { .testimonial-card { flex-basis: 100%; } 
    .header-topbar{display:none !important;}
}
.testimonial-card .quote-mark {
  font-family: var(--font-display);
  font-size: 4rem;
  color: var(--c-teal);
  line-height: 0.5;
  margin-bottom: var(--sp-4);
}
.testimonial-card blockquote {
  font-size: var(--fs-lg);
  line-height: 1.6;
  color: var(--c-charcoal);
  margin: 0 0 var(--sp-6);
}
.testimonial-meta {
  display: flex; align-items: center; gap: var(--sp-3);
  border-top: 1px solid var(--c-line);
  padding-top: var(--sp-4);
}
.testimonial-meta .avatar {
  width: 48px; height: 48px;
  background: var(--c-ink);
  color: var(--c-lime);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: 700;
}
.testimonial-meta .author { font-weight: 600; color: var(--c-ink); }
.testimonial-meta .role { font-size: var(--fs-sm); color: var(--c-muted); }

/* ── 15. FAQ Accordion ───────────────────────────────────── */
.faq-list {
  max-width: 880px;
  margin: 0 auto;
}
.faq-item {
  border-bottom: 1px solid var(--c-line);
}
.faq-q {
  width: 100%;
  text-align: left;
  padding: var(--sp-6) 0;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 600;
  color: var(--c-ink);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-4);
  transition: color var(--dur) var(--ease);
}
.faq-q:hover { color: var(--c-teal-dark); }
.faq-q .icon {
  width: 32px; height: 32px;
  flex-shrink: 0;
  background: var(--c-cream);
  display: flex; align-items: center; justify-content: center;
  position: relative;
  transition: all var(--dur) var(--ease);
}
.faq-q .icon::before, .faq-q .icon::after {
  content: '';
  position: absolute;
  background: var(--c-ink);
  transition: all var(--dur) var(--ease);
}
.faq-q .icon::before { width: 14px; height: 2px; }
.faq-q .icon::after { width: 2px; height: 14px; }
.faq-item.is-open .faq-q .icon { background: var(--c-lime); }
.faq-item.is-open .faq-q .icon::after { transform: scaleY(0); }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 500ms var(--ease);
}
.faq-item.is-open .faq-a { max-height: 600px; }
.faq-a-inner { padding-bottom: var(--sp-6); color: var(--c-slate); line-height: 1.75; }

/* ── 16. CTA Banner ──────────────────────────────────────── */
.cta-banner {
  background: var(--c-ink);
  color: var(--c-white);
  position: relative;
  overflow: hidden;
}
.cta-banner::before {
  content: '';
  position: absolute;
  top: -50%; right: -10%;
  width: 600px; height: 600px;
  background: radial-gradient(circle, var(--c-teal) 0%, transparent 60%);
  opacity: 0.4;
  z-index: 1;
}
.cta-banner::after {
  content: '';
  position: absolute;
  bottom: -40%; left: -10%;
  width: 500px; height: 500px;
  background: radial-gradient(circle, var(--c-lime) 0%, transparent 60%);
  opacity: 0.18;
  z-index: 1;
}
.cta-banner .container { position: relative; z-index: 2; }
.cta-banner-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--sp-12);
  align-items: center;
}
@media (max-width: 768px) { .cta-banner-grid { grid-template-columns: 1fr; } }
.cta-banner h2 { color: var(--c-white); }
.cta-banner h2 .accent { color: var(--c-lime); }
.cta-banner p { color: rgba(255,255,255,0.8); font-size: var(--fs-lg); }

/* ── 17. Contact Form ────────────────────────────────────── */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4) var(--sp-6);
}
@media (max-width: 600px) { .form-grid { grid-template-columns: 1fr; } }
.form-row { grid-column: 1 / -1; }

.form-field { display: flex; flex-direction: column; }
.form-field label {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--c-slate);
  margin-bottom: var(--sp-2);
  font-weight: 500;
}
.form-field input,
.form-field select,
.form-field textarea {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  padding: 0.95rem 1rem;
  background: var(--c-white);
  border: 1px solid var(--c-line);
  color: var(--c-ink);
  transition: all var(--dur) var(--ease);
  border-radius: 2px;
}
.form-field textarea { resize: vertical; min-height: 140px; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--c-teal);
  box-shadow: 0 0 0 4px rgba(13,175,170,0.12);
}
.form-consent {
  font-size: var(--fs-sm);
  color: var(--c-muted);
  display: flex; align-items: flex-start; gap: var(--sp-3);
}
.form-consent input { margin-top: 4px; }

.contact-section {
  background: var(--c-cream);
}
.contact-card {
  display: grid;
  grid-template-columns: minmax(320px, 0.85fr) 1fr;
  gap: 0;
  background: var(--c-white);
  border-top: 6px solid var(--c-teal);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  align-items: stretch;
}
.contact-card > *:not(.contact-aside) {
  padding: clamp(2rem, 4vw, 3.5rem);
}
@media (max-width: 900px) {
  .contact-card { grid-template-columns: 1fr; }
}
.contact-aside {
  background: var(--c-ink);
  color: var(--c-white);
  padding: clamp(2rem, 4vw, 3.5rem);
  height: 100%;
}
.contact-aside h3 { color: var(--c-white); margin-bottom: var(--sp-6); }
.contact-aside .info-row {
  display: flex; gap: var(--sp-4);
  padding: var(--sp-4) 0;
  border-top: 1px solid rgba(255,255,255,0.1);
  align-items: flex-start;
}
.contact-aside .info-row:first-of-type { border-top: 0; padding-top: 0; }
.contact-aside .info-row .ico {
  width: 40px; height: 40px;
  background: var(--c-teal);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.contact-aside .info-row .ico svg { width: 18px; height: 18px; color: var(--c-white); }
.contact-aside .info-row .lbl {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--c-lime);
  margin-bottom: 4px;
}
.contact-aside .info-row .val { color: var(--c-white); }

/* ── 18. Footer ──────────────────────────────────────────── */
.site-footer {
  background: var(--c-ink);
  color: rgba(255,255,255,0.75);
  padding-top: clamp(4rem, 6vw, 5rem);
}
.footer-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
  gap: var(--sp-8);
  padding-bottom: var(--sp-12);
}
@media (max-width: 900px) { .footer-top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 500px) { .footer-top { grid-template-columns: 1fr; } }

.footer-brand img { height: 64px; margin-bottom: var(--sp-4); }
.footer-brand p { color: rgba(255,255,255,0.7); font-size: var(--fs-sm); line-height: 1.7; }
.footer-col h5 {
  color: var(--c-lime);
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: var(--sp-4);
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: var(--sp-3); }
.footer-col a {
  color: rgba(255,255,255,0.7);
  font-size: var(--fs-sm);
  transition: all var(--dur-fast) var(--ease);
}
.footer-col a:hover { color: var(--c-lime); padding-left: 4px; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: var(--sp-6) 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-4);
  font-size: var(--fs-sm);
}
.footer-bottom .legal { color: rgba(255,255,255,0.5); }
.social-list { display: flex; gap: var(--sp-2); list-style: none; padding: 0; margin: 0; }
.social-list a {
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: center;
  transition: all var(--dur) var(--ease);
}
.social-list a:hover { background: var(--c-lime); color: var(--c-ink) !important; }
.social-list svg { width: 16px; height: 16px; }

/* ── 19. Reveal-on-scroll ────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(28px); transition: all 800ms var(--ease); }
.reveal.is-in { opacity: 1; transform: translateY(0); }
.reveal[data-delay="1"] { transition-delay: 100ms; }
.reveal[data-delay="2"] { transition-delay: 200ms; }
.reveal[data-delay="3"] { transition-delay: 300ms; }
.reveal[data-delay="4"] { transition-delay: 400ms; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* ── 20. Floating Quick CTA ──────────────────────────────── */
.quick-cta {
  position: fixed;
  bottom: 24px; right: 24px;
  z-index: 50;
  background: var(--c-teal);
  color: var(--c-white);
  padding: 0.85rem 1.4rem;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  box-shadow: var(--shadow-lg);
  font-weight: 600;
  font-size: var(--fs-sm);
  transition: all var(--dur) var(--ease);
}
.quick-cta:hover { background: var(--c-ink); color: var(--c-white); transform: translateY(-3px); }
.quick-cta svg { width: 18px; height: 18px; }
@media (max-width: 600px) { .quick-cta { padding: 0.75rem 1rem; bottom: 16px; right: 16px; } }

/* ── 21. Skip link (a11y) ────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -40px; left: 0;
  background: var(--c-ink);
  color: var(--c-lime);
  padding: 0.5rem 1rem;
  z-index: 1000;
  font-size: var(--fs-sm);
}
.skip-link:focus { top: 0; }

/* ── 22. Utility helpers ─────────────────────────────────── */
.text-teal { color: var(--c-teal-dark); }
.text-lime { color: var(--c-lime-dark); }
.bg-tint { background: var(--c-tint); }
.bg-cream { background: var(--c-cream); }
.bg-ink { background: var(--c-ink); color: var(--c-white); }
.text-center { text-align: center; }
.mt-0 { margin-top: 0; } .mb-0 { margin-bottom: 0; }
.mt-4 { margin-top: var(--sp-4); }
.mt-6 { margin-top: var(--sp-8); }
.mt-8 { margin-top: var(--sp-10); }
.mt-10 { margin-top: var(--sp-12); }
.mt-12 { margin-top: var(--sp-16); }
.mb-4 { margin-bottom: var(--sp-4); }
.mb-6 { margin-bottom: var(--sp-8); }
.mb-8 { margin-bottom: var(--sp-10); }
.divider { height: 4px; width: 56px; background: var(--c-lime); margin: var(--sp-4) 0; }

/* Form alert states */
.form-alert {
  padding: var(--sp-4) var(--sp-6);
  border-left: 4px solid;
  margin-bottom: var(--sp-6);
  font-size: var(--fs-sm);
}
.form-alert.success { background: #ECFDF5; border-color: #10B981; color: #047857; }
.form-alert.error   { background: #FEF2F2; border-color: #EF4444; color: #B91C1C; }

/* ── 23. Inner page elements (about/technology/solutions/etc) ───────────── */

/* Page hero — reused on all inner pages */
.page-hero {
  background: linear-gradient(135deg, var(--c-tint) 0%, var(--c-cream) 100%);
  padding: calc(var(--sp-12) + 80px) 0 var(--sp-12);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  top: -100px; right: -100px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(13,175,170,0.10) 0%, transparent 70%);
  pointer-events: none;
}
.page-hero::after {
  content: '';
  position: absolute;
  bottom: -120px; left: -100px;
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(168,224,85,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.page-hero-inner { max-width: 920px; position: relative; z-index: 1; }
.page-hero h1 {
  font-family: var(--ff-display);
  font-size: clamp(2.25rem, 4.6vw, 3.75rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: var(--sp-3) 0 var(--sp-5);
}
.page-hero .lead { max-width: 760px; }
.page-hero-breadcrumb {
  margin-top: var(--sp-6);
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-ink-soft);
}
.page-hero-breadcrumb a {
  color: var(--c-teal-dark);
  text-decoration: none;
  font-weight: 600;
}
.page-hero-breadcrumb a:hover { text-decoration: underline; }
.page-hero-breadcrumb span { margin: 0 0.4rem; opacity: 0.5; }

/* Section spacing variant */
section.tight { padding: var(--sp-10) 0; }

/* Section head variants */
.section-head.center { text-align: center; max-width: 760px; margin: 0 auto var(--sp-8); }

/* Industry quick nav (used on solutions) */
.industry-quicknav {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-3);
}
.iq-link {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--c-ink);
  transition: all 0.25s ease;
  position: relative;
}
.iq-link::after {
  content: '→';
  position: absolute;
  right: var(--sp-5);
  color: var(--c-teal);
  opacity: 0;
  transform: translateX(-8px);
  transition: all 0.25s ease;
  font-weight: 700;
}
.iq-link:hover {
  border-color: var(--c-teal);
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(10,22,40,0.08);
}
.iq-link:hover::after { opacity: 1; transform: translateX(0); }
.iq-link span {
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  color: var(--c-teal-dark);
  font-weight: 700;
  letter-spacing: 0.08em;
}
.iq-link strong {
  font-family: var(--ff-display);
  font-size: 1rem;
  font-weight: 600;
}

/* Leader / team grid */
.leader-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-5);
}
.leader-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  padding: var(--sp-6);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}
.leader-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--c-teal);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.35s ease;
}
.leader-card:hover { transform: translateY(-4px); border-color: var(--c-teal); box-shadow: 0 14px 32px rgba(10,22,40,0.08); }
.leader-card:hover::before { transform: scaleY(1); }
.leader-avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-teal) 0%, var(--c-lime) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-white);
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.4rem;
  margin-bottom: var(--sp-4);
}
.leader-card h4 {
  font-family: var(--ff-display);
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0 0 0.25rem;
}
.leader-role {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--c-teal-dark);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--sp-3);
}

/* Identity strip (about — mission/vision/values) */
.identity-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0;
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--c-white);
}
.identity-cell {
  padding: var(--sp-6);
  border-right: 1px solid var(--c-border);
}
.identity-cell:last-child { border-right: none; }
.identity-num {
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  color: var(--c-teal-dark);
  letter-spacing: 0.1em;
  font-weight: 700;
  display: block;
  margin-bottom: var(--sp-2);
}
.identity-lbl {
  font-family: var(--ff-display);
  font-size: 1.1rem;
  font-weight: 600;
}

/* Industry stat card */
.ind-stat-card {
  padding: var(--sp-6);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-top: 4px solid var(--c-teal);
  border-radius: var(--radius);
}
.ind-stat-card.lime { border-top-color: var(--c-lime-dark); }
.ind-stat-card.warm { border-top-color: var(--c-warm); }
.ind-stat-card.indigo { border-top-color: var(--c-indigo); }

/* Industry section card (numbered) — solutions page */
.isc-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--sp-6);
  padding: var(--sp-8) 0;
  border-bottom: 1px solid var(--c-border);
  align-items: start;
}
.isc-row:last-child { border-bottom: none; }
.isc-num {
  font-family: var(--ff-display);
  font-size: 3.25rem;
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(135deg, var(--c-teal) 0%, var(--c-lime-dark) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.isc-eyebrow {
  font-family: var(--ff-mono);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  color: var(--c-teal-dark);
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: var(--sp-2);
}
.isc-list {
  list-style: none;
  padding: 0;
  margin: var(--sp-4) 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-2);
}
.isc-list li {
  position: relative;
  padding-left: 22px;
  font-size: 0.95rem;
  color: var(--c-ink-soft);
  line-height: 1.55;
}
.isc-list li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--c-teal);
  font-weight: 700;
}

/* Process strip — used on technology */
.process-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sp-4);
  margin-top: var(--sp-6);
}
.process-step {
  padding: var(--sp-5);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  position: relative;
}
.process-step h4 {
  font-family: var(--ff-display);
  font-size: 1.05rem;
  margin: var(--sp-3) 0 var(--sp-2);
}
.process-step p { font-size: 0.92rem; color: var(--c-ink-soft); margin: 0; }
.ps-num, .phase-num {
  display: inline-block;
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--c-teal-dark);
  letter-spacing: 0.1em;
  font-weight: 700;
  padding: 4px 10px;
  background: var(--c-tint);
  border-radius: 2px;
}

/* Check list */
.check-list {
  list-style: none;
  padding: 0;
  margin: var(--sp-5) 0;
  display: grid;
  gap: var(--sp-3);
}
.check-list li {
  position: relative;
  padding-left: 32px;
  font-size: 0.98rem;
  color: var(--c-ink-soft);
  line-height: 1.6;
}
.check-list li::before {
  content: '';
  position: absolute;
  left: 0; top: 4px;
  width: 20px; height: 20px;
  background: var(--c-lime);
  border-radius: 50%;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path d='M5 10l3 3 7-7' stroke='%230A1628' stroke-width='2.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
}

/* Split section reverse variant */
.split.reverse > *:first-child { order: 2; }
.split.reverse > *:last-child { order: 1; }
@media (max-width: 768px) {
  .split.reverse > *:first-child { order: 1; }
  .split.reverse > *:last-child { order: 2; }
}

/* Generic accent text */
.accent { color: var(--c-teal-dark); font-weight: 600; }

/* Insights / blog cards */
.insights-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--sp-5);
}
.insight-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
}
.insight-card:hover {
  transform: translateY(-4px);
  border-color: var(--c-teal);
  box-shadow: 0 14px 32px rgba(10,22,40,0.08);
}
.insight-cover {
  height: 180px;
  background: linear-gradient(135deg, var(--c-teal) 0%, var(--c-ink) 100%);
  position: relative;
  overflow: hidden;
}
.insight-cover.cream { background: linear-gradient(135deg, var(--c-cream) 0%, #E8C7A8 100%); }
.insight-cover.lime  { background: linear-gradient(135deg, var(--c-lime) 0%, var(--c-teal) 100%); }
.insight-cover.indigo{ background: linear-gradient(135deg, var(--c-indigo) 0%, #4338CA 100%); }
.insight-cover.warm  { background: linear-gradient(135deg, var(--c-warm) 0%, #E07B39 100%); }
.insight-cover::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
}
.insight-body { padding: var(--sp-5); flex: 1; display: flex; flex-direction: column; }
.insight-meta {
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-teal-dark);
  margin-bottom: var(--sp-2);
  font-weight: 700;
}
.insight-card h3 {
  font-family: var(--ff-display);
  font-size: 1.2rem;
  line-height: 1.3;
  margin: 0 0 var(--sp-3);
}
.insight-card p { font-size: 0.92rem; color: var(--c-ink-soft); margin: 0 0 var(--sp-4); }
.insight-card a.read-more {
  margin-top: auto;
  font-family: var(--ff-mono);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: var(--c-teal-dark);
  text-decoration: none;
}
.insight-card a.read-more:hover { color: var(--c-ink); }

/* Careers — open roles list */
.role-list { display: grid; gap: var(--sp-3); margin-top: var(--sp-6); }
.role-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-4);
  align-items: center;
  padding: var(--sp-5) var(--sp-6);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  transition: all 0.25s ease;
}
.role-item:hover { border-color: var(--c-teal); transform: translateX(4px); }
.role-item h4 { font-family: var(--ff-display); font-size: 1.1rem; margin: 0 0 0.2rem; }
.role-meta {
  font-family: var(--ff-mono);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-ink-soft);
}
.role-meta span { color: var(--c-teal-dark); font-weight: 700; }

/* Value tiles (careers) */
.value-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-4);
}
.value-card {
  padding: var(--sp-5);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
}
.value-card .v-num {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--c-teal-dark);
  letter-spacing: 0.1em;
  font-weight: 700;
}
.value-card h4 {
  font-family: var(--ff-display);
  font-size: 1.1rem;
  margin: var(--sp-2) 0 var(--sp-2);
}
.value-card p { font-size: 0.92rem; color: var(--c-ink-soft); margin: 0; }

/* Partnership tracks */
.track-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-5);
}
.track-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.track-head {
  padding: var(--sp-6);
  background: var(--c-ink);
  color: var(--c-white);
  border-bottom: 4px solid var(--c-lime);
}
.track-head.teal  { background: var(--c-teal-dark); border-bottom-color: var(--c-lime); }
.track-head.warm  { background: var(--c-warm); border-bottom-color: var(--c-ink); }
.track-head h3 { font-family: var(--ff-display); font-size: 1.4rem; margin: 0; color: inherit; }
.track-head .t-tag {
  font-family: var(--ff-mono);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.85;
  display: block;
  margin-bottom: var(--sp-2);
}
.track-body { padding: var(--sp-6); flex: 1; display: flex; flex-direction: column; }
.track-body p { font-size: 0.96rem; color: var(--c-ink-soft); margin: 0 0 var(--sp-4); }
.track-body .btn { margin-top: auto; align-self: flex-start; }

/* Two-column textual block */
.two-col {
  columns: 2;
  column-gap: var(--sp-8);
}
.two-col p { break-inside: avoid; margin-bottom: var(--sp-4); }
@media (max-width: 768px) { .two-col { columns: 1; } }

/* 404 page */
.notfound-hero {
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: linear-gradient(135deg, var(--c-tint) 0%, var(--c-cream) 100%);
  padding: var(--sp-12) var(--sp-4);
}
.nf-code {
  font-family: var(--ff-display);
  font-size: clamp(6rem, 18vw, 12rem);
  font-weight: 900;
  line-height: 0.9;
  background: linear-gradient(135deg, var(--c-teal) 0%, var(--c-lime-dark) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.04em;
}

/* Legal page (privacy/terms/cookies) */
.legal-body {
  max-width: 820px;
  margin: 0 auto;
}
.legal-body h2 {
  font-family: var(--ff-display);
  font-size: 1.6rem;
  margin: var(--sp-8) 0 var(--sp-3);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--c-border);
}
.legal-body h3 { font-family: var(--ff-display); font-size: 1.15rem; margin: var(--sp-5) 0 var(--sp-2); }
.legal-body p, .legal-body ul, .legal-body ol { color: var(--c-ink-soft); line-height: 1.75; }
.legal-body ul, .legal-body ol { padding-left: var(--sp-5); margin: var(--sp-3) 0 var(--sp-4); }
.legal-body li { margin-bottom: var(--sp-2); }
.legal-meta {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-teal-dark);
  background: var(--c-tint);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius);
  display: inline-block;
  margin-bottom: var(--sp-6);
}

/* Contact page specific */
.contact-page-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--sp-8);
  align-items: start;
}
@media (max-width: 900px) { .contact-page-grid { grid-template-columns: 1fr; } }
.contact-info-card {
  background: var(--c-ink);
  color: var(--c-white);
  padding: var(--sp-7);
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
}
.contact-info-card::after {
  content: '';
  position: absolute;
  bottom: -60px; right: -60px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(168,224,85,0.15) 0%, transparent 70%);
}
.contact-info-card h3 { color: var(--c-white); font-family: var(--ff-display); }
.contact-info-card .ci-row {
  display: flex; align-items: flex-start; gap: var(--sp-3);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.contact-info-card .ci-row:last-of-type { border-bottom: none; }
.contact-info-card .ci-row .ci-icon {
  width: 36px; height: 36px;
  background: var(--c-teal);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--c-white);
}
.contact-info-card .ci-row strong { display: block; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--c-lime); margin-bottom: 4px; font-family: var(--ff-mono); }
.contact-info-card .ci-row a { color: var(--c-white); text-decoration: none; }
.contact-info-card .ci-row a:hover { color: var(--c-lime); }


/* Legal section / doc compatibility — used on privacy, terms, cookies */
.legal-section { padding: var(--sp-10) 0; }
.legal-doc {
  max-width: 820px;
  margin: 0 auto;
}
.legal-doc p, .legal-doc ul, .legal-doc ol { color: var(--c-ink-soft); line-height: 1.75; }
.legal-doc h2 {
  font-family: var(--ff-display);
  font-size: 1.6rem;
  margin: var(--sp-8) 0 var(--sp-3);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--c-border);
}
.legal-doc h3 { font-family: var(--ff-display); font-size: 1.15rem; margin: var(--sp-5) 0 var(--sp-2); }
.legal-doc ul, .legal-doc ol { padding-left: var(--sp-5); margin: var(--sp-3) 0 var(--sp-4); }
.legal-doc li { margin-bottom: var(--sp-2); color: var(--c-ink-soft); }
.legal-doc a { color: var(--c-teal-dark); }

/* 404 / error page */
.error-page {
  background: linear-gradient(135deg, var(--c-tint) 0%, var(--c-cream) 100%);
  padding: calc(var(--sp-12) + 80px) 0 var(--sp-12);
  min-height: 70vh;
  display: flex;
  align-items: center;
}
.error-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--sp-8);
  align-items: center;
}
@media (max-width: 900px) { .error-grid { grid-template-columns: 1fr; } }
.error-content h1 {
  font-family: var(--ff-display);
  font-size: clamp(2.25rem, 4.6vw, 3.75rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: var(--sp-3) 0 var(--sp-5);
}
.error-links { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--sp-2); }
.error-links a {
  font-family: var(--ff-mono);
  font-size: 0.9rem;
  color: var(--c-ink);
  text-decoration: none;
  padding: 0.4rem 0;
  display: inline-block;
}
.error-links a:hover { color: var(--c-teal-dark); }
.error-visual svg { width: 100%; height: auto; max-width: 420px; border-radius: var(--radius); display: block; margin-left: auto; }

/* ═══════════════════════════════════════════════════════════
   PAGE HERO (used by every inner page)
   ═══════════════════════════════════════════════════════════ */
.page-hero {
  background: linear-gradient(135deg, var(--c-cream) 0%, #FFFFFF 50%, var(--c-tint) 100%);
  padding: clamp(5rem, 10vw, 8rem) 0 clamp(3rem, 6vw, 5rem);
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  top: -100px; right: -100px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(13,175,170,0.15), transparent 70%);
  z-index: 0;
}
.page-hero::after {
  content: '';
  position: absolute;
  bottom: -200px; left: -100px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(168,224,85,0.18), transparent 70%);
  z-index: 0;
}
.page-hero-inner {
  position: relative; z-index: 2;
  max-width: 880px;
}
.page-hero h1 {
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: var(--sp-4) 0;
}
.page-hero-breadcrumb {
  margin-top: var(--sp-6);
  font-family: var(--ff-mono);
  font-size: var(--fs-sm);
  color: var(--c-muted);
  display: flex; gap: var(--sp-2); align-items: center;
}
.page-hero-breadcrumb a { color: var(--c-teal-dark); text-decoration: none; }
.page-hero-breadcrumb a:hover { color: var(--c-ink); }
.page-hero-breadcrumb span:not(:last-child) { color: var(--c-muted); }

/* ═══════════════════════════════════════════════════════════
   IDENTITY STRIP (about page)
   ═══════════════════════════════════════════════════════════ */
.identity-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-2);
  background: var(--c-white);
  border: 1px solid var(--c-line);
}
.identity-cell {
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
  border-right: 1px solid var(--c-line);
}
.identity-cell:last-child { border-right: none; }
.identity-num {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: var(--c-teal);
  line-height: 1;
  margin-bottom: var(--sp-2);
}
.identity-lbl {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--c-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
@media (max-width: 800px) {
  .identity-strip { grid-template-columns: repeat(2, 1fr); }
  .identity-cell:nth-child(2) { border-right: none; }
  .identity-cell:nth-child(1), .identity-cell:nth-child(2) { border-bottom: 1px solid var(--c-line); }
}

/* ═══════════════════════════════════════════════════════════
   VISION PILLARS
   ═══════════════════════════════════════════════════════════ */
.vision-pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  margin-top: var(--sp-12);
}
.vision-pillar {
  padding: var(--sp-8);
  background: rgba(255,255,255,0.04);
  border-left: 4px solid var(--c-lime);
}
.vision-pillar .vp-num {
  font-family: var(--ff-mono);
  font-size: 0.85rem;
  color: var(--c-lime);
  letter-spacing: 0.1em;
  margin-bottom: var(--sp-4);
}
.vision-pillar h4 { color: var(--c-white); margin-bottom: var(--sp-3); font-size: var(--fs-xl); }
.vision-pillar p { color: rgba(255,255,255,0.75); }
@media (max-width: 900px) { .vision-pillars { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   TIMELINE (about page history)
   ═══════════════════════════════════════════════════════════ */
.timeline {
  position: relative;
  padding-left: 80px;
}
.timeline::before {
  content: '';
  position: absolute;
  left: 30px; top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--c-teal), var(--c-lime));
}
.timeline-item {
  position: relative;
  padding: var(--sp-6) 0;
}
.timeline-item .tl-marker {
  position: absolute;
  left: -80px;
  top: var(--sp-6);
  width: 70px;
  display: flex; flex-direction: column; align-items: center;
}
.timeline-item .tl-marker::before {
  content: '';
  width: 16px; height: 16px;
  background: var(--c-lime);
  border: 4px solid var(--c-white);
  box-shadow: 0 0 0 2px var(--c-teal);
  position: absolute;
  left: 22px; top: 4px;
}
.timeline-item .tl-year {
  position: absolute;
  left: -80px; top: 30px;
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  background: var(--c-ink);
  color: var(--c-lime);
  padding: 4px 10px;
  letter-spacing: 0.08em;
}
.timeline-item .tl-content {
  background: var(--c-white);
  padding: var(--sp-6) var(--sp-8);
  border: 1px solid var(--c-line);
  border-left: 4px solid var(--c-teal);
}
.timeline-item .tl-content h4 { margin-bottom: var(--sp-3); }
@media (max-width: 700px) {
  .timeline { padding-left: 30px; }
  .timeline::before { left: 8px; }
  .timeline-item .tl-marker { left: -30px; width: auto; }
  .timeline-item .tl-marker::before { left: 0; }
  .timeline-item .tl-year { left: -30px; top: 50px; font-size: 0.7rem; }
}

/* ═══════════════════════════════════════════════════════════
   LEADER CARDS
   ═══════════════════════════════════════════════════════════ */
.leader-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-6);
}
.leader-card {
  background: var(--c-white);
  padding: var(--sp-8);
  border: 1px solid var(--c-line);
  transition: all 300ms var(--ease);
}
.leader-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--c-teal); }
.leader-avatar {
  width: 72px; height: 72px;
  background: var(--c-ink);
  color: var(--c-lime);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.4rem;
  margin-bottom: var(--sp-5);
}
.leader-card h4 { font-size: var(--fs-lg); margin-bottom: 4px; }
.leader-role {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--c-teal-dark);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--sp-4);
}
.leader-card p { color: var(--c-slate); font-size: var(--fs-sm); line-height: 1.65; }
@media (max-width: 1000px) { .leader-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .leader-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   CHECK LIST — see canonical definition above (line ~1469)
   ═══════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════
   INDUSTRY QUICK NAV (solutions page)
   ═══════════════════════════════════════════════════════════ */
.industry-quicknav {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-2);
}
.iq-link {
  background: var(--c-white);
  padding: var(--sp-6);
  text-decoration: none;
  color: var(--c-ink);
  border: 1px solid var(--c-line);
  display: flex; align-items: center; gap: var(--sp-4);
  transition: all 250ms var(--ease);
}
.iq-link:hover { background: var(--c-ink); color: var(--c-white); border-color: var(--c-ink); }
.iq-link span {
  font-family: var(--ff-mono);
  font-size: 0.85rem;
  color: var(--c-teal);
  font-weight: 500;
}
.iq-link:hover span { color: var(--c-lime); }
.iq-link strong { font-family: var(--ff-display); font-size: var(--fs-lg); }
@media (max-width: 900px) { .industry-quicknav { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .industry-quicknav { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   IND STAT CARD (solutions)
   ═══════════════════════════════════════════════════════════ */
.ind-stat-card {
  background: var(--c-ink);
  color: var(--c-white);
  padding: var(--sp-10);
}
.isc-eyebrow {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--c-lime);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: var(--sp-6);
}
.isc-list { display: flex; flex-direction: column; gap: var(--sp-5); }
.isc-row { display: flex; gap: var(--sp-5); }
.isc-num {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--c-lime);
  flex-shrink: 0;
  width: 40px;
}
.isc-row strong { display: block; color: var(--c-white); margin-bottom: 4px; }
.isc-row span { color: rgba(255,255,255,0.7); font-size: var(--fs-sm); line-height: 1.6; }

/* ═══════════════════════════════════════════════════════════
   PROCESS STRIP
   ═══════════════════════════════════════════════════════════ */
.process-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-2);
  position: relative;
}
.process-strip::before {
  content: '';
  position: absolute;
  top: 28px; left: 8%; right: 8%;
  height: 2px;
  background: var(--c-teal);
  opacity: 0.3;
  z-index: 0;
}
.process-step {
  background: var(--c-white);
  padding: var(--sp-6);
  text-align: center;
  position: relative;
  z-index: 1;
  border: 1px solid var(--c-line);
}
.process-step .ps-num {
  width: 56px; height: 56px;
  background: var(--c-teal);
  color: var(--c-white);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 1.2rem;
  margin: 0 auto var(--sp-4);
}
.process-step h4 { font-size: var(--fs-base); margin-bottom: var(--sp-2); }
.process-step p { font-size: 0.85rem; color: var(--c-slate); line-height: 1.55; }
@media (max-width: 1100px) {
  .process-strip { grid-template-columns: repeat(3, 1fr); }
  .process-strip::before { display: none; }
}
@media (max-width: 700px) { .process-strip { grid-template-columns: repeat(2, 1fr); } }

/* Process strip variant for 6 steps (partnerships) */
section .process-strip:has(> *:nth-child(6)) {
  grid-template-columns: repeat(6, 1fr);
}
@media (max-width: 1200px) {
  section .process-strip:has(> *:nth-child(6)) { grid-template-columns: repeat(3, 1fr); }
}

/* ═══════════════════════════════════════════════════════════
   IP CARD
   ═══════════════════════════════════════════════════════════ */
.ip-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  padding: var(--sp-8);
}
.ip-header { margin-bottom: var(--sp-6); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--c-line); }
.ip-pill {
  display: inline-block;
  background: var(--c-teal);
  color: var(--c-white);
  padding: 4px 12px;
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
}
.ip-header h3 { margin: 0; font-size: var(--fs-2xl); }
.ip-row {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: var(--sp-6);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--c-line);
  color: var(--c-slate);
  font-size: var(--fs-sm);
}
.ip-row:last-of-type { border-bottom: none; }
.ip-row strong { color: var(--c-ink); flex-shrink: 0; min-width: 130px; }
.ip-row span { text-align: right; }

/* ═══════════════════════════════════════════════════════════
   R&D CARDS (innovation page)
   ═══════════════════════════════════════════════════════════ */
.rd-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
}
.rd-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  padding: var(--sp-8);
  transition: all 300ms var(--ease);
  position: relative;
  overflow: hidden;
}
.rd-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--c-teal);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 350ms var(--ease);
}
.rd-card:hover::before { transform: scaleX(1); }
.rd-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.rd-num {
  font-family: var(--ff-mono);
  font-size: 0.85rem;
  color: var(--c-teal);
  letter-spacing: 0.1em;
  margin-bottom: var(--sp-4);
}
.rd-card h4 { margin-bottom: var(--sp-3); }
.rd-card p { color: var(--c-slate); line-height: 1.65; font-size: var(--fs-sm); }
@media (max-width: 1000px) { .rd-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .rd-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   FILTER PILLS (insights)
   ═══════════════════════════════════════════════════════════ */
.filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: center;
}
.pill {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  padding: 10px 22px;
  font-family: var(--ff-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-ink);
  cursor: pointer;
  transition: all 200ms var(--ease);
}
.pill:hover { border-color: var(--c-teal); color: var(--c-teal-dark); }
.pill.is-active { background: var(--c-ink); border-color: var(--c-ink); color: var(--c-white); }

/* ═══════════════════════════════════════════════════════════
   FEATURED INSIGHT
   ═══════════════════════════════════════════════════════════ */
.featured-insight {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--c-white);
  border: 1px solid var(--c-line);
}
.featured-insight .fi-content { padding: var(--sp-12); }
.featured-insight .fi-meta {
  font-family: var(--ff-mono);
  font-size: var(--fs-sm);
  color: var(--c-muted);
  margin-top: var(--sp-4);
  display: flex; gap: var(--sp-3);
}
.fi-visual svg { width: 100%; height: 100%; display: block; }
@media (max-width: 900px) { .featured-insight { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   INSIGHT GRID (cards)
   ═══════════════════════════════════════════════════════════ */
.insight-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
}
.insight-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  display: flex; flex-direction: column;
  transition: all 300ms var(--ease);
}
.insight-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.ic-banner {
  height: 140px;
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: var(--sp-5);
}
.ic-cat {
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  background: rgba(0,0,0,0.18);
  padding: 4px 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.ic-emblem svg { width: 28px; height: 28px; opacity: 0.85; }
.ic-body { padding: var(--sp-6); flex: 1; display: flex; flex-direction: column; }
.ic-meta { font-family: var(--ff-mono); font-size: 0.75rem; color: var(--c-muted); margin-bottom: var(--sp-3); }
.insight-card h4 { font-size: var(--fs-lg); margin-bottom: var(--sp-3); line-height: 1.3; }
.insight-card p { color: var(--c-slate); font-size: var(--fs-sm); line-height: 1.6; flex: 1; }
.insight-card .btn-ghost { margin-top: var(--sp-4); }
@media (max-width: 1000px) { .insight-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .insight-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   NEWSLETTER CARD
   ═══════════════════════════════════════════════════════════ */
.newsletter-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-12);
  align-items: center;
}
.newsletter-form {
  display: flex;
  gap: var(--sp-3);
  position: relative;
}
.newsletter-form input[type="email"] {
  flex: 1;
  padding: 18px 22px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.2);
  color: var(--c-white);
  font-family: var(--ff-body);
  font-size: var(--fs-base);
}
.newsletter-form input[type="email"]:focus {
  outline: none;
  border-color: var(--c-lime);
  background: rgba(255,255,255,0.1);
}
.newsletter-form input[type="email"]::placeholder { color: rgba(255,255,255,0.4); }
@media (max-width: 900px) {
  .newsletter-card { grid-template-columns: 1fr; }
  .newsletter-form { flex-direction: column; }
}

/* ═══════════════════════════════════════════════════════════
   JOB LIST
   ═══════════════════════════════════════════════════════════ */
.job-list { display: flex; flex-direction: column; }
.job-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-6) var(--sp-8);
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-bottom: none;
  transition: all 200ms var(--ease);
}
.job-row:last-child { border-bottom: 1px solid var(--c-line); }
.job-row:hover { background: var(--c-cream); border-color: var(--c-teal); }
.job-left h4 { margin: 0 0 6px; font-size: var(--fs-xl); }
.job-meta {
  display: flex; gap: var(--sp-3);
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  color: var(--c-muted);
  flex-wrap: wrap;
}
.job-team { color: var(--c-teal-dark); font-weight: 500; }
@media (max-width: 700px) {
  .job-row { flex-direction: column; align-items: flex-start; gap: var(--sp-4); }
  .job-right { align-self: stretch; }
  .job-right a { width: 100%; text-align: center; }
}

/* ═══════════════════════════════════════════════════════════
   BENEFITS GRID
   ═══════════════════════════════════════════════════════════ */
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
}
.benefit {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  padding: var(--sp-6) var(--sp-8);
  border-left: 4px solid var(--c-lime);
}
.benefit strong { display: block; font-family: var(--ff-display); font-size: var(--fs-lg); margin-bottom: 6px; }
.benefit span { color: var(--c-slate); font-size: var(--fs-sm); line-height: 1.55; }
@media (max-width: 900px) { .benefits-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .benefits-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   CONTACT METHODS (contact page)
   ═══════════════════════════════════════════════════════════ */
.contact-methods {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
}
.cm-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  padding: var(--sp-8);
  text-decoration: none;
  color: var(--c-ink);
  text-align: center;
  transition: all 250ms var(--ease);
}
.cm-card:hover { background: var(--c-ink); color: var(--c-white); border-color: var(--c-ink); transform: translateY(-3px); }
.cm-card:hover .cm-label { color: var(--c-lime); }
.cm-icon {
  width: 56px; height: 56px;
  background: var(--c-teal);
  color: var(--c-white);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--sp-4);
}
.cm-icon svg { width: 24px; height: 24px; }
.cm-label {
  font-family: var(--ff-mono);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-muted);
  margin-bottom: 6px;
  transition: color 200ms;
}
.cm-value { font-family: var(--ff-display); font-size: var(--fs-lg); font-weight: 600; }
@media (max-width: 800px) { .contact-methods { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   CONTACT META LIST
   ═══════════════════════════════════════════════════════════ */
.contact-meta-list {
  margin-top: var(--sp-8);
  display: flex; flex-direction: column; gap: var(--sp-2);
}
.cml-item {
  background: var(--c-white);
  padding: var(--sp-4) var(--sp-5);
  border: 1px solid var(--c-line);
  border-left: 3px solid var(--c-teal);
}
.cml-item strong { display: block; color: var(--c-ink); font-size: var(--fs-base); margin-bottom: 2px; }
.cml-item span { color: var(--c-slate); font-size: 0.85rem; }

/* ═══════════════════════════════════════════════════════════
   MAP BLOCK
   ═══════════════════════════════════════════════════════════ */
.map-block {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  background: var(--c-white);
  border: 1px solid var(--c-line);
}
.map-info { padding: var(--sp-12); }
.map-info p { color: var(--c-slate); line-height: 1.7; margin-top: var(--sp-3); }
.map-visual { background: var(--c-ink); }
.map-visual svg { width: 100%; height: 100%; display: block; }
@media (max-width: 900px) {
  .map-block { grid-template-columns: 1fr; }
  .map-visual { aspect-ratio: 16 / 9; }
}

/* ═══════════════════════════════════════════════════════════
   ERROR PAGE (404)
   ═══════════════════════════════════════════════════════════ */
.error-page { padding: clamp(4rem, 10vw, 8rem) 0; min-height: 70vh; display: flex; align-items: center; }
.error-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp-12);
  align-items: center;
}
.error-content h1 { font-size: clamp(2.5rem, 5vw, 4rem); margin: var(--sp-3) 0; }
.error-links { list-style: none; padding: 0; }
.error-links li { padding: 6px 0; }
.error-links a { color: var(--c-teal-dark); text-decoration: none; font-weight: 500; }
.error-links a:hover { color: var(--c-ink); }
@media (max-width: 900px) { .error-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   LEGAL DOC
   ═══════════════════════════════════════════════════════════ */
.legal-section { padding: clamp(3rem, 6vw, 5rem) 0; }
.legal-doc { background: var(--c-white); border: 1px solid var(--c-line); padding: clamp(2rem, 5vw, 4rem); }
.legal-doc h2 { margin-top: var(--sp-10); margin-bottom: var(--sp-4); font-size: var(--fs-2xl); }
.legal-doc h2:first-of-type { margin-top: var(--sp-6); }
.legal-doc h3 { margin-top: var(--sp-6); margin-bottom: var(--sp-3); font-size: var(--fs-lg); color: var(--c-teal-dark); }
.legal-doc p { color: var(--c-slate); line-height: 1.75; margin-bottom: var(--sp-4); }
.legal-doc ul { padding-left: var(--sp-6); margin-bottom: var(--sp-4); color: var(--c-slate); line-height: 1.75; }
.legal-doc li { margin-bottom: var(--sp-2); }
.legal-doc a { color: var(--c-teal-dark); }
.legal-doc a:hover { color: var(--c-ink); }

/* ── 24. Contact page specifics ──────────────────────────── */
.contact-methods {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-4);
}
.cm-card {
  display: block;
  padding: var(--sp-6);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--c-ink);
  text-align: center;
  transition: all 0.25s ease;
}
.cm-card:hover {
  border-color: var(--c-teal);
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(10,22,40,0.08);
}
.cm-icon {
  width: 56px; height: 56px;
  margin: 0 auto var(--sp-3);
  background: var(--c-tint);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--c-teal-dark);
}
.cm-icon svg { width: 24px; height: 24px; }
.cm-label {
  font-family: var(--ff-mono);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-ink-soft);
  margin-bottom: 0.4rem;
}
.cm-value {
  font-family: var(--ff-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--c-ink);
}

/* Contact page meta list */
.contact-meta-list {
  display: grid;
  gap: var(--sp-3);
  margin-top: var(--sp-6);
}
.cml-item {
  padding: var(--sp-3) var(--sp-4);
  background: var(--c-white);
  border-left: 3px solid var(--c-teal);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.cml-item strong {
  display: block;
  font-family: var(--ff-display);
  font-size: 1rem;
  margin-bottom: 0.2rem;
}
.cml-item span {
  font-size: 0.88rem;
  color: var(--c-ink-soft);
}

/* Contact aside info rows */
.contact-aside .info-row {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-start;
  padding: var(--sp-4) 0;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.contact-aside .info-row:last-child { border-bottom: none; }
.contact-aside .info-row .ico {
  width: 36px; height: 36px;
  background: var(--c-teal);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--c-white);
}
.contact-aside .info-row .ico svg { width: 16px; height: 16px; }
.contact-aside .info-row .lbl {
  display: block;
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-lime);
  margin-bottom: 2px;
  font-weight: 700;
}
.contact-aside .info-row .val {
  display: block;
  font-size: 0.96rem;
  color: var(--c-white);
}

/* Map block */
.map-block {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--sp-7);
  align-items: center;
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  overflow: hidden;
}
@media (max-width: 900px) { .map-block { grid-template-columns: 1fr; } }
.map-info { padding: var(--sp-7); }
.map-info h3 { font-family: var(--ff-display); font-size: 1.7rem; margin: var(--sp-2) 0 var(--sp-3); }
.map-visual svg { width: 100%; height: auto; display: block; }

/* ── 25. Insights / blog page specifics ──────────────────── */
.featured-insight {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: var(--sp-8);
}
@media (max-width: 900px) { .featured-insight { grid-template-columns: 1fr; } }
.fi-visual {
  background: linear-gradient(135deg, var(--c-teal) 0%, var(--c-ink) 100%);
  min-height: 320px;
  position: relative;
  overflow: hidden;
}
.fi-visual::after {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
}
.fi-content { padding: var(--sp-8); display: flex; flex-direction: column; justify-content: center; }
.fi-meta {
  font-family: var(--ff-mono);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-teal-dark);
  font-weight: 700;
  margin-bottom: var(--sp-3);
}
.fi-content h2 {
  font-family: var(--ff-display);
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  line-height: 1.15;
  margin: 0 0 var(--sp-4);
}

/* Filter pills */
.filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
}
.pill {
  padding: 0.5rem 1.1rem;
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: 100px;
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--c-ink-soft);
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
}
.pill:hover { border-color: var(--c-teal); color: var(--c-ink); }
.pill.is-active {
  background: var(--c-ink);
  color: var(--c-lime);
  border-color: var(--c-ink);
}

/* Insight grid (alt to insights-grid) */
.insight-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--sp-5);
}
.insight-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
}
.insight-card:hover {
  transform: translateY(-4px);
  border-color: var(--c-teal);
  box-shadow: 0 14px 32px rgba(10,22,40,0.08);
}
.ic-banner {
  height: 160px;
  background: linear-gradient(135deg, var(--c-teal) 0%, var(--c-ink) 100%);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ic-banner.cream  { background: linear-gradient(135deg, var(--c-cream) 0%, #E8C7A8 100%); }
.ic-banner.lime   { background: linear-gradient(135deg, var(--c-lime) 0%, var(--c-teal) 100%); }
.ic-banner.warm   { background: linear-gradient(135deg, var(--c-warm) 0%, #E07B39 100%); }
.ic-banner.indigo { background: linear-gradient(135deg, var(--c-indigo) 0%, #4338CA 100%); }
.ic-banner.magenta{ background: linear-gradient(135deg, var(--c-magenta) 0%, #BE185D 100%); }
.ic-banner.ink    { background: linear-gradient(135deg, var(--c-ink) 0%, #1F2937 100%); }
.ic-banner::after {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 22px 22px;
}
.ic-emblem {
  font-family: var(--ff-display);
  font-size: 3.6rem;
  font-weight: 800;
  color: rgba(255,255,255,0.92);
  position: relative;
  z-index: 1;
}
.ic-banner.cream .ic-emblem { color: var(--c-ink); }
.ic-body { padding: var(--sp-5); flex: 1; display: flex; flex-direction: column; }
.ic-cat {
  font-family: var(--ff-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-teal-dark);
  font-weight: 700;
  margin-bottom: var(--sp-2);
}
.ic-meta {
  margin-top: auto;
  font-family: var(--ff-mono);
  font-size: 0.74rem;
  color: var(--c-ink-soft);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--c-border);
}

/* Newsletter card */
.newsletter-card {
  background: var(--c-ink);
  color: var(--c-white);
  padding: var(--sp-8);
  border-radius: var(--radius);
  margin-top: var(--sp-10);
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
  align-items: center;
}
@media (max-width: 768px) { .newsletter-card { grid-template-columns: 1fr; } }
.newsletter-card::after {
  content: '';
  position: absolute;
  bottom: -100px; right: -100px;
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(168,224,85,0.15) 0%, transparent 70%);
}
.newsletter-card h3 { color: var(--c-white); font-family: var(--ff-display); font-size: 1.6rem; margin: 0 0 var(--sp-3); }
.newsletter-card p { color: rgba(255,255,255,0.78); margin: 0; }
.newsletter-form {
  display: flex;
  gap: var(--sp-2);
  position: relative;
  z-index: 1;
}
.newsletter-form input[type=email] {
  flex: 1;
  padding: 0.85rem 1rem;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius);
  color: var(--c-white);
  font-family: var(--ff-body);
  font-size: 0.95rem;
}
.newsletter-form input[type=email]::placeholder { color: rgba(255,255,255,0.5); }
.newsletter-form input[type=email]:focus { outline: none; border-color: var(--c-lime); background: rgba(255,255,255,0.14); }

/* ── 26. Innovation page specifics ───────────────────────── */
.rd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--sp-5);
}
.rd-card {
  padding: var(--sp-6);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}
.rd-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-teal) 0%, var(--c-lime) 100%);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
.rd-card:hover { transform: translateY(-4px); border-color: var(--c-teal); box-shadow: 0 14px 32px rgba(10,22,40,0.08); }
.rd-card:hover::before { transform: scaleX(1); }
.rd-num {
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  font-weight: 700;
  color: var(--c-teal-dark);
  display: block;
  margin-bottom: var(--sp-2);
}
.rd-card h4 {
  font-family: var(--ff-display);
  font-size: 1.2rem;
  margin: 0 0 var(--sp-3);
}
.rd-card p {
  font-size: 0.95rem;
  color: var(--c-ink-soft);
  margin: 0;
  line-height: 1.6;
}

/* IP card / pill (innovation page) */
.ip-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  padding: var(--sp-6);
  display: grid;
  gap: var(--sp-4);
}
.ip-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.ip-header h4 { font-family: var(--ff-display); font-size: 1.15rem; margin: 0; }
.ip-pill {
  font-family: var(--ff-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
  padding: 4px 10px;
  background: var(--c-tint);
  color: var(--c-teal-dark);
  border-radius: 2px;
}
.ip-pill.lime { background: rgba(168,224,85,0.18); color: #5C8D17; }
.ip-pill.warm { background: rgba(244,162,97,0.2); color: #B7572A; }
.ip-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--c-border);
  font-size: 0.92rem;
}
.ip-row:last-child { border-bottom: none; }
.ip-row strong { font-family: var(--ff-mono); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--c-ink-soft); font-weight: 700; }
.ip-row span { font-family: var(--ff-display); font-weight: 600; color: var(--c-ink); }

/* Visual stack helper */
.visual-stack {
  display: grid;
  gap: var(--sp-3);
  position: relative;
}