/* HavenFi marketing site — kit styles. Tokens come from ../../colors_and_type.css */

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--fg1);
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{display:block;}
::selection{background:var(--blue-100);}

.container{max-width:1180px;margin:0 auto;padding:0 32px;}
.section{padding:96px 0;}
.section--tight{padding:72px 0;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-sans);font-size:15px;font-weight:600;
  line-height:1;padding:12px 20px;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;
  transition:background var(--dur-base) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);}
.btn svg{width:18px;height:18px;}
.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus);}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--blue-600);color:#fff;}
.btn-primary:hover{background:var(--blue-700);}
.btn-secondary{background:var(--panel);color:var(--fg1);border-color:var(--border-strong);}
.btn-secondary:hover{background:var(--slate-50);}
.btn-ghost{background:transparent;color:var(--fg1);}
.btn-ghost:hover{background:var(--slate-100);}
.btn-onblue{background:#fff;color:var(--blue-700);}
.btn-onblue:hover{background:var(--blue-50);}
.btn-lg{font-size:16px;padding:14px 24px;}
.btn-sm{font-size:14px;padding:9px 15px;}

/* ---------- eyebrow ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;color:var(--blue-600);white-space:nowrap;}
.eyebrow svg{width:15px;height:15px;}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);}
.nav-inner{display:flex;align-items:center;gap:32px;height:68px;}
.brand{display:flex;align-items:center;gap:10px;font-size:19px;font-weight:700;letter-spacing:-.02em;color:var(--fg1);}
.brand img{width:28px;height:28px;}
.brand .fi{color:inherit;}
.nav-links{display:flex;gap:26px;font-size:14.5px;font-weight:500;color:var(--fg2);}
.nav-links a{transition:color var(--dur-fast);}
.nav-links a:hover{color:var(--fg1);}
.nav-links a.active{color:var(--fg1);font-weight:600;}
.nav-spacer{flex:1;}
.nav-actions{display:flex;align-items:center;gap:14px;}

/* ---------- hero ---------- */
.hero{padding:84px 0 72px;}
.hero-grid{display:grid;grid-template-columns:1.02fr 1fr;gap:56px;align-items:center;}
.hero h1{font-size:54px;line-height:1.05;letter-spacing:-.025em;font-weight:700;margin:18px 0 0;color:var(--fg1);}
.hero .sub{font-size:19px;line-height:1.6;color:var(--fg2);margin:22px 0 0;max-width:34ch;}
.hero-cta{display:flex;gap:14px;margin-top:32px;}
.hero-trust{margin-top:28px;font-size:13px;color:var(--fg3);display:flex;align-items:center;gap:8px;}
.hero-trust svg{width:16px;height:16px;color:var(--success);}

/* ---------- product visual (app mock) ---------- */
.appcard{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);overflow:hidden;}
.appbar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--panel-subtle);}
.appbar .title{font-size:13px;font-weight:600;color:var(--fg2);margin-left:4px;}
.appbar .dot{width:10px;height:10px;border-radius:50%;}
.appbar .grow{flex:1;}
.appbar .live{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--success);
  background:var(--success-bg);border:1px solid var(--success-border);padding:3px 9px;border-radius:var(--radius-full);}
.appbar .live i{width:7px;height:7px;border-radius:50%;background:var(--success);display:block;}
.appbody{padding:18px;}
.alertbox{display:flex;gap:13px;background:var(--danger-bg);border:1px solid var(--danger-border);
  border-radius:var(--radius-lg);padding:15px;}
.alertbox .ai{width:40px;height:40px;border-radius:10px;background:#fff;color:var(--danger);
  display:flex;align-items:center;justify-content:center;flex:none;}
