/*
 * Industry Landing Pages — Stylesheet v2.1
 * Source: Medical_Practices_-_single-file.html (latest)
 */

/* Divi/theme container reset */
#ilp{max-width:none !important;padding:0 !important;margin:0 !important}
#ilp,#ilp *{box-sizing:border-box}
#ilp ul,#ilp ol{padding:0;margin:0;list-style:none}
/* Heading reset stays at #ilp specificity (beats Divi's heading defaults). Paragraphs
 * are intentionally NOT in this reset — variants like .hero-disclaimer, .lede,
 * .feat p, etc. need to win by class specificity over the base. The universal
 * `* { margin:0; padding:0 }` reset on line 59 handles the base case for <p>.
 * The single targeted #ilp p { padding-bottom:0 } rule (further down) handles
 * the only Divi paragraph bleed we actually need to neutralize. */
#ilp h1,#ilp h2,#ilp h3,#ilp h4,#ilp h5{margin:0;padding:0}
#ilp a{text-decoration:none}
#ilp img{max-width:100%;height:auto}

/* Force grids over Divi */
#ilp .persona-grid{display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:20px !important}
#ilp .persona-card{display:flex !important;flex-direction:column !important}
#ilp .hero-grid{display:grid !important;grid-template-columns:1.15fr .85fr !important;gap:40px !important;align-items:center !important}
#ilp .stats-grid{display:grid !important;grid-template-columns:repeat(4,1fr) !important}
#ilp .split-grid{display:grid !important;grid-template-columns:1fr 1fr !important;gap:0 !important}
#ilp .feat-grid{display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:1px !important;background:var(--line) !important}
#ilp .testi-grid{display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:20px !important}
#ilp .process-rail{display:grid !important;grid-template-columns:repeat(4,1fr) !important;gap:24px !important}
#ilp section{width:100% !important;max-width:none !important;padding-left:0 !important;padding-right:0 !important}
@media(max-width:980px){#ilp .persona-grid,#ilp .testi-grid{grid-template-columns:1fr !important}#ilp .hero-grid{display:flex !important;flex-direction:column !important;gap:20px !important}}
@media(max-width:880px){#ilp .process-rail{grid-template-columns:1fr 1fr !important}#ilp .split-grid{grid-template-columns:1fr !important}#ilp .feat-grid{grid-template-columns:1fr 1fr !important}}
@media(max-width:560px){#ilp .process-rail,#ilp .feat-grid{grid-template-columns:1fr !important}#ilp .stats-grid{grid-template-columns:repeat(2,1fr) !important}}

:root{
  /* Forest Trust palette — modern, confident healthcare green */
  --primary:#0F7A52;
  --primary-600:#085E3E;
  --primary-900:#053E29;
  --accent:#10B981;
  --accent-soft:#D6EFE2;
  --teal-100:#D6EFE2;
  --teal-50:#F1F8F4;
  --gold:#C9A24E;
  --gold-soft:#E8D8A8;
  --green:#10B981;
  --hero-bg:linear-gradient(180deg,#F1F8F4 0%,#DDEEE2 100%);
  --tag-bg:#D6EFE2;
  --tag-fg:#0F7A52;

  --bg:#FBFBFA;
  --surface:#FFFFFF;
  --line:#E5E2DC;
  --line-soft:#EFEDE7;
  --ink-900:#1A1F23;
  --ink-700:#3A4248;
  --ink-500:#6B7378;
  --ink-300:#A8AEB2;
  --danger:#B0302F;
  --shadow-md:0 8px 28px rgba(20,40,50,.08);
  --radius:10px;
  --radius-lg:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{background:var(--bg);color:var(--ink-900);font-family:"Inter Tight","Inter",ui-sans-serif,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.serif{font-family:"Poppins","Inter Tight",ui-sans-serif,system-ui,sans-serif}
.mono{font-family:"JetBrains Mono",ui-monospace,SFMono-Regular,Consolas,monospace}
h1,h2,h3,h4{font-family:"Poppins","Inter Tight",ui-sans-serif,system-ui,sans-serif;font-weight:600;letter-spacing:-.02em;color:var(--primary);margin:0}
h1{font-size:54px;line-height:1.06;letter-spacing:-.02em}
h2{font-size:42px;line-height:1.1;letter-spacing:-.018em}
h3{font-size:24px;line-height:1.2}
h4{font-size:18px;line-height:1.25}
p{color:var(--ink-700)}

.container{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.hero .eyebrow .dot{display:none}
.btn{display:inline-flex;align-items:center;gap:8px;height:46px;padding:0 22px;border-radius:8px;font-weight:600;font-size:14.5px;border:1px solid transparent;cursor:pointer;transition:all .15s ease;text-decoration:none;font-family:inherit}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-600);border-color:var(--primary-600)}
.btn-ghost{border-color:var(--line);color:var(--ink-900);background:#fff}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-link-nav{color:var(--ink-700);font-size:14px;font-weight:500;padding:6px 4px}
.btn-link-nav:hover{color:var(--primary)}
/* ============== HERO ============== */
.hero{background:var(--hero-bg);padding:72px 0 88px;position:relative;border-bottom:1px solid var(--line);overflow-x:clip}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
@media(max-width:980px){
  .hero-grid{display:flex;flex-direction:column;align-items:flex-start;gap:20px}
  .hero-grid > div{display:contents}
  .hero-grid .eyebrow{order:1;align-self:flex-start}
  .hero-grid h1{order:2;margin-top:0 !important;align-self:stretch;text-align:left}
  .hero-logos{order:3;align-self:stretch}
  .hero-art{order:4;align-self:center;margin:4px auto 0;max-width:460px}
  .hero-floating{padding:9px 12px;border-radius:10px;font-size:11px;line-height:1.35;max-width:44%;box-shadow:0 6px 18px rgba(20,40,50,.10)}
  .hero-floating .lbl{font-size:9px;letter-spacing:.12em}
  .hero-floating .val{font-size:14px;margin-top:2px}
  .hero-floating .sub{font-size:10.5px;margin-top:2px}
  .hero-floating.f1{top:10px;left:10px}
  .hero-floating.f2{bottom:10px;right:10px}
  .hero p.lede{order:5;margin-top:8px !important;max-width:none;align-self:stretch}
  .hero-bullets{order:6;margin-top:4px !important;align-self:stretch}
  .hero-cta{order:7;margin-top:12px !important;align-self:stretch}
  .hero-disclaimer{order:8;margin-top:6px !important;max-width:none;align-self:stretch}
}
.hero h1{color:#0F7A52;font-weight:600;font-size:50px;line-height:1.04;letter-spacing:-.03em}
.hero h1 .accent{color:var(--accent);font-weight:500}
.hero p.lede{font-size:17.5px;color:var(--ink-700);margin-top:22px;max-width:520px;line-height:1.55}
.hero-bullets{margin-top:26px;display:grid;gap:11px;list-style:none}
.hero-bullets li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--ink-700)}
.hero-tick{flex:0 0 20px;height:20px;border-radius:50%;background:var(--accent-soft);color:var(--primary-600);display:grid;place-items:center;font-size:12px;font-weight:700;margin-top:1px}
.hero-cta{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap}
.hero-disclaimer{margin-top:24px;font-size:11.5px;color:var(--ink-500);max-width:520px;line-height:1.55}

/* hero illustration */
.hero-art{position:relative;aspect-ratio:1/1;max-width:560px;margin-left:auto;margin-right:-80px;width:100%}
@media(max-width:980px){.hero-art{margin-right:auto;margin-left:auto}}
.hero-art .bg-circle{position:absolute;inset:0;background:radial-gradient(circle at 50% 45%, #F1F8F4 0%, #C6E3D1 60%, #9FCFB1 100%);border-radius:50%}
.hero-art .ring{position:absolute;inset:6%;border:1px dashed rgba(8,94,62,.3);border-radius:50%}
.hero-art svg{position:relative;z-index:2;width:100%;height:100%}
.hero-floating{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-md);z-index:3;font-size:12px;line-height:1.4}
.hero-floating.f1{top:4%;left:-6%}
.hero-floating.f2{bottom:6%;right:-4%}
.hero-floating .lbl{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.14em}
.hero-floating .val{font-family:"Poppins",sans-serif;font-size:18px;color:var(--primary);margin-top:4px;font-weight:500}
.hero-floating .sub{color:var(--ink-500);font-size:11.5px;margin-top:3px}
.dot-status{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--green);margin-right:6px;vertical-align:middle}

/* hero compliance logos row */
.hero-right{display:flex;flex-direction:column;align-items:flex-end;gap:28px;width:100%}
@media(max-width:980px){.hero-right{align-items:center}}
.hero-logos{
  display:flex;align-items:center;gap:14px;
  max-width:560px;width:100%;
  flex-wrap:nowrap;justify-content:flex-start;
  margin-right:-80px;
}
@media(max-width:980px){.hero-logos{margin-right:0;justify-content:center}}
.hero-logos img{
  height:34px;width:auto;flex:0 0 auto;
  transition:transform .2s ease;
}
.hero-logos img:hover{transform:translateY(-2px)}
@media(max-width:560px){
  .hero-logos{gap:14px 18px;flex-wrap:wrap;justify-content:flex-start;padding:14px 0;margin:6px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
  .hero-logos img{height:26px;opacity:.85}
}

/* hero animations */
.hero-art .ring{animation:hsRingSpin 60s linear infinite}
.hero-svg .hs-check{transform-box:fill-box;transform-origin:center 90%;animation:hsCheckMail 6s cubic-bezier(.5,.0,.3,1) infinite}
.hero-svg .hs-flap{transform-box:fill-box;transform-origin:50% 0;animation:hsFlapOpen 6s ease-in-out infinite}
.hero-svg .hs-badge{transform-box:fill-box;transform-origin:center;animation:hsBadgeOrbit 4s ease-in-out infinite}
.hero-svg .hs-badge-ring{transform-box:fill-box;transform-origin:center;animation:hsRingSpin 12s linear infinite reverse}
.hero-svg .hs-stamp{transform-box:fill-box;transform-origin:center;animation:hsStampSlam 6s ease-out infinite}
.hero-svg .hs-route{stroke-dasharray:4 4;animation:hsRouteFlow 1s linear infinite}
.hero-svg .hs-route-end{transform-box:fill-box;transform-origin:center;animation:hsDotPulse 1s ease-in-out infinite}
.hero-svg .hs-packet{filter:drop-shadow(0 0 4px rgba(16,185,129,.6));animation:hsPacketPulse 1s ease-in-out infinite}
.hero-floating.f1{animation:hsFloatA 5.5s ease-in-out infinite}
.hero-floating.f2{animation:hsFloatB 6.5s ease-in-out infinite}
.dot-status{animation:hsDotGlow 2s ease-in-out infinite}

/* check sequence: rest IN envelope → pop UP & scale → linger → drop back IN */
@keyframes hsCheckMail{
  0%   {transform:translateY(180px) scale(.55);opacity:0}
  10%  {transform:translateY(180px) scale(.55);opacity:0}
  25%  {transform:translateY(-10px) scale(1.03);opacity:1}
  35%  {transform:translateY(0) scale(1);opacity:1}
  65%  {transform:translateY(0) scale(1);opacity:1}
  78%  {transform:translateY(-10px) scale(1.03);opacity:1}
  92%  {transform:translateY(180px) scale(.55);opacity:.4}
  100% {transform:translateY(180px) scale(.55);opacity:0}
}
/* flap opens while check is out, closes while check is hidden */
@keyframes hsFlapOpen{
  0%,12%   {transform:rotateX(0deg)}
  22%,80%  {transform:rotateX(-150deg)}
  92%,100% {transform:rotateX(0deg)}
}
/* badge orbits in a small circle */
@keyframes hsBadgeOrbit{
  0%   {transform:translate(0,0) scale(1)}
  25%  {transform:translate(4px,-4px) scale(1.05)}
  50%  {transform:translate(0,-6px) scale(1.02)}
  75%  {transform:translate(-4px,-4px) scale(1.05)}
  100% {transform:translate(0,0) scale(1)}
}
@keyframes hsRingSpin{
  to{transform:rotate(360deg)}
}
/* stamp: quick scale slam every cycle, then settles */
@keyframes hsStampSlam{
  0%      {transform:scale(1) rotate(0)}
  40%     {transform:scale(1) rotate(0)}
  45%     {transform:scale(1.5) rotate(-8deg);opacity:.6}
  52%     {transform:scale(.95) rotate(2deg)}
  58%     {transform:scale(1.05) rotate(-1deg)}
  65%     {transform:scale(1) rotate(0)}
  100%    {transform:scale(1) rotate(0)}
}
@keyframes hsRouteFlow{
  to{stroke-dashoffset:-16}
}
@keyframes hsDotPulse{
  0%,100%{r:5;opacity:1}
  50%{r:8;opacity:.6}
}
@keyframes hsPacketPulse{
  0%,100%{r:5}
  50%{r:7}
}
@keyframes hsFloatA{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
@keyframes hsFloatB{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(8px)}
}
@keyframes hsDotGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.55)}
  50%{box-shadow:0 0 0 5px rgba(16,185,129,0)}
}
@media (prefers-reduced-motion: reduce){
  .hero-art .ring,
  .hero-svg .hs-check,.hero-svg .hs-flap,.hero-svg .hs-badge,.hero-svg .hs-badge-ring,
  .hero-svg .hs-stamp,.hero-svg .hs-route,.hero-svg .hs-route-end,.hero-svg .hs-packet,
  .hero-floating.f1,.hero-floating.f2,.dot-status{animation:none !important}
}

/* ============== COMPLIANCE STRIP ============== */
.comp-strip{background:#fff;padding:24px 0;border-bottom:1px solid var(--line)}
.comp-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.comp-label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-500);font-weight:500}
.badges{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.badge-cert{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--teal-50);border:1px solid var(--accent-soft);border-radius:999px;font-size:12px;font-weight:600;color:var(--primary-600);font-family:"Inter Tight",sans-serif}
.badge-cert .b-mark{width:6px;height:6px;background:var(--accent);border-radius:50%}

/* ============== STATS ============== */
.stats-section{background:var(--primary);color:#fff;padding:72px 0}
.stats-eyebrow{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.stats-eyebrow .l{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:8px}
.stats-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.stats-asof{font-family:"JetBrains Mono",monospace;font-size:11.5px;letter-spacing:.04em;color:rgba(255,255,255,.6)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.15)}
@media(max-width:780px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
.stat{padding:36px 28px 32px;border-right:1px solid rgba(255,255,255,.15)}
.stat:last-child{border-right:none}
@media(max-width:780px){.stat:nth-child(2){border-right:none}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.15)}}
.stat .num{display:flex;align-items:flex-start;gap:2px;font-family:"Poppins",sans-serif;font-weight:400;line-height:1;letter-spacing:-.025em;color:#fff;font-variant-numeric:tabular-nums}
.stat .num-val{font-size:60px}
.stat .num-suffix{font-size:30px;color:var(--gold);margin-top:6px;font-weight:500;font-style:italic}
.stat .lab{margin-top:14px;font-size:14px;font-weight:600;color:rgba(255,255,255,.85)}
.stats-foot{margin-top:28px;font-size:12px;color:rgba(255,255,255,.55);font-style:italic;max-width:880px;line-height:1.6}
.stats-foot strong{color:rgba(255,255,255,.8);font-style:normal;font-weight:600}

/* ============== SECTION COMMON ============== */
section.sec{padding:96px 0;border-bottom:1px solid var(--line)}
.sec-head{margin-bottom:56px;max-width:780px}
.sec-head h2{margin-top:14px}
.sec-head p{margin-top:14px;font-size:16px;color:var(--ink-500)}

/* ============== PROBLEM/SOLUTION ============== */
.split{background:#fff}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
@media(max-width:880px){.split-grid{grid-template-columns:1fr}}
.split-col{padding:40px}
.split-col.problem{background:#FAF6F4;border-right:1px solid var(--line)}
.split-col.solution{background:linear-gradient(180deg,#fff 0%,var(--accent-soft) 100%)}
@media(max-width:880px){.split-col.problem{border-right:none;border-bottom:1px solid var(--line)}}
.split-col h3{font-family:"Inter Tight",sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-500);margin-bottom:24px;font-weight:600}
.split-col.solution h3{color:var(--primary)}
.split-item{padding:22px 0;border-bottom:1px dashed var(--line)}
.split-item:last-child{border-bottom:none}
.split-item h4{font-family:"Poppins",sans-serif;font-size:22px;font-weight:500;letter-spacing:-.005em;margin-bottom:8px;color:var(--primary)}
.split-col.problem .split-item h4{color:var(--ink-900)}
.split-item p{font-size:14.5px;color:var(--ink-700);line-height:1.55}

/* ============== PROCESS RAIL ============== */
.process{background:var(--bg)}
.process-rail{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
@media(max-width:880px){.process-rail{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.process-rail{grid-template-columns:1fr}}
.process-rail::before{content:"";position:absolute;left:80px;right:80px;top:80px;height:1px;background:var(--accent-soft);z-index:1}
@media(max-width:880px){.process-rail::before{display:none}}
.process-step{text-align:center;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.process-step .step-art{width:160px;height:160px;border-radius:18px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(8,94,62,.06);position:relative;overflow:hidden}
.process-step .step-art svg{width:100%;height:100%;display:block}
.process-step .step-art .step-tag{position:absolute;top:10px;left:10px;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;color:var(--ink-500);background:var(--bg);padding:3px 8px;border-radius:4px;font-weight:500}
.process-step h4{font-family:"Inter Tight",sans-serif;font-size:15px;color:var(--ink-900);margin-top:20px;font-weight:600}
.process-step p{font-size:13px;color:var(--ink-500);max-width:220px;margin:6px auto 0;line-height:1.5}

/* step animations */
@keyframes psBillSlide{
  0%   {transform:translateX(-90px) rotate(-8deg);opacity:0}
  20%  {transform:translateX(0) rotate(0);opacity:1}
  70%  {transform:translateX(0) rotate(0);opacity:1}
  85%  {transform:translateX(8px) translateY(8px) rotate(2deg);opacity:.4}
  100% {transform:translateX(-90px) rotate(-8deg);opacity:0}
}
@keyframes psTrayBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}
@keyframes psStampDrop1{
  0%,5%   {transform:translateY(-30px) scale(1.8) rotate(-8deg);opacity:0}
  18%     {transform:translateY(2px) scale(.92) rotate(-4deg);opacity:1}
  24%     {transform:translateY(0) scale(1.05) rotate(-2deg);opacity:1}
  30%,100%{transform:translateY(0) scale(1) rotate(-2deg);opacity:1}
}
@keyframes psStampDrop2{
  0%,30%  {transform:translateY(-30px) scale(1.8) rotate(6deg);opacity:0}
  43%     {transform:translateY(2px) scale(.92) rotate(3deg);opacity:1}
  49%     {transform:translateY(0) scale(1.05) rotate(2deg);opacity:1}
  55%,100%{transform:translateY(0) scale(1) rotate(2deg);opacity:1}
}
@keyframes psStampDrop3{
  0%,55%  {transform:translateY(-30px) scale(1.8) rotate(-3deg);opacity:0}
  68%     {transform:translateY(2px) scale(.92) rotate(0deg);opacity:1}
  74%     {transform:translateY(0) scale(1.05) rotate(-1deg);opacity:1}
  80%,94% {transform:translateY(0) scale(1) rotate(-1deg);opacity:1}
  100%    {transform:translateY(0) scale(1) rotate(-1deg);opacity:0}
}
.step-art .ps-stamp-1{transform-box:fill-box;transform-origin:center;animation:psStampDrop1 5s cubic-bezier(.4,0,.2,1) infinite}
.step-art .ps-stamp-2{transform-box:fill-box;transform-origin:center;animation:psStampDrop2 5s cubic-bezier(.4,0,.2,1) infinite}
.step-art .ps-stamp-3{transform-box:fill-box;transform-origin:center;animation:psStampDrop3 5s cubic-bezier(.4,0,.2,1) infinite}
@keyframes psPrintFeed{
  0%   {transform:translateY(-30px);opacity:0}
  20%  {transform:translateY(0);opacity:1}
  70%  {transform:translateY(0);opacity:1}
  100% {transform:translateY(45px);opacity:0}
}
@keyframes psPrinterPulse{0%,100%{fill:var(--accent-soft)}50%{fill:#10B981}}
@keyframes psTickIn1{0%,15%{stroke-dashoffset:24}30%,100%{stroke-dashoffset:0}}
@keyframes psTickIn2{0%,40%{stroke-dashoffset:24}55%,100%{stroke-dashoffset:0}}
@keyframes psTickIn3{0%,65%{stroke-dashoffset:24}80%,100%{stroke-dashoffset:0}}
@keyframes psBarGrow{0%,10%{transform:scaleX(0)}90%,100%{transform:scaleX(1)}}

.step-art .ps-bill{transform-origin:center;animation:psBillSlide 4s ease-in-out infinite}
.step-art .ps-tray{transform-origin:center;animation:psTrayBob 2.5s ease-in-out infinite}
.step-art .ps-paper{animation:psPrintFeed 3.5s ease-in-out infinite}
.step-art .ps-printer-led{animation:psPrinterPulse 1.2s ease-in-out infinite}
.step-art .ps-tick-1{stroke-dasharray:24;stroke-dashoffset:24;animation:psTickIn1 4s ease-out infinite}
.step-art .ps-tick-2{stroke-dasharray:24;stroke-dashoffset:24;animation:psTickIn2 4s ease-out infinite}
.step-art .ps-tick-3{stroke-dasharray:24;stroke-dashoffset:24;animation:psTickIn3 4s ease-out infinite}
.step-art .ps-bar{transform-origin:left center;animation:psBarGrow 4s ease-out infinite}

@media (prefers-reduced-motion: reduce){
  .step-art *{animation:none !important}
}

/* ============== PERSONAS ============== */
.personas{background:#fff}
.persona-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:980px){.persona-grid{grid-template-columns:1fr}}
.persona-card{display:flex;flex-direction:column;gap:16px;padding:32px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);min-height:380px;transition:all .2s ease}
.persona-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.persona-card .ico{width:54px;height:54px;border-radius:12px;background:var(--accent-soft);color:var(--primary-600);display:grid;place-items:center}
.persona-card h3{font-size:22px;color:var(--primary)}
.persona-card p{font-size:14.5px;color:var(--ink-700);line-height:1.55}
.persona-card .stat-row{display:flex;gap:24px;padding-top:16px;border-top:1px solid var(--line);margin-top:auto}
.persona-card .stat-row .col .s{font-family:"Poppins",sans-serif;font-size:22px;color:var(--primary);display:block;line-height:1;font-weight:500}
.persona-card .stat-row .col .l{font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-top:4px;display:block}

/* ============== FEATURES ============== */
.features{background:var(--bg)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
@media(max-width:880px){.feat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.feat-grid{grid-template-columns:1fr}}
.feat{background:#fff;padding:32px;display:flex;flex-direction:column}
.feat .ico{width:42px;height:42px;color:var(--accent);margin-bottom:18px}
.feat .feat-num{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-300);letter-spacing:.16em;font-weight:500}
.feat h3{font-size:21px;margin-top:8px}
.feat p{font-size:14px;color:var(--ink-700);margin-top:10px;line-height:1.55}

.zilm-callout{margin-top:48px;padding:32px;background:linear-gradient(180deg,#fff 0%,var(--accent-soft) 100%);border:1px solid var(--line);border-radius:var(--radius-lg);display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center}
@media(max-width:780px){.zilm-callout{grid-template-columns:1fr}}
#ilp .zilm-logo{height:42px;width:auto;display:block;max-width:none}
.zilm-callout p{font-size:14.5px;color:var(--ink-700);line-height:1.55}
.zilm-callout p strong{color:var(--primary-900)}

/* ============== ROI CALCULATOR ============== */
.roi-section{background:#fff}
.roi-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
@media(max-width:880px){.roi-grid{grid-template-columns:1fr}}
.roi-input{padding:40px;background:#fff;border-right:1px solid var(--line)}
@media(max-width:880px){.roi-input{border-right:none;border-bottom:1px solid var(--line)}}
.roi-input .top-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}
.roi-input h3{font-size:22px;color:var(--primary)}
.roi-reset{font-size:12px;color:var(--primary);font-weight:500;cursor:pointer;text-decoration:underline;text-underline-offset:3px;background:none;border:none;font-family:inherit}
.roi-input .field{margin-bottom:24px}
.roi-input .field:last-child{margin-bottom:0}
.roi-input .field label{font-size:13.5px;font-weight:500;color:var(--ink-700);display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.roi-input .field label .v{font-family:"JetBrains Mono",monospace;font-size:15px;color:var(--primary);font-weight:600;font-variant-numeric:tabular-nums}
.roi-input input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:4px;background:var(--accent-soft);border-radius:999px;outline:none}
.roi-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;border:3px solid #fff;box-shadow:0 0 0 1px var(--primary)}
.roi-input input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;border:3px solid #fff;box-shadow:0 0 0 1px var(--primary)}
.roi-input .field .hint{font-size:11.5px;color:var(--ink-500);margin-top:8px}
.roi-output{padding:40px;background:linear-gradient(180deg,var(--accent-soft) 0%,#fff 100%);display:flex;flex-direction:column;gap:20px}
.roi-pill{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);background:rgba(201,162,78,.1);border:1px solid rgba(201,162,78,.3);padding:4px 10px;border-radius:999px;align-self:flex-start}
.roi-pill::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px rgba(201,162,78,.2)}
.roi-output .savings{font-family:"Poppins",sans-serif;font-size:64px;font-weight:500;color:var(--primary);line-height:1;letter-spacing:-.025em;font-variant-numeric:tabular-nums}
.roi-output .savings .suffix{font-size:32px;color:var(--gold);font-style:italic;margin-left:4px}
.roi-output .save-label{font-size:13px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-top:-8px}
.roi-breakdown{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.roi-cell{padding:18px 20px;border-right:1px solid var(--line)}
.roi-cell:last-child{border-right:none}
.roi-cell .lbl{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-500)}
.roi-cell .val{font-family:"Poppins",sans-serif;font-size:24px;color:var(--primary);font-weight:500;margin-top:6px;font-variant-numeric:tabular-nums}
.roi-cell.now .val{color:var(--ink-900)}
.roi-foot{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--ink-500);padding-top:8px;border-top:1px dashed var(--line);flex-wrap:wrap;gap:8px}
.roi-foot .annual{color:var(--primary);font-weight:600;font-family:"Poppins",sans-serif;font-size:18px}

/* ============== TIMELINE ============== */
.timeline-section{background:#fff}
.tl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
@media(max-width:880px){.tl-grid{grid-template-columns:1fr 1fr}}

/* base track + animated fill that draws across all 4 steps */
.tl-line{position:absolute;left:0;right:0;top:30px;height:1px;background:var(--accent-soft);overflow:visible}
.tl-line::before{content:"";position:absolute;inset:0;background:var(--accent);transform-origin:left center;transform:scaleX(0);animation:tlDraw 8s cubic-bezier(.65,0,.35,1) infinite}
.tl-line::after{content:"";position:absolute;top:-2px;width:5px;height:5px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px rgba(8,94,62,.12);left:0;opacity:0;animation:tlPulse 8s ease-in-out infinite}
@media(max-width:880px){.tl-line{display:none}}

.tl-step{position:relative;opacity:0;transform:translateY(8px);animation:tlStepIn 8s cubic-bezier(.4,0,.2,1) infinite}
.tl-step:nth-child(2){animation-delay:.6s}
.tl-step:nth-child(3){animation-delay:1.4s}
.tl-step:nth-child(4){animation-delay:2.2s}
.tl-step:nth-child(5){animation-delay:3.0s}

.tl-dot{width:14px;height:14px;border-radius:50%;background:var(--accent);border:4px solid #fff;box-shadow:0 0 0 1px var(--accent);margin:24px 0 18px;position:relative;z-index:2;transform:scale(.4);animation:tlDotPop 8s cubic-bezier(.34,1.56,.64,1) infinite;animation-delay:inherit}
.tl-step .day{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;color:var(--accent);text-transform:uppercase;font-weight:600}
.tl-step h4{font-family:"Poppins",sans-serif;font-size:20px;font-weight:500;margin-top:8px;color:var(--primary)}
.tl-step p{font-size:13.5px;color:var(--ink-500);margin-top:8px;line-height:1.5}

@keyframes tlDraw{
  0%{transform:scaleX(0)}
  50%,90%{transform:scaleX(1)}
  100%{transform:scaleX(0)}
}
@keyframes tlStepIn{
  0%{opacity:0;transform:translateY(8px)}
  10%,90%{opacity:1;transform:translateY(0)}
  100%{opacity:0;transform:translateY(8px)}
}
@keyframes tlDotPop{
  0%{transform:scale(.4);opacity:0}
  8%{transform:scale(1.25);opacity:1}
  12%,90%{transform:scale(1);opacity:1}
  100%{transform:scale(.4);opacity:0}
}
@keyframes tlPulse{
  0%,55%{left:0;opacity:0;transform:scale(.6)}
  60%{opacity:1;transform:scale(1)}
  85%{left:100%;opacity:1;transform:scale(1)}
  90%,100%{left:100%;opacity:0;transform:scale(.6)}
}
@media (prefers-reduced-motion: reduce){
  .tl-line::before,.tl-line::after,.tl-step,.tl-dot{animation:none !important;opacity:1 !important;transform:none !important}
  .tl-line::before{transform:scaleX(1) !important}
}

/* ============== TESTIMONIALS ============== */
.testi{background:var(--bg)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:880px){.testi-grid{grid-template-columns:1fr}}
.testi-card{background:#fff;border:1px solid var(--line);padding:28px;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:18px}
.stars{color:var(--gold);font-size:14px;letter-spacing:2px}
.testi-card blockquote{font-family:"Poppins",sans-serif;font-size:20px;font-weight:500;line-height:1.35;letter-spacing:-.005em;color:var(--primary)}
.testi-foot{display:flex;align-items:center;gap:12px;margin-top:auto;border-top:1px solid var(--line);padding-top:16px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-family:"Poppins",sans-serif;font-weight:600}
.testi-card .nm{font-size:14px;font-weight:600;color:var(--ink-900)}
.testi-card .role{font-size:12px;color:var(--ink-500);margin-top:2px}

/* ============== FAQ ============== */
.faq-section{background:#fff}
.faq-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:64px}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr;gap:32px}}
.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
details{border-bottom:1px solid var(--line);padding:22px 0}
summary{font-family:"Poppins",sans-serif;font-size:19px;font-weight:500;color:var(--primary);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-family:"Poppins",sans-serif;font-size:24px;color:var(--accent);transition:transform .2s;flex:0 0 auto}
details[open] summary::after{content:"−"}
details p{margin-top:14px;font-size:14.5px;color:var(--ink-700);line-height:1.6}

/* ============== CTA BAND ============== */
.cta-band{background:var(--primary-900);color:#fff;padding:120px 0;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%, rgba(42,122,126,.45) 0%, transparent 60%);pointer-events:none}
.cta-inner{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center}
@media(max-width:880px){.cta-inner{grid-template-columns:1fr}}
.cta-inner h2{color:#fff;font-size:52px;line-height:1.05;letter-spacing:-.02em}
.cta-inner h2 .accent{color:var(--gold);font-style:italic}
.cta-inner p{margin-top:20px;color:rgba(255,255,255,.75);font-size:16px;max-width:480px}
.cta-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:28px}
.cta-card .lbl{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;color:var(--gold);text-transform:uppercase;font-weight:500}
.cta-card .row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px dashed rgba(255,255,255,.14);font-size:14px;color:rgba(255,255,255,.85)}
.cta-card .row:last-child{border-bottom:none}
.cta-card .row span:last-child{font-family:"Poppins",sans-serif;font-size:18px;color:#fff;font-weight:500}
.cta-band .btn-primary{background:#fff;color:var(--primary-900);border-color:#fff}
.cta-band .btn-primary:hover{background:var(--gold);color:var(--primary-900);border-color:var(--gold)}
.cta-band .btn-ghost{border-color:rgba(255,255,255,.4);color:#fff;background:transparent}
.cta-band .btn-ghost:hover{background:#fff;color:var(--primary-900)}

@media(max-width:980px){
  h1{font-size:48px;line-height:1.06}
  h2{font-size:34px;line-height:1.12}
  .hero{padding:56px 0 64px}
  .hero h1{font-size:48px}
  section.sec{padding:72px 0}
  .sec-head{margin-bottom:40px}
  .stats-section{padding:56px 0}
  .stat{padding:30px 22px 28px}
  .stat .num-val{font-size:50px}
  .stat .num-suffix{font-size:26px}
  .cta-band{padding:88px 0}
  .cta-inner h2{font-size:42px}
  .roi-output .savings{font-size:54px}
  .roi-output .savings .suffix{font-size:26px}
}
@media(max-width:780px){
  .container{padding:0 24px}
  h1{font-size:42px;line-height:1.07}
  h2{font-size:28px;line-height:1.15}
  h3{font-size:20px}
  .hero{padding:40px 0 56px}
  .hero h1{font-size:42px}
  .hero-art{display:none}
  .hero p.lede{font-size:18px;margin-top:18px}
  .hero-bullets{margin-top:20px;gap:9px}
  .hero-bullets li{font-size:16.5px}
  .hero-cta{margin-top:24px}
  .hero-disclaimer{font-size:13px;margin-top:18px;line-height:1.5}
  section.sec{padding:56px 0}
  .sec-head{margin-bottom:32px}
  .sec-head p{font-size:17px}
  .stats-section{padding:48px 0}
  .stats-eyebrow{margin-bottom:22px}
  .stat{padding:26px 20px 24px}
  .stat .num-val{font-size:40px}
  .stat .num-suffix{font-size:20px}
  .stat .lab{margin-top:10px;font-size:15px}
  .cta-band{padding:64px 0}
  .cta-inner{gap:36px}
  .cta-inner h2{font-size:34px}
  .cta-inner p{font-size:17px}
  .cta-card{padding:24px}
  .roi-input,.roi-output{padding:28px}
  .roi-output .savings{font-size:46px}
  .roi-output .savings .suffix{font-size:22px}
  .split-col{padding:28px}
  .split-item h4{font-size:19px}
  .feat{padding:24px}
  .feat h3{font-size:19px}
  .persona-card{padding:26px;min-height:auto}
  .persona-card h3{font-size:20px}
  .testi-grid{gap:16px}
  .testi-card{padding:22px}
  .testi-card blockquote{font-size:20px}
  .faq-grid{gap:24px}
  summary{font-size:19px;gap:16px}
  .footer{padding:48px 0 24px}
  .footer .top{padding-bottom:36px;gap:28px}
  .zilm-callout{padding:26px;gap:22px;margin-top:36px}
  #ilp .zilm-logo{height:36px}
  /* compliance strip */
  .comp-strip{padding:20px 0}
  .comp-inner{gap:16px;justify-content:center}
  .comp-label{width:100%;text-align:center}
  .badges{gap:8px;justify-content:center}
}

/* phones */
@media(max-width:560px){
  .container{padding:0 18px}
  h1{font-size:38px;line-height:1.08;letter-spacing:-.02em}
  h2{font-size:25px;line-height:1.15}
  .site-header .row{height:62px;gap:12px}
  .brand-logo-img{height:34px}
  .header-cta{gap:8px}
  .header-cta a.btn{height:36px !important;padding:0 12px !important;font-size:13px !important}
  .hero{padding:28px 0 44px}
  .hero h1{font-size:38px}
  .hero p.lede{font-size:17px;margin-top:16px;max-width:none}
  .hero-bullets li{font-size:15.5px;gap:8px}
  .hero-tick{flex-basis:18px;height:18px;font-size:13px}
  .hero-cta{flex-direction:column;align-items:stretch;gap:10px;margin-top:22px}
  .hero-cta .btn{width:100%;justify-content:center;height:50px;font-size:15px;font-weight:600}
  .hero-cta .btn-ghost{background:transparent;border-color:transparent;color:var(--primary);text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px;height:auto;padding:6px 0;font-size:14px;font-weight:500}
  .hero-cta .btn-ghost:hover{color:var(--primary-600);background:transparent}
  .hero-disclaimer{font-size:12.5px}
  .hero-grid{gap:24px}
  .hero-right{gap:18px}
  .hero-art{max-width:300px}
  .hero-floating{padding:7px 10px;border-radius:9px;max-width:48%}
  .hero-floating .lbl{font-size:8.5px}
  .hero-floating .val{font-size:12.5px}
  .hero-floating .sub{font-size:9.5px}
  .hero-floating.f1{top:6px;left:6px}
  .hero-floating.f2{bottom:6px;right:6px}
  section.sec{padding:44px 0}
  .sec-head{margin-bottom:26px}
  .sec-head p{font-size:16px;line-height:1.55}
  .stats-section{padding:36px 0}
  .stats-eyebrow .l{font-size:10.5px;letter-spacing:.14em}
  .stats-asof{font-size:10.5px}
  /* stats: compact 2x2 card with hairline dividers */
  .stats-section{padding:36px 0 40px}
  .stats-eyebrow{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:22px}
  .stats-eyebrow .l{font-family:"Poppins",sans-serif;font-size:15px;font-weight:500;letter-spacing:0;line-height:1.45;color:rgba(255,255,255,.92);text-transform:none}
  .stats-eyebrow .l .dot{display:none}
  .stats-asof{font-size:11px;letter-spacing:.14em;color:rgba(255,255,255,.55);text-transform:uppercase;font-weight:500}
  .stats-grid{
    grid-template-columns:repeat(2,1fr);
    gap:1px;
    background:rgba(255,255,255,.14);
    border:1px solid rgba(255,255,255,.16);
    border-radius:14px;
    overflow:hidden;
  }
  .stat{
    padding:22px 18px;
    background:var(--primary);
    border:none !important;
  }
  .stat .num{align-items:baseline;gap:3px}
  .stat .num-val{font-size:36px;font-weight:600;letter-spacing:-.025em;line-height:1}
  .stat .num-suffix{font-size:17px;margin-top:0;font-style:italic;color:var(--gold)}
  .stat .lab{margin-top:10px;font-size:14.5px;font-weight:600;line-height:1.4;color:rgba(255,255,255,.92);letter-spacing:.005em}
  .stats-foot{margin-top:22px;font-size:13px;line-height:1.65}
  .cta-band{padding:48px 0}
  .cta-inner{gap:28px}
  .cta-inner h2{font-size:26px}
  .cta-inner p{font-size:16.5px;margin-top:14px}
  .cta-card{padding:20px}
  .cta-card .row{padding:12px 0;font-size:15px}
  .cta-card .row span:last-child{font-size:18px}
  .roi-input,.roi-output{padding:22px}
  .roi-input .top-row{margin-bottom:22px}
  .roi-input h3{font-size:19px}
  .roi-output{gap:16px}
  .roi-output .savings{font-size:38px}
  .roi-output .savings .suffix{font-size:18px}
  .roi-breakdown{grid-template-columns:1fr}
  .roi-cell{border-right:none;border-bottom:1px solid var(--line);padding:14px 16px}
  .roi-cell:last-child{border-bottom:none}
  .roi-cell .val{font-size:21px}
  .roi-foot{font-size:13.5px}
  .roi-foot .annual{font-size:16px}
  .split-col{padding:22px}
  .split-item{padding:18px 0}
  .split-item h4{font-size:17px}
  .split-item p{font-size:15.5px}
  .feat{padding:20px}
  .feat h3{font-size:17px}
  .feat p{font-size:15.5px}
  .feat .ico{width:36px;height:36px;margin-bottom:14px}
  .persona-card{padding:22px}
  .persona-card h3{font-size:19px}
  .persona-card p{font-size:15.5px}
  .persona-card .stat-row{gap:18px;padding-top:14px}
  .persona-card .stat-row .col .s{font-size:19px}
  .testi-card{padding:20px;gap:14px}
  .testi-card blockquote{font-size:18px;line-height:1.4}
  .faq-grid{gap:22px}
  summary{font-size:18px;gap:14px}
  details{padding:18px 0}
  details p{font-size:15.5px;margin-top:10px}
  /* process step */
  .process-step .step-art{width:140px;height:140px}
  .process-step h4{font-size:14px;margin-top:16px}
  .process-step p{font-size:14.5px}
  /* timeline */
  .tl-grid{grid-template-columns:1fr;gap:14px}
  .tl-step{padding-left:22px;border-left:1px solid var(--accent-soft)}
  .tl-dot{margin:0 0 8px;position:absolute;left:-7px;top:0}
  .tl-step h4{font-size:18px}
  .tl-step p{font-size:15px}
  /* zilm callout */
  .zilm-callout{padding:22px;gap:16px;margin-top:28px}
  #ilp .zilm-logo{height:30px}
  .zilm-callout p{font-size:15.5px}
  /* footer */
  .footer{padding:36px 0 22px}
  .footer .top{grid-template-columns:1fr;gap:24px;padding-bottom:26px}
  .footer .desc{max-width:none;font-size:15px}
  .footer .brand-foot{font-size:22px;margin-bottom:10px}
  .footer h5{margin-bottom:10px}
  .footer ul{gap:7px}
  .footer a{font-size:15.5px}
  .footer .bot{flex-direction:column;align-items:flex-start;gap:12px;font-size:14px}
  .footer .legal{gap:18px}
  .disclosure{font-size:12.5px}
  .comp-inner{gap:12px}
  .badge-cert{padding:6px 11px;font-size:13px}
}

/* small phones */
@media(max-width:400px){
  .container{padding:0 16px}
  h1,.hero h1{font-size:32px;letter-spacing:-.02em;line-height:1.08}
  h2,.cta-inner h2{font-size:22px}
  .hero{padding:20px 0 36px}
  .hero-grid{gap:18px}
  .hero-art{max-width:260px}
  .hero-logos img{height:22px}
  .hero-floating{max-width:50%}
  .hero-floating .val{font-size:11.5px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1px}
  .stat{padding:18px 14px}
  .stat .num-val{font-size:30px}
  .stat .num-suffix{font-size:15px}
  .stat .lab{font-size:12.5px;line-height:1.35}
  .roi-output .savings{font-size:34px}
  .roi-output .savings .suffix{font-size:16px}
  .testi-card blockquote{font-size:15px}
  summary{font-size:15px}
  .footer .brand-foot{font-size:20px}
}

/* ============== THEME-COMPATIBILITY LAYER ==============
 * Plugin runs inside themes (Divi, Astra) that inject typography rules with
 * compound-class specificity (e.g. `.et_pb_section p` at (0,1,1)) that beat
 * our `.hero p.lede` (0,2,1) — wait, no, those tie. The real problem is Divi
 * ships `body { line-height: 1.7 }` and `.et_pb_module p { margin-bottom: 1em }`
 * which bleed margins/line-heights everywhere. We re-assert every variant at
 * `#ilp` specificity (1,*,*) so it always wins — no `!important` needed.
 */

/* --- Body baseline: kills Divi's body { line-height: 1.7 } --- */
#ilp { line-height: 1.5; }

/* --- Container width: Divi ships `.container { margin: 0 10% }` which on a 375px
   phone leaves only ~268px of content width — so H1 wraps each word individually.
   Restore the plugin's intended `margin: 0 auto` + responsive padding. --- */
#ilp .container { max-width: 1240px; margin: 0 auto; padding: 0 32px; width: 100%; box-sizing: border-box; }
@media(max-width:780px){ #ilp .container { padding: 0 24px; } }
@media(max-width:560px){ #ilp .container { padding: 0 18px; } }
@media(max-width:400px){ #ilp .container { padding: 0 16px; } }

/* --- Paragraph defaults --- */
#ilp p { padding-bottom: 0; line-height: 1.55; margin: 0; }
#ilp ul, #ilp ol { padding-left: 0; margin: 0; }
#ilp a, #ilp a:hover { text-decoration: none; }

/* --- Heading sizes & line-heights (Divi typically ships h2 at 30px / lh:1.4) --- */
#ilp h1, #ilp h2, #ilp h3, #ilp h4 { line-height: 1.1; font-family: "Poppins", "Inter Tight", ui-sans-serif, system-ui, sans-serif; font-weight: 600; color: var(--primary); letter-spacing: -.02em; }
#ilp h1 { font-size: 54px; line-height: 1.06; letter-spacing: -.02em; }
#ilp h2 { font-size: 42px; line-height: 1.1; letter-spacing: -.018em; }
#ilp h3 { font-size: 24px; line-height: 1.2; }
#ilp h4 { font-size: 18px; line-height: 1.25; }

/* --- PROBLEM/SOLUTION split: re-assert at #ilp so Divi can't bleed in --- */
#ilp .split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; }
#ilp .split-col { padding: 40px; }
#ilp .split-col.problem { background: #FAF6F4; border-right: 1px solid var(--line); }
#ilp .split-col.solution { background: linear-gradient(180deg, #fff 0%, var(--accent-soft) 100%); }
#ilp .split-col h3 { font-family: "Inter Tight", sans-serif; font-size: 13px; text-transform: uppercase; letter-spacing: .1em; color: var(--ink-500); margin-bottom: 24px; font-weight: 600; }
#ilp .split-col.solution h3 { color: var(--primary); }
#ilp .split-item { padding: 22px 0; border-bottom: 1px dashed var(--line); }
#ilp .split-item:last-child { border-bottom: none; }
#ilp .split-item h4 { font-family: "Poppins", sans-serif; font-size: 22px; font-weight: 500; letter-spacing: -.005em; margin-bottom: 8px; color: var(--primary); line-height: 1.25; }
#ilp .split-col.problem .split-item h4 { color: var(--ink-900); }
#ilp .split-item p { font-size: 14.5px; color: var(--ink-700); line-height: 1.55; }

@media(max-width:880px){
  #ilp .split-grid { grid-template-columns: 1fr; }
  #ilp .split-col.problem { border-right: none; border-bottom: 1px solid var(--line); }
}
@media(max-width:780px){
  #ilp h2 { font-size: 34px; line-height: 1.12; }
  #ilp .split-col { padding: 28px; }
  #ilp .split-item h4 { font-size: 19px; }
}
@media(max-width:560px){
  #ilp h2 { font-size: 28px; line-height: 1.15; }
  #ilp .split-col { padding: 22px; }
  #ilp .split-item h4 { font-size: 17px; }
  #ilp .split-item p { font-size: 15.5px; }
}
@media(max-width:400px){
  #ilp h2 { font-size: 22px; }
}

/* --- Section paddings (kill .et_pb_section { padding:4% 0 } and similar) --- */
#ilp section.hero        { padding: 72px 0 88px; }
#ilp section.comp-strip  { padding: 24px 0; }
#ilp section.stats-section { padding: 72px 0; }
#ilp section.sec         { padding: 96px 0; }
#ilp section.cta-band    { padding: 120px 0; }

/* --- Eyebrow + buttons --- */
#ilp .eyebrow { font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Consolas, monospace; line-height: 1.2; }

/* --- HERO --- */
/* font-size + line-height get !important because some Divi installs ship inline
   <style> blocks targeting h1 with very high specificity that the ID alone can't beat. */
#ilp .hero h1 { font-weight: 600; color: #0F7A52; font-size: 50px !important; line-height: 1.04 !important; letter-spacing: -.03em; margin: 0; }
#ilp .hero h1 .accent { font-weight: 500; color: var(--accent); }
#ilp .hero p.lede { font-size: 17.5px; line-height: 1.55 !important; margin-top: 22px; max-width: 520px; color: var(--ink-700); }

/* --- Hero compliance logos: prelude `#ilp img { height: auto }` wins (1,0,1)
   over plain `.hero-logos img { height: 34px }` (0,1,1) — bump variant to (1,1,1)
   so each PNG renders at 34px tall instead of natural ~300px. --- */
#ilp .hero-logos img { height: 34px; width: auto; flex: 0 0 auto; max-width: none; }
#ilp .hero-bullets { margin-top: 26px; gap: 11px; display: grid; list-style: none; padding: 0; }
#ilp .hero-bullets li { font-size: 14.5px; line-height: 1.5; color: var(--ink-700); display: flex; gap: 10px; align-items: flex-start; }
#ilp .hero-cta { margin-top: 32px; }
#ilp .hero-disclaimer { font-size: 11.5px; line-height: 1.55; margin-top: 24px; max-width: 520px; color: var(--ink-500); }

/* --- STATS section: re-assert at #ilp specificity so Divi can't bleed in --- */
#ilp .stats-section { background: var(--primary); color: #fff; padding: 72px 0; }
#ilp .stats-eyebrow { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; flex-wrap: wrap; gap: 12px; }
#ilp .stats-eyebrow .l { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.7); display: flex; align-items: center; gap: 8px; line-height: 1.5; }
#ilp .stats-eyebrow .l .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); display: inline-block; }
#ilp .stats-asof { font-family: "JetBrains Mono", monospace; font-size: 11.5px; letter-spacing: .04em; color: rgba(255,255,255,.6); }
#ilp .stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(255,255,255,.15); }
#ilp .stat { padding: 36px 28px 32px; border-right: 1px solid rgba(255,255,255,.15); }
#ilp .stat:last-child { border-right: none; }
#ilp .stat .num { display: flex; align-items: flex-start; gap: 2px; font-family: "Poppins", sans-serif; font-weight: 400; line-height: 1; letter-spacing: -.025em; color: #fff; font-variant-numeric: tabular-nums; }
#ilp .stat .num-val { font-size: 60px; }
#ilp .stat .num-suffix { font-size: 30px; color: var(--gold); margin-top: 6px; font-weight: 500; font-style: italic; }
#ilp .stat .lab { margin-top: 14px; font-size: 14px; font-weight: 600; color: rgba(255,255,255,.85); line-height: 1.4; }
#ilp .stats-foot { margin-top: 28px; font-size: 12px; color: rgba(255,255,255,.55); font-style: italic; max-width: 880px; line-height: 1.6; }
#ilp .stats-foot strong { color: rgba(255,255,255,.8); font-style: normal; font-weight: 600; }

/* --- STATS mobile: 2x2 hairline-card treatment matching single-file --- */
@media(max-width:780px){
  #ilp .stats-section { padding: 48px 0; }
  #ilp .stats-grid { grid-template-columns: repeat(2, 1fr); }
  #ilp .stat { padding: 26px 20px 24px; }
  #ilp .stat .num-val { font-size: 40px; }
  #ilp .stat .num-suffix { font-size: 20px; }
  #ilp .stat .lab { margin-top: 10px; font-size: 15px; }
}
@media(max-width:560px){
  #ilp .stats-section { padding: 36px 0 40px; }
  #ilp .stats-eyebrow { flex-direction: column; align-items: flex-start; gap: 8px; margin-bottom: 22px; }
  #ilp .stats-eyebrow .l { font-family: "Poppins", sans-serif; font-size: 15px; font-weight: 500; letter-spacing: 0; line-height: 1.45; color: rgba(255,255,255,.92); text-transform: none; }
  #ilp .stats-eyebrow .l .dot { display: none; }
  #ilp .stats-asof { font-size: 11px; letter-spacing: .14em; color: rgba(255,255,255,.55); text-transform: uppercase; font-weight: 500; }
  #ilp .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1px; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.16); border-radius: 14px; overflow: hidden; border-top: none; }
  #ilp .stat { padding: 22px 18px; background: var(--primary); border: none; }
  #ilp .stat:last-child { border: none; }
  #ilp .stat .num { align-items: baseline; gap: 3px; }
  #ilp .stat .num-val { font-size: 36px; font-weight: 600; letter-spacing: -.025em; line-height: 1; }
  #ilp .stat .num-suffix { font-size: 17px; margin-top: 0; font-style: italic; color: var(--gold); }
  #ilp .stat .lab { margin-top: 10px; font-size: 14.5px; font-weight: 600; line-height: 1.4; color: rgba(255,255,255,.92); letter-spacing: .005em; }
  #ilp .stats-foot { margin-top: 22px; font-size: 13px; line-height: 1.65; }
}
@media(max-width:400px){
  #ilp .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1px; }
  #ilp .stat { padding: 18px 14px; }
  #ilp .stat .num-val { font-size: 30px; }
  #ilp .stat .num-suffix { font-size: 15px; }
  #ilp .stat .lab { font-size: 12.5px; line-height: 1.35; }
}

/* --- PROBLEM/SOLUTION --- */
#ilp .split-item p { font-size: 14.5px; line-height: 1.55; color: var(--ink-700); }

/* --- PROCESS RAIL: re-assert at #ilp specificity --- */
#ilp .process { background: var(--bg); }
#ilp .process-rail { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; position: relative; }
#ilp .process-rail::before { content: ""; position: absolute; left: 80px; right: 80px; top: 80px; height: 1px; background: var(--accent-soft); z-index: 1; }
#ilp .process-step { text-align: center; position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; }
#ilp .process-step .step-art { width: 160px; height: 160px; border-radius: 18px; background: #fff; border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 14px rgba(8,94,62,.06); position: relative; overflow: hidden; }
#ilp .process-step .step-art svg { width: 100%; height: 100%; display: block; }
#ilp .process-step .step-num { position: absolute; top: 10px; left: 10px; font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Consolas, monospace; font-size: 10px; letter-spacing: .14em; color: var(--ink-500); background: var(--bg); padding: 3px 8px; border-radius: 4px; font-weight: 500; z-index: 2; }
#ilp .process-step h4 { font-family: "Inter Tight", sans-serif; font-size: 15px; color: var(--ink-900); margin-top: 20px; font-weight: 600; }
#ilp .process-step p { font-size: 13px; line-height: 1.5; color: var(--ink-500); max-width: 220px; margin: 6px auto 0; }

@media(max-width:880px){
  #ilp .process-rail { grid-template-columns: 1fr 1fr; }
  #ilp .process-rail::before { display: none; }
}
@media(max-width:560px){
  #ilp .process-rail { grid-template-columns: 1fr; }
  #ilp .process-step .step-art { width: 140px; height: 140px; }
  #ilp .process-step h4 { font-size: 14px; margin-top: 16px; }
  #ilp .process-step p { font-size: 14.5px; }
}

/* --- PERSONAS --- */
#ilp .persona-card p { font-size: 14.5px; line-height: 1.55; color: var(--ink-700); }

/* --- FEATURES --- */
#ilp .feat p { font-size: 14px; line-height: 1.55; color: var(--ink-700); margin-top: 10px; }
#ilp .zilm-callout p { font-size: 14.5px; line-height: 1.55; color: var(--ink-700); }

/* --- TIMELINE --- */
#ilp .tl-step p { font-size: 13.5px; line-height: 1.5; color: var(--ink-500); margin-top: 8px; }

/* --- TESTIMONIALS --- */
#ilp .testi-card blockquote { font-size: 20px; line-height: 1.35; color: var(--primary); margin: 0; }

/* --- FAQ --- */
#ilp details p { font-size: 14.5px; line-height: 1.6; color: var(--ink-700); margin-top: 14px; }

/* --- CTA BAND --- */
#ilp .cta-inner p { font-size: 16px; line-height: 1.55; color: rgba(255,255,255,.75); margin-top: 20px; }

/* --- SECTION HEADS --- */
#ilp .sec-head p { font-size: 16px; line-height: 1.55; color: var(--ink-500); margin-top: 14px; }

/* --- Mobile adjustments — same selectors, ID specificity carries through --- */
@media(max-width:980px){
  #ilp .hero h1 { font-size: 48px !important; line-height: 1.06 !important; }
  #ilp section.hero { padding: 56px 0 64px; }
  #ilp section.sec  { padding: 72px 0; }
}
@media(max-width:780px){
  #ilp .hero h1 { font-size: 42px !important; line-height: 1.07 !important; }
  #ilp .hero p.lede { font-size: 18px; margin-top: 18px; }
  #ilp .hero-bullets li { font-size: 16.5px; }
  #ilp .hero-disclaimer { font-size: 13px; margin-top: 18px; }
  #ilp section.hero { padding: 40px 0 56px; }
  #ilp section.sec  { padding: 56px 0; }
}
@media(max-width:560px){
  #ilp .hero h1 { font-size: 38px !important; line-height: 1.08 !important; }
  #ilp .hero p.lede { font-size: 17px; margin-top: 16px; max-width: none; }
  #ilp .hero-bullets li { font-size: 15.5px; gap: 8px; }
  #ilp .hero-disclaimer { font-size: 12.5px; }
  #ilp .hero-logos img { height: 36px; }
  #ilp section.hero { padding: 28px 0 44px; }
  #ilp section.sec  { padding: 44px 0; }
}
@media(max-width:400px){
  #ilp .hero h1 { font-size: 32px !important; line-height: 1.08 !important; }
  #ilp .hero-logos img { height: 30px; }
}

/* v1.14.2 — Hero external-SVG wrapper.
 * Mirrors the original `.hero-art svg` positioning so the <object> fills
 * the same 1:1 aspect-ratio container as the legacy inline-SVG path. */
.hero-art .hero-animation-wrapper {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    margin: 0;
}
.hero-art .hero-animation-wrapper object {
    width: 100%;
    height: 100%;
    display: block;
    pointer-events: none;
}
