/* ==========================================================================
   The Talent People — site.css
   Single global stylesheet. Mobile-first, design-token driven.
   Components are grouped by role: base, utilities, layout primitives,
   then page sections (hero, journey, platform, proof, data, roundtable,
   insights, closing, footer).
   ========================================================================== */

/* -------- FONTS (self-hosted) ------------------------------------------- */
@font-face{font-family:'Gilroy';src:url('/assets/fonts/Gilroy-Light.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/assets/fonts/Gilroy-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/assets/fonts/Gilroy-Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/assets/fonts/Gilroy-Bold.ttf') format('truetype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/assets/fonts/Gilroy-BoldItalic.ttf') format('truetype');font-weight:700;font-style:italic;font-display:swap}
@font-face{font-family:'JetBrains Mono';src:url('/assets/fonts/JetBrainsMono-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'JetBrains Mono';src:url('/assets/fonts/JetBrainsMono-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}

/* -------- DESIGN TOKENS -------------------------------------------------- */
:root{
  --ink:#323442;
  --ink-2:#23242E;
  --ink-3:#4A5A72;
  --ink-4:#8592A3;
  --paper:#F5F1EA;
  --paper-2:#EEE7DB;
  --paper-3:#E3DBCB;
  --sage:#D8DED1;
  --sage-2:#C4CDB7;
  --coral:#EF558B;
  --coral-deep:#EF558B;
  --white:#FFFFFF;
  --hair:rgba(14,27,44,.12);
  --hair-strong:rgba(14,27,44,.22);

  --sans:'Gilroy','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --serif:'Gilroy',-apple-system,BlinkMacSystemFont,sans-serif;
  --serif-italic:'Gilroy',-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  --maxw:1440px;
  --gutter:48px;
  --section-y:clamp(88px,10vw,124px);
  --section-y-lg:clamp(104px,12vw,144px);
  --head-gap:clamp(40px,5vw,64px);

  --fs-h1:clamp(36px,4vw,60px);
  --fs-h2:clamp(28px,3vw,42px);
  --fs-h3:clamp(22px,1.8vw,30px);
  --fs-h4:clamp(20px,1.6vw,24px);
  --fs-h5:18px;
  --fs-h6:16px;
  --fs-hero:clamp(38px,4.4vw,64px);
  --fs-hero-sub:16.5px;
}

/* -------- BASE ----------------------------------------------------------- */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html.has-smooth-scroll{scroll-behavior:auto}
html.has-smooth-scroll,
html.has-smooth-scroll body{height:auto}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
  font-size:16px;
  line-height:1.5;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4,h5,h6{font-family:var(--sans);font-weight:700;line-height:1.08;letter-spacing:-.015em}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
h4{font-size:var(--fs-h4)}
h5{font-size:var(--fs-h5)}
h6{font-size:var(--fs-h6)}

/* Visible focus for keyboard users (a11y baseline) */
:focus-visible{outline:2px solid var(--coral);outline-offset:2px;border-radius:4px}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
}

/* -------- UTILITIES ------------------------------------------------------ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-3);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--ink);display:inline-block;flex-shrink:0}
.eyebrow.coral{color:var(--coral-deep)}
.eyebrow.coral::before{background:var(--coral)}
.eyebrow.light{color:rgba(245,241,234,.72)}
.eyebrow.light::before{background:rgba(245,241,234,.5)}

/* -------- ICONS ---------------------------------------------------------
   Inline SVG icons rendered via CSS mask. Color follows currentColor, so
   you can place an icon anywhere text lives and it picks up the surrounding
   colour. Size via font-size or explicit width/height.

   Usage:  <span class="icon icon-arrow-right" aria-hidden="true"></span>
   Or:     <a class="btn btn-primary">Get in touch <span class="icon icon-arrow-right"></span></a>
   ------------------------------------------------------------------------ */