.alertbox .ai svg{width:22px;height:22px;}
.scoreline{display:flex;align-items:baseline;gap:9px;}
.scoreline .score{font-family:var(--font-mono);font-size:26px;font-weight:600;color:var(--danger);}
.scoreline .lab{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--danger);}
.alertbox .desc{font-size:13px;color:var(--slate-700);line-height:1.45;margin-top:3px;}
.meta-row{display:flex;gap:10px;margin-top:14px;}
.meta{flex:1;background:var(--panel-subtle);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;}
.meta .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg3);font-weight:600;}
.meta .v{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--fg1);margin-top:3px;font-variant-numeric:tabular-nums;}
.steps{margin-top:16px;}
.steps .sh{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg2);font-weight:600;margin-bottom:9px;}
.step{display:flex;align-items:center;gap:11px;padding:9px 0;border-top:1px solid var(--border);font-size:13.5px;color:var(--fg1);}
.step .sc{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border-strong);color:var(--fg2);
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex:none;}
.step.done .sc{background:var(--success);border-color:var(--success);color:#fff;}
.step.done svg{width:13px;height:13px;}
.step.active .sc{border-color:var(--blue-600);color:var(--blue-600);}
.step.active{font-weight:600;}

/* ---------- trust band ---------- */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--panel);}
.trust-inner{padding:34px 0;text-align:center;}
.trust .lab{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg3);}
.trust-logos{display:flex;justify-content:center;flex-wrap:wrap;gap:14px 44px;margin-top:22px;}
.trust-logos .inst{display:flex;align-items:center;gap:9px;font-size:16px;font-weight:700;color:var(--slate-400);letter-spacing:-.01em;}
.trust-logos .inst svg{width:20px;height:20px;}

/* ---------- section heading ---------- */
.sec-head{max-width:640px;}
.sec-head.center{margin:0 auto;text-align:center;}
.sec-head h2{font-size:38px;line-height:1.15;letter-spacing:-.02em;font-weight:700;margin:14px 0 0;}
.sec-head p{font-size:18px;line-height:1.6;color:var(--fg2);margin:16px 0 0;}

/* ---------- feature grid ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px;}
.feature{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);padding:26px;transition:box-shadow var(--dur-base),transform var(--dur-base);}
.feature:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.feature .ico{width:46px;height:46px;border-radius:11px;background:var(--blue-50);color:var(--blue-700);
  display:flex;align-items:center;justify-content:center;}
.feature .ico svg{width:23px;height:23px;}
.feature h3{font-size:19px;font-weight:600;margin:18px 0 0;letter-spacing:-.01em;}
.feature p{font-size:15px;line-height:1.6;color:var(--fg2);margin:10px 0 0;}

/* ---------- how it works ---------- */
.how{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:52px;}
.how-step{position:relative;}
.how-step .n{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--blue-600);}
.how-step .bar{height:2px;background:var(--border);margin:12px 0 18px;position:relative;}
.how-step .bar::before{content:"";position:absolute;left:0;top:0;height:2px;width:34px;background:var(--blue-600);}
.how-step h3{font-size:19px;font-weight:600;margin:0;letter-spacing:-.01em;}
.how-step p{font-size:15px;line-height:1.6;color:var(--fg2);margin:9px 0 0;}

/* ---------- stat band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px;}
.stat{text-align:left;border-left:2px solid var(--border);padding-left:18px;}
.stat .num{font-family:var(--font-mono);font-size:40px;font-weight:600;letter-spacing:-.02em;color:var(--fg1);
  font-variant-numeric:tabular-nums;line-height:1;}
.stat .num b{color:var(--blue-600);font-weight:600;}
.stat .lab{font-size:14px;color:var(--fg2);margin-top:11px;line-height:1.45;}

/* ---------- deep dive ---------- */
.deep{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center;}
.deep-list{margin-top:26px;display:flex;flex-direction:column;gap:18px;}
.deep-item{display:flex;gap:14px;}
.deep-item .di{width:38px;height:38px;border-radius:10px;flex:none;display:flex;align-items:center;justify-content:center;
  background:var(--blue-50);color:var(--blue-700);}
.deep-item .di svg{width:20px;height:20px;}
.deep-item h4{font-size:16px;font-weight:600;margin:2px 0 0;}
.deep-item p{font-size:14.5px;line-height:1.55;color:var(--fg2);margin:5px 0 0;}

