@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,wght@0,400;0,600;0,700;0,800;1,600&family=Barlow+Condensed:wght@600;700;800;900&display=swap');

/* ── Reset + base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%;overflow-x:hidden}
body{
  font-family:'Nunito Sans',sans-serif;
  background:var(--light);
  color:var(--text);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
}

/* ── CSS custom properties ── */
:root {
  --blue:#116ade; --navy:#001a76;
  --chrome-bg:#116ade;
  --light:#f4f6fb; --mid:#e8edf7; --border:#d0d8ee;
  --text:#0d1b3e; --muted:#5a6a9a;
  --shadow:0 2px 12px rgba(0,26,118,0.08);
  --shadow-md:0 4px 24px rgba(0,26,118,0.13);
}

/* ── Nav ── */
nav{background:var(--chrome-bg);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:60px;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:200;flex-shrink:0;min-width:0}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-mark{height:28px;width:auto;object-fit:contain;filter:brightness(0) invert(1);flex-shrink:0}
.nav-banner{height:28px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}
.site-nav{display:flex;align-items:center;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.site-nav::-webkit-scrollbar{display:none}
.site-nav-link{color:rgba(255,255,255,0.55);text-decoration:none;font-size:11px;font-weight:800;letter-spacing:0.06em;text-transform:uppercase;padding:6px 11px;border-radius:6px;transition:all .15s;position:relative;white-space:nowrap;flex-shrink:0}
.site-nav-link::after{content:'';position:absolute;bottom:0;left:11px;right:11px;height:2px;background:#fff;border-radius:2px;opacity:0;transition:opacity .15s}
.site-nav-link:hover{color:rgba(255,255,255,0.9)}
.site-nav-link:hover::after{opacity:0.35}
.site-nav-link.active{color:#fff;background:rgba(255,255,255,0.12)}
.site-nav-link.active::after{opacity:0.7}
@media(max-width:600px){nav{padding:0 0.75rem}.nav-mark{height:24px}.nav-banner{height:24px}.site-nav-link{padding:5px 6px;font-size:9.5px;letter-spacing:0.04em}}

/* ── Page header (navy hero, shared by all pages) ── */
.page-header{background:var(--navy);padding:2.5rem 2rem;border-bottom:3px solid rgba(255,255,255,0.08);box-shadow:inset 0 -1px 0 rgba(255,255,255,0.06);flex-shrink:0}
.header-logo-wrap{display:flex;flex-direction:column;align-items:center;gap:0;text-align:center}
.header-page-title{font-size:2rem;font-weight:800;color:#fff;letter-spacing:-0.01em;line-height:1.15;margin-bottom:8px}
.header-tagline{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;color:rgba(255,255,255,0.45);letter-spacing:0.22em;text-transform:uppercase;text-align:center}
.header-desc{max-width:560px;margin:16px auto 0;font-size:13px;font-weight:600;color:rgba(255,255,255,0.38);line-height:1.7;text-align:center}
@media(max-width:600px){.page-header{padding:2rem 1.25rem}.header-page-title{font-size:1.6rem}}

/* ── Generic content container ── */
.container{flex:1;max-width:760px;margin:0 auto;padding:2rem 1.5rem 4rem;width:100%}
.container:has(.placeholder-wrap){display:flex;align-items:center;justify-content:center}
@media(max-width:600px){.container{padding:1.25rem 1rem 3rem}}

/* ── Placeholder / coming-soon card ── */
.placeholder-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;text-align:center;padding:2rem 0}
.placeholder-wrap h2{font-size:1.35rem;font-weight:800;color:var(--navy);margin-bottom:0.5rem;letter-spacing:-0.01em}
.placeholder-wrap p{font-size:0.95rem;font-weight:600;color:var(--muted);max-width:420px;line-height:1.65;margin-bottom:1.25rem}
.placeholder-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;color:var(--blue);background:rgba(17,106,222,0.08);border:1.5px solid rgba(17,106,222,0.18);border-radius:20px;padding:4px 14px}

/* ── Shared components ── */
.card{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:1.25rem 1.5rem;box-shadow:var(--shadow)}
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:700;font-family:'Nunito Sans',sans-serif;border:1.5px solid var(--border);border-radius:8px;background:#fff;color:var(--text);cursor:pointer;transition:all .15s;text-decoration:none;white-space:nowrap}
.btn:hover{background:var(--light);border-color:var(--blue);color:var(--blue)}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--navy);border-color:var(--navy);color:#fff}

/* ── Footer ── */
.site-footer{background:var(--chrome-bg);box-shadow:0 -4px 24px rgba(0,26,118,0.13);padding:2rem;flex-shrink:0}
.footer-inner{max-width:760px;margin:0 auto;display:flex;gap:2rem;align-items:flex-start;flex-wrap:wrap}
.footer-left{display:flex;align-items:center;gap:12px;flex-shrink:0}
.footer-mark{height:36px;width:auto;opacity:0.55;filter:brightness(0) invert(1)}
.footer-text{display:flex;flex-direction:column;gap:3px}
.footer-brand{font-size:13px;font-weight:800;color:rgba(255,255,255,0.55);letter-spacing:0.04em}
.footer-copy{font-size:11px;color:rgba(255,255,255,0.55);font-weight:600}
.footer-right{flex:1;min-width:240px}
.footer-legal{font-size:11px;color:rgba(255,255,255,0.55);line-height:1.7;font-weight:600;margin-bottom:8px}
.footer-contact{font-size:11px;color:rgba(255,255,255,0.55);font-weight:600}
.footer-contact a{color:rgba(255,255,255,0.55);text-decoration:none}
.footer-contact a:hover{color:#fff}
@media(max-width:560px){.footer-inner{flex-direction:column}.footer-right{min-width:0}}