.icon{
  display:inline-block;
  width:1em;height:1em;
  background-color:currentColor;
  -webkit-mask:var(--icon) no-repeat center / contain;
          mask:var(--icon) no-repeat center / contain;
  vertical-align:-0.125em;
  flex-shrink:0;
}
.icon-arrow-right { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='black' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'><path d='M4 10h12m0 0-4-4m4 4-4 4'/></svg>"); }
.icon-arrow-down  { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='black' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'><path d='M10 4v12m0 0 4-4m-4 4-4-4'/></svg>"); }
.icon-arrow-up-right { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='black' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'><path d='M6 14 14 6m0 0H7m7 0v7'/></svg>"); }
.icon-check       { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m4 10 4 4 8-9'/></svg>"); }
.icon-marker      { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 12'><rect x='0' y='5' width='24' height='2' rx='1' fill='black'/></svg>"); width:24px;height:2px; }
.icon-dot         { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'><circle cx='4' cy='4' r='3' fill='black'/></svg>"); width:0.5em;height:0.5em; }
.icon-chevron-down { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10' fill='none' stroke='black' stroke-width='1.5' stroke-linecap='round'><path d='M2 4l3 3 3-3'/></svg>"); }
.icon-external    { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='black' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'><path d='M11 4h5v5M16 4 9 11M14 12v3a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V7a1 1 0 0 1 1-1h3'/></svg>"); }
.icon-mail        { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='black' stroke-width='1.5'><rect x='3' y='5' width='14' height='10' rx='1.5'/><path d='m3.5 6 6.5 5 6.5-5'/></svg>"); }
.icon-calendar    { --icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='black' stroke-width='1.5'><rect x='3' y='5' width='14' height='12' rx='1.5'/><path d='M3 9h14M7 3v4M13 3v4'/></svg>"); }

.display{
  font-family:var(--sans);
  font-weight:700;
  font-style:normal;
  letter-spacing:-.015em;
  line-height:1.06;
}
.display em{
  font-style:italic;font-weight:700;color:var(--coral-deep);
  font-family:var(--sans);
  letter-spacing:-.015em;
}
.section-subhead{margin:14px 0 32px;font-size:var(--fs-h2)}

/* -------- BUTTONS -------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  height:48px;padding:0 22px;border-radius:999px;
  font-weight:500;font-size:14px;letter-spacing:.01em;
  transition:all .2s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--coral-deep)}
.btn-primary .arr{background:var(--coral)}
.btn-secondary{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1px var(--hair-strong)}
.btn-secondary:hover{background:var(--ink);color:var(--paper)}
.btn .arr{
  width:22px;height:22px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(245,241,234,.16);color:var(--paper);
  transition:transform .2s ease;
}
.btn-secondary .arr{background:var(--ink);color:var(--paper)}
.btn:hover .arr{transform:translateX(3px)}

/* -------- TOP BAR -------------------------------------------------------- */
.topbar{
  background:var(--ink);color:var(--paper);
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;height:34px;color:rgba(245,241,234,.74)}
.topbar-inner .pill{display:inline-flex;align-items:center;gap:8px;color:var(--paper)}
.topbar-inner .pill .dot{width:6px;height:6px;border-radius:999px;background:var(--coral);box-shadow:0 0 0 4px rgba(255,107,74,.18)}
.topbar-right{display:flex;gap:22px;align-items:center}
.topbar-right a{display:inline-flex;align-items:center;gap:8px;color:rgba(245,241,234,.72)}
.topbar-right a:hover{color:var(--paper)}
.topbar-right a img{height:14px;width:auto;opacity:.9}

/* -------- PRIMARY NAV ---------------------------------------------------- */
nav.primary{
  position:sticky;top:0;z-index:50;
  background:rgba(245,241,234,.82);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--hair);
}
.nav-inner{display:flex;align-items:center;height:72px;gap:40px}
.logo{display:inline-flex;align-items:center}
.logo img{height:28px;width:auto;display:block}
.nav-links{display:flex;gap:4px;margin:0 0 0 12px;padding:0;list-style:none}
.nav-item{position:relative;display:flex;align-items:center}
.nav-link{
  padding:10px 14px;border-radius:999px;
  font-size:14px;font-weight:500;color:var(--ink-2);
  display:inline-flex;align-items:center;gap:6px;
  transition:background .15s;
  position:relative;
}
.nav-link:hover{background:rgba(14,27,44,.05)}
.nav-link .chev{width:10px;height:10px;opacity:.5;transition:transform .15s ease}

/* -------- NAV DROPDOWNS -- hover + keyboard focus-within -------------- */
.nav-dropdown{
  position:absolute;left:-8px;top:calc(100% + 4px);
  min-width:260px;padding:8px;
  background:var(--white);border-radius:12px;
  box-shadow:0 24px 48px -16px rgba(14,27,44,.28), inset 0 0 0 1px var(--hair);
  opacity:0;transform:translateY(-6px);pointer-events:none;visibility:hidden;
  transition:opacity .15s ease, transform .15s ease, visibility 0s linear .15s;
  z-index:60;
}
.nav-dropdown a{
  display:block;padding:9px 12px;border-radius:8px;
  font-size:13.5px;color:var(--ink-2);line-height:1.35;
  white-space:nowrap;
}
.nav-dropdown a:hover,
.nav-dropdown a:focus-visible{background:rgba(14,27,44,.05);color:var(--ink);outline:none}
.nav-item:hover > .nav-dropdown,
.nav-item:focus-within > .nav-dropdown{
  opacity:1;transform:translateY(0);pointer-events:auto;visibility:visible;
  transition:opacity .15s ease, transform .15s ease, visibility 0s linear 0s;
}
.nav-item:hover .chev,
.nav-item:focus-within .chev{transform:rotate(180deg)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-cta .btn{height:42px}
.search-btn{
  width:42px;height:42px;border-radius:999px;display:grid;place-items:center;
  box-shadow:inset 0 0 0 1px var(--hair);
}

/* -------- HERO ----------------------------------------------------------- */
.hero{
  --hero-y:0px;
  position:relative;
  min-height:100vh;
  min-height:100dvh;
  padding:clamp(48px,8vh,96px) 0 clamp(112px,13vh,150px);
  overflow:hidden;
  display:flex;
  align-items:center;
  background:var(--paper);
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background:url('/assets/img/Photos/HeroHome.png')  center / cover no-repeat;
  transform:translate3d(0,var(--hero-y),0) scale(1.1);
  transform-origin:center;
}
.hero-grid{
  position:relative;
  z-index:1;
  display:grid;grid-template-columns:minmax(0,640px);gap:0;align-items:center;
  min-height:0;
  width:100%;
}
.hero-head{
  max-width:600px;
  padding:clamp(24px,4vw,44px);
  background:radial-gradient(ellipse at center,rgba(245,241,234,.84) 0%,rgba(245,241,234,.72) 48%,rgba(245,241,234,0) 76%);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.hero-head h1{margin:0;font-size:var(--fs-hero)}
.hero-head .kicker{display:flex;gap:14px;align-items:center;margin-bottom:28px}
.badge-social{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 12px 6px 6px;border-radius:999px;
  background:var(--white);box-shadow:inset 0 0 0 1px var(--hair);
  font-size:12.5px;color:var(--ink-3);
}
.badge-social .avs{display:flex}
.badge-social .av{
  width:24px;height:24px;border-radius:999px;
  box-shadow:0 0 0 2px var(--paper);
  margin-right:-8px;background:var(--sage);
  background-size:cover;background-position:center;
}
.hero-sub{margin:26px 0 0;max-width:46ch;font-size:var(--fs-hero-sub);line-height:1.62;color:var(--ink-2)}
.hero-actions{margin-top:30px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.hero-meta{
  margin:30px 0 0;padding:0;
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;
  max-width:500px;
  overflow:hidden;
  border-radius:8px;
  background:rgba(14,27,44,.12);
}
.hero-meta div{margin:0;padding:14px 16px;background:rgba(245,241,234,.42)}
.hero-meta .m-n{margin:0;font-family:var(--sans);font-weight:700;font-size:clamp(24px,2.2vw,32px);line-height:1;letter-spacing:-.015em}
.hero-meta .m-l{margin:7px 0 0;font-size:10.5px;color:var(--ink-3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em}

/* -------- LOGO STRIP ----------------------------------------------------- */
.logostrip{
  position:relative;
  z-index:3;
  width:min(calc(100% - 48px),calc(var(--maxw) - 64px));
  margin:clamp(-104px,-11vh,-72px) auto 0;
  padding:0;
  border:1px solid rgba(14,27,44,.1);
  border-radius:18px;
  background:rgba(245,241,234,.92);
  box-shadow:0 34px 90px -52px rgba(14,27,44,.55),0 1px 0 rgba(255,255,255,.72) inset;
  overflow:hidden;
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}
.logostrip-inner{
  width:100%;
  display:grid;
  grid-template-columns:minmax(190px,250px) minmax(0,1fr);
  gap:0;
  align-items:stretch;
}
.logostrip h5,
.logostrip-title{
  margin:0;
  padding:28px 30px;
  min-height:132px;
  display:flex;
  align-items:center;
  font-family:var(--mono);
  font-size:11px;
  line-height:1.55;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:rgba(245,241,234,.72);
  font-weight:500;
  background:var(--ink);
  border-right:1px solid rgba(245,241,234,.1);
}
.logo-marquee{
  overflow:hidden;
  min-width:0;
  position:relative;
  cursor:grab;
  touch-action:pan-y;
  user-select:none;
  padding:24px 0;
  background:linear-gradient(180deg,rgba(255,255,255,.62),rgba(255,255,255,.22));
}
.logo-marquee::before,
.logo-marquee::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  z-index:2;
  width:72px;
  pointer-events:none;
}
.logo-marquee::before{
  left:0;
  background:linear-gradient(90deg,var(--paper),rgba(245,241,234,0));
}
.logo-marquee::after{
  right:0;
  background:linear-gradient(270deg,var(--paper),rgba(245,241,234,0));
}
.logo-marquee.is-dragging{
  cursor:grabbing;
}
.logo-marquee-track{
  display:flex;
  width:max-content;
  will-change:transform;
}
.logo-marquee-set{
  display:flex;
  align-items:center;
  gap:16px;
  padding-right:16px;
  flex:0 0 auto;
}
.logo-marquee img{
  display:block;
  width:auto;
  max-width:210px;
  height:82px;
  object-fit:contain;
  flex:0 0 auto;
  pointer-events:none;
  padding:18px 24px;
  border-radius:12px;
  background:rgba(255,255,255,.88);
  box-shadow:inset 0 0 0 1px rgba(14,27,44,.08),0 14px 28px -24px rgba(14,27,44,.45);
  filter:saturate(.92) contrast(1.02);
}
.logo-marquee img[src*="tfl"]{height:82px;max-width:210px}
.logo-marquee img[src*="channel4"]{height:82px;max-width:126px;padding-left:30px;padding-right:30px}
.logo-marquee img[src*="dhl"]{height:82px}
.logo-marquee img[src*="johnLewis"]{height:82px}
.logo-marquee img[src*="scheniderElectric"]{height:82px;max-width:250px}

@keyframes logoMarqueeFallback{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
html:not(.js) .logo-marquee-track{
  animation:logoMarqueeFallback 32s linear infinite;
}
html:not(.js) .logo-marquee:hover .logo-marquee-track{
  animation-play-state:paused;
}

/* -------- SECTION HEAD --------------------------------------------------- */
.section{padding:var(--section-y) 0}
.section-head{
  display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,5vw,72px);align-items:end;
  margin-bottom:var(--head-gap);
}
.split-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(340px,.68fr);
  gap:16px clamp(40px,5vw,72px);
  align-items:start;
}
.split-head > :first-child{min-width:0}
.split-head > :last-child{min-width:0;justify-self:stretch;align-self:start}
.split-head .desc,
.split-head .p,
.split-head .closing-side,
.journey-desc{
  max-width:620px;
}
.section-head h2{margin:14px 0 0;font-size:var(--fs-h2)}
.section-head .desc{font-size:17px;line-height:1.55;color:var(--ink-2);max-width:560px}

/* -------- STATS (problem section) --------------------------------------- */
.stat-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  background:var(--hair);border-radius:12px;overflow:hidden;
  margin-top:48px;
}
.stat{background:var(--paper);padding:36px 32px;display:flex;flex-direction:column;gap:10px;min-height:220px;justify-content:space-between}
.stat .n{font-family:var(--sans);font-size:72px;line-height:.95;font-weight:700;letter-spacing:-.035em}
.stat .n sub{font-size:28px;vertical-align:baseline;margin-left:4px;color:var(--coral-deep);font-weight:700;font-style:italic}
.stat .l{color:var(--ink-3);max-width:280px;font-size:14px;line-height:1.45}
.stat .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--ink-3);text-transform:uppercase}

.signal-board,
.problem-diagnostic{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(.42fr,320px);
  gap:24px;
  align-items:stretch;
  margin-top:var(--head-gap);
}
.problem-panel{grid-column:2}
.problem-diagnostic .signal-loop{grid-column:1;grid-row:1}
.problem-panel{
  min-height:500px;
  background:var(--white);
  color:var(--ink);
  border-radius:14px;
  padding:34px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
  position:relative;
  box-shadow:inset 0 0 0 1px var(--hair);
}
.problem-panel::after{
  content:"";
  position:absolute;
  right:-64px;
  top:-64px;
  width:190px;
  height:190px;
  border-radius:999px;
  border:1px solid rgba(14,27,44,.1);
  box-shadow:0 0 0 36px rgba(14,27,44,.035),0 0 0 72px rgba(14,27,44,.02);
}
.problem-count{
  position:relative;
  z-index:1;
  font-family:var(--sans);
  font-weight:700;
  letter-spacing:-.04em;
  line-height:.9;
}
.problem-count span:first-child{font-size:clamp(72px,7vw,118px);color:var(--coral)}
.problem-count span:last-child{font-size:28px;color:var(--ink-4);margin-left:8px}
.problem-kicker{
  margin:0;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.problem-progress{
  height:2px;
  background:var(--hair);
  overflow:hidden;
  border-radius:999px;
}
.problem-progress span{
  display:block;
  width:100%;
  height:100%;
  background:var(--coral);
  transform:scaleX(.25);
  transform-origin:left center;
}
.problem-metric{
  position:relative;
  z-index:1;
  padding:24px 0;
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
}
.problem-metric .k{
  display:block;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.problem-metric .n{
  margin-top:14px;
  font-family:var(--sans);
  font-size:clamp(62px,7vw,104px);
  line-height:.86;
  font-weight:700;
  letter-spacing:-.045em;
}
.problem-metric .n sub{
  font-size:.36em;
  vertical-align:baseline;
  color:var(--coral-deep);
  font-style:italic;
  margin-left:4px;
}
.problem-metric p{
  margin:18px 0 0;
  max-width:30ch;
  color:var(--ink-2);
  font-weight:600;
  line-height:1.55;
}
.problem-impact{
  display:block;
  margin-top:18px;
  max-width:34ch;
  color:var(--ink-3);
  font-size:13.5px;
  line-height:1.55;
}
.problem-cta{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  border-radius:999px;
  padding:14px 16px 14px 20px;
  background:var(--ink);
  color:var(--paper);
  font-weight:700;
  font-size:13.5px;
}
.problem-cta:hover{background:var(--coral);color:var(--paper)}
.signal-loop{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:2px;
  background:var(--hair);
  border-radius:14px;
  overflow:hidden;
}
.signal-step{
  min-height:238px;
  background:var(--paper);
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
  opacity:.6;
  transition:opacity .25s,background .25s,box-shadow .25s,transform .25s;
}
.signal-step::after{
  content:"";
  position:absolute;
  right:24px;
  top:28px;
  width:42px;
  height:1px;
  background:var(--hair-strong);
}
.signal-step .step-no{
  display:inline-block;
  margin-right:10px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.08em;
  color:var(--coral-deep);
}
.signal-step .k{
  margin:0;
  font-family:var(--mono);
  font-size:11px;
  line-height:1.4;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-3);
  font-weight:500;
}
.signal-step h3{
  margin:auto 0 0;
  max-width:12ch;
  font-size:clamp(36px,4.7vw,72px);
  line-height:.92;
  letter-spacing:-.035em;
}
.signal-step p{
  margin:24px 0 0;
  max-width:26ch;
  color:var(--ink-3);
  font-size:18px;
  line-height:1.35;
}
.signal-step:hover,
.signal-step.is-active{
  opacity:1;
  box-shadow:inset 0 0 0 1px rgba(239,85,139,.45);
}
.signal-step.outcome{
  background:var(--ink);
  color:var(--paper);
}
.signal-step.outcome .k{color:rgba(245,241,234,.55)}
.signal-step.outcome p{color:rgba(245,241,234,.72)}
.signal-step.outcome::after{background:var(--coral)}

@media (min-width:901px){
  .problem-diagnostic .signal-loop{
    display:block;
    min-height:500px;
    align-self:center;
    background:transparent;
    border-radius:14px;
    overflow:visible;
    position:relative;
  }
  .problem-diagnostic .signal-step{
    position:absolute;
    inset:0;
    min-height:500px;
    display:flex;
    justify-content:center;
    border-radius:14px;
    box-shadow:inset 0 0 0 1px var(--hair);
    opacity:0;
    pointer-events:none;
  }
  .problem-diagnostic .signal-step.is-active{
    opacity:1;
    pointer-events:auto;
  }
}
.signal-metrics{
  display:grid;
  gap:2px;
  background:var(--hair);
  border-radius:14px;
  overflow:hidden;
}
.signal-metric{
  background:var(--paper);
  padding:26px 28px;
}
.signal-metric .k,
.data-hero-card .k{
  display:block;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.signal-metric .n{
  margin-top:14px;
  font-family:var(--sans);
  font-size:clamp(48px,5vw,78px);
  line-height:.88;
  font-weight:700;
  letter-spacing:-.035em;
}
.signal-metric .n sub{
  font-size:.38em;
  vertical-align:baseline;
  color:var(--coral-deep);
  font-style:italic;
  margin-left:4px;
}
.signal-metric p{
  margin:14px 0 0;
  color:var(--ink-3);
  font-size:13.5px;
  line-height:1.45;
}
.signal-metric.compact{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px 18px;
  align-items:end;
}
.signal-metric.compact .n{grid-column:2;grid-row:1 / span 2;font-size:46px;margin:0}
.signal-metric.compact p{margin:0}
.signal-cta{
  background:var(--coral);
  color:var(--paper);
  padding:22px 28px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.signal-cta:hover{background:var(--coral-deep)}

/* -------- JOURNEY -------------------------------------------------------- */
.journey{
  background:var(--ink);color:var(--paper);border-radius:0;overflow:hidden;
  margin:var(--section-y-lg) 0;max-width:none;
  min-height:100svh;
  padding:clamp(56px,8vh,88px) 0 clamp(24px,4vh,40px);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.journey-head,
.journey > .j-track{
  max-width:var(--maxw);
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--gutter);
  padding-right:var(--gutter);
}
.journey-head{width:100%}
.journey-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.68fr);gap:clamp(40px,5vw,72px);align-items:end}
.journey-head .eyebrow{display:flex}
.journey h2{margin-top:16px;margin-bottom:0;font-size:var(--fs-h2);max-width:820px}
.journey .display em{color:var(--coral)}
.journey-desc{margin:0;max-width:600px;color:rgba(245,241,234,.72);font-size:16px;line-height:1.55}
.j-viewport{
  margin-top:clamp(44px,6vh,68px);
  width:100%;
  overflow:hidden;
  padding-left:max(var(--gutter),calc((100vw - var(--maxw)) / 2 + var(--gutter)));
}
.j-grid{
  display:flex;
  gap:28px;
  width:max-content;
  background:transparent;
  border-radius:0;
  overflow:visible;
  will-change:transform;
}
.j-card{
  flex:0 0 clamp(520px,68vw,860px);
  background:var(--ink);padding:44px 42px 38px;min-height:430px;
  display:flex;flex-direction:column;gap:18px;
  position:relative;transition:background .25s,opacity .25s,transform .25s;
  border-radius:16px;
  opacity:.58;
  visibility:visible;
  box-shadow:inset 0 0 0 1px rgba(245,241,234,.14);
}
.j-card:hover,
.j-card.is-active{background:var(--ink-2);opacity:1}
.j-card.is-active{box-shadow:inset 0 0 0 1px rgba(239,85,139,.58)}
.j-card .stage{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:rgba(245,241,234,.5);text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;
}
.j-card .stage .age{color:var(--coral)}
.j-card .prod{font-family:var(--sans);font-size:32px;line-height:1;font-weight:700;margin:16px 0 0;letter-spacing:-.025em}
.j-media{
  overflow:hidden;
  border-radius:12px;
  aspect-ratio:16 / 9;
  background:rgba(245,241,234,.06);
  box-shadow:inset 0 0 0 1px rgba(245,241,234,.12);
}
.j-media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}
.j-card p{margin:0;color:rgba(245,241,234,.72);font-size:17px;line-height:1.55;max-width:52ch}
.j-card .foot{margin-top:auto;display:flex;justify-content:space-between;align-items:flex-end;padding-top:22px;border-top:1px solid rgba(245,241,234,.12)}
.j-card .foot .lk{font-size:13px;color:var(--paper);display:inline-flex;align-items:center;gap:8px}
.j-card .num{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:rgba(245,241,234,.5)}
.j-track{
  margin-top:clamp(28px,4vh,44px);padding-top:18px;padding-bottom:10px;display:flex;align-items:center;gap:16px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,241,234,.5);
}
.j-track .line{flex:1;height:1px;background:rgba(245,241,234,.14);position:relative}
.j-track .line::after{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:var(--journey-progress,25%);height:1px;background:var(--coral);
}

/* -------- PLATFORM ------------------------------------------------------- */
.platform-section{
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
}
.plat-head{margin-bottom:var(--head-gap)}
.plat-head h2{margin:14px 0 0;font-size:var(--fs-h2)}
.platform-intro{
  align-self:stretch;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:18px;
}
.platform-intro p{
  margin:0;
  color:var(--ink-2);
  font-size:16px;
  line-height:1.6;
  max-width:620px;
}
.platform-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.platform-actions .btn{min-height:42px}
.platform-actions .btn.ghost{background:var(--white)}
.plat-head .ls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.tab{
  padding:8px 14px;border-radius:999px;font-size:12.5px;font-weight:500;
  box-shadow:inset 0 0 0 1px var(--hair);color:var(--ink-2);
  background:rgba(255,255,255,.55);
  transition:all .15s;
}
.tab.on{background:var(--ink);color:var(--paper);box-shadow:none}
.tab:hover:not(.on){background:rgba(14,27,44,.05)}

.platform-showcase{
  min-height:clamp(620px,78vh,820px);
  display:grid;
  grid-template-columns:minmax(320px,.72fr) minmax(0,1.28fr);
  gap:clamp(32px,4vw,64px);
  align-items:stretch;
  position:relative;
}
.platform-step-list{
  position:relative;
  width:100%;
  height:100%;
  min-height:clamp(520px,58vh,620px);
  align-self:stretch;
  border-radius:18px;
  background:var(--ink);
  color:var(--paper);
  box-shadow:0 34px 90px -54px rgba(14,27,44,.58);
  overflow:hidden;
}
.platform-step{
  position:absolute;
  inset:0;
  padding:clamp(28px,3.4vw,48px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:18px;
  opacity:0;
  visibility:hidden;
  transform:translateY(24px);
  clip-path:inset(18% 0 18% 0);
}
.platform-step.is-active{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  clip-path:inset(0 0 0 0);
}
.platform-step .step-k{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--coral);
}
.platform-step h3{
  margin:0;
  max-width:16ch;
  font-size:var(--fs-h3);
  line-height:1.08;
  letter-spacing:-.015em;
}
.platform-step h3 em,
.platform-step h3 strong{color:var(--coral)}
.platform-step p{
  margin:0;
  max-width:44ch;
  color:rgba(245,241,234,.72);
  font-size:16.5px;
  line-height:1.6;
}
.platform-step .lk.strong{
  width:max-content;
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:4px;
  font-weight:700;
  color:var(--paper);
}
.platform-step-shot{display:none}
.platform-visual-stage{
  min-height:clamp(420px,58vh,620px);
  position:relative;
  align-self:center;
  border-radius:0;
  background:transparent;
  overflow:visible;
  box-shadow:none;
}
.platform-visual{
  position:absolute;
  inset:0;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transform:scale(.965);
}
.platform-visual.is-active{
  opacity:1;
  visibility:visible;
  transform:scale(1);
}
.platform-visual img{
  width:100%;
  height:auto;
  aspect-ratio:1672 / 941;
  object-fit:cover;
  object-position:top left;
  border-radius:12px;
  background:transparent;
  box-shadow:0 28px 70px -46px rgba(14,27,44,.55),0 0 0 1px rgba(14,27,44,.08);
}
.platform-progress{
  position:absolute;
  left:clamp(18px,2vw,28px);
  right:clamp(18px,2vw,28px);
  bottom:clamp(16px,2vw,24px);
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
}
.platform-progress span{
  height:2px;
  border-radius:999px;
  background:rgba(14,27,44,.16);
  overflow:hidden;
}
.platform-progress span::before{
  content:"";
  display:block;
  width:100%;
  height:100%;
  transform:scaleX(0);
  transform-origin:left center;
  background:var(--coral);
}
.platform-progress span.is-active::before{transform:scaleX(1)}

.platform-section .plat-grid{display:none}
.plat-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(380px,.92fr);gap:24px;align-items:stretch}
.plat-feature{
  background:var(--white);border-radius:16px;padding:48px;overflow:hidden;position:relative;
  min-height:560px;display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 24px 70px -48px rgba(14,27,44,.42),inset 0 0 0 1px rgba(14,27,44,.06);
}
.plat-feature .f-head h3{margin:18px 0 0;font-family:var(--sans);font-size:var(--fs-h3);line-height:1.08;font-weight:700;letter-spacing:-.015em}
.plat-feature .f-head h3 em{font-style:italic;color:var(--coral-deep);font-weight:700}
.plat-feature .f-desc{max-width:480px;margin-top:20px;color:var(--ink-2);font-size:16px;line-height:1.55}
.platform-proof-points{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.platform-proof-points span{
  padding:7px 10px;
  border-radius:999px;
  background:var(--paper);
  color:var(--ink-2);
  box-shadow:inset 0 0 0 1px var(--hair);
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.product-shot{
  margin-top:22px;
  border-radius:12px;
  overflow:hidden;
  background:var(--paper);
  border:1px solid rgba(14,27,44,.08);
  box-shadow:0 18px 42px -30px rgba(14,27,44,.42);
}
.product-shot img{
  display:block;
  width:100%;
  aspect-ratio:1672 / 941;
  object-fit:cover;
  object-position:top left;
}
.product-shot-main{
  margin-top:34px;
  border-radius:14px;
  box-shadow:0 28px 70px -42px rgba(14,27,44,.55);
}
.plat-feature .ui-mock{display:none}

/* Product UI mock */
.ui-mock{
  margin-top:40px;border-radius:12px;background:var(--paper);
  border:1px solid var(--hair);overflow:hidden;
  box-shadow:0 18px 40px -20px rgba(14,27,44,.25);
}
.ui-topbar{
  height:38px;display:flex;align-items:center;padding:0 14px;gap:8px;
  background:var(--paper-2);border-bottom:1px solid var(--hair);
}
.ui-topbar .dots{display:flex;gap:5px}
.ui-topbar .dots i{width:9px;height:9px;border-radius:999px;background:var(--paper-3)}
.ui-topbar .bread{margin-left:10px;font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.ui-topbar .bread b{color:var(--ink);font-weight:500}
.ui-body{display:grid;grid-template-columns:160px 1fr;min-height:260px}
.ui-side{background:var(--paper-2);padding:16px 12px;border-right:1px solid var(--hair);font-size:12px}
.ui-side .item{padding:7px 10px;border-radius:6px;color:var(--ink-3);margin-bottom:2px;display:flex;align-items:center;gap:8px}
.ui-side .item.on{background:var(--white);color:var(--ink);font-weight:500;box-shadow:0 1px 0 rgba(14,27,44,.05)}
.ui-side .item .sq{width:10px;height:10px;border-radius:3px;background:var(--ink-4);opacity:.6}
.ui-side .item.on .sq{background:var(--coral);opacity:1}
.ui-main{padding:18px 20px;background:var(--white)}
.ui-row{display:grid;grid-template-columns:28px 1fr 60px 90px 80px;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--hair);font-size:12.5px}
.ui-row:first-child{border-bottom:1px solid var(--hair-strong);color:var(--ink-3);font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;padding-bottom:8px}
.ui-row .ava{width:24px;height:24px;border-radius:999px;background:var(--sage)}
.ui-row .nm{font-weight:500}
.ui-row .sc{font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.ui-row .bar{width:80px;height:5px;border-radius:999px;background:var(--paper-2);overflow:hidden}
.ui-row .bar i{display:block;height:100%;background:var(--ink);border-radius:999px}
.ui-row .chip{font-size:10.5px;font-family:var(--mono);padding:3px 8px;border-radius:999px;text-align:center}
.ui-row .chip.adv{background:rgba(255,107,74,.12);color:var(--coral-deep)}
.ui-row .chip.rev{background:rgba(14,27,44,.08);color:var(--ink-2)}
.ui-row .chip.int{background:var(--sage);color:var(--ink)}
.feature-cta{
  margin-top:22px;
  padding-top:20px;
  border-top:1px solid var(--hair);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  color:var(--ink-3);
  font-size:13px;
  line-height:1.45;
}
.feature-cta .lk.strong{
  flex:0 0 auto;
  color:var(--ink);
  font-weight:700;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.plat-side{display:grid;grid-template-rows:repeat(3,minmax(0,1fr));gap:24px}
.plat-card{
  background:var(--white);border-radius:16px;padding:26px;position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;min-height:0;
  box-shadow:inset 0 0 0 1px rgba(14,27,44,.06);
}
.plat-card.dark{background:var(--ink);color:var(--paper)}
.plat-card.sage{background:var(--sage)}
.plat-card .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.plat-card.dark .lbl{color:rgba(245,241,234,.55)}
.plat-card h4{margin:16px 0 0;font-family:var(--sans);font-size:var(--fs-h4);line-height:1.08;font-weight:700;letter-spacing:-.015em}
.plat-card h4 em{font-style:italic;color:var(--coral);font-weight:700}
.plat-card .p{margin-top:10px;font-size:13.5px;color:var(--ink-3);line-height:1.5}
.plat-card.dark .p{color:rgba(245,241,234,.68)}
.plat-card.dark .product-shot{border-color:rgba(245,241,234,.12);background:rgba(245,241,234,.08)}
.plat-card .lk{margin-top:16px;font-size:12.5px;display:inline-flex;align-items:center;gap:6px;color:var(--coral-deep);font-weight:500}
.plat-card.dark .lk{color:var(--coral)}

.mini-chart{display:none}
.platform-flow{
  margin-top:24px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1px;
  overflow:hidden;
  border-radius:14px;
  background:var(--hair);
  box-shadow:inset 0 0 0 1px var(--hair);
}
.flow-step{
  min-height:150px;
  padding:28px;
  background:rgba(255,255,255,.74);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:24px;
}
.flow-step .k{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--coral-deep);
}
.flow-step strong{
  display:block;
  max-width:26ch;
  font-size:20px;
  line-height:1.18;
  letter-spacing:-.015em;
}

/* -------- PROOF QUOTE ---------------------------------------------------- */
.proof{padding:var(--section-y-lg) 0;background:var(--paper-2);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.proof-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(48px,6vw,80px);align-items:center}
.proof-img{aspect-ratio:4/5;border-radius:12px;overflow:hidden;background:var(--ink);position:relative}
.proof-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05)}
.proof-img .tag{
  position:absolute;left:20px;bottom:20px;background:var(--white);
  padding:10px 14px;border-radius:8px;font-size:12px;color:var(--ink-3);
  font-family:var(--mono);
}
.proof-quote{font-family:var(--sans);font-weight:700;font-size:clamp(28px,3vw,44px);line-height:1.12;letter-spacing:-.015em;margin:28px 0 0}
.proof-quote em{font-style:italic;color:var(--coral-deep)}
.proof-cite{
  margin-top:40px;padding-top:28px;border-top:1px solid var(--hair-strong);
  display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;
}
.proof-cite .who{font-size:14px}
.proof-cite .who b{display:block;font-weight:600;color:var(--ink)}
.proof-cite .who span{color:var(--ink-3);font-size:13px}
.proof-cite .metrics{display:flex;gap:32px}
.proof-cite .metric .n{font-family:var(--sans);font-size:32px;font-weight:700;letter-spacing:-.03em;line-height:1}
.proof-cite .metric .l{font-size:11.5px;font-family:var(--mono);color:var(--ink-3);margin-top:6px;text-transform:uppercase;letter-spacing:.06em}

/* -------- DATA ----------------------------------------------------------- */
.data-head{margin-bottom:var(--head-gap)}
.data-head h2{margin:14px 0 0;font-size:var(--fs-h2)}
.data-head .p{color:var(--ink-2);font-size:16px;line-height:1.55;max-width:480px}
.data-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.data-card{
  background:var(--white);border-radius:16px;padding:36px 32px;min-height:260px;
  display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;
}
.data-card .n{font-family:var(--sans);font-weight:300;font-size:76px;line-height:.95;letter-spacing:-.028em}
.data-card .n em{font-style:italic;color:var(--coral-deep);font-size:40px;margin-left:-4px}
.data-card .l{color:var(--ink-3);font-size:13.5px;line-height:1.5;max-width:220px}
.data-card .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.data-card.invert{background:var(--ink);color:var(--paper)}
.data-card.invert .l{color:rgba(245,241,234,.68)}
.data-card.invert .k{color:rgba(245,241,234,.5)}

.data-console{
  display:grid;
  grid-template-columns:minmax(320px,.72fr) minmax(0,1.28fr);
  gap:24px;
  align-items:stretch;
}
.data-hero-card{
  background:var(--ink);
  color:var(--paper);
  border-radius:16px;
  padding:36px;
  min-height:360px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
  position:relative;
}
.data-hero-card::after{
  content:"";
  position:absolute;
  right:-80px;
  top:-80px;
  width:240px;
  height:240px;
  border-radius:999px;
  border:1px solid rgba(245,241,234,.16);
  box-shadow:0 0 0 36px rgba(245,241,234,.04),0 0 0 72px rgba(245,241,234,.025);
}
.data-hero-card .k{color:rgba(245,241,234,.55)}
.data-hero-card .n{
  position:relative;
  margin-top:32px;
  font-family:var(--sans);
  font-size:clamp(82px,8vw,128px);
  line-height:.86;
  font-weight:700;
  letter-spacing:-.05em;
  z-index:1;
}
.data-hero-card .n em{
  font-size:.36em;
  color:var(--coral);
  font-style:italic;
  margin-left:8px;
}
.data-hero-card p{
  position:relative;
  margin:24px 0 0;
  color:rgba(245,241,234,.72);
  max-width:32ch;
  z-index:1;
}
.data-hero-card a{
  position:relative;
  z-index:1;
  display:inline-flex;
  gap:8px;
  color:var(--coral);
  font-weight:700;
  font-size:13.5px;
}
.data-ledger{
  display:grid;
  gap:2px;
  background:var(--hair);
  border-radius:16px;
  overflow:hidden;
}
.ledger-row{
  display:grid;
  grid-template-columns:minmax(160px,.8fr) 140px minmax(0,1.2fr);
  gap:24px;
  align-items:center;
  background:var(--white);
  padding:28px 32px;
  min-height:88px;
}
.ledger-row .label{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.ledger-row strong{
  font-family:var(--sans);
  font-size:clamp(34px,4vw,58px);
  line-height:.9;
  letter-spacing:-.04em;
}
.ledger-row span:last-child{
  color:var(--ink-3);
  font-size:14px;
  line-height:1.45;
}
.ledger-row.accent{
  background:var(--sage);
}

/* -------- ROUNDTABLE BAND ----------------------------------------------- */
.rt{padding:var(--section-y) 0}
.rt-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,64px);align-items:center}
.rt-img{aspect-ratio:1/1;border-radius:16px;background:var(--ink);overflow:hidden;position:relative}
.rt-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);opacity:.92}
.rt-img .date{
  position:absolute;left:24px;top:24px;
  background:var(--coral);color:var(--paper);
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;
}
.rt h2{margin:16px 0 0;font-size:var(--fs-h2)}
.rt .rt-meta{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.rt-chip{
  padding:6px 12px;border-radius:999px;font-size:12px;
  background:var(--white);box-shadow:inset 0 0 0 1px var(--hair);
  color:var(--ink-2);
}
.rt p{color:var(--ink-2);font-size:16px;line-height:1.55;max-width:480px;margin-top:24px}
.rt-cta{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap}

/* -------- INSIGHTS ------------------------------------------------------- */
.ins{padding:var(--section-y) 0;background:var(--paper-2);border-top:1px solid var(--hair)}
.ins-head{margin-bottom:var(--head-gap)}
.split-actions{display:flex;gap:8px;align-items:end;justify-content:flex-end}
.ins-head h2{margin:14px 0 0;font-size:var(--fs-h2)}
.ins-head .nav{display:flex;gap:8px}
.ins-head .nav button{width:44px;height:44px;border-radius:999px;background:var(--white);box-shadow:inset 0 0 0 1px var(--hair);display:grid;place-items:center}
.ins-head .nav button:hover{background:var(--ink);color:var(--paper)}
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ins-card{background:var(--white);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.ins-cover{aspect-ratio:4/3;background:var(--ink);position:relative;overflow:hidden}
.ins-cover.c1{background:linear-gradient(135deg,#23242E,#323442)}
.ins-cover.c2{background:var(--sage)}
.ins-cover.c3{background:var(--coral);color:var(--paper)}
.ins-cover .badge{
  position:absolute;left:20px;top:20px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  background:rgba(255,255,255,.12);backdrop-filter:blur(8px);
  color:var(--paper);padding:5px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
}
.ins-cover.c2 .badge{background:rgba(14,27,44,.1);color:var(--ink);border-color:rgba(14,27,44,.15)}
.ins-cover .big{
  position:absolute;left:24px;bottom:20px;right:24px;
  font-family:var(--sans);font-weight:700;font-size:36px;line-height:.98;
  letter-spacing:-.028em;color:var(--paper);
}
.ins-cover.c2 .big{color:var(--ink)}
.ins-body{padding:24px 24px 28px;display:flex;flex-direction:column;gap:12px;flex:1}
.ins-body h4{margin:0;font-size:19px;line-height:1.25;font-weight:600;letter-spacing:-.01em}
.ins-body p{margin:0;color:var(--ink-3);font-size:13.5px;line-height:1.55}
.ins-body .kicker-mono{color:var(--ink-3);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.ins-meta{margin-top:auto;padding-top:18px;border-top:1px solid var(--hair);display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}

/* -------- CLOSING CTA ---------------------------------------------------- */
.closing{background:var(--ink);color:var(--paper);padding:var(--section-y-lg) 0 clamp(56px,7vw,80px);position:relative;overflow:hidden}
.closing::before{
  content:"Potential.";
  position:absolute;left:-4vw;bottom:-120px;
  font-family:var(--sans);font-style:italic;font-weight:700;
  font-size:40vw;line-height:.8;color:rgba(245,241,234,.03);
  letter-spacing:-.04em;pointer-events:none;
}
.closing-inner{position:relative}
.closing h2{margin:20px 0 0;font-size:var(--fs-hero)}
.closing h2 em{color:var(--coral)}
.closing-side{padding-bottom:10px}
.closing-side p{color:rgba(245,241,234,.72);font-size:17px;line-height:1.55;margin:0 0 28px}
.closing-actions{display:flex;gap:12px;flex-wrap:wrap}
.closing-actions .btn-primary{background:var(--coral);color:var(--paper)}
.closing-actions .btn-primary:hover{background:var(--coral-deep)}
.closing-actions .btn-primary .arr{background:rgba(255,255,255,.25)}
.closing-actions .btn-secondary{color:var(--paper);box-shadow:inset 0 0 0 1px rgba(245,241,234,.25)}
.closing-actions .btn-secondary .arr{background:var(--paper);color:var(--ink)}
.closing-actions .btn-secondary:hover{background:rgba(245,241,234,.08)}

/* Shared section heading alignment: eyebrow above, heading/copy top-aligned below. */
.split-head,
.journey-head{
  align-items:start;
  row-gap:16px;
}
.split-head > :first-child,
.journey-head > :first-child{
  display:contents;
}
.split-head > :first-child > .eyebrow,
.journey-head > :first-child > .eyebrow{
  grid-column:1 / -1;
  grid-row:1;
  justify-self:start;
  margin:0;
}
.split-head > :first-child > .display,
.journey-head > :first-child > .display{
  grid-column:1;
  grid-row:2;
  margin-top:0;
}
.split-head > :last-child,
.journey-head > :last-child{
  grid-column:2;
  grid-row:2;
  align-self:start;
}

/* -------- HOME SCROLL ENHANCEMENTS -------------------------------------- */
.home-scroll-progress{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:80;
  height:3px;
  pointer-events:none;
  background:transparent;
}
.home-scroll-progress span{
  display:block;
  width:100%;
  height:100%;
  background:var(--coral);
  transform:scaleX(0);
  transform-origin:left center;
}
html:not(.js) .home-scroll-progress{display:none}

/* -------- FOOTER --------------------------------------------------------- */
footer{background:var(--ink);color:var(--paper);padding:clamp(72px,8vw,100px) 0 40px;position:relative}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:48px;padding-top:48px;border-top:1px solid rgba(245,241,234,.12)}
.foot-brand{display:flex;flex-direction:column;gap:20px}
.foot-brand .logo img{height:34px;filter:none}
.foot-brand p{color:rgba(245,241,234,.6);font-size:13.5px;line-height:1.55;max-width:300px;margin:0}
.foot-brand .partof{display:flex;align-items:center;gap:14px;margin-top:4px}
.foot-brand .partof span{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(245,241,234,.45)}
.foot-brand .partof img{height:28px;width:auto;opacity:.92}
.foot-brand .badges{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}
.foot-col h5,
.foot-heading{margin:0 0 18px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(245,241,234,.5);font-weight:500}
.foot-col a{display:block;padding:5px 0;font-size:13.5px;color:rgba(245,241,234,.85)}
.foot-col a:hover{color:var(--coral)}
.foot-bottom{margin-top:64px;padding-top:24px;border-top:1px solid rgba(245,241,234,.1);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11.5px;color:rgba(245,241,234,.5);letter-spacing:.04em;flex-wrap:wrap;gap:16px}
.foot-bottom .badges{display:flex;gap:12px}
.foot-badge{padding:5px 10px;border-radius:999px;background:rgba(245,241,234,.06);color:rgba(245,241,234,.7)}

/* -------- RESPONSIVE (coarse stacking under 1100px) --------------------- */
@media (max-width:1100px){
  :root{--gutter:32px}
  .hero-grid,
  .section-head,
  .plat-head,
  .plat-grid,
  .data-grid,
  .proof-grid,
  .rt-grid,
  .ins-grid,
  .closing-inner,
  .foot-grid{grid-template-columns:1fr}
  .j-grid{grid-template-columns:repeat(2,1fr)}
  .data-grid{grid-template-columns:repeat(2,1fr)}
}

/* -------- MOBILE NAV (progressive enhancement) -------------------------- */
/* The hamburger button and drawer only activate when JS has loaded
   (html.js). Without JS, nav-links stay visible on mobile as a plain list. */
.nav-toggle{
  display:none;
  width:42px;height:42px;border-radius:999px;
  place-items:center;
  box-shadow:inset 0 0 0 1px var(--hair);
  margin-left:auto;
}
.nav-toggle .bar{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;position:relative}
.nav-toggle .bar::before,
.nav-toggle .bar::after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s}
.nav-toggle .bar::before{top:-6px}
.nav-toggle .bar::after{top:6px}
.nav-toggle[aria-expanded="true"] .bar{background:transparent}
.nav-toggle[aria-expanded="true"] .bar::before{transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar::after{transform:translateY(-6px) rotate(-45deg)}

/* -------- BREADCRUMBS --------------------------------------------------- */
.breadcrumbs{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;
  color:var(--ink-3);display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  margin-bottom:28px;
}
.breadcrumbs a{color:var(--ink-3)}
.breadcrumbs a:hover{color:var(--ink)}
.breadcrumbs .sep{color:var(--ink-4)}
.breadcrumbs [aria-current="page"]{color:var(--ink)}

/* ==========================================================================
   PAGE: About
   ========================================================================== */
.hero-about{padding:60px 0 40px}
.hero-about h1{margin:16px 0 0;font-size:var(--fs-hero);max-width:18ch}
.hero-about .sub{margin-top:28px;max-width:620px;font-size:var(--fs-hero-sub);line-height:1.6;color:var(--ink-2)}
.hero-wex{padding:60px 0 72px}
.hero-wex-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(420px,1.1fr);
  gap:clamp(40px,6vw,88px);
  align-items:center;
}
.hero-wex-copy{min-width:0}
.hero-wex-media{
  border-radius:16px;
  overflow:hidden;
  background:var(--ink);
  box-shadow:0 34px 90px -54px rgba(14,27,44,.58);
}
.hero-wex-media img{
  width:100%;
  aspect-ratio:1672 / 941;
  height:auto;
  object-fit:cover;
  object-position:center;
}

.manifesto{padding:80px 0 120px;border-bottom:1px solid var(--hair)}
.manifesto-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
.manifesto-grid h2{margin:14px 0 0;font-size:var(--fs-h2)}
.manifesto-body p{font-size:18px;line-height:1.65;color:var(--ink-2);margin:0 0 22px;max-width:58ch}
.manifesto-body p b{color:var(--ink);font-weight:600}
.manifesto-body .pull{font-family:var(--sans);font-weight:700;font-size:32px;line-height:1.2;letter-spacing:-.015em;color:var(--ink);padding:24px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);margin:32px 0}
.manifesto-body .pull em{font-style:italic;color:var(--coral-deep)}

.wex-story{
  padding:var(--section-y) 0;
  background:var(--paper-2);
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
}
.wex-story-grid{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);
  grid-auto-rows:minmax(190px,auto);
  gap:24px;
}
.wex-story-card{
  position:relative;
  min-height:250px;
  border-radius:14px;
  overflow:hidden;
  background:var(--ink);
  color:var(--paper);
}
.wex-story-card.featured-card{
  grid-row:span 3;
  min-height:620px;
}
.wex-story-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.wex-story-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(14,27,44,0) 38%,rgba(14,27,44,.78) 100%);
}
.wex-story-card > div{
  position:absolute;
  left:24px;
  right:24px;
  bottom:22px;
  z-index:1;
}
.wex-story-card .k{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--coral);
}
.wex-story-card h3{
  margin:8px 0 0;
  max-width:22ch;
  font-size:var(--fs-h4);
  line-height:1.12;
  letter-spacing:-.015em;
}
.wex-story-card.featured-card h3{
  max-width:18ch;
  font-size:var(--fs-h3);
}

.timeline{background:var(--ink);color:var(--paper);padding:120px 0}
.timeline h2{margin:16px 0 0;font-size:var(--fs-h2)}
.timeline h2 em{color:var(--coral);font-style:italic}
.tl-grid{margin-top:64px;display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:rgba(245,241,234,.14);border-radius:12px;overflow:hidden}
.tl{background:var(--ink);padding:28px 22px;min-height:280px;display:flex;flex-direction:column;gap:10px;position:relative}
.tl .y{font-family:var(--mono);font-size:11px;color:var(--coral);letter-spacing:.08em}
.tl h3,
.tl h4{margin:4px 0 0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);line-height:1.1;letter-spacing:-.015em}
.tl p{margin:0;color:rgba(245,241,234,.7);font-size:13px;line-height:1.55}
.tl .big{font-family:var(--sans);font-size:54px;font-weight:700;line-height:.9;letter-spacing:-.025em;margin-top:auto}
.tl .big em{color:var(--coral);font-style:italic;font-size:28px}
.tl .big-k{font-family:var(--mono);font-size:10.5px;color:rgba(245,241,234,.5);letter-spacing:.06em;margin-top:4px;text-transform:uppercase}

.values{padding:120px 0}
.val-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.val{padding:32px;border-radius:14px;background:var(--white);min-height:260px;display:flex;flex-direction:column;gap:14px}
.val .n{font-family:var(--mono);font-size:11px;color:var(--coral-deep);letter-spacing:.08em}
.val h3{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);letter-spacing:-.015em}
.val p{margin:0;color:var(--ink-3);font-size:14px;line-height:1.55}

