/* ─────────────────────────────────────────
   Supply Lens — main.css
   Shared across all pages
   Includes: tokens, reset, typography, nav, buttons,
   layout, hero, bento, cards, stats, CTA, trusted-by,
   solution pages, footer, animations, responsive
───────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,300;12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Geist:wght@300;400;500;600&display=swap');

/* ─────────────────────────────────────────
   TOKENS
───────────────────────────────────────── */
:root {
  --bg0: #080a0d;
  --bg1: #0d0f14;
  --bg2: #111318;
  --bg3: #161920;
  --bg4: #1c1f28;

  --border: rgba(255,255,255,0.055);
  --border2: rgba(255,255,255,0.10);
  --border3: rgba(255,255,255,0.16);

  --text0: #f1f0ee;
  --text1: #9b98a3;
  --text2: #5c5966;
  --text3: #3a3845;

  --p: #6366f1;       /* primary indigo */
  --p-light: #818cf8;
  --p-dim: rgba(99,102,241,0.12);
  --p-glow: rgba(99,102,241,0.25);

  --green: #22d3a5;
  --amber: #f5a623;
  --rose:  #f43f5e;

  --nav-h: 64px;
  --r: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}

body{
  font-family:'Geist','Geist Fallback',system-ui,sans-serif;
  background:var(--bg0);
  color:var(--text0);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* noise texture */
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:0.028;
  pointer-events:none;
  z-index:9998;
}

/* ─────────────────────────────────────────
   TYPOGRAPHY
───────────────────────────────────────── */
h1,h2,h3{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;
  line-height:1.04;
  letter-spacing:-0.03em;
  color:var(--text0);
}
h1{font-size:clamp(48px,6.5vw,88px);font-weight:800}
h2{font-size:clamp(32px,4.2vw,58px);font-weight:700}
h3{font-size:clamp(18px,2vw,24px);font-weight:600}
h4{font-family:'Geist',sans-serif;font-size:14px;font-weight:600;color:var(--text0);letter-spacing:0.01em}
p{color:var(--text1);line-height:1.75;font-size:15px}
.lead{font-size:clamp(16px,1.6vw,19px);line-height:1.72;color:var(--text1);font-weight:300}
.mono{font-family:'Geist Mono',monospace}

/* ─────────────────────────────────────────
   NAV
───────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);
  z-index:1000;
  border-bottom:1px solid var(--border);
  background:rgba(8,10,13,0.82);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
}
.nav-inner{
  max-width:1280px;width:100%;
  margin:0 auto;padding:0 40px;
  height:100%;display:flex;align-items:center;
}
.logo{
  display:flex;align-items:center;gap:9px;
  text-decoration:none;margin-right:52px;flex-shrink:0;
}
.logo-icon{
  width:30px;height:30px;
  background:var(--p);border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 1px rgba(99,102,241,0.5), 0 4px 16px rgba(99,102,241,0.35);
}
.logo-icon svg{display:block}
.logo-name{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;font-size:17px;
  color:var(--text0);letter-spacing:-0.03em;
}
.nav-links{display:flex;align-items:center;gap:0;flex:1;list-style:none}
.nav-links>li>a{
  display:flex;align-items:center;gap:4px;
  font-size:13.5px;font-weight:500;
  color:var(--text1);
  padding:7px 13px;border-radius:7px;
  text-decoration:none;
  transition:color .15s,background .15s;
}
.nav-links>li>a:hover,
.nav-links>li>a.active{color:var(--text0);background:var(--bg3)}
/* chevron */
.nav-links .has-dd>a::after{
  content:'';
  border:4px solid transparent;
  border-top-color:currentColor;
  margin-top:2px;
  opacity:.45;
  transition:transform .2s;
}
.nav-links .has-dd:hover>a::after{transform:rotate(180deg)}

/* dropdown */
.dd{
  position:absolute;top:calc(100% + 8px);left:0;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:var(--r-lg);
  padding:6px;min-width:276px;
  box-shadow:0 0 0 1px rgba(255,255,255,0.04), 0 28px 60px rgba(0,0,0,0.7);
  opacity:0;pointer-events:none;
  transform:translateY(-6px) scale(0.98);
  transition:opacity .18s .25s,transform .18s .25s;
  transform-origin:top left;
}
.has-dd{position:relative}
/* Invisible bridge fills the gap so mouse doesn't lose hover
   state while travelling from the nav item down into the menu */
