/* ==========================================================================
   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:#FFFFFF;
  --paper-2:#FFFFFF;
  --paper-3:#FFFFFF;
  --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;
  --fs-hero-other:clamp(20px,4.4vw,35px);;
}

/* -------- 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}
.manifesto-body a,.feat-card p a,.feat-card li a,.sub a,.outcomes-list a,.faq-a a{
  color:var(--coral-deep);text-decoration:underline;
  text-underline-offset:3px;text-decoration-thickness:1px;
}
.manifesto-body a:hover,.feat-card p a:hover,.feat-card li a:hover,.sub a:hover,.outcomes-list a:hover,.faq-a a:hover{color:var(--coral)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
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)}

/* -------- 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)}
.section-label{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--coral);margin:0 0 12px}

/* -------- 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(255,255,255,.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(255,255,255,.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:18px;align-items:center}
.topbar-right a{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.72)}
.topbar-right a:hover{color:var(--paper)}
.topbar-right a img{height:14px;width:auto;opacity:.9}
.topbar-right .topbar-gmfj{line-height:1}
.topbar-right .topbar-gmfj img{height:18px;display:block;opacity:1}

/* -------- PRIMARY NAV ---------------------------------------------------- */
nav.primary{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.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-item::after{
  content:"";position:absolute;left:0;right:0;top:100%;height:18px;
  display:none;
}
.nav-item:hover::after,.nav-item:focus-within::after{display:block}
.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,color .15s,box-shadow .15s;
  position:relative;
}
.nav-link:hover,
.nav-item:focus-within > .nav-link{
  background:rgba(239,85,139,.1);
  color:var(--ink);
  box-shadow:inset 0 0 0 1px rgba(239,85,139,.18);
}
.nav-link .chev{width:10px;height:10px;opacity:.5;transition:transform .15s ease}

/* -------- NAV DROPDOWNS -- hover + keyboard focus-within -------------- */
.nav-dropdown{
  position:absolute;left:-18px;top:calc(100% + 12px);
  min-width:310px;padding:12px;
  background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(255,255,255,.94));
  border-radius:0;
  border:0;
  box-shadow:0 28px 70px -28px rgba(14,27,44,.42),0 12px 28px -20px rgba(239,85,139,.55);
  opacity:0;transform:translateY(-8px) scale(.98);pointer-events:none;visibility:hidden;
  transition:opacity .18s ease, transform .18s ease, visibility 0s linear .18s;
  z-index:60;
  overflow:visible;
}
.nav-dropdown::before{content:none}
.nav-dropdown::after{
  content:"";position:absolute;left:32px;top:-7px;width:14px;height:14px;
  background:rgba(255,255,255,.98);border-left:1px solid rgba(14,27,44,.1);border-top:1px solid rgba(14,27,44,.1);
  transform:rotate(45deg);
}
.nav-item:nth-child(1) .nav-dropdown{width:min(650px,calc(100vw - 96px));display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
.nav-item:nth-child(2) .nav-dropdown{width:min(520px,calc(100vw - 96px));display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
.nav-item:nth-child(3) .nav-dropdown{width:min(500px,calc(100vw - 96px));display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
.nav-item:nth-child(4) .nav-dropdown,
.nav-item:nth-child(6) .nav-dropdown{width:330px}
.nav-item:nth-child(6) .nav-dropdown{left:auto;right:-12px}
.nav-item:nth-child(6) .nav-dropdown::after{left:auto;right:34px}
.nav-dropdown a{
  position:relative;display:flex;align-items:center;min-height:46px;
  padding:11px 40px 11px 14px;border-radius:0;
  font-size:13.5px;font-weight:500;color:var(--ink-2);line-height:1.25;
  white-space:normal;
  background:transparent;
  overflow:hidden;
  transition:background .16s ease,color .16s ease;
}
.nav-dropdown a::before{
  content:"";width:7px;height:7px;border-radius:999px;margin-right:10px;flex:0 0 auto;
  background:rgba(239,85,139,.34);
  box-shadow:0 0 0 4px rgba(239,85,139,.08);
  transition:background .16s ease,box-shadow .16s ease;
}
.nav-dropdown a::after{
  content:"\2192";position:absolute;right:14px;top:50%;
  transform:translate(-4px,-50%);opacity:0;color:var(--coral);
  transition:opacity .16s ease,transform .16s ease;
}
.nav-dropdown a:hover,
.nav-dropdown a:focus-visible{
  background:rgba(14,27,44,.04);color:var(--ink);outline:none;
}
.nav-dropdown a:hover::before,
.nav-dropdown a:focus-visible::before{background:var(--coral);box-shadow:0 0 0 4px rgba(239,85,139,.14)}
.nav-dropdown a:hover::after,
.nav-dropdown a:focus-visible::after{opacity:1;transform:translate(0,-50%)}
.nav-item:hover > .nav-dropdown,
.nav-item:focus-within > .nav-dropdown{
  opacity:1;transform:translateY(0) scale(1);pointer-events:auto;visibility:visible;
  transition:opacity .18s ease, transform .18s 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}

/* -------- HERO ----------------------------------------------------------- */
.hero{
  --hero-y:0px;
  --stones-y:-44px;
  --stones-rotate:-18deg;
  --white-stones-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:2;
  background:url('/assets/img/Photos/HeroHome.png') center top / cover no-repeat;
  transform:translate3d(0,var(--hero-y),0) scale(1.1);
  transform-origin:top center;
}
.hero::after{
  content:"";
  position:absolute;
  z-index:1;
  top:clamp(-280px,-15vw,-140px);
  right:clamp(-160px,-5vw,40px);
  width:clamp(820px,92vw,1500px);
  aspect-ratio:2906/1938;
  pointer-events:none;
  background:url('/assets/img/BrandAssets/TTP-Stones.png') center / contain no-repeat;
  opacity:1;
  mix-blend-mode:multiply;
  filter:saturate(1.05) contrast(.98);
  transform:translate3d(0,var(--stones-y),0) rotate(var(--stones-rotate)) scale(1.08);
  transform-origin:center;
}
.hero-stones-white{
  position:absolute;
  inset:-8% 0;
  z-index:0;
  pointer-events:none;
  background:url('/assets/img/BrandAssets/Infinity BackgroundsWhite.jpg') center / cover no-repeat;
  opacity:1;
  transform:translate3d(0,var(--white-stones-y),0) scale(1.08);
  transform-origin:center top;
}
.hero-grid{
  position:relative;
  z-index:3;
  display:grid;grid-template-columns:minmax(0,780px);gap:0;align-items:center;
  min-height:0;
  width:100%;
}
.hero-head{
  max-width:740px;
  padding:clamp(28px,4vw,52px) clamp(40px,5vw,72px) clamp(28px,4vw,52px) clamp(20px,3vw,48px);
  background:linear-gradient(105deg,rgba(235,241,248,.95) 0%,rgba(235,241,248,.88) 42%,rgba(235,241,248,.22) 74%,transparent 100%);
  position:relative;
  z-index:1;
}
.hero-head h1{margin:0;font-size:clamp(44px,5.5vw,76px);font-weight:800}
.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-actions .btn{opacity:1;visibility:visible}
.hero-meta{
  margin:32px 0 0;padding:24px 0 0;
  display:flex;gap:32px;flex-wrap:wrap;
  max-width:none;overflow:visible;
  border-top:1px solid rgba(14,27,44,.1);
  border-radius:0;background:none;
}
.hero-meta div{margin:0;padding:0;background:none;display:flex;flex-direction:column;gap:5px}
.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: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:100%;
  margin:0;
  padding:var(--section-y) 0 0;
  border:0;
  border-radius:0;
  background:var(--paper);
  box-shadow:none!important;
  overflow:hidden;
}
.logostrip-inner{
  width:min(100% - (var(--gutter) * 2),var(--maxw));
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  align-items:start;
  margin-inline:auto;
}
.logostrip h5,
.logostrip-title{
  margin:0 0 12px;
  padding:0;
  min-height:0;
  font-family:var(--mono);
  font-size:11px;
  line-height:1.4;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--coral);
  font-weight:400;
  background:transparent;
  border:0;
}
.logo-marquee{
  overflow:hidden;
  min-width:0;
  position:relative;
  cursor:grab;
  touch-action:pan-y;
  user-select:none;
  padding:0;
  background:transparent;
  box-shadow:none!important;
}
.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(255,255,255,0));
}
.logo-marquee::after{
  right:0;
  background:linear-gradient(270deg,var(--paper),rgba(255,255,255,0));
}
.logo-marquee.is-dragging{
  cursor:grabbing;
}
.logo-marquee-track{
  display:flex;
  width:max-content;
  will-change:transform;
  background:transparent;
}
.logo-marquee-set{
  display:flex;
  align-items:center;
  gap:16px;
  padding-right:16px;
  flex:0 0 auto;
}
.logo-marquee img{
  display:block;
  width:auto;
  min-width:160px;
  max-width:240px;
  height:150px;
  object-fit:contain;
  flex:0 0 auto;
  pointer-events:none;
  padding:18px 24px;
  border-radius:0;
  background:transparent;
  box-shadow:none!important;
  filter:saturate(.92) contrast(1.02);
}
.logo-marquee img[src*="channel4"]{padding-left:30px;padding-right:30px}

@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-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-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) url('/assets/img/BrandAssets/Fresh%20green.jpg') center / cover no-repeat;
  color:var(--paper);
}
.signal-step.outcome .k{color:rgba(255,255,255,.55)}
.signal-step.outcome p{color:rgba(255,255,255,.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)}

/* -------- PROBLEM POINTS ------------------------------------------- */
.problem-points{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:rgba(14,27,44,.1);
  border-radius:16px;
  overflow:visible;
  margin-top:var(--head-gap);
}
.problem-point{
  background:rgba(235,241,248,.95);
  padding:28px 24px;
  min-height:220px;
  display:flex;
  flex-direction:column;
  gap:12px;
  position:relative;
  z-index:0;
  transition:background .2s,transform .18s,box-shadow .18s,color .2s;
}
/* 4-col: only first and last need outer rounded corners */
.problem-point:first-child{border-radius:16px 0 0 16px}
.problem-point:last-child{border-radius:0 16px 16px 0}
.problem-point:hover{
  background:var(--coral);
  transform:translateY(-2px);
  box-shadow:0 18px 48px -24px rgba(239,85,139,.45);
  z-index:2;
}
.problem-point .step-no{
  position:absolute;
  top:20px;right:20px;
  font-family:var(--mono);
  font-size:11px;
  color:var(--ink-4);
  letter-spacing:.04em;
  transition:color .2s;
}
.problem-point p{
  font-family:var(--sans);
  font-size:var(--fs-h4);
  font-weight:700;
  line-height:1.12;
  letter-spacing:-.015em;
  color:var(--ink);
  margin:0;
  transition:color .2s;
}
.problem-point:hover .step-no,
.problem-point:hover p{color:var(--paper)}
.problem-cta-block{
  margin-top:40px;
  text-align:center;
}
.problem-cta-text{
  font-size:18px;
  color:var(--ink-3);
  margin-bottom:16px;
}

/* -------- FE PATHWAY & SOCIAL ENTERPRISE (new) --------------------------- */
.fe-pathway{
  text-align:center;
  background:var(--sage);
  padding:var(--section-y) 0;
  border-radius:0;
}
.fe-pathway .display{margin-bottom:12px}
.fe-pathway p{
  font-size:18px;
  color:var(--ink-3);
  margin-bottom:24px;
}
.social-enterprise{
  text-align:center;
  padding:clamp(48px,6vw,80px) 0;
}
.se-text{
  font-size:18px;
  color:var(--ink-3);
  margin-bottom:20px;
}
.se-logos{
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
}
.se-badge{
  min-height:62px;
  min-width:140px;
  padding:10px 18px;
  border:1px solid var(--hair);
  border-radius:6px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--white);
}
.se-badge img,
.se-badge svg{
  display:block;
  max-width:140px;
  max-height:38px;
}
.se-badge img{
  object-fit:contain;
}
.se-badge img{
  filter:grayscale(1) contrast(1.05);
}
.se-partner-svg{
  color:var(--ink);
}
.se-partner-svg path{
  fill:currentColor;
}

/* -------- PROOF (updated for awards) ------------------------------------- */
.proof-awards{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}
.award-badge{
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:20px 28px;
  border:1px solid var(--hair);
  border-radius:12px;
  background:var(--white);
}
.award-card{
  margin:0;
  border:1px solid var(--hair);
  border-radius:12px;
  overflow:hidden;
  background:var(--white);
  max-width:360px;
}
.award-card img{
  width:100%;
  aspect-ratio:3/2;
  object-fit:cover;
}
.award-card figcaption{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:20px 22px 22px;
}
.award-card strong{
  color:var(--ink);
  font-size:18px;
  line-height:1.16;
  letter-spacing:-.01em;
}
.award-card figcaption > span:last-child{
  color:var(--ink-3);
  font-size:13.5px;
  line-height:1.45;
}
.award-year{
  font-family:var(--mono);
  font-size:28px;
  font-weight:700;
  color:var(--coral);
}
.award-body{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:var(--ink-3);
  margin-top:4px;
}
.proof-text{
  font-size:clamp(16px,1.4vw,18px);
  line-height:1.6;
  color:var(--ink-3);
  margin-bottom:32px;
}

