/* BUILD: 2026-02-19 mega-menu-grid-fix */
/* components.css — header, footer, widgets */

.site-header{
  position:sticky;
  top:0;
  z-index:200;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--c-border);
  overflow:visible;
}

.header-inner{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 0;
  overflow:visible;
}

/* ===============================
   Brand
================================ */

.brand-logo{
  height:75px;
  width:auto;
  display:block;
}

.brand{
  display:flex;
  gap:14px;
  align-items:center;
  color:var(--c-ink);
  text-decoration:none;
}

.brand:hover{ text-decoration:none; }

.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.05;
}

.brand-name{
  font-weight:900;
  font-size:2.35rem;
  letter-spacing:-0.005em;
  display:inline-flex;
  align-items:baseline;
}

.brand-catalog{
  color:#8A8F98;
  font-weight:400;
}

.brand-intel{
  color:#3C80C1;
  font-weight:900;
}

.brand-io{
  color:#8A8F98;
  font-weight:400;
  font-size:0.65em;
  vertical-align:baseline;
  margin-left:2px;
}

.brand-tagline{
  font-weight:500;
  font-size:1.05rem;
}

/* ===============================
   Mega Menu
================================ */

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.nav-toggle{
  display:none;
  border:1px solid var(--c-border);
  background:#fff;
  border-radius:12px;
  padding:10px 12px;
  font-weight:900;
}

.nav-list{
  display:flex;
  gap:18px;
  align-items:center;
  margin:0;
  padding:0;
  list-style:none;
  overflow:visible;
}

.nav{ position:relative; }

.nav-item{ position:relative; }
.nav-item.has-mega{ position:static; }

.nav-link{
  font-weight:700;
  color:var(--c-text);
}

.nav-btn{
  appearance:none;
  background:transparent;
  border:0;
  padding:8px 2px;
  cursor:pointer;
  font:inherit;
}

.chev{ font-size:.9em; opacity:.8; }

.mega{
  position:absolute;
  top:100%;
  margin-top:-1px;
  left:0;
  right:0;
  width:100%;
  background:#fff;
  border-top:1px solid var(--c-border);
  border-bottom:1px solid var(--c-border);
  box-shadow:0 18px 50px rgba(0,0,0,.12);
  padding:22px 0;
  display:none;
  z-index:9999;
}

.nav-item.has-mega:hover > .mega,
.nav-item.has-mega:focus-within > .mega,
.nav-item.has-mega.is-open > .mega{
  display:block;
}

/* ===============================
   Buttons
================================ */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 20px;
  border-radius:999px;
  border:1px solid var(--c-border);
  font-weight:600;
  background:#fff;
  color:var(--c-ink);
}

.btn--primary{
  background:var(--c-brand-blue);
  color:#fff;
  border-color:transparent;
}

.btn--primary:hover{
  background:var(--c-brand-blue-hover);
  color:#fff;
}

.nav .btn--primary,
.nav .btn--primary:hover{
  color:#fff !important;
}

.btn:hover{
  filter:brightness(.98);
  text-decoration:none;
}

/* ===============================
   Hero + Cards
================================ */

.hero{
  background:#eef2f7;
  border-bottom:1px solid rgba(15, 23, 42, 0.12);
}

.hero-inner{
  padding:var(--s-6) 0;
}

.card{
  border:1px solid var(--c-border);
  border-radius:var(--r);
  background:#fff;
  padding:var(--s-3);
  box-shadow:var(--shadow);
}

.card p{ margin:0; }

.icon{
  width:64px;
  height:64px;
  border-radius:16px;
  background:var(--c-surface);
  border:1px solid var(--c-border);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:1.8rem;
  color:var(--c-ink);
}

/* ===============================
   Footer (Refined)
================================ */

.site-footer{
  background:#0b2b5b;
  color:rgba(255,255,255,.92);
  padding:70px 0 40px;
  margin-top:var(--s-6);
}

.footer-grid{
  display:grid;
  gap:60px;
  grid-template-columns:2fr 1fr 1fr 1fr;
  align-items:start;
}

.site-footer h4{
  font-size:.9rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  opacity:.8;
  margin-bottom:14px;
}

.footer-tagline{
  font-weight:700;
  margin-bottom:14px;
  opacity:.95;
}

.footer-audience{
  opacity:.75;
  margin-bottom:16px;
  line-height:1.6;
}

/* Footer Contact Styling (UPDATED) */
.footer-contact a{
  font-weight:400;
  color:#ffffff;
  border-bottom:1px solid rgba(255,255,255,.35);
  padding-bottom:2px;
}

.footer-contact strong{
  font-weight:700;
}

.footer-contact a:hover{
  border-bottom-color:rgba(255,255,255,.75);
}

.footer-links{
  list-style:none;
  padding:0;
  margin:0;
}

.footer-links li{ margin-bottom:9px; }

.site-footer a{
  color:rgba(255,255,255,.85);
  text-decoration:none;
}

.site-footer a:hover{ color:#fff; }

.footer-bottom{
  margin-top:50px;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.15);
}

.site-footer .small{
  color:rgba(255,255,255,.7);
  font-size:.9rem;
}

/* ===============================
   Footer Wordmark
================================ */

.footer-logo{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:6px;
}

.footer-icon{
  width:56px;
  height:56px;
  border-radius:14px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:1.6rem;
  line-height:1;
  color:#ffffff;
}

.footer-wordmark{
  font-weight:900;
  font-size:2.1rem;
  letter-spacing:-0.005em;
  display:inline-flex;
  align-items:baseline;
  line-height:1;
}

.footer-catalog{ color:#FFFFFF; font-weight:400; }
.footer-intel{ color:#8EC5FF; font-weight:900; }

.footer-io{
  color:rgba(255,255,255,.7);
  font-weight:400;
  font-size:0.65em;
  margin-left:2px;
  vertical-align:baseline;
}

.site-footer .footer-tagline{
  color:rgba(255,255,255,.92);
}