.has-dd::before{
  content:'';
  position:absolute;
  top:100%;left:-8px;right:-8px;
  height:16px;
}
.has-dd:hover .dd{
  opacity:1;pointer-events:all;transform:translateY(0) scale(1);
  transition:opacity .18s 0s,transform .18s 0s;
}
.dd a{
  display:flex;align-items:center;gap:14px;
  padding:11px 13px;border-radius:10px;
  text-decoration:none;transition:background .1s;
}
.dd a:hover{background:var(--bg3)}
.dd a:hover .dd-icon{background:var(--bg4)!important;border-color:var(--border2)!important;color:var(--text0)!important}
.dd-icon{
  width:36px;height:36px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.dd-text{}
.dd-title{font-size:13.5px;font-weight:600;color:var(--text0);display:block}
.dd-desc{font-size:12px;color:var(--text2);margin-top:1px;display:block;line-height:1.35}
.nav-end{margin-left:auto;display:flex;align-items:center;gap:8px}

/* ─────────────────────────────────────────
   BUTTONS
───────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 18px;border-radius:8px;
  font-family:'Geist',sans-serif;font-size:13.5px;font-weight:500;
  text-decoration:none;border:none;cursor:pointer;
  transition:all .15s;white-space:nowrap;
}
.btn-primary{
  background:var(--p);color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,0.12) inset, 0 4px 20px rgba(99,102,241,0);
}
.btn-primary:hover{
  background:#5254cc;
  box-shadow:0 1px 0 rgba(255,255,255,0.12) inset, 0 4px 24px rgba(99,102,241,0.45);
  transform:translateY(-1px);
}
.btn-secondary{
  background:var(--bg3);color:var(--text0);
  border:1px solid var(--border2);
}
.btn-secondary:hover{background:var(--bg4);border-color:var(--border3)}
.btn-lg{padding:12px 24px;font-size:15px;border-radius:10px}
.btn-sm{padding:6px 14px;font-size:12.5px;border-radius:7px}

/* ─────────────────────────────────────────
   PAGE WRAPPER
───────────────────────────────────────── */
.page{padding-top:var(--nav-h)}
.container{max-width:1280px;margin:0 auto;padding:0 40px}
section{padding:112px 40px}
section.dense{padding:72px 40px}

/* ─────────────────────────────────────────
   EYEBROW
───────────────────────────────────────── */
.tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11.5px;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;
  color:var(--p-light);
  background:var(--p-dim);
  border:1px solid rgba(99,102,241,0.2);
  border-radius:100px;padding:4px 12px;
  margin-bottom:22px;
}

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
.hero{
  position:relative;
  min-height:calc(100vh - var(--nav-h));
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:0;
  align-items:center;
  padding:100px 40px 80px;
  max-width:1280px;
  margin:0 auto;
  overflow:visible;
}

/* dot grid BG — positioned relative to page */
.hero-bg{
  position:absolute;
  top:calc(-1 * var(--nav-h));
  left:0;right:0;
  height:calc(100vh + 100px);
  pointer-events:none;z-index:0;
  overflow:hidden;
}
.hero-bg::before{
  content:'';
  position:absolute;inset:0;
  background-image:radial-gradient(circle, rgba(255,255,255,0.12) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse 75% 70% at 65% 45%, black 20%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 75% 70% at 65% 45%, black 20%, transparent 75%);
}
.hero-bg::after{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 55% 55% at 75% 35%, rgba(99,102,241,0.13) 0%, transparent 65%),
    radial-gradient(ellipse 40% 50% at 30% 75%, rgba(34,211,165,0.05) 0%, transparent 60%);
}

.hero-left{position:relative;z-index:2}

.hero-pretag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:100px;
  padding:5px 14px 5px 8px;
  margin-bottom:30px;
}
.hero-dot{
  width:24px;height:24px;
  background:rgba(34,211,165,0.15);
  border-radius:100px;
  display:flex;align-items:center;justify-content:center;
}
.hero-dot::after{
  content:'';
  width:8px;height:8px;
  background:var(--green);
  border-radius:50%;
  box-shadow:0 0 8px rgba(34,211,165,0.7);
  animation:hpulse 2.8s ease-in-out infinite;
}
@keyframes hpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.75)}}
.hero-pretag span{font-size:12.5px;font-weight:500;color:var(--text1)}

