﻿@charset "UTF-8";
/* ===== Base tokens ===== */
:root{
  --clr-primary:#031744; /* Navy */
  --clr-accent:#06d6a0;  /* Teal/green for cashflow */
  --btn-text:#001219;
  --chip-text:#fff;
  --clr-light:#f6f7fb;
  --clr-dark:#333;
  --gap:1.5rem; --radius:.75rem; --transition:.2s ease-in-out;
}

/* Reset & base */
*,*::before,*::after{box-sizing:border-box}
html:focus-within{scroll-behavior:smooth}
body{margin:0;font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,'Helvetica Neue',Arial,sans-serif;color:var(--clr-dark);line-height:1.6;background:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1200px,92%);margin-inline:auto}
h1{font-size:clamp(2rem,5vw,3rem);margin:0 0 var(--gap);font-weight:700}
h2{font-size:clamp(1.7rem,4vw,2.3rem);margin:0 0 1.25rem;text-align:center}
h3{font-size:clamp(1.2rem,3vw,1.35rem);margin:0 0 .25rem}
.subhead{opacity:.9;max-width:60ch}

[data-animate]{opacity:0;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out;}
[data-animate].visible{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){[data-animate]{transform:none;transition:none;}}

/* Accessibility */
.skip-link{position:absolute;top:.5rem;left:.5rem;transform:translateY(-200%);padding:.5rem .75rem;background:#fff;border:2px solid var(--clr-primary);border-radius:.5rem;z-index:999}
.skip-link:focus{transform:translateY(0)}
:focus-visible{outline:3px solid var(--clr-accent);outline-offset:3px;border-radius:.35rem}
.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap;border:0;padding:0;margin:-1px}
/* Anchor offset for sticky header when jumping to sections */
[id]{scroll-margin-top:80px}

