/* Capital Legacy & Vision — shared brand stylesheet
   Palette: --navy #0a1628, --gold #c9a84c, --slate #8a9bb5, --paper #f7f5f0, --ink #10161f
*/
:root{
  --navy:#0a1628;
  --navy-2:#0e1e35;
  --gold:#c9a84c;
  --gold-light:#e2c878;
  --slate:#8a9bb5;
  --paper:#f7f5f0;
  --ink:#10161f;
  --line:#22304a;
  --ok:#2f8f5b;
  --err:#b6462f;
  --font-display:'Trebuchet MS', 'Segoe UI', Arial, sans-serif;
  --font-body:'Georgia', 'Times New Roman', serif;
  --font-ui:'Trebuchet MS', Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
}
h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--navy);
  margin:0 0 .5em;
  letter-spacing:.01em;
}
a{color:var(--navy)}
img{max-width:100%;display:block}

.eyebrow{
  font-family:var(--font-ui);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
}

/* ---- Header ---- */
.site-header{
  background:var(--navy);
  border-bottom:3px solid var(--gold);
  position:sticky;top:0;z-index:50;
}
.nav-wrap{
  max-width:1180px;margin:0 auto;padding:16px 28px;
  display:flex;align-items:center;justify-content:space-between;
}
.brand{
  color:#fff;font-family:var(--font-ui);font-weight:700;
  font-size:15px;letter-spacing:.12em;text-decoration:none;
  display:flex;flex-direction:column;line-height:1.2;
}
.brand small{color:var(--gold);font-size:9px;letter-spacing:.24em;font-weight:400;margin-top:2px}
.nav-links{display:flex;gap:28px;list-style:none;margin:0;padding:0}
.nav-links a{
  color:#c7d2e5;text-decoration:none;font-family:var(--font-ui);
  font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;
  transition:color .2s;
}
.nav-links a:hover{color:var(--gold)}
.nav-cta{
  background:var(--gold);color:var(--navy);padding:9px 20px;
  font-family:var(--font-ui);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
}
.nav-toggle{display:none}
@media(max-width:860px){
  .nav-links{display:none}
  .nav-toggle{display:block}
}

/* ---- Hero ---- */
.hero{
  background:linear-gradient(180deg,var(--navy) 0%,var(--navy-2) 100%);
  color:#fff;padding:96px 28px 84px;text-align:center;position:relative;
  overflow:hidden;
}
.hero::after{
  content:'';position:absolute;left:50%;bottom:0;width:1px;height:56px;
  background:var(--gold);transform:translateX(-50%);
}
.hero h1{
  color:#fff;font-size:clamp(30px,4.4vw,52px);max-width:820px;margin:14px auto 20px;
  font-weight:400;line-height:1.15;
}
.hero p{
  color:var(--slate);max-width:600px;margin:0 auto 34px;font-size:17px;
}
.btn{
  display:inline-block;font-family:var(--font-ui);font-size:12.5px;
  letter-spacing:.14em;text-transform:uppercase;text-decoration:none;
  padding:15px 34px;font-weight:700;border:1px solid var(--gold);
  transition:all .2s;
}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-light)}
.btn-ghost{background:transparent;color:var(--gold)}
.btn-ghost:hover{background:var(--gold);color:var(--navy)}