@media (min-width:901px){
  .solution-values{
    overflow:hidden;
  }
  .solution-val-viewport{
    margin-top:clamp(44px,6vh,68px);
    width:100%;
    overflow:hidden;
    padding-left:max(var(--gutter),calc((100vw - var(--maxw)) / 2 + var(--gutter)));
  }
  .solution-values .val-grid{
    display:flex;
    width:max-content;
    gap:24px;
    margin-top:0;
    will-change:transform;
  }
  .solution-values .val{
    flex:0 0 clamp(360px,32vw,520px);
    min-height:360px;
    justify-content:flex-start;
    opacity:.52;
    transform:scale(.965);
    transition:opacity .28s ease,transform .28s ease,border-color .28s ease;
    border:1px solid transparent;
  }
  .solution-values .val.is-active{
    opacity:1;
    transform:scale(1);
    border-color:rgba(255,91,58,.34);
  }
}

.team{padding:120px 0;background:var(--paper-2);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.member{background:var(--white);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.member .ph{aspect-ratio:4/5;background:linear-gradient(180deg,#2B3A4E,#323442);position:relative;overflow:hidden}
.member .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05)}
.member .ph .tag{position:absolute;left:16px;top:16px;padding:4px 10px;border-radius:999px;background:rgba(245,241,234,.88);backdrop-filter:blur(6px);font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink);text-transform:uppercase}
.member-body{padding:20px 22px 24px}
.member h3{margin:0;font-size:17px;font-weight:600;letter-spacing:-.01em}
.member .role{margin-top:4px;font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em}
.member p{margin:10px 0 0;font-size:13px;color:var(--ink-3);line-height:1.5}

.impact{padding:120px 0}
.impact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:72px;align-items:start;margin-top:48px}
.impact-grid h2{margin:14px 0 0;font-size:var(--fs-h2)}
.impact-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hair);border-radius:14px;overflow:hidden}
.im{background:var(--paper);padding:28px;min-height:200px;display:flex;flex-direction:column;justify-content:space-between;gap:12px}
.im .k{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase}
.im .n{font-family:var(--sans);font-size:58px;font-weight:700;letter-spacing:-.025em;line-height:.95}
.im .n em{font-style:italic;color:var(--coral-deep);font-size:28px}
.im .l{font-size:13px;color:var(--ink-3);line-height:1.5}