/* -------- JOURNEY -------------------------------------------------------- */
.journey{
  background:var(--ink);
  color:var(--paper);border-radius:0;overflow:hidden;
  margin:var(--section-y-lg) 0 0;max-width:none;
  min-height:0;
  padding:clamp(80px,10vh,124px) 0 clamp(80px,9vh,116px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
}
.journey::before{
  content:"";
  position:absolute;
  inset:0;
  background:url('/assets/img/BrandAssets/Infinity%20Backgrounds5.jpg') center / cover no-repeat;
  transform:scaleY(-1);
  z-index:0;
}
.journey > *{
  position:relative;
  z-index:1;
}
.journey-head{
  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 h2{margin-top:16px;margin-bottom:0;font-size:var(--fs-h2);max-width:820px}
.journey .display em{color:inherit}
.journey-desc{margin:0;max-width:600px;color:rgba(255,255,255,.72);font-size:16px;line-height:1.55}
.j-viewport{
  margin-top:clamp(44px,6vh,68px);
  width:min(100%,var(--maxw));
  overflow:visible;
  margin-left:auto;
  margin-right:auto;
  padding-left:var(--gutter);
  padding-right:var(--gutter);
}
.j-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  width:100%;
  background:transparent;
  border-radius:0;
  overflow:visible;
}
.j-card{
  background:var(--white);color:var(--ink);padding:30px 28px 28px;min-height:100%;
  display:flex;flex-direction:column;gap:16px;
  position:relative;transition:transform .2s ease,box-shadow .2s ease;
  border-radius:12px;
  opacity:1;
  visibility:visible;
  overflow:hidden;
  box-shadow:0 28px 70px -48px rgba(14,27,44,.36),inset 0 0 0 1px var(--hair);
}
.j-card:hover,
.j-card:focus-within{
  transform:translateY(-4px);
  box-shadow:0 36px 72px -42px rgba(14,27,44,.5),inset 0 0 0 1px rgba(239,85,139,.42);
}
.j-card .stage{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--ink-3);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:clamp(26px,2.1vw,32px);line-height:1;font-weight:700;margin:10px 0 0;letter-spacing:-.025em}
.j-media{
  overflow:hidden;
  border-radius:10px;
  aspect-ratio:16 / 9;
  background:var(--white);
  box-shadow:inset 0 0 0 1px var(--hair);
}
.j-media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}
.j-card p{margin:0;color:var(--ink-2);font-size:15.5px;line-height:1.52;max-width:58ch}
.j-card .foot{margin-top:auto;display:flex;justify-content:flex-start;align-items:flex-end;padding-top:12px}
.j-card .j-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:44px;padding:0 20px;border-radius:999px;
  background:var(--coral);color:var(--white);
  font-size:13px;font-weight:700;
  box-shadow:0 14px 26px -18px rgba(239,85,139,.9);
  transition:background .18s ease,transform .18s ease,box-shadow .18s ease;
}
.j-card .j-cta:hover,
.j-card .j-cta:focus-visible{
  background:var(--coral-deep);color:var(--white);
  transform:translateY(-1px);
  box-shadow:0 18px 32px -18px rgba(239,85,139,.95);
}
.j-card .j-cta span{transition:transform .18s ease}
.j-card .j-cta:hover span,
.j-card .j-cta:focus-visible span{transform:translateX(3px)}
.j-card .num{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--ink-3)}
@media (max-width:1180px) and (min-width:901px){
  .j-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (min-width:641px) and (max-height:820px){
  .journey{
    min-height:0;
    padding-top:clamp(40px,6vh,58px);
    padding-bottom:clamp(18px,3vh,28px);
  }
  .journey h2{font-size:clamp(32px,4vw,48px)}
  .journey-desc{font-size:14.5px;line-height:1.45}
  .j-viewport{margin-top:clamp(28px,4vh,42px)}
  .j-card{
    min-height:330px;
    padding:28px 30px 24px;
    gap:12px;
  }
  .j-card .prod{font-size:28px;margin-top:8px}
  .j-media{aspect-ratio:2.25 / 1}
  .j-card p{font-size:15px;line-height:1.42}
  .j-card .foot{padding-top:10px}
  .j-card .j-cta{min-height:38px;padding:0 16px;font-size:12px}
}

/* -------- PLATFORM ------------------------------------------------------- */
.platform-section{
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
}
.section.platform-section{
  padding-bottom:calc(var(--section-y) + clamp(32px,5vw,72px));
}
.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;isolation:isolate}
.tab{
  position:relative;
  z-index:1;
  overflow:hidden;
  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:has(.tab-flip-indicator),
.tab.is-preview{background:transparent;color:var(--paper);box-shadow:none}
.tab:hover:not(.on){background:rgba(14,27,44,.05)}
.tab-flip-indicator{
  position:absolute;
  inset:0;
  z-index:-1;
  border-radius:inherit;
  background:var(--ink);
  pointer-events:none;
}

.platform-showcase{
  --platform-showcase-h:clamp(560px,62vh,680px);
  height:var(--platform-showcase-h);
  display:grid;
  grid-template-columns:minmax(320px,.72fr) minmax(0,1.28fr);
  gap:clamp(32px,4vw,64px);
  align-items:stretch;
  position:relative;
  isolation:isolate;
}
.platform-step-list{
  position:relative;
  width:100%;
  height:100%;
  align-self:stretch;
  border-radius:18px;
  background:var(--ink) url('/assets/img/BrandAssets/Frame.jpg') center / cover no-repeat;
  color:var(--paper);
  box-shadow:0 34px 90px -54px rgba(14,27,44,.58);
  overflow:hidden;
  contain:layout paint;
}
.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);
  pointer-events:none;
  will-change:opacity,transform;
}
.platform-step.card-linkable,
.plat-feature.card-linkable,
.plat-card.card-linkable{
  cursor:pointer;
}
.platform-step.card-linkable:focus-visible,
.plat-feature.card-linkable:focus-visible,
.plat-card.card-linkable:focus-visible{
  outline:3px solid var(--coral);
  outline-offset:4px;
}
.platform-step.is-active{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.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(255,255,255,.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-section .platform-step .lk.strong,
.platform-section .feature-cta .lk.strong,
.platform-section .plat-card .lk{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:max-content;
  min-height:44px;
  padding:0 20px;
  border-radius:999px;
  background:var(--coral);
  color:var(--white);
  font-size:13px;
  font-weight:700;
  box-shadow:0 14px 26px -18px rgba(239,85,139,.9);
  transition:background .18s ease,transform .18s ease,box-shadow .18s ease;
}
.platform-section .platform-step .lk.strong:hover,
.platform-section .platform-step .lk.strong:focus-visible,
.platform-section .feature-cta .lk.strong:hover,
.platform-section .feature-cta .lk.strong:focus-visible,
.platform-section .plat-card .lk:hover,
.platform-section .plat-card .lk:focus-visible{
  background:var(--coral-deep);
  color:var(--white);
  transform:translateY(-1px);
  box-shadow:0 18px 32px -18px rgba(239,85,139,.95);
}
.platform-section .platform-step .lk.strong span,
.platform-section .feature-cta .lk.strong span,
.platform-section .plat-card .lk span{transition:transform .18s ease}
.platform-section .platform-step .lk.strong:hover span,
.platform-section .platform-step .lk.strong:focus-visible span,
.platform-section .feature-cta .lk.strong:hover span,
.platform-section .feature-cta .lk.strong:focus-visible span,
.platform-section .plat-card .lk:hover span,
.platform-section .plat-card .lk:focus-visible span{transform:translateX(3px)}
.platform-step-shot{display:none}
.platform-visual-stage{
  height:100%;
  min-height:0;
  position:relative;
  align-self:stretch;
  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);
  will-change:opacity,transform;
}
.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-visual iframe{
  display:block;
  width:100%;
  height:100%;
  min-height:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.platform-visual video,
.platform-step-shot video,
.product-shot video{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
}
.platform-visual-promo{
  overflow:hidden;
}
.platform-visual-promo iframe{
  transform:scale(1.08);
  transform-origin:center;
}
.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(5,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) url('/assets/img/BrandAssets/Frame.jpg') center / cover no-repeat;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 iframe{
  display:block;
  width:100%;
  aspect-ratio:16 / 9;
  border:0;
  background:var(--paper);
  pointer-events:none;
}
.product-shot video{
  aspect-ratio:16 / 9;
  background:var(--paper);
}
.platform-step-shot video{
  aspect-ratio:16 / 9;
  background:var(--paper);
}
.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) url('/assets/img/BrandAssets/Frame.jpg') center / cover no-repeat;border-radius:0;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);
  transition:box-shadow .22s;
}
.plat-card:hover{box-shadow:0 28px 64px -42px rgba(14,27,44,.28),inset 0 0 0 1px rgba(14,27,44,.06)}
.plat-card.dark{background:var(--ink) url('/assets/img/BrandAssets/Frame.jpg') center / cover no-repeat;color:var(--paper)}
.plat-card.sage{background:var(--sage) url('/assets/img/BrandAssets/Frame.jpg') center / cover no-repeat}
.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(255,255,255,.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(255,255,255,.68)}
.plat-card.dark .product-shot{border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.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:64px;
  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;
}

/* -------- RECOGNITION ---------------------------------------------------- */
.recognition{padding:var(--section-y-lg) 0;background:var(--ink) url('/assets/img/BrandAssets/Infinity BackgroundDark.jpg') center/cover no-repeat}
.recognition-head{text-align:center;margin-bottom:clamp(40px,5vw,60px)}
.recognition-head .section-label{color:var(--coral)}
.recognition-head .display{color:var(--paper);margin-top:12px}
.recognition-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.recognition-card{margin:0;position:relative;border-radius:16px;overflow:hidden;background:var(--ink)}
.recognition-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.recognition-card figcaption{
  position:absolute;bottom:0;left:0;right:0;
  padding:clamp(20px,2.5vw,32px);
  background:linear-gradient(to top,rgba(14,20,33,.92) 0%,rgba(14,20,33,.4) 60%,transparent 100%);
  display:flex;flex-direction:column;gap:6px;
}
.recog-year{font-family:var(--mono);font-size:11px;color:var(--coral);letter-spacing:.07em;text-transform:uppercase}
.recog-status{display:inline-flex;align-items:center;gap:8px;margin-bottom:2px}
.recog-status strong{font-size:clamp(18px,2vw,24px);font-weight:700;color:#fff;line-height:1.1;letter-spacing:-.01em}
.recog-status .badge{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-family:var(--mono);padding:3px 8px;border-radius:20px;font-weight:600}
.recog-status .badge-winner{background:var(--coral);color:#fff}
.recog-status .badge-nom{background:rgba(255,255,255,.15);color:rgba(255,255,255,.8)}
.recognition-card figcaption p{font-size:13.5px;color:rgba(255,255,255,.65);line-height:1.4;margin:0}
.recog-client{font-size:12.5px;color:rgba(255,255,255,.45);font-style:italic}
.recognition-bottom{max-width:760px;margin:clamp(48px,6vw,72px) auto 0;text-align:center}
.recognition-quote{font-family:var(--sans);font-weight:700;font-size:clamp(24px,2.8vw,40px);line-height:1.15;letter-spacing:-.015em;color:var(--paper);margin:0}
.recognition-quote em{font-style:italic;color:var(--coral)}
.recognition-cite{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}
.recognition-cite b{display:block;font-weight:600;color:var(--paper);font-size:14px}
.recognition-cite span{color:rgba(255,255,255,.45);font-size:13px}

/* -------- 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(255,255,255,.68)}
.data-card.invert .k{color:rgba(255,255,255,.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) url('/assets/img/BrandAssets/Dark%20Blue.jpg') center / cover no-repeat;
  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(255,255,255,.16);
  box-shadow:0 0 0 36px rgba(255,255,255,.04),0 0 0 72px rgba(255,255,255,.025);
}
.data-hero-card .k{color:rgba(255,255,255,.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(255,255,255,.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:14px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  position:relative;
  isolation:isolate;
  box-shadow:0 18px 46px -34px rgba(14,27,44,.5);
  transition:transform .18s,box-shadow .18s;
}
.ins-card:hover{
  transform:translateY(-2px);
  box-shadow:0 28px 64px -38px rgba(14,27,44,.58);
}
.ins-cover{aspect-ratio:4/3;background:var(--ink);position:relative;overflow:hidden}
.ins-cover.c1{background:#32B6CC;color:var(--ink)}
.ins-cover.c2{background:#9CCB3B;color:var(--ink)}
.ins-cover.c3{background:#7C499C;color:var(--paper)}
.ins-cover.c4{background:#F58628;color:var(--ink)}
.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,.18);backdrop-filter:blur(8px);
  color:var(--paper);padding:5px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.25);
}
.ins-cover.c1 .badge,.ins-cover.c2 .badge,.ins-cover.c4 .badge{background:rgba(14,27,44,.12);color:var(--ink);border-color:rgba(14,27,44,.2)}
.ins-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.05;letter-spacing:-.015em}
.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(--paper);
  color:var(--ink);
  padding:var(--section-y-lg) 0 clamp(56px,7vw,80px);
  position:relative;
  overflow:hidden;
}
.closing::before{display: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:var(--ink-2);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(--ink);box-shadow:inset 0 0 0 1px var(--hair-strong)}
.closing-actions .btn-secondary .arr{background:var(--ink);color:var(--paper)}
.closing-actions .btn-secondary:hover{background:var(--ink);color:var(--paper)}

/* Shared section heading alignment. */
.split-head,
.journey-head{
  align-items:start;
  row-gap:16px;
}
.split-head > :first-child,
.journey-head > :first-child{
  display:contents;
}
.split-head > :first-child > .display,
.journey-head > :first-child > .display{
  grid-column:1;
  grid-row:1;
  margin-top:0;
}
.split-head > :last-child,
.journey-head > :last-child{
  grid-column:2;
  grid-row:1;
  align-self:start;
}

/* -------- PLATFORM SHOWCASE SCROLL ARROW -------------------------------- */
.platform-scroll-arrow{
  position:fixed;
  bottom:32px;
  left:50%;
  transform:translateX(-50%) translateY(10px);
  z-index:900;
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--ink);
  border:1px solid rgba(255,255,255,.12);
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  cursor:pointer;
  transition:opacity .22s ease, transform .22s ease;
  box-shadow:0 4px 16px rgba(0,0,0,.22);
}
.platform-scroll-arrow.is-visible{
  opacity:1;
  transform:translateX(-50%) translateY(0);
  pointer-events:auto;
}
.platform-scroll-arrow:hover,
.platform-scroll-arrow:focus-visible{
  background:var(--coral);
  outline:none;
  box-shadow:0 8px 22px rgba(239,85,139,.32);
}
.platform-scroll-arrow svg{
  width:16px;height:16px;color:#fff;
  transition:transform .28s ease;
}
.platform-scroll-arrow.is-up svg{transform:rotate(180deg)}
html:not(.js) .platform-scroll-arrow{display:none}

/* -------- PLATFORM CAROUSEL -------------------------------------------- */
.platform-glide{position:relative;margin-top:clamp(28px,3vw,48px);overflow:hidden}
.platform-glide .glide__track{overflow:hidden}
.platform-glide .glide__slides{display:flex;align-items:stretch}
.platform-glide .glide__slide{height:auto}
.plat-carousel-card{
  display:grid;
  grid-template-columns:minmax(0,.55fr) minmax(0,1.45fr);
  gap:clamp(24px,3.5vw,52px);
  align-items:center;
  background:var(--white) url('/assets/img/BrandAssets/Frame.jpg') center / cover no-repeat;
  border-radius:16px;
  padding:clamp(28px,3.5vw,52px);
  min-height:clamp(340px,44vh,520px);
  box-shadow:0 24px 70px -48px rgba(14,27,44,.38),inset 0 0 0 1px rgba(14,27,44,.07);
}
.plat-carousel-body{display:flex;flex-direction:column}
.plat-carousel-body h3{
  margin:0;
  font-family:var(--sans);
  font-size:clamp(20px,2.2vw,30px);
  line-height:1.1;
  font-weight:700;
  letter-spacing:-.015em;
}
.plat-carousel-body h3 em{color:var(--coral);font-style:italic}
.plat-carousel-body p{
  margin:16px 0 0;
  font-size:16px;
  color:var(--ink-2);
  line-height:1.6;
  max-width:46ch;
}
.plat-carousel-body .platform-proof-points{margin-top:20px}
.plat-carousel-body .lk.strong{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:24px;
  padding:11px 20px;
  border-radius:999px;
  background:var(--coral);
  color:var(--white);
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  width:max-content;
  transition:background .18s,transform .18s,box-shadow .18s;
}
.plat-carousel-body .lk.strong:hover,
.plat-carousel-body .lk.strong:focus-visible{
  background:var(--coral-deep);
  transform:translateY(-1px);
  box-shadow:0 12px 24px -10px rgba(239,85,139,.6);
}
.plat-carousel-media{
  position:relative;
  border-radius:12px;
  overflow:hidden;
  aspect-ratio:16/10;
  background:var(--ink);
  box-shadow:0 28px 70px -32px rgba(14,27,44,.55),0 0 0 1px rgba(14,27,44,.08);
}
.plat-carousel-media video,
.plat-carousel-media iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  border:none;
}
.platform-glide-nav{display:flex;justify-content:center;margin-top:20px}
.platform-glide-arrows{display:flex;align-items:center;gap:14px}
.platform-glide-arrow{
  width:36px;height:36px;border-radius:50%;
  border:1.5px solid rgba(14,27,44,.18);
  background:var(--white);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;
  transition:background .18s,border-color .18s,color .18s;
  color:var(--ink);
}
.platform-glide-arrow:hover,
.platform-glide-arrow:focus-visible{background:var(--coral);border-color:var(--coral);color:var(--white)}
.platform-glide-arrow svg{width:14px;height:14px;display:block}
.platform-glide-bullets{display:flex;gap:8px;align-items:center}
.platform-glide-bullet{
  position:relative;
  width:36px;height:4px;
  border-radius:999px;
  border:none;
  background:rgba(14,27,44,.14);
  padding:0;
  cursor:pointer;
  overflow:hidden;
}
.platform-glide-bullet::after{
  content:"";
  position:absolute;
  inset:0;
  background:var(--coral);
  transform:scaleX(0);
  transform-origin:left;
  border-radius:inherit;
}
.platform-glide-bullet.glide__bullet--active::after{
  animation:plat-bullet-fill 20s linear forwards;
}
@keyframes plat-bullet-fill{from{transform:scaleX(0)}to{transform:scaleX(1)}}
html:not(.js) .platform-glide .glide__slides{flex-direction:column;gap:24px}
html:not(.js) .platform-glide-nav{display:none}
@media(max-width:860px){
  .plat-carousel-card{grid-template-columns:1fr;min-height:auto;gap:20px;padding:clamp(20px,3vw,32px)}
  .plat-carousel-media{aspect-ratio:16/9}
  .plat-carousel-body .lk.strong{width:100%;justify-content:center}
}
@media(max-width:560px){
  .plat-carousel-body h3{font-size:20px}
  .plat-carousel-body p{font-size:15px}
  .platform-glide-bullet{width:24px}
  .platform-glide-arrows{gap:8px}
}