/* ---- Sections ---- */
.section{padding:80px 28px}
.section-narrow{max-width:840px;margin:0 auto}
.section-wide{max-width:1180px;margin:0 auto}
.section-head{text-align:center;max-width:640px;margin:0 auto 52px}
.section-head h2{font-size:clamp(24px,3vw,34px);font-weight:400}
.section-alt{background:#fff}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media(max-width:860px){.grid-3,.grid-2{grid-template-columns:1fr}}

.card{
  background:#fff;border:1px solid #e6e1d6;padding:34px 30px;
}
.card .num{
  font-family:var(--font-ui);color:var(--gold);font-size:11px;
  letter-spacing:.2em;margin-bottom:14px;display:block;
}
.card h3{font-size:19px;margin-bottom:12px}
.card p{font-size:15px;color:#444}

.stat{text-align:center}
.stat .value{font-family:var(--font-ui);color:var(--navy);font-size:44px;font-weight:700}
.stat .label{font-family:var(--font-ui);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:6px}
.stat .desc{font-size:14px;color:#555;margin-top:8px}

.divider-gold{width:36px;height:1px;background:var(--gold);margin:0 auto 20px}

blockquote.quote{
  border-left:2px solid var(--gold);padding-left:22px;margin:0 0 24px;
  font-style:italic;font-size:16px;color:#333;
}
.quote-author{font-family:var(--font-ui);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--navy);font-weight:700}
.quote-role{font-size:12.5px;color:#777}

.faq-item{border-bottom:1px solid #e6e1d6;padding:22px 0}
.faq-item h3{font-size:16.5px;margin-bottom:8px}
.faq-item p{font-size:15px;color:#444;margin:0}

form.contact-form{display:grid;gap:16px;max-width:520px}
form.contact-form label{font-family:var(--font-ui);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);margin-bottom:6px;display:block}
form.contact-form input,form.contact-form textarea{
  width:100%;padding:12px 14px;border:1px solid #d8d2c4;background:#fff;
  font-family:var(--font-body);font-size:15px;
}
form.contact-form button{
  justify-self:start;background:var(--navy);color:#fff;border:none;
  padding:14px 30px;font-family:var(--font-ui);font-size:12.5px;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;
}
form.contact-form button:hover{background:var(--gold);color:var(--navy)}

.contact-meta{font-family:var(--font-ui);font-size:14px;color:var(--navy);line-height:2}
.contact-meta .gold{color:var(--gold)}

/* ---- Footer ---- */
.site-footer{background:var(--navy);color:var(--slate);padding:48px 28px 28px;text-align:center}
.site-footer .brand{margin:0 auto 14px;align-items:center}
.footer-links{display:flex;gap:22px;justify-content:center;list-style:none;padding:0;margin:0 0 20px;flex-wrap:wrap}
.footer-links a{color:#c7d2e5;text-decoration:none;font-family:var(--font-ui);font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.footer-links a:hover{color:var(--gold)}
.footer-fine{font-size:11.5px;color:#5a6c8a;font-family:var(--font-ui);letter-spacing:.04em}

/* ---- Auth / portal shared shell (login screens) ---- */
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy);padding:24px}
.auth-card{background:#0e1e35;border:1px solid var(--line);padding:44px 40px;width:100%;max-width:400px}
.auth-card .brand{align-items:center;margin-bottom:6px}
.auth-card .kicker{text-align:center;font-family:var(--font-ui);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:28px}
.auth-card label{font-family:var(--font-ui);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);display:block;margin:0 0 6px}
.auth-card input{
  width:100%;padding:12px 14px;margin-bottom:16px;background:#0a1628;
  border:1px solid var(--line);color:#fff;font-family:var(--font-ui);font-size:14px;
}
.auth-card input:focus{outline:none;border-color:var(--gold)}
.auth-card button{
  width:100%;background:var(--gold);color:var(--navy);border:none;padding:14px;
  font-family:var(--font-ui);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:700;cursor:pointer;margin-top:6px;
}
.auth-card button:hover{background:var(--gold-light)}
.auth-card button:disabled{opacity:.5;cursor:not-allowed}
.auth-link{display:block;text-align:center;margin-top:16px;color:var(--slate);font-family:var(--font-ui);font-size:12px;text-decoration:none}
.auth-link:hover{color:var(--gold)}
.auth-msg{font-family:var(--font-ui);font-size:12.5px;padding:10px 12px;margin-bottom:16px;display:none}
.auth-msg.ok{display:block;background:rgba(47,143,91,.15);border:1px solid var(--ok);color:#8fe0b5}
.auth-msg.err{display:block;background:rgba(182,70,47,.15);border:1px solid var(--err);color:#f0a48f}
.auth-foot{text-align:center;margin-top:22px;font-family:var(--font-ui);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#4a5a78}

/* ---- Dashboard shell ---- */
.dash{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:var(--paper)}
.dash-side{background:var(--navy);color:#fff;padding:28px 22px}
.dash-side .brand{margin-bottom:36px}
.dash-nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}
.dash-nav a{color:#c7d2e5;text-decoration:none;font-family:var(--font-ui);font-size:13px;padding:11px 12px;letter-spacing:.03em}
.dash-nav a.active,.dash-nav a:hover{background:rgba(201,168,76,.12);color:var(--gold)}
.dash-main{padding:40px 44px}
.dash-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.dash-topbar h1{font-size:24px;margin:0}
.logout-btn{font-family:var(--font-ui);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);background:none;border:1px solid var(--navy);padding:8px 16px;cursor:pointer}
.logout-btn:hover{background:var(--navy);color:#fff}
.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:36px}
.stat-card{background:#fff;border:1px solid #e6e1d6;padding:22px}
.stat-card .k{font-family:var(--font-ui);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate)}
.stat-card .v{font-family:var(--font-ui);font-size:28px;color:var(--navy);font-weight:700;margin-top:6px}
@media(max-width:860px){.dash{grid-template-columns:1fr}.dash-side{display:none}.stat-cards{grid-template-columns:1fr}}