/* ---------- testimonial ---------- */
.quote{background:var(--slate-900);border-radius:var(--radius-xl);padding:56px;color:#fff;}
.quote .eyebrow{color:var(--blue-200);}
.quote blockquote{font-size:28px;line-height:1.4;letter-spacing:-.015em;font-weight:600;margin:18px 0 0;max-width:24ch;}
.quote .by{display:flex;align-items:center;gap:13px;margin-top:30px;}
.quote .av{width:46px;height:46px;border-radius:50%;background:var(--slate-700);display:flex;align-items:center;
  justify-content:center;font-weight:600;font-size:16px;color:#fff;}
.quote .who .n{font-size:15px;font-weight:600;}
.quote .who .r{font-size:13px;color:var(--slate-400);margin-top:2px;}

/* ---------- cta ---------- */
.cta-band{background:var(--blue-600);border-radius:var(--radius-xl);padding:56px;text-align:center;color:#fff;
  background-image:linear-gradient(180deg,var(--blue-600),var(--blue-800));}
.cta-band h2{font-size:36px;letter-spacing:-.02em;font-weight:700;margin:0;}
.cta-band p{font-size:18px;color:var(--blue-100);margin:16px auto 0;max-width:46ch;line-height:1.55;}
.cta-band .row{display:flex;gap:14px;justify-content:center;margin-top:30px;}

/* ---------- footer ---------- */
.footer{background:var(--panel);border-top:1px solid var(--border);padding:56px 0 40px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;}
.footer .brand{margin-bottom:14px;}
.footer .blurb{font-size:14px;color:var(--fg2);line-height:1.6;max-width:30ch;}
.footer h5{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--fg3);font-weight:600;margin:0 0 14px;}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.footer ul a{font-size:14px;color:var(--fg2);}
.footer ul a:hover{color:var(--fg1);}
.footer-bottom{display:flex;align-items:center;gap:16px;margin-top:44px;padding-top:24px;border-top:1px solid var(--border);
  font-size:13px;color:var(--fg3);}
.footer-bottom .grow{flex:1;}

/* ---------- demo modal ---------- */
.modal-scrim{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(3px);z-index:100;
  display:flex;align-items:center;justify-content:center;padding:24px;animation:fade var(--dur-base) var(--ease-out);}
.modal{background:var(--panel);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:460px;max-width:100%;
  padding:32px;animation:rise var(--dur-slow) var(--ease-out);}
.modal h3{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:0;}
.modal p{font-size:15px;color:var(--fg2);line-height:1.55;margin:10px 0 0;}
.modal .field{margin-top:18px;}
.modal label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;}
.modal input{width:100%;font-family:var(--font-sans);font-size:14px;padding:11px 13px;border-radius:var(--radius-md);
  border:1px solid var(--border-strong);background:var(--panel);color:var(--fg1);}
.modal input:focus{outline:none;border-color:var(--blue-600);box-shadow:var(--shadow-focus);}
.modal .actions{display:flex;gap:12px;margin-top:24px;}
.modal-close{position:absolute;top:18px;right:18px;background:none;border:none;cursor:pointer;color:var(--fg3);}
.modal-success{text-align:center;padding:14px 0;}
.modal-success .ok{width:56px;height:56px;border-radius:50%;background:var(--success-bg);color:var(--success);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.modal-success .ok svg{width:28px;height:28px;}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ============================================================
   EDITORIAL LAYER — elevated, crafted sections
   ============================================================ */

/* keyword emphasis in headlines */
.kw{color:var(--blue-600);}
.hl{box-shadow:inset 0 -.14em 0 var(--blue-200);}

/* bigger editorial hero headline */
.hero h1{font-size:clamp(44px,5.4vw,68px);line-height:1.02;letter-spacing:-.03em;}
.hero .sub{font-size:20px;max-width:38ch;}
.eyebrow.idx::before{content:attr(data-idx);font-family:var(--font-mono);color:var(--fg3);margin-right:2px;}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--panel);}
.marquee-track{display:flex;width:max-content;animation:scroll 42s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-item{display:flex;align-items:center;gap:11px;padding:17px 30px;font-size:14px;font-weight:600;
  color:var(--fg2);white-space:nowrap;letter-spacing:-.01em;}
.marquee-item .d{width:5px;height:5px;border-radius:50%;background:var(--blue-600);flex:none;}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- editorial feature columns ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:52px;
  border-top:1px solid var(--border);box-shadow:none;}
.feature{background:transparent;border:0;border-right:1px solid var(--border);border-radius:0;box-shadow:none;
  padding:30px 30px 8px;transform:none;}