.backers{padding:72px 0;border-top:1px solid var(--hair);background:var(--paper-2)}
.backers-inner{display:grid;grid-template-columns:240px 1fr;gap:48px;align-items:center}
.backers h2{margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:500;line-height:1.5}
.backers-row{display:flex;gap:48px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.backers-row span{font-family:var(--sans);font-weight:700;font-style:italic;font-size:22px;color:var(--ink);letter-spacing:-.01em;opacity:.75}
.backers-row span.caps{font-family:var(--sans);font-weight:600;font-style:normal;letter-spacing:.18em;font-size:12px;text-transform:uppercase}

.careers{padding:120px 0;background:var(--ink);color:var(--paper)}
.careers-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end}
.careers h2{margin:14px 0 0;font-size:var(--fs-h2)}
.careers h2 em{color:var(--coral);font-style:italic}
.careers p{margin:24px 0;color:rgba(245,241,234,.72);font-size:16px;line-height:1.55;max-width:440px}
.careers .btn-primary{background:var(--coral);color:var(--paper)}
.careers .btn-primary:hover{background:var(--coral-deep)}
.careers .btn-secondary{color:var(--paper);box-shadow:inset 0 0 0 1px rgba(245,241,234,.25)}
.careers .btn-secondary:hover{background:rgba(245,241,234,.08)}
.roles{display:flex;flex-direction:column;gap:2px;background:rgba(245,241,234,.12);border-radius:12px;overflow:hidden}
.role{background:var(--ink);padding:22px 28px;display:grid;grid-template-columns:1.3fr 1fr 140px 60px;gap:16px;align-items:center;font-size:13.5px;transition:background .2s;color:var(--paper)}
.role:hover{background:var(--ink-2)}
.role .t{font-weight:500;font-size:15px}
.role .s{font-size:11.5px;color:rgba(245,241,234,.6);margin-top:3px}
.role .loc{font-family:var(--mono);font-size:11px;color:rgba(245,241,234,.6);letter-spacing:.04em}
.role .t-type{font-family:var(--mono);font-size:11px;color:var(--coral);letter-spacing:.06em;text-transform:uppercase}
.role .arr{width:32px;height:32px;border-radius:999px;background:rgba(245,241,234,.1);display:grid;place-items:center;justify-self:end}

