/* Shared design system for Upside inner pages (navy base + product indigo accent) */
:root{
  --font-serif:'Newsreader','Georgia',serif;--font-sans:'Inter',-apple-system,system-ui,sans-serif;
  --navy:#0F1B2D;--ink:#16223A;--ink-2:#46566A;--muted:#7C8C9C;--faint:#9aa1ab;
  --paper:#fff;--bg:#F6F8FC;--bg-2:#F1F4FA;--line:#E7EBF2;--line-2:#DCE2EC;
  --accent:#6366F1;--accent-2:#8B5CF6;--accent-deep:#4F46E5;--accent-soft:#EEF0FE;--accent-tint:#F3F1FB;
  --green:#10B981;--blue:#2563EB;--blue-bright:#3B82F6;--blue-soft:#E8F0FF;--gold:#F59E0B;--gold-soft:#FDF2DC;
  --radius:14px;--maxw:1180px;--ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 14px 40px -18px rgba(15,27,45,.20),0 6px 14px -8px rgba(15,27,45,.10);
  --shadow-lg:0 50px 90px -40px rgba(40,38,80,.32),0 20px 44px -26px rgba(15,27,45,.16);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
h1,h2,h3{font-family:var(--font-serif);font-weight:400;font-optical-sizing:auto;letter-spacing:-0.02em;color:var(--navy);margin:0;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px;}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);display:inline-block;}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:500;font-size:15px;letter-spacing:-0.01em;padding:12px 21px;border-radius:11px;border:1px solid transparent;cursor:pointer;transition:all .3s var(--ease);}
.btn-primary{background:var(--navy);color:#fff;}.btn-primary:hover{background:var(--accent-deep);transform:translateY(-1px);}
.btn-ghost{background:var(--paper);color:var(--navy);border-color:var(--line-2);}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn-text{color:var(--ink-2);font-weight:500;padding:12px 8px;}.btn-text:hover{color:var(--navy);}
.btn .arw{transition:transform .3s var(--ease);}.btn:hover .arw{transform:translateX(3px);}

header.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .4s var(--ease);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:17px 30px;display:flex;align-items:center;justify-content:space-between;transition:padding .4s var(--ease);}
header.nav.scrolled{background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--line);}
header.nav.scrolled .nav-inner{padding-top:12px;padding-bottom:12px;}
.brand{display:flex;align-items:center;gap:2px;font-weight:600;font-size:21px;letter-spacing:-0.02em;color:var(--navy);}
.brand-logo{height:22px;width:auto;display:block;}
.brand .tri{color:var(--accent);font-size:14px;margin-left:3px;transform:translateY(-1px);}
.nav-mid{display:flex;align-items:center;gap:30px;}
.nav-item{position:relative;font-size:15px;font-weight:500;color:var(--ink-2);cursor:pointer;display:flex;align-items:center;gap:5px;padding:6px 0;transition:color .2s;}
.nav-item:hover{color:var(--navy);}
.nav-right{display:flex;align-items:center;gap:10px;}
.drop{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;width:240px;opacity:0;visibility:hidden;transition:all .28s var(--ease);}
.nav-item:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.drop::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;}
.drop a{display:block;padding:10px 12px;border-radius:9px;font-weight:500;font-size:14.5px;color:var(--ink);transition:background .2s;}
.drop a:hover{background:var(--bg);color:var(--accent);}

/* mobile menu */
.nav-toggle{display:none;width:42px;height:42px;border:none;background:none;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:0;margin-left:4px;}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s var(--ease),opacity .2s var(--ease);}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.is-open span:nth-child(2){opacity:0;}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-menu{position:fixed;inset:0;z-index:99;background:var(--paper);padding:88px 26px 40px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;}
body.menu-open{overflow:hidden;}
body.menu-open .mobile-menu{opacity:1;visibility:visible;transform:none;}
.mobile-menu .mm-group{padding:8px 0 16px;border-bottom:1px solid var(--line);}
.mobile-menu .mm-label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:8px 0 6px;}
.mobile-menu .mm-group a{display:block;font-size:19px;font-weight:500;color:var(--navy);padding:9px 0;letter-spacing:-0.01em;}
.mobile-menu a.mm-top{display:block;font-size:19px;font-weight:500;color:var(--navy);padding:18px 0;border-bottom:1px solid var(--line);letter-spacing:-0.01em;}
.mobile-menu .mm-actions{display:flex;flex-direction:column;gap:12px;margin-top:26px;}
.mobile-menu .mm-actions .btn{width:100%;justify-content:center;padding:15px;font-size:16px;}

.hero{position:relative;padding:144px 0 84px;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:-1;}
.hero-bg .blob{position:absolute;border-radius:50%;filter:blur(72px);}
.hero-bg .b1{width:560px;height:560px;background:radial-gradient(circle,rgba(139,92,246,.16),transparent 70%);top:-160px;right:-120px;}
.hero-bg .b2{width:440px;height:440px;background:radial-gradient(circle,rgba(99,102,241,.10),transparent 70%);top:140px;left:-180px;}
.hero-grid{display:grid;grid-template-columns:1fr 1.08fr;gap:54px;align-items:center;}
.hero-copy{max-width:540px;}
.hero h1{font-size:clamp(40px,5vw,64px);line-height:1.04;letter-spacing:-0.028em;margin:18px 0 0;}
.hero .sub{margin:22px 0 0;font-size:19px;line-height:1.6;color:var(--ink-2);max-width:480px;}
.hero-actions{display:flex;gap:13px;margin-top:30px;flex-wrap:wrap;}