/* -------- 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}

/* -------- PLATFORM PAGE FEATURES ----------------------------------------- */
.feat-table{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(340px, 1fr));
  gap:24px;
  margin-top:40px;
  counter-reset:platform-feature;
}
.feat-card{
  counter-increment:platform-feature;
  position:relative;
  min-height:300px;
  padding:72px 30px 30px;
  border:1px solid rgba(14,27,44,.08);
  border-radius:8px;
  background:
    linear-gradient(180deg,rgba(14,27,44,.12),rgba(14,27,44,.76)),
    url('/assets/img/Coloured%20squares/Frame%2028.jpg') center / cover no-repeat;
  box-shadow:0 24px 62px -48px rgba(14,27,44,.42);
  overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.feat-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:5px;
  background:linear-gradient(90deg,var(--coral),rgba(239,85,139,.28),rgba(14,27,44,.12));
}
.feat-card::after{
  content:counter(platform-feature, decimal-leading-zero);
  position:absolute;
  top:24px;
  left:30px;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.72);
}
.feat-card:hover{
  transform:translateY(-4px);
  border-color:rgba(14,27,44,.14);
  box-shadow:0 34px 82px -48px rgba(14,27,44,.5);
}
.feat-card h3{
  max-width:18ch;
  font-size:clamp(21px,2vw,28px);
  line-height:1.08;
  font-weight:700;
  letter-spacing:-.015em;
  margin:0 0 18px;
  color:var(--paper);
}
.feat-what{
  font-size:15.5px;
  line-height:1.62;
  color:rgba(255,255,255,.78);
  margin:0 0 18px;
}
.feat-why{
  position:relative;
  font-size:14.5px;
  line-height:1.55;
  color:rgba(255,255,255,.86);
  margin:auto 0 0;
  padding:18px 0 0 18px;
  border-top:1px solid rgba(255,255,255,.2);
}
.feat-why::before{
  content:"";
  position:absolute;
  left:0;
  top:22px;
  bottom:3px;
  width:3px;
  background:var(--coral);
  border-radius:999px;
}

/* -------- VIDEO PLACEHOLDERS --------------------------------------------- */
.video-placeholders{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:24px;
  margin-top:32px;
}
.video-placeholder{
  border:1px solid var(--hair);
  border-radius:12px;
  overflow:hidden;
  background:var(--white);
}
.video-thumb{
  width:100%;
  height:180px;
  background:var(--sage);
  display:flex;
  align-items:center;
  justify-content:center;
}
.video-thumb::after{
  content:"▶";
  font-size:32px;
  color:var(--ink-4);
}
.video-title{
  font-size:16px;
  font-weight:600;
  margin:16px 20px 6px;
  color:var(--ink);
}
.video-msg{
  font-size:14px;
  color:var(--ink-3);
  margin:0 20px 12px;
  line-height:1.5;
}
.video-dur{
  display:inline-block;
  font-family:var(--mono);
  font-size:12px;
  color:var(--ink-4);
  margin:0 20px 16px;
  padding:3px 8px;
  border:1px solid var(--hair);
  border-radius:4px;
}

/* -------- INSIGHTS PAGE -------------------------------------------------- */
.insights-featured{
  padding:40px;
  border:1px solid var(--hair);
  border-radius:14px;
  background:var(--white);
}
.insights-featured .badge{
  display:inline-block;
  font-family:var(--mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.05em;
  padding:4px 10px;
  border-radius:4px;
  background:var(--coral);
  color:#fff;
  margin-bottom:12px;
}
.insights-featured h2{font-size:var(--fs-h3);margin:0 0 8px}
.insights-featured p{color:var(--ink-3);font-size:16px;margin:0}

.insights-filters{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:32px;
}
.filter-btn{
  padding:8px 16px;
  border:1px solid var(--hair);
  border-radius:20px;
  background:var(--white);
  font-size:14px;
  cursor:pointer;
  color:var(--ink-3);
  transition:all .15s;
}
.filter-btn:hover,.filter-btn.active{
  background:var(--ink);
  color:var(--white);
  border-color:var(--ink);
}

.insights-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:24px;
}
.insight-card{
  padding:24px;
  border:1px solid var(--hair);
  border-radius:12px;
  background:var(--white);
}
.insight-pillar{
  display:inline-block;
  font-family:var(--mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--coral);
  margin-bottom:10px;
}
.insight-card h3{font-size:18px;margin:0 0 8px}
.insight-card h3 a{color:var(--ink);text-decoration:none}
.insight-card h3 a:hover{color:var(--coral)}
.insight-card p{font-size:15px;color:var(--ink-3);line-height:1.5;margin:0 0 14px}
.insight-meta{
  display:flex;
  gap:12px;
  font-size:13px;
  color:var(--ink-4);
}
.insight-author{font-weight:600;color:var(--ink-3)}

/* -------- ABOUT PAGE DATA BLOCK ------------------------------------------ */
.data-block{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  gap:24px;
  margin-top:32px;
}
.data-block-item{
  text-align:center;
  padding:24px 16px;
}
.data-block-item .n{
  font-size:clamp(32px,4vw,48px);
  font-weight:700;
  color:var(--ink);
  line-height:1.1;
}
.data-block-item .l{
  font-size:14px;
  color:var(--ink-3);
  margin-top:6px;
}

/* -------- ACCREDITATION CARDS -------------------------------------------- */
.accred-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:20px;
  margin-top:24px;
}
.accred-card{
  padding:24px;
  border:1px solid var(--hair);
  border-radius:12px;
}
.accred-card h3{font-size:16px;font-weight:700;margin:0 0 8px;color:var(--ink)}
.accred-card p{font-size:14px;line-height:1.5;color:var(--ink-3);margin:0}

/* -------- TALENT HUB HEXAGON GRID ---------------------------------------- */
.hex-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:16px;
  margin-top:var(--head-gap);
}
.hex-item{
  display:flex;
  flex-direction:column;
  gap:0;
  min-height:220px;
  padding:0;
  border:1px solid rgba(14,27,44,.08);
  border-radius:8px;
  background:linear-gradient(180deg,#fff,rgba(255,255,255,.84));
  text-decoration:none;
  color:var(--ink);
  overflow:hidden;
  position:relative;
  box-shadow:0 18px 46px -38px rgba(14,27,44,.45);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  text-align:left;
}
.hex-item::before{content:none}
.hex-item::after{content:none}
.hex-item:hover{
  transform:translateY(-2px);
  background:#fff;
  box-shadow:0 28px 64px -40px rgba(14,27,44,.54);
}
.hex-media{
  display:block;
  aspect-ratio:16 / 10;
  background:var(--paper-2);
  overflow:hidden;
}
.hex-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.hex-k{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--coral-deep);
  line-height:1.2;
  padding:22px 24px 0;
}
.hex-label{
  font-size:clamp(21px,1.8vw,28px);
  line-height:1.05;
  font-weight:700;
  letter-spacing:-.015em;
  color:var(--ink);
  padding:8px 24px 0;
  min-height:2.3em;
}
.hex-desc{
  font-size:14px;
  line-height:1.55;
  color:var(--ink-3);
  padding:10px 24px 26px;
  flex-grow:1;
}
.hub-system-grid{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(340px,.58fr);
  gap:clamp(40px,6vw,88px);
  align-items:start;
}
.hub-system-grid .manifesto-body{max-width:780px}
.hub-evidence-panel{
  position:sticky;
  top:104px;
  background:var(--ink);
  color:var(--paper);
  border-radius:8px;
  padding:clamp(24px,3vw,34px);
  box-shadow:0 30px 80px -54px rgba(14,27,44,.72);
}
.hub-evidence-row{
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  gap:4px 16px;
  padding:20px 0;
  border-bottom:1px solid rgba(255,255,255,.11);
}
.hub-evidence-row:first-child{padding-top:0}
.hub-evidence-row:last-child{padding-bottom:0;border-bottom:0}
.hub-evidence-k{
  grid-row:1 / span 2;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.08em;
  color:var(--coral);
}
.hub-evidence-row strong{
  font-size:18px;
  line-height:1.15;
}
.hub-evidence-row p{
  margin:0;
  color:rgba(255,255,255,.66);
  font-size:14px;
  line-height:1.5;
}

/* -------- FOOTER --------------------------------------------------------- */
footer{
  background:var(--ink) url('/assets/img/BrandAssets/Infinity%20BackgroundDark.jpg') center / cover no-repeat;
  color:var(--paper);
  padding:clamp(72px,8vw,100px) 0 40px;
  position:relative;
}
footer > .wrap{position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:48px;padding-top:48px;border-top:1px solid rgba(255,255,255,.12)}
.foot-brand{display:flex;flex-direction:column;gap:20px}
.foot-brand .logo img{height:34px;filter:none}
.foot-brand p{color:rgba(255,255,255,.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(255,255,255,.45)}
.foot-brand .partof img{height:28px;width:auto;opacity:.92}
.foot-brand .badges{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}
.footer-partner-badges{align-items:center}
.footer-partner-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:7px 10px;
  background:transparent;
}
.footer-partner-badge img,
.footer-partner-badge svg{
  display:block;
  width:auto;
  max-width:112px;
  max-height:24px;
}
.footer-partner-badge img{object-fit:contain;filter:grayscale(1) invert(1);opacity:.78}
.footer-partner-svg{color:rgba(255,255,255,.78)}
.footer-partner-svg path{fill:currentColor}
.foot-col h5,
.foot-heading{margin:0 0 18px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);font-weight:500}
.foot-col a{display:block;padding:5px 0;font-size:13.5px;color:rgba(255,255,255,.85)}
.foot-col a:hover{color:var(--coral)}
.foot-bottom{margin-top:64px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11.5px;color:rgba(255,255,255,.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(255,255,255,.06);color:rgba(255,255,255,.7)}
.foot-brand .footer-partner-badge{background:transparent}

/* -------- ACCESSIBILITY TOOLS ------------------------------------------ */
.a11y-panel{
  position:fixed;inset:0;z-index:120;
  display:grid;place-items:end center;
  padding:24px;background:rgba(14,27,44,.52);
}
.a11y-panel[hidden]{display:none}
.a11y-panel-card{
  width:min(100%,520px);max-height:min(680px,calc(100vh - 48px));overflow:auto;
  background:var(--paper);color:var(--ink);border:1px solid var(--hair);
  box-shadow:0 30px 90px -30px rgba(14,27,44,.55);padding:22px;border-radius:8px;
}
.a11y-panel-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.a11y-panel h2{margin:0;font-size:24px;letter-spacing:0}
.a11y-close,
.a11y-reset{
  appearance:none;border:1px solid var(--hair);background:var(--paper-2);color:var(--ink);
  min-height:40px;padding:0 14px;border-radius:6px;font:600 13px/1 var(--sans);cursor:pointer;
}
.a11y-tools{display:grid;gap:10px}
.a11y-tool{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:14px;border:1px solid var(--hair);border-radius:8px;background:var(--paper-2);
}
.a11y-tool b{display:block;font-size:15px;color:var(--ink)}
.a11y-tool small{display:block;margin-top:4px;font-size:13px;line-height:1.35;color:var(--ink-2)}
.a11y-tool input{width:22px;height:22px;flex:0 0 auto;accent-color:var(--coral)}
.a11y-actions{margin-top:16px;display:flex;justify-content:flex-end}
.a11y-panel-open{overflow:hidden}
.a11y-large-text{
  --fs-h1:clamp(42px,4.4vw,68px);
  --fs-h2:clamp(32px,3.3vw,48px);
  --fs-h3:clamp(25px,2vw,34px);
  --fs-h4:clamp(22px,1.8vw,28px);
  --fs-h5:20px;
  --fs-h6:18px;
  --fs-hero:clamp(43px,4.8vw,72px);
  --fs-hero-sub:18px;
}
.a11y-large-text body{font-size:112%}
.a11y-readable-text body{line-height:1.7}
.a11y-readable-text p,
.a11y-readable-text li{line-height:1.8}
.a11y-readable-text p{max-width:68ch}
.a11y-high-contrast body{background:#fff;color:#08111f}
.a11y-high-contrast a{color:#003b8f;text-decoration-thickness:2px;text-underline-offset:3px}
.a11y-high-contrast .topbar,
.a11y-high-contrast footer{background:#05070a}
.a11y-high-contrast :focus-visible{outline-color:#ffbf00;outline-width:3px}
.a11y-high-contrast .btn,
.a11y-high-contrast .foot-badge,
.a11y-high-contrast .card,
.a11y-high-contrast .j-card,
.a11y-high-contrast .plat-card{border-color:#08111f}
.a11y-reduce-motion,
.a11y-reduce-motion *,
.a11y-reduce-motion *::before,
.a11y-reduce-motion *::after{
  scroll-behavior:auto!important;
  animation-duration:.001ms!important;
  animation-iteration-count:1!important;
  transition-duration:.001ms!important;
}

/* -------- RESPONSIVE (coarse stacking under 1100px) --------------------- */
@media (max-width:1100px){
  :root{--gutter:32px}
  .hero-grid,
  .section-head,
  .plat-head,
  .plat-grid,
  .data-grid,
  .recognition-cards,
  .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:clamp(32px,3vw,48px) 0 clamp(32px,3vw,48px);
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 72% 28%,rgba(239,85,139,.18),rgba(239,85,139,0) 32%),
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.97) 38%,rgba(235,241,248,.6) 62%,rgba(235,241,248,.12) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds6.jpg') right center / cover no-repeat;
}
.hero-about .wrap{position:relative;z-index:4}
.hero-about h1{margin:16px 0 0;font-size:clamp(36px,4.4vw,62px);max-width:18ch;line-height:1.05}
.hero-about h1 em{color:var(--coral-deep);font-style:italic}
.hero-about .sub{margin-top:28px;max-width:620px;font-size:var(--fs-hero-sub);line-height:1.6;color:var(--ink-2)}
.hero-about-grid{
  display:grid;
  grid-template-columns:1fr minmax(0,400px);
  gap:clamp(40px,5vw,80px);
  align-items:start;
}
.hero-about-media{position:relative;align-self:stretch;overflow:hidden}
.hero-about-media img{position:absolute;bottom:0;left:0;width:100%;height:100%;object-fit:contain;object-position:center bottom}
.hero-about-stones{
  position:absolute;
  width:28%;
  bottom:-12%;
  right:-2%;
  transform:rotate(14deg);
  pointer-events:none;
  z-index:2;
}
.about-lead{font-size:clamp(18px,1.6vw,22px);line-height:1.55;color:var(--ink);font-weight:500;margin-bottom:20px}
.about-stats-section{background:var(--ink);color:var(--paper)}
.about-stats-section h2{color:#fff;margin-bottom:clamp(32px,4vw,48px)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1px;background:rgba(255,255,255,.08);border-radius:14px;overflow:hidden;margin-top:0}
.stats-grid .stat{background:rgba(255,255,255,.04);padding:32px 28px;display:flex;flex-direction:column;gap:8px}
.stat-number{font-family:var(--sans);font-size:clamp(40px,5vw,64px);font-weight:700;line-height:.9;letter-spacing:-.03em;color:var(--coral)}
.stat-unit{font-size:.52em;font-weight:700;color:var(--coral)}
.stat-label{font-size:clamp(15px,1.3vw,18px);line-height:1.5;color:#fff;font-weight:500;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.12)}
.accred-badge-img{width:72px;height:auto;margin-bottom:14px;display:block}
.hero-platform{
  padding:clamp(72px,7vw,104px) 0 clamp(88px,8vw,124px);
  min-height:640px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 78% 22%,rgba(239,85,139,.2),rgba(239,85,139,0) 28%),
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.98) 34%,rgba(235,241,248,.66) 58%,rgba(235,241,248,.14) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds7.jpg') right center / cover no-repeat;
}
.hero-resources{
  background:
    radial-gradient(circle at 78% 22%,rgba(239,85,139,.18),rgba(239,85,139,0) 28%),
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.98) 34%,rgba(235,241,248,.66) 58%,rgba(235,241,248,.14) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds9.jpg') right center / cover no-repeat;
}
.hero-roundtable{
  background:
    radial-gradient(circle at 76% 18%,rgba(239,85,139,.16),rgba(239,85,139,0) 28%),
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.97) 35%,rgba(235,241,248,.62) 60%,rgba(235,241,248,.12) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds5.jpg') right center / cover no-repeat;
}
.hero-company{
  background:
    radial-gradient(circle at 78% 22%,rgba(239,85,139,.12),rgba(239,85,139,0) 28%),
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.98) 36%,rgba(235,241,248,.7) 60%,rgba(235,241,248,.16) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds10.png') right center / cover no-repeat;
}
.hero-platform::before{
  content:"";
  position:absolute;
  inset:auto -8% -34% 46%;
  height:68%;
  pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(14,27,44,.16),rgba(14,27,44,0) 62%);
  z-index:1;
}
.hero-platform::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.26),rgba(255,255,255,0) 32%,rgba(14,27,44,.06));
  z-index:1;
}
.hero-platform-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(420px,1.1fr);
  gap:clamp(40px,6vw,88px);
  align-items:center;
}
.hero-platform-copy{min-width:0}
.hero-platform h1{font-size:clamp(52px,6.2vw,92px);max-width:none;line-height:.96}
/* Solutions pages: long headline copy needs tighter size + readable line-height */
.hero-platform-copy h1:not(.display){
  font-size:clamp(26px,3.2vw,44px);
  line-height:1.22;
  letter-spacing:-.016em;
  font-weight:700;
  max-width:600px;
  margin-top:8px;
}
.hero-platform:has(.breadcrumbs a[href="/solutions/"]) .hero-platform-copy h1:not(.display) em{
  color:var(--coral-deep);
  font-style:italic;
}
.hero-platform .sub{font-size:clamp(17px,1.45vw,21px);line-height:1.58;max-width:540px}
.hero-platform-media{
  min-width:0;
  align-self:start;
  position:relative;
}
.hero-platform-media::before{
  content:"";
  position:absolute;
  left:6%;
  right:2%;
  bottom:2%;
  height:18%;
  background:radial-gradient(ellipse at center,rgba(14,27,44,.26),rgba(14,27,44,0) 70%);
  filter:blur(10px);
  pointer-events:none;
}
.hero-platform-media img{
  position:relative;
  display:block;
  width:100%;
  height:auto;
  filter:drop-shadow(0 44px 70px rgba(14,27,44,.24));
}
.hero-editorial{min-height:0}
.hero-editorial .hero-platform-grid{
  grid-template-columns:minmax(0,.92fr) minmax(360px,1.08fr);
  align-items:start;
}
.hero-editorial .hero-platform-media{
  position:relative;
  align-self:stretch;
  overflow:hidden;
}
.hero-editorial .hero-platform-media img{
  position:absolute;
  bottom:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center bottom;
  filter:none;
}
.hero-company .hero-platform-media img{object-position:center 42%}
.hero-company h1{
  font-size:clamp(38px,4.9vw,72px);
  line-height:1;
  max-width:12ch;
}
.hero-company h1 em,
.hero-roundtable h1 em{
  color:var(--coral-deep);
  font-style:italic;
}
.hero-data-card{background:linear-gradient(135deg,var(--ink),rgba(14,27,44,.88));border-radius:16px;padding:28px 32px;display:flex;flex-direction:column;gap:0;box-shadow:0 44px 70px rgba(14,27,44,.24);overflow:hidden;position:relative}
.hero-data-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(255,107,74,.2),transparent 55%);pointer-events:none}
.hero-data-row{position:relative;display:flex;flex-direction:column;gap:4px;padding:22px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.hero-data-row:last-child{border-bottom:none}
.hero-data-row .n{font-size:clamp(36px,3.8vw,52px);font-weight:700;letter-spacing:-.025em;color:var(--paper);line-height:1;margin:0}
.hero-data-row .n em{color:var(--coral);font-style:normal}
.hero-data-row .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.5);margin:6px 0 0}
.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)}
.sol-split{
  display:grid;
  grid-template-columns:1fr minmax(280px,44%);
  gap:clamp(40px,6vw,80px);
  align-items:center;
}
.sol-split:not(:has(.sol-split-img img)){
  grid-template-columns:1fr;
}
.sol-split--media-left{
  grid-template-columns:minmax(280px,44%) 1fr;
}
.sol-split-copy{
  display:flex;
  flex-direction:column;
}
.sol-split-copy .display{
  margin:0 0 clamp(20px,3vw,36px);
}
.sol-split-copy .outcomes-list{
  margin-top:0;
}
.sol-split-img{
  margin:0;
  border-radius:12px;
  overflow:hidden;
}
.sol-split-img img{
  display:block;
  width:100%;
  height:auto;
  border-radius:12px;
}

