/* ===== Harlan — enterprise B2B platform ===== */
:root{
  --navy:#0E2236; --navy-2:#0A1A2B; --amber:#E8A317; --amber-d:#cf9012;
  --ink:#16202B; --slate:#5B6B7A; --line:#E4E9EF; --line-2:#EEF2F6;
  --bg:#FFFFFF; --bg-2:#F6F8FB; --azure:#2563A8;
  --maxw:1180px; --r:12px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{margin:0;font-weight:800;letter-spacing:-.02em;line-height:1.12;color:var(--navy)}
p{margin:0}
a{color:inherit;text-decoration:none}
svg{display:block}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;
  padding:13px 24px;border-radius:8px;cursor:pointer;border:1.5px solid transparent;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--amber);color:var(--navy);border-color:var(--amber)}
.btn-primary:hover{background:var(--amber-d);border-color:var(--amber-d)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-outline:hover{border-color:#fff}
.btn-light{background:#fff;color:var(--navy);border-color:#fff}
.btn-light:hover{background:var(--bg-2)}
.btn-block{width:100%;font-size:16px;padding:15px}

/* utility bar */
.util{background:var(--navy-2);color:#c7d2dd;font-size:13px}
.util-inner{max-width:var(--maxw);margin:0 auto;padding:9px 28px;display:flex;justify-content:space-between;gap:16px;align-items:center}
.util-right{display:flex;gap:20px}
.util-right a{color:#c7d2dd}
.util-right a:hover{color:#fff}
.util-sales{color:var(--amber)!important;font-weight:600}

/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:14px 28px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px}
.brand-badge{width:36px;height:36px}
.brand-badge.sm{width:42px;height:42px}
.brand-word{font-family:'Oswald',sans-serif;font-weight:700;font-size:25px;letter-spacing:2px;color:var(--navy)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-weight:500;font-size:15px;color:var(--slate)}
.nav-links a:hover{color:var(--navy)}
.nav-cta{color:var(--navy)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:2.5px;background:var(--navy);border-radius:2px}

/* hero */
.hero{background:linear-gradient(180deg,#fff,var(--bg-2));padding:84px 28px 76px;border-bottom:1px solid var(--line)}
.hero-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.eyebrow{font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--azure);font-size:13px;margin-bottom:16px}
.hero h1{font-size:clamp(36px,5vw,60px)}
.lede{max-width:560px;font-size:clamp(17px,1.6vw,20px);color:var(--slate);margin:22px 0 28px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}
.hero-note{margin-top:22px;color:#8493a1;font-size:14px}

/* hero product mock */
.hero-visual{display:flex;justify-content:center}
.ui-card{width:100%;max-width:420px;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:0 30px 60px -20px rgba(14,34,54,.28);padding:22px}
.ui-head{display:flex;align-items:center;gap:9px;font-weight:600;color:var(--navy);font-size:14px;
  padding-bottom:14px;border-bottom:1px solid var(--line-2);margin-bottom:16px}
.ui-dot{width:9px;height:9px;border-radius:50%;background:#2bb673}
.ui-row{display:grid;grid-template-columns:1fr 1.4fr auto;align-items:center;gap:12px;margin-bottom:14px}
.ui-label{font-size:13px;color:var(--slate)}
.gauge{height:8px;background:var(--line-2);border-radius:6px;overflow:hidden}
.gauge span{display:block;height:100%;background:var(--azure);border-radius:6px}
.ui-val{font-weight:700;font-size:13px;color:var(--navy);text-align:right}
.ui-val.warn{color:#d9822b}
.ui-order{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--bg-2);
  border:1px solid var(--line);border-radius:10px;padding:13px 15px;margin-top:6px;font-size:13px}
.ui-sub{color:var(--slate)}
.ui-status{background:#e8f5ee;color:#1f8f5b;font-weight:600;font-size:12px;padding:5px 11px;border-radius:20px;white-space:nowrap}

/* credibility band */
.cred{background:var(--navy);color:#fff}
.cred-inner{max-width:var(--maxw);margin:0 auto;padding:26px 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.cred-item{display:flex;flex-direction:column;gap:2px;border-left:2px solid var(--amber);padding-left:16px}
.cred-item strong{font-size:18px}
.cred-item span{color:#a9b8c6;font-size:14px}

/* sections */
.section{max-width:var(--maxw);margin:0 auto;padding:92px 28px}
.section-head{margin-bottom:48px}
.section-head.center{text-align:center;max-width:760px;margin-left:auto;margin-right:auto}
.label{font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:13px;color:var(--azure);margin-bottom:12px}
.section-head h2{font-size:clamp(28px,3.6vw,42px)}
.section-head .sub{margin-top:14px;color:var(--slate);font-size:18px}

/* platform features */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:.15s}
.feat:hover{box-shadow:0 14px 34px -18px rgba(14,34,54,.3);transform:translateY(-3px);border-color:#d6dde6}
.ic{width:46px;height:46px;border-radius:10px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--azure);margin-bottom:16px}
.ic svg{width:24px;height:24px}
.feat h3{font-size:19px;margin-bottom:8px}
.feat p{color:var(--slate);font-size:15px}

/* solutions (dark) */
.solutions{max-width:none;background:var(--navy);color:#fff}
.solutions .section-head, .solutions .steps{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.section-head.light h2{color:#fff}
.section-head.light .label{color:var(--amber)}
.steps{list-style:none;margin:0;padding:0 28px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.steps li{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:28px}
.step-num{font-weight:800;font-size:15px;color:var(--amber);letter-spacing:.1em}
.steps h3{color:#fff;font-size:20px;margin:12px 0 8px}
.steps p{color:#b9c6d2;font-size:15px}

/* industries */
.industries{background:var(--bg-2);max-width:none}
.industries .section-head, .industries .ind-grid{max-width:var(--maxw);margin-left:auto;margin-right:auto;padding-left:28px;padding-right:28px}
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ind{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;border-top:3px solid var(--amber)}
.ind h3{font-size:18px;margin-bottom:7px}
.ind p{color:var(--slate);font-size:15px}

/* tech */
.tech{background:var(--navy);color:#fff}
.tech-inner{max-width:var(--maxw);margin:0 auto;padding:92px 28px;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.light-label{color:var(--amber)}
.tech h2{color:#fff;font-size:clamp(26px,3.4vw,40px)}
.tech-copy p{color:#b9c6d2;font-size:18px;margin-top:16px}
.checks{list-style:none;padding:0;margin:24px 0 0}
.checks li{padding-left:30px;position:relative;margin-bottom:12px;color:#dbe4ec}
.checks li::before{content:"";position:absolute;left:0;top:8px;width:12px;height:12px;border:2px solid var(--amber);border-top:0;border-right:0;transform:rotate(-45deg)}
.checks.dark li{color:var(--slate)}
.checks.dark li::before{border-color:var(--amber)}
.tech-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:22px}
.stat strong{display:block;font-size:18px;color:#fff}
.stat span{color:#a9b8c6;font-size:14px}

/* cta band */
.ctaband{background:var(--amber)}
.ctaband-inner{max-width:880px;margin:0 auto;padding:64px 28px;text-align:center}
.ctaband h2{font-size:clamp(26px,3.6vw,40px);color:var(--navy)}
.ctaband p{color:#5a4a17;font-size:18px;margin:14px 0 26px}
.ctaband-btns{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.ctaband .btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.ctaband .btn-primary:hover{background:var(--navy-2)}

/* start / form */
.start-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:54px;align-items:start}
.start-copy h2{font-size:clamp(26px,3.4vw,40px);margin-bottom:14px}
.start-copy p{color:var(--slate);font-size:17px}
.start-form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px;box-shadow:0 24px 60px -28px rgba(14,34,54,.3)}
.start-form label{display:block;font-weight:600;font-size:13px;color:var(--navy);margin-bottom:16px}
.start-form input,.start-form select{width:100%;margin-top:7px;padding:12px 13px;border-radius:8px;border:1px solid var(--line);
  background:#fff;color:var(--ink);font-size:15px;font-family:'Inter',sans-serif;font-weight:400}
.start-form input::placeholder{color:#9aa7b3}
.start-form input:focus,.start-form select:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 3px rgba(37,99,168,.12)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.needs{border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:0 0 16px}
.needs legend{font-weight:600;font-size:12px;color:var(--navy);padding:0 6px}
.chk{display:inline-flex!important;align-items:center;gap:7px;margin:6px 16px 6px 0;font-weight:400!important;font-size:14px!important;color:var(--ink)!important}
.chk input{width:auto!important;margin:0!important}
.fineprint{font-size:12px;color:#8493a1;font-weight:400;margin:14px 0 0}
.form-msg{margin:14px 0 0;font-weight:600;font-size:15px}
.form-msg.ok{color:#1f8f5b}
.form-msg.err{color:#c0392b}

/* footer */
.foot{background:var(--navy-2);color:#c7d2dd;padding:60px 28px 30px}
.foot-top{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:48px;flex-wrap:wrap;
  border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:36px}
.foot-brand .brand-word{color:#fff;font-size:26px}
.foot-brand .tagline{color:#90a1b1;font-size:14px;margin-top:10px;max-width:240px}
.foot-cols{display:flex;gap:56px;flex-wrap:wrap}
.foot-cols h4{color:#fff;font-size:14px;font-weight:600;margin-bottom:14px;letter-spacing:.02em}
.foot-cols a{display:block;color:#a9b8c6;font-size:14px;margin-bottom:9px}
.foot-cols a:hover{color:#fff}
.foot-bottom{max-width:var(--maxw);margin:24px auto 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#7d8e9d;font-size:13px}
.runs{color:var(--amber);font-weight:600}

/* responsive */
@media (max-width:920px){
  .hero-inner,.tech-inner,.start-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{order:-1}
  .feat-grid,.cred-inner{grid-template-columns:1fr 1fr}
  .ind-grid,.steps{grid-template-columns:1fr}
}
@media (max-width:860px){
  .util{display:none}
  .nav-links{position:fixed;top:65px;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;gap:0;
    padding:0 28px;max-height:0;overflow:hidden;transition:max-height .25s;border-bottom:1px solid var(--line)}
  .nav-links.open{max-height:360px;padding:10px 28px 22px}
  .nav-links a{padding:12px 0;width:100%}
  .nav-toggle{display:flex}
}
@media (max-width:560px){
  .feat-grid,.cred-inner,.tech-stats,.row2{grid-template-columns:1fr}
}

/* ===== polish / motion ===== */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.16,.84,.44,1), transform .7s cubic-bezier(.16,.84,.44,1)}
  .reveal.in{opacity:1;transform:none}
}
.nav{transition:box-shadow .2s ease, background .2s ease}
.nav.scrolled{box-shadow:0 8px 30px -14px rgba(14,34,54,.28)}
.btn{position:relative;overflow:hidden}
.btn-primary::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);transition:left .5s ease}
.btn-primary:hover::after{left:140%}

/* hero glow + chips */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(720px 340px at 80% 4%, rgba(232,163,23,.16), transparent 60%);pointer-events:none}
.hero-inner{position:relative;z-index:1}
.eyebrow-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(37,99,168,.08);color:var(--azure);border:1px solid rgba(37,99,168,.18);padding:6px 14px;border-radius:999px;font-weight:600;font-size:13px;letter-spacing:.02em;margin-bottom:18px}
.eyebrow-pill .pdot{width:7px;height:7px;border-radius:50%;background:var(--azure);box-shadow:0 0 0 4px rgba(37,99,168,.15)}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:26px}
.chip{font-size:13px;font-weight:600;color:var(--navy);background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 14px}

/* animated gauges + pulse */
@media (prefers-reduced-motion: no-preference){
  .ui-card .gauge span{transform:scaleX(0);transform-origin:left;animation:fillbar 1.3s .35s cubic-bezier(.16,.84,.44,1) forwards}
  .ui-dot{animation:pulse 2.2s infinite}
}
@keyframes fillbar{to{transform:scaleX(1)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(43,182,115,.5)}50%{box-shadow:0 0 0 7px rgba(43,182,115,0)}}
.hero-visual{position:relative}
.hero-visual::after{content:"";position:absolute;inset:auto -6% -12% 14%;height:72%;background:linear-gradient(180deg, rgba(37,99,168,.12), transparent);filter:blur(34px);border-radius:30px;z-index:-1}
.ui-card{transition:transform .3s ease}
.ui-card:hover{transform:translateY(-4px)}

/* stats band (animated counters) */
.stats{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats-inner{max-width:var(--maxw);margin:0 auto;padding:52px 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.st{border-right:1px solid var(--line)}
.st:last-child{border-right:0}
.statnum{font-family:'Inter',sans-serif;font-weight:800;font-size:clamp(40px,5vw,58px);color:var(--navy);letter-spacing:-.03em;line-height:1}
.statlabel{color:var(--slate);font-size:15px;margin-top:8px}

/* comparison */
.compare{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cmp-col{border-radius:14px;padding:32px}
.cmp-col.bad{background:var(--bg-2);border:1px solid var(--line)}
.cmp-col.good{background:var(--navy);color:#fff;box-shadow:0 30px 70px -32px rgba(14,34,54,.45)}
.cmp-col .cmp-h{display:flex;align-items:center;gap:10px;font-family:'Inter';font-weight:700;font-size:20px;color:var(--navy);margin-bottom:16px}
.cmp-col.good .cmp-h{color:#fff}
.cmp-list{list-style:none;padding:0;margin:0}
.cmp-list li{padding:12px 0 12px 32px;position:relative;border-bottom:1px solid rgba(0,0,0,.06)}
.cmp-col.good .cmp-list li{border-bottom:1px solid rgba(255,255,255,.1);color:#dbe4ec}
.cmp-list li:last-child{border-bottom:0}
.cmp-list.x li::before{content:"✕";position:absolute;left:2px;color:#c0563f;font-weight:700}
.cmp-list.check li::before{content:"✓";position:absolute;left:2px;color:var(--amber);font-weight:800}

/* credibility pills */
.indpills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.indpill{font-weight:600;font-size:14px;color:var(--navy);background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 16px;transition:.15s}
.indpill:hover{border-color:var(--amber);transform:translateY(-2px)}

@media (max-width:920px){ .stats-inner{grid-template-columns:1fr 1fr} .st:nth-child(2){border-right:0} .compare{grid-template-columns:1fr} }

/* ===== product tour ===== */
.tour-tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.tour-tab{font-family:'Inter';font-weight:600;font-size:14px;color:var(--slate);background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 18px;cursor:pointer;transition:.15s}
.tour-tab:hover{color:var(--navy)}
.tour-tab.is-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.tour-panels{max-width:860px;margin:0 auto}
.tour-panel{display:none;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 30px 70px -34px rgba(14,34,54,.32);overflow:hidden}
.tour-panel.is-active{display:block;animation:fadeup .45s ease}
@keyframes fadeup{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.tp-head{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--line-2);background:var(--bg-2);font-weight:600;color:var(--navy);font-size:14px}
.tp-dots{display:flex;gap:6px}
.tp-dots i{width:10px;height:10px;border-radius:50%;background:#d6dee6;display:inline-block}
.tp-body{padding:22px 24px}
.tp-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-2)}
.tp-row:last-child{border-bottom:0}
.tp-name{font-weight:600;color:var(--navy);font-size:15px}
.tp-sub{color:var(--slate);font-size:13px}
.tp-pill{font-size:12px;font-weight:600;padding:5px 11px;border-radius:20px;background:#e8f5ee;color:#1f8f5b;white-space:nowrap}
.tp-pill.amber{background:#fdf0d6;color:#9a6b12}
.tp-pill.blue{background:#e7f0fa;color:var(--azure)}
.tp-gauge{flex:1;max-width:200px;height:8px;background:var(--line-2);border-radius:6px;overflow:hidden}
.tp-gauge span{display:block;height:100%;background:var(--azure);border-radius:6px}
.tp-gauge span.warn{background:#d9822b}

/* ===== outcomes / proof ===== */
.outcomes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.outcome{background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px;border-top:3px solid var(--amber)}
.outcome .big{font-family:'Inter';font-weight:800;font-size:34px;color:var(--navy);letter-spacing:-.02em}
.outcome h3{font-size:18px;margin:6px 0 8px}
.outcome p{color:var(--slate);font-size:15px}
.quote{max-width:840px;margin:32px auto 0;background:var(--navy);color:#fff;border-radius:16px;padding:36px;text-align:center;position:relative}
.quote .qmark{font-family:'Oswald';font-size:60px;color:var(--amber);line-height:0;opacity:.5}
.quote p{font-size:clamp(18px,2.2vw,24px);font-weight:600;line-height:1.4;margin-top:6px}
.quote .qattr{color:#9fb0c0;font-size:14px;margin-top:16px;font-weight:500}
@media (max-width:920px){ .outcomes{grid-template-columns:1fr} }

/* ===== login ===== */
.auth{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:60px 24px;background:linear-gradient(180deg,#fff,var(--bg-2))}
.auth-card{width:100%;max-width:420px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 30px 70px -34px rgba(14,34,54,.3);padding:34px}
.auth-card .brand{justify-content:center;margin-bottom:8px}
.auth-card h1{font-size:26px;text-align:center;margin-bottom:6px}
.auth-card .auth-sub{text-align:center;color:var(--slate);font-size:15px;margin-bottom:22px}
.auth-card label{display:block;font-weight:600;font-size:13px;color:var(--navy);margin-bottom:16px}
.auth-card input{width:100%;margin-top:7px;padding:12px 13px;border-radius:8px;border:1px solid var(--line);font-size:15px;font-family:'Inter',sans-serif}
.auth-card input:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 3px rgba(37,99,168,.12)}
.auth-note{text-align:center;font-size:13px;color:var(--slate);margin-top:16px}
.auth-banner{background:#e7f0fa;color:var(--azure);border:1px solid rgba(37,99,168,.2);border-radius:8px;padding:10px 12px;font-size:13px;font-weight:600;text-align:center;margin-bottom:18px}
