*,*::before,*::after{box-sizing:border-box}
:root{
  --navy:#231f20;--navy-1:#2c2726;--ink:#231f20;--slate:#5b6b7d;--muted:#8a98a8;
  --orange:#ff8700;--ember:#e57700;--orange-soft:#ffeede;
  --mist:#f4f6f9;--card:#fff;--line:#e4e9ef;--line-2:#d3dbe5;--ok:#1f9d57;
  --r:14px;--r-lg:22px;--maxw:1180px;
  --fd:'Archivo','Helvetica Neue',system-ui,sans-serif;
  --fb:'Inter',system-ui,-apple-system,sans-serif;
  --fm:'IBM Plex Mono',ui-monospace,monospace;
}
html{scroll-behavior:smooth}
body{margin:0;background:var(--card);color:var(--ink);font-family:var(--fb);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
.hpf-ink{fill:currentColor}.hpf-bolt{fill:var(--orange)}
a{color:inherit;text-decoration:none}img,svg{display:block}
h1,h2,h3{font-family:var(--fd);font-weight:800;letter-spacing:-.025em;line-height:1.04;margin:0;color:var(--ink)}
p{margin:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}
.eyebrow{font-family:var(--fm);font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ember)}
.num{font-family:var(--fm);font-variant-numeric:tabular-nums}
.ph{color:var(--ember);font-family:var(--fm);font-size:.94em}
a.reg-link{text-decoration:underline;text-underline-offset:2px}a.reg-link:hover{color:var(--orange)}

.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--fd);font-weight:700;font-size:15.5px;letter-spacing:-.01em;
  padding:.86em 1.35em;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:transform .15s,background .15s,box-shadow .2s,color .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--orange);color:#231f20}