/* -------- OUTCOMES LIST (solutions pages) -------------------------------- */
.outcomes-list{
  list-style:none;
  padding:0;
  margin:0;
  counter-reset:outcome;
  max-width:780px;
}
.outcomes-list li{
  counter-increment:outcome;
  padding:20px 0 20px 48px;
  border-bottom:1px solid var(--hair);
  font-size:17px;
  line-height:1.6;
  color:var(--ink-2);
  position:relative;
}
.outcomes-list li:first-child{border-top:1px solid var(--hair)}
.outcomes-list li::before{
  content:counter(outcome);
  position:absolute;
  left:0;
  top:20px;
  font-family:var(--mono);
  font-size:14px;
  font-weight:700;
  color:var(--coral);
}

/* -------- STANDALONE CALLOUT BLOCK (solutions pages) --------------------- */
.callout-block{
  max-width:780px;
  padding:28px 32px;
  border-left:3px solid var(--coral);
  background:rgba(239,85,139,.03);
  border-radius:0 8px 8px 0;
  margin-top:32px;
}
.callout-block p{
  font-size:16px;
  line-height:1.65;
  color:var(--ink-2);
  margin:0 0 12px;
}
.callout-block p:last-child{margin-bottom:0}

.approach-visual-grid{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(340px,1.05fr);
  gap:clamp(32px,5vw,72px);
  align-items:center;
}
.approach-visual-grid .manifesto-body{max-width:780px}
.approach-visual{
  margin:0;
  border-radius:16px;
  overflow:hidden;
  background:transparent;
  box-shadow:none;
}
.approach-visual img{
  display:block;
  width:100%;
  height:auto;
}