.hero h1{margin-bottom:26px}
.hero h1 i{font-style:italic;color:var(--p-light);font-weight:300}
.hero .lead{max-width:500px;margin-bottom:38px}
.hero-ctas{display:flex;gap:10px;flex-wrap:wrap}
.hero-social{
  display:flex;align-items:center;gap:16px;
  margin-top:44px;padding-top:32px;
  border-top:1px solid var(--border);
}
.hero-social-label{font-size:12px;color:var(--text2);white-space:nowrap}
.avatar-stack{display:flex}
.avatar{
  width:28px;height:28px;border-radius:50%;
  background:var(--bg4);border:2px solid var(--bg1);
  margin-left:-8px;display:flex;align-items:center;justify-content:center;
  font-size:12px;
}
.avatar:first-child{margin-left:0}
.hero-social-text{font-size:12px;color:var(--text1)}
.hero-social-text strong{color:var(--text0);font-weight:600}

/* ─────────────────────────────────────────
   TERMINAL / FLOW CARD
───────────────────────────────────────── */
.flow-card{
  background:var(--bg1);
  border:1px solid var(--border2);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.04),
    0 40px 80px rgba(0,0,0,0.7),
    0 0 60px rgba(99,102,241,0.04);
  position:relative;
}
.fc-header{
  display:flex;align-items:center;gap:8px;
  padding:14px 20px;
  border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.fc-dots{display:flex;gap:6px}
.fc-dot{width:10px;height:10px;border-radius:50%}
.fc-title{
  font-family:'Geist',sans-serif;font-size:12px;
  color:var(--text2);font-weight:500;margin-left:4px;
}
.fc-body{padding:24px}

/* pipeline rows */
.pipe-list{display:flex;flex-direction:column;gap:3px}
.pipe-row{
  display:flex;align-items:center;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:11px 14px;gap:10px;
  transition:border-color .2s, background .2s;
  cursor:default;
}
.pipe-row:hover{border-color:var(--border2);background:var(--bg3)}
.pipe-row.active{
  border-color:rgba(99,102,241,0.35);
  background:rgba(99,102,241,0.06);
}
.pipe-row.hub{
  background:var(--p);
  border-color:transparent;
  box-shadow:0 2px 20px rgba(99,102,241,0.35);
  justify-content:center;margin:6px 0;
}
.pipe-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.pipe-label{font-size:13px;font-weight:600;color:var(--text0);flex:1}
.pipe-row.hub .pipe-label{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:14px;font-weight:700;
  color:white;letter-spacing:-0.02em;
  text-align:center;
}
.pipe-stat{
  font-size:11px;font-weight:600;
  padding:3px 9px;border-radius:100px;
}
.ps-green{background:rgba(34,211,165,0.15);color:var(--green)}
.ps-blue{background:rgba(99,102,241,0.15);color:var(--p-light)}
.ps-amber{background:rgba(245,166,35,0.15);color:var(--amber)}

.fc-divider{height:1px;background:var(--border);margin:16px 0}
.fc-tags{display:flex;flex-wrap:wrap;gap:6px}
.fc-tag{
  font-size:11px;font-weight:600;
  color:var(--p-light);
  background:var(--p-dim);
  border:1px solid rgba(99,102,241,0.15);
  padding:3px 10px;border-radius:100px;
}

/* ─────────────────────────────────────────
   MARQUEE / LOGOS
───────────────────────────────────────── */
/* ─────────────────────────────────────────
   INTEGRATION ICON CAROUSEL
───────────────────────────────────────── */
.icon-carousel{
  position:relative;
  padding:72px 0 80px;
  background:var(--bg0);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;
}

/* edge fades — the signature look */
.icon-carousel-scroll-outer{
  -webkit-mask-image:linear-gradient(
    to right,
    transparent 0%,
    black 10%,
    black 90%,
    transparent 100%
  );
  mask-image:linear-gradient(
    to right,
    transparent 0%,
    black 10%,
    black 90%,
    transparent 100%
  );
}

.icon-row{
  overflow:hidden;
  margin-bottom:14px;
}
.icon-row:last-child{margin-bottom:0}

.icon-inner{
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:0;
  white-space:nowrap;
}

/* Row 1 scrolls left, Row 2 scrolls right */
.icon-fwd{animation:iconFwd 55s linear infinite}
.icon-rev{animation:iconRev 65s linear infinite}
.icon-fwd:hover,.icon-rev:hover{animation-play-state:paused}

@keyframes iconFwd{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes iconRev{from{transform:translateX(-50%)}to{transform:translateX(0)}}

/* Row 2 starts offset so tiles don't align vertically with row 1 */
.icon-rev{animation-delay:-8s}

/* Individual icon tile */
.icon-tile{
  flex-shrink:0;
  cursor:pointer;
  transition:transform .2s,opacity .2s;
}
.icon-tile:hover{transform:translateY(-4px) scale(1.06)}
.icon-tile:hover .it-sq{
  box-shadow:0 12px 32px rgba(0,0,0,0.6),0 0 0 1px rgba(255,255,255,0.15);
}

/* The square icon itself */
.it-sq{
  width:68px;
  height:68px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,0.45),0 0 0 1px rgba(255,255,255,0.07);
  transition:box-shadow .2s;
}

/* Gloss sheen overlay */
.it-sq::after{
  content:'';
  position:absolute;inset:0;
  border-radius:18px;
  background:linear-gradient(
    145deg,
    rgba(255,255,255,0.18) 0%,
    rgba(255,255,255,0.04) 40%,
    transparent 60%
  );
  pointer-events:none;
}

/* Letter fallback for platforms without SVG */
.it-ltr{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:22px;
  font-weight:800;
  color:#fff;
  line-height:1;
  letter-spacing:-0.02em;
  position:relative;
  z-index:1;
}

/* CTA below */
.icon-carousel-cta{
  text-align:center;
  margin-top:56px;
  position:relative;
  z-index:2;
}

/* Remove old int-band, trusted, brand-grid styles — they're gone */

/* ─────────────────────────────────────────
   BENTO GRID
───────────────────────────────────────── */
.bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:min-content;
  gap:12px;
}
.bento-cell{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:32px;
  position:relative;overflow:hidden;
  transition:border-color .25s, box-shadow .25s;
}
.bento-cell::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,0.08) 50%,transparent 100%);
}
.bento-cell:hover{
  border-color:var(--border2);
  box-shadow:0 8px 40px rgba(0,0,0,0.4);
}
.bento-cell.accent:hover{
  border-color:rgba(99,102,241,0.3);
  box-shadow:0 8px 40px rgba(99,102,241,0.07);
}
.b-4{grid-column:span 4}
.b-6{grid-column:span 6}
.b-8{grid-column:span 8}
.b-12{grid-column:span 12}
.b-icon{
  width:44px;height:44px;
  border-radius:11px;
  background:var(--bg3);
  border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-size:21px;
  margin-bottom:22px;
}
.b-tag{
  position:absolute;top:20px;right:20px;
  font-size:11px;font-weight:600;letter-spacing:0.05em;
  color:var(--text2);text-transform:uppercase;
}