/* ==========================================================================
   PAGE: Contact
   ========================================================================== */
.contact{padding:60px 0 120px}
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:start;margin-top:28px}
.contact h1{margin:16px 0 0;font-size:var(--fs-h1)}
.contact h1 em{color:var(--coral-deep);font-style:italic}
.contact .sub{margin-top:24px;max-width:480px;font-size:17px;line-height:1.55;color:var(--ink-2)}
.c-list{margin-top:36px;display:flex;flex-direction:column;gap:2px;background:var(--hair);border-radius:12px;overflow:hidden;max-width:480px;list-style:none;padding:0}
.c-list li{background:var(--paper);padding:18px 22px;display:flex;gap:14px;align-items:center;font-size:14px}
.c-list li .num{font-family:var(--mono);font-size:11px;color:var(--coral-deep);letter-spacing:.06em;font-weight:500;width:30px}
.c-list li b{font-weight:600}
.c-list li .when{color:var(--ink-3);font-size:13px;margin-left:auto;font-family:var(--mono);letter-spacing:.04em}

.what-youll-get{margin-top:44px;padding:24px;background:var(--ink);color:var(--paper);border-radius:12px;max-width:480px}
.what-youll-get h3,
.what-youll-get-heading{margin:0 0 12px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(245,241,234,.6);font-weight:500;line-height:1.5}
.what-youll-get ul{list-style:none;padding:0;margin:0;font-size:13.5px;line-height:1.6}
.what-youll-get li{padding:8px 0;border-top:1px solid rgba(245,241,234,.12);display:flex;gap:12px}
.what-youll-get li:first-child{border-top:0}
.what-youll-get li .tick{color:var(--coral);flex-shrink:0}

.form-card{background:var(--white);border-radius:16px;padding:40px 44px;box-shadow:0 24px 60px -30px rgba(14,27,44,.2), inset 0 0 0 1px var(--hair);position:sticky;top:96px}
.form-card h2{margin:12px 0 6px;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);letter-spacing:-.015em}
.form-card .desc{font-size:14px;color:var(--ink-3);line-height:1.5;margin-bottom:24px}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:span 2}
.field label{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.field label .req{color:var(--coral-deep);margin-left:2px}
.field input,.field select,.field textarea{
  font:inherit;padding:13px 14px;border-radius:9px;border:1px solid var(--hair);background:var(--paper);font-size:14px;color:var(--ink);
  transition:all .15s;
}
.field textarea{resize:vertical;min-height:80px;font-family:var(--sans)}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--coral);outline-offset:-1px;border-color:transparent;background:var(--white)}

.topics{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:4px}
.topic{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:9px;background:var(--paper);border:1px solid var(--hair);cursor:pointer;transition:all .15s;font-size:13px;font-weight:500;user-select:none}
.topic:hover{background:var(--white)}
.topic input{position:absolute;opacity:0;pointer-events:none}
.topic .box{width:14px;height:14px;border-radius:4px;border:1.5px solid var(--hair-strong);flex-shrink:0;display:grid;place-items:center;background:var(--white);font-size:10px;color:var(--paper)}
.topic:has(input:checked){background:var(--ink);color:var(--paper);border-color:var(--ink)}
.topic:has(input:checked) .box{background:var(--coral);border-color:var(--coral);color:var(--paper)}

.size-choice{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:4px}
.size-choice label{padding:10px 0;border-radius:9px;background:var(--paper);border:1px solid var(--hair);text-align:center;font-size:12.5px;cursor:pointer;font-family:var(--mono);transition:all .15s;display:block;letter-spacing:.04em;color:var(--ink-2)}
.size-choice input{position:absolute;opacity:0;pointer-events:none}
.size-choice label:has(input:checked){background:var(--ink);color:var(--paper);border-color:var(--ink)}

.submit-row{display:flex;gap:12px;margin-top:18px;align-items:center;flex-wrap:wrap}
.submit-row .btn{flex:1;justify-content:center;min-width:200px;border:0}
.submit-row .note{font-size:11.5px;color:var(--ink-3);max-width:180px;line-height:1.45}

.section-head-mini{display:flex;justify-content:space-between;align-items:baseline;margin-top:28px;padding-top:24px;border-top:1px solid var(--hair);font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);gap:12px;flex-wrap:wrap}
.section-head-mini b{color:var(--ink);font-weight:500}

.alt-paths{padding:80px 0 120px;background:var(--paper-2);border-top:1px solid var(--hair)}
.alt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.alt{background:var(--white);border-radius:14px;padding:32px;display:flex;flex-direction:column;gap:12px;min-height:220px}
.alt .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--coral-deep)}
.alt h3{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);letter-spacing:-.015em;line-height:1.1}
.alt p{margin:0;color:var(--ink-3);font-size:13.5px;line-height:1.55}
.alt .lk{margin-top:auto;padding-top:10px;font-size:13px;color:var(--ink);font-weight:500;display:inline-flex;align-items:center;gap:6px}

/* ==========================================================================
   PAGE: Industries
   ========================================================================== */
.hero-ind{padding:60px 0 72px}
.hero-ind h1{margin:18px 0 0;font-size:var(--fs-hero)}
.hero-ind .sub{margin-top:24px;max-width:580px;font-size:var(--fs-hero-sub);line-height:1.55;color:var(--ink-2)}

