/* ===== Actuary CPD Tracker — marketing site (Pace light theme) ===== */
:root{
  --accent:#0e8a5f; --accent-press:#0b6e4c; --on-accent:#fff;
  --green:#0e8a5f; --amber:#d98a2b; --coral:#d6502f;
  --canvas:#f6f4f0; --canvas-2:#efece6; --surface:#fff; --surface-2:#faf8f5;
  --ink:#1c1a17; --ink-soft:#6f6a63; --ink-faint:#a39a90;
  --hairline:#f1ece5; --hairline-2:#e8e2d9; --track:#ece6dd; --chip:#f3f0ea;
  --accent-soft:color-mix(in srgb, var(--accent) 11%, transparent);
  --sage:color-mix(in srgb, var(--accent) 14%, #fff);
  --shadow-card:0 1px 2px rgba(28,26,23,.04), 0 14px 30px -22px rgba(28,26,23,.22);
  --shadow-hero:0 2px 4px rgba(28,26,23,.05), 0 40px 80px -34px rgba(28,26,23,.42);
  --font:'Plus Jakarta Sans',-apple-system,system-ui,sans-serif;
  --maxw:1180px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--canvas); color:var(--ink); font-family:var(--font);
  -webkit-font-smoothing:antialiased; line-height:1.5;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{
  font-size:13px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:var(--accent);
}
h1,h2,h3{letter-spacing:-.028em;line-height:1.04;font-weight:800;text-wrap:balance;}
p{text-wrap:pretty;}
.muted{color:var(--ink-soft);}

/* ---------- buttons / badges ---------- */
.appstore{
  display:inline-flex;align-items:center;gap:11px;
  background:var(--ink);color:#fff;border-radius:15px;
  padding:13px 22px 13px 18px;transition:transform .18s ease, background .18s ease;
}
.appstore:hover{transform:translateY(-2px);background:#000;}
.appstore svg{width:27px;height:27px;flex:0 0 27px;fill:#fff;}
.appstore .t{display:flex;flex-direction:column;line-height:1.12;}
.appstore .t small{font-size:11px;font-weight:600;letter-spacing:.02em;opacity:.82;}
.appstore .t b{font-size:19px;font-weight:700;letter-spacing:-.01em;}
.cta-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.cta-note{font-size:13.5px;font-weight:500;color:var(--ink-soft);max-width:200px;line-height:1.4;}
.cta-note b{color:var(--ink);font-weight:700;}

/* ---------- header ---------- */
header.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb, var(--canvas) 82%, transparent);
  backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s ease, background .3s ease;
}
header.nav.scrolled{border-bottom-color:var(--hairline-2);}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px;}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:17px;letter-spacing:-.02em;}
.brand .mark{
  width:34px;height:34px;border-radius:10px;flex:0 0 34px;
  background:var(--accent);display:grid;place-items:center;color:#fff;
  box-shadow:0 4px 10px -4px color-mix(in srgb,var(--accent) 60%, transparent);
}
.brand .mark svg{width:20px;height:20px;fill:none;stroke:#fff;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-size:14.5px;font-weight:600;color:var(--ink-soft);transition:color .15s;}
.nav-links a:hover{color:var(--ink);}
.nav-cta{display:flex;align-items:center;gap:18px;}
.nav-cta .mini{
  display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;
  font-size:14px;font-weight:700;padding:9px 16px;border-radius:11px;transition:transform .16s, background .16s;
}
.nav-cta .mini:hover{transform:translateY(-1px);background:#000;}
.nav-cta .mini svg{width:15px;height:15px;fill:#fff;}
@media(max-width:820px){.nav-links{display:none;}}

/* ---------- device frame ---------- */
.device{
  position:relative;width:var(--dw,300px);flex:0 0 auto;
  background:linear-gradient(150deg,#dcd7cf,#c9c3ba 52%,#bdb7ad);
  border-radius:15.5% / 7.2%;padding:2.5%;
  box-shadow:var(--shadow-hero);
}
.device::after{content:"";position:absolute;inset:0;border-radius:inherit;
  border:1px solid rgba(255,255,255,.5);pointer-events:none;}
.device .screen{position:relative;border-radius:13.5%/6.3%;overflow:hidden;background:#000;}
.device .screen img{width:100%;}
.device .island{
  position:absolute;top:3.6%;left:50%;transform:translateX(-50%);
  width:30%;height:2.6%;min-height:18px;background:#000;border-radius:99px;z-index:2;
}

/* ---------- hero (shared) ---------- */
.hero{padding:54px 0 40px;position:relative;}
.hero-a,.hero-b,.hero-c{display:none;}
body[data-hero="a"] .hero-a{display:block;}
body[data-hero="b"] .hero-b{display:block;}
body[data-hero="c"] .hero-c{display:block;}
.glow{
  position:absolute;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 20%,transparent),transparent 70%);
  filter:blur(20px);pointer-events:none;z-index:0;
}
.h-trust{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;font-weight:700;color:var(--ink-faint);letter-spacing:.02em;}
.h-trust .dot{width:4px;height:4px;border-radius:50%;background:var(--ink-faint);opacity:.5;}

/* hero A — split */
.hero-a .grid{display:grid;grid-template-columns:1.06fr .94fr;gap:40px;align-items:center;}
.hero-a h1{font-size:clamp(38px,5.4vw,62px);}
.hero-a .sub{margin-top:22px;font-size:clamp(17px,1.7vw,20px);color:var(--ink-soft);font-weight:500;max-width:30ch;}
.hero-a .cta-row{margin-top:34px;}
.hero-a .h-trust{margin-top:30px;}
.hero-a .art{position:relative;display:flex;justify-content:center;}
.hero-a .device{--dw:312px;}
.hero-a .glow{width:420px;height:420px;top:-30px;right:-40px;}

/* hero B — centered + cluster */
.hero-b{text-align:center;}
.hero-b .top{max-width:760px;margin:0 auto;display:flex;flex-direction:column;align-items:center;}
.hero-b h1{font-size:clamp(40px,6vw,72px);margin-top:18px;}
.hero-b .sub{margin-top:22px;font-size:clamp(17px,1.7vw,20px);color:var(--ink-soft);font-weight:500;max-width:54ch;}
.hero-b .cta-row{margin-top:32px;justify-content:center;}
.hero-b .cluster{position:relative;height:520px;margin-top:30px;display:flex;justify-content:center;align-items:flex-start;}
.hero-b .cluster .device{position:absolute;top:0;}
.hero-b .cluster .d1{--dw:236px;transform:translateX(-58%) translateY(40px) rotate(-7deg);z-index:1;}
.hero-b .cluster .d2{--dw:268px;z-index:3;}
.hero-b .cluster .d3{--dw:236px;transform:translateX(58%) translateY(40px) rotate(7deg);z-index:1;}
.hero-b .glow{width:560px;height:560px;top:120px;left:50%;transform:translateX(-50%);}

/* hero C — editorial */
.hero-c .bar{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  font-size:12.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);
  padding-bottom:26px;margin-bottom:40px;border-bottom:1px solid var(--hairline-2);
}
.hero-c .bar .lab{color:var(--ink-soft);letter-spacing:.04em;text-transform:none;font-size:13.5px;}
.hero-c .grid{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center;}
.hero-c h1{font-size:clamp(44px,7vw,86px);line-height:.98;}
.hero-c h1 .em{color:var(--accent);}
.hero-c .sub{margin-top:26px;font-size:clamp(17px,1.7vw,21px);color:var(--ink-soft);font-weight:500;max-width:34ch;}
.hero-c .cta-row{margin-top:36px;}
.hero-c .art{position:relative;display:flex;justify-content:flex-end;}
.hero-c .device{--dw:330px;transform:rotate(4deg);}
.hero-c .glow{width:480px;height:480px;top:-20px;right:-90px;}

/* ---------- standards strip ---------- */
.strip{padding:30px 0;border-top:1px solid var(--hairline-2);border-bottom:1px solid var(--hairline-2);background:var(--surface-2);}
.strip .lead{font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--ink-faint);text-align:center;margin-bottom:18px;}
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}
.chip{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--surface);border:1px solid var(--hairline-2);
  border-radius:999px;padding:10px 18px;font-size:15px;font-weight:700;color:var(--ink);
  box-shadow:0 1px 1px rgba(28,26,23,.03);
}
.chip i{width:7px;height:7px;border-radius:50%;background:var(--accent);}

