/* ============================================================
   Axis — shared site styles
   Design tokens & chrome lifted from the v2 landing page so every
   page reads as one product. Page-specific components live below.
   ============================================================ */
:root {
  --ink:#0A2540; --navy:#0B1B2B; --slate:#425466; --muted:#8792A2;
  --ivory:#F9F8F6; --paper:#FFFFFF; --mist:#F3F2EF; --line:#E5E3DE; --line2:#D4D1CC;
  --lilac:#8FB8F0; --sky:#A3C8FF; --mint:#9FE7D8; --peach:#FFD6B8;
  --violet:#2A6FDB; --teal:#00D4B4; --amber:#F5A623; --red:#FF6259; --green:#00866F;
  --sans: ui-sans-serif, -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --mono: ui-monospace, 'SF Mono', 'Menlo', 'Consolas', monospace;
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
html,body { background:var(--mist); color:var(--ink); font-family:var(--sans); -webkit-font-smoothing:antialiased; letter-spacing:-0.011em; overflow-x:hidden; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
.mono { font-family:var(--mono); }
.eyebrow { font-family:var(--mono); font-size:10px; letter-spacing:0.16em; color:var(--muted); text-transform:uppercase; }
.wordmark { font-family:var(--sans); font-weight:500; letter-spacing:-0.04em; }
::selection { background:rgba(42,111,219,0.18); }

/* Grain + grid backdrop */
body::before {
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(10,37,64,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,37,64,0.04) 1px, transparent 1px);
  background-size: 88px 88px;
  mask-image: radial-gradient(ellipse at top, #000 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at top, #000 0%, transparent 70%);
}
body::after {
  content:''; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.04 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:0.6; mix-blend-mode:multiply;
}
.glow { position:fixed; pointer-events:none; z-index:0; width:780px; height:780px; border-radius:50%; filter:blur(120px); opacity:0.35; }
.glow-1 { top:-280px; right:-200px; background:radial-gradient(circle, rgba(143,184,240,0.7), transparent 60%); }
.glow-2 { top:480px; left:-280px; background:radial-gradient(circle, rgba(159,231,216,0.55), transparent 60%); }
main, nav, footer { position:relative; z-index:1; }

/* ===== nav ===== */
.nav { background:rgba(243,242,239,0.78); backdrop-filter:saturate(180%) blur(18px); -webkit-backdrop-filter:saturate(180%) blur(18px); border-bottom:1px solid var(--line); position:sticky; top:0; z-index:50; }
.nav-inner { max-width:1320px; margin:0 auto; padding:0 32px; height:64px; display:flex; align-items:center; gap:24px; }
.nav-brand { display:flex; align-items:center; gap:10px; }
.nav-links { display:flex; gap:28px; flex:1; justify-content:center; }
.nav-links a { font-size:13px; color:var(--slate); transition:color .15s; position:relative; cursor:pointer; }
.nav-links a::after { content:''; position:absolute; left:0; right:0; bottom:-22px; height:2px; background:var(--ink); transform:scaleX(0); transition:transform .25s ease; transform-origin:left; }
.nav-links a:hover { color:var(--ink); }
.nav-links a:hover::after { transform:scaleX(1); }
.nav-links a.active { color:var(--ink); }
.nav-cta { display:flex; align-items:center; gap:16px; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:9px 16px; border-radius:7px; font-size:13px; font-weight:500; transition:all .2s; cursor:pointer; border:1px solid transparent; white-space:nowrap; position:relative; overflow:hidden; }
.btn-primary { background:var(--ink); color:#fff; }
.btn-primary::before { content:''; position:absolute; inset:0; background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.18) 50%, transparent 70%); transform:translateX(-100%); transition:transform .6s; }
.btn-primary:hover { background:var(--navy); transform:translateY(-1px); box-shadow:0 8px 24px -8px rgba(10,37,64,0.4); }
.btn-primary:hover::before { transform:translateX(100%); }
.btn-ghost { background:transparent; color:var(--ink); border-color:var(--line2); }
.btn-ghost:hover { border-color:var(--ink); transform:translateY(-1px); }
.btn-lg { padding:13px 22px; font-size:14px; border-radius:8px; }
.btn-signin { background:var(--ink); color:#fff; padding:8px 18px; }
.btn-signin::before { content:''; position:absolute; inset:0; background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.22) 50%, transparent 70%); transform:translateX(-100%); transition:transform .6s; }
.btn-signin:hover { background:var(--navy); transform:translateY(-1px); box-shadow:0 8px 24px -8px rgba(10,37,64,0.55); }
.btn-signin:hover::before { transform:translateX(100%); }