/* ─────────────────────────────────────────
   CARDS
───────────────────────────────────────── */
.card{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);padding:30px;
  position:relative;overflow:hidden;
  transition:border-color .2s, transform .2s, box-shadow .2s;
}
.card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.07),transparent);
}
.card:hover{
  border-color:var(--border2);
  transform:translateY(-2px);
  box-shadow:0 16px 40px rgba(0,0,0,0.5);
}

/* ─────────────────────────────────────────
   SECTION HEADER
───────────────────────────────────────── */
.sh{margin-bottom:64px}
.sh.ctr{text-align:center}
.sh.ctr .tag{display:inline-flex}
.sh h2{margin-bottom:18px}
.sh p{max-width:520px}
.sh.ctr p{margin:0 auto}

/* ─────────────────────────────────────────
   STATS
───────────────────────────────────────── */
.stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  background:var(--border);gap:1px;
}
.stat-cell{background:var(--bg1);padding:40px 44px}
.s-num{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:clamp(44px,5vw,68px);
  font-weight:800;letter-spacing:-0.04em;
  line-height:1;
  background:linear-gradient(135deg,var(--text0) 40%,var(--text1) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:10px;
}
.s-lbl{font-size:14px;color:var(--text2);line-height:1.5}

/* ─────────────────────────────────────────
   CTA BAND
───────────────────────────────────────── */
.cta-band{
  position:relative;overflow:hidden;
  background:var(--bg1);
  border:1px solid var(--border2);
  border-radius:var(--r-xl);padding:80px 72px;
  display:flex;align-items:center;
  justify-content:space-between;gap:56px;
}
.cta-band::before{
  content:'';position:absolute;
  top:-120px;right:-80px;width:480px;height:480px;
  background:radial-gradient(circle,rgba(99,102,241,0.10) 0%,transparent 65%);
  pointer-events:none;
}
.cta-band::after{
  content:'';position:absolute;
  bottom:-80px;left:120px;width:320px;height:320px;
  background:radial-gradient(circle,rgba(34,211,165,0.04) 0%,transparent 65%);
  pointer-events:none;
}
.cta-band h2{color:var(--text0);margin-bottom:14px}
.cta-btns{display:flex;gap:10px;flex-shrink:0;position:relative;z-index:1;flex-wrap:wrap}

/* ─────────────────────────────────────────
   TRUSTED BY
───────────────────────────────────────── */

/* ─────────────────────────────────────────
   BREADCRUMB
───────────────────────────────────────── */
.breadcrumb{
  display:flex;align-items:center;gap:8px;
  font-size:12.5px;color:var(--text2);margin-bottom:26px;
}
.breadcrumb a{color:var(--text2);text-decoration:none;transition:color .12s}
.breadcrumb a:hover{color:var(--text1)}
.breadcrumb .sep{opacity:0.35}

/* ─────────────────────────────────────────
   SOLUTION HERO
───────────────────────────────────────── */
.sol-hero{
  position:relative;overflow:hidden;
  padding:100px 40px 90px;
  border-bottom:1px solid var(--border);
}
.sol-glow{
  position:absolute;top:-100px;right:-100px;
  width:600px;height:600px;
  background:radial-gradient(circle,var(--sol-color,rgba(99,102,241,0.08)) 0%,transparent 65%);
  pointer-events:none;
}
.sol-hero-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,0.08) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 60% 80% at 80% 40%,black 10%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 60% 80% at 80% 40%,black 10%,transparent 75%);
}
.sol-inner{
  position:relative;z-index:1;
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}