/* ---------- section heads ---------- */
.sec{padding:96px 0;}
.sec-head{max-width:660px;margin:0 auto 64px;text-align:center;}
.sec-head h2{font-size:clamp(30px,3.6vw,46px);}
.sec-head p{margin-top:18px;font-size:18px;color:var(--ink-soft);font-weight:500;}

/* ---------- features (alternating rows) ---------- */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-bottom:108px;}
.feat:last-child{margin-bottom:0;}
.feat:nth-child(even) .f-art{order:2;}
.feat .f-num{font-size:13px;font-weight:800;color:var(--accent);letter-spacing:.04em;}
.feat h3{font-size:clamp(26px,3vw,38px);margin-top:14px;}
.feat .f-body{margin-top:18px;font-size:17.5px;color:var(--ink-soft);font-weight:500;line-height:1.6;}
.feat ul{margin-top:22px;display:flex;flex-direction:column;gap:12px;}
.feat li{display:flex;gap:12px;align-items:flex-start;font-size:16px;font-weight:600;color:var(--ink);}
.feat li svg{width:21px;height:21px;flex:0 0 21px;margin-top:1px;stroke:var(--accent);fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;}
.f-art{display:flex;justify-content:center;position:relative;}
.f-art .device{--dw:286px;}
.f-art .halo{position:absolute;inset:auto;width:360px;height:360px;border-radius:50%;
  background:var(--accent-soft);filter:blur(10px);z-index:-1;top:50%;left:50%;transform:translate(-50%,-50%);}

