/* Pioneer Federal Group — pioneerfedgroup.com
   Palette: Navy #0C2340 · Mid Navy #1B3A5C · Gold #C9A84C · Off-White #F5F2EA */

:root{
  --navy:#0C2340;
  --navy-2:#1B3A5C;
  --gold:#C9A84C;
  --gold-soft:#E3CD8B;
  --paper:#F5F2EA;
  --ink:#22303F;
  --muted:#5C6B7A;
  --line:rgba(12,35,64,.14);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Public Sans",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:17px;line-height:1.65;color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}

h1,h2,h3,.display{font-family:"Marcellus",Georgia,serif;font-weight:400;color:var(--navy)}
.eyebrow{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
}
.eyebrow.dark{color:var(--navy-2)}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;background:var(--navy);
  border-bottom:1px solid rgba(201,168,76,.35);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:38px;height:38px;flex:none}
.brand .name{color:#fff;font-family:"Marcellus",serif;font-size:18px;letter-spacing:.04em;line-height:1.1}
.brand .name small{display:block;font-family:"Public Sans",sans-serif;font-size:9.5px;letter-spacing:.28em;color:var(--gold);text-transform:uppercase}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{color:rgba(255,255,255,.78);font-size:14px;letter-spacing:.06em;text-transform:uppercase;padding:6px 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:var(--gold);border-color:var(--gold)}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:26px;cursor:pointer}