.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border-radius:16px;overflow:hidden;margin-top:64px}
.ind{background:var(--paper);padding:40px 32px;min-height:340px;display:flex;flex-direction:column;gap:16px;position:relative;transition:background .2s;color:inherit}
.ind:hover{background:var(--white)}
.ind .top-row{display:flex;justify-content:space-between;align-items:flex-start}
.ind .num{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em}
.ind .ic{width:42px;height:42px;border-radius:10px;background:var(--sage);display:grid;place-items:center;font-family:var(--sans);font-style:italic;font-weight:700;font-size:22px;color:var(--ink)}
.ind h2,
.ind h3{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);line-height:1.08;letter-spacing:-.015em}
.ind p{margin:0;color:var(--ink-3);font-size:13.5px;line-height:1.55}
.ind .ind-stat{margin-top:auto;padding-top:16px;border-top:1px solid var(--hair);display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em}
.ind .ind-stat b{font-family:var(--sans);font-style:normal;font-size:22px;color:var(--ink);letter-spacing:-.02em;font-weight:700}

.featured{margin:120px auto;max-width:calc(var(--maxw) - 64px);border-radius:16px;overflow:hidden;background:var(--ink);color:var(--paper)}
.featured-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:0}
.featured-img{background:linear-gradient(180deg,#23242E,#323442);min-height:100%;position:relative;overflow:hidden}
.featured-img::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 40%, rgba(255,107,74,.3), transparent 60%)}
.featured-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.7)}
.featured-img .tag{position:absolute;left:24px;bottom:24px;padding:6px 12px;border-radius:999px;font-family:var(--mono);font-size:11px;background:var(--coral);color:var(--paper);letter-spacing:.06em;text-transform:uppercase}
.featured-body{padding:64px 56px;display:flex;flex-direction:column;justify-content:center;gap:24px}
.featured h2{margin:14px 0 0;font-size:var(--fs-h2);line-height:1.08}
.featured h2 em{color:var(--coral)}
.featured p{margin:0;color:rgba(245,241,234,.72);font-size:16px;line-height:1.55;max-width:520px}
.featured-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(245,241,234,.12);border-radius:10px;overflow:hidden;margin-top:8px}
.featured-metric{background:var(--ink);padding:20px 20px}
.featured-metric .n{font-family:var(--sans);font-size:36px;font-weight:700;letter-spacing:-.02em;line-height:1}
.featured-metric .n em{color:var(--coral);font-style:italic;font-size:20px}
.featured-metric .l{margin-top:6px;font-family:var(--mono);font-size:10.5px;color:rgba(245,241,234,.55);letter-spacing:.06em;text-transform:uppercase}
.featured .btn-primary{background:var(--coral);color:var(--paper)}
.featured .btn-primary:hover{background:var(--coral-deep)}
.featured .btn-secondary{color:var(--paper);box-shadow:inset 0 0 0 1px rgba(245,241,234,.25)}
.featured .btn-secondary:hover{background:rgba(245,241,234,.08)}

.rfp{padding:120px 0;background:var(--paper-2);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.rfp-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.rfp h2{margin:14px 0 0;font-size:var(--fs-h2)}
.rfp ul{list-style:none;padding:0;margin:32px 0 0;display:flex;flex-direction:column;gap:2px}
.rfp li{background:var(--white);padding:20px 24px;border-radius:10px;display:flex;gap:16px;align-items:center;font-size:14.5px}
.rfp li .tick{width:24px;height:24px;border-radius:999px;background:var(--sage);display:grid;place-items:center;flex-shrink:0;color:var(--ink);font-size:14px}
.rfp li b{font-weight:600}
.rfp li span{color:var(--ink-3);font-size:13px}
.rfp-sticky{position:sticky;top:96px}
.rfp-downloads{background:var(--white);border-radius:16px;padding:36px;display:flex;flex-direction:column;gap:18px}
.rfp-downloads h3{margin:0 0 4px;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);letter-spacing:-.015em}
.rfp-downloads p{margin:0;color:var(--ink-3);font-size:13.5px;line-height:1.55}
.dl-item{display:flex;justify-content:space-between;align-items:center;padding:18px 0;border-top:1px solid var(--hair);font-size:14px;gap:12px;color:inherit}
.dl-item .k{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;margin-left:auto}
.dl-item .arr{width:32px;height:32px;border-radius:999px;background:var(--ink);color:var(--paper);display:grid;place-items:center;flex-shrink:0}

/* ==========================================================================
   PAGE: Insights
   ========================================================================== */
.hero-ins{padding:60px 0 72px}
.hero-ins h1{margin:18px 0 0;font-size:var(--fs-hero)}
.hero-ins .sub{margin-top:24px;max-width:620px;font-size:var(--fs-hero-sub);line-height:1.55;color:var(--ink-2)}

.filters{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:48px;padding:18px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);flex-wrap:wrap}
.filter-tabs{display:flex;gap:4px;flex-wrap:wrap}
.filter-tabs a{font-size:13px;padding:8px 14px;border-radius:999px;color:var(--ink-2)}
.filter-tabs a.on,.filter-tabs a[aria-current="page"]{background:var(--ink);color:var(--paper)}
.filter-tabs a:hover:not(.on):not([aria-current="page"]){background:rgba(14,27,44,.06)}
.filter-right{display:flex;gap:14px;align-items:center;font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.04em}
.filter-right label{display:inline-flex;gap:10px;align-items:center}
.filter-right select{font:inherit;padding:8px 12px;border-radius:8px;background:var(--white);border:1px solid var(--hair);color:var(--ink)}

.featured-ins{margin-top:56px;background:var(--ink);color:var(--paper);border-radius:16px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.featured-ins-img{min-height:420px;background:linear-gradient(135deg,#23242E,#323442);position:relative;overflow:hidden}
.featured-ins-img::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 30%, rgba(255,107,74,.35), transparent 55%)}
.featured-ins-img .chapters{position:absolute;left:40px;top:40px;right:40px;bottom:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;align-content:start}
.featured-ins-img .ch{background:rgba(245,241,234,.08);border:1px solid rgba(245,241,234,.14);border-radius:8px;padding:14px;backdrop-filter:blur(12px);font-size:11.5px;font-family:var(--mono);letter-spacing:.04em;color:rgba(245,241,234,.72);display:flex;flex-direction:column;gap:6px;min-height:80px}
.featured-ins-img .ch b{color:var(--paper);font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:0}
.featured-ins-body{padding:56px 48px;display:flex;flex-direction:column;gap:24px;justify-content:center}
.featured-ins-body h2{margin:16px 0 0;font-size:var(--fs-h2);line-height:1.08;font-family:var(--sans);font-weight:700;letter-spacing:-.015em}
.featured-ins-body h2 em{color:var(--coral);font-style:italic}
.featured-ins-body p{margin:0;color:rgba(245,241,234,.72);font-size:16px;line-height:1.55;max-width:480px}
.featured-ins-body .meta{display:flex;gap:20px;font-family:var(--mono);font-size:11px;color:rgba(245,241,234,.5);letter-spacing:.06em;text-transform:uppercase;flex-wrap:wrap}
.featured-ins-body .btn-primary{background:var(--coral);color:var(--paper)}
.featured-ins-body .btn-primary:hover{background:var(--coral-deep)}
.featured-ins-body .btn-secondary{color:var(--paper);box-shadow:inset 0 0 0 1px rgba(245,241,234,.25)}
.featured-ins-body .btn-secondary:hover{background:rgba(245,241,234,.08)}

.ic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.ic{background:var(--white);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.ic-cover{aspect-ratio:4/3;position:relative;overflow:hidden}
.ic-cover .badge{position:absolute;left:18px;top:18px;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px;backdrop-filter:blur(8px)}
.ic-cover .read{position:absolute;right:18px;bottom:18px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:rgba(255,255,255,.8)}
.ic-cover .big{position:absolute;left:22px;right:22px;bottom:22px;font-family:var(--sans);font-style:normal;font-weight:700;font-size:28px;line-height:1;letter-spacing:-.015em}
.ic-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.ic-body .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--ink-3);text-transform:uppercase}
.ic-body h3{margin:0;font-size:18px;line-height:1.3;font-weight:600;letter-spacing:-.01em}
.ic-body h3 a{color:inherit}
.ic-body h3 a:hover{color:var(--coral-deep)}
.ic-body p{margin:0;color:var(--ink-3);font-size:13px;line-height:1.55}
.ic-meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--hair);display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em}
.cov-a{background:linear-gradient(135deg,#23242E,#323442);color:var(--paper)}
.cov-a .badge{background:rgba(255,255,255,.14);color:var(--paper);border:1px solid rgba(255,255,255,.2)}
.cov-b{background:var(--sage);color:var(--ink)}
.cov-b .badge{background:rgba(14,27,44,.1);color:var(--ink);border:1px solid rgba(14,27,44,.2)}
.cov-b .read{color:rgba(14,27,44,.6)}
.cov-c{background:var(--coral);color:var(--paper)}
.cov-c .badge{background:rgba(14,27,44,.2);color:var(--paper);border:1px solid rgba(14,27,44,.3)}
.cov-d{background:var(--paper-3);color:var(--ink)}
.cov-d .badge{background:var(--white);color:var(--ink);border:1px solid var(--hair)}
.cov-d .read{color:rgba(14,27,44,.6)}
.cov-e{background:var(--ink-2);color:var(--paper)}
.cov-e .badge{background:var(--coral);color:var(--paper);border:none}
.cov-f{background:linear-gradient(160deg,#C4CDB7,#D8DED1);color:var(--ink)}
.cov-f .badge{background:var(--ink);color:var(--paper)}
.cov-f .read{color:rgba(14,27,44,.6)}

.rt-ins{margin:120px auto;max-width:calc(var(--maxw) - 64px);background:var(--ink);color:var(--paper);border-radius:16px;padding:64px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.rt-ins h2{margin:14px 0 0;font-size:var(--fs-h2)}
.rt-ins h2 em{color:var(--coral);font-style:italic}
.rt-ins p{margin-top:20px;color:rgba(245,241,234,.72);font-size:16px;line-height:1.55;max-width:480px}
.rt-ins .list{list-style:none;margin:32px 0 0;padding:0;display:flex;flex-direction:column;gap:2px;background:rgba(245,241,234,.12);border-radius:12px;overflow:hidden}
.rt-ins .list li{background:var(--ink);padding:18px 22px;display:grid;grid-template-columns:100px 1fr 90px;gap:24px;align-items:center;font-size:13.5px}
.rt-ins .list li .d{font-family:var(--mono);font-size:11px;color:var(--coral);letter-spacing:.06em}
.rt-ins .list li .ttl{font-weight:500}
.rt-ins .list li .sub{font-size:11.5px;color:rgba(245,241,234,.55);margin-top:2px}
.rt-ins .list li .s{font-family:var(--mono);font-size:11px;color:rgba(245,241,234,.6);text-align:right}
.rt-ins .btn-primary{background:var(--coral);color:var(--paper)}
.rt-ins .btn-primary:hover{background:var(--coral-deep)}

.newsletter{padding:120px 0;background:var(--paper-2);border-top:1px solid var(--hair)}
.news-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:end}
.news-grid h2{margin:14px 0 0;font-size:var(--fs-h2)}
.news-grid p{max-width:420px;color:var(--ink-2);font-size:16px;line-height:1.55;margin:24px 0 0}
.news-form{background:var(--white);border-radius:14px;padding:28px;display:flex;flex-direction:column;gap:10px}
.news-form label{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.news-form input{font:inherit;padding:14px 16px;border-radius:10px;border:1px solid var(--hair);background:var(--paper);font-size:14px}
.news-form input:focus{outline:2px solid var(--coral);outline-offset:-1px;border-color:transparent;background:var(--white)}
.news-form .btn{margin-top:6px;justify-content:center;border:0}
.news-form .check{font-size:12px;color:var(--ink-3);display:flex;gap:8px;align-items:flex-start;margin-top:8px;line-height:1.4;text-transform:none;letter-spacing:0}
.news-form .check input{width:16px;height:16px;padding:0;flex-shrink:0;margin-top:2px}

/* ==========================================================================
   PAGE: Solutions
   ========================================================================== */
.hero-sol{padding:60px 0 96px;position:relative;overflow:hidden}
.hero-sol h1{margin:16px 0 0;font-size:var(--fs-hero)}
.hero-sol .sub{margin-top:26px;max-width:620px;font-size:var(--fs-hero-sub);line-height:1.55;color:var(--ink-2)}

.journey-map{margin-top:72px;position:relative;padding:48px 0 0;border-top:1px solid var(--hair)}
.jm-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;gap:40px;flex-wrap:wrap}
.jm-ages{display:flex;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-3);text-transform:uppercase;flex-wrap:wrap}
.jm-ages span{padding:4px 10px;border-radius:999px;background:var(--white);box-shadow:inset 0 0 0 1px var(--hair)}

.rail{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--hair);border-radius:14px;overflow:hidden;margin-top:24px}
.rail-cell{background:var(--paper);padding:28px 24px;min-height:240px;display:flex;flex-direction:column;gap:12px;position:relative}
.rail-cell .age{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;color:var(--coral-deep);text-transform:uppercase}
.rail-cell h2,
.rail-cell h3{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);line-height:1.08;letter-spacing:-.015em}
.rail-cell p{margin:0;font-size:13px;color:var(--ink-3);line-height:1.5}
.rail-cell .num{position:absolute;top:20px;right:20px;font-family:var(--mono);font-size:11px;color:var(--ink-4)}

.sol-grid{display:grid;grid-template-columns:260px 1fr;gap:64px}
.sol-side{position:sticky;top:96px;align-self:start}
.sol-side h2{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin:0 0 16px;font-weight:500}
.sol-side a{display:flex;justify-content:space-between;padding:11px 14px;border-radius:8px;font-size:13.5px;color:var(--ink-2);transition:background .15s}
.sol-side a:hover,.sol-side a.on{background:var(--white)}
.sol-side a .no{font-family:var(--mono);font-size:10.5px;color:var(--ink-4);letter-spacing:.06em}
.sol-side .help{margin-top:28px;padding:18px;background:var(--white);border-radius:12px;font-size:12.5px;line-height:1.5;color:var(--ink-3)}
.sol-side .help b{color:var(--ink);display:block;font-weight:600;margin-bottom:4px}
.sol-side .help a{display:inline-flex;padding:0;margin-top:10px;color:var(--coral-deep);font-weight:500;background:transparent}

.sol-list{display:flex;flex-direction:column;gap:2px;background:var(--hair);border-radius:16px;overflow:hidden}
.sol-item{background:var(--paper);padding:40px 44px;display:grid;grid-template-columns:80px 1fr 200px;gap:32px;align-items:center;transition:background .2s}
.sol-item:hover{background:var(--white)}
.sol-item .idx{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em}
.sol-item h3{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h3);line-height:1.08;letter-spacing:-.015em}
.sol-item h3 em{font-style:italic;color:var(--coral-deep)}
.sol-item .sd{margin-top:8px;color:var(--ink-3);font-size:14px;max-width:540px;line-height:1.5}
.sol-item .tags{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}
.sol-item .tag{font-size:11.5px;font-family:var(--mono);padding:3px 9px;border-radius:999px;background:var(--sage);color:var(--ink)}
.sol-item .cta{display:flex;justify-content:flex-end}
.sol-item .cta a{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-size:13.5px;font-weight:500}
.sol-item .cta a .arrow{width:26px;height:26px;border-radius:999px;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-size:12px;transition:transform .2s}
.sol-item:hover .cta a .arrow{transform:translateX(4px)}

