/* Finview — marketing site styles. Tokens from BRAND.md (accounter.co.za visual language). */
:root{
  --accent:#FF860B; --accent-dk:#E8740A; --accent-soft:#FFF1E2;
  --brand-dark:#0D333F; --brand-dark-2:#0A2832;
  --ink:#1A1A1A; --muted:#64748B; --outline:#334155;
  --surface:#FFFFFF; --surface-alt:#F8FAFC; --line:#E5E7EB;
  --positive:#16A34A; --negative:#DC2626;
  --radius:14px; --radius-sm:8px;
  --font-head:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,sans-serif;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--surface);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.15;margin:0;letter-spacing:-.02em}
p{margin:0}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-head);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.muted{color:var(--muted)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:600;font-size:15px;
  padding:12px 20px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:.15s ease;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dk);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--outline);background:var(--surface-alt)}
.btn-light{background:#fff;color:var(--brand-dark)}
.btn-light:hover{background:var(--accent-soft)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-lg{padding:14px 26px;font-size:16px}

/* ---------- logo ---------- */
.logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--ink)}
.logo .mark{width:30px;height:30px;flex:0 0 30px}
.logo.on-dark{color:#fff}

/* ---------- header ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header.site .bar{display:flex;align-items:center;gap:28px;height:68px}
header.site nav{display:flex;gap:26px;margin-left:8px}
header.site nav a{font-size:15px;color:var(--muted);font-weight:500}
header.site nav a:hover{color:var(--ink)}
header.site .spacer{margin-left:auto}
header.site .actions{display:flex;align-items:center;gap:12px}

/* ---------- hero ---------- */
.hero{background:radial-gradient(1200px 600px at 80% -10%,#15485a 0%,var(--brand-dark) 45%,var(--brand-dark-2) 100%);color:#fff;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding-top:84px;padding-bottom:90px}
.hero h1{font-size:clamp(34px,4.4vw,56px);font-weight:800;color:#fff}
.hero h1 .hl{color:var(--accent)}
.hero .lede{margin-top:20px;font-size:clamp(16px,1.5vw,19px);color:#c7d6dc;max-width:34em}
.hero .cta-row{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.hero .micro{margin-top:18px;font-size:13.5px;color:#8fa9b2;display:flex;gap:18px;flex-wrap:wrap}
.hero .micro span{display:inline-flex;align-items:center;gap:7px}
.tick{color:var(--accent)}

/* ---------- mock report window ---------- */
.mock{background:#fff;border-radius:var(--radius);box-shadow:0 30px 70px -20px rgba(0,0,0,.5);overflow:hidden;color:var(--ink);transform:rotate(.4deg)}
.mock .titlebar{display:flex;align-items:center;gap:8px;padding:11px 14px;background:var(--surface-alt);border-bottom:1px solid var(--line)}
.mock .dot{width:11px;height:11px;border-radius:50%}
.mock .dot.r{background:#ff5f57}.mock .dot.y{background:#febc2e}.mock .dot.g{background:#28c840}
.mock .titlebar .t{margin-left:8px;font-size:12.5px;color:var(--muted);font-weight:600}
.mock .body{padding:16px 18px 20px}
.mock .rhead{text-align:center;margin-bottom:12px}
.mock .rhead .b{font-family:var(--font-head);font-weight:700;font-size:14px}
.mock .rhead .s{font-size:11.5px;color:var(--muted)}
.mock table{width:100%;border-collapse:collapse;font-size:12.5px;font-variant-numeric:tabular-nums}
.mock td{padding:5px 4px}
.mock td.n{text-align:right;white-space:nowrap}
.mock thead td{font-size:11px;color:var(--ink);font-weight:700;border-bottom:1px solid var(--ink);text-align:right;padding-bottom:6px}
.mock thead td.py{background:#eef2f6}
.mock td.py{background:#eef2f6}
.mock tr.tot td{font-weight:700;border-top:1px solid var(--ink)}
.mock tr.grand td{font-weight:800;border-top:1px solid var(--outline);border-bottom:2px solid var(--outline)}
.mock .pill{display:inline-block;margin-top:12px;font-size:11px;color:var(--positive);background:#e9f7ee;border-radius:999px;padding:3px 10px;font-weight:600}

/* ---------- section scaffolding ---------- */
section{padding:84px 0}
.section-head{max-width:680px;margin:0 auto 52px;text-align:center}
.section-head h2{font-size:clamp(26px,3vw,38px);margin-top:12px}
.section-head p{margin-top:14px;font-size:17px;color:var(--muted)}
.alt{background:var(--surface-alt)}

/* value strip */
.strip{background:var(--brand-dark);color:#cfe0e6}
.strip .wrap{display:flex;gap:14px 40px;flex-wrap:wrap;justify-content:center;padding:22px 24px;font-family:var(--font-head);font-weight:600;font-size:15px}
.strip span{display:inline-flex;align-items:center;gap:9px}

/* feature grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.18s ease}
.card:hover{border-color:#d4dbe3;box-shadow:0 12px 30px -16px rgba(13,51,63,.25);transform:translateY(-2px)}
.card .ico{width:42px;height:42px;border-radius:10px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:16px}
.card h3{font-size:18px}
.card p{margin-top:8px;font-size:14.5px;color:var(--muted)}

/* split feature rows */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.rev .copy{order:2}
.split h2{font-size:clamp(24px,2.6vw,32px);margin-top:12px}
.split p.lede{margin-top:16px;font-size:16.5px;color:var(--muted)}
.split ul{margin:20px 0 0;padding:0;list-style:none;display:grid;gap:12px}
.split li{display:flex;gap:12px;font-size:15px}
.split li .tick{flex:0 0 auto;margin-top:3px}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 20px 50px -28px rgba(13,51,63,.4);overflow:hidden}

/* pack visual */
.pack-vis{display:flex;flex-direction:column;gap:0}
.pack-vis .sheettab{display:flex;gap:6px;padding:12px 14px 0;background:var(--surface-alt);border-bottom:1px solid var(--line)}
.pack-vis .sheettab b{font-size:12px;font-weight:600;color:var(--muted);padding:7px 12px;border-radius:8px 8px 0 0;border:1px solid var(--line);border-bottom:none;background:#fff}
.pack-vis .sheettab b.on{color:var(--ink);box-shadow:0 -2px 0 var(--accent) inset}
.pack-vis .pg{padding:18px 20px}
.pack-row{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px solid #f1f4f7;font-variant-numeric:tabular-nums}
.pack-row.h{color:var(--muted);font-weight:600;border-bottom-color:var(--ink)}
.pack-row.t{font-weight:700;border-top:1px solid var(--ink);border-bottom:2px solid var(--outline)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{position:relative;padding:26px 22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.step .num{width:34px;height:34px;border-radius:9px;background:var(--brand-dark);color:#fff;font-family:var(--font-head);font-weight:800;display:grid;place-items:center;margin-bottom:14px}
.step h3{font-size:16.5px}
.step p{margin-top:7px;font-size:14px;color:var(--muted)}

/* roadmap */
.road{display:grid;grid-template-columns:repeat(auto-fit,minmax(232px,1fr));gap:18px}
.road .r{padding:20px 22px;border-radius:var(--radius);border:1px solid var(--line)}
.road .r .tag{font-family:var(--font-head);font-weight:800;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.road .r h4{margin-top:6px;font-size:16px}
.road .r p{margin-top:6px;font-size:14px;color:var(--muted)}
.road .live{border-color:var(--accent);background:var(--accent-soft)}
.road .live .tag{color:var(--accent-dk)}
.road .soon .tag{color:var(--muted)}
.badge{display:inline-block;font-size:11px;font-weight:700;font-family:var(--font-head);padding:2px 9px;border-radius:999px;margin-left:8px;vertical-align:middle}
.badge.now{background:var(--accent);color:#fff}
.badge.soon{background:#e2e8f0;color:var(--outline)}

/* CTA band */
.cta{background:linear-gradient(120deg,var(--brand-dark),#14485a);color:#fff;border-radius:22px;padding:56px;text-align:center}
.cta h2{font-size:clamp(26px,3vw,36px);color:#fff}
.cta p{margin-top:14px;color:#bcd0d8;font-size:17px;max-width:40em;margin-left:auto;margin-right:auto}
.cta .cta-row{margin-top:28px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* footer */
footer.site{background:var(--brand-dark-2);color:#9fb4bd;padding:56px 0 30px}
footer.site .top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.1)}
footer.site h5{font-family:var(--font-head);color:#fff;font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 14px}
footer.site a{display:block;color:#9fb4bd;font-size:14.5px;padding:5px 0}
footer.site a:hover{color:#fff}
footer.site .blurb{font-size:14.5px;max-width:30em;margin-top:14px}
footer.site .bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:22px;font-size:13.5px}
footer.site .bottom a{display:inline}

/* ---------- login page ---------- */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth .brandside{background:radial-gradient(900px 500px at 70% -10%,#15485a,var(--brand-dark) 55%,var(--brand-dark-2));color:#fff;padding:48px 56px;display:flex;flex-direction:column}
.auth .brandside .grow{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:30em}
.auth .brandside h2{font-size:32px;color:#fff;margin-top:20px}
.auth .brandside p{margin-top:16px;color:#c7d6dc;font-size:16px}
.auth .brandside ul{margin:26px 0 0;padding:0;list-style:none;display:grid;gap:14px}
.auth .brandside li{display:flex;gap:11px;color:#dce8ec;font-size:15px}
.auth .formside{display:flex;align-items:center;justify-content:center;padding:40px 24px}
.authcard{width:100%;max-width:400px}
.authcard h1{font-size:26px}
.authcard .sub{color:var(--muted);margin-top:8px;font-size:15px}
.field{margin-top:18px}
.field label{display:block;font-size:13.5px;font-weight:600;margin-bottom:7px}
.field input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:15px;background:#fff}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.authcard .row{display:flex;justify-content:space-between;align-items:center;margin-top:14px;font-size:13.5px}
.authcard .full{width:100%;justify-content:center;margin-top:22px}
.authcard .alt{background:transparent;text-align:center;margin-top:22px;font-size:14px;color:var(--muted);padding:0}
.note{margin-top:24px;background:var(--accent-soft);border:1px solid #f3d6b3;color:#8a5a16;border-radius:var(--radius-sm);padding:12px 14px;font-size:13px}
.backlink{font-size:14px;color:var(--muted);display:inline-flex;gap:6px;align-items:center}
.backlink:hover{color:var(--ink)}

/* ---------- responsive ---------- */
@media (max-width:900px){
  header.site nav{display:none}
  .hero .wrap{grid-template-columns:1fr;gap:36px;padding-top:54px;padding-bottom:60px}
  .hero .mockwrap{max-width:460px}
  .grid,.steps{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:30px}
  .split.rev .copy{order:0}
  .auth{grid-template-columns:1fr}
  .auth .brandside{display:none}
  footer.site .top{grid-template-columns:1fr 1fr}
  section{padding:60px 0}
  .cta{padding:40px 24px}
}
@media (max-width:560px){
  footer.site .top{grid-template-columns:1fr}
  .strip .wrap{font-size:13.5px}
}
