/* =============================================================================
   FOOTHILLS — Design System v4
   Company-forward. Solid pine nav (no translucency). Crest identity.
   Pine + Carolina clay + warm paper · Fraunces + Inter
   ============================================================================= */

:root{
  --pine:#1f3d34; --pine-2:#2a5446; --pine-3:#16302a; --pine-deep:#13261f;
  --sage:#8ba596; --sage-2:#5f9181; --haze:#b8cabf;
  --clay:#c4722e; --clay-2:#d98a3d; --clay-soft:#e7a866;
  --paper:#f7f0e4; --paper-2:#efe6d6; --paper-3:#e9e0cf; --cream:#fbf6ec;
  --ink:#1b211d; --ink-soft:#3b463f; --muted:#5d6b62; --muted-2:#7e8a81;
  --line:#e0d6c4; --line-2:#d6cab4; --ok:#3a6e5d;
  --serif:'Fraunces', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, sans-serif;
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px; --r-pill:100px;
  --shadow-sm:0 1px 2px rgba(31,61,52,.06),0 1px 3px rgba(31,61,52,.05);
  --shadow-md:0 10px 30px rgba(31,61,52,.10);
  --shadow-lg:0 28px 70px rgba(20,40,33,.18);
  --maxw:1180px; --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);font-size:17px;line-height:1.65;color:var(--ink-soft);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--pine-2);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--clay)}
h1,h2,h3,h4{font-family:var(--serif);color:var(--pine);font-weight:600;line-height:1.08;letter-spacing:-.02em}
h1 em,h2 em,h3 em{font-style:italic;color:var(--clay);font-weight:600}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:760px;margin:0 auto}
.section{padding:104px 0}.section-sm{padding:64px 0}
.bg-paper{background:var(--paper)}.bg-paper2{background:var(--paper-2)}.bg-cream{background:var(--cream)}
.bg-pine{background:var(--pine);color:var(--paper)}
.bg-pine .lead,.bg-pine p{color:var(--haze)}
.bg-pine h1,.bg-pine h2,.bg-pine h3,.bg-pine h4{color:var(--paper)}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--clay);display:inline-block}
.bg-pine .eyebrow{color:var(--clay-2)}.bg-pine .eyebrow::before{background:var(--clay-2)}
.center .eyebrow{justify-content:center}
.display{font-family:var(--serif);font-weight:600;letter-spacing:-.025em;line-height:1.04}
.h-xl{font-size:clamp(2.6rem,5.4vw,4.2rem)}.h-lg{font-size:clamp(2rem,3.8vw,3rem)}.h-md{font-size:clamp(1.5rem,2.4vw,2rem)}
.lead{font-size:clamp(1.08rem,1.5vw,1.3rem);line-height:1.6;color:var(--muted)}
.muted{color:var(--muted)}.center{text-align:center}.maxc{max-width:680px}.center .maxc{margin:0 auto}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--sans);font-weight:600;font-size:1.02rem;padding:16px 30px;border-radius:var(--r-pill);border:1.6px solid transparent;cursor:pointer;transition:all .22s var(--ease);line-height:1}
.btn-primary{background:var(--clay);color:#fff;box-shadow:0 6px 18px rgba(196,114,46,.28)}
.btn-primary:hover{background:#b3651f;color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px rgba(196,114,46,.34)}
.btn-pine{background:var(--pine);color:var(--paper)}
.btn-pine:hover{background:var(--pine-3);color:var(--paper);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--pine);border-color:var(--line-2)}
.btn-ghost:hover{background:var(--pine);color:var(--paper);border-color:var(--pine)}
.bg-pine .btn-ghost,.hero .btn-ghost,.finalcta .btn-ghost{color:var(--paper);border-color:rgba(247,240,228,.32)}
.bg-pine .btn-ghost:hover,.hero .btn-ghost:hover,.finalcta .btn-ghost:hover{background:var(--paper);color:var(--pine);border-color:var(--paper)}
.btn-lg{padding:19px 38px;font-size:1.1rem}.btn-block{display:flex;width:100%}
.btn .arr{transition:transform .22s var(--ease)}.btn:hover .arr{transform:translateX(3px)}

.ridge{display:block;width:100%;height:54px;line-height:0}.ridge svg{width:100%;height:100%;display:block}

/* brand lockup */
.fh-lockup{display:inline-flex;align-items:center;gap:13px}
.fh-crest{flex:none}
.fh-words{display:flex;flex-direction:column;line-height:1}
.fh-name{font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:-.01em;color:var(--pine)}
.fh-name .t{color:var(--clay)}
.fh-tag{font-family:var(--sans);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);font-weight:600;margin-top:5px}
.on-pine .fh-name{color:var(--paper)}.on-pine .fh-name .t{color:var(--clay-2)}.on-pine .fh-tag{color:var(--haze)}