.nav-burger { display:none; width:44px; height:44px; border-radius:8px; flex-direction:column; align-items:center; justify-content:center; gap:4.5px; }
.nav-burger span { display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s, opacity .25s; }
.nav-burger[aria-expanded="true"] span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.nav-burger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.nav-mobile { display:none; flex-direction:column; padding:6px 24px 16px; border-top:1px solid var(--line); }
.nav-mobile.open { display:flex; }
.nav-mobile a { padding:13px 4px; font-size:15px; color:var(--ink); border-bottom:1px solid var(--line); }
.nav-mobile a:last-of-type { border-bottom:0; }
@media (min-width:901px) { .nav-mobile { display:none !important; } .nav-burger { display:none !important; } }

/* ===== layout primitives ===== */
.container { max-width:1320px; margin:0 auto; padding:0 32px; position:relative; }
.container-narrow { max-width:880px; margin:0 auto; padding:0 32px; position:relative; }
section { padding:104px 0; position:relative; }
.section-tag { display:inline-flex; align-items:center; gap:8px; padding:5px 11px; border:1px solid var(--line2); border-radius:999px; background:var(--paper); }
.section-tag .dot { width:6px; height:6px; border-radius:50%; background:var(--violet); animation:pulse 2.4s ease-in-out infinite; }
.section-tag span:last-child { font-family:var(--mono); font-size:10px; letter-spacing:0.16em; color:var(--slate); }
@keyframes pulse { 0%,100% { box-shadow:0 0 0 0 rgba(42,111,219,0.5); } 50% { box-shadow:0 0 0 6px rgba(42,111,219,0); } }
.h2 { font-size:48px; line-height:1.04; letter-spacing:-0.038em; font-weight:500; color:var(--ink); max-width:820px; }
.lede { font-size:18px; line-height:1.55; color:var(--slate); max-width:640px; margin-top:18px; }
.divider { height:1px; background:var(--line); border:0; }

/* ===== page hero ===== */
.page-hero { padding:84px 0 28px; }
.page-hero .eyebrow { margin-bottom:22px; display:inline-block; }
.page-title { font-size:72px; line-height:0.98; letter-spacing:-0.045em; font-weight:500; color:var(--ink); max-width:18ch; }
.page-title em { font-style:normal; color:var(--violet); position:relative; display:inline-block; }
.page-title em::after { content:''; position:absolute; left:0; right:0; bottom:6px; height:14px; background:rgba(42,111,219,0.14); z-index:-1; transform:skewX(-6deg); }
.page-lede { font-size:20px; line-height:1.5; color:var(--slate); max-width:660px; margin-top:28px; }
.page-lede b { color:var(--ink); font-weight:500; }
.hero-actions { display:flex; gap:12px; margin-top:36px; align-items:center; flex-wrap:wrap; }

/* ===== generic card ===== */
.card { background:var(--paper); border:1px solid var(--line); border-radius:12px; }
.grid { display:grid; gap:16px; }
.cols-2 { grid-template-columns:repeat(2,1fr); }
.cols-3 { grid-template-columns:repeat(3,1fr); }
.cols-4 { grid-template-columns:repeat(4,1fr); }

/* ===== feature cards ===== */
.feature-card { background:var(--paper); border:1px solid var(--line); border-radius:12px; padding:26px; transition:transform .25s, box-shadow .25s, border-color .25s; position:relative; overflow:hidden; }
.feature-card:hover { transform:translateY(-3px); box-shadow:0 24px 50px -28px rgba(10,37,64,0.28); border-color:var(--line2); }
.feature-card .fc-ico { width:40px; height:40px; border-radius:9px; background:var(--mist); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--violet); margin-bottom:18px; }
.feature-card h3 { font-size:18px; font-weight:500; letter-spacing:-0.02em; color:var(--ink); }
.feature-card p { font-size:14px; line-height:1.6; color:var(--slate); margin-top:8px; }
.feature-card .fc-tag { font-family:var(--mono); font-size:9px; letter-spacing:0.14em; color:var(--muted); margin-bottom:10px; }

