html { font-display: swap; }

/* ============ PAGE COMPOSITIONS (Plus & Minus home) ============ */

/* Header */
.site-head {
  position: sticky; top: 0; z-index: 60;
  background: color-mix(in oklab, var(--surface) 82%, transparent);
  backdrop-filter: saturate(1.4) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, box-shadow .3s;
}
.site-head.scrolled { border-color: var(--line); box-shadow: 0 1px 0 var(--line-2); }
.nav { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; column-gap: 28px; height: 72px; }
.nav .brand { justify-self: start; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--ink); letter-spacing: -.02em; }
/* Official brand lockup (icon + “PLUS AND MINUS”). Icon-forward, so the
   symbol stays prominent. Header target: 72px bar, 42px logo (32px mobile).
   Vector source — crisp at any height / DPR; ratio never altered. */
.brand-img { height: 42px; width: auto; max-width: 260px; display: block; object-fit: contain; }
.brand.has-logo { gap: 0; }
.foot .brand-img { height: 36px; max-width: 230px; }
@media (max-width: 880px){ .brand-img { height: 38px; max-width: 240px; } }
@media (max-width: 560px){ .brand-img { height: 32px; max-width: 210px; } .foot .brand-img { height: 32px; } }
@media (max-width: 360px){ .brand-img { height: 30px; max-width: 195px; } }
.brand-word { white-space: nowrap; }
.brand-mark {
  width: 38px; height: 38px; border-radius: 11px; flex: none;
  background: var(--brand); color: #fff;
  display: grid; place-items: center; font-size: 22px; font-weight: 700;
  font-family: var(--font-display); box-shadow: var(--sh-brand);
  letter-spacing: 0;
}
.nav-links { display: flex; align-items: center; justify-content: center; gap: 4px; }
.nav-links a { padding: 9px 14px; border-radius: 10px; font-size: 15.5px; font-weight: 500; color: var(--ink-2); transition: background .15s, color .15s; }
.nav-links a:hover { background: var(--soft); color: var(--ink); }
.nav-cta { justify-self: end; display: flex; align-items: center; gap: 10px; }
.nav-toggle { display: none; width: 42px; height: 42px; border-radius: 11px; box-shadow: inset 0 0 0 1.5px var(--line); place-items: center; }
.nav-toggle [data-lucide] { width: 22px; height: 22px; color: var(--ink); }
@media (max-width: 1080px){
  .nav-links, .nav-cta .btn { display: none; }
  .nav-toggle { display: grid; }
}
/* mobile drawer */
.drawer { display: none; }
.drawer.open { display: block; position: fixed; inset: 0; z-index: 70; }
.drawer-bg { position: absolute; inset: 0; background: rgba(7,11,22,.4); backdrop-filter: blur(2px); }
.drawer-panel { position: absolute; top: 12px; right: 12px; left: 12px; background: var(--surface); border-radius: var(--r-lg); box-shadow: var(--sh-lg); padding: 18px; }
.drawer-panel a { display: block; padding: 14px 12px; border-radius: 12px; font-weight: 600; font-size: 17px; color: var(--ink); }
.drawer-panel a:hover { background: var(--soft); }
.drawer-panel .btn { width: 100%; margin-top: 8px; }
.drawer-close { position: absolute; top: 26px; right: 26px; }

/* ============ SERVICES MEGA-MENU (desktop) ============ */
.nav-mega { position: relative; display: flex; align-items: center; }
.nav-mega-trigger {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 9px 14px; border-radius: 10px;
  font-family: inherit; font-size: 15.5px; font-weight: 500; color: var(--ink-2);
  cursor: pointer; transition: background .15s, color .15s;
}
.nav-mega-trigger [data-lucide] { width: 16px; height: 16px; transition: transform .2s var(--ease); }
.nav-mega-trigger:hover,
.nav-mega:hover .nav-mega-trigger,
.nav-mega.is-open .nav-mega-trigger { background: var(--soft); color: var(--ink); }
.nav-mega:hover .nav-mega-trigger [data-lucide],
.nav-mega.is-open .nav-mega-trigger [data-lucide] { transform: rotate(180deg); }
.nav-mega-trigger.is-active { color: var(--brand); }