/* Header / Nav */
.site-header{position:sticky;top:0;backdrop-filter:blur(6px);background:rgba(255,255,255,.92);z-index:100;box-shadow:0 2px 10px rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;position:relative}
.logo{font-size:1.25rem;font-weight:700;color:var(--clr-primary);display:flex;align-items:center;gap:.35rem}
.logo .accent-chip{color:var(--chip-text);background:var(--clr-accent);padding:.15rem .4rem;border-radius:.4rem}
.nav-menu{list-style:none;display:flex;gap:var(--gap);align-items:center}
.nav-menu a{font-weight:500}
.nav-menu a:hover{border-bottom:1px solid currentColor}
.nav-toggle{display:none;background:transparent;border:2px solid var(--clr-primary);border-radius:.5rem;padding:.35rem .6rem;font-weight:700;color:var(--clr-primary);cursor:pointer}
@media(max-width:800px){
  .nav-toggle{display:block}
  .nav-menu{display:none;position:absolute;right:4%;top:60px;background:#fff;padding:.75rem 1rem;border:1px solid #e6e9ef;border-radius:.6rem;box-shadow:0 10px 20px rgba(0,0,0,.08)}
  .nav-menu.show{display:flex;flex-direction:column;gap:.5rem}
}

/* Buttons */
.btn{display:inline-flex;gap:.5rem;align-items:center;justify-content:center;padding:.75rem 1.1rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:var(--transition);font-weight:700;text-align:center;min-height:44px}
.btn-primary{background:var(--clr-accent);color:var(--btn-text);border-color:var(--clr-accent)}
.btn-primary:hover{filter:saturate(1.05) brightness(.98);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.btn-secondary:hover{background:rgba(255,255,255,.1)}

/* Hero */
.hero{background:linear-gradient(135deg,#031744 0%, #0b2568 60%, #0a2154 100%);color:#fff;min-height:clamp(460px,62vh,680px);display:block;position:relative;text-align:center}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.25),rgba(0,0,0,.35))}
.hero-inner{position:relative;z-index:1;display:grid;gap:var(--gap);align-items:center;width:100%;grid-template-columns:1fr;max-width:1400px;margin-inline:auto;padding-top:clamp(1rem,4vh,3rem);padding-bottom:clamp(.5rem,2vh,1rem)}
.hero-copy{display:grid;gap:.75rem;justify-items:center;max-width:600px;margin-inline:auto}
.hero-copy .metric{white-space:nowrap;}
@media(max-width:720px){.hero-copy .metric{white-space:normal;}}

.hero-ctas{display:flex;gap:.75rem;justify-content:center;}
@media(min-width:900px){.hero-ctas{justify-content:flex-start;justify-self:start;}}
.hero-eyebrow{display:inline-block;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.25);color:#fff;padding:.25rem .6rem;border-radius:999px;font-weight:700;letter-spacing:.02em;font-size:.8rem;text-transform:uppercase;margin-bottom:.1rem}
.subline{opacity:.9;max-width:60ch;margin-top:.5rem}
.section-intro{opacity:.8;max-width:52ch;margin:0 auto 1.75rem;text-align:center}
.cred-line{margin-top:.25rem;opacity:.85}
.kpi-proof{margin-top:.35rem;opacity:.95}
.trust-inline{opacity:.85;margin-top:.35rem}
.text-link{color:var(--clr-primary);text-decoration:underline;font-weight:600}
.text-link:hover{color:var(--clr-accent);}
.hero-img-wrap{width:auto;max-width:clamp(420px,48vw,860px);border-radius:0;overflow:visible;background:transparent;display:grid;place-items:center;justify-self:center}
/* Hero benefit bullets + visual */
.benefit-bullets{display:grid;gap:.25rem;margin:.25rem 0 0;padding:0;list-style:none}
.benefit-bullets li{position:relative;padding-left:1.25rem}
.benefit-bullets li::before{content:"";position:absolute;left:0;top:.55rem;width:.55rem;height:.55rem;border-radius:50%;background:var(--clr-accent)}
svg.hero-visual{width:clamp(420px,48vw,860px);height:auto;display:block;border-radius:24px;box-shadow:0 12px 28px rgba(0,0,0,.18)}
.hero-visual text{font-family:'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif; font-weight:700; letter-spacing:.02em}
.micro-quote{margin-top:.35rem;opacity:.9}
/* Clear, curved flow arrow with animated dash */
.hero-visual .flow-arrow{stroke:#06d6a0;stroke-width:5;stroke-linecap:round;stroke-linejoin:round;fill:none;stroke-dasharray:12 10;animation:dash 2.4s ease-in-out infinite}
@keyframes dash{to{stroke-dashoffset:-44}}}
@media(min-width:900px){
  .hero-inner{grid-template-columns:1.05fr .95fr;text-align:left}
  .hero-copy{justify-items:start;margin-inline:0}
  .hero-img-wrap{transform:translateY(-6%)}
}

  .hero-copy{justify-items:start;margin-inline:0}
  /* Align visual vertically with copy mid */
  .hero-img-wrap{width:auto;max-width:clamp(420px,48vw,860px);border-radius:0;overflow:visible;background:transparent;display:grid;place-items:center;justify-self:center}
}
@media(min-width:1200px){ svg.hero-visual{width:clamp(420px,48vw,860px);height:auto;display:block;border-radius:24px;box-shadow:0 12px 28px rgba(0,0,0,.18)} }
@media(min-width:1440px){ svg.hero-visual{width:clamp(420px,48vw,860px);height:auto;display:block;border-radius:24px;box-shadow:0 12px 28px rgba(0,0,0,.18)} }
/* removed extra desktop offset; handled above */
@media(min-width:1440px){
  .hero-img-wrap{width:auto;max-width:clamp(420px,48vw,860px);border-radius:0;overflow:visible;background:transparent;display:grid;place-items:center;justify-self:center}
}

.tiny-trust{margin-top:.75rem;opacity:.8;font-size:.9rem}
/* Ensure clean stars even if source text is garbled */
.tiny-trust .stars{position:relative;color:transparent;letter-spacing:.08em;margin-right:.35rem}
.tiny-trust .stars::before{content:"\2605\2605\2605\2605\2605";position:absolute;inset:0;color:#f3c23c}

/* Simple logo strip under tiny trust */
.logo-strip{display:flex;gap:1rem;justify-content:center;opacity:.65;flex-wrap:wrap;margin-top:.35rem}
.logo-strip span{padding:.15rem .4rem;border:1px solid rgba(255,255,255,.25);border-radius:.4rem;font-weight:700;font-size:.8rem}
/* Hero KPIs */
.hero-kpis{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1.25rem;background:rgba(255,255,255,.05);border-radius:1rem;padding:.75rem 1rem;backdrop-filter:blur(4px)}
.kpi-mini{display:grid;gap:.2rem;align-items:center;justify-items:start;padding:0;border:none;background:transparent}
.kpi-mini .num{font-weight:800;font-size:1.6rem}
.kpi-mini .label{opacity:.85;font-size:.95rem}
@media(min-width:900px){
  .hero-inner{grid-template-columns:1.05fr .95fr;text-align:left}
  .hero-copy{justify-items:start;margin-inline:0}
  .hero-img-wrap{transform:translateY(-6%)}
}

}

/* Before / After */
#before-after{background:linear-gradient(180deg,#f8fafc,#fff);}
.beforeafter{display:grid;gap:1.5rem;text-align:center}
.ba-grid{display:grid;gap:1.5rem}
@media(min-width:900px){.ba-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:2rem;align-items:start}}
.ba-column{display:grid;gap:1rem}
.ba-figure{position:relative;border-radius:1rem;overflow:hidden}
.ba-figure img{width:100%;height:auto;border-radius:1rem;transition:transform .3s ease,box-shadow .3s ease}
.ba-column:hover .ba-figure img{transform:scale(1.02);box-shadow:0 8px 30px rgba(0,0,0,.1)}
.img-chip{position:absolute;top:.6rem;left:.6rem;background:rgba(0,0,0,.65);color:#fff;font-weight:700;padding:.25rem .55rem;border-radius:.5rem;border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(2px)}
.img-chip.good{background:var(--clr-accent);color:var(--btn-text);border-color:rgba(0,0,0,.06)}
.img-chip.bad{background:#ff6b6b;color:#001219;border-color:#ff8c8c}
.ba-list{list-style:none;padding:0;margin:0;display:grid;gap:.6rem;text-align:left}
.ba-list li{background:#fff;border:1px solid #e6e9ef;border-radius:.6rem;padding:.75rem 1rem;box-shadow:0 2px 8px rgba(0,0,0,.04);position:relative;padding-left:2.1rem}
.ba-list li::before{content:"";position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;border-radius:50%}
.ba-list.bad li::before{background:#ff6b6b}
.ba-list.good li::before{background:#06d6a0}
/* Robot: gentle bobbing motion (respects reduced motion) */
.hero-img{
  transform:translateZ(0);
  width:100%;
  height:auto;
  object-fit:contain;
  display:block;
  border-radius:24px;
  box-shadow:0 12px 28px rgba(0,0,0,.18);
  will-change: transform;
  transform-origin:50% 50%;
  animation: hero-bob 16s ease-in-out infinite;
}

@keyframes hero-bob{
  0%   { transform: translate(0, 0) rotate(0deg); }
  20%  { transform: translate(3px, -4px) rotate(-0.25deg); }
  40%  { transform: translate(1px, -6px) rotate(0.2deg); }
  60%  { transform: translate(-3px, -3px) rotate(-0.2deg); }
  80%  { transform: translate(-1px, -1px) rotate(0.15deg); }
  100% { transform: translate(0, 0) rotate(0deg); }
}

@media (prefers-reduced-motion: reduce){
  .hero-img{animation:none}
  .hero-visual .flow-arrow{animation:none}
}

/* Divider (disabled to remove visual seam) */
.section-divider{display:none}

/* Sections & cards */
.section{padding:clamp(3rem,8vh,4rem) 0}
.section.tight-top{padding-top:clamp(1.25rem,4vh,2rem)}
.section.tight-bottom{padding-bottom:clamp(1.25rem,4vh,2rem)}
.light-bg{background:var(--clr-light)}
.cards{display:grid;gap:var(--gap)}
@media(min-width:600px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){
  .hero-inner{grid-template-columns:1.05fr .95fr;text-align:left}
  .hero-copy{justify-items:start;margin-inline:0}
  .hero-img-wrap{transform:translateY(-6%)}
}
}
.card{background:#fff;border-radius:var(--radius);padding:var(--gap);box-shadow:0 2px 12px rgba(0,0,0,.06);transition:transform var(--transition), box-shadow var(--transition)}
.card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.09)}
.card ul{margin:.25rem 0 0 1rem;display:grid;gap:.25rem}

/* Center card headers */
.cards .card h3{
  text-align:center;
  margin-bottom:1rem;
}

/* Trust bar */
.trust{display:grid;gap:1rem;justify-items:center}
.trust .eyebrow{font-weight:600;letter-spacing:.08em;text-transform:uppercase;opacity:.7}
.trust-logos{display:flex;gap:1.25rem;flex-wrap:wrap;list-style:none;padding:0;margin:0}
.trust-logos li{background:#fff;border:1px solid #e6e9ef;border-radius:.6rem;padding:.6rem .9rem;box-shadow:0 2px 8px rgba(0,0,0,.04)}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap)}
.kpi{background:#fff;border-radius:var(--radius);padding:1.25rem;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.kpi h3{font-size:clamp(1.6rem,5vw,2.2rem);margin:0;color:var(--clr-primary)}
.kpi p{margin:.35rem 0 0}

/* Steps */
.steps{max-width:800px;margin:0 auto;display:grid;gap:.6rem}
.steps li{background:#fff;border:1px solid #e6e9ef;border-radius:.6rem;padding:.8rem 1rem;box-shadow:0 2px 8px rgba(0,0,0,.04)}

/* Pricing */
.pricing .card{border-top:5px solid var(--clr-accent); position:relative}
.price{font-size:1.6rem;font-weight:800;margin:.25rem 0 .75rem;color:var(--clr-primary)}
/* Center EVERYTHING inside pricing cards */
.pricing .card{ text-align:center; }
.pricing .card .price{ text-align:center; }         /* redundant but explicit */
.pricing .card ul{
  margin:.75rem 0 0;     /* override global .card ul margin */
  padding:0;             /* remove left padding */
  list-style-position:inside; /* keep bullets with centered text */
}
.pricing .card ul li{ margin:.25rem 0; }
.pricing .card .btn-secondary{ background:#f5f7fb; color:var(--clr-primary); border:1px solid #e6e9ef }
.pricing .card .btn-secondary:hover{ background:#eef2f8 }
.pricing .card .badge.popular{ position:absolute; top:-10px; right:12px; background:var(--clr-accent); color:var(--btn-text); padding:.2rem .6rem; border-radius:999px; font-weight:800; font-size:.8rem; letter-spacing:.02em }
.plan-hint{ color:#667085; margin:0 0 .5rem; font-size:.95rem }
.caption{text-align:center;opacity:.75;margin-top:.5rem}

/* Pricing includes (grid list) */
.pricing-includes{ margin-top:1rem }
.pricing-includes ul{ display:grid; grid-template-columns:1fr; gap:.25rem .75rem; padding-left:1rem }
@media(min-width:600px){ .pricing-includes ul{ grid-template-columns:repeat(2,1fr) } }

/* Product preview */
.ui-preview{background:#fdfefe;border:1px solid #e6e9ef;border-radius:1rem;box-shadow:0 12px 30px rgba(0,0,0,.08);overflow:hidden}
.ui-topbar{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:#f6f7fb;border-bottom:1px solid #e6e9ef}
.ui-topbar .dot{width:.65rem;height:.65rem;border-radius:50%}
.ui-topbar .red{background:#ff6b6b}.ui-topbar .amber{background:#ffd166}.ui-topbar .green{background:#06d6a0}
.ui-topbar .ui-title{margin-left:.5rem;font-weight:700;opacity:.8}
.ui-toolbar{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-bottom:1px solid #eef1f6}
.chip{background:#eef7f4;color:#0b3b2e;border:1px solid #d7efe7;border-radius:999px;padding:.2rem .6rem;font-weight:600;font-size:.85rem}
.chip.alt{background:#fff7ea;color:#6a3b00;border-color:#ffe2b6}
.ui-toolbar .spacer{flex:1}
.btn-mini{background:#fff;border:1px solid #dfe6ef;border-radius:.5rem;padding:.35rem .6rem;font-weight:600;font-size:.85rem;cursor:pointer}
.btn-mini.ghost{background:transparent}
.ui-table{display:grid}
.ui-row{display:grid;grid-template-columns:1.2fr 1.3fr .9fr .6fr 1fr .9fr;gap:.5rem;padding:.6rem .75rem;border-bottom:1px solid #f0f2f7}
.ui-head{background:#fafbfe;font-weight:700}
.badge{border-radius:.5rem;padding:.1rem .45rem;font-weight:700;font-size:.78rem}
.badge.bad{background:#ffe3e3;color:#7f1d1d}
.badge.warn{background:#fff0d6;color:#6a3b00}
.badge.ok{background:#e6fff5;color:#0b3b2e}
.ui-row .bad{color:#b00020}
.ui-row .warn{color:#9c6c00}
.ui-dock{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:#fafbfe}
.ui-dock .draft{flex:1;opacity:.9}
.dock-actions{display:flex;gap:.5rem}

/* Mobile handling for wide preview table */
@media(max-width:700px){
  .ui-preview{ overflow-x:auto; overflow-y:hidden; -webkit-overflow-scrolling:touch; }
  .ui-table{ min-width:680px; }
}

/* Improve tap targets in mobile nav */
@media(max-width:800px){
  .nav-menu.show a{ padding:.5rem 0; }
}

/* Generic illustrations */
.illustration{width:min(100%, 900px);height:auto;display:block;margin:0.5rem auto 1rem;border-radius:12px;border:1px solid #e6e9ef;box-shadow:0 6px 18px rgba(0,0,0,.06)}

/* Quotes */
.quote p{margin:.25rem 0}
.byline{opacity:.7}

/* Lead magnet & forms */
.leadmagnet{background:#fff;border:1px solid #e6e9ef;border-radius:var(--radius);padding:var(--gap);box-shadow:0 2px 12px rgba(0,0,0,.06);max-width:760px;margin:0 auto}
.leadmagnet .badge{display:inline-block;background:var(--clr-accent);color:var(--btn-text);font-weight:800;border-radius:999px;padding:.2rem .6rem;margin-bottom:.5rem;font-size:.8rem;letter-spacing:.02em}
.form{width:min(680px,100%);display:grid;gap:1rem}
.form.inline{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;justify-content:center}
.form.inline input{flex:1;min-width:220px;padding:.8rem;border:1px solid #cfd4dc;border-radius:.6rem;font:inherit}
.form.inline button{white-space:nowrap}

/* Plan picker (radio pills) */
.plan-picker{display:flex;gap:.5rem;justify-content:center;align-items:center;margin:.25rem 0 .75rem;border:0;padding:0}
.plan-pill{position:relative}
.plan-pill input{position:absolute;opacity:0;inset:0}
.plan-pill label{display:inline-block;border:1px solid #cfd4dc;border-radius:999px;padding:.6rem 1rem;cursor:pointer;font-weight:700;min-height:44px;line-height:1}
.plan-pill input:checked + label{background:var(--clr-accent);color:var(--btn-text);border-color:var(--clr-accent)}

/* Inline errors + password meter */
.error{color:#b00020;margin-top:-.35rem;margin-bottom:.25rem;min-height:1.1rem;display:block}
.pw-meter{display:flex;gap:.25rem;margin-top:.25rem}
.pw-meter .bar{flex:1;height:6px;background:#e6e9ef;border-radius:999px}
.pw-meter.str-1 .bar:nth-child(1){background:#ffb3b3}
.pw-meter.str-2 .bar:nth-child(-n+2){background:#ffd399}
.pw-meter.str-3 .bar:nth-child(-n+3){background:#c9f2df}
.pw-meter.str-4 .bar:nth-child(-n+4){background:#6ee7b7}

/* ===== FAQ (tidy + accordion-ready) ===== */
.faq{
  max-width:800px;
  margin:0 auto;
  display:grid;
  gap:1rem;
}
.faq details{
  background:#fff;
  border:1px solid #e6e9ef;
  border-radius:.6rem;
  box-shadow:0 2px 6px rgba(0,0,0,.04);
  padding:.75rem 1rem;
  transition:box-shadow .25s ease,border-color .25s ease, background .25s ease;
  overflow:hidden;
}
.faq details[open]{
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  border-color:var(--clr-accent);
  background:#fff;
}
.faq summary{
  cursor:pointer;
  font-weight:600;
  list-style:none;
  position:relative;
  padding-right:1.5rem;
  outline:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"\203A";
  position:absolute; right:0; top:50%;
  transform:translateY(-50%) rotate(0deg);
  transition:transform .25s ease;
  font-size:1.1rem; color:var(--clr-primary);
}
.faq details[open] summary::after{
  transform:translateY(-50%) rotate(90deg);
}
.faq details > :not(summary){
  margin:.75rem 0 0;
  opacity:.95;
}

/* Book section */
#book{text-align:center}
#book .btn{margin-top:1.5rem}


/* Footer */
.site-footer{background:var(--clr-primary);color:#fff;padding:1.25rem 0}
.footer-inner{display:flex;gap:1rem;justify-content:space-between;align-items:center;flex-wrap:wrap}
.footer-nav{display:flex;gap:1rem;flex-wrap:wrap}
.footer-nav a{color:#fff;opacity:.85}
.footer-nav a:hover{opacity:1}

/* Sticky mobile CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:env(safe-area-inset-bottom,0);display:none;gap:.6rem;justify-content:space-between;align-items:center;background:rgba(255,255,255,.96);box-shadow:0 -4px 20px rgba(0,0,0,.12);padding:.6rem clamp(.8rem,4vw,1.25rem);z-index:999}
.sticky-cta .btn{flex:1}
@media(max-width:800px){.sticky-cta.show{display:flex}}

/* Features grid */

/* Ensure clean stars in trust copy */
.tiny-trust .stars::before{content:"\2605\2605\2605\2605\2605" !important; color:#f3c23c}

/* Override garbled star content (ensure clean stars) */
.tiny-trust .stars::before{content:"\2605\2605\2605\2605\2605" !important;color:#f3c23c}

/* Override garbled star content */
.tiny-trust .stars::before{content:"\2605\2605\2605\2605\2605" !important; color:#f3c23c}

/* Exit-intent modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:1000;padding:1rem}
.modal-overlay.show{display:flex}
.modal{position:relative;background:#fff;border-radius:.75rem;box-shadow:0 12px 32px rgba(0,0,0,.22);max-width:520px;width:100%;padding:1.25rem}
.modal h3{margin-top:0;margin-bottom:.35rem}
.modal p{margin:.25rem 0 .75rem}
.modal form{display:flex;gap:.5rem;flex-wrap:wrap}
.modal input[type='email']{flex:1;min-width:220px;padding:.75rem;border:1px solid #cfd4dc;border-radius:.6rem;font:inherit}
.modal .modal-close{position:absolute;right:1rem;top:1rem;background:transparent;border:0;color:#222;font-size:1.5rem;cursor:pointer}
.features{display:grid;gap:var(--gap)}
@media(min-width:700px){.features{grid-template-columns:repeat(3,1fr)}}
.feature{background:#fff;border:1px solid #e6e9ef;border-radius:.75rem;padding:1rem;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.feature h3{margin-top:.5rem;margin-bottom:.25rem}
.feature p{margin:0;opacity:.9}
.feature svg{width:24px;height:24px;color:var(--clr-primary)}

/* Slim Why band */
.why-band{display:grid;gap:.75rem;list-style:none;padding:0;margin:0}
@media(min-width:700px){.why-band{grid-template-columns:repeat(4,1fr)}}
.why-band li{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid #e6e9ef;border-radius:.75rem;padding:.75rem 1rem;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.why-band svg{width:18px;height:18px;color:var(--clr-primary);flex:0 0 auto}
.why-band strong{font-weight:700}

/* Before/After section is enabled (no override) */

/* Value section */
.value{display:grid;gap:1rem;align-items:center}
@media(min-width:900px){
  .hero-inner{grid-template-columns:1.05fr .95fr;text-align:left}
  .hero-copy{justify-items:start;margin-inline:0}
  .hero-img-wrap{transform:translateY(-6%)}
}
}
.value-media .illustration{margin:0 auto}
.value-copy ul{margin:0 0 1rem 1.1rem;display:grid;gap:.35rem}

/* Accessibility: respect reduced motion preferences */
@media (prefers-reduced-motion: reduce){
  html:focus-within{scroll-behavior:auto}
  *, *::before, *::after{transition:none!important;animation-duration:0.001ms!important;animation-iteration-count:1!important}
  .hero-visual .flow-arrow{animation:none}
}

/* Fix secondary button contrast inside sticky mobile cta */
.sticky-cta .btn-secondary{
  color:var(--clr-primary);
  border-color:var(--clr-primary);
}

/* ===== How It Works (compact 3-step grid) ===== */
.how-grid{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:stretch;}
@media(min-width:900px){.how-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}}
.how-card{background:#fff;border:1px solid #e6e9ef;border-radius:.85rem;padding:1.5rem;box-shadow:0 10px 30px rgba(3,23,68,.06);display:grid;gap:.75rem;text-align:left;justify-items:flex-start;}
.how-card h3{margin:0;}
.how-card p{margin:0;opacity:.85;}
.step-icon{width:2.5rem;height:2.5rem;border-radius:50%;display:grid;place-items:center;background:rgba(3,23,68,.08);color:var(--clr-primary);font-weight:700;}
.step-lede{margin:0;opacity:.9;}
.step-details{width:100%;margin-top:.25rem;}
.step-details summary{cursor:pointer;font-weight:600;color:var(--clr-primary);display:inline-flex;align-items:center;gap:.35rem;}
.step-details summary:hover{color:var(--clr-accent);}
.step-details summary::-webkit-details-marker{display:none;}
.step-details[open] summary{color:var(--clr-accent);}
.step-details ul{margin:.6rem 0 0 1rem;padding:0;display:grid;gap:.35rem;}
.step-details li{opacity:.8;}
/* Trim spacing between How and Expectations */
#how{ padding-bottom:clamp(1.5rem,4vh,2.25rem) }
#expectations{ padding-top:clamp(1.5rem,4vh,2.25rem) }

/* Expectations cards */
.expect-grid{max-width:1080px;margin:1.5rem auto 0;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.expect-card{background:#fff;border:1px solid #e6e9ef;border-radius:.85rem;padding:1.5rem;box-shadow:0 8px 26px rgba(3,23,68,.05);display:grid;gap:.6rem;}
.expect-card h3{margin:0;}
.expect-card p{margin:0;opacity:.85;}
.expect-icon{width:2.25rem;height:2.25rem;border-radius:50%;display:grid;place-items:center;background:rgba(3,23,68,.1);color:var(--clr-primary);}
.expect-icon svg{width:1.15rem;height:1.15rem;}

/* Industry proof callouts */
.proof-grid{display:grid;gap:1.5rem;}
@media(min-width:900px){.proof-grid{grid-template-columns:minmax(0,0.9fr) minmax(0,1.1fr);align-items:stretch;}}
.proof-card{background:#fff;border:1px solid #e6e9ef;border-radius:1rem;padding:1.75rem;box-shadow:0 12px 30px rgba(3,23,68,.08);display:grid;gap:.75rem;}
.proof-card.highlight{background:linear-gradient(135deg,#031744,#0b2568);color:#fff;border-color:rgba(255,255,255,.18);box-shadow:0 20px 50px rgba(3,23,68,.35);}
.proof-label{text-transform:uppercase;font-size:.75rem;letter-spacing:.14em;opacity:.85;}
.proof-num{font-size:2rem;font-weight:800;}
.proof-card.highlight p{margin:0;opacity:.9;}
.proof-card.copy h3{margin:0;}
.proof-card.copy p{margin:0;opacity:.85;}
.proof-list{margin:.75rem 0 0 1.1rem;padding:0;display:grid;gap:.35rem;}
.proof-list li{opacity:.85;}

/* (removed how-includes block; merged into cards) */

/* ---- Hero overrides (final) ---- */
/* Ensure consistent, visible sizing and animation even if earlier rules conflict */
.hero-img-wrap{width:auto;max-width:clamp(520px,48vw,920px);border-radius:0;overflow:visible;background:transparent;display:grid;place-items:center;justify-self:center}
svg.hero-visual{width:clamp(520px,48vw,920px);height:auto;display:block;border-radius:24px;box-shadow:0 12px 28px rgba(0,0,0,.18)}
.micro-quote{margin-top:.35rem;opacity:.9}
  .hero-visual .flow-arrow{stroke:#06d6a0;stroke-width:5;stroke-linecap:round;stroke-linejoin:round;fill:none;stroke-dasharray:12 10;animation:dash 2.2s ease-in-out infinite}
  @keyframes dash{to{stroke-dashoffset:-44}}
  /* Place KPI chips under the hero image and keep them in one row on larger screens */
  .hero-kpis{ max-width:clamp(520px,48vw,920px); justify-self:center }
  .kpi-mini{ white-space:nowrap }
  @media(min-width:900px){ .hero-kpis{ grid-column:2 } }
  @media(min-width:1100px){ .hero-kpis{ flex-wrap:nowrap } }
@media(min-width:900px){
  .hero-inner{grid-template-columns:1.1fr .9fr;text-align:left}
  .hero-copy{justify-items:start;margin-inline:0}
  .hero-img-wrap{transform:translateY(-6%)}
}
@media(min-width:1200px){ svg.hero-visual{width:clamp(560px,46vw,980px)} }
@media(min-width:1440px){ svg.hero-visual{width:clamp(600px,48vw,1040px)} }

/* ---- Pricing layout overrides ---- */
.cards.pricing{ display:grid; grid-template-columns:1fr; gap:var(--gap); align-items:start }
@media(min-width:700px){ .cards.pricing{ grid-template-columns:repeat(2,1fr) } }
@media(min-width:1000px){ .cards.pricing{ grid-template-columns:repeat(3,1fr) } }
.cards.pricing .card{ height:100% }
.cards.pricing .card .btn-center{ margin-top:auto }


/* ---- Before / After storytelling ---- */
.beforeafter-grid{display:grid;gap:1.5rem;align-items:stretch}
@media(min-width:900px){.beforeafter-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:2rem}}
.ba-card{background:#fff;border:1px solid #e6e9ef;border-radius:1.2rem;padding:1.25rem;box-shadow:0 12px 32px rgba(3,23,68,.07);display:grid;gap:1rem}
.ba-card img{width:100%;height:auto;border-radius:1rem}
.ba-card ul{margin:0;padding-left:1.1rem;display:grid;gap:.35rem;opacity:.85}
.ba-label{display:inline-block;margin-bottom:.5rem;font-weight:700;text-transform:uppercase;font-size:.75rem;letter-spacing:.12em}
.ba-label.bad{color:#ff6b6b}
.ba-label.good{color:var(--clr-accent)}
/* ---- Stats & value grid ---- */
.stat-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:1.5rem;align-items:stretch}
.stat-card{background:#fff;border:1px solid #e6e9ef;border-radius:1rem;padding:1.25rem;box-shadow:0 10px 26px rgba(3,23,68,.05);display:grid;gap:.5rem;justify-items:flex-start}
.stat-card h3{margin:0}
.stat-card p{margin:0;opacity:.8}
.stat-icon{font-size:1.9rem}
.stat-note{margin-top:1.5rem}

/* ---- Problem / solution story ---- */
.ps-grid{display:grid;gap:1.5rem;align-items:start}
@media(min-width:900px){.ps-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:2rem}}
.ps-block{background:#fff;border:1px solid #e6e9ef;border-radius:1rem;padding:1.5rem;box-shadow:0 12px 32px rgba(3,23,68,.06);display:grid;gap:.75rem}
.ps-block p{margin:0;opacity:.85}
.ps-label{text-transform:uppercase;font-weight:700;font-size:.78rem;letter-spacing:.14em;opacity:.7}
.ps-label.accent{color:var(--clr-accent);opacity:1}
.ps-block.solution{background:linear-gradient(135deg,#031744,#0b2568);color:#fff;border-color:rgba(255,255,255,.22)}
.ps-block.solution p{opacity:.9}
.ps-block.solution .ps-label{color:rgba(255,255,255,.85);opacity:1}
.ps-diagram{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;font-weight:600}
.ps-diagram span{padding:.1rem 0}
.ps-block.solution .ps-diagram span{color:rgba(255,255,255,.9)}
.diagram-arrow{opacity:.7}
.ps-block.solution .diagram-arrow{opacity:.5}
.diagram-paid{background:var(--clr-accent);color:var(--btn-text);padding:.25rem .75rem;border-radius:999px}

/* ---- Why controllers love it ---- */
.why-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:1.5rem}
.why-card{background:#fff;border:1px solid #e6e9ef;border-radius:1rem;padding:1.5rem;box-shadow:0 10px 28px rgba(3,23,68,.05);display:grid;gap:.5rem}
.why-card h3{margin:0}
.why-card p{margin:0;opacity:.85}
.why-icon{font-size:1.8rem}
.why-note{margin-top:1.5rem;display:flex;gap:1rem;align-items:center;justify-content:space-between;flex-wrap:wrap}
.why-note p{margin:0;opacity:.85}

/* ---- Pricing cards ---- */
.pricing-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));align-items:stretch;margin-top:2rem}
.pricing-card{background:#fff;border:1px solid #e6e9ef;border-radius:1rem;padding:1.75rem;box-shadow:0 12px 32px rgba(3,23,68,.06);display:grid;gap:.75rem}
.pricing-card h3{margin:0}
.price{font-size:2rem;font-weight:800;margin:0}
.plan-copy{margin:0;opacity:.85}
.pricing-card .btn{margin-top:auto;width:max-content}
.roi-bar{margin-top:2rem;display:flex;align-items:center;gap:.75rem;background:#f1f4fb;border:1px solid #e1e6f1;border-radius:1rem;padding:1rem 1.25rem}
.roi-icon{font-size:1.75rem}
.pricing-summary{margin-top:1.5rem;overflow-x:auto}
.pricing-summary{-webkit-overflow-scrolling:touch}
.pricing-summary table{width:100%;border-collapse:collapse;font-size:.95rem;min-width:480px}
.pricing-summary th,.pricing-summary td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid #e1e6f1}
.pricing-summary th{font-weight:600;color:#2f3453}

/* ---- Final CTA ---- */
.final-cta{padding:clamp(3rem,8vh,4rem) 0}
.cta-inner{background:linear-gradient(135deg,#031744,#0b2568);color:#fff;border-radius:1.5rem;padding:clamp(2rem,6vw,3rem);display:grid;gap:1.5rem;box-shadow:0 20px 48px rgba(3,23,68,.25)}
@media(min-width:900px){.cta-inner{grid-template-columns:minmax(0,1fr) auto;align-items:center}}
.cta-copy h2{margin:0}
.cta-copy .subhead{margin-top:.75rem;color:rgba(255,255,255,.85)}
.cta-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem}
.cta-visual{display:grid;gap:.35rem;justify-items:center;text-align:center}
.cta-icon{font-size:2.5rem}

/* Encode-safe icon fallbacks: render icons via ::before to avoid garbled emoji */
.roi-icon{font-size:0}
.roi-icon::before{content:"\1F4C8";font-size:1.75rem}
.cta-icon{font-size:0}
.cta-icon::before{content:"\2705";font-size:2.5rem}
.why-icon{font-size:0}
.why-card:nth-child(1) .why-icon::before{content:"\1F464";font-size:1.5rem}
.why-card:nth-child(2) .why-icon::before{content:"\1F4AC";font-size:1.5rem}
.why-card:nth-child(3) .why-icon::before{content:"\1F4CB";font-size:1.5rem}
.why-card:nth-child(4) .why-icon::before{content:"\2705";font-size:1.5rem}
.cta-inner .btn-secondary{border-color:rgba(255,255,255,.4);color:#fff}
.cta-inner .btn-secondary:hover{background:rgba(255,255,255,.12)}

/* Ensure content isn’t obscured by sticky CTA on small screens */
@media(max-width:800px){
  body.sticky-offset{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}
}

\n/* ---- Legal pages ---- */\n.legal-section{margin-top:2rem;display:grid;gap:.6rem}\n.legal-section h2{margin:0;font-size:1.2rem;text-align:left}\n.legal-section p{margin:0;opacity:.85}\nmain.section.container{max-width:900px}\n\n/* ---- Misc helpers ---- */
.btn-center{display:flex;justify-content:center;margin-top:1.5rem}
/* Hero credibility stats */
.hero-stat{
  margin:0;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  padding:.7rem 1.2rem;
  border-radius:1rem;
  font-weight:600;
  max-width:32rem;
  text-align:center;
}
.hero-stats{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  justify-content:center;
  margin-top:.25rem;
}
.hero-stat-card{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:.9rem;
  padding:.85rem 1.05rem;
  min-width:150px;
  display:grid;
  gap:.2rem;
  justify-items:center;
  text-align:center;
}
.hero-stat-card .stat-value{
  font-size:1.4rem;
  font-weight:700;
}
.hero-stat-card .stat-label{
  font-size:.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.8;
}
@media(min-width:900px){
  .hero-stats{justify-content:flex-start;}
}

/* Problem section stat box */
.problem-section .problem-inner{
  display:grid;
  gap:2rem;
  align-items:flex-start;
}
.problem-section .problem-copy{
  display:grid;
  gap:1rem;
  text-align:left;
}
.problem-section .problem-copy h2{
  text-align:left;
}
.problem-section .problem-copy p{
  max-width:60ch;
}
.problem-section .stat-box{
  background:#fff;
  border:1px solid #e6e9ef;
  border-radius:1rem;
  padding:1.5rem;
  box-shadow:0 18px 34px rgba(3,23,68,.08);
}
.problem-section .stat-box h3{
  margin:0 0 .75rem;
}
.problem-section .stat-box ul{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:.6rem;
}
.problem-section .stat-box li{
  font-weight:500;
  color:var(--clr-primary);
  line-height:1.5;
}
@media(min-width:900px){
  .problem-section .problem-inner{
    grid-template-columns:minmax(0,1fr) minmax(280px,360px);
  }
}

/* Product dashboard caption */
.dashboard-caption{
  text-align:center;
  margin-top:1.5rem;
  color:rgba(3,23,68,.7);
}
@media(min-width:900px){
  .dashboard-caption{text-align:left;}
}

/* Pricing credibility line */
.pricing-callout{
  text-align:center;
  font-weight:600;
  margin:1.25rem auto 1.75rem;
  max-width:55ch;
}

/* Footer sources note */
.site-footer .sources-note{
  flex-basis:100%;
  margin:0;
  color:rgba(255,255,255,.65);
  font-size:.8rem;
}