.cmp{margin:120px auto;max-width:calc(var(--maxw) - 64px);background:var(--ink);border-radius:16px;color:var(--paper);padding:72px var(--gutter)}
.cmp h2{margin:14px 0 32px;font-size:var(--fs-h2)}
.cmp table{width:100%;border-collapse:collapse;margin-top:28px;font-size:13.5px}
.cmp th,.cmp td{padding:18px 16px;border-bottom:1px solid rgba(245,241,234,.12);text-align:left;vertical-align:middle}
.cmp thead th{font-family:var(--mono);font-size:11px;color:rgba(245,241,234,.5);letter-spacing:.08em;text-transform:uppercase;font-weight:500;padding-bottom:14px}
.cmp td.us{color:var(--coral)}
.cmp td.them{color:rgba(245,241,234,.5)}
.cmp td strong{color:var(--paper);font-weight:500}

.cta-band{padding:120px 0;background:var(--paper-2);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.cta-band .wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:end}
.cta-band h2{margin:14px 0 0;font-size:var(--fs-h2)}
.cta-band .side{padding-bottom:8px}
.cta-band p{color:var(--ink-2);font-size:16px;line-height:1.55;margin:0 0 24px;max-width:420px}

/* ==========================================================================
   PAGE: TalentAssess (platform product template)
   ========================================================================== */
.plat-subnav{border-bottom:1px solid var(--hair);background:var(--paper)}
.plat-subnav-inner{display:flex;gap:4px;align-items:center;height:56px;overflow-x:auto}
.plat-subnav a{font-size:13.5px;padding:8px 14px;border-radius:999px;color:var(--ink-2);white-space:nowrap;font-weight:500}
.plat-subnav a.on,.plat-subnav a[aria-current="page"]{background:var(--ink);color:var(--paper)}
.plat-subnav a:hover:not(.on):not([aria-current="page"]){background:rgba(14,27,44,.06)}
.plat-subnav .version{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-3);white-space:nowrap}

.hero-prod{padding:60px 0 72px;position:relative;overflow:hidden}
.hero-prod-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:72px;align-items:end;margin-top:20px}
.hero-prod h1{margin:18px 0 0;font-size:var(--fs-hero)}
.hero-prod .sub{margin-top:24px;max-width:460px;font-size:var(--fs-hero-sub);line-height:1.55;color:var(--ink-2)}
.prod-actions{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap}
.prod-specs{margin-top:40px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px;max-width:440px}
.prod-specs .s{padding:14px 16px;border-radius:10px;background:var(--white);box-shadow:inset 0 0 0 1px var(--hair)}
.prod-specs .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.prod-specs .v{margin-top:4px;font-size:14px;font-weight:500}

.prod-hero-card{background:var(--white);border-radius:14px;padding:32px;box-shadow:0 24px 60px -24px rgba(14,27,44,.25), inset 0 0 0 1px var(--hair);align-self:stretch;display:flex;flex-direction:column}
.prod-hero-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}
.prod-hero-card-top .chip{font-family:var(--mono);font-size:10.5px;padding:3px 8px;border-radius:999px;background:rgba(36,107,72,.08);color:var(--ink);letter-spacing:.04em}
.prod-hero-card-h{font-family:var(--sans);font-weight:700;font-size:var(--fs-h3);line-height:1.08;margin:0 0 14px;letter-spacing:-.015em}
.prod-hero-card-p{margin:0 0 24px;color:var(--ink-2);font-size:15.5px;line-height:1.6}
.prod-hero-card-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--hair)}
.prod-hero-card-list li{display:flex;align-items:baseline;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--hair);gap:14px}
.prod-hero-card-list .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.prod-hero-card-list .v{font-size:14px;font-weight:500;text-align:right;color:var(--ink)}