.mega-panel {
  position: absolute; top: calc(100% + 11px); left: 0;
  width: 344px; background: var(--surface);
  border-radius: var(--r-lg); box-shadow: var(--sh-lg), inset 0 0 0 1px var(--line);
  padding: 10px; z-index: 80;
  opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(6px);
  transition: opacity .18s var(--ease), transform .18s var(--ease), visibility .18s;
}
/* invisible hover bridge so the panel doesn't close in the gap */
.mega-panel::before { content: ""; position: absolute; top: -13px; left: 0; right: 0; height: 13px; }
.nav-mega:hover .mega-panel,
.nav-mega.is-open .mega-panel { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
.mega-list { display: grid; gap: 2px; }
.mega-item { display: flex; align-items: center; gap: 13px; padding: 11px 12px; border-radius: 12px; transition: background .14s var(--ease); }
.mega-item:hover { background: var(--soft); }
.mega-ic {
  width: 40px; height: 40px; border-radius: 11px; flex: none;
  display: grid; place-items: center; background: var(--brand-50); color: var(--brand);
  transition: background .14s var(--ease), color .14s var(--ease), transform .14s var(--ease);
}
.mega-ic [data-lucide] { width: 20px; height: 20px; }
.mega-item:hover .mega-ic { background: var(--brand); color: #fff; transform: scale(1.05); }
.mega-tx { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mega-tx b { font-family: var(--font-display); font-size: 15px; font-weight: 600; color: var(--ink); letter-spacing: -.01em; }
.mega-tx small { font-size: 13px; color: var(--muted); line-height: 1.3; }
.mega-all {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 8px; padding: 14px 12px 8px; border-top: 1px solid var(--line-2);
  font-size: 14.5px; font-weight: 600; color: var(--brand);
}
.mega-all [data-lucide] { width: 16px; height: 16px; transition: transform .15s var(--ease); }
.mega-all:hover [data-lucide] { transform: translateX(3px); }

/* ============ SERVICES ACCORDION (mobile drawer) ============ */
.drawer-acc-trigger {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
  padding: 14px 12px; border-radius: 12px; font-family: inherit;
  font-weight: 600; font-size: 17px; color: var(--ink); cursor: pointer;
}
.drawer-acc-trigger:hover { background: var(--soft); }
.drawer-acc-trigger [data-lucide] { width: 20px; height: 20px; color: var(--muted); transition: transform .22s var(--ease); }
.drawer-acc.open .drawer-acc-trigger [data-lucide] { transform: rotate(180deg); }
.drawer-acc-panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .26s var(--ease); }
.drawer-acc.open .drawer-acc-panel { grid-template-rows: 1fr; }
.drawer-acc-inner { overflow: hidden; }
.drawer-acc-inner a {
  display: block; padding: 11px 12px 11px 18px; margin: 2px 0;
  border-radius: 10px; color: var(--ink-2);
}
.drawer-acc-inner a b { display: block; font-size: 15.5px; font-weight: 600; color: var(--ink); line-height: 1.25; }
.drawer-acc-inner a small { display: block; font-size: 13px; color: var(--muted); margin-top: 1px; }
.drawer-acc-inner a.drawer-acc-all { color: var(--brand); font-weight: 600; font-size: 15px; padding-left: 12px; margin-top: 4px; }

/* HERO */
.hero { position: relative; overflow: hidden; padding-top: clamp(40px, 6vw, 80px); padding-bottom: clamp(56px, 7vw, 104px); }
.hero-bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(60% 50% at 82% 8%, color-mix(in oklab, var(--brand) 12%, transparent), transparent 70%),
    radial-gradient(45% 40% at 10% 0%, var(--brand-50), transparent 65%);
}
.hero-grid { display: grid; grid-template-columns: 1.04fr .96fr; gap: 56px; align-items: center; }
.hero-eyebrow-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.avatars { display: flex; }
.avatars span { width: 30px; height: 30px; border-radius: 50%; margin-left: -8px; box-shadow: 0 0 0 2.5px var(--surface); background: var(--soft-2); }
.avatars span:nth-child(1){ background: color-mix(in oklab,var(--brand) 30%, #fff); }
.avatars span:nth-child(2){ background: color-mix(in oklab,var(--green) 30%, #fff); }
.avatars span:nth-child(3){ background: color-mix(in oklab,var(--amber) 32%, #fff); }
.avatars span:nth-child(4){ background: color-mix(in oklab,var(--ink) 28%, #fff); }
.hero h1 { margin-top: 24px; }
.hero h1 .accent { color: var(--brand); }
.hero .lead { margin-top: 22px; max-width: 540px; }
.hero-cta { margin-top: 32px; display: flex; gap: 12px; flex-wrap: wrap; }
.hero-trust { margin-top: 30px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; color: var(--muted); font-size: 14.5px; }
.stars { display: inline-flex; gap: 2px; color: var(--amber); }
.stars [data-lucide] { width: 16px; height: 16px; fill: currentColor; }
.hero-trust .div { width: 1px; height: 16px; background: var(--line); }

/* DASHBOARD MOCKUP */
.mock { position: relative; }
.mock-card {
  background: var(--surface); border-radius: var(--r-xl);
  box-shadow: var(--sh-lg), inset 0 0 0 1px var(--line);
  padding: 22px; position: relative; z-index: 2;
}
.mock-top { display: flex; align-items: center; justify-content: space-between; }
.mock-id { display: flex; align-items: center; gap: 10px; }
.mock-id .dotmark { width: 34px; height: 34px; border-radius: 9px; background: var(--brand); color:#fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; }
.mock-id b { color: var(--ink); font-size: 15px; }
.mock-id small { color: var(--muted); font-size: 12px; }
.mock-score { display: flex; align-items: flex-end; gap: 16px; margin-top: 20px; padding: 18px; border-radius: var(--r-md); background: var(--soft); }
.mock-score .num { font-family: var(--font-display); font-size: 46px; font-weight: 700; color: var(--ink); line-height: 1; letter-spacing: -.03em; }
.mock-score .num i { font-size: 22px; color: var(--green); font-style: normal; }
.mock-score .meta { font-size: 13px; color: var(--muted); padding-bottom: 4px; }
.mock-score .meta b { display:block; color: var(--ink-2); font-size: 14px; }
.bars { display: flex; align-items: flex-end; gap: 7px; height: 56px; margin-left: auto; padding-bottom: 2px; }
.bars i { width: 9px; background: var(--brand-100); border-radius: 4px; display: block; }
.bars i.on { background: var(--brand); }
.mock-list { margin-top: 16px; }
.mock-row { display: flex; align-items: center; gap: 12px; padding: 12px 4px; border-top: 1px solid var(--line-2); }
.mock-row:first-child { border-top: 0; }
.mock-row .rdot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.mock-row .g { background: var(--green); }
.mock-row .a { background: var(--amber); }
.mock-row .b { background: var(--brand); }
.mock-row b { color: var(--ink-2); font-size: 14px; font-weight: 600; }
.mock-row .due { margin-left: auto; font-size: 12.5px; color: var(--muted); font-weight: 600; }
.mock-row .ok { color: var(--green); }

/* Roomier rows for the compliance overview (6 status lines, no score block) */
.mock-list-lg { margin-top: 18px; }
.mock-list-lg .mock-row { padding: 13.5px 4px; }
.mock-list-lg .mock-row b { font-size: 14.5px; }

/* Business Health summary card */
.mock-health { display: flex; align-items: center; gap: 13px; margin-top: 18px; padding: 16px 18px; border-radius: var(--r-md); background: var(--soft); box-shadow: inset 0 0 0 1px var(--line-2); }
.mock-health .ic { width: 40px; height: 40px; border-radius: 11px; flex: none; display: grid; place-items: center; background: var(--green-100); color: var(--green); }
.mock-health .ic [data-lucide] { width: 21px; height: 21px; }
.mock-health .mh-tx { min-width: 0; }
.mock-health .mh-tx b { display: block; color: var(--ink); font-size: 14.5px; font-weight: 700; }
.mock-health .mh-tx small { display: block; color: var(--muted); font-size: 12.5px; margin-top: 2px; line-height: 1.45; }
/* Integrated savings footer (replaces the floating "tax saved" tag) */
.mock-foot { display: flex; align-items: center; gap: 12px; margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line-2); }
.mock-foot .ic { width: 36px; height: 36px; border-radius: 10px; flex: none; display: grid; place-items: center; background: var(--brand-50); color: var(--brand); }
.mock-foot .ic [data-lucide] { width: 19px; height: 19px; }
.mock-foot .mf-tx { min-width: 0; }
.mock-foot .mf-tx b { display: block; color: var(--ink); font-size: 14px; font-weight: 600; }
.mock-foot .mf-tx small { display: block; color: var(--muted); font-size: 12px; margin-top: 1px; }
.mock-foot .mf-amt { margin-left: auto; font-family: var(--font-display); font-weight: 700; font-size: 20px; letter-spacing: -.02em; color: var(--brand); white-space: nowrap; }
.mock-float {
  position: absolute; z-index: 3; background: var(--surface);
  border-radius: 14px; box-shadow: var(--sh-md), inset 0 0 0 1px var(--line);
  padding: 12px 15px; display: flex; align-items: center; gap: 11px;
}
.mock-float .ic { width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; background: var(--green-100); color: var(--green); }
.mock-float .ic [data-lucide] { width: 19px; height: 19px; }
.mock-float b { display: block; color: var(--ink); font-size: 13.5px; }
.mock-float small { color: var(--muted); font-size: 12px; }
.mock-float.f1 { top: -26px; left: -26px; }
.mock-float.f2 { bottom: -22px; right: -20px; }
.mock-glow { position: absolute; inset: -8% -6%; z-index: 1; background: radial-gradient(closest-side, color-mix(in oklab,var(--brand) 22%, transparent), transparent); filter: blur(10px); }
@media (max-width: 900px){
  .hero-grid { grid-template-columns: 1fr; gap: 64px; }
  .mock { max-width: 460px; margin-inline: auto; }
}
/* Phone: pull floating badges onto the card edge so they never overflow
   the viewport or cover adjacent content. */
@media (max-width: 640px){
  .mock-float { padding: 9px 12px; }
  .mock-float.f1 { top: -14px; left: -6px; }
  .mock-float.f2 { bottom: -14px; right: -6px; }
}

/* TRUST NUMBERS */
.trust-lede {
  max-width: 720px; margin: 0 auto clamp(30px, 3.6vw, 44px);
  text-align: center; text-wrap: balance;
  font-family: var(--font-display); color: var(--ink);
  font-size: clamp(22px, 2.4vw, 30px); font-weight: 600;
  letter-spacing: -.018em; line-height: 1.25;
}

/* STATS BAND */
.stats { display: grid; grid-template-columns: repeat(4,1fr); align-items: center; }
.stat { position: relative; padding: 6px 28px; text-align: center; }
.stat:not(:first-child)::before {
  content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 1px; height: 46px; background: var(--line);
}
.stat .n { font-family: var(--font-display); font-size: clamp(34px,4vw,48px); font-weight: 700; color: var(--ink); letter-spacing: -.03em; line-height: 1; }
.stat .n span { color: var(--brand); }
.stat .l { margin-top: 10px; color: var(--body); font-size: 15px; font-weight: 500; }
@media (max-width: 760px){
  .stats { grid-template-columns: 1fr 1fr; gap: 36px 0; }
  .stat { padding: 0 18px; }
  .stat:not(:first-child)::before { display: none; }
  .stat:nth-child(even)::before { display: block; height: 40px; }
}

/* SERVICES BENTO */
.bento { display: grid; grid-template-columns: 1.1fr 1fr 1fr; grid-auto-rows: 1fr; gap: 20px; }
.svc { display: flex; flex-direction: column; gap: 16px; min-width: 0; }
.svc .chip { transition: transform .25s var(--ease); }
.svc:hover .chip { transform: scale(1.06) rotate(-3deg); }
.svc h3 { color: var(--ink); }
.svc p { color: var(--body); font-size: 15.5px; line-height: 1.5; }
.svc .tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 2px; }
.svc .link-arrow { margin-top: auto; padding-top: 6px; }
.svc-feature { grid-row: span 2; background:
   linear-gradient(180deg, var(--brand-50), var(--surface) 60%); }
.svc-feature .ph { margin-top: 6px; height: 168px; }

/* Start-a-business feature: live incorporation tracker (echoes the .mock dashboard language) */
.incorp { margin-top: 8px; background: var(--surface); border-radius: var(--r-md);
  box-shadow: var(--sh-sm), inset 0 0 0 1px var(--line); padding: 16px 16px 12px; }
.incorp-head { display: flex; align-items: center; gap: 11px; }
.incorp-head .dotmark { width: 34px; height: 34px; border-radius: 9px; flex: none;
  background: var(--brand); color: #fff; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.incorp-id { flex: 1; min-width: 0; }
.incorp-id b { display: block; color: var(--ink); font-size: 14px; font-weight: 600; letter-spacing: -.01em; line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.incorp-id small { color: var(--muted); font-size: 12px; }
.incorp-stat { flex: none; display: inline-flex; align-items: center; gap: 6px;
  font-size: 11.5px; font-weight: 700; color: var(--green);
  padding: 5px 11px 5px 9px; border-radius: var(--r-pill); background: var(--green-100); }
.incorp-stat .pill-dot { background: var(--green); box-shadow: none; }
.incorp-bar { height: 6px; border-radius: var(--r-pill); background: var(--soft-2); margin: 14px 0 2px; overflow: hidden; }
.incorp-bar i { display: block; height: 100%; border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--brand-600), var(--brand)); }
.incorp .mock-list { margin-top: 4px; }
.incorp .mock-row { padding: 8.5px 2px; }
.incorp .mock-row b { font-size: 13.5px; }
.incorp .due { font-size: 12px; white-space: nowrap; }
.incorp .due.prog { color: var(--brand); font-weight: 600; }
.incorp .due.next { color: var(--amber); font-weight: 600; }
@media (max-width: 920px){
  .bento { grid-template-columns: 1fr 1fr; }
  .svc-feature { grid-row: auto; grid-column: span 2; }
}
@media (max-width: 600px){ .bento { grid-template-columns: 1fr; } .svc-feature { grid-column: auto; } }

/* WHY (dark) */
.why { position: relative; overflow: hidden; }
.why-glow { position: absolute; z-index:0; top: -30%; right: -10%; width: 60%; height: 120%; background: radial-gradient(closest-side, color-mix(in oklab,var(--brand) 30%, transparent), transparent); filter: blur(30px); opacity: .6; }
.why .wrap { position: relative; z-index: 1; }
.why-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 28px; margin-top: 56px; align-items: start; }
.why-item { padding: 0; }
.why-item .chip { margin-bottom: 18px; }
.why-item h4 { color: #fff; font-size: 18px; }
.why-item p { color: var(--on-dark-mut); font-size: 14.5px; margin-top: 7px; line-height: 1.5; }

/* Card variant — padded, equal-height, hover-lift (Services "why choose us") */
.why-cards { align-items: stretch; }
.why-cards .why-item {
  display: flex; flex-direction: column; height: 100%;
  padding: 30px 26px;
  border-radius: var(--r-lg);
  background: color-mix(in oklab, #fff 4%, transparent);
  box-shadow: inset 0 0 0 1px var(--dark-line);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.why-cards .why-item .chip { margin-bottom: 24px; transition: background .25s var(--ease), box-shadow .25s var(--ease); }
.why-cards .why-item p { margin-top: 12px; }
.why-cards .why-item:hover {
  transform: translateY(-4px);
  background: color-mix(in oklab, var(--brand) 7%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--brand) 42%, transparent), 0 18px 40px -22px color-mix(in oklab, var(--brand) 80%, transparent);
}
.why-cards .why-item:hover .chip { background: color-mix(in oklab, var(--brand) 22%, transparent); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--brand) 50%, transparent); }
@media (max-width: 920px){
  .why-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .why-item { padding: 0; }
}
@media (max-width: 560px){ .why-grid { grid-template-columns: 1fr; } }

/* 4-up why-cards (responsive — replaces inline grid override) */
.why-grid.cols4 { grid-template-columns: repeat(4,1fr); }
@media (max-width: 920px){ .why-grid.cols4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .why-grid.cols4 { grid-template-columns: 1fr; } }

/* HOW IT WORKS */
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; margin-top: 56px; position: relative; }
.steps::before { content:""; position: absolute; top: 26px; left: 6%; right: 6%; height: 2px; background: repeating-linear-gradient(90deg, var(--line) 0 8px, transparent 8px 16px); z-index: 0; }
.step { position: relative; z-index: 1; }
.step .num { width: 54px; height: 54px; border-radius: 16px; background: var(--surface); box-shadow: var(--sh-sm), inset 0 0 0 1px var(--line); display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--brand); margin-bottom: 20px; }
.step:hover .num { color:#fff; background: var(--brand); box-shadow: var(--sh-brand); }
.step h4 { color: var(--ink); }
.step p { margin-top: 8px; color: var(--body); font-size: 15px; }
@media (max-width: 760px){ .steps { grid-template-columns: 1fr 1fr; } .steps::before { display:none; } }
@media (max-width: 440px){ .steps { grid-template-columns: 1fr; } }

/* TESTIMONIALS */
.tcard { display: flex; flex-direction: column; gap: 18px; height: 100%; }
.tcard .quote { font-size: 17px; color: var(--ink-2); line-height: 1.55; font-weight: 500; }
.tcard .who { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.tcard .av { width: 44px; height: 44px; border-radius: 50%; flex: none; }
.tcard .who b { display: block; color: var(--ink); font-size: 15px; }
.tcard .who small { color: var(--muted); font-size: 13px; }
.tstars { display: inline-flex; gap: 2px; color: var(--amber); }
.tstars [data-lucide] { width: 16px; height: 16px; fill: currentColor; }

/* LEARN — category quick-nav row (home) */
.learn-cats { display: flex; flex-wrap: wrap; gap: 10px; }
.learn-cat { display: inline-flex; align-items: center; gap: 9px; padding: 9px 16px 9px 10px; border-radius: var(--r-pill);
  font-size: 14.5px; font-weight: 600; color: var(--ink-2);
  background: var(--surface); box-shadow: inset 0 0 0 1px var(--line); transition: all .16s var(--ease); }
.learn-cat:hover { color: var(--brand); box-shadow: inset 0 0 0 1px color-mix(in oklab,var(--brand) 36%, transparent); transform: translateY(-1px); }
.learn-cat .lc-ic { width: 28px; height: 28px; border-radius: 8px; display: grid; place-items: center;
  background: var(--brand-50); color: var(--brand); transition: background .16s var(--ease), color .16s var(--ease); }
.learn-cat .lc-ic [data-lucide] { width: 16px; height: 16px; }
.learn-cat:hover .lc-ic { background: var(--brand); color: #fff; }

/* INSIGHTS */
.post { overflow: hidden; padding: 0; position: relative; }
.post .card-link { position: absolute; inset: 0; z-index: 2; font-size: 0; }
.post .cover { height: 188px; border-radius: 0; }
.post .pbody { padding: 22px 24px 26px; }
.post .tag { margin-bottom: 12px; }
.post h4 { color: var(--ink); font-size: 19px; line-height: 1.25; }
.post .meta { margin-top: 14px; color: var(--muted); font-size: 13.5px; display: flex; gap: 8px; align-items: center; }

/* FINAL CTA (brand panel) */
.cta-panel {
  position: relative; overflow: hidden;
  border-radius: var(--r-xl); padding: clamp(40px, 6vw, 72px);
  background: linear-gradient(135deg, var(--brand-700), var(--brand));
  color: #fff; text-align: center;
}
.cta-panel::before { content:""; position:absolute; inset:0; background: radial-gradient(60% 90% at 50% -10%, rgba(255,255,255,.22), transparent 60%); }
.cta-panel > * { position: relative; }
.cta-panel h2 { color: #fff; max-width: 760px; margin-inline: auto; }
.cta-panel p { color: rgba(255,255,255,.86); font-size: 19px; margin-top: 16px; max-width: 560px; margin-inline: auto; }
.cta-panel .row { margin-top: 32px; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.cta-mini { margin-top: 22px; color: rgba(255,255,255,.8); font-size: 14px; display:flex; gap: 18px; justify-content:center; flex-wrap: wrap; }
.cta-mini span { display: inline-flex; align-items: center; gap: 6px; }
.cta-mini [data-lucide]{ width: 16px; height: 16px; }

/* FOOTER */
.foot { background: var(--ink); color: var(--on-dark-mut); }
.foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; padding-block: 64px 40px; }
.foot .brand { color: #fff; }
.foot .brand-mark { box-shadow: none; }
/* White logo treatment on the dark footer — forces any logo source
   (SVG / PNG / stored data-URL) to crisp pure white. Vector filter,
   so it stays sharp on retina / high-DPI. Size & spacing unchanged. */
/* Footer logo: the official footer wordmark is supplied pre-coloured
   (blue pill, white text) and reads correctly on the dark footer, so it
   renders as-is. The white-forcing filter only applies to the no-logo
   fallback mark. */
.foot .brand-img { filter: none; }
.foot .brand.has-logo .brand-img { filter: none; }
/* Fallback wordmark mark, kept white-on-dark for the same contrast */
.foot .brand-mark { background: transparent; color: #fff; box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.45); }
/* Brand statement — occupies the (logo-free) first footer column.
   Large, bold, white headline; layout otherwise unchanged. */
.foot-statement { margin: 0; font-family: var(--font-display); font-weight: 700; font-size: clamp(30px, 2.6vw, 40px); line-height: 1.04; letter-spacing: -.022em; color: #fff; max-width: 300px; text-wrap: balance; }
.foot p.blurb { margin-top: 16px; max-width: 280px; font-size: 14.5px; line-height: 1.6; color: var(--on-dark-mut); }
.foot h5 { color: #fff; font-size: 13px; letter-spacing: .08em; text-transform: uppercase; font-family: var(--font-body); font-weight: 700; margin-bottom: 16px; }
.foot a { display: block; padding: 6px 0; font-size: 14.5px; color: var(--on-dark-mut); transition: color .15s; }
.foot a:hover { color: #fff; }
.foot .socials { display: flex; gap: 8px; margin-top: 22px; }
.foot .socials a { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: var(--on-dark-mut); box-shadow: inset 0 0 0 1px var(--dark-line); padding: 0; transition: color .18s var(--ease), background .18s var(--ease), box-shadow .18s var(--ease), transform .18s var(--ease); }
.foot .socials a svg, .foot .socials a [data-lucide] { width: 16px; height: 16px; display: block; }
.foot .socials a:hover { color: #fff; background: rgba(255,255,255,.07); box-shadow: inset 0 0 0 1px rgba(255,255,255,.18); transform: translateY(-1px); }
.foot-bottom { border-top: 1px solid var(--dark-line); padding-block: 24px 20px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: 13.5px; }
.foot-bottom .links { display: flex; gap: 22px; flex-wrap: wrap; }
.foot-bottom .links a { padding: 0; }
/* Founder signature — centered, quiet */
.foot-sign { text-align: center; padding-bottom: 38px; font-size: 12.5px; letter-spacing: .015em; color: var(--on-dark-mut); opacity: .8; display: flex; align-items: center; justify-content: center; gap: 6px; }
.foot-sign .pm-heart { font-size: 11px; line-height: 1; filter: saturate(1.1); }
@media (max-width: 820px){ .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 480px){ .foot-grid { grid-template-columns: 1fr; } }