/* ─────────────────────────────────────────
   FLOW PANEL
───────────────────────────────────────── */
.flow-panel{
  background:var(--bg1);
  border:1px solid var(--border2);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 40px 80px rgba(0,0,0,0.6),0 0 0 1px rgba(255,255,255,0.03);
}
.fp-bar{
  display:flex;align-items:center;gap:6px;
  padding:13px 18px;border-bottom:1px solid var(--border);
  background:var(--bg2);
}
.fp-dot{width:10px;height:10px;border-radius:50%}
.fp-title{font-size:12px;color:var(--text2);font-weight:500;margin-left:4px;font-family:'Geist',sans-serif}
.fp-body{padding:22px}
.fp-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
  border-bottom:1px solid var(--border);
  padding:13px 0;
}
.fp-row:last-child{border-bottom:none;padding-bottom:0}
.fp-left{display:flex;align-items:center;gap:10px}
.fp-icon{
  width:30px;height:30px;border-radius:7px;
  background:var(--bg3);display:flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;
}
.fp-name{font-size:13px;font-weight:600;color:var(--text0)}
.fp-sub{font-size:11.5px;color:var(--text2);margin-top:1.5px}
.chip{
  font-size:11px;font-weight:700;
  padding:3px 9px;border-radius:100px;
  white-space:nowrap;letter-spacing:0.02em;
}
.chip-green{background:rgba(34,211,165,0.12);color:var(--green)}
.chip-blue{background:rgba(99,102,241,0.12);color:var(--p-light)}
.chip-amber{background:rgba(245,166,35,0.12);color:var(--amber)}
.chip-p{background:var(--p-dim);color:var(--p-light);border:1px solid rgba(99,102,241,0.2)}

/* ─────────────────────────────────────────
   STEPS
───────────────────────────────────────── */
.steps{display:flex;flex-direction:column;gap:0}
.step{
  display:flex;gap:20px;
  padding:26px 0;
  border-bottom:1px solid var(--border);
}
.step:last-child{border-bottom:none;padding-bottom:0}
.step:first-child{padding-top:0}
.step-n{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;margin-top:2px;
  background:var(--p);color:white;
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;font-size:13px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 16px rgba(99,102,241,0.35);
}