.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}

.viz{background:var(--paper);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;font-size:13px;}
.hero-viz{transform:perspective(1900px) rotateY(-3deg) rotateX(1.4deg);transform-origin:left center;opacity:0;transition:opacity 1s var(--ease),transform 1.1s var(--ease);}
.loaded .hero-viz{opacity:1;transform:perspective(1900px) rotateY(-2deg) rotateX(1deg);}
.viz-pad{padding:20px 22px;}
.reveal-i{opacity:0;transform:translateY(10px);transition:opacity .55s var(--ease),transform .55s var(--ease);}
.play .reveal-i{opacity:1;transform:none;}
.ov-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px;}
.ov-title{font-size:16px;font-weight:700;color:var(--navy);}
.ov-btn{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));padding:7px 11px;border-radius:9px;box-shadow:0 6px 14px -6px rgba(99,102,241,.6);}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px;}
.kpi .kl{font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.kpi .kv{font-size:21px;font-weight:700;letter-spacing:-0.02em;margin-top:5px;color:var(--navy);}
.kpi .ks{font-size:10.5px;color:var(--muted);margin-top:3px;}.kpi .ks.up{color:var(--green);font-weight:600;}
.ov-secl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:9px;}
.stack{position:relative;height:13px;border-radius:8px;background:#eef0f3;overflow:hidden;}
.seg{position:absolute;top:0;bottom:0;transform:scaleX(0);transform-origin:left center;transition:transform .9s var(--ease);}
.seg.s1{left:0;width:30%;background:var(--blue-bright);border-radius:8px 0 0 8px;}
.seg.s2{left:30%;width:50%;background:var(--gold);}
.seg.s3{left:80%;width:20%;background:var(--accent);border-radius:0 8px 8px 0;}
.play .seg.s1{transition-delay:.5s;transform:scaleX(1);}.play .seg.s2{transition-delay:.72s;transform:scaleX(1);}.play .seg.s3{transition-delay:.94s;transform:scaleX(1);}
.legend{display:flex;gap:16px;margin-top:11px;flex-wrap:wrap;}
.legend span{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-2);font-weight:500;}
.legend i{width:9px;height:9px;border-radius:3px;}
.ov-rows{margin-top:16px;border-top:1px solid var(--line);}
.ov-row{display:grid;grid-template-columns:1.5fr .7fr .6fr 1fr .7fr;gap:8px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);font-size:12px;}
.ov-row .nm{font-weight:600;color:var(--navy);}
.ov-row .badge{font-size:9.5px;font-weight:600;padding:3px 7px;border-radius:6px;justify-self:start;background:var(--blue-soft);color:var(--blue);}
.ov-row .badge.mm{background:var(--gold-soft);color:#b45309;}
.ov-row .yld{color:var(--green);font-weight:700;text-align:right;}
.ov-row .amt{text-align:right;font-weight:600;color:var(--navy);}

/* feature row layout (copy + animated tile) — shared with the homepage */
.frow{display:grid;grid-template-columns:0.92fr 1.08fr;gap:56px;align-items:center;padding:30px 0;}
.frow.flip .f-copy{order:2;}
.f-copy .k{font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);font-weight:600;}
.f-copy h3{font-size:clamp(24px,3vw,34px);line-height:1.14;margin:13px 0 0;}
.f-copy p{font-size:16.5px;color:var(--ink-2);line-height:1.6;margin:15px 0 0;max-width:440px;}
.f-copy ul{margin:18px 0 0;padding:0;list-style:none;}
.f-copy li{display:flex;align-items:center;gap:9px;font-size:14.5px;color:var(--ink-2);padding:6px 0;}
.f-copy li .ck{width:18px;height:18px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex:none;font-size:11px;font-weight:700;}
.stage{background:linear-gradient(160deg,var(--accent-tint),var(--bg-2) 60%,var(--bg));border:1px solid var(--line);border-radius:22px;padding:28px;display:flex;align-items:center;justify-content:center;}

