/* ── DESIGN TOKENS ── */
:root {
  --page:    #F5F7FF;
  --white:   #FFFFFF;
  --ink:     #0B0D14;
  --navy:    #00114D;
  --blue:    #0037FF;
  --accent:  #3B82F6;
  --muted:   #6B7280;
  --subtle:  #9CA3AF;
  --rule:    #E4E6EF;
  --card-bg: #FFFFFF;
  --mid-bg:  #EEF1FB;
  --font:    'Poppins', sans-serif;
  --font-wm: 'Fraunces', serif;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;background:var(--page);color:var(--ink);overflow-x:hidden;line-height:1.6}

/* ── BRAND NAME ── */
/* Wrap any inline "jig" mention in copy with <span class="jig">jig</span> */
.jig{
  font-family:'Fraunces',serif;font-style:italic;font-weight:700;
  font-variation-settings:'opsz' 72,'SOFT' 0,'WONK' 0;
  color:var(--blue);font-size:inherit;line-height:inherit;letter-spacing:0;
}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:68px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 64px;
  background:rgba(245,247,255,0.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--rule);
  transition:box-shadow .3s;
}
nav.scrolled{box-shadow:0 1px 16px rgba(0,17,77,.06)}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-wordmark{display:flex;flex-direction:column;line-height:1;gap:2px}
.nav-wordmark .wm-main{
  font-family:var(--font-wm);font-style:italic;font-weight:700;
  font-variation-settings:'opsz' 20,'SOFT' 0,'WONK' 0;
  font-size:20px;color:var(--ink);letter-spacing:0;
}
.nav-wordmark .wm-rule{width:100%;height:1.5px;background:var(--blue);opacity:0.6;display:block}
.nav-wordmark .wm-sub{font-size:7px;font-weight:400;color:var(--subtle);letter-spacing:.6px;text-transform:uppercase}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{color:var(--muted);text-decoration:none;font-size:13.5px;font-weight:500;transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{
  background:var(--blue);color:#fff !important;
  padding:9px 20px;border-radius:4px;
  font-size:13px !important;font-weight:600 !important;
  transition:background .15s;
}
.nav-cta:hover{background:#0029cc !important}

/* ── SHARED LAYOUT ── */
.max-w{max-width:1200px;margin:0 auto}
.eyebrow{
  font-size:9px;font-weight:600;
  text-transform:uppercase;letter-spacing:1.5px;
  color:var(--blue);margin-bottom:16px;
  display:flex;align-items:center;gap:8px;
}
.eyebrow::before{content:'';width:16px;height:2px;background:var(--blue);flex-shrink:0}
h2{
  font-size:clamp(26px,3vw,38px);
  font-weight:600;line-height:1.15;
  letter-spacing:-.3px;color:var(--ink);
  margin-bottom:16px;
}
h2 em{font-style:italic;color:var(--blue);font-weight:300}
.section-sub{font-size:15px;font-weight:300;color:var(--muted);max-width:500px;line-height:1.8;margin-bottom:56px}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── BUTTONS ── */
.btn-primary{
  background:var(--blue);color:#fff;
  padding:13px 28px;border-radius:4px;
  font-weight:600;font-size:14px;
  text-decoration:none;transition:all .15s;
  display:inline-block;font-family:'Poppins',sans-serif;
  letter-spacing:.01em;
}
.btn-primary:hover{background:#0029cc;box-shadow:0 4px 20px rgba(0,55,255,.25)}
.btn-outline{
  color:var(--ink);padding:13px 24px;
  border-radius:4px;font-weight:500;font-size:14px;
  text-decoration:none;border:1px solid var(--rule);
  transition:all .15s;display:inline-flex;align-items:center;gap:7px;
  background:var(--white);
}
.btn-outline:hover{border-color:#C7D2FE;background:#F8F9FF}

/* ── FOOTER ── */
footer{background:var(--ink);padding:60px 64px 40px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:280px 1fr;gap:80px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-brand{display:flex;flex-direction:column;gap:16px}
.footer-logo{display:flex;align-items:center;gap:10px}
.footer-wm{display:flex;flex-direction:column;line-height:1;gap:3px}
.footer-wm .fm{
  font-family:var(--font-wm);font-style:italic;font-weight:700;
  font-variation-settings:'opsz' 18,'SOFT' 0,'WONK' 0;
  font-size:18px;color:#fff;letter-spacing:0;
}
.footer-wm .fm-rule{width:100%;height:1.5px;background:var(--blue);opacity:.55;display:block}
.footer-wm .fs{font-size:7px;color:rgba(255,255,255,.25);letter-spacing:.5px;text-transform:uppercase}
.footer-desc{font-size:12.5px;color:rgba(255,255,255,.3);font-weight:300;line-height:1.7}
.footer-uptime{display:flex;align-items:center;gap:7px;font-size:11px;color:rgba(255,255,255,.25);font-weight:300}
.fu-dot{width:6px;height:6px;border-radius:50%;background:#22C55E;flex-shrink:0}
.footer-links-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.footer-col{display:flex;flex-direction:column;gap:10px}
.fc-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.25);margin-bottom:4px}
.footer-col a{font-size:12.5px;color:rgba(255,255,255,.4);text-decoration:none;font-weight:300;transition:color .15s}
.footer-col a:hover{color:rgba(255,255,255,.8)}
.footer-regions{font-size:12px;color:rgba(255,255,255,.2);font-weight:300;margin-top:4px}
.footer-bottom{padding-top:28px;display:flex;align-items:center;justify-content:space-between}
.footer-bottom p{font-size:11.5px;color:rgba(255,255,255,.18);font-weight:300}

/* ── RESPONSIVE (nav + footer shared rules) ── */
@media(max-width:1024px){
  nav{padding-left:32px;padding-right:32px}
  footer{padding-left:32px;padding-right:32px}
  .footer-top{grid-template-columns:1fr}
  .footer-links-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-links{display:none}
  footer{padding:40px 24px 32px}
  .footer-links-grid{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
}

/* ── COOKIE CONSENT BANNER ── */
#cookie-banner {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  z-index: 9999;
  width: calc(100% - 48px);
  max-width: 680px;
  background: var(--ink);
  color: rgba(255,255,255,0.85);
  border-radius: 8px;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.28);
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease, transform .35s ease;
}
#cookie-banner.cookie-banner--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
#cookie-banner.cookie-banner--hidden {
  opacity: 0;
  transform: translateX(-50%) translateY(16px);
  pointer-events: none;
}
.cookie-banner__text {
  flex: 1;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,0.75);
}
.cookie-banner__text a {
  color: rgba(255,255,255,0.9);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cookie-banner__actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}
#cookie-accept {
  background: var(--blue);
  color: #fff;
  border: none;
  padding: 9px 18px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}
#cookie-accept:hover { background: #0029cc; }
#cookie-decline {
  background: transparent;
  color: rgba(255,255,255,0.55);
  border: 1px solid rgba(255,255,255,0.18);
  padding: 9px 18px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font);
  cursor: pointer;
  transition: border-color .15s, color .15s;
  white-space: nowrap;
}
#cookie-decline:hover {
  border-color: rgba(255,255,255,0.4);
  color: rgba(255,255,255,0.8);
}
@media (max-width: 560px) {
  #cookie-banner { flex-direction: column; align-items: flex-start; gap: 14px; bottom: 16px; }
  .cookie-banner__actions { width: 100%; }
  #cookie-accept, #cookie-decline { flex: 1; text-align: center; }
}