/* utility bar */
.util{background:#0f211b;color:#bcd0c5;font-size:13px}
.util .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:9px 28px;flex-wrap:wrap}
.util strong{color:var(--clay-2);font-weight:600}.util a{color:#cdddd3}.util a:hover{color:#fff}

/* ---------- NAV: SOLID pine, no translucency ---------- */
.nav{position:sticky;top:0;z-index:90;background:var(--pine-3);border-bottom:1px solid rgba(255,255,255,.08)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:80px;gap:24px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a.nl{font-size:1rem;font-weight:500;color:#d4e1d9;position:relative}
.nav-links a.nl:hover{color:#fff}
.nav-links a.nl::after{content:"";position:absolute;left:0;right:0;bottom:-28px;height:2px;background:var(--clay-2);transform:scaleX(0);transition:transform .22s var(--ease)}
.nav-links a.nl:hover::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav .btn{padding:11px 22px;font-size:.96rem}
.nav-chip{display:inline-flex;align-items:center;gap:9px;font-weight:600;color:#eef3ee}
.nav-chip .av{width:32px;height:32px;border-radius:50%;background:var(--clay);color:#fff;display:grid;place-items:center;font-weight:700;text-transform:uppercase;font-size:.85rem}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-burger span{width:24px;height:2px;background:var(--paper);border-radius:2px}

/* ---------- hero ---------- */
.hero{background:var(--pine);color:var(--paper);position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;min-height:580px}
.hero-l{padding:80px 56px 80px 0;display:flex;flex-direction:column;justify-content:center;max-width:620px;margin-left:auto;padding-left:28px}
.hero h1{font-size:clamp(2.6rem,4.7vw,3.9rem);color:var(--paper);margin-bottom:22px}
.hero h1 em{color:var(--clay-2)}
.hero-sub{font-size:clamp(1.08rem,1.5vw,1.28rem);color:#cfe0d6;line-height:1.6;margin-bottom:32px;max-width:490px}
.hero-cta{display:flex;gap:15px;flex-wrap:wrap;align-items:center}
.hero-micro{display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;font-size:.95rem;color:var(--haze)}
.hero-micro span{display:inline-flex;align-items:center;gap:8px}.hero-micro .ck{color:var(--clay-2);font-weight:700}
.hero-r{position:relative;background:#16302a}
.hero-r>img.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.hero-r .wash{position:absolute;inset:0;background:linear-gradient(100deg,var(--pine) 2%,rgba(31,61,52,.5) 26%,rgba(31,61,52,.04) 60%)}
.hero-pill{position:absolute;left:34px;bottom:34px;background:var(--paper);color:var(--pine);border-radius:var(--r-md);padding:14px 20px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-lg)}
.hero-pill .amt{font-family:var(--serif);font-weight:700;font-size:1.9rem;line-height:1}
.hero-pill small{display:block;color:var(--muted);font-size:11.5px;line-height:1.3;max-width:120px}
.hero-seal{position:absolute;right:30px;top:30px;width:92px;height:92px;filter:drop-shadow(0 10px 24px rgba(0,0,0,.3))}

/* trust band */
.band{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.band-item{display:flex;align-items:center;gap:14px;padding:30px 26px;border-right:1px solid var(--line)}
.band-item:last-child{border-right:0}
.band-item .bi{width:42px;height:42px;flex:none;border-radius:11px;background:var(--paper-2);color:var(--pine-2);display:grid;place-items:center}
.band-item .bt{font-family:var(--serif);font-weight:600;color:var(--pine);font-size:1.04rem;line-height:1.15}
.band-item .bs{font-size:.84rem;color:var(--muted)}

/* editorial split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative}
.split-media img{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-md)}
.split-media .frame{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line)}

.checks{list-style:none;display:grid;gap:15px;margin-top:8px}
.checks li{display:flex;gap:13px;align-items:flex-start;font-size:1.06rem;color:var(--ink-soft)}
.checks .ck{flex:none;width:24px;height:24px;border-radius:50%;background:var(--sage);color:var(--pine);display:grid;place-items:center;margin-top:2px;font-size:.8rem;font-weight:700}

.pricecard{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:38px;box-shadow:var(--shadow-md);text-align:center}
.pricecard .tier{font-size:.82rem;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;font-weight:600}
.pricecard .old{font-family:var(--serif);text-decoration:line-through;color:var(--muted-2);font-size:1.6rem}
.pricecard .vs{color:var(--muted);margin:10px 0}
.pricecard .big{font-family:var(--serif);font-weight:700;font-size:4rem;color:var(--pine);line-height:1}
.pricecard .note{font-size:.85rem;color:var(--muted);border-top:1px solid var(--line);margin-top:22px;padding-top:18px}

.cards{display:grid;gap:22px}.cards-3{grid-template-columns:repeat(3,1fr)}.cards-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;transition:all .25s var(--ease)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--line-2)}
.card .ci{width:50px;height:50px;border-radius:13px;background:var(--pine);color:var(--clay-2);display:grid;place-items:center;margin-bottom:20px}
.card h3{font-size:1.28rem;margin-bottom:9px}.card p{font-size:.99rem;color:var(--muted)}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.stat{text-align:center;padding:0 12px}
.stat .n{font-family:var(--serif);font-weight:600;font-size:clamp(2.6rem,4.6vw,3.4rem);color:var(--clay-2);line-height:1}
.stat .l{margin-top:10px;color:#cfe0d6;font-size:1rem}
.stat+.stat{border-left:1px solid rgba(255,255,255,.12)}

.pull{font-family:var(--serif);font-weight:500;font-size:clamp(1.5rem,2.8vw,2.2rem);line-height:1.3;color:var(--pine);letter-spacing:-.01em}
.bg-pine .pull{color:var(--paper)}.pull em{font-style:italic;color:var(--clay)}.bg-pine .pull em{color:var(--clay-2)}

.curri{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff}
.crow{display:flex;gap:18px;padding:22px 26px;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.crow .cn{font-family:var(--serif);font-weight:700;color:var(--clay);font-size:1.1rem;flex:none;width:30px}
.crow .ct{font-family:var(--serif);font-weight:600;color:var(--pine);font-size:1.08rem;line-height:1.2}
.crow .cd{font-size:.88rem;color:var(--muted);margin-top:3px}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.step{text-align:center;position:relative}
.step .sn{width:58px;height:58px;margin:0 auto 18px;border-radius:50%;background:var(--paper);border:1.5px solid var(--line-2);color:var(--clay);display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1.4rem}
.bg-pine .step .sn{background:var(--pine-3);border-color:var(--pine-2);color:var(--clay-2)}
.step h4{font-size:1.14rem;margin-bottom:7px}.step p{font-size:.93rem;color:var(--muted)}.bg-pine .step p{color:var(--haze)}

.faq{max-width:820px;margin:0 auto}.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:26px 0;font-family:var(--serif);font-weight:600;font-size:1.18rem;color:var(--pine);display:flex;justify-content:space-between;gap:18px;align-items:center}
.faq-q .pl{flex:none;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line-2);color:var(--clay);display:grid;place-items:center;font-size:1.2rem;transition:transform .25s var(--ease)}
.faq-item.open .faq-q .pl{transform:rotate(135deg);background:var(--clay);color:#fff;border-color:var(--clay)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a-in{padding:0 0 26px;color:var(--muted);font-size:1.02rem;line-height:1.7;max-width:680px}

.lead-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:40px;box-shadow:var(--shadow-md)}
.lead-card .frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.lead-card label{display:block;font-weight:600;font-size:.88rem;color:var(--pine);margin:0 0 7px}
.lead-card input,.lead-card textarea,.lead-card select{width:100%;padding:14px 16px;border:1.5px solid var(--line-2);border-radius:var(--r-sm);font-family:var(--sans);font-size:1rem;background:var(--paper);color:var(--ink);margin-bottom:16px;transition:border-color .2s var(--ease)}
.lead-card input:focus,.lead-card textarea:focus{outline:none;border-color:var(--clay);background:#fff}

.finalcta{background:var(--pine);color:var(--paper);text-align:center;position:relative;overflow:hidden}.finalcta h2{color:var(--paper)}

/* credential card (About — the one place it appears) */
.cred-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 32px;box-shadow:var(--shadow-lg);max-width:440px;margin:0 auto}
.cred-card .cc-top{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1.5px solid var(--line-2)}
.cred-card .cc-eyebrow{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700}
.cred-card .cc-name{font-family:var(--serif);font-weight:600;font-size:1.55rem;color:var(--pine);line-height:1.1;margin-top:3px}
.cred-card .cc-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:12px 0;border-bottom:1px solid var(--line)}
.cred-card .cc-k{font-size:.74rem;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700;flex:none}
.cred-card .cc-v{font-size:.94rem;color:var(--ink);font-weight:600;text-align:right}
.cred-card .cc-verify{margin-top:16px;background:#e7f0ea;color:var(--ok);border-radius:10px;padding:11px 14px;font-size:.84rem;font-weight:600;display:flex;gap:9px;align-items:center}

/* receipt (Program cost — distinct from the home pricecard) */
.receipt{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:34px 36px;box-shadow:var(--shadow-md)}
.receipt .r-head{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;text-align:center;padding-bottom:14px;border-bottom:1.5px dashed var(--line-2);margin-bottom:6px}
.receipt .r-row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:12px 0;border-bottom:1px dashed var(--line-2)}
.receipt .r-l{color:var(--ink-soft);font-size:.96rem}
.receipt .r-l small{display:block;color:var(--muted);font-size:.78rem}
.receipt .r-v{font-weight:700;color:var(--pine);font-variant-numeric:tabular-nums;font-size:1rem}
.receipt .r-total{display:flex;justify-content:space-between;align-items:baseline;padding-top:18px}
.receipt .r-total .tl{font-family:var(--serif);font-weight:600;font-size:1.15rem;color:var(--pine)}
.receipt .r-total .tv{font-family:var(--serif);font-weight:700;font-size:2.1rem;color:var(--pine)}
.receipt .r-note{font-size:.82rem;color:var(--muted);margin-top:14px;border-top:1px solid var(--line);padding-top:14px}

.foot{background:var(--pine-deep);color:#a9bdb1;padding:72px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
.foot h4{color:#fff;font-family:var(--serif);font-size:1.05rem;margin-bottom:16px}
.foot a{color:#a9bdb1}.foot a:hover{color:var(--clay-2)}
.foot ul{list-style:none;display:grid;gap:10px;font-size:.96rem}
.foot .f-about{font-size:.96rem;line-height:1.7;margin-top:16px;max-width:300px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem;color:#7e8f84}
.foot-disc{font-size:.8rem;color:#6b7c71;margin-top:12px;max-width:760px;line-height:1.6}

.msg{padding:15px 20px;border-radius:var(--r-md);margin:18px auto;max-width:var(--maxw);font-weight:500}
.msg.success{background:#e7f0ea;color:var(--ok);border:1px solid #bcd6c8}
.msg.error{background:#fbeae6;color:#b3431f;border:1px solid #f0cabb}
.msg.info{background:#eef2f0;color:var(--pine-2);border:1px solid #d6e0da}

.authwrap{max-width:480px;margin:0 auto}
.legal-prose h2{font-size:1.4rem;margin:34px 0 12px}.legal-prose h3{font-size:1.15rem;margin:24px 0 8px}
.legal-prose p{margin-bottom:14px;color:var(--ink-soft)}.legal-prose ul{margin:0 0 16px 22px;color:var(--ink-soft)}.legal-prose li{margin-bottom:7px}
.legal-updated{color:var(--muted);font-size:.9rem;margin-bottom:28px}

@media(max-width:940px){
  .hero-grid{grid-template-columns:1fr}.hero-l{padding:64px 28px;max-width:none}.hero-r{min-height:420px}
  .split{grid-template-columns:1fr;gap:36px}.split.rev .split-media{order:0}
  .cards-3,.cards-2{grid-template-columns:1fr}
  .band-grid{grid-template-columns:1fr 1fr}.band-item:nth-child(2){border-right:0}.band-item{border-bottom:1px solid var(--line)}
  .curri{grid-template-columns:1fr}.steps{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr}.stat+.stat{border-left:0;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;margin-top:8px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}.nav-burger{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:80px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:18px;background:var(--pine-3);padding:24px 28px;border-bottom:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-md)}
  .nav.open .nav-links a.nl::after{display:none}
}
@media(max-width:560px){
  .section{padding:68px 0}.lead-card .frow{grid-template-columns:1fr}.steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}.pricecard .big{font-size:3.2rem}.hero-seal{width:72px;height:72px;right:20px;top:20px}
}