/* ── Branded conversion visuals (stat panel + feature stack) ─────────── */
.brand-stat-panel{
  background:var(--ink);
  border-radius:16px;
  padding:clamp(28px,3.5vw,48px);
  display:flex;
  flex-direction:column;
  gap:0;
  justify-content:center;
  width:100%;
  box-sizing:border-box;
  align-self:stretch;
}
.brand-stat-panel .bsp-item{
  padding:20px 0;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.brand-stat-panel .bsp-item:first-child{padding-top:0}
.brand-stat-panel .bsp-item:last-child{border-bottom:0;padding-bottom:0}
.brand-stat-panel .bsp-n{
  display:block;
  font-size:clamp(36px,4.5vw,64px);
  font-weight:700;
  line-height:1;
  color:var(--coral);
  letter-spacing:-.03em;
  margin-bottom:6px;
}
.brand-stat-panel .bsp-label{
  display:block;
  font-size:clamp(13px,1.1vw,16px);
  color:rgba(255,255,255,.85);
  line-height:1.45;
}
.brand-feature-stack{
  display:flex;
  flex-direction:column;
  gap:10px;
  justify-content:center;
  width:100%;
  box-sizing:border-box;
  align-self:stretch;
}
.brand-feature-stack .bfs-item{
  display:flex;
  flex-direction:column;
  padding:18px 22px;
  border-radius:10px;
  background:var(--ink);
  border-left:3px solid var(--coral);
}
.brand-feature-stack .bfs-title{
  font-weight:600;
  font-size:clamp(14px,1.1vw,16px);
  margin:0 0 5px;
  color:#fff;
  display:block;
}
.brand-feature-stack .bfs-desc{
  font-size:clamp(13px,1vw,15px);
  color:rgba(255,255,255,.75);
  line-height:1.5;
  margin:0;
}
/* ─────────────────────────────────────────────────────────────────────── */

.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{display:none}
.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(255,255,255,.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(255,255,255,.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(255,255,255,.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}
.team-grid--6{grid-template-columns:repeat(3,1fr)}
@media(max-width:700px){.team-grid--6{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid--6{grid-template-columns:1fr}}
.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(255,255,255,.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;background:none;display:block;padding:0;transition:none}
.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(255,255,255,.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(255,255,255,.25)}
.careers .btn-secondary:hover{background:rgba(255,255,255,.08)}
.roles{display:flex;flex-direction:column;gap:2px;background:rgba(255,255,255,.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(255,255,255,.6);margin-top:3px}
.role .loc{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.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(255,255,255,.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(255,255,255,.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(255,255,255,.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)}

.hp-field{position:absolute;left:-9999px;opacity:0;pointer-events:none;tab-size:0}
.form-status{display:none;padding:14px 16px;border-radius:9px;font-size:14px;margin-top:12px}
.form-status[hidden]{display:none}
.form-status--ok{background:rgba(34,137,82,.1);border:1px solid rgba(34,137,82,.25);color:#176a3a;display:block}
.form-status--err{background:rgba(220,53,53,.08);border:1px solid rgba(220,53,53,.2);color:#b91c1c;display:block}

.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:clamp(72px,7vw,104px) 0 clamp(72px,7vw,104px);
  min-height:640px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 78% 22%,rgba(239,85,139,.2),rgba(239,85,139,0) 28%),
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.98) 34%,rgba(235,241,248,.66) 58%,rgba(235,241,248,.14) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds7.jpg') right center / cover no-repeat;
  color:var(--ink);
}
.hero-ind::before{
  content:"";
  position:absolute;
  inset:auto -8% -34% 46%;
  height:68%;
  pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(14,27,44,.16),rgba(14,27,44,0) 62%);
  z-index:2;
}
.hero-ind::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(180deg,rgba(255,255,255,.28),rgba(255,255,255,0) 32%,rgba(14,27,44,.07)),
    radial-gradient(circle at 83% 12%,rgba(235,241,248,.5),rgba(235,241,248,0) 22%);
  z-index:1;
}
.hero-ind .wrap{
  position:relative;
  z-index:4;
}
.hero-ind .wrap::before,.hero-ind .wrap::after{display:none}
.hero-ind h1{margin:16px 0 0;font-size:clamp(52px,6.2vw,92px);max-width:11ch;line-height:.96;color:var(--ink)}
.hero-ind h1 em{color:var(--coral-deep)}
.hero-ind .sub{margin-top:28px;max-width:610px;font-size:clamp(17px,1.45vw,21px);line-height:1.58;color:var(--ink-2)}
.hero-ind-grid{display:grid;grid-template-columns:1fr minmax(0,460px);gap:clamp(40px,5vw,80px);align-items:center;margin-bottom:clamp(40px,5vw,64px)}
.hero-ind-media{position:relative;min-width:0}
.hero-ind-media img{display:block;width:100%;max-height:420px;object-fit:contain;object-position:center bottom}
.hero-ind-stones{
  position:absolute;
  width:30%;
  bottom:-12%;
  right:-2%;
  transform:rotate(16deg);
  pointer-events:none;
  z-index:2;
}

.industry-glide{
  position:relative;
  margin-top:clamp(56px,6vw,84px);
  padding:0 0 48px;
  width:100%;
  overflow:hidden;
  border:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.js .industry-glide .glide__track{
  overflow:hidden;
}
.industry-glide-controls{
  position:absolute;
  left:0;
  bottom:0;
  display:none;
  gap:8px;
}
.js .industry-glide-controls{
  display:flex;
}
.industry-glide-btn{
  width:38px;
  height:38px;
  border:0;
  border-radius:0;
  display:grid;
  place-items:center;
  background:var(--ink);
  color:var(--paper);
  cursor:pointer;
  transition:background .18s,transform .18s;
}
.industry-glide-btn:hover,
.industry-glide-btn:focus-visible{
  background:var(--coral-deep);
  transform:translateY(-1px);
}
.industry-glide-btn .material-icons{
  font-size:18px;
}
.ind-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  background:transparent;
  border:0;
  border-radius:0;
  overflow:visible;
  margin-top:clamp(30px,3.8vw,44px);
  color:var(--ink);
  box-shadow:none;
}
.industry-glide .ind-grid{
  margin-top:0;
}
.js .industry-glide .ind-grid{
  display:flex;
  gap:0;
}
.js .industry-glide .glide__slides{
  transition-timing-function:linear!important;
}
.ind{
  --ind-art:url('/assets/img/Coloured squares/Dark Blue.jpg');
  background:#fff;
  padding:76px 24px 24px;
  min-height:232px;
  display:flex;
  flex-direction:column;
  gap:12px;
  position:relative;
  isolation:isolate;
  overflow:hidden;
  transition:background .2s,color .2s,box-shadow .2s,transform .2s;
  color:inherit;
  border:0;
  box-shadow:0 18px 50px -44px rgba(14,27,44,.48);
}
.js .industry-glide .ind{
  height:100%;
}
.ind:nth-child(2){--ind-art:url('/assets/img/Coloured squares/Orange.jpg')}
.ind:nth-child(3){--ind-art:url('/assets/img/Coloured squares/Purple.jpg')}
.ind:nth-child(4){--ind-art:url('/assets/img/Coloured squares/Frame 28.jpg')}
.ind:nth-child(5){--ind-art:url('/assets/img/Coloured squares/Pink.jpg')}
.ind:nth-child(6){--ind-art:url('/assets/img/Coloured squares/Fresh green.jpg')}
.ind:nth-child(7){--ind-art:url('/assets/img/Coloured squares/Frame 30.jpg')}
.ind::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:56px;
  background:var(--ind-art) center / cover no-repeat;
  z-index:0;
  opacity:.94;
  transform:scale(1);
  transform-origin:center;
  transition:height .28s ease,opacity .28s ease,transform .28s ease;
}
.ind:hover{background:#fff}
.ind:hover,
.ind:focus-visible{
  box-shadow:0 28px 64px -42px rgba(14,27,44,.56);
}
.ind:hover::before,
.ind:focus-visible::before{
  height:62px;
  opacity:1;
  transform:scale(1.025);
}
.ind-border-line{
  position:absolute;
  z-index:2;
  display:block;
  background:var(--coral);
  pointer-events:none;
}
.ind-border-line.top,
.ind-border-line.bottom{
  left:0;
  right:0;
  height:1px;
  transform:scaleX(0);
}
.ind-border-line.top{top:0;transform-origin:left center}
.ind-border-line.bottom{bottom:0;transform-origin:right center}
.ind-border-line.left,
.ind-border-line.right{
  top:0;
  bottom:0;
  width:1px;
  transform:scaleY(0);
}
.ind-border-line.left{left:0;transform-origin:center bottom}
.ind-border-line.right{right:0;transform-origin:center top}
.ind .top-row{
  position:absolute;
  top:14px;
  left:20px;
  right:20px;
  z-index:2;
  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:34px;height:34px;border-radius:0;background:rgba(255,255,255,.9);display:grid;place-items:center;font-family:var(--sans);font-style:italic;font-weight:700;font-size:20px;color:var(--ink);box-shadow:0 14px 34px -28px rgba(14,27,44,.55);backdrop-filter:blur(8px)}
.ind .ic .material-icons{font-size:18px;font-style:normal;font-weight:400;font-family:'Material Icons'}
.feat .ic .material-icons{font-size:20px;font-style:normal;font-weight:400;font-family:'Material Icons'}
.ind h2,
.ind h3{position:relative;z-index:1;margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h4);line-height:1.08;letter-spacing:-.015em}
.ind p{position:relative;z-index:1;margin:0;color:var(--ink-3);font-size:13px;line-height:1.45}
.ind .ind-cta{position:relative;z-index:1;margin-top:auto;padding-top:12px;border-top:1px solid var(--hair);display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--coral-deep);transition:color .18s}
.ind .ind-cta .arr{display:inline-block;font-size:15px;transition:transform .18s}
.ind:hover .ind-cta .arr{transform:translateX(5px)}
.ind::after{content:'↗';position:absolute;top:20px;right:22px;z-index:2;font-size:13px;color:rgba(255,255,255,.9);opacity:0;transform:translate(-3px,3px);transition:opacity .2s,transform .2s;pointer-events:none}
.ind:hover::after{opacity:1;transform:translate(0,0)}

.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(255,255,255,.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(255,255,255,.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(255,255,255,.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(255,255,255,.25)}
.featured .btn-secondary:hover{background:rgba(255,255,255,.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:0;padding:36px;display:flex;flex-direction:column;gap:18px;position:relative;overflow:hidden}
.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;transition:color .18s;position:relative;overflow:hidden}
.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;transition:transform .18s,background .18s}
.dl-item:hover .arr{background:var(--coral-deep);transform:translateX(3px)}

/* ==========================================================================
   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)}

/* ---- Article / roundtable detail ---------------------------------------- */
.art-cover{border-radius:16px;min-height:clamp(200px,28vw,340px);position:relative;overflow:hidden;padding:clamp(28px,4vw,56px);display:flex;flex-direction:column;justify-content:flex-end;margin-bottom:40px}
.art-cover .badge{position:absolute;top:clamp(20px,2.5vw,32px);left:clamp(28px,4vw,56px);font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px;backdrop-filter:blur(8px)}
.art-cover.cov-a .badge,.art-cover.cov-b .badge,.art-cover.cov-d .badge{background:rgba(14,27,44,.12);color:var(--ink);border:1px solid rgba(14,27,44,.2)}
.art-cover.cov-c .badge{background:rgba(255,255,255,.15);color:var(--paper);border:1px solid rgba(255,255,255,.25)}
.art-cover-title{margin:0;font-size:clamp(32px,4.8vw,68px);line-height:.97}
.art-cover .art-cover-title{max-width:none}
.art-meta{display:flex;gap:20px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);padding:24px 0 28px;border-bottom:1px solid var(--hair);margin-bottom:32px}
.art-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.art-tag{display:inline-block;padding:4px 12px;border-radius:999px;background:rgba(14,27,44,.07);color:var(--ink-3);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.art-lede{font-size:clamp(18px,1.55vw,22px);line-height:1.55;color:var(--ink-2);max-width:760px;margin:0 0 48px;font-weight:400}
.article-body{max-width:720px;font-size:17px;line-height:1.75;color:var(--ink)}
.article-body h2{font-size:clamp(22px,2vw,28px);margin:2em 0 .6em;line-height:1.2}
.article-body h3{font-size:clamp(18px,1.6vw,22px);margin:1.8em 0 .5em}
.article-body p{margin:0 0 1.25em}
.article-body ul,.article-body ol{margin:0 0 1.25em 1.5em;padding:0}
.article-body li{margin-bottom:.4em}
.article-body blockquote{margin:2em 0;padding:24px 32px;border-left:4px solid var(--coral);background:rgba(14,27,44,.03);border-radius:0 8px 8px 0;font-size:18px;font-style:italic;color:var(--ink-2)}
.article-body a{color:var(--coral-deep);text-decoration:underline}
.article-body img{max-width:100%;border-radius:8px;margin:1.5em 0}
.art-author{display:flex;align-items:flex-start;gap:20px;padding:32px 0;border-top:1px solid var(--hair);margin-top:56px}
.art-author img{border-radius:50%;flex-shrink:0;object-fit:cover;width:72px;height:72px}
.art-author-name{font-weight:600;margin:0}
.art-author-job{color:var(--ink-3);font-size:14px;margin:2px 0 8px}
.art-author-bio{font-size:15px;color:var(--ink-2)}
.art-author-bio p{margin:0 0 .5em}
.art-author-link{font-size:13px;color:var(--coral-deep)}
/* Roundtable detail accordions */
.rt-accordions{margin:40px 0;border-top:1px solid var(--hair)}
.rt-acc{border-bottom:1px solid var(--hair)}
.rt-acc-trigger{display:flex;justify-content:space-between;align-items:center;padding:20px 0;font-size:16px;font-weight:600;cursor:pointer;list-style:none;color:var(--ink);user-select:none}
.rt-acc-trigger::-webkit-details-marker{display:none}
.rt-acc-trigger::after{content:"";display:block;width:20px;height:20px;flex-shrink:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 8l5 5 5-5' stroke='%230e1b2c' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;transition:transform .2s}
.rt-acc[open] .rt-acc-trigger::after{transform:rotate(180deg)}
.rt-acc-body{padding:0 0 28px}
.rt-acc-body ul{margin:0;padding:0 0 0 20px;display:flex;flex-direction:column;gap:10px}
.rt-acc-body ul li{font-size:15px;color:var(--ink-2);line-height:1.6}
.rt-facilitator{margin-bottom:20px}
.rt-facilitator p{font-size:15px;color:var(--ink-2);line-height:1.65;margin:0}
.rt-facilitator strong{color:var(--ink)}
.rt-quote{margin:24px 0 0;padding:20px 24px;border-left:3px solid #F58628;background:rgba(245,134,40,.07);border-radius:0 8px 8px 0}
.rt-quote p{font-size:15px;font-style:italic;color:var(--ink-2);margin:0 0 8px;line-height:1.65}
.rt-quote cite{font-size:13px;font-style:normal;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}
/* Shared structure */
.art-rt-cta{border-radius:16px;padding:clamp(40px,5vw,64px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,56px);align-items:center}
.art-rt-cta h2{margin:14px 0 0;font-size:var(--fs-h2)}
.art-rt-cta h2 em{font-style:italic}
.art-rt-cta > div > p{margin-top:16px;font-size:16px;line-height:1.6}
.art-rt-cta .session-label{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px}
.art-rt-cta .session-title{font-size:clamp(18px,1.6vw,22px);font-weight:600;margin:0 0 12px;line-height:1.25}
.art-rt-cta .session-meta{font-family:var(--mono);font-size:11px;letter-spacing:.05em;margin:0 0 28px}
/* Platform — dark ink */
.art-rt-cta--platform{background:var(--ink);color:var(--paper)}
.art-rt-cta--platform h2 em{color:var(--coral)}
.art-rt-cta--platform > div > p{color:rgba(255,255,255,.7)}
.art-rt-cta--platform .section-label{color:rgba(255,255,255,.5)}
.art-rt-cta--platform .session-label{color:rgba(255,255,255,.45)}
.art-rt-cta--platform .session-title{color:var(--paper)}
.art-rt-cta--platform .session-meta{color:rgba(255,255,255,.5)}
.art-rt-cta--platform .btn-primary{background:var(--coral);color:var(--paper)}
.art-rt-cta--platform .btn-primary:hover{background:var(--coral-deep)}
/* Solution — sky blue */
.art-rt-cta--solution{background:#32B6CC;color:var(--ink)}
.art-rt-cta--solution h2 em{color:var(--ink-2)}
.art-rt-cta--solution > div > p{color:rgba(14,27,44,.72)}
.art-rt-cta--solution .section-label{color:rgba(14,27,44,.55)}
.art-rt-cta--solution .session-label{color:rgba(14,27,44,.5)}
.art-rt-cta--solution .session-title{color:var(--ink)}
.art-rt-cta--solution .session-meta{color:rgba(14,27,44,.55)}
.art-rt-cta--solution .btn-primary{background:var(--ink);color:var(--paper)}
.art-rt-cta--solution .btn-primary:hover{background:var(--ink-2)}
/* Roundtable — purple */
.art-rt-cta--roundtable{background:#7C499C;color:var(--paper)}
.art-rt-cta--roundtable h2 em{color:rgba(255,255,255,.75)}
.art-rt-cta--roundtable > div > p{color:rgba(255,255,255,.72)}
.art-rt-cta--roundtable .section-label{color:rgba(255,255,255,.5)}
.art-rt-cta--roundtable .session-label{color:rgba(255,255,255,.45)}
.art-rt-cta--roundtable .session-title{color:var(--paper)}
.art-rt-cta--roundtable .session-meta{color:rgba(255,255,255,.5)}
.art-rt-cta--roundtable .btn-primary{background:var(--paper);color:#7C499C}
.art-rt-cta--roundtable .btn-primary .arr{background:#7C499C;color:var(--paper)}
.art-rt-cta--roundtable .btn-primary:hover{background:rgba(255,255,255,.88)}
/* Roundtable form sidebar layout */
.rt-layout{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:clamp(40px,5vw,72px);align-items:start;margin-top:8px}
.rt-form-aside{position:sticky;top:32px}
.rt-form-card{padding:40px;border-radius:16px;background:var(--ink)}
@media(max-width:1000px){.rt-layout{grid-template-columns:1fr}.rt-form-aside{position:static}}
/* Article body grid + sidebar */
.art-body-grid{display:grid;grid-template-columns:minmax(0,1fr);align-items:start}
.art-body-grid.has-sidebar{grid-template-columns:minmax(0,1fr) 340px;gap:clamp(40px,4vw,72px)}
.art-sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:32px}
.art-sidebar .art-rt-cta{grid-template-columns:1fr;padding:28px 24px;gap:16px}
.art-sidebar .art-rt-cta h2{font-size:clamp(17px,1.5vw,22px);margin-top:10px}
.art-sidebar .art-rt-cta > div > p{font-size:14px;margin-top:10px;line-height:1.55}
.art-sidebar .art-rt-cta .session-title{font-size:16px}
.art-sidebar .art-rt-cta .btn-primary{margin-top:4px}
@media(max-width:960px){.art-body-grid.has-sidebar{grid-template-columns:1fr;gap:32px}.art-sidebar{position:static}}

.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(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:14px;backdrop-filter:blur(12px);font-size:11.5px;font-family:var(--mono);letter-spacing:.04em;color:rgba(255,255,255,.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(255,255,255,.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(255,255,255,.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(255,255,255,.25)}
.featured-ins-body .btn-secondary:hover{background:rgba(255,255,255,.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}
#tp-upcoming .ic,
#tp-past .ic,
#tp-grid .ic{
  position:relative;
  isolation:isolate;
  box-shadow:0 18px 46px -34px rgba(14,27,44,.5);
  transition:transform .18s,box-shadow .18s;
}
#tp-upcoming .ic:hover,
#tp-past .ic:hover,
#tp-grid .ic:hover{
  transform:translateY(-2px);
  box-shadow:0 28px 64px -38px rgba(14,27,44,.58);
}
.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;top: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}
.resource-card .ic-body{gap:14px}
.resource-tags{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-bottom:2px;
}
.resource-tag{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(239,85,139,.08);
  color:var(--coral-deep);
  box-shadow:inset 0 0 0 1px rgba(239,85,139,.18);
  font-family:var(--mono);
  font-size:10px;
  line-height:1;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.resource-card .ic-meta{
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-start;
  line-height:1.45;
}
.resource-card .ic-meta b{
  color:var(--ink);
  font-weight:700;
}
.resource-card-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:max-content;
  color:var(--ink);
  font-size:13px;
  font-weight:700;
}
.resource-card-link:hover{color:var(--coral-deep)}
.rt-card .ic-body{gap:14px}
.rt-card-details{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  margin:2px 0 0;
}
.rt-card-detail{
  display:grid;
  grid-template-columns:72px minmax(0,1fr);
  gap:12px;
  align-items:baseline;
  padding:10px 0;
  border-top:1px solid var(--hair);
}
.rt-card-detail:first-child{border-top:0;padding-top:0}
.rt-card-detail dt{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--coral-deep);
}
.rt-card-detail dd{
  margin:0;
  color:var(--ink);
  font-size:14.5px;
  line-height:1.35;
  font-weight:700;
}
.rt-card-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:max-content;
  margin-top:auto;
  padding-top:8px;
  color:var(--ink);
  font-size:13px;
  font-weight:700;
}
.rt-card-link:hover{color:var(--coral-deep)}
.cov-a{background:#32B6CC;color:var(--ink)}
.cov-a .badge{background:rgba(14,27,44,.12);color:var(--ink);border:1px solid rgba(14,27,44,.2)}
.cov-a .read{color:rgba(14,27,44,.6)}
.cov-b{background:#9CCB3B;color:var(--ink)}
.cov-b .badge{background:rgba(14,27,44,.12);color:var(--ink);border:1px solid rgba(14,27,44,.2)}
.cov-b .read{color:rgba(14,27,44,.6)}
.cov-c{background:#7C499C;color:var(--paper)}
.cov-c .badge{background:rgba(255,255,255,.15);color:var(--paper);border:1px solid rgba(255,255,255,.25)}
.cov-c .read{color:rgba(255,255,255,.8)}
.cov-d{background:#F58628;color:var(--ink)}
.cov-d .badge{background:rgba(14,27,44,.12);color:var(--ink);border:1px solid rgba(14,27,44,.2)}
.cov-d .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(255,255,255,.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(255,255,255,.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(255,255,255,.55);margin-top:2px}
.rt-ins .list li .s{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.6);text-align:right}
.rt-ins .btn-primary{background:var(--coral);color:var(--paper)}
.rt-ins .btn-primary:hover{background:var(--coral-deep)}

/* === Roundtable Event Hero === */
.rt-hero{
  position:relative;
  background:
    linear-gradient(110deg,rgba(14,27,44,.97) 0%,rgba(14,27,44,.86) 52%,rgba(14,27,44,.54) 100%),
    url('/assets/img/Coloured%20squares/Frame%2028.jpg') center / cover no-repeat;
  color:var(--paper);
  padding:clamp(64px,9vh,112px) 0 clamp(72px,10vh,120px);
  overflow:hidden;
}
.rt-hero .hero-se-crumb{color:rgba(255,255,255,.48)}
.rt-hero .hero-se-crumb a:hover{color:var(--paper)}
.rt-hero .hero-se-crumb [aria-current="page"]{color:rgba(255,255,255,.7)}
.rt-hero-grid{
  display:grid;
  grid-template-columns:1fr minmax(280px,360px);
  gap:clamp(40px,6vw,80px);
  align-items:center;
  margin-top:clamp(28px,4vh,48px);
}
.rt-hero-copy{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}
.rt-hero-copy .badge{
  width:max-content;
  margin-bottom:22px;
  color:var(--paper);
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.2);
}
.rt-hero-copy .badge.rt-hero-badge-past{
  background:rgba(239,85,139,.12);
  border-color:rgba(239,85,139,.35);
  color:var(--coral);
}
.rt-hero-title{
  margin:0 0 14px;
  font-size:clamp(36px,5vw,72px);
  line-height:.96;
  letter-spacing:-.025em;
  color:var(--paper);
  max-width:none;
}
.rt-hero-theme{
  margin:0 0 clamp(20px,3vw,32px);
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--coral);
}
.rt-hero-chips{
  list-style:none;
  padding:0;
  margin:0 0 clamp(24px,3.5vw,40px);
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.rt-hero-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 16px;
  border-radius:100px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.07);
  font-size:13.5px;
  font-weight:500;
  color:rgba(255,255,255,.9);
  white-space:nowrap;
}
.rt-hero-chip-k{
  font-family:var(--mono);
  font-size:9.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.45);
  padding-right:6px;
  border-right:1px solid rgba(255,255,255,.18);
  margin-right:2px;
}
.rt-hero-actions{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:14px 22px;
}
.rt-hero-back{
  font-size:13px;
  font-weight:600;
  color:rgba(255,255,255,.58);
  text-decoration:none;
}
.rt-hero-back:hover{color:var(--paper)}
.rt-hero-panel{
  background:rgba(14,27,44,.82);
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  padding:clamp(28px,3.5vw,44px);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  box-shadow:0 40px 100px -50px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.1);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}
.rt-hero-panel-label{
  margin:0 0 22px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--coral);
}
.rt-hero-date-display{
  margin:0 0 22px;
  padding-bottom:22px;
  border-bottom:1px solid rgba(255,255,255,.12);
  width:100%;
}
.rt-hero-day{
  display:block;
  font-size:clamp(72px,8vw,108px);
  font-weight:800;
  line-height:.88;
  letter-spacing:-.04em;
  color:var(--paper);
}
.rt-hero-weekday{
  display:block;
  margin-top:10px;
  font-size:clamp(18px,2vw,26px);
  font-weight:700;
  line-height:1.1;
  letter-spacing:-.015em;
  color:var(--paper);
}
.rt-hero-monthyr{
  display:block;
  margin-top:4px;
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
}
.rt-hero-meta{
  display:flex;
  flex-direction:column;
  gap:11px;
  margin-bottom:26px;
  width:100%;
}
.rt-hero-meta-row{
  display:flex;
  align-items:center;
  gap:11px;
  font-size:14.5px;
  color:rgba(255,255,255,.8);
  line-height:1.3;
}
.rt-hero-meta-dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--coral);
  flex-shrink:0;
}
.rt-hero-panel .btn{
  width:100%;
  justify-content:center;
}
/* Body section below hero */
.rt-body{
  padding:clamp(56px,7vw,96px) 0 clamp(80px,10vw,140px);
}
.rt-body-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,400px);
  gap:clamp(34px,5vw,72px) clamp(40px,6vw,88px);
  align-items:start;
}
.rt-event-main{min-width:0}
.rt-event-summary{
  max-width:780px;
  padding-top:36px;
  border-top:1px solid var(--hair);
}
.rt-event-summary h2{
  margin:0 0 18px;
  font-size:var(--fs-h3);
  line-height:1.08;
  letter-spacing:-.015em;
}
.rt-event-summary p,
.rt-event-summary li{
  font-size:17px;
  line-height:1.72;
  color:var(--ink-2);
}
.rt-event-summary p{margin:0 0 18px}
.rt-event-summary ul,
.rt-event-summary ol{margin:18px 0 0;padding-left:22px}
.rt-event-panel{
  position:sticky;
  top:96px;
  padding:34px;
  border-radius:12px;
  background:
    linear-gradient(180deg,rgba(14,27,44,.94),rgba(14,27,44,.88)),
    url('/assets/img/Coloured%20squares/Dark%20Blue.jpg') center / cover no-repeat;
  color:var(--paper);
  box-shadow:0 32px 86px -54px rgba(14,27,44,.72), inset 0 0 0 1px rgba(255,255,255,.12);
}
.rt-event-panel-k{
  margin:0 0 12px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--coral);
}
.rt-event-panel h2{
  margin:0;
  font-size:clamp(26px,2.6vw,36px);
  line-height:1.04;
  letter-spacing:-.015em;
}
.rt-event-panel-p{
  margin:16px 0 28px;
  color:rgba(255,255,255,.72);
  font-size:15px;
  line-height:1.6;
}
.rt-event-panel .btn{width:100%;justify-content:center;margin-top:8px}
.rt-event-panel .btn-secondary{
  color:var(--paper);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.25);
}
.rt-event-back{
  display:inline-flex;
  margin-top:22px;
  color:rgba(255,255,255,.62);
  font-size:13px;
  font-weight:600;
}
.rt-event-back:hover{color:var(--paper)}
.rt-event-panel #tp-hs-form{
  margin-top:22px;
  color:var(--paper);
}
.rt-event-info{
  list-style:none;
  padding:0;
  margin:28px 0 36px;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.rt-event-info-item{
  display:flex;
  flex-direction:column;
  gap:5px;
  padding:14px 18px;
  border-radius:10px;
  background:var(--paper-2,#f7f7f8);
  border:1px solid var(--hair);
  min-width:130px;
}
.rt-event-info-label{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.rt-event-info-value{
  font-size:15px;
  font-weight:600;
  color:var(--ink);
  line-height:1.3;
}

.rt-next-session-section{
  padding-top:clamp(28px,4vw,52px);
  padding-bottom:clamp(56px,7vw,88px);
}
.rt-next-session-section .display{
  margin-bottom:32px;
}
.rt-next-session-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:clamp(24px,4vw,48px) clamp(28px,5vw,72px);
  align-items:end;
  padding:clamp(36px,5vw,64px);
  border-radius:14px;
  background:#32B6CC;
  color:var(--ink);
  box-shadow:0 18px 46px -34px rgba(14,27,44,.5);
  overflow:hidden;
  position:relative;
  transition:transform .18s,box-shadow .18s;
}
.rt-next-session-card:hover{
  transform:translateY(-2px);
  box-shadow:0 28px 64px -38px rgba(14,27,44,.58);
}
.rt-next-session-copy,
.rt-next-session-action{
  position:relative;
  z-index:1;
}
.rt-next-session-cover{
  position:absolute;
  inset:0;
  min-height:0;
  z-index:0;
}
.rt-next-session-cover .badge{
  position:absolute;
  left:clamp(36px,5vw,64px);
  top:clamp(28px,4vw,44px);
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:5px 10px;
  border-radius:999px;
  backdrop-filter:blur(8px);
}
.rt-next-session-title{
  margin:42px 0 0;
  max-width:860px;
  color:var(--paper);
  font-size:clamp(42px,5.2vw,72px);
  line-height:.98;
}
.rt-next-session-details{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:28px 0 0;
  max-width:860px;
}
.rt-next-session-detail{
  padding:18px 20px;
  border-radius:10px;
  background:var(--white);
  box-shadow:0 18px 40px -32px rgba(14,27,44,.45);
}
.rt-next-session-detail dt{
  margin:0 0 6px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--coral-deep);
}
.rt-next-session-detail dd{
  margin:0;
  color:var(--ink);
  font-size:clamp(18px,1.7vw,24px);
  line-height:1.25;
  font-weight:700;
}
.rt-next-session-summary{
  margin:18px 0 0;
  max-width:620px;
  color:rgba(255,255,255,.84);
  font-size:16px;
  line-height:1.6;
}
.rt-next-session-action{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}
.rt-next-session-action .btn{
  min-width:170px;
  justify-content:center;
  background:var(--paper);
  color:var(--ink);
}
.rt-next-session-action .btn .arr{
  background:var(--ink);
  color:var(--paper);
}

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

/* ==========================================================================
   COMPONENT: Solution page hero — split layout
   ========================================================================== */

/* Section wrapper */
.hero-se{
  position:relative;
  background:url('/assets/img/Coloured%20squares/Purple.jpg') center / cover no-repeat;
  overflow:hidden;
  border-bottom:1px solid #e8e8eb;
}
/* Soft coral radial tint — top-right atmosphere */
.hero-se::before{
  display:none;
}
/* Single-column grid: media panel removed from solution pages */
.hero-se-grid{
  display:grid;
  grid-template-columns:1fr;
  align-items:stretch;
  position:relative;
  z-index:1;
  gap:0;
}
/* Left: copy column */
.hero-se-copy{
  padding:clamp(52px,6.5vw,88px) clamp(32px,4vw,72px) clamp(60px,7vw,96px) 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  max-width:680px;
}
/* Breadcrumb */
.hero-se-crumb{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:4px 10px;
  list-style:none;
  padding:0;
  margin:0 0 clamp(28px,3.5vw,44px);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--paper);
}
.hero-se-crumb li{display:flex;align-items:center;gap:10px}
.hero-se-crumb li+li::before{content:"/";color:var(--paper)}
.hero-se-crumb a{color:inherit;text-decoration:none;transition:color .15s}
.hero-se-crumb a:hover{color:var(--paper)}
.hero-se-crumb [aria-current="page"]{color:var(--paper)}
/* H1 */
.hero-se h1{
  font-size:clamp(24px,3vw,42px);
  line-height:1.26;
  letter-spacing:-.018em;
  font-weight:700;
  color:var(--paper);
  margin:0 0 clamp(20px,2.5vw,32px);
  max-width:640px;
}
/* Highlighted statement — coral left-rule treatment */
.hero-se-pull{
  font-size:clamp(17px,1.8vw,24px);
  line-height:1.42;
  font-weight:700;
  color:var(--paper);
  border-left:3px solid var(--coral);
  padding-left:18px;
  margin:0 0 clamp(36px,4.5vw,56px);
  max-width:520px;
}
/* CTA row */
.hero-se-actions{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
/* Secondary text CTA */
.hero-se-link{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-size:13.5px;
  font-family:var(--mono);
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--paper);
  text-decoration:none;
  border-bottom:1px solid var(--paper);
  padding-bottom:2px;
  transition:color .15s,border-color .15s;
}
.hero-se-link::after{content:"→";font-family:inherit}
.hero-se-link:hover{color:var(--coral);border-color:var(--coral)}
/* Right: dark media panel */
.hero-se-media{
  margin:0;
  position:relative;
  background:transparent;
  overflow:hidden;
  min-height:480px;
}
/* Coral ground glow behind person */
.hero-se-media::after{
  display:none;
}
/* Subtle top fade so panel blends at join */
.hero-se-media::before{
  display:none;
}
/* Absolute bottom-anchor: feet always at the panel base regardless of panel height */
.hero-se-media img{
  display:block;
  position:absolute;
  bottom:0;
  right:0;
  z-index:2;
  height:100%;
  width:auto;
  max-width:none;
  opacity:.92;
}
.hero-se-person-layer{
  position:fixed;
  left:0;
  top:0;
  right:auto;
  bottom:auto;
  z-index:10;
  pointer-events:none;
  display:block;
  object-fit:contain;
  object-position:bottom center;
  opacity:.92;
}
.hero-se-person-layer.is-over-body{
  z-index:0;
  filter:saturate(.78) contrast(.94) drop-shadow(0 30px 52px rgba(14,27,44,.14));
}
body:has(.hero-se-person-layer.is-over-body) main .section,
body:has(.hero-se-person-layer.is-over-body) main .closing-prod{
  position:relative;
  z-index:1;
}
@media(max-width:800px){
  .hero-se-copy{padding:48px 0 56px;max-width:100%}
}