/* cash forecast & optimization tile */
.cf-sub{font-size:11.5px;color:var(--muted);margin-top:3px;}
.cf-rows{margin-top:10px;}
.cf-row{display:flex;align-items:center;gap:12px;padding:7px 0;}
.cf-mo{flex:none;width:38px;font-size:11.5px;font-weight:600;color:var(--ink-2);}
.cf-bar{flex:1;display:flex;height:10px;border-radius:6px;overflow:hidden;background:#eef0f3;transform:scaleX(0);transform-origin:left center;transition:transform .8s var(--ease);}
.cf-seg{height:100%;}
.cf-seg.chk{background:var(--gold);}
.cf-seg.trs{background:linear-gradient(90deg,var(--accent-2),var(--accent));}
.cf-tot{flex:none;width:50px;text-align:right;font-size:12px;font-weight:700;color:var(--navy);font-variant-numeric:tabular-nums;}
.play .cf-row:nth-child(1) .cf-bar{transition-delay:.15s;transform:scaleX(1);}
.play .cf-row:nth-child(2) .cf-bar{transition-delay:.28s;transform:scaleX(1);}
.play .cf-row:nth-child(3) .cf-bar{transition-delay:.41s;transform:scaleX(1);}
.play .cf-row:nth-child(4) .cf-bar{transition-delay:.54s;transform:scaleX(1);}

/* static "Ask Upside" card (Upside AI hero) */
.chatcard{padding:22px;}
.chatcard .cc-h{display:flex;align-items:center;gap:9px;margin-bottom:15px;}
.chatcard .cc-ic{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;flex:none;box-shadow:0 6px 14px -6px rgba(99,102,241,.6);color:#fff;font-size:13px;}
.chatcard .cc-h b{font-size:14px;font-weight:700;color:var(--navy);}
.chatcard .cc-bub{max-width:88%;padding:11px 14px;border-radius:14px;font-size:13px;line-height:1.5;margin-bottom:10px;}
.chatcard .cc-user{margin-left:auto;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-bottom-right-radius:5px;}
.chatcard .cc-bot{background:var(--bg);border:1px solid var(--line);color:var(--ink-2);border-bottom-left-radius:5px;}
.chatcard .cc-bot b{color:var(--navy);font-weight:700;}
.chatcard .cc-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}
.chatcard .cc-chip{font-size:11.5px;color:var(--accent);background:var(--accent-soft);border-radius:999px;padding:7px 12px;}

.sec{padding:96px 0;}.sec.soft{background:var(--bg);}
.sec-head{max-width:680px;margin:0 auto;text-align:center;}
.sec-head h2{font-size:clamp(28px,3.6vw,42px);line-height:1.12;margin:14px 0 0;}
.sec-head p{margin:14px auto 0;font-size:17px;color:var(--ink-2);}
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;}
.duo{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:50px;max-width:880px;margin-left:auto;margin-right:auto;}
.feat{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:28px 26px;transition:all .4s var(--ease);}
.feat:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--line-2);}
.feat-ic{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.feat h3{font-size:19px;font-weight:500;line-height:1.22;margin-bottom:9px;letter-spacing:-0.012em;}
.feat p{font-size:14.5px;color:var(--ink-2);line-height:1.55;margin:0;}
.feat ul{margin:12px 0 0;padding:0;list-style:none;}
.feat li{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink-2);padding:5px 0;}
.feat li .ck{width:18px;height:18px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex:none;font-size:11px;font-weight:700;}

.cta-final{padding:30px 0 100px;}
.cta-card{background:linear-gradient(150deg,var(--navy) 0%,#1B2A48 55%,#241F46 100%);border-radius:26px;padding:74px 40px;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-lg);}
.cta-card::before{content:"";position:absolute;top:-150px;left:50%;transform:translateX(-50%);width:680px;height:400px;background:radial-gradient(ellipse,rgba(139,92,246,.34),transparent 64%);}
.cta-card .eyebrow{color:#A9B0F5;position:relative;}
.cta-card h2{color:#fff;font-size:clamp(30px,4vw,50px);margin:14px 0 0;line-height:1.06;position:relative;}
.cta-card .btn{margin-top:28px;position:relative;}
.cta-card .btn-primary{background:#fff;color:var(--navy);}.cta-card .btn-primary:hover{background:var(--accent-soft);}

footer.ft{border-top:1px solid var(--line);padding:60px 0 38px;}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:34px;}
.ft-brand .brand{margin-bottom:12px;}
.ft-col h5{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 14px;}
.ft-col a{display:block;font-size:14px;color:var(--ink-2);margin-bottom:10px;transition:color .2s;}.ft-col a:hover{color:var(--accent);}
.ft-bottom{margin-top:46px;padding-top:22px;border-top:1px solid var(--line);font-size:13px;color:var(--muted);}

@media (max-width:900px){
  .nav-mid,.nav-right{display:none;}.nav-toggle{display:flex;}.hero-grid{grid-template-columns:1fr;gap:46px;}
  .hero-viz{transform:none;}.loaded .hero-viz{transform:none;}
  .trio,.duo{grid-template-columns:1fr;}.ft-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .frow{grid-template-columns:1fr;gap:34px;}.frow.flip .f-copy{order:0;}
}
@media (max-width:600px){.wrap{padding:0 20px;}.kpis,.ft-grid{grid-template-columns:1fr;}.nav-right .btn-text,.nav-right .btn-ghost{display:none;}.cta-card{padding:52px 24px;}}
/* give content more presence on large / ultra-wide desktops */
@media (min-width:1600px){:root{--maxw:1320px;}body{font-size:18px;}}
@media (min-width:2200px){:root{--maxw:1440px;}}
@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;}.reveal,.reveal-i{opacity:1;transform:none;}.hero-viz{opacity:1;transform:none;}}