.prod-ui{background:var(--white);border-radius:14px;overflow:hidden;box-shadow:0 24px 60px -24px rgba(14,27,44,.25), inset 0 0 0 1px var(--hair);font-size:13px}
.pui-top{height:42px;background:var(--paper-2);border-bottom:1px solid var(--hair);display:flex;align-items:center;padding:0 16px;gap:10px;font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.pui-top .dots{display:flex;gap:5px}
.pui-top .dots i{width:10px;height:10px;border-radius:999px;background:var(--paper-3)}
.pui-top .url{margin-left:10px}
.pui-top .url b{color:var(--ink);font-weight:500}
.pui-top .chip{margin-left:auto;font-family:var(--mono);font-size:10.5px;padding:3px 8px;border-radius:999px;background:rgba(255,107,74,.1);color:var(--coral-deep)}
.pui-body{display:grid;grid-template-columns:180px 1fr;min-height:520px}
.pui-side{background:var(--paper-2);border-right:1px solid var(--hair);padding:18px 14px;font-size:12.5px}
.pui-side h6,
.pui-side-label{margin:0 0 10px;font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.pui-side a{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;color:var(--ink-2);margin-bottom:2px}
.pui-side a.on{background:var(--white);font-weight:500;box-shadow:0 1px 0 rgba(14,27,44,.06)}
.pui-side a .sq{width:12px;height:12px;border-radius:3px;background:var(--ink-4);opacity:.5}
.pui-side a.on .sq{background:var(--coral);opacity:1}
.pui-main{padding:20px 24px;background:var(--white);display:flex;flex-direction:column;gap:18px}
.pui-ttl{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}
.pui-ttl h4,
.pui-ttl-heading{margin:0;font-family:var(--sans);font-weight:700;font-size:24px;letter-spacing:-.015em;line-height:1.08}
.pui-ttl .meta{font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.pui-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi{padding:14px;border-radius:10px;background:var(--paper);border:1px solid var(--hair)}
.kpi .k{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase}
.kpi .v{margin-top:6px;font-family:var(--sans);font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1}
.kpi .v em{font-style:italic;color:var(--coral-deep);font-size:14px;margin-left:2px}
.kpi .trend{font-size:11px;color:var(--ink-3);margin-top:4px;font-family:var(--mono)}
.kpi .trend.up{color:#2E7A4A}
.pui-table{border:1px solid var(--hair);border-radius:10px;overflow:hidden}
.pui-row{display:grid;grid-template-columns:28px 1.6fr 70px 90px 1fr 100px 80px;align-items:center;gap:14px;padding:11px 16px;border-top:1px solid var(--hair);font-size:12.5px}
.pui-row:first-child{border-top:0;background:var(--paper-2);color:var(--ink-3);font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;padding:10px 16px}
.pui-row .ava{width:26px;height:26px;border-radius:999px;background:var(--sage)}
.pui-row .nm{font-weight:500}
.pui-row .sub{font-size:11px;color:var(--ink-3);font-weight:400}
.pui-row .sc{font-family:var(--mono);color:var(--ink-2);font-size:11.5px}
.pui-row .bar{height:5px;border-radius:999px;background:var(--paper-2);overflow:hidden}
.pui-row .bar i{display:block;height:100%;background:var(--ink);border-radius:999px}
.pui-row .chip{font-size:10.5px;font-family:var(--mono);padding:3px 9px;border-radius:999px;text-align:center}
.pui-row .chip.adv{background:rgba(255,107,74,.12);color:var(--coral-deep)}
.pui-row .chip.int{background:var(--sage);color:var(--ink)}
.pui-row .chip.rev{background:rgba(14,27,44,.08);color:var(--ink-2)}
.pui-row .chip.new{background:rgba(46,122,74,.1);color:#2E7A4A}
.pui-row .sig{display:flex;gap:3px;align-items:center;font-size:11px;color:var(--ink-3)}
.pui-row .sig i{width:8px;height:8px;border-radius:2px;background:var(--coral);opacity:.9}
.pui-row .sig i.off{background:var(--paper-3);opacity:1}
.pui-footer{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-3);padding:4px 2px;gap:12px;flex-wrap:wrap}

.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.feat{background:var(--white);border-radius:16px;padding:32px;min-height:280px;display:flex;flex-direction:column;gap:12px;position:relative}
.feat h3{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);letter-spacing:-.015em;line-height:1.1}
.feat p{margin:0;color:var(--ink-3);font-size:14px;line-height:1.55}
.feat .ic{width:40px;height:40px;border-radius:10px;background:var(--sage);display:grid;place-items:center;color:var(--ink);font-family:var(--sans);font-style:italic;font-weight:700;font-size:18px}
.feat .step{margin-top:auto;font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em}
.feat.dark{background:var(--ink);color:var(--paper)}
.feat.dark p{color:rgba(245,241,234,.7)}
.feat.dark .ic{background:rgba(255,107,74,.18);color:var(--coral)}
.feat.dark .step{color:var(--coral)}

.how{margin:120px auto;max-width:calc(var(--maxw) - 64px);background:var(--ink);color:var(--paper);border-radius:16px;padding:80px var(--gutter)}
.how h2{margin:14px 0 40px;font-size:var(--fs-h2)}
.how h2 em{color:var(--coral);font-style:italic}
.how-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(245,241,234,.14);border-radius:12px;overflow:hidden;margin-top:32px}
.how-step{background:var(--ink);padding:28px 24px 28px;min-height:220px;display:flex;flex-direction:column;gap:8px;position:relative}
.how-step .n{font-family:var(--mono);font-size:11px;color:var(--coral);letter-spacing:.08em}
.how-step h3{margin:6px 0 0;font-family:var(--sans);font-weight:700;font-size:22px;letter-spacing:-.015em}
.how-step p{margin:0;color:rgba(245,241,234,.7);font-size:13.5px;line-height:1.55}

.out-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.out{background:var(--white);border-radius:14px;padding:32px;min-height:200px;display:flex;flex-direction:column;justify-content:space-between;gap:12px}
.out .n{font-family:var(--sans);font-size:72px;line-height:.95;font-weight:700;letter-spacing:-.025em}
.out .n em{font-style:italic;color:var(--coral-deep);font-size:36px}
.out .l{color:var(--ink-3);font-size:13px;line-height:1.5}

.integ{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:48px}
.integration-heading{margin-top:14px;font-size:var(--fs-h2)}
.integ-intro{max-width:400px;color:var(--ink-2);line-height:1.6}
.integ-list{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--hair);border-radius:12px;overflow:hidden}
.integ-list .i{background:var(--paper);padding:22px;min-height:96px;display:flex;align-items:center;justify-content:space-between;font-size:13.5px;font-weight:500}
.integ-list .i .k{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;font-weight:500}

.closing-prod{background:var(--ink);color:var(--paper);padding:140px 0 72px;position:relative;overflow:hidden}
.closing-prod h2{margin:16px 0 0;font-size:var(--fs-hero)}
.closing-prod h2 em{color:var(--coral)}
.closing-prod .grid{display:grid;grid-template-columns:1.3fr 1fr;gap:72px;align-items:end}
.closing-prod p{color:rgba(245,241,234,.72);font-size:17px;line-height:1.55;margin:0 0 24px}
.closing-prod .btn-primary{background:var(--coral);color:var(--paper)}
.closing-prod .btn-primary:hover{background:var(--coral-deep)}
.closing-prod .btn-secondary{color:var(--paper);box-shadow:inset 0 0 0 1px rgba(245,241,234,.25)}
.closing-prod .btn-secondary:hover{background:rgba(245,241,234,.08)}

/* -------- RESPONSIVE -------------------------------------------------- */
@media (max-width:1100px){
  .manifesto-grid,.impact-grid,.careers-grid,.backers-inner,.hero-prod-grid,.hero-wex-grid,.integ,.rt-ins,.news-grid{grid-template-columns:1fr}
  .tl-grid{grid-template-columns:repeat(3,1fr)}
  .val-grid,.team-grid,.impact-metrics,.ic-grid{grid-template-columns:repeat(2,1fr)}
  .wex-story-grid{grid-template-columns:1fr 1fr}
  .wex-story-card.featured-card{grid-column:1 / -1;grid-row:auto;min-height:420px}
  .ind-grid{grid-template-columns:repeat(2,1fr)}
  .featured-grid,.rfp-grid,.featured-ins,.sol-grid{grid-template-columns:1fr}
  .rail{grid-template-columns:repeat(2,1fr)}
  .sol-item{grid-template-columns:1fr;gap:16px}
  .feat-grid,.how-steps,.out-grid,.pui-kpis{grid-template-columns:repeat(2,1fr)}
  .signal-board,.problem-diagnostic,.data-console{grid-template-columns:1fr}
  .split-head,
  .journey-head{grid-template-columns:1fr;gap:24px}
  .split-head > :first-child > .eyebrow,
  .journey-head > :first-child > .eyebrow{grid-column:1;grid-row:1}
  .split-head > :first-child > .display,
  .journey-head > :first-child > .display{grid-column:1;grid-row:2}
  .split-head > :last-child,
  .journey-head > :last-child{grid-column:1;grid-row:3}
  .journey-desc{max-width:680px}
  .platform-intro{justify-content:flex-start}
  .platform-showcase{
    min-height:0;
    grid-template-columns:1fr;
    gap:28px;
  }
  .platform-step-list{
    min-height:0;
    display:grid;
    gap:18px;
    background:transparent;
    color:var(--ink);
    box-shadow:none;
    overflow:visible;
  }
  .platform-step{
    position:relative;
    inset:auto;
    min-height:0;
    padding:28px;
    border-radius:14px;
    background:rgba(255,255,255,.72);
    box-shadow:inset 0 0 0 1px var(--hair);
    opacity:1;
    visibility:visible;
    transform:none;
  }
  .platform-step h3{max-width:18ch;font-size:var(--fs-h3);line-height:1.08}
  .platform-step .step-k{color:var(--coral-deep)}
  .platform-step p{color:var(--ink-2)}
  .platform-step .lk.strong{color:var(--ink)}
  .platform-step-shot{
    display:block;
    margin-top:4px;
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 18px 42px -32px rgba(14,27,44,.5);
  }
  .platform-step-shot img{
    display:block;
    width:100%;
    aspect-ratio:1672 / 941;
    object-fit:cover;
    object-position:top left;
  }
  .platform-visual-stage{display:none}
  .platform-flow{grid-template-columns:1fr}
  .flow-step{min-height:auto}
  .problem-panel{grid-column:auto}
  .problem-diagnostic .signal-loop{grid-column:auto;grid-row:auto}
  .problem-panel{min-height:340px}
  .ledger-row{grid-template-columns:1fr auto;gap:8px 20px}
  .ledger-row span:last-child{grid-column:1 / -1}
  .pui-body{grid-template-columns:1fr}
  .pui-side{display:none}
  .rt-ins{padding:48px}
  .contact-grid,.alt-grid,.cta-band .wrap{grid-template-columns:1fr}
  .form-card{position:relative;top:0}
  .fields{grid-template-columns:1fr}
  .field.full{grid-column:span 1}
  .topics{grid-template-columns:1fr}
  .size-choice{grid-template-columns:repeat(2,1fr)}
  .rfp-sticky{position:relative;top:0}
}

/* -------- MOBILE NAV breakpoint ----------------------------------------- */
@media (max-width:900px){
  /* Hamburger appears once JS is active. Without JS, nav stays visible. */
  html.js .nav-toggle{display:grid}
  html.js .nav-links{
    position:absolute;left:0;right:0;top:100%;
    flex-direction:column;gap:0;margin:0;padding:16px var(--gutter) 24px;
    background:var(--paper);border-bottom:1px solid var(--hair);
    box-shadow:0 20px 30px -20px rgba(14,27,44,.18);
    display:none;
  }
  html.js nav.primary[data-nav-open="true"] .nav-links{display:flex}
  html.js .nav-item{display:block;width:100%}
  html.js .nav-link{padding:14px 12px;border-radius:8px;width:100%}
  html.js .nav-cta .btn-secondary,
  html.js .nav-cta .search-btn{display:none}

  /* Dropdown: collapses inline as an indented sub-list inside the hamburger */
  html.js nav.primary[data-nav-open="true"] .nav-dropdown{
    position:static;
    opacity:1;transform:none;pointer-events:auto;visibility:visible;
    background:transparent;box-shadow:none;
    padding:0 0 8px 16px;min-width:0;
    border-left:2px solid var(--hair);
    margin:4px 0 8px 12px;
    transition:none;
  }
  html.js nav.primary[data-nav-open="true"] .nav-dropdown a{
    padding:8px 12px;font-size:13px;color:var(--ink-3);
  }
  html.js nav.primary[data-nav-open="true"] .nav-dropdown a:hover{color:var(--ink)}
  html.js nav.primary[data-nav-open="true"] .nav-link .chev{transform:none}
}

/* -------- SMALL SCREEN overrides ---------------------------------------- */
@media (max-width:640px){
  :root{
    --gutter:20px;
    --section-y:72px;
    --section-y-lg:88px;
    --head-gap:36px;
    --fs-h1:clamp(32px,8vw,40px);
    --fs-h2:clamp(26px,6.8vw,34px);
    --fs-h3:clamp(21px,5.2vw,27px);
    --fs-h4:20px;
    --fs-h5:17px;
    --fs-h6:15px;
    --fs-hero:clamp(34px,8.8vw,42px);
    --fs-hero-sub:15.5px;
  }
  .section{padding:var(--section-y) 0}
  .journey{margin:72px 0;padding:56px 24px 22px;min-height:0;display:block}
  .proof{padding:var(--section-y-lg) 0}
  .rt,.ins{padding:var(--section-y) 0}
  .rt-ins{padding:48px 24px;margin:72px 16px}
  .closing,.closing-prod{padding:96px 0 48px}
  footer{padding:72px 0 32px}
  .hero{padding:40px 0 118px}
  .hero::before{background-position:82% center}
  .hero-head{padding:28px 20px;background:radial-gradient(ellipse at center,rgba(245,241,234,.88) 0%,rgba(245,241,234,.74) 50%,rgba(245,241,234,0) 78%)}
  .hero-sub{max-width:100%}
  .hero-meta{grid-template-columns:repeat(3,minmax(0,1fr))}
  .hero-meta div{padding:12px 10px}
  .hero-meta .m-n{font-size:22px}
  .hero-meta .m-l{font-size:9.5px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .journey-head,
  .journey > .j-track{padding-left:0;padding-right:0}
  .j-viewport{margin-top:40px;overflow:visible;padding-left:0}
  .j-grid{display:grid;grid-template-columns:1fr;width:auto;gap:1px;background:rgba(245,241,234,.14);overflow:hidden}
  .j-card{flex:auto;min-height:300px;border-radius:0;opacity:1;padding:32px 24px}
  .j-media{border-radius:10px}
  .ins-grid,.ic-grid{grid-template-columns:1fr}
  .data-grid{grid-template-columns:1fr}
  .signal-loop{grid-template-columns:1fr}
  .signal-step{min-height:220px}
  .problem-diagnostic{margin-top:36px}
  .problem-panel{min-height:auto;gap:24px;padding:24px}
  .problem-count span:first-child{font-size:64px}
  .problem-cta{border-radius:10px;align-items:flex-start}
  .signal-step{opacity:1}
  .signal-metric.compact{grid-template-columns:1fr}
  .signal-metric.compact .n{grid-column:auto;grid-row:auto;margin-top:14px}
  .data-hero-card{min-height:320px}
  .ledger-row{padding:24px}
  .plat-feature{padding:28px;min-height:auto}
  .platform-actions .btn{width:100%;justify-content:center}
  .feature-cta{align-items:flex-start;flex-direction:column}
  .ui-body{grid-template-columns:1fr}
  .ui-side{display:none}
  .ui-main{padding:14px}
  .ui-row{grid-template-columns:24px 1fr 44px;gap:8px}
  .ui-row span:nth-child(4),
  .ui-row span:nth-child(5){display:none}
  .platform-proof-points span{font-size:10px}
  .flow-step{padding:22px}
  .flow-step strong{font-size:18px}
  .stat-row{grid-template-columns:1fr}
  .logostrip{width:calc(100% - 24px);margin-top:-82px;border-radius:14px}
  .logostrip-inner{grid-template-columns:1fr}
  .logostrip-title{min-height:auto;padding:18px 20px;border-right:0;border-bottom:1px solid rgba(245,241,234,.1)}
  .logo-marquee{padding:16px 0}
  .logo-marquee::before,
  .logo-marquee::after{width:42px}
  .logo-marquee-set{gap:10px;padding-right:10px}
  .logo-marquee img{height:64px;max-width:172px;padding:14px 18px;border-radius:10px}
  .logo-marquee img[src*="tfl"]{height:64px;max-width:168px}
  .logo-marquee img[src*="channel4"]{height:64px;max-width:104px;padding-left:22px;padding-right:22px}
  .logo-marquee img[src*="dhl"]{height:64px}
  .logo-marquee img[src*="johnLewis"]{height:64px}
  .logo-marquee img[src*="scheniderElectric"]{height:64px;max-width:200px}
  .tl-grid{grid-template-columns:1fr 1fr}
  .val-grid,.team-grid,.ind-grid,.impact-metrics{grid-template-columns:1fr}
  .wex-story-grid{grid-template-columns:1fr}
  .wex-story-card,
  .wex-story-card.featured-card{min-height:300px}
  .rail{grid-template-columns:1fr}
  .sol-item{padding:28px 24px}
  .feat-grid,.how-steps,.out-grid,.pui-kpis{grid-template-columns:1fr}
  .featured-body{padding:40px 28px}
  .how{padding:56px 24px;margin-left:16px;margin-right:16px}
  .cmp{padding:48px 24px;margin-left:16px;margin-right:16px}
  .cmp table,.cmp thead,.cmp tbody,.cmp th,.cmp td,.cmp tr{display:block}
  .cmp thead{display:none}
  .cmp tr{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(245,241,234,.12)}
  .cmp td{padding:6px 0;border:0}
  .cmp td.us::before,.cmp td.them::before{content:attr(data-col) " — ";color:rgba(245,241,234,.45);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;display:inline-block;margin-right:8px}
  .form-card{padding:28px 24px}
  .contact{padding:40px 0 72px}
  .alt-paths{padding:56px 0 80px}
  .newsletter{padding:72px 0}
  .manifesto,.timeline,.values,.team,.impact,.backers,.careers{padding:72px 0}
  .tl{min-height:220px}
  .role{grid-template-columns:1fr;gap:8px}
  .role .arr{justify-self:start}
  .hero-about,.hero-ind,.hero-ins,.hero-sol{padding:32px 0 56px}
  .hero-prod{padding:32px 0 56px}
  .featured{margin:72px 16px}
  .featured-body{padding:40px 24px}
  .sol-item{grid-template-columns:1fr}
  .sol-item .cta{justify-content:flex-start}
  .sol-grid{gap:32px}
  .plat-subnav-inner{height:48px}
}