/* ─────────────────────────────────────────
   CHECKLIST
───────────────────────────────────────── */
.checklist{list-style:none;display:flex;flex-direction:column;gap:11px}
.checklist li{
  display:flex;align-items:flex-start;gap:11px;
  font-size:14.5px;color:var(--text1);
}
.checklist li::before{
  content:'';width:20px;height:20px;flex-shrink:0;margin-top:1px;
  background:var(--p-dim);border-radius:50%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M6 10.5l2.5 2.5 5-6' stroke='%23818cf8' stroke-width='1.7' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}

/* ─────────────────────────────────────────
   TWO-COL LAYOUT
───────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.two-col.center{align-items:center}

/* ─────────────────────────────────────────
   DARK INSET PANEL
───────────────────────────────────────── */
.inset{
  background:var(--bg0);
  border:1px solid var(--border);
  border-radius:var(--r-md);padding:24px;
}
.inset+.inset{margin-top:10px}
.ir{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;background:var(--bg2);
  border:1px solid var(--border);border-radius:var(--r);
  margin-bottom:6px;
}
.ir:last-child{margin-bottom:0}
.ir-label{font-size:13px;font-weight:600;color:var(--text1)}
.ir-sub{font-size:11.5px;color:var(--text2);margin-top:2px}

/* ─────────────────────────────────────────
   XREF
───────────────────────────────────────── */
.xref{
  display:grid;grid-template-columns:1fr 24px 1fr;
  align-items:center;gap:8px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);padding:14px 16px;margin-bottom:6px;
}
.xref-from{font-size:12.5px;font-weight:600;color:var(--text2);font-family:'Geist Mono',monospace}
.xref-arr{color:var(--p-light);font-weight:700;text-align:center;font-size:14px}
.xref-to{font-size:12.5px;font-weight:600;color:var(--p-light);font-family:'Geist Mono',monospace}

/* ─────────────────────────────────────────
   INTEGRATION GRID
───────────────────────────────────────── */
.int-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.int-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-md);padding:22px 16px;
  text-align:center;transition:border-color .2s,background .2s;
}
.int-card:hover{background:var(--bg2);border-color:var(--border2)}
.int-emoji{font-size:26px;margin-bottom:10px}
.int-name{font-size:13px;font-weight:600;color:var(--text1)}
.int-cat{font-size:11px;color:var(--text2);margin-top:3px}

/* ─────────────────────────────────────────
   PROBLEM CARDS (italic quote)
───────────────────────────────────────── */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.prob-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:28px;
  position:relative;overflow:hidden;
}
.prob-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
}
.prob-card.red::after{background:linear-gradient(90deg,#f43f5e,transparent)}
.prob-card.amber::after{background:linear-gradient(90deg,#f5a623,transparent)}
.prob-card.purple::after{background:linear-gradient(90deg,#a855f7,transparent)}
.prob-card.green::after{background:linear-gradient(90deg,var(--green),transparent)}
.prob-quote{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:15px;font-weight:500;font-style:italic;
  color:var(--text0);line-height:1.55;margin-bottom:14px;
}
.prob-exp{font-size:13.5px;color:var(--text1)}

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
footer{
  border-top:1px solid var(--border);
  padding:80px 40px 48px;
}
.foot-grid{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:200px 1fr 1fr 1.4fr 1fr 1fr;gap:40px;
}
.foot-brand-name{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;font-size:16px;letter-spacing:-0.03em;
  color:var(--text0);margin-left:9px;
}
.foot-brand p{font-size:13px;color:var(--text2);margin-top:16px;line-height:1.7}
.foot-col h5{
  font-size:11px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;
  color:var(--text2);margin-bottom:18px;
}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{
  font-size:13.5px;color:var(--text2);text-decoration:none;
  transition:color .12s;
}
.foot-col a:hover{color:var(--text1)}
.foot-bottom{
  max-width:1280px;margin:48px auto 0;
  padding-top:24px;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.foot-bottom p{font-size:13px;color:var(--text2)}

/* ─────────────────────────────────────────
   ANIMATIONS
───────────────────────────────────────── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
.anim{opacity:1}
.anim.will-animate{opacity:0}
.anim.will-animate.in{animation:fadeUp .6s cubic-bezier(0.16,1,0.3,1) forwards}

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;gap:60px;min-height:auto}
  .hero-right{padding-left:0;justify-content:center}
  .sol-inner{grid-template-columns:1fr;gap:48px}
  .two-col{grid-template-columns:1fr;gap:48px}
  .bento .b-4,.bento .b-8{grid-column:span 6}
  .int-grid{grid-template-columns:repeat(3,1fr)}
  .stats-row{grid-template-columns:1fr 1fr}
  .problem-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .foot-brand{grid-column:1/-1}
  .cta-band{flex-direction:column;text-align:center;padding:56px 40px}
  .cta-band .cta-btns{justify-content:center}
}
@media(max-width:680px){
  section{padding:72px 24px}
  .container{padding:0 24px}
  h1{font-size:42px}
  .bento .b-4,.bento .b-6,.bento .b-8{grid-column:span 12}
  .problem-grid,.int-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .foot-brand{grid-column:auto}
  .stats-row{grid-template-columns:1fr}
}