/* ==========================================================================
   PAGE: Solutions
   ========================================================================== */
.hero-sol{
  padding:clamp(72px,7vw,104px) 0 clamp(88px,8vw,124px);
  min-height:0;
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(135deg,rgba(239,85,139,.14),rgba(239,85,139,0) 34%),
    radial-gradient(circle at 86% 16%,rgba(14,27,44,.1),rgba(14,27,44,0) 30%),
    linear-gradient(180deg,rgba(235,241,248,.92) 0%,rgba(255,255,255,.85) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds9.jpg') center / cover no-repeat;
}
.hero-sol::before{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:1px;
  pointer-events:none;
  background:rgba(14,27,44,.1);
  z-index:2;
}
.hero-sol .wrap{position:relative;z-index:4}
.hero-sol-grid{display:grid;grid-template-columns:1fr minmax(0,480px);gap:clamp(40px,5vw,80px);align-items:center}
.hero-sol-copy{max-width:none}
.hero-sol h1{margin:14px 0 0;font-size:clamp(52px,7vw,104px);max-width:12ch;line-height:.94;text-wrap:balance}
.hero-sol .sub{margin-top:28px;max-width:600px;font-size:clamp(18px,1.6vw,22px);line-height:1.56;color:var(--ink-2)}
.hero-sol-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}
.hero-sol-media{position:relative;min-width:0}
.hero-sol-media img{display:block;width:100%}
.hero-sol-stones{
  position:absolute;
  width:46%;
  bottom:-22%;
  right:-6%;
  transform:rotate(22deg);
  pointer-events:none;
  z-index:3;
}
.hero-platform-stones{
  position:absolute;
  width:32%;
  bottom:-12%;
  right:-2%;
  transform:rotate(16deg);
  pointer-events:none;
  z-index:2;
}

/* Journey map stage labels — now links */
.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 a{padding:4px 10px;border-radius:999px;background:var(--white);box-shadow:inset 0 0 0 1px var(--hair);color:var(--ink-3);transition:background .15s,color .15s,box-shadow .15s}
.jm-ages a:hover{background:var(--ink);color:var(--paper);box-shadow:inset 0 0 0 1px var(--ink)}

