:root{
  --ink:#071B3D; --ink2:#0E2A55; --paper:#F7F5F0; --gold:#C98A20; --slate:#53657C;
  --warm:#C77438; --cool:#6D7FA3;
  --disp:'Fraunces',Georgia,serif; --body:'Source Sans 3',system-ui,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:#22324a;background:var(--paper);font-size:17px;line-height:1.6}
.wrap{width:100%;max-width:1080px;margin:0 auto;padding:0 22px}
h1,h2,h3{font-family:var(--disp);color:var(--ink);line-height:1.12}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem);font-weight:600;margin:.5rem 0 1.2rem}
.eyebrow{font-size:12.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.eyebrow.light{color:#E4B566}
.btn{display:inline-block;font-weight:800;font-size:15.5px;padding:13px 26px;border-radius:100px;text-decoration:none;transition:transform .15s,box-shadow .2s}
.btn.gold{background:var(--gold);color:#fff}
.btn.gold:hover{transform:translateY(-1px);box-shadow:0 12px 28px -12px rgba(201,138,32,.7)}
.btn.ghost{border:1.5px solid rgba(255,255,255,.55);color:#fff}
.btn.ghost:hover{border-color:#fff}

/* header */
.hd{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid #E7E2D6}
.hd-in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--disp);font-weight:700;font-size:21px;color:var(--ink);text-decoration:none}
.brand-word{color:var(--ink)}
.brand-word .brand-gold{color:var(--gold)}
.nav{display:flex;align-items:center;gap:20px}
.nav a{color:#3A4D63;text-decoration:none;font-size:14px;font-weight:700}
.nav a:hover{color:var(--ink)}
.nav-cta{border:1.5px solid var(--gold);border-radius:100px;padding:8px 16px;color:var(--ink) !important;background:#fff}
@media(max-width:840px){.nav a:not(.nav-cta){display:none}}

/* hero */
.hero{background:linear-gradient(178deg,var(--ink) 0%,var(--ink2) 100%);color:#fff;padding:92px 0 82px;text-align:center}
.hero-wrap{max-width:980px}
.hero-kicker{display:block;font-size:12.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#E4B566;margin-bottom:18px}
.hero h1{color:#fff;font-size:clamp(2.35rem,5.5vw,4.25rem);font-weight:600;letter-spacing:-.02em}
.hero-copy{max-width:820px;margin:20px auto 0}
.hero-copy p{margin:0 auto 15px;color:rgba(255,255,255,.84);font-size:clamp(1.02rem,1.65vw,1.17rem)}
.hero-sub{font-size:clamp(1.15rem,2vw,1.35rem)!important;color:#fff!important;max-width:62ch}
.need-lines{display:grid;gap:8px;max-width:720px;margin:28px auto 22px;padding:24px 28px;border:1px solid rgba(255,255,255,.18);border-radius:24px;background:rgba(255,255,255,.06);box-shadow:0 25px 60px -42px rgba(0,0,0,.9)}
.need-lines div{font-family:var(--disp);font-size:clamp(1.08rem,2vw,1.35rem);color:#fff;line-height:1.22}
.hero-close{font-weight:800;color:#E4B566;font-size:1.08rem;margin:4px auto 26px}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}

/* emblem */
.emblem{max-width:760px;margin:34px auto 30px}
.emblem svg{width:100%;height:auto;display:block}
.strand{stroke-width:2.5;stroke-linecap:round}
.strand.warm{stroke:var(--warm);stroke-dasharray:640;stroke-dashoffset:640;animation:draw 1.6s ease forwards .2s}
.strand.cool{stroke:var(--cool);stroke-dasharray:640;stroke-dashoffset:640;animation:draw 1.6s ease forwards .5s}
@keyframes draw{to{stroke-dashoffset:0}}
.node{fill:var(--gold);opacity:0;animation:pop .5s ease forwards 1.7s}
@keyframes pop{from{opacity:0;r:2}to{opacity:1;r:7}}
.s-label{font-family:var(--body);font-size:15px;font-weight:700}
.warm-t{fill:#E8A468}.cool-t{fill:#A9B8D8}
.n-label{font-family:var(--body);font-size:15px;font-weight:800;fill:#fff}
@media(prefers-reduced-motion:reduce){.strand{animation:none;stroke-dashoffset:0}.node{animation:none;opacity:1}}

/* thesis */
.thesis{padding:84px 0}
.two{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.thesis-body p{margin-bottom:1rem;font-size:1.08rem;color:#33465f}
@media(max-width:800px){.two{grid-template-columns:1fr}}

/* flagship */
.flagship{background:var(--ink);padding:76px 0 84px}
.flag-card{margin-top:18px;background:#fff;border-radius:24px;padding:44px 48px;box-shadow:0 30px 80px -30px rgba(0,0,0,.5)}
.flag-copy h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:.7rem}
.gold-4{color:var(--gold)}
.flag-lead{font-size:1.12rem;color:#33465f;max-width:62ch;margin-bottom:14px}
.flag-loop{font-weight:800;font-size:1.02rem;margin-bottom:14px}
.e.guide{color:#0B49B5}.e.plan{color:#C98610}.e.act{color:#A8641E}.e.learn{color:#6136B0}
.flag-line{color:#53657C;font-size:1rem;max-width:66ch;margin-bottom:22px}
@media(max-width:640px){.flag-card{padding:30px 24px}}

/* values */
.values{padding:84px 0;background:#fff;border-top:1px solid #ECE6DA;border-bottom:1px solid #ECE6DA}
.values-head{margin-bottom:30px;text-align:left}
.values-head h2{max-width:14em;margin:.45rem 0 0;font-size:clamp(1.85rem,3.3vw,2.55rem)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.value-card{background:var(--paper);border:1px solid #E7E2D6;border-radius:18px;padding:24px 24px 26px;min-height:176px;box-shadow:0 16px 36px -30px rgba(7,27,61,.45)}
.value-num{display:block;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.value-card h3{font-size:1.22rem;font-weight:600;margin-bottom:.55rem}
.value-card p{font-size:16px;color:#4a5c74;line-height:1.45}
.value-card-wide{grid-column:span 3;min-height:0;background:#FBF8F1;border-left:5px solid var(--gold)}
.value-card-wide p{max-width:50em}
@media(max-width:920px){.values-grid{grid-template-columns:repeat(2,1fr)}.value-card-wide{grid-column:span 2}}
@media(max-width:640px){.values-grid{grid-template-columns:1fr}.value-card{min-height:0}.value-card-wide{grid-column:span 1}}

/* founders */
.founders{padding:10px 0 84px}
.f-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:12px}
.f-card{display:flex;gap:20px;background:#fff;border:1px solid #E7E2D6;border-radius:18px;padding:24px}
.f-card img{width:92px;height:92px;border-radius:50%;object-fit:cover;flex:none}
.f-card h3{font-size:1.25rem;font-weight:600}
.f-role{font-size:13px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--gold);margin:4px 0 8px}
.f-card p{font-size:14.5px;color:#4a5c74}
@media(max-width:760px){.f-grid{grid-template-columns:1fr}}

/* contact */
.contact{background:linear-gradient(178deg,var(--ink2),var(--ink));color:#fff;padding:76px 0;text-align:center}
.contact h2{color:#fff}
.contact p{color:rgba(255,255,255,.85);max-width:56ch;margin:0 auto 26px}

/* footer */
.ft{background:#04122B;color:rgba(255,255,255,.8);padding:34px 0}
.ft-in{display:flex;justify-content:space-between;gap:26px;flex-wrap:wrap;font-size:14px}
.ft strong{font-family:var(--disp);font-size:17px;color:#fff}
.gold-t{color:var(--gold)}
.ft-legal{text-align:right}
.ft-marks{font-size:11px;color:rgba(255,255,255,.55)}
@media(max-width:640px){.ft-in{flex-direction:column}.ft-legal{text-align:left}}

a:focus-visible,.btn:focus-visible{outline:3px solid var(--gold);outline-offset:2px}

.brand{display:flex;align-items:center;gap:10px}
.brand-logo{height:40px;width:40px;object-fit:contain}
.ft-brandrow{display:flex;align-items:center;gap:12px}


/* expansion sections */
.juvenile{background:#fff;padding:86px 0 92px;border-top:1px solid #ECE6DA;border-bottom:1px solid #ECE6DA}
.jj-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:stretch;margin-bottom:26px}
.jj-title{padding-right:20px}
.jj-lead{font-family:var(--disp);font-size:clamp(1.35rem,2.7vw,2rem);line-height:1.18;color:var(--ink);max-width:15.5em;margin-top:14px}
.jj-note{background:var(--ink);color:#fff;border-radius:22px;padding:30px 32px;box-shadow:0 24px 60px -42px rgba(0,0,0,.8)}
.jj-note h3{color:#fff;font-size:1.35rem;margin-bottom:10px}
.jj-note p{color:rgba(255,255,255,.82);font-size:1rem;line-height:1.55}
.jj-focus{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:24px}
.jj-card{background:var(--paper);border:1px solid #E7E2D6;border-radius:18px;padding:23px 22px 25px;min-height:218px;position:relative}
.jj-num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:#fff;color:var(--gold);font-weight:800;font-size:13px;margin-bottom:18px;border:1px solid #E7E2D6}
.jj-card h3{font-size:1.14rem;font-weight:600;margin-bottom:.55rem}
.jj-card p{font-size:15px;color:#4a5c74;line-height:1.48}
.jj-outcome{margin-top:20px;background:#FBF8F1;border-left:5px solid var(--gold);border-radius:16px;padding:22px 26px;display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:center}
.jj-outcome span{font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.jj-outcome p{font-family:var(--disp);font-size:clamp(1.18rem,2.2vw,1.55rem);line-height:1.22;color:var(--ink)}
.horizon{background:var(--paper);padding:84px 0 88px}
.beyond-head{margin-bottom:26px}
.use-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.use-card{background:#fff;border:1px solid #E7E2D6;border-radius:18px;padding:26px 28px}
.horizon .use-card{background:#fff}
.use-card h3{font-size:1.18rem;font-weight:600;margin-bottom:.55rem}
.use-card p{font-size:15.5px;color:#4a5c74}
@media(max-width:980px){.nav{gap:14px}.nav a{font-size:13.2px}.nav-cta{padding:7px 12px}.jj-focus{grid-template-columns:repeat(2,1fr)}}
@media(max-width:960px){.nav a:not(.nav-cta){display:none}}
@media(max-width:760px){.jj-hero{grid-template-columns:1fr}.jj-title{padding-right:0}.jj-focus{grid-template-columns:1fr}.jj-card{min-height:0}.jj-outcome{grid-template-columns:1fr;gap:8px}}

/* production fixes requested */
.hd-in{height:82px}
.brand{font-size:25px;letter-spacing:.01em;gap:14px;white-space:nowrap}
.brand-logo{height:58px;width:58px;border-radius:12px;padding:2px}
.ft-logo{height:58px;width:58px;border-radius:12px;padding:3px}
.jj-hero{display:block;margin-bottom:30px}
.jj-title{padding-right:0;text-align:left}
.jj-lead{max-width:24em;margin-top:14px}
.jj-subline{max-width:54em;margin-top:18px;color:#4a5c74;font-size:1.08rem;line-height:1.5}
.jj-note{display:none!important}
.founders{padding:72px 0 84px}
.f-grid{margin-top:0}
@media(max-width:640px){.hd-in{height:74px}.brand{font-size:21px;gap:10px}.brand-logo{height:50px;width:50px}}

/* final polish for visible logo and juvenile justice section */
.juvenile{padding:78px 0 86px}
.jj-hero{margin-bottom:32px}
.jj-focus{gap:18px}
.jj-card{min-height:198px;padding:26px 24px 28px}
.jj-card h3{font-size:1.18rem}
.jj-outcome{margin-top:26px}
.f-card{align-items:flex-start}


/* final requested refinements */
.jj-hero{margin-bottom:32px}
.jj-title,
.jj-title h2,
.jj-title p,
.jj-lead,
.jj-subline,
.jj-card,
.jj-card h3,
.jj-card p,
.jj-outcome,
.jj-outcome p{
  text-align:left;
}
.jj-lead{
  max-width:28em;
  margin-left:0;
  margin-right:0;
}
.jj-subline{
  max-width:58em;
  margin-left:0;
  margin-right:0;
}
.hd-in{
  height:86px;
}
.brand{
  font-size:23px;
  gap:12px;
}
.brand-logo{
  height:58px;
  width:58px;
}

@media(max-width:640px){
  .hd-in{height:82px}
  .brand{font-size:22px;gap:12px}
  .brand-logo{height:60px;width:60px}
  .ft-logo{height:60px;width:60px}
}

/* refined header: white banner, navy text, mark sits directly on white */
@media(max-width:900px){.nav a:not(.nav-cta){display:none}}