/* ===== split feature row ===== */
.split { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.split.flip > div:first-child { order:2; }
.split-eyebrow { font-family:var(--mono); font-size:10px; letter-spacing:0.16em; color:var(--violet); text-transform:uppercase; }
.split h3 { font-size:34px; font-weight:500; letter-spacing:-0.03em; color:var(--ink); margin-top:14px; line-height:1.08; }
.split p { font-size:16px; line-height:1.6; color:var(--slate); margin-top:16px; }
.split ul { list-style:none; margin-top:22px; display:flex; flex-direction:column; gap:12px; }
.split ul li { display:flex; gap:11px; font-size:14px; color:var(--ink); align-items:flex-start; }
.split ul li::before { content:'✓'; color:var(--green); font-size:12px; margin-top:2px; flex-shrink:0; }

/* image / mock placeholder */
.placeholder {
  border:1px solid var(--line); border-radius:12px; background:var(--paper);
  background-image: repeating-linear-gradient(135deg, rgba(10,37,64,0.035) 0 12px, transparent 12px 24px);
  display:flex; align-items:center; justify-content:center; min-height:300px;
  font-family:var(--mono); font-size:11px; letter-spacing:0.1em; color:var(--muted); text-align:center; padding:24px;
}

/* ===== pricing ===== */
.tiers { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:stretch; }
.tier { background:var(--paper); border:1px solid var(--line); border-radius:16px; padding:30px; display:flex; flex-direction:column; position:relative; }
.tier.featured { border-color:var(--ink); box-shadow:0 30px 70px -34px rgba(10,37,64,0.34); }
.tier .tier-flag { position:absolute; top:18px; right:18px; font-family:var(--mono); font-size:9px; letter-spacing:0.14em; color:#fff; background:var(--violet); padding:4px 9px; border-radius:999px; }
.tier .tier-name { font-size:14px; font-weight:500; color:var(--ink); letter-spacing:-0.01em; }
.tier .tier-desc { font-size:13px; color:var(--slate); margin-top:8px; line-height:1.5; min-height:56px; }
.tier .price { display:flex; align-items:baseline; gap:6px; margin:18px 0 4px; }
.tier .price .amt { font-size:46px; font-weight:500; letter-spacing:-0.04em; color:var(--ink); line-height:1; }
.tier .price .per { font-size:13px; color:var(--muted); }
.tier .price-note { font-family:var(--mono); font-size:10px; color:var(--muted); letter-spacing:0.04em; }
.tier .btn { width:100%; margin:22px 0; }
.tier-features { list-style:none; display:flex; flex-direction:column; gap:11px; }
.tier-features li { display:flex; gap:10px; font-size:13px; color:var(--ink); align-items:flex-start; line-height:1.45; }
.tier-features li::before { content:'✓'; color:var(--green); font-size:12px; margin-top:1px; flex-shrink:0; }
.tier-features li.off { color:var(--muted); }
.tier-features li.off::before { content:'–'; color:var(--line2); }

/* ===== stats / values / team ===== */
.stat-row { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line); }
.stat { padding:26px 24px 0 0; display:flex; flex-direction:column; gap:8px; }
.stat .v { font-size:42px; font-weight:500; letter-spacing:-0.035em; color:var(--ink); line-height:1; }
.stat .k { font-size:13px; color:var(--slate); }
.value-card { background:var(--paper); border:1px solid var(--line); border-radius:12px; padding:28px; }
.value-card .num { font-family:var(--mono); font-size:11px; letter-spacing:0.14em; color:var(--violet); }
.value-card h3 { font-size:20px; font-weight:500; letter-spacing:-0.02em; margin-top:14px; color:var(--ink); }
.value-card p { font-size:14px; line-height:1.6; color:var(--slate); margin-top:10px; }
.team-card { text-align:left; }
.team-avatar { width:100%; aspect-ratio:1; border-radius:12px; background:linear-gradient(135deg,var(--lilac),var(--mint)); border:1px solid var(--line); display:flex; align-items:flex-end; padding:14px; font-family:var(--mono); font-size:10px; color:rgba(10,37,64,0.55); }
.team-card .nm { font-size:15px; font-weight:500; color:var(--ink); margin-top:14px; }
.team-card .rl { font-size:13px; color:var(--slate); margin-top:3px; }

/* ===== careers ===== */
.role-row { display:flex; align-items:center; gap:20px; padding:22px 4px; border-top:1px solid var(--line); transition:padding-left .2s; }
.role-row:hover { padding-left:10px; }
.role-row:last-child { border-bottom:1px solid var(--line); }
.role-row .r-title { font-size:18px; font-weight:500; color:var(--ink); letter-spacing:-0.02em; flex:1; }
.role-row .r-meta { font-size:13px; color:var(--slate); width:160px; }
.role-row .r-dept { font-family:var(--mono); font-size:10px; letter-spacing:0.12em; color:var(--violet); width:150px; text-transform:uppercase; }
.role-row .r-arrow { color:var(--muted); transition:transform .2s, color .2s; }
.role-row:hover .r-arrow { transform:translateX(4px); color:var(--ink); }

/* ===== help center ===== */
.help-search { display:flex; align-items:center; gap:12px; background:var(--paper); border:1px solid var(--line); border-radius:12px; padding:16px 20px; max-width:560px; }
.help-search input { flex:1; border:0; outline:0; font-size:15px; color:var(--ink); background:transparent; font-family:inherit; }
.help-search input::placeholder { color:var(--muted); }
.help-search .kbd { font-family:var(--mono); font-size:10px; padding:3px 7px; background:var(--mist); border:1px solid var(--line); border-radius:5px; color:var(--slate); }
.help-cat { background:var(--paper); border:1px solid var(--line); border-radius:12px; padding:24px; transition:transform .22s, box-shadow .22s; cursor:pointer; }
.help-cat:hover { transform:translateY(-3px); box-shadow:0 20px 44px -26px rgba(10,37,64,0.26); }
.help-cat .hc-ico { font-size:20px; color:var(--violet); }
.help-cat h3 { font-size:16px; font-weight:500; color:var(--ink); margin-top:14px; }
.help-cat p { font-size:13px; color:var(--slate); margin-top:6px; line-height:1.5; }
.help-cat .hc-count { font-family:var(--mono); font-size:10px; color:var(--muted); margin-top:14px; letter-spacing:0.06em; }
.help-art { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:16px 0; border-top:1px solid var(--line); font-size:14px; color:var(--ink); }
.help-art:hover { color:var(--violet); }
.help-art .ha-arrow { color:var(--muted); }

/* ===== login ===== */
.auth-wrap { min-height:calc(100vh - 64px); display:grid; grid-template-columns:1fr 1fr; }
.auth-form-col { display:flex; align-items:center; justify-content:center; padding:48px 32px; }
.auth-card { width:100%; max-width:400px; }
.auth-card h1 { font-size:32px; font-weight:500; letter-spacing:-0.035em; color:var(--ink); }
.auth-card .sub { font-size:14px; color:var(--slate); margin-top:10px; line-height:1.55; }
.auth-field { display:flex; flex-direction:column; gap:7px; margin-top:18px; }
.auth-field label { font-family:var(--mono); font-size:10px; letter-spacing:0.12em; color:var(--muted); text-transform:uppercase; }
.auth-field input { padding:12px 14px; border:1px solid var(--line2); border-radius:9px; font-size:14px; font-family:inherit; color:var(--ink); background:var(--paper); transition:border-color .15s; }
.auth-field input:focus { outline:0; border-color:var(--ink); }
.auth-row { display:flex; align-items:center; justify-content:space-between; margin-top:16px; font-size:13px; color:var(--slate); }
.auth-row a { color:var(--violet); }
.auth-submit { width:100%; margin-top:22px; padding:13px; border-radius:9px; background:var(--ink); color:#fff; font-size:14px; font-weight:500; transition:background .15s; }
.auth-submit:hover { background:var(--navy); }
.auth-sso { display:flex; flex-direction:column; gap:10px; margin-top:18px; }
.auth-sso button { padding:11px; border:1px solid var(--line2); border-radius:9px; font-size:13px; font-weight:500; color:var(--ink); background:var(--paper); display:flex; align-items:center; justify-content:center; gap:9px; transition:border-color .15s, background .15s; }
.auth-sso button:hover { border-color:var(--ink); background:var(--mist); }
.auth-or { display:flex; align-items:center; gap:14px; margin:22px 0 6px; font-family:var(--mono); font-size:10px; letter-spacing:0.14em; color:var(--muted); }
.auth-or::before, .auth-or::after { content:''; flex:1; height:1px; background:var(--line); }
.auth-foot { margin-top:26px; font-size:13px; color:var(--slate); }
.auth-foot a { color:var(--violet); }
.auth-aside { background:var(--navy); color:#fff; padding:56px 48px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden; }
.auth-aside::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 30% 20%, rgba(42,111,219,0.32), transparent 55%), radial-gradient(ellipse at 80% 90%, rgba(0,212,180,0.22), transparent 55%); }
.auth-aside > * { position:relative; z-index:1; }
.auth-quote { font-size:26px; line-height:1.32; letter-spacing:-0.02em; font-weight:500; max-width:18ch; }
.auth-attr { font-size:13px; color:rgba(255,255,255,0.65); margin-top:20px; }
.auth-aside .a-stats { display:flex; gap:40px; }
.auth-aside .a-stats .v { font-size:30px; font-weight:500; letter-spacing:-0.03em; }
.auth-aside .a-stats .k { font-size:12px; color:rgba(255,255,255,0.6); margin-top:4px; }

/* ===== prose (legal pages) ===== */
.legal-layout { display:grid; grid-template-columns:240px 1fr; gap:64px; align-items:start; }
.toc { position:sticky; top:96px; }
.toc .toc-label { font-family:var(--mono); font-size:10px; letter-spacing:0.14em; color:var(--muted); text-transform:uppercase; margin-bottom:16px; }
.toc ul { list-style:none; display:flex; flex-direction:column; gap:2px; }
.toc a { display:block; font-size:13px; color:var(--slate); padding:6px 12px; border-left:2px solid var(--line); transition:color .15s, border-color .15s; }
.toc a:hover { color:var(--ink); border-left-color:var(--ink); }
.prose { max-width:680px; }
.prose .updated { font-family:var(--mono); font-size:11px; letter-spacing:0.06em; color:var(--muted); margin-bottom:36px; }
.prose h2 { font-size:24px; font-weight:500; letter-spacing:-0.025em; color:var(--ink); margin:48px 0 14px; scroll-margin-top:88px; }
.prose h2:first-of-type { margin-top:0; }
.prose h3 { font-size:16px; font-weight:500; color:var(--ink); margin:28px 0 10px; }
.prose p { font-size:15px; line-height:1.7; color:var(--slate); margin-bottom:16px; }
.prose ul, .prose ol { margin:0 0 16px 20px; }
.prose li { font-size:15px; line-height:1.7; color:var(--slate); margin-bottom:8px; }
.prose a { color:var(--violet); }
.prose a:hover { text-decoration:underline; }
.prose strong { color:var(--ink); font-weight:500; }
.callout { background:var(--paper); border:1px solid var(--line); border-left:3px solid var(--violet); border-radius:0 10px 10px 0; padding:18px 22px; margin:24px 0; }
.callout p { margin:0; font-size:14px; }

/* ===== contact / CTA band ===== */
.cta-band { background:var(--navy); border-radius:18px; padding:64px; text-align:center; position:relative; overflow:hidden; }
.cta-band::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 0%, rgba(42,111,219,0.3), transparent 60%); }
.cta-band > * { position:relative; z-index:1; }
.cta-band h2 { font-size:40px; font-weight:500; letter-spacing:-0.035em; color:#fff; line-height:1.06; }
.cta-band p { font-size:16px; color:rgba(255,255,255,0.7); margin-top:14px; max-width:46ch; margin-left:auto; margin-right:auto; }
.cta-band .actions { display:flex; gap:12px; justify-content:center; margin-top:30px; flex-wrap:wrap; }
.btn-on-dark { background:#fff; color:var(--ink); }
.btn-on-dark:hover { background:var(--mist); transform:translateY(-1px); }

/* ===== footer ===== */
.footer { background:var(--navy); color:#fff; padding:80px 0 32px; position:relative; }
.footer-inner { max-width:1320px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:1.4fr 3fr; gap:80px; }
.footer-cols { display:grid; grid-template-columns:repeat(3,1fr); gap:40px; }
.footer-list { list-style:none; margin-top:16px; display:flex; flex-direction:column; gap:10px; }
.footer-list a { font-size:13px; color:rgba(255,255,255,0.65); transition:color .15s; cursor:pointer; }
.footer-list a:hover { color:#fff; }
.footer-baseline { max-width:1320px; margin:56px auto 0; padding:24px 32px 0; border-top:1px solid rgba(255,255,255,0.08); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }

/* ===== reveal — content is visible by default (no blank/animation dependency).
   The .reveal / .reveal-stagger classes remain as harmless hooks. ===== */
.reveal, .reveal.on { opacity:1; transform:none; }
.reveal-stagger > *, .reveal-stagger.on > * { opacity:1; transform:none; }

/* ===== responsive ===== */
@media (max-width:900px) {
  .nav-links { display:none; }
  .nav-burger { display:flex; }
  section { padding:72px 0; }
  .page-title { font-size:46px; }
  .h2, .cta-band h2 { font-size:30px; }
  .split, .legal-layout, .auth-wrap { grid-template-columns:1fr; gap:36px; }
  .split.flip > div:first-child { order:0; }
  .tiers, .cols-2, .cols-3, .cols-4, .stat-row { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; gap:40px; }
  .footer-cols { grid-template-columns:repeat(2,1fr); }
  .toc { display:none; }
  .auth-aside { display:none; }
  .cta-band { padding:40px 24px; }
  .role-row .r-meta, .role-row .r-dept { display:none; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior:auto; }
  .reveal, .reveal-stagger > * { opacity:1 !important; transform:none !important; transition:none !important; }
}