.btn-primary:hover{background:var(--ember);color:#fff;box-shadow:0 10px 24px -10px rgba(229,119,0,.85)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--navy);background:var(--mist)}
.btn-ghost.on-navy{color:#fff;border-color:rgba(255,255,255,.34)}
.btn-ghost.on-navy:hover{background:rgba(255,255,255,.09);border-color:#fff}
.btn-dark{background:var(--navy);color:#fff}.btn-dark:hover{background:#15110f}
.arr{transition:transform .15s}.btn:hover .arr{transform:translateX(3px)}

.trustbar{background:var(--navy);color:#c7d2df;font-size:12.5px}
.trustbar .wrap{display:flex;gap:1.2em;align-items:center;justify-content:center;min-height:38px;flex-wrap:wrap;text-align:center}
.trustbar b{color:#fff;font-weight:600}.trustbar .dot{color:var(--orange)}

header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;gap:18px;min-height:72px}
.logo-word{height:30px;width:auto;color:var(--ink)}
.brand{display:flex;align-items:center}
nav.main{display:flex;align-items:center;gap:26px;margin-left:10px}
nav.main a.nl{font-size:15px;color:var(--slate);font-weight:500;transition:color .15s}
nav.main a.nl:hover{color:var(--orange)}
.header-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.menu-btn{display:none}
.mobile-menu{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
  box-shadow:0 22px 34px -22px rgba(35,31,32,.5);padding:8px clamp(20px,5vw,40px) 20px;flex-direction:column}
.mobile-menu.open{display:flex}
.mobile-menu a.nl{padding:14px 2px;font-size:16px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line)}
.mobile-menu a.nl:last-of-type{border-bottom:0}
.mobile-menu .btn{margin-top:10px;justify-content:center;width:100%}

/* ---------- WHO WE ARE hero (image-ready) ---------- */
/* To use a photo: set --hero-img on .who, e.g. style="--hero-img:url('/assets/hero.jpg')" */
.who{position:relative;background:var(--navy);color:#fff;overflow:hidden;
  background-image:linear-gradient(100deg,rgba(18,15,15,.94) 0%,rgba(35,31,32,.80) 42%,rgba(35,31,32,.45) 100%),var(--hero-img,none);
  background-size:cover;background-position:center right}
.who::after{content:"";position:absolute;right:-40px;bottom:-30px;width:560px;height:360px;opacity:.10;pointer-events:none;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='560' height='360' fill='none' stroke='white' stroke-width='2'><path d='M50 240 L210 100 L370 240'/><path d='M90 220 V320 H330 V220'/><path d='M180 320 V250 H260 V320'/><path d='M320 270 L440 180 L560 270'/><path d='M350 255 V340 H520 V255'/></svg>") no-repeat}
.who .wrap{position:relative;padding-top:clamp(64px,11vw,128px);padding-bottom:clamp(64px,11vw,128px);max-width:980px}
.who .eyebrow{color:var(--orange);font-size:18px}
.who h1{color:#fff;font-size:clamp(40px,6vw,72px);max-width:16ch;margin-top:16px}
.who h1 .hl{color:var(--orange)}
.who p.lede{margin-top:18px;font-size:clamp(17px,1.7vw,21px);color:#d7dee6;max-width:60ch;line-height:1.55}
.who .cta{margin-top:32px;display:flex;gap:13px;flex-wrap:wrap}
.who .meta{margin-top:30px;display:flex;gap:1.4em;flex-wrap:wrap;font-family:var(--fm);font-size:12.5px;color:#9fb0c1}
.who .meta b{color:#fff;font-weight:600}.who .meta .dot{color:#5a504c}

/* ---------- sections ---------- */
.sec,.who{scroll-margin-top:80px}
.sec{padding:clamp(60px,8vw,100px) 0}
.sec.mist{background:var(--mist)}
.sec-head{max-width:62ch;margin-bottom:clamp(30px,5vw,48px)}
.sec-head.ctr{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(30px,4vw,46px);margin-top:13px}
.sec-head p{margin-top:14px;color:var(--slate);font-size:18px}
.sec-head .eyebrow{color:var(--ember)}

/* ---------- partners ---------- */
.partners-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:6px}
.plogo{height:110px;border:1px solid var(--line);border-radius:12px;display:flex;align-items:center;justify-content:center;background:#fff;padding:18px 22px;overflow:hidden}
.plogo img{display:block;max-width:100%;max-height:64px;width:auto;height:auto;object-fit:contain;transition:transform .2s}
.plogo:hover img{transform:scale(1.04)}

/* ---------- advantage (3 Ps) ---------- */
.adv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;transition:transform .2s,box-shadow .2s,border-color .2s;scroll-margin-top:96px}
.pcard:hover{transform:translateY(-4px);box-shadow:0 26px 44px -28px rgba(35,31,32,.45);border-color:var(--line-2)}
.pcard .pn{font-family:var(--fm);font-size:12px;color:var(--ember);letter-spacing:.1em}
.picon{width:52px;height:52px;border-radius:50%;background:var(--orange-soft);display:grid;place-items:center;margin:0 0 18px;color:var(--ember)}
.picon svg{width:25px;height:25px}
.pcard h3{font-size:22px}
.pcard>p{margin-top:10px;font-size:15px;color:var(--slate);line-height:1.55}
.plist{list-style:none;margin:16px 0 0;padding:0;display:grid;gap:9px}
.plist li{display:flex;gap:9px;align-items:flex-start;font-size:14.5px;color:var(--ink)}
.plist svg{flex:none;width:17px;height:17px;margin-top:3px;color:var(--ok)}
.pcard .fineprint{margin-top:16px;font-size:14.5px;color:var(--ink);line-height:1.55}
.pcard .fineprint a{color:var(--ember);font-weight:600}.pcard .fineprint a:hover{text-decoration:underline}

/* ---------- how it works (3 steps) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;position:relative}
.step .sn{width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;font-family:var(--fm);font-weight:600;font-size:14px;display:grid;place-items:center;margin-bottom:16px}
.step h3{font-size:20px}
.step p{margin-top:9px;font-size:14.5px;color:var(--slate);line-height:1.55}
.how-note{margin-top:26px;text-align:center;font-size:14.5px;color:var(--slate)}
.how-note b{color:var(--ink)}

/* ---------- cta ---------- */
.cta-band{background:var(--orange)}
.cta-band .wrap{padding:clamp(54px,7vw,82px) clamp(20px,5vw,40px);text-align:center}
.cta-band h2{font-size:clamp(30px,4.4vw,50px);color:#231f20;max-width:20ch;margin:0 auto}
.cta-band p{margin:16px auto 0;max-width:50ch;color:#6a4413;font-size:18px}
.cta-band .row{margin-top:28px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
footer.site{background:var(--navy);color:#9fb0c1;font-size:15px;padding:62px 0 36px}
footer .top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;padding-bottom:32px;border-bottom:1px solid #3a3432}
.logo-word.foot{height:26px;color:#fff}
footer .blurb{margin-top:15px;max-width:36ch;line-height:1.6;color:#8497a8;font-size:15px}
footer .contact{margin-top:16px;font-size:14.5px;line-height:1.7;color:#8497a8}
footer .contact b{color:#c7d2df}
footer h4{font-family:var(--fd);color:#fff;font-size:13.5px;letter-spacing:.05em;text-transform:uppercase;margin:0 0 13px}
footer ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
footer ul a{color:#9fb0c1;font-size:15px}footer ul a:hover{color:var(--orange)}
footer .legal{margin-top:28px;font-size:13.5px;line-height:1.7;color:#8497a8}
footer .legal a{color:#c7d2df;text-decoration:underline}footer .legal a:hover{color:var(--orange)}
footer .copy{margin-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:#73869a;font-family:var(--fm)}

.rv{opacity:0;transform:translateY(18px);transition:opacity .6s,transform .6s}.rv.in{opacity:1;transform:none}

/* ---------- programs / document page ---------- */
.page-hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.page-hero .wrap{padding:clamp(48px,7vw,88px) clamp(20px,5vw,40px) clamp(40px,6vw,64px)}
.page-hero .eyebrow{color:var(--orange);font-size:18px}
.page-hero h1{color:#fff;font-size:clamp(34px,5vw,58px);margin-top:14px;max-width:20ch}
.page-hero p{margin-top:16px;color:#d7dee6;font-size:clamp(16px,1.6vw,19px);max-width:62ch;line-height:1.55}
.page-hero .updated{margin-top:16px;font-family:var(--fm);font-size:12.5px;letter-spacing:.03em;color:#9fb0c1;max-width:none}
.doc{max-width:780px;margin:0 auto}
.doc>*:first-child{margin-top:0}
.doc h2{font-size:clamp(22px,2.6vw,30px);margin-top:clamp(38px,5vw,56px)}
.doc h3{font-size:19px;margin-top:32px}
.doc p{margin-top:12px;color:var(--slate);line-height:1.65;font-size:16px}
.doc p.lead{color:var(--ink);font-size:clamp(17px,1.8vw,20px);font-weight:500;line-height:1.5}
.doc ul{margin:14px 0 0;padding:0 0 0 1.3em;list-style:disc}
.doc ul li{font-size:15.5px;color:var(--ink);line-height:1.55;margin-top:9px;padding-left:.25em}
.doc ul li::marker{color:var(--ember)}
.doc ul ul{list-style:circle;margin:9px 0 0;padding-left:1.4em}
.doc .note{margin-top:14px;font-size:13px;color:var(--muted);line-height:1.55}
.doc .fineprint{margin-top:16px;font-size:14.5px;color:var(--ink);line-height:1.55}
.doc p a,.doc li a{color:var(--ember);text-decoration:underline;text-underline-offset:2px;font-weight:500}
.doc p a:hover,.doc li a:hover{color:var(--navy)}
.doc .prod{border-top:1px solid var(--line);padding-top:clamp(28px,4vw,44px)}
.doc .back-link{display:inline-flex;align-items:center;gap:.45em;margin-top:clamp(34px,5vw,52px);font-family:var(--fd);font-weight:700;color:var(--ember)}
.doc .back-link:hover{text-decoration:underline}
.doc-table{width:100%;border-collapse:collapse;margin:18px 0;font-size:15px}
.doc-table th,.doc-table td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top;color:var(--ink);line-height:1.5}
.doc-table thead th{background:var(--mist);font-family:var(--fd);font-weight:700}
.doc-table tbody th{background:var(--mist);font-weight:600;width:32%}
.doc-table a{color:var(--ember);font-weight:600}
@media(max-width:560px){.doc-table,.doc-table tbody,.doc-table tr,.doc-table th,.doc-table td{display:block;width:auto}.doc-table tbody th{border-bottom:0}}

@media(max-width:960px){
  .adv-grid,.steps{grid-template-columns:1fr}
  .partners-grid{grid-template-columns:repeat(3,1fr)}
  footer .top{grid-template-columns:1fr 1fr}
  nav.main{display:none}.header-cta .btn{display:none}
  .menu-btn{display:inline-flex;margin-left:auto;background:none;border:1.5px solid var(--line-2);border-radius:10px;padding:9px 11px;cursor:pointer}
  .menu-btn svg{width:22px;height:22px;color:var(--ink)}.header-cta{margin-left:auto}
}
@media(max-width:560px){
  body{font-size:16px}
  .who h1{font-size:clamp(28px,7vw,46px);max-width:14ch}
  .partners-grid{grid-template-columns:1fr 1fr}
  footer .top{grid-template-columns:1fr}
  .who .cta{flex-direction:column;align-items:stretch}
  .who .cta .btn{width:100%;justify-content:center}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}.rv{transition:none;opacity:1;transform:none}.btn,.pcard{transition:none}}