/* ---------- compare (mobile vs web) ---------- */
.compare-sec{background:var(--surface-2);border-top:1px solid var(--hairline-2);border-bottom:1px solid var(--hairline-2);}
.compare{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:920px;margin:0 auto;}
.cmp{background:var(--surface);border:1px solid var(--hairline-2);border-radius:22px;padding:34px;box-shadow:var(--shadow-card);}
.cmp.them{background:var(--canvas-2);box-shadow:none;}
.cmp .cmp-h{display:flex;align-items:center;gap:12px;margin-bottom:24px;}
.cmp .cmp-h .tag{font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;}
.cmp.us .tag{color:var(--accent);}
.cmp.them .tag{color:var(--ink-faint);}
.cmp .cmp-h h3{font-size:20px;font-weight:800;}
.cmp ul{display:flex;flex-direction:column;gap:16px;}
.cmp li{display:flex;gap:13px;align-items:flex-start;font-size:16px;font-weight:600;line-height:1.45;}
.cmp.us li{color:var(--ink);}
.cmp.them li{color:var(--ink-soft);}
.cmp li svg{width:22px;height:22px;flex:0 0 22px;margin-top:1px;}
.cmp.us li svg{stroke:var(--accent);fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;}
.cmp.them li svg{stroke:var(--ink-faint);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;}

