/* ============================================================
   Attribute — marketing site design system
   Deep blue #003f9f · navy #0f1729 · orange #ff7500
   Poppins (display) + Inter (body)
   ============================================================ */

:root {
  --navy:#0f1729;
  --navy-2:#0b1222;
  --blue:#003f9f;
  --blue-2:#0b4fc0;
  --blue-ink:#0a2a63;
  --orange:#ff7500;
  --orange-2:#ff9233;
  --orange-ink:#ab5102;
  --pink:#b8184d;
  --slate:#65758b;
  --slate-2:#8a97a8;
  --ink:#0f1729;
  --bg:#ffffff;
  --soft:#f6f8fb;
  --soft-2:#eef2f7;
  --line:#e4e8ee;
  --line-2:#d6dbe3;
  --white:#ffffff;

  --green:#1f8a52;
  --green-tint:#e9f7ef;

  --r-sm:8px; --r:14px; --r-lg:20px; --r-xl:28px;
  --shadow-sm:0 1px 2px rgba(15,23,41,.06);
  --shadow:0 12px 32px -10px rgba(15,23,41,.16);
  --shadow-lg:0 32px 70px -24px rgba(15,23,41,.34);
  --shadow-blue:0 24px 60px -20px rgba(0,63,159,.45);

  --maxw:1200px;
  --gutter:24px;

  --display:"Poppins","Inter",system-ui,sans-serif;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

* { box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--body); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
h1,h2,h3,h4 { margin:0; font-family:var(--display); font-weight:600; line-height:1.08; letter-spacing:-.02em; color:var(--ink); }
p { margin:0; }
ul { margin:0; padding:0; list-style:none; }
button { font-family:inherit; cursor:pointer; }
::selection { background:rgba(255,117,0,.22); }

/* ---- layout ---- */
.wrap { max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }
.section { padding:104px 0; position:relative; }
.section.tight { padding:76px 0; }
.section--soft { background:var(--soft); }
.section--navy { background:var(--navy); color:#dfe5ef; }
.section--navy h1,.section--navy h2,.section--navy h3 { color:#fff; }

/* ---- type scale ---- */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--blue); font-family:var(--body);
}
.eyebrow--orange { color:var(--orange-ink); }
.eyebrow--light { color:var(--orange-2); }
.eyebrow .dot { width:6px; height:6px; border-radius:50%; background:currentColor; }

.display { font-size:clamp(38px,5.4vw,68px); line-height:1.02; }
.h-sec { font-size:clamp(30px,3.8vw,46px); line-height:1.06; }
.h-card { font-size:21px; line-height:1.25; }
.lead { font-size:clamp(17px,1.5vw,21px); color:var(--slate); line-height:1.55; }
.section--navy .lead { color:#aab6c8; }
.muted { color:var(--slate); }
.accent-o { color:var(--orange); }
.accent-b { color:var(--blue); }

.sec-head { max-width:680px; }
.sec-head.center { margin:0 auto; text-align:center; }
.sec-head .h-sec { margin:16px 0 0; }
.sec-head .lead { margin-top:18px; }

/* ---- buttons ---- */
.btn {
  display:inline-flex; align-items:center; gap:9px; justify-content:center;
  font-family:var(--body); font-weight:600; font-size:16px; line-height:1;
  padding:15px 24px; border-radius:12px; border:1px solid transparent;
  transition:transform .18s var(--ease), box-shadow .25s var(--ease), background .2s, color .2s, border-color .2s;
  white-space:nowrap;
}
.btn svg { width:17px; height:17px; transition:transform .2s var(--ease); }
.btn:hover svg { transform:translateX(3px); }
.btn--primary { background:var(--orange); color:#fff; box-shadow:0 10px 24px -10px rgba(255,117,0,.7); }
.btn--primary:hover { background:#ff8417; transform:translateY(-2px); box-shadow:0 16px 30px -10px rgba(255,117,0,.8); }
.btn--blue { background:var(--blue); color:#fff; box-shadow:0 10px 24px -10px rgba(0,63,159,.6); }
.btn--blue:hover { background:var(--blue-2); transform:translateY(-2px); }
.btn--dark { background:var(--navy); color:#fff; }
.btn--dark:hover { background:#1b2740; transform:translateY(-2px); }
.btn--ghost { background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn--ghost:hover { border-color:var(--ink); background:var(--ink); color:#fff; }
.btn--on-navy { background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.2); backdrop-filter:blur(6px); }
.btn--on-navy:hover { background:rgba(255,255,255,.16); transform:translateY(-2px); }
.btn--lg { padding:18px 30px; font-size:17px; }
.btn--sm { padding:11px 17px; font-size:14px; }

.textlink { display:inline-flex; align-items:center; gap:7px; font-weight:600; color:var(--blue); }
.textlink svg { width:16px; height:16px; transition:transform .2s var(--ease); }
.textlink:hover svg { transform:translateX(3px); }
.textlink--orange { color:var(--orange-ink); }

/* ============================================================
   HEADER  (injected by site.js)
   ============================================================ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  transition:background .3s, box-shadow .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.nav__inner {
  max-width:1240px; margin:0 auto; padding:14px 24px;
  display:flex; align-items:center; gap:24px;
}
.nav.scrolled { background:rgba(255,255,255,.94); backdrop-filter:saturate(180%) blur(16px); border-color:var(--line); box-shadow:0 1px 0 rgba(15,23,41,.04); }
.brand { display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:700; font-size:20px; letter-spacing:-.02em; color:#fff; }
.nav.scrolled .brand { color:var(--ink); }
.brand__mark { height:34px; width:auto; flex:none; object-fit:contain; display:block; }
/* full logo (mark + wordmark) — wordmark is dark, so invert on dark surfaces */
.brand__logo { height:30px; width:auto; flex:none; object-fit:contain; display:block; }
.nav .brand__logo { filter:brightness(0) invert(1); }            /* dark hero nav -> white logo */
.nav.scrolled .brand__logo { filter:none; }                       /* light scrolled nav -> original */
.footer .brand__logo { filter:brightness(0) invert(1); }          /* dark footer -> white logo */
.nav__links { display:flex; align-items:center; gap:4px; margin-left:8px; }
.nav__link {
  position:relative; display:inline-flex; align-items:center; gap:7px;
  padding:9px 14px; border-radius:10px; font-size:15px; font-weight:500; color:#e7ecf4;
  transition:background .18s, color .18s;
}
.nav__link:hover { background:rgba(255,255,255,.12); }
.nav__link.active { color:#fff; }
.nav.scrolled .nav__link { color:var(--ink); }
.nav.scrolled .nav__link:hover { background:var(--soft-2); }
.nav.scrolled .nav__link.active { color:var(--blue); }
.nav__spacer { flex:1; }
.nav__cta { display:flex; align-items:center; gap:10px; }
.nav__signin { font-size:15px; font-weight:500; padding:9px 12px; color:#e7ecf4; border-radius:10px; }
.nav__signin:hover { background:rgba(255,255,255,.12); }
.nav.scrolled .nav__signin { color:var(--ink); }
.nav.scrolled .nav__signin:hover { background:var(--soft-2); }
.badge-soon {
  font-size:9.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--orange-2); background:rgba(255,146,51,.18);
  padding:2px 6px; border-radius:99px; line-height:1.4;
}
.nav.scrolled .badge-soon { color:var(--orange-ink); background:rgba(255,117,0,.14); }

/* dropdown */
.nav__group { position:relative; }
.nav__menu {
  position:absolute; top:calc(100% + 10px); left:0; min-width:280px;
  background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow);
  padding:8px; opacity:0; visibility:hidden; transform:translateY(8px);
  transition:opacity .2s, transform .2s, visibility .2s;
}
.nav__group:hover .nav__menu, .nav__group:focus-within .nav__menu { opacity:1; visibility:visible; transform:translateY(0); }
.nav__menu a { display:flex; gap:12px; align-items:flex-start; padding:11px 12px; border-radius:11px; transition:background .15s; }
.nav__menu a:hover { background:var(--soft); }
.nav__menu .mi-ic { width:34px; height:34px; border-radius:9px; flex:none; display:grid; place-items:center; background:var(--soft-2); color:var(--blue); }
.nav__menu .mi-ic svg { width:18px; height:18px; }
.nav__menu .mi-t { font-size:14.5px; font-weight:600; color:var(--ink); }
.nav__menu .mi-d { font-size:12.5px; color:var(--slate); margin-top:1px; }

.nav__burger { display:none; width:42px; height:42px; border:1px solid var(--line); background:#fff; border-radius:11px; align-items:center; justify-content:center; }
.nav__burger span, .nav__burger span::before, .nav__burger span::after {
  content:""; display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s, opacity .2s;
}
.nav__burger span::before { transform:translateY(-6px); }
.nav__burger span::after { transform:translateY(4px); }
body.menu-open .nav__burger span { background:transparent; }
body.menu-open .nav__burger span::before { transform:rotate(45deg); }
body.menu-open .nav__burger span::after { transform:rotate(-45deg); }

/* mobile sheet */
.mobile {
  position:fixed; inset:0; z-index:190; background:#fff; padding:88px 24px 32px;
  display:none; flex-direction:column; gap:6px; overflow-y:auto;
}
body.menu-open .mobile { display:flex; }
.mobile a { font-family:var(--display); font-size:24px; font-weight:600; padding:12px 0; border-bottom:1px solid var(--line); color:var(--ink); display:flex; align-items:center; gap:10px; }
.mobile .m-sub { font-family:var(--body); font-size:17px; font-weight:500; padding-left:16px; color:var(--slate); border-bottom:1px solid var(--soft-2); }
.mobile .m-actions { display:flex; flex-direction:column; gap:12px; margin-top:22px; }

.page { padding-top:104px; } /* offset for fixed nav (light pages) */

/* ============================================================
   HERO
   ============================================================ */
.hero { position:relative; background:radial-gradient(120% 120% at 80% -10%, #14224a 0%, var(--navy) 45%, #070c18 100%); color:#fff; overflow:hidden; }
.hero::before {
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:54px 54px; mask-image:radial-gradient(80% 70% at 50% 0%, #000 30%, transparent 80%); opacity:.5;
}
.hero::after {
  content:""; position:absolute; width:520px; height:520px; right:-120px; top:-160px;
  background:radial-gradient(circle, rgba(255,117,0,.32), transparent 65%); filter:blur(20px);
}
.hero__inner { position:relative; z-index:2; max-width:920px; margin:0 auto; text-align:center; padding:128px 24px 0; }
.hero .display { color:#fff; }
.hero .display .accent-o { color:var(--orange-2); }
.hero__sub { margin:22px auto 0; max-width:620px; color:#aeb9cc; font-size:clamp(17px,1.6vw,20px); }
.hero__actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:34px; }
.hero__pill {
  display:inline-flex; align-items:center; gap:9px; padding:7px 15px; border-radius:99px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16);
  font-size:13.5px; font-weight:600; letter-spacing:.04em; color:#cdd7e6; text-transform:uppercase; backdrop-filter:blur(6px);
}
.hero__pill .dot { width:7px; height:7px; border-radius:50%; background:var(--orange-2); box-shadow:0 0 0 4px rgba(255,146,51,.2); }

/* hero product mock */
.hero__stage { position:relative; z-index:2; max-width:1080px; margin:64px auto 0; padding:0 24px; }
.hero__stage .mock { box-shadow:var(--shadow-lg); transform:perspective(1600px) rotateX(4deg); }
.hero__shot { display:block; width:100%; height:auto; border-radius:14px; box-shadow:var(--shadow-lg); }

/* compact sub-page hero */
.hero--page .hero__inner { max-width:920px; padding:120px 24px 64px; }
.hero--page.hero { background:radial-gradient(120% 130% at 85% -20%, #15244c 0%, var(--navy) 50%, #070c18 100%); }
.subhero-stats { background:#fff; border-bottom:1px solid var(--line); padding:36px 0; }
.subhero-stats .stats { grid-template-columns:repeat(4,1fr); }

/* logos strip */
.logos { padding:46px 0; border-bottom:1px solid var(--line); background:#fff; }
.logos__label { text-align:center; font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--slate-2); }
.logos__row { display:flex; flex-wrap:wrap; gap:20px 56px; justify-content:center; align-items:center; margin-top:26px; }
.logos__row .lg { display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:600; font-size:19px; color:#9aa6b6; letter-spacing:-.01em; }
.logos__row .lg svg { width:22px; height:22px; opacity:.7; }

/* ============================================================
   PRODUCT MOCK (CSS dashboard)
   ============================================================ */
.mock { background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden; box-shadow:var(--shadow); }
.mock__bar { display:flex; align-items:center; gap:8px; padding:13px 16px; background:#0f1729; }
.mock__bar .tl { width:11px; height:11px; border-radius:50%; background:#33405c; }
.mock__bar .tl:nth-child(1){background:#ff5f57;} .mock__bar .tl:nth-child(2){background:#febc2e;} .mock__bar .tl:nth-child(3){background:#28c840;}
.mock__bar .url { margin-left:12px; font-size:12px; color:#7e8aa3; font-family:var(--body); }
.mock__app { display:grid; grid-template-columns:200px 1fr; min-height:300px; background:#fafbfd; }
.mock__side { background:#fff; border-right:1px solid var(--line); padding:18px 14px; }
.mock__side .s-grp { font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--slate-2); margin:14px 0 8px; }
.mock__side .s-item { display:flex; align-items:center; gap:9px; padding:8px 10px; border-radius:8px; font-size:13px; color:#3d4757; font-weight:500; }
.mock__side .s-item.on { background:rgba(0,63,159,.08); color:var(--blue); }
.mock__side .s-item .si { width:15px; height:15px; }
.mock__main { padding:20px; }
.mock__crumb { font-size:12px; color:var(--slate); margin-bottom:14px; }
.mock__kpis { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:16px; }
.kpi { background:#fff; border:1px solid var(--line); border-radius:12px; padding:14px; }
.kpi .k-l { font-size:11.5px; color:var(--slate); }
.kpi .k-v { font-family:var(--display); font-weight:700; font-size:23px; margin-top:4px; color:var(--ink); }
.kpi .k-d { font-size:11.5px; font-weight:600; margin-top:3px; color:var(--green); }
.kpi .k-d.down { color:var(--pink); }
.mock__panel { background:#fff; border:1px solid var(--line); border-radius:12px; padding:16px; }
.mock__panel .p-h { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.mock__panel .p-t { font-weight:600; font-size:13.5px; }
.mock__chart { display:flex; align-items:flex-end; gap:10px; height:120px; }
.mock__chart .bar { flex:1; border-radius:6px 6px 0 0; background:linear-gradient(var(--blue),#2f6fd6); opacity:.9; position:relative; }
.mock__chart .bar.o { background:linear-gradient(var(--orange),var(--orange-2)); }
.mock__rows { display:flex; flex-direction:column; }
.mock__row { display:grid; grid-template-columns:1.6fr .8fr .8fr .9fr; gap:10px; align-items:center; padding:10px 0; border-top:1px solid var(--soft-2); font-size:12.5px; }
.mock__row:first-child { border-top:none; color:var(--slate); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.04em; }
.mock__row .src { display:flex; align-items:center; gap:8px; font-weight:600; color:var(--ink); }
.mock__row .av { width:22px; height:22px; border-radius:6px; flex:none; display:grid; place-items:center; font-size:10px; font-weight:700; color:#fff; }
.pill-tag { display:inline-block; font-size:10.5px; font-weight:700; padding:2px 9px; border-radius:99px; }
.pill-tag.good { background:var(--green-tint); color:var(--green); }
.pill-tag.warn { background:#fdeef0; color:var(--pink); }
.pill-tag.neutral { background:var(--soft-2); color:var(--slate); }

/* ============================================================
   CARDS / GRIDS
   ============================================================ */
.grid { display:grid; gap:22px; }
.grid-2 { grid-template-columns:repeat(2,1fr); }
.grid-3 { grid-template-columns:repeat(3,1fr); }
.grid-4 { grid-template-columns:repeat(4,1fr); }

.card {
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:28px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.card:hover { transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--line-2); }
.card__ic { width:48px; height:48px; border-radius:13px; display:grid; place-items:center; margin-bottom:18px; }
.card__ic svg { width:24px; height:24px; }
.ic-blue { background:rgba(0,63,159,.09); color:var(--blue); }
.ic-orange { background:rgba(255,117,0,.12); color:var(--orange-ink); }
.ic-pink { background:rgba(184,24,77,.1); color:var(--pink); }
.ic-green { background:var(--green-tint); color:var(--green); }
.card h3 { font-size:19px; }
.card p { margin-top:10px; color:var(--slate); font-size:15.5px; }

/* problem cards */
.prob { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; position:relative; }
.prob__tag { font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--slate-2); }
.prob h3 { font-size:20px; margin-top:12px; }
.prob p { margin-top:10px; color:var(--slate); font-size:15px; }
.prob__quote { margin-top:18px; padding:14px 16px; border-left:3px solid var(--orange); background:var(--soft); border-radius:0 10px 10px 0; font-size:14.5px; font-style:italic; color:#37404f; }

/* black-box vs connected visual */
.flow3 { display:grid; grid-template-columns:1fr auto 1fr auto 1fr; align-items:center; gap:0; }
.flow3__node { text-align:center; padding:26px 18px; border-radius:var(--r-lg); border:1px solid var(--line); background:#fff; }
.flow3__node .f-lbl { font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--slate-2); }
.flow3__node .f-val { font-family:var(--display); font-weight:700; font-size:26px; margin-top:8px; color:var(--ink); }
.flow3__box { text-align:center; padding:26px 18px; border-radius:var(--r-lg); background:var(--navy); color:#fff; border:1px solid var(--navy); position:relative; overflow:hidden; }
.flow3__box .f-q { font-family:var(--display); font-weight:700; font-size:42px; color:var(--orange-2); line-height:1; }
.flow3__box .f-cap { font-size:12.5px; color:#9fadc2; margin-top:8px; }
.flow3__box.lit { background:linear-gradient(160deg,#0c4fc0,#003f9f); border-color:#003f9f; }
.flow3__box.lit .f-q { color:#fff; font-size:24px; }
.flow3__arrow { padding:0 14px; color:var(--slate-2); display:flex; align-items:center; justify-content:center; }
.flow3__arrow svg { width:30px; height:18px; }

/* connected chain (solution) */
.chain { display:flex; align-items:stretch; gap:0; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:8px; overflow:hidden; }
.chain__step { flex:1; text-align:center; padding:20px 14px; border-radius:var(--r); position:relative; }
.chain__step + .chain__step::before { content:"→"; position:absolute; left:-10px; top:50%; transform:translateY(-50%); color:var(--line-2); font-size:18px; }
.chain__step .c-l { font-size:12px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--slate-2); }
.chain__step .c-v { font-family:var(--display); font-weight:700; font-size:22px; margin-top:6px; color:var(--ink); }
.chain__step .c-d { font-size:12px; color:var(--slate); margin-top:4px; }
.chain__step.win { background:var(--green-tint); }
.chain__step.win .c-v { color:var(--green); }
@media(max-width:760px){
  .flow3 { grid-template-columns:1fr; gap:14px; }
  .flow3__arrow { transform:rotate(90deg); padding:4px 0; }
  .chain { flex-direction:column; gap:6px; }
  .chain__step + .chain__step::before { content:"↓"; left:50%; top:-2px; transform:translateX(-50%); }
}

/* feature list with checks */
.checks { display:flex; flex-direction:column; gap:11px; margin-top:18px; }
.checks li { display:flex; gap:11px; align-items:flex-start; font-size:15px; color:#39424f; }
.checks .ck { width:21px; height:21px; flex:none; border-radius:50%; background:var(--green-tint); color:var(--green); display:grid; place-items:center; margin-top:1px; }
.checks .ck svg { width:12px; height:12px; }
.checks.lim .ck { background:var(--soft-2); color:var(--slate-2); }
.checks.lock .ck { background:rgba(0,63,159,.08); color:var(--blue); }

/* stat band */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat { text-align:center; }
.stat__v { font-family:var(--display); font-weight:700; font-size:clamp(34px,4vw,52px); line-height:1; background:linear-gradient(120deg,var(--blue),var(--orange)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.section--navy .stat__v { background:linear-gradient(120deg,#5d8bff,var(--orange-2)); -webkit-background-clip:text; background-clip:text; }
.stat__l { margin-top:8px; font-size:14.5px; color:var(--slate); }
.section--navy .stat__l { color:#9fadc2; }

/* steps */
.steps { display:grid; grid-template-columns:repeat(5,1fr); gap:0; counter-reset:step; }
.step { position:relative; padding:0 16px; text-align:center; }
.step:not(:last-child)::after { content:""; position:absolute; top:26px; left:60%; right:-40%; height:2px; background:repeating-linear-gradient(90deg,var(--line-2) 0 6px,transparent 6px 12px); }
.step__n { width:54px; height:54px; margin:0 auto 16px; border-radius:50%; background:#fff; border:2px solid var(--blue); color:var(--blue); display:grid; place-items:center; font-family:var(--display); font-weight:700; font-size:20px; position:relative; z-index:2; }
.step__n.o { border-color:var(--orange); color:var(--orange-ink); }
.step h4 { font-size:16px; }
.step p { margin-top:7px; font-size:13.5px; color:var(--slate); }

/* split feature row */
.split { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.split--rev .split__media { order:-1; }

/* two-hub diagram */
.hubs { display:grid; grid-template-columns:1fr auto 1fr; gap:0; align-items:stretch; }
.hub { position:relative; display:flex; flex-direction:column; border-radius:var(--r-lg); padding:34px 32px; border:1px solid var(--line); background:#fff; box-shadow:var(--shadow-sm); overflow:hidden; transition:transform .2s var(--ease), box-shadow .25s var(--ease); }
.hub:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.hub::before { content:""; position:absolute; inset:0 0 auto 0; height:4px; }
.hub--agency { background:linear-gradient(180deg,#fff, #f7faff); border-color:#d9e4f7; }
.hub--company { background:linear-gradient(180deg,#fff,#fff7f0); border-color:#f7e3cf; }
.hub--agency::before { background:var(--blue); }
.hub--company::before { background:var(--orange); }
.hub__label { display:inline-flex; align-items:center; gap:11px; font-family:var(--display); font-weight:600; font-size:20px; }
.hub__label .hl-ic { width:30px; height:30px; border-radius:9px; display:grid; place-items:center; color:#fff; flex:none; }
.hub__label .hl-ic svg { width:17px; height:17px; }
.hub--agency .hl-ic { background:var(--blue); box-shadow:0 8px 18px -8px rgba(0,63,159,.7); }
.hub--company .hl-ic { background:var(--orange); box-shadow:0 8px 18px -8px rgba(255,117,0,.7); }
.hub p { margin-top:16px; color:var(--slate); font-size:15px; line-height:1.6; }
.hub__flow { margin-top:auto; margin-bottom:0; padding:14px 16px; border-radius:12px; font-size:14px; font-weight:600; display:flex; align-items:center; gap:11px; }
.hub--company .hub__flow { background:rgba(255,117,0,.09); color:var(--orange-ink); }
.hub--agency .hub__flow { background:rgba(0,63,159,.08); color:var(--blue-ink); }
.hub__check { width:22px; height:22px; flex:none; border-radius:50%; display:grid; place-items:center; color:#fff; }
.hub--company .hub__check { background:var(--orange); }
.hub--agency .hub__check { background:var(--blue); }
.hub__check svg { width:13px; height:13px; }
.hub .textlink { margin-top:20px; }
/* center connector */
.hubs__mid { position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:0 26px; gap:14px; }
.hubs__mid::before { content:""; position:absolute; top:0; bottom:0; left:50%; width:2px; background:linear-gradient(180deg,transparent,var(--line-2),transparent); }
.hubs__conn { position:relative; z-index:1; width:52px; height:52px; border-radius:50%; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); display:grid; place-items:center; color:var(--slate); }
.hubs__conn svg { width:24px; height:24px; }
.hubs__mid-txt { position:relative; z-index:1; background:var(--soft); padding:4px 6px; font-size:11.5px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; text-align:center; color:var(--slate-2); line-height:1.4; }

/* ecosystem portal cards */
.portal { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; }
.portal__top { display:flex; align-items:center; gap:12px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.portal__top .p-ic { width:42px; height:42px; border-radius:11px; display:grid; place-items:center; color:#fff; }
.portal__top h3 { font-size:18px; }
.portal__top .p-for { font-size:12.5px; color:var(--slate); margin-top:2px; }
.portal__up { margin-top:18px; padding-top:16px; border-top:1px dashed var(--line-2); }

/* CTA band */
.cta-band { position:relative; border-radius:var(--r-xl); padding:64px; text-align:center; background:radial-gradient(120% 140% at 50% -20%, #15244c, var(--navy) 60%); color:#fff; overflow:hidden; }
.cta-band::before { content:""; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px); background-size:46px 46px; mask-image:radial-gradient(70% 90% at 50% 0,#000,transparent 75%); opacity:.6; }
.cta-band > * { position:relative; z-index:2; }
.cta-band h2 { color:#fff; max-width:680px; margin:0 auto; }
.cta-band .lead { color:#aeb9cc; max-width:560px; margin:18px auto 0; }
.cta-band .fine { margin-top:20px; font-size:13.5px; color:#7e8aa3; }

/* values / who-we-build-for chips */
.chips { display:flex; flex-wrap:wrap; gap:12px; }
.chip { padding:12px 18px; border-radius:99px; background:#fff; border:1px solid var(--line); font-weight:500; font-size:15px; color:#39424f; transition:transform .2s var(--ease), border-color .2s; }
.chip:hover { transform:translateY(-2px); border-color:var(--blue); color:var(--blue); }

/* mission/vision */
.mv { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.mv__card { padding:32px; border-radius:var(--r-lg); border:1px solid var(--line); }
.mv__card.m { background:linear-gradient(160deg,#f7faff,#fff); }
.mv__card.v { background:linear-gradient(160deg,#fff7f0,#fff); }

/* contact */
.contact-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:start; }
.form { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; box-shadow:var(--shadow-sm); }
.field { margin-bottom:18px; }
.field label { display:block; font-size:13.5px; font-weight:600; margin-bottom:7px; color:#39424f; }
.field input, .field select, .field textarea {
  width:100%; padding:13px 14px; border:1px solid var(--line-2); border-radius:11px; font-family:var(--body); font-size:15px; color:var(--ink);
  background:#fff; transition:border-color .18s, box-shadow .18s;
}
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(0,63,159,.12); }
.field textarea { resize:vertical; min-height:96px; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form__ok { display:none; text-align:center; padding:24px; background:var(--green-tint); border-radius:12px; color:var(--green); font-weight:600; }
.contact-info .ci { display:flex; gap:14px; padding:18px 0; border-bottom:1px solid var(--line); }
.contact-info .ci .ci-ic { width:42px; height:42px; border-radius:11px; flex:none; background:var(--soft-2); color:var(--blue); display:grid; place-items:center; }
.contact-info .ci .ci-t { font-size:13px; color:var(--slate); }
.contact-info .ci .ci-v { font-weight:600; margin-top:2px; }

/* AI page chat */
.chat { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; box-shadow:var(--shadow-sm); }
.chat__q { margin-left:auto; max-width:80%; background:var(--blue); color:#fff; padding:12px 16px; border-radius:14px 14px 4px 14px; font-size:14.5px; }
.chat__a { max-width:90%; margin-top:14px; background:var(--soft); padding:14px 16px; border-radius:14px 14px 14px 4px; font-size:14.5px; color:#37404f; border:1px solid var(--line); }
.chat__a .ai-tag { display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--blue); margin-bottom:8px; }
/* typing animation */
.chat__q { min-height:1.4em; }
.chat__a { min-height:3.2em; }
.chat__type::after { content:"\200b"; }
.chat.is-typing .chat__type[data-typing="on"]::after {
  content:""; display:inline-block; width:2px; height:1.05em; vertical-align:-0.18em;
  margin-left:2px; background:currentColor; animation:caret 1s steps(1) infinite;
}
.chat__q .chat__type[data-typing="on"]::after { background:#fff; }
@keyframes caret { 0%,50%{opacity:1} 51%,100%{opacity:0} }
.chat__dots { display:none; align-items:center; gap:4px; }
.chat__dots.on { display:inline-flex; }
.chat__dots i { width:6px; height:6px; border-radius:50%; background:var(--slate-2); animation:dot 1.2s infinite ease-in-out; }
.chat__dots i:nth-child(2){ animation-delay:.18s; }
.chat__dots i:nth-child(3){ animation-delay:.36s; }
@keyframes dot { 0%,80%,100%{ transform:translateY(0); opacity:.4 } 40%{ transform:translateY(-4px); opacity:1 } }
@media (prefers-reduced-motion: reduce){
  .chat__dots i, .chat.is-typing .chat__type[data-typing="on"]::after { animation:none; }
}

.qbank { display:flex; flex-direction:column; gap:10px; }
.qbank li { padding:14px 16px; border:1px solid var(--line); border-radius:12px; font-size:14.5px; color:#39424f; display:flex; gap:10px; align-items:center; background:#fff; }
.qbank li svg { width:16px; height:16px; color:var(--blue); flex:none; }

/* legal pages */
.legal { max-width:820px; margin:0 auto; }
.legal h1 { font-size:clamp(32px,4vw,46px); }
.legal .updated { color:var(--slate); margin:14px 0 36px; font-size:15px; }
.legal h2 { font-size:23px; margin:38px 0 12px; }
.legal h3 { font-size:18px; margin:26px 0 8px; }
.legal p, .legal li { color:#39424f; font-size:16px; line-height:1.7; margin-bottom:12px; }
.legal ul { list-style:disc; padding-left:22px; }
.legal li { margin-bottom:8px; }
.legal .toc { background:var(--soft); border:1px solid var(--line); border-radius:var(--r); padding:22px 26px; margin-bottom:34px; }
.legal .toc a { color:var(--blue); font-size:15px; }
.legal .toc li { margin-bottom:6px; }
.legal a { color:var(--blue); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background:var(--navy); color:#9fadc2; padding:72px 0 32px; }
.footer__top { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; }
.footer .brand { color:#fff; }
.footer__tag { margin-top:18px; max-width:280px; font-size:15px; color:#8d9bb0; }
.footer__col h4 { font-family:var(--body); font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#6b7a91; margin-bottom:16px; }
.footer__col a { display:block; padding:7px 0; font-size:15px; color:#aeb9cc; transition:color .15s; }
.footer__col a:hover { color:#fff; }
.footer__bottom { margin-top:52px; padding-top:24px; border-top:1px solid rgba(255,255,255,.08); display:flex; justify-content:space-between; align-items:center; gap:16px; font-size:13.5px; color:#6b7a91; flex-wrap:wrap; }

/* ---- reveal ---- */
.reveal { transform:translateY(16px); transition:transform .7s var(--ease); will-change:transform; }
.reveal.in { transform:none; }
.reveal.d1 { transition-delay:.08s; } .reveal.d2 { transition-delay:.16s; } .reveal.d3 { transition-delay:.24s; } .reveal.d4 { transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){ .reveal{transform:none;transition:none;} html{scroll-behavior:auto;} }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .stats { grid-template-columns:repeat(2,1fr); gap:32px 24px; }
  .steps { grid-template-columns:repeat(2,1fr); gap:34px 0; }
  .step::after { display:none; }
  .footer__top { grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:880px){
  .nav__links, .nav__signin, .nav__group { display:none; }
  .nav__burger { display:flex; }
  .nav__cta .btn--primary { display:none; }
  .split, .contact-grid, .mv, .hubs { grid-template-columns:1fr; gap:24px; }
  .hubs__mid { flex-direction:row; padding:6px 0; gap:12px; }
  .hubs__mid::before { top:50%; bottom:auto; left:0; right:0; width:auto; height:2px; background:linear-gradient(90deg,transparent,var(--line-2),transparent); }
  .hubs__conn svg { transform:rotate(90deg); }
  .hub__flow { margin-top:18px; }
  .split--rev .split__media { order:0; }
  .mock__app { grid-template-columns:1fr; }
  .mock__side { display:none; }
}
@media (max-width:680px){
  body { font-size:16px; }
  .section { padding:68px 0; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns:1fr; }
  .stats { grid-template-columns:1fr 1fr; }
  .cta-band { padding:44px 24px; }
  .footer__top { grid-template-columns:1fr 1fr; }
  .hero__inner { padding-top:104px; }
  .field-row { grid-template-columns:1fr; }
}
@media (max-width:420px){
  .footer__top { grid-template-columns:1fr; }
  .stats { grid-template-columns:1fr; }
}