.feature:first-child{padding-left:0;}
.feature:last-child{border-right:0;padding-right:0;}
.feature:hover{transform:none;box-shadow:none;}
.feature .fnum{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--blue-600);}
.feature .ico{width:auto;height:auto;background:none;border-radius:0;color:var(--blue-700);margin-top:16px;}
.feature .ico svg{width:26px;height:26px;}
.feature h3{font-size:21px;margin-top:14px;}

/* ---------- how it works with imagery ---------- */
.how-steps{gap:24px;}
.how-step .shot{width:100%;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;display:flex;
  align-items:center;justify-content:center;border:1px solid var(--border);
  background:linear-gradient(160deg,var(--blue-50),var(--panel-subtle));}
.how-step .shot svg{width:46px;height:46px;color:var(--blue-600);opacity:.92;}
.how-step .n{display:inline-flex;align-items:center;gap:8px;margin:16px 0 0;}
.how-step .n b{color:var(--blue-600);}
.how-step .bar{display:none;}
.how-step h3{margin-top:10px;}

/* ---------- benchmark bar chart ---------- */
.bench{background:var(--panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.bars{margin-top:44px;display:flex;flex-direction:column;gap:14px;max-width:820px;}
.bar-row{display:grid;grid-template-columns:188px 1fr 78px;align-items:center;gap:20px;}
.bar-row .bl{font-size:14.5px;color:var(--fg1);font-weight:500;text-align:right;line-height:1.25;}
.bar-track{height:32px;background:var(--slate-100);border-radius:6px;overflow:hidden;}
.bar-fill{height:100%;border-radius:6px;width:0;background:var(--slate-300);
  transition:width 1.1s var(--ease-out);}
.bar-row.hl .bl{font-weight:700;}
.bar-row.hl .bar-fill{background:var(--blue-600);}
.bar-row .bv{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--fg2);
  font-variant-numeric:tabular-nums;text-align:right;}
.bar-row.hl .bv{color:var(--blue-700);}
.bench .foot{margin-top:26px;font-size:12.5px;color:var(--fg3);max-width:680px;line-height:1.5;}

/* ---------- case study (dark, big numbers) ---------- */
.case{background:var(--slate-900);color:#fff;border-radius:var(--radius-xl);overflow:hidden;
  display:grid;grid-template-columns:1.15fr .85fr;}
.case-body{padding:52px;}
.case-body .eyebrow{color:var(--blue-200);}
.case-body h2{color:#fff;font-size:40px;line-height:1.08;letter-spacing:-.025em;font-weight:700;margin:16px 0 0;}
.case-body h2 .kw{color:var(--blue-400,#60a5fa);}
.case-body .lede{font-size:16px;color:var(--slate-300);line-height:1.6;margin:18px 0 0;max-width:46ch;}
.case-stats{display:grid;grid-template-columns:1fr 1fr;gap:28px 36px;margin-top:36px;}
.case-stat .n{font-family:var(--font-mono);font-size:34px;font-weight:600;letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;line-height:1;}
.case-stat .n.accent{color:#60a5fa;}
.case-stat .l{font-size:13px;color:var(--slate-400);margin-top:8px;line-height:1.4;}
.case-quote{margin-top:38px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);}
.case-quote blockquote{font-size:18px;line-height:1.5;font-weight:500;margin:0;color:#e2e8f0;max-width:42ch;}
.case-quote .by{display:flex;align-items:center;gap:12px;margin-top:18px;}
.case-quote .by .who .nm{font-size:14px;font-weight:600;}
.case-quote .by .who .rl{font-size:12.5px;color:var(--slate-400);margin-top:2px;}
.case.case--solo{grid-template-columns:1fr;}
.case.case--solo .case-stats{max-width:560px;}

@media(max-width:900px){
  .hero-grid,.deep,.case{grid-template-columns:1fr;}
  .features{grid-template-columns:1fr;}
  .feature{border-right:0;border-bottom:1px solid var(--border);padding:26px 0;}
  .feature:first-child{padding-top:0;}
  .how-steps,.stats,.case-stats{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .nav-links{display:none;}
  .case-photo{min-height:280px;}
  .bar-row{grid-template-columns:120px 1fr 64px;gap:12px;}
}