.solution-hero-enhanced{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.97) 36%,rgba(235,241,248,.52) 60%,rgba(235,241,248,.06) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds7.jpg') right center / cover no-repeat;
}
.hero-ind-enhanced{
  background:
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.97) 36%,rgba(235,241,248,.52) 60%,rgba(235,241,248,.06) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds10.png') right center / cover no-repeat;
}
.hero-ind-dark{
  background:
    linear-gradient(105deg,#0E1B2C 0%,rgba(14,27,44,.97) 44%,rgba(14,27,44,.68) 68%,rgba(14,27,44,.12) 100%),
    url('/assets/img/BrandAssets/Infinity BackgroundDark.jpg') right center / cover no-repeat;
}
.hero-ind-dark.solution-hero-enhanced h1{
  font-size:clamp(36px,4.4vw,60px);
  font-weight:700;
  line-height:1.08;
  color:#fff;
  margin:0 0 18px;
}
.hero-ind-dark.solution-hero-enhanced h1 span:first-child{
  font-size:inherit;font-weight:inherit;color:inherit;line-height:inherit;
}
.hero-ind-dark.solution-hero-enhanced h1 span+span{display:none}
.hero-ind-dark .hero-sector-stat{display:none}
.hero-ind-sub{
  margin:0 0 30px;
  font-size:clamp(16px,1.4vw,19px);
  line-height:1.62;
  color:rgba(255,255,255,.52);
  max-width:520px;
}
.hero-ind-actions{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.hero-ind-link{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(255,255,255,.52);
  display:inline-flex;
  align-items:center;
  gap:5px;
  transition:color .18s;
}
.hero-ind-link:hover{color:#fff}
.hero-ind-proof{
  display:flex;
  gap:36px;
  margin-top:40px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.09);
  flex-wrap:wrap;
}
.hero-ind-proof-item{display:flex;flex-direction:column;gap:5px}
.hero-ind-proof-item strong{
  display:flex;
  align-items:baseline;
  gap:2px;
  font-family:var(--sans);
  font-size:clamp(24px,2.6vw,34px);
  font-weight:700;
  line-height:1;
  letter-spacing:-.02em;
  color:#fff;
}
.hero-ind-proof-unit{font-size:.62em;font-weight:600;opacity:.5}
.hero-ind-proof-item p{
  margin:0;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.07em;
  text-transform:uppercase;
  color:rgba(255,255,255,.36);
}
.hero-ind-dark.solution-hero-enhanced .breadcrumbs{
  background:rgba(255,255,255,.06);
  box-shadow:none;
  border:1px solid rgba(255,255,255,.1);
}
.hero-ind-dark.solution-hero-enhanced .breadcrumbs,
.hero-ind-dark.solution-hero-enhanced .breadcrumbs a,
.hero-ind-dark.solution-hero-enhanced .breadcrumbs [aria-current="page"]{color:rgba(255,255,255,.5)}
.hero-ind-dark .hero-sector-eyebrow{
  background:none;
  border-color:transparent;
  padding:0;
  color:rgba(255,255,255,.5);
  margin-bottom:16px;
}
.hero-ind-dark .hero-sector-chips{display:none}
.hero-sector-stat{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:0 10px;
  margin:20px 0 24px;
  padding-bottom:0;
  border-bottom:none;
}
.hero-ind-dark .hero-sector-stat{border-bottom-color:transparent}
.hero-sector-stat-n{
  font-family:var(--sans);
  font-size:clamp(44px,5.5vw,72px);
  font-weight:800;
  line-height:1;
  letter-spacing:-.03em;
  color:var(--coral-deep);
}
.hero-sector-stat-unit{
  font-family:var(--sans);
  font-size:clamp(28px,4vw,50px);
  font-weight:700;
  line-height:1;
  color:var(--coral-deep);
  opacity:.5;
}
.hero-sector-stat-label{
  flex:1 1 100%;
  margin:10px 0 0;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.07em;
  text-transform:uppercase;
  color:var(--ink-3);
  line-height:1.4;
  max-width:480px;
}
.hero-ind-dark .hero-sector-stat-label{color:rgba(255,255,255,.38)}
.hero-sector-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:7px;
  margin-bottom:20px;
  padding:6px 14px 6px 10px;
  border-radius:999px;
  background:rgba(14,27,44,.05);
  border:1px solid rgba(14,27,44,.1);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-2);
}
.hero-sector-eyebrow .material-icons{font-size:15px;color:var(--coral-deep)}
.hero-sector-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:24px;
}
.hero-sector-chips span{
  display:inline-flex;
  align-items:center;
  padding:5px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(14,27,44,.1);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.07em;
  text-transform:uppercase;
  color:var(--ink-2);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.solution-hero-enhanced::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:1px;
  background:rgba(14,27,44,.1);
}
.solution-hero-enhanced .wrap{
  position:relative;
  z-index:1;
}
.solution-hero-copy{
  padding-block:clamp(24px,3.4vw,40px);
}
.solution-hero-enhanced .breadcrumbs{
  width:fit-content;
  max-width:100%;
  padding:10px 14px;
  margin-bottom:20px;
  background:rgba(235,241,248,.82);
  box-shadow:0 14px 42px rgba(14,27,44,.06);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  color:rgba(14,27,44,.72);
}
.solution-hero-enhanced .breadcrumbs a,
.solution-hero-enhanced .breadcrumbs [aria-current="page"]{color:rgba(14,27,44,.84)}
.solution-hero-enhanced h1{
  max-width:none;
  margin:0;
  color:var(--ink);
  text-wrap:balance;
}
.solution-hero-enhanced h1 span{display:block}
.solution-hero-enhanced h1 span + span{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid rgba(14,27,44,.14);
  color:var(--coral-deep);
}
.solution-sticky-visual{
  position:absolute;
  z-index:4;
  right:clamp(24px,6vw,92px);
  bottom:0;
  width:min(34vw,430px);
  height:80%;
  max-height:calc(100vh - 96px);
  margin:0;
  pointer-events:none;
  transform-origin:50% 12%;
  filter:drop-shadow(0 34px 54px rgba(14,27,44,.2));
}
.solution-sticky-visual.is-scroll-layer{
  position:fixed;
  left:auto;
  top:auto;
  right:clamp(24px,6vw,92px);
  bottom:10vh;
  width:min(34vw,430px);
  height:80vh;
  max-height:calc(90vh - 96px);
}
.solution-sticky-visual img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:bottom center;
}
.solution-sticky-visual::after{
  content:"";
  position:absolute;
  left:18%;
  right:10%;
  bottom:5%;
  height:10%;
  background:radial-gradient(ellipse at center,rgba(14,27,44,.18),rgba(14,27,44,0) 68%);
  z-index:-1;
}
.hero-wex-premium{
  min-height:680px;
  padding:clamp(76px,7vw,108px) 0 clamp(86px,8vw,124px);
  background:
    radial-gradient(circle at 76% 20%,rgba(239,85,139,.22),rgba(239,85,139,0) 26%),
    linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.98) 34%,rgba(235,241,248,.7) 58%,rgba(235,241,248,.08) 100%),
    url('/assets/img/BrandAssets/Infinity Backgrounds7.jpg') right center / cover no-repeat;
}
.hero-wex-premium::before{
  content:"";
  position:absolute;
  inset:auto -10% -32% 42%;
  height:68%;
  pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(14,27,44,.18),rgba(14,27,44,0) 64%);
  z-index:1;
}
.hero-wex-premium .wrap{z-index:5}
.hero-wex-premium .solution-hero-copy{
  max-width:690px;
  padding-block:clamp(30px,4vw,52px);
}
.hero-wex-premium h1{
  font-size:clamp(48px,5.7vw,84px);
  line-height:.98;
  max-width:10.8ch;
}
.hero-wex-sub{
  margin:26px 0 0;
  max-width:600px;
  color:var(--ink-2);
  font-size:clamp(16px,1.35vw,20px);
  line-height:1.6;
}
.hero-wex-signals{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:28px;
}
.hero-wex-signals span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 12px;
  border:1px solid rgba(14,27,44,.1);
  background:rgba(255,255,255,.68);
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.07em;
  text-transform:uppercase;
  color:var(--ink-2);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.hero-wex-premium .solution-sticky-visual{
  right:max(0px,calc((100vw - var(--maxw)) / 2 - 56px));
  bottom:0;
  width:min(54vw,760px);
  height:82%;
  max-height:680px;
  filter:drop-shadow(0 48px 76px rgba(14,27,44,.22));
}
.hero-wex-premium .solution-sticky-visual img{
  object-position:bottom right;
}
.hero-wex-premium .solution-sticky-visual.is-scroll-layer{
  right:max(0px,calc((100vw - var(--maxw)) / 2 - 56px));
  bottom:10vh;
  width:min(54vw,760px);
  height:82vh;
  max-height:min(680px,90vh - 96px);
}
.hero-wex-premium .solution-sticky-visual::before{
  content:"";
  position:absolute;
  left:19%;
  bottom:13%;
  width:38%;
  height:24%;
  border:1px solid rgba(255,255,255,.42);
  background:
    linear-gradient(180deg,rgba(255,255,255,.74),rgba(255,255,255,.48)),
    linear-gradient(90deg,rgba(239,85,139,.42) 0 28%,rgba(14,27,44,.18) 28% 30%,rgba(255,255,255,0) 30%);
  box-shadow:0 24px 60px -42px rgba(14,27,44,.52);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  z-index:2;
}
@media (min-width:1180px){
  .solution-hero-enhanced .wrap,
  body:has(.solution-hero-enhanced) main > .section .wrap{padding-right:min(38vw,520px)}
  body:has(.solution-hero-enhanced) .closing-prod .wrap{padding-right:min(32vw,420px)}
  .hero-wex-premium .wrap{padding-right:min(43vw,620px)}
  .hero-ind-dark.solution-hero-enhanced .wrap{padding-right:min(34vw,480px)}
}
@media (max-width:1179px){
  .solution-sticky-visual{display:none}
  .hero-wex-premium{
    min-height:auto;
    padding:56px 0 72px;
  }
  .hero-wex-premium .solution-hero-copy{
    max-width:760px;
  }
  .hero-wex-premium h1{
    max-width:12ch;
  }
}
@media (max-width:760px){
  .solution-hero-enhanced{
    padding:48px 0 64px;
    background:
      linear-gradient(180deg,rgba(235,241,248,.96) 0%,rgba(235,241,248,.84) 100%),
      url('/assets/img/BrandAssets/Infinity Backgrounds9.jpg') center / cover no-repeat;
  }
  .hero-sol{padding:28px 0 40px}
}


.journey-map{
  margin-top:clamp(48px,6vw,76px);
  position:relative;
  padding:20px;
  max-width:1180px;
  border:1px solid rgba(14,27,44,.11);
  background:rgba(255,255,255,.74);
  box-shadow:0 26px 70px -56px rgba(14,27,44,.45);
}
.jm-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;gap:40px;flex-wrap:wrap}

.rail{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:rgba(14,27,44,.12);border-radius:0;overflow:hidden;margin-top:24px}
.rail-cell{
  background:rgba(235,241,248,.9);padding:28px 24px;min-height:240px;
  display:flex;flex-direction:column;gap:12px;position:relative;
  transition:background .18s,transform .18s,box-shadow .18s;
  cursor:default;
}
.rail-cell:hover{background:var(--white);transform:translateY(-2px);box-shadow:0 18px 42px -34px rgba(14,27,44,.42)}
.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)}

/* Solutions section wrapper */
.sol-section{padding:72px 0 96px}

/* Solution list layout */
.sol-grid{display:grid;grid-template-columns:1fr;align-items:start}

/* ---- Sidebar ---- */
.sol-side{position:sticky;top:96px;align-self:start}
.sol-side-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin:0 0 12px;font-weight:500;padding:0 14px}
.sol-side nav{display:flex;flex-direction:column;gap:2px}
.sol-side a{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 14px;border-radius:8px;font-size:13.5px;color:var(--ink-2);
  transition:background .15s,color .15s;
  position:relative;
}
.sol-side a::before{
  content:'';position:absolute;left:4px;top:50%;transform:translateY(-50%);
  width:2px;height:0;background:var(--coral-deep);border-radius:2px;
  transition:height .2s;
}
.sol-side a:hover{background:rgba(239,85,139,.06);color:var(--ink)}
.sol-side a.on{background:var(--white);color:var(--ink);box-shadow:0 2px 8px rgba(14,27,44,.06)}
.sol-side a.on::before{height:55%}
.sol-side a .no{font-family:var(--mono);font-size:10.5px;color:var(--ink-4);letter-spacing:.06em}
.sol-side a.on .no{color:var(--coral-deep)}
.sol-side .help{
  margin-top:20px;padding:18px;
  background:var(--white);border-radius:12px;
  font-size:12.5px;line-height:1.55;color:var(--ink-3);
  box-shadow:inset 0 0 0 1px var(--hair);
}
.sol-side .help b{color:var(--ink);display:block;font-weight:600;margin-bottom:6px}
.sol-side .help a{display:inline-flex;padding:0;margin-top:10px;color:var(--coral-deep);font-weight:500;background:transparent;font-size:12.5px}
.sol-side .help a:hover{text-decoration:underline}

/* ---- Stage groups ---- */
.sol-list{display:flex;flex-direction:column;gap:12px}

/* Each stage is a self-contained card group */
.sol-stage{
  border-radius:16px;
  box-shadow:inset 0 0 0 1px var(--hair),0 2px 8px rgba(14,27,44,.04);
  background:var(--paper);
  isolation:isolate;
  overflow:visible;
}

.sol-stage-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 40px;
  background:rgba(14,27,44,.025);
  gap:12px;
  border-bottom:1px solid var(--hair);
  border-radius:16px 16px 0 0;
  position:relative;
}
.sol-stage-header::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:3px;background:var(--coral-deep);border-radius:16px 0 0 0;
}
.sol-stage-header-left{display:flex;align-items:center;gap:10px}
.sol-stage-num{
  font-family:var(--mono);font-size:10.5px;color:var(--ink-4);
  letter-spacing:.08em;line-height:1;
}
.sol-stage-label{
  margin:0;font-family:var(--mono);font-size:11.5px;font-weight:500;
  color:var(--coral-deep);text-transform:uppercase;letter-spacing:.1em;
  line-height:1;
}
.sol-stage-count{
  font-family:var(--mono);font-size:10.5px;color:var(--ink-4);letter-spacing:.04em;
}

/* ---- Individual solution cards ---- */
.sol-item{
  background:var(--paper);
  padding:36px 40px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:32px;
  align-items:center;
  transition:background .18s,transform .18s;
  position:relative;
  overflow:visible;
  z-index:0;
}
.sol-item::before{
  content:"";
  position:absolute;
  inset:8px;
  border-radius:12px;
  background:linear-gradient(90deg,rgba(239,85,139,.08),rgba(239,85,139,0) 42%);
  box-shadow:inset 0 0 0 1px rgba(239,85,139,.16),0 18px 44px -34px rgba(14,27,44,.45);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s,transform .18s;
  z-index:-1;
}
.sol-item + .sol-item{border-top:1px solid var(--hair)}
.sol-stage .sol-item:last-child{border-radius:0 0 16px 16px}
.sol-item:hover{background:var(--white);transform:translateY(-1px);z-index:2}
.sol-item:hover::before{opacity:1;transform:translateY(1px)}
.sol-item-title{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h3);line-height:1.1;letter-spacing:-.015em}
.sol-item-title em{font-style:italic;color:var(--coral-deep)}
/* Legacy h3/h4 inside sol-item — keep for any pages using old markup */
.sol-item h3,.sol-item h4{margin:0;font-family:var(--sans);font-weight:700;font-size:var(--fs-h3);line-height:1.1;letter-spacing:-.015em}
.sol-item h3 em,.sol-item h4 em{font-style:italic;color:var(--coral-deep)}
.sol-item .sd{margin-top:8px;color:var(--ink-3);font-size:14px;max-width:560px;line-height:1.55}
.sol-item .tags{margin-top:14px;display:flex;gap:6px;flex-wrap:wrap}
.sol-item .tag{font-size:11px;font-family:var(--mono);padding:3px 9px;border-radius:999px;background:var(--sage);color:var(--ink);letter-spacing:.02em}
.sol-item .cta{display:flex;justify-content:flex-end;align-self:end}
.sol-item .cta a{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-size:13px;font-weight:500;white-space:nowrap}
.sol-item .cta a .arrow{
  width:28px;height:28px;border-radius:999px;
  background:var(--ink);color:var(--paper);
  display:grid;place-items:center;font-size:12px;
  transition:transform .2s,background .2s;
  flex-shrink:0;
}
.sol-item:hover .cta a .arrow{transform:translateX(5px);background:var(--coral-deep)}

.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(255,255,255,.12);text-align:left;vertical-align:middle}
.cmp thead th{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.08em;text-transform:uppercase;font-weight:500;padding-bottom:14px}
.cmp td.us{color:var(--coral)}
.cmp td.them{color:rgba(255,255,255,.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:minmax(0,1fr) minmax(320px,.55fr);gap:64px;align-items:end}
.cta-band h2{margin:14px 0 0;font-size:var(--fs-h2)}
.cta-band .side{padding-bottom:8px;justify-self:end;width:min(100%,520px)}
.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:0;padding:32px;min-height:280px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;transition:box-shadow .22s}
.feat:hover{box-shadow:0 28px 64px -42px rgba(14,27,44,.22)}
.feat.dark:hover{box-shadow:0 28px 64px -42px rgba(14,27,44,.5)}
.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(255,255,255,.7)}
.feat.dark .ic{background:rgba(255,107,74,.18);color:var(--coral)}
.feat.dark .step{color:var(--coral)}
.feat.dark .prod-link{color:var(--coral);font-weight:500}
.feat.dark .prod-link:hover{color:var(--paper)}

.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(255,255,255,.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(255,255,255,.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:minmax(0,1fr) auto;gap:72px;align-items:end}
.closing-prod .grid > div:last-child{display:flex;justify-content:flex-end;align-items:flex-end}
.closing-prod p{color:rgba(255,255,255,.72);font-size:17px;line-height:1.55;margin:0 0 24px}
.resources-closing .grid{
  grid-template-columns:minmax(0,.9fr) minmax(320px,.55fr);
  align-items:center;
}
.resources-closing .grid > div:last-child{
  display:block;
  justify-content:initial;
  align-items:initial;
  justify-self:end;
  width:min(100%,520px);
}
.resources-closing p{max-width:520px}
.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(255,255,255,.25)}
.closing-prod .btn-secondary:hover{background:rgba(255,255,255,.08)}

/* -------- FAQ section -------------------------------------------------- */
.faq-section{padding:var(--section-y) 0}
.faq-list{max-width:780px;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--hair)}
.faq-item{border-bottom:1px solid var(--hair)}
.faq-item summary.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 0;cursor:pointer;list-style:none;
  font-size:17px;font-weight:600;color:var(--ink);line-height:1.4;
}
.faq-item summary.faq-q::-webkit-details-marker{display:none}
.faq-item summary.faq-q::after{
  content:'';flex-shrink:0;width:20px;height:20px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none' stroke='%23374151' stroke-width='1.75'%3E%3Cpath d='M5 8l5 5 5-5'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:transform .2s;
}
.faq-item[open] summary.faq-q::after{transform:rotate(180deg)}
.faq-item summary.faq-q:hover{color:var(--coral-deep)}
.faq-a{padding:0 24px 20px 0;color:var(--ink-2);font-size:15.5px;line-height:1.65;max-width:680px}