/* ---------- built for actuaries ---------- */
.creds{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:720px;margin:0 auto 56px;}
.cred{background:var(--chip);border-radius:10px;padding:9px 15px;font-size:14.5px;font-weight:700;color:var(--ink);letter-spacing:.01em;}
.std-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1000px;margin:0 auto;}
.std{background:var(--surface);border:1px solid var(--hairline-2);border-radius:18px;padding:26px;box-shadow:var(--shadow-card);}
.std .nm{font-size:17px;font-weight:800;letter-spacing:-.01em;}
.std .rq{margin-top:8px;font-size:14.5px;font-weight:600;color:var(--accent);}
.std .ds{margin-top:10px;font-size:14px;color:var(--ink-soft);font-weight:500;line-height:1.5;}
.engine{
  max-width:760px;margin:54px auto 0;text-align:center;
  background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);
  border-radius:20px;padding:34px 38px;
}
.engine p{font-size:18px;font-weight:600;color:var(--ink);line-height:1.55;}
.engine p b{color:var(--accent);}

/* ---------- final CTA ---------- */
.final{background:var(--ink);color:#fff;text-align:center;padding:104px 0;position:relative;overflow:hidden;}
.final .glow{width:680px;height:680px;top:-220px;left:50%;transform:translateX(-50%);
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 42%,transparent),transparent 68%);opacity:.5;}
.final .eyebrow{color:color-mix(in srgb,var(--accent) 60%,#fff);}
.final h2{font-size:clamp(34px,4.6vw,58px);color:#fff;position:relative;}
.final .sub{margin:20px auto 0;font-size:19px;color:#cfc8bd;font-weight:500;max-width:46ch;position:relative;}
.final .cta-row{justify-content:center;margin-top:38px;position:relative;}
.final .appstore{background:#fff;color:var(--ink);}
.final .appstore:hover{background:#fff;}
.final .appstore svg{fill:var(--ink);}
.final .pricing{margin-top:26px;font-size:15px;font-weight:600;color:#a39a90;position:relative;}
.final .pricing b{color:#fff;}

/* ---------- footer ---------- */
footer{background:var(--canvas);padding:56px 0 44px;border-top:1px solid var(--hairline-2);}
.foot-in{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;flex-wrap:wrap;}
.foot-brand{display:flex;flex-direction:column;gap:12px;max-width:340px;}
.foot-brand .brand{font-size:16px;}
.foot-brand p{font-size:13.5px;color:var(--ink-soft);font-weight:500;line-height:1.5;}
.foot-links{display:flex;gap:54px;flex-wrap:wrap;}
.foot-col{display:flex;flex-direction:column;gap:11px;}
.foot-col .ttl{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:3px;}
.foot-col a{font-size:14.5px;font-weight:600;color:var(--ink-soft);transition:color .15s;}
.foot-col a:hover{color:var(--accent);}
.foot-bot{margin-top:40px;padding-top:24px;border-top:1px solid var(--hairline);font-size:13px;color:var(--ink-faint);font-weight:500;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .hero-a .grid{grid-template-columns:1fr;gap:18px;text-align:center;}
  .hero-a .sub{max-width:none;margin-left:auto;margin-right:auto;}
  .hero-a .cta-row,.hero-a .h-trust{justify-content:center;}
  .hero-a .art{margin-top:20px;}
  .hero-c .grid{grid-template-columns:1fr;gap:18px;}
  .hero-c .art{justify-content:center;margin-top:20px;}
  .hero-c .device{transform:none;}
  .feat{grid-template-columns:1fr;gap:30px;margin-bottom:72px;}
  .feat:nth-child(even) .f-art{order:0;}
  .feat .f-txt{text-align:center;}
  .feat ul{align-items:flex-start;max-width:340px;margin-left:auto;margin-right:auto;}
  .feat li{text-align:left;}
  .compare{grid-template-columns:1fr;}
  .std-grid{grid-template-columns:1fr;max-width:440px;}
  .sec{padding:68px 0;}
}
@media(max-width:520px){
  .hero-b .cluster{height:400px;}
  .hero-b .cluster .d2{--dw:210px;}
  .hero-b .cluster .d1,.hero-b .cluster .d3{--dw:180px;}
  .foot-links{gap:34px;}
}