/* ---------- hero ---------- */
.hero{position:relative;background:linear-gradient(160deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;overflow:hidden}
.hero .wrap{position:relative;padding:96px 24px 110px;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero h1{color:#fff;font-size:clamp(34px,5vw,56px);line-height:1.12;margin:14px 0 20px}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero p{color:rgba(255,255,255,.82);max-width:54ch;font-size:18px}
.hero .compass{width:min(360px,80%);margin:0 auto;opacity:.95}
.hero-cta{margin-top:34px;display:flex;gap:16px;flex-wrap:wrap}
.btn{
  display:inline-block;padding:14px 28px;font-size:14px;letter-spacing:.12em;text-transform:uppercase;
  border:1px solid var(--gold);transition:background .2s,color .2s;
}
.btn.solid{background:var(--gold);color:var(--navy);font-weight:600}
.btn.solid:hover{background:var(--gold-soft)}
.btn.ghost{color:var(--gold)}
.btn.ghost:hover{background:rgba(201,168,76,.12)}
.meridian{position:absolute;left:0;right:0;bottom:0;height:4px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}

/* small page hero (interior pages) */
.page-hero{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff;position:relative}
.page-hero .wrap{padding:72px 24px}
.page-hero h1{color:#fff;font-size:clamp(30px,4vw,44px);margin-top:12px}
.page-hero p{color:rgba(255,255,255,.8);max-width:62ch;margin-top:14px;font-size:17px}

/* ---------- sections ---------- */
.section{padding:84px 0}
.section.alt{background:#fff}
.section-head{max-width:62ch;margin-bottom:46px}
.section-head h2{font-size:clamp(26px,3.4vw,38px);margin-top:10px}
.section-head p{color:var(--muted);margin-top:12px}

/* status banner */
.status{background:var(--navy);color:rgba(255,255,255,.9)}
.status .wrap{display:flex;gap:14px;align-items:center;justify-content:center;padding:13px 24px;font-size:13.5px;letter-spacing:.04em;text-align:center;flex-wrap:wrap}
.status .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex:none}

/* capability grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{
  background:#fff;border:1px solid var(--line);padding:30px 26px 28px;position:relative;
  transition:transform .2s,box-shadow .2s;
}
.section.alt .card{background:var(--paper)}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(12,35,64,.10)}
.card .naics{font-size:11.5px;letter-spacing:.18em;color:var(--gold);font-weight:700;text-transform:uppercase}
.card h3{font-size:20px;margin:10px 0 10px}
.card p{font-size:15px;color:var(--muted)}
.card::before{content:"";position:absolute;top:0;left:0;width:44px;height:3px;background:var(--gold)}

/* two-column feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split .compass-line{width:min(320px,90%);margin:0 auto}
.list{margin-top:18px;display:grid;gap:14px}
.list li{list-style:none;display:flex;gap:14px;align-items:flex-start;font-size:16px}
.list .tick{flex:none;width:20px;height:20px;margin-top:3px}

/* leadership */
.people{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.person{background:var(--navy);border:1px solid rgba(201,168,76,.25);padding:34px 30px;position:relative}
.person::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--gold),transparent)}
.person .role{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:700}
.person h3{font-size:24px;margin:8px 0 4px;color:#fff}
.person .sub{font-size:13.5px;color:rgba(255,255,255,.5);letter-spacing:.04em;margin-bottom:14px}
.person p{font-size:15.5px;color:rgba(255,255,255,.75)}

/* values strip */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;text-align:left}
.value h3{font-size:18px;margin-bottom:8px}
.value p{font-size:15px;color:var(--muted)}

/* company data block */
.data-block{background:var(--navy);color:#fff;padding:40px 36px;border-top:3px solid var(--gold)}
.data-block h3{color:var(--gold);font-size:14px;letter-spacing:.2em;text-transform:uppercase;font-family:"Public Sans",sans-serif;font-weight:700;margin-bottom:22px}
.data-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 36px}
.data-grid div{font-size:15px}
.data-grid dt{color:rgba(255,255,255,.55);font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px}
.data-grid dd{margin:0}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.contact-card{background:#fff;border:1px solid var(--line);padding:36px}
.contact-card h3{font-size:20px;margin-bottom:18px}
.contact-card .row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--line)}
.contact-card .row:first-of-type{border-top:0}
.contact-card .row svg{flex:none;width:20px;height:20px;margin-top:4px}
.contact-card .row b{display:block;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:2px}
.contact-card .row a:hover{color:var(--navy-2);text-decoration:underline}

/* footer */
.footer{background:var(--navy);color:rgba(255,255,255,.7);margin-top:0}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:58px 0 44px}
.footer h4{color:#fff;font-size:13px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px;font-family:"Public Sans",sans-serif}
.footer a{color:rgba(255,255,255,.7);display:block;padding:4px 0;font-size:14.5px}
.footer a:hover{color:var(--gold)}
.footer .brandline{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.footer .brandline .mark{width:34px;height:34px}
.footer .brandline span{font-family:"Marcellus",serif;color:#fff;font-size:17px}
.footer p{font-size:14px;max-width:40ch}
.footer .legal{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;font-size:12.5px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer .legal .gold{color:var(--gold)}

/* trust bar */
.trust-bar{background:var(--navy);border-bottom:1px solid rgba(201,168,76,.2)}
.trust-bar .wrap{display:flex;gap:10px;align-items:center;justify-content:center;padding:14px 24px;flex-wrap:wrap}
.trust-chip{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.85);font-size:13px;letter-spacing:.05em}
.trust-chip svg{width:15px;height:15px;flex:none}
.trust-divider{color:rgba(201,168,76,.45);font-size:15px;line-height:1}

/* cta strip */
.cta-strip{background:var(--navy-2);padding:72px 0;border-top:3px solid var(--gold)}
.cta-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta-strip h2{color:#fff;font-size:clamp(24px,3vw,34px);margin-bottom:12px}
.cta-strip p{color:rgba(255,255,255,.75);max-width:58ch;font-size:16px}
.cta-strip .btn{flex:none;white-space:nowrap}

/* ---------- responsive ---------- */
@media (max-width:880px){
  .hero .wrap{grid-template-columns:1fr;padding:64px 24px 78px}
  .hero .compass{display:none}
  .grid,.values{grid-template-columns:1fr 1fr}
  .split,.people,.contact-grid,.cta-strip-inner{grid-template-columns:1fr}
  .cta-strip-inner{flex-direction:column;align-items:flex-start}
  .footer .top{grid-template-columns:1fr;gap:28px}
  .nav-links{
    position:fixed;inset:72px 0 auto 0;background:var(--navy);flex-direction:column;gap:0;
    padding:10px 24px 22px;display:none;border-bottom:1px solid rgba(201,168,76,.35);
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 0;width:100%;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav-toggle{display:block}
}
@media (max-width:560px){
  .grid,.values,.data-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