/* -------- RESPONSIVE -------------------------------------------------- */
@media (max-width:1100px){
  .manifesto-grid,.impact-grid,.careers-grid,.backers-inner,.hero-prod-grid,.hero-platform-grid,.hero-wex-grid,.approach-visual-grid,.integ,.rt-ins,.news-grid,.hero-sol-grid,.hero-ind-grid,.hero-about-grid,.hub-system-grid{grid-template-columns:1fr}
  .hero-sol-media,.hero-ind-media,.hero-about-media{display:none}
  .hero-sol-stones,.hero-platform-stones,.hero-ind-stones,.hero-about-stones{display:none}
  .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}
  .hero-platform{
    min-height:auto;
    padding:56px 0 72px;
  }
  .hero-platform h1{
    max-width:10ch;
  }
  .hero-editorial h1,
  .hero-company h1{
    max-width:12ch;
  }
  .hero-platform-media{
    max-width:720px;
    margin-inline:auto;
  }
  .hero-ind{
    min-height:auto;
    padding:56px 0 72px;
    background:
      radial-gradient(circle at 78% 22%,rgba(239,85,139,.16),rgba(239,85,139,0) 28%),
      linear-gradient(95deg,#EBF1F8 0%,rgba(235,241,248,.98) 38%,rgba(235,241,248,.72) 100%),
      url('/assets/img/BrandAssets/Infinity Backgrounds7.jpg') right center / cover no-repeat;
  }
  .hero-ind h1{
    max-width:12ch;
  }
  .hero-ind .wrap::before{
    right:-120px;
    top:32px;
    opacity:.35;
  }
  .hero-ind .wrap::after{
    display:none;
  }
  .hero-sol{
    min-height:auto;
    padding:56px 0 72px;
  }
  .hero-sol h1{
    max-width:12ch;
  }
  .journey-map{
    padding:18px;
  }
  .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}
  .sol-section{padding:48px 0 72px}
  .sol-side{position:relative;top:0}
  .rail,.problem-points{grid-template-columns:repeat(2,1fr)}
  .problem-point:first-child{border-radius:16px 0 0 0}
  .problem-point:nth-child(2){border-radius:0 16px 0 0}
  .problem-point:nth-child(3){border-radius:0 0 0 16px}
  .problem-point:last-child{border-radius:0 0 16px 0}
  .sol-item{grid-template-columns:1fr;gap:16px}
  .sol-stage-header{padding:14px 28px}
  .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 > .display,
  .journey-head > :first-child > .display{grid-column:1;grid-row:1}
  .split-head > :last-child,
  .journey-head > :last-child{grid-column:1;grid-row:2}
  .journey-desc{max-width:680px}
  .platform-intro{justify-content:flex-start}
  .platform-showcase{
    height:auto;
    min-height:0;
    grid-template-columns:1fr;
    gap:28px;
    max-width:900px;
    margin-left:auto;
    margin-right:auto;
  }
  .platform-step-list{
    width:100%;
    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:none;font-size:var(--fs-h3);line-height:1.08}
  .platform-step p{max-width:62ch}
  .platform-step .step-k{color:var(--coral-deep)}
  .platform-step p{color:var(--ink-2)}
  .platform-section .platform-step .lk.strong{color:var(--white)}
  .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-step-shot iframe{
    display:block;
    width:100%;
    aspect-ratio:16 / 9;
    border:0;
    background:var(--paper);
    pointer-events:none;
  }
  .platform-visual-stage{display:none}
  .platform-flow{grid-template-columns:1fr}
  .flow-step{min-height:auto}
  .problem-panel{grid-column:auto}
  .hub-evidence-panel{position:relative;top:0}
  .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}
  .cta-band .side{justify-self:start;width:100%}
  .closing-prod .grid{grid-template-columns:1fr;gap:32px}
  .closing-prod .grid > div:last-child{justify-content:flex-start}
  .rt-hero-grid{grid-template-columns:1fr}
  .rt-body-grid{grid-template-columns:1fr}
  .rt-event-panel{position:relative;top:0}
  .rt-next-session-card{grid-template-columns:1fr;align-items:start}
  .rt-next-session-details{grid-template-columns:1fr 1fr}
  .rt-next-session-action{justify-content:flex-start}
  .sol-split{grid-template-columns:1fr;gap:clamp(28px,4vw,44px)}
  .sol-split-copy .display{margin-bottom:18px}
  .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){
  :root{
    --fs-h2:clamp(29px,5.2vw,38px);
    --head-gap:40px;
  }
  .split-head,
  .journey-head{
    gap:20px;
  }
  .split-head .display,
  .journey-head .display{
    max-width:760px;
    text-wrap:balance;
  }
  .journey{
    min-height:0;
    padding-top:72px;
    padding-bottom:72px;
  }
  .journey h2{margin-top:10px}
  .journey-desc{max-width:720px}
  .journey-head{padding-left:var(--gutter);padding-right:var(--gutter)}
  .j-viewport{
    margin-top:36px;
    overflow:visible;
    padding-left:var(--gutter);
    padding-right:var(--gutter);
  }
  .j-grid{
    display:grid;
    grid-template-columns:1fr;
    width:min(100%,760px);
    margin-left:auto;
    margin-right:auto;
    gap:16px;
  }
  .j-card{
    flex:auto;
    min-height:0;
    padding:30px;
  }
  .j-media{aspect-ratio:2.1 / 1}
  .platform-section{padding-top:84px}
  .platform-intro{gap:18px}
  .plat-head{
    margin-bottom:34px;
  }
  .platform-intro p{
    max-width:720px;
  }
  .platform-actions .btn{
    justify-content:center;
  }
  .plat-head .ls{
    gap:6px;
  }
  .platform-step{
    display:grid;
    grid-template-columns:minmax(0,.86fr) minmax(300px,1.14fr);
    align-items:center;
    gap:14px 24px;
  }
  .platform-step h3,
  .platform-step p,
  .platform-step .platform-proof-points,
  .platform-step .lk.strong{
    grid-column:1;
  }
  .platform-step-shot{
    grid-column:2;
    grid-row:1 / span 5;
    margin-top:0;
  }
  .logostrip{
    width:100%;
    margin:0;
    padding:var(--section-y) 0 0;
    border-radius:0;
  }
  .logostrip-inner{
    grid-template-columns:1fr;
  }
  .logostrip-title{
    padding:0;
    border:0;
    text-align:left;
  }
  .logo-marquee{padding:0}
  .logo-marquee::before,
  .logo-marquee::after{width:44px}
  .logo-marquee img{
    width:auto;
    min-width:130px;
    max-width:200px;
    height:150px;
    padding:14px 18px;
  }
  .logo-marquee img[src*="channel4"]{padding-left:22px;padding-right:22px}
  .hero{
    min-height:auto;
    align-items:flex-start;
    padding-top:54px;
    padding-bottom:132px;
  }
  .hero-head{
    max-width:100%;
  }
  .hero-actions{
    display:flex;
    width:100%;
  }
  .hero-actions .btn{
    flex:1 1 220px;
    justify-content:center;
  }

  /* 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-item::after{display:none}
  html.js .nav-cta .btn-secondary{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;
    display:block;width:auto;min-width:0;
    background:rgba(255,255,255,.72);box-shadow:none;border-radius:12px;
    padding:8px;margin:4px 0 12px 12px;
    border:1px solid var(--hair);
    transition:none;
    overflow:visible;
  }
  html.js nav.primary[data-nav-open="true"] .nav-dropdown::before,
  html.js nav.primary[data-nav-open="true"] .nav-dropdown::after{display:none}
  html.js nav.primary[data-nav-open="true"] .nav-dropdown a{
    min-height:0;padding:9px 12px;font-size:13px;color:var(--ink-3);
    background:transparent;box-shadow:none;transform:none;
  }
  html.js nav.primary[data-nav-open="true"] .nav-dropdown a::before{width:5px;height:5px;margin-right:8px;box-shadow:none}
  html.js nav.primary[data-nav-open="true"] .nav-dropdown a::after{display:none}
  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:clamp(48px,10vw,72px);
    --section-y-lg:clamp(64px,12vw,88px);
    --head-gap:32px;
    --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 0;padding:56px 24px 64px;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-actions .btn{flex:1 1 100%}
  .hero::before{background-position:82% top}
  .hero::after{
    top:-156px;
    right:-360px;
    width:1080px;
    opacity:1;
  }
  .hero-stones-white{
    inset:-6% -18%;
    background-position:center top;
    opacity:1;
  }
  .hero-head{padding:28px 20px 28px 20px;background:none}
  .hero-sub{max-width:100%}
  .hero-meta{gap:20px}
  .hero-meta .m-n{font-size:22px}
  .hero-meta .m-l{font-size:9.5px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .journey-head{padding-left:0;padding-right:0}
  .j-viewport{margin-top:40px;overflow:visible;padding-left:0;padding-right:0}
  .j-grid{display:grid;grid-template-columns:1fr;width:100%;margin-left:0;margin-right:0;gap:12px;background:transparent;overflow:visible}
  .j-card{flex:auto;min-height:300px;border-radius:12px;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-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}
  .platform-step{
    display:flex;
    grid-template-columns:none;
  }
  .platform-step h3,
  .platform-step p,
  .platform-step .platform-proof-points,
  .platform-step .lk.strong,
  .platform-step-shot{
    grid-column:auto;
    grid-row:auto;
  }
  .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:100%;margin:0;padding:var(--section-y) 0 0;border-radius:0}
  .logostrip-inner{grid-template-columns:1fr}
  .logostrip-title{padding:0;border:0}
  .logo-marquee{padding:0}
  .logo-marquee::before,
  .logo-marquee::after{width:42px}
  .logo-marquee-set{gap:10px;padding-right:10px}
  .logo-marquee img{width:auto;min-width:110px;max-width:180px;height:150px;padding:14px 18px;border-radius:0}
  .logo-marquee img[src*="channel4"]{padding-left:22px;padding-right:22px}
  .rt-hero-title{font-size:clamp(32px,9vw,52px)}
  .rt-hero-day{font-size:clamp(56px,16vw,80px)}
  .rt-hero-panel{border-radius:14px;padding:24px 22px}
  .rt-hero-chip{white-space:normal}
  .rt-event-panel{padding:28px 24px}
  .rt-next-session-section{padding-top:24px;padding-bottom:72px}
  .rt-next-session-card{border-radius:14px;padding:32px 24px}
  .rt-next-session-cover .badge{left:24px;top:24px}
  .rt-next-session-title{margin-top:42px}
  .rt-next-session-details{grid-template-columns:1fr}
  .rt-next-session-title{font-size:clamp(28px,8vw,38px)}
  .rt-next-session-action .btn{width:100%}
  .sol-split{gap:clamp(20px,6vw,32px)}
  .sol-split-copy .display{margin-bottom:16px}
  .outcomes-list li{padding:14px 0 14px 36px}
  .outcomes-list li::before{top:14px}
  .manifesto-body p{font-size:16.5px}
  .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,.problem-points{grid-template-columns:1fr}
  .problem-point:first-child{border-radius:16px 16px 0 0}
  .problem-point:nth-child(2),.problem-point:nth-child(3){border-radius:0}
  .problem-point:last-child{border-radius:0 0 16px 16px}
  .sol-item{padding:24px 20px}
  .sol-stage-header{padding:12px 20px}
  .feat-grid,.how-steps,.out-grid,.pui-kpis{grid-template-columns:1fr}
  .feat-table{grid-template-columns:1fr}
  .feat-card{min-height:0;padding:64px 24px 26px}
  .feat-card::after{left:24px}
  .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(255,255,255,.12)}
  .cmp td{padding:6px 0;border:0}
  .cmp td.us::before,.cmp td.them::before{content:attr(data-col) " — ";color:rgba(255,255,255,.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}
  .sol-side a::before{display:none}
  .plat-subnav-inner{height:48px}
}
@media (max-width:1020px){
  .hero-platform::before{display:none}
  .hero-platform-media::before{opacity:.55}
  .hero-sol{min-height:0}
  .hero-sol::before{display:none}
  .journey-map{padding:14px;margin-top:40px}
}
@media (max-width:720px){
  .hero-ind .wrap::before,
  .hero-ind .wrap::after{display:none}
  .industry-glide{padding:0 0 48px}
  .hero-wex-signals span{
    flex:1 1 100%;
    justify-content:center;
  }
}

/* ── Policy pages (privacy / terms / cookies) ──────────────────────────── */
.policy-hero{padding:56px 0 48px;background:var(--ink);color:#fff}
.policy-hero .display{color:#fff;margin-top:12px}
.policy-hero .display em{color:var(--coral);font-style:normal}
.policy-hero .sub{color:rgba(255,255,255,.65);margin-top:12px;font-size:1rem}
.policy-hero .sub a{color:rgba(255,255,255,.85);text-decoration:underline}
.policy-hero .sub a:hover{color:#fff}
.policy-hero .breadcrumb{margin-bottom:16px}
.policy-hero .breadcrumb ol{display:flex;gap:8px;list-style:none;padding:0;margin:0;flex-wrap:wrap}
.policy-hero .breadcrumb li{font-size:.8125rem;color:rgba(255,255,255,.5)}
.policy-hero .breadcrumb li+li::before{content:"›";margin-right:8px}
.policy-hero .breadcrumb a{color:rgba(255,255,255,.7);text-decoration:none}
.policy-hero .breadcrumb a:hover{color:#fff;text-decoration:underline}
.policy-body{padding:72px 0 100px}
.policy-content{max-width:740px}
.policy-content h2{font-size:1.375rem;margin:2.5em 0 .6em;color:var(--ink)}
.policy-content h2:first-child{margin-top:0}
.policy-content h3{font-size:1.0625rem;margin:1.75em 0 .45em;color:var(--ink)}
.policy-content p,.policy-content li{font-size:1rem;line-height:1.75;color:#3a3a3a}
.policy-content ul{padding-left:1.4em;margin:.4em 0 1em}
.policy-content li{margin-bottom:.35em}
.policy-content a{color:var(--coral);text-decoration:underline}
.policy-content a:hover{color:#c9552e}
.policy-content code{font-family:var(--mono);font-size:.85em;background:#f3f3f3;padding:1px 5px;border-radius:4px}
.policy-content strong{color:var(--ink)}
.policy-content table{width:100%;border-collapse:collapse;margin:1.25em 0 1.75em;font-size:.9375rem}
.policy-content th,.policy-content td{padding:10px 14px;border:1px solid var(--hair);text-align:left}
.policy-content th{background:#f9f8f6;font-weight:600;color:var(--ink)}
@media(max-width:640px){
  .policy-hero{padding:40px 0 36px}
  .policy-body{padding:48px 0 72px}
  .policy-content h2{font-size:1.1875rem}
}

/* ── Team photo colour-on-hover (Section 12c) ──────────────────────────── */
.member .ph img{filter:grayscale(100%);transition:filter .3s ease}
.member .ph:hover img{filter:grayscale(0%)}

/* ── HubSpot consent gate ───────────────────────────────────────────────── */
.hs-consent{padding:24px;border-radius:12px;background:#f9f8f6;border:1px solid var(--hair)}
.hs-consent p{font-size:.9rem;line-height:1.6;margin:0 0 16px;color:#3a3a3a}
.hs-consent a{color:var(--coral);text-decoration:underline}
.hs-consent-btn{background:var(--coral);color:#fff;border:none;padding:10px 22px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;font-family:inherit;transition:background .2s}
.hs-consent-btn:hover{background:#c9552e}
.hs-consent-btn:focus-visible{outline:2px solid var(--coral);outline-offset:2px}

/* ── Cookie consent banner ──────────────────────────────────────────────── */
#ttp-cookie-notice{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  background:#fff;border-top:2px solid var(--hair);
  padding:16px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  box-shadow:0 -4px 24px rgba(0,0,0,.08);
  font-size:.9rem;line-height:1.5;
  transform:translateY(100%);transition:transform .35s ease;
}
#ttp-cookie-notice.is-visible{transform:translateY(0)}
#ttp-cookie-notice p{margin:0;color:#3a3a3a;flex:1 1 300px}
#ttp-cookie-notice a{color:var(--coral);text-decoration:underline}
#ttp-cookie-notice a:hover{color:#c9552e}
.ttp-cookie-btns{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
#ttp-cookie-accept{
  background:var(--coral);color:#fff;border:none;
  padding:9px 20px;border-radius:7px;cursor:pointer;
  font-size:.875rem;font-weight:600;font-family:inherit;
  transition:background .2s;
}
#ttp-cookie-accept:hover{background:#c9552e}
#ttp-cookie-accept:focus-visible{outline:2px solid var(--coral);outline-offset:2px}
#ttp-cookie-decline{
  background:transparent;color:#3a3a3a;
  border:1.5px solid var(--hair);
  padding:9px 20px;border-radius:7px;cursor:pointer;
  font-size:.875rem;font-weight:600;font-family:inherit;
  transition:border-color .2s,color .2s;
}
#ttp-cookie-decline:hover{border-color:#aaa;color:#111}
#ttp-cookie-decline:focus-visible{outline:2px solid var(--coral);outline-offset:2px}
@media(max-width:600px){
  #ttp-cookie-notice{flex-direction:column;align-items:flex-start}
  .ttp-cookie-btns{align-self:flex-end}
}
