/* assets/css/footer.css  (FOOTER ONLY) */
/* Match NAV palette + typography */
:root{
  --ft-font: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --ft-ink:#0b1f33;
  --ft-muted:rgba(11,31,51,.70);

  --ft-navy:#0b1f33;
  --ft-blue:#1f6feb;
  --ft-cyan:#2bc4e3;

  --ft-bg:linear-gradient(180deg, rgba(11,31,51,1) 0%, rgba(7,22,38,1) 100%);
  --ft-card:rgba(255,255,255,.06);
  --ft-card2:rgba(255,255,255,.10);

  --ft-line:rgba(255,255,255,.14);
  --ft-line2:rgba(255,255,255,.08);

  --ft-max:1280px;
  --ft-radius:18px;

  --ft-shadow:0 18px 40px rgba(0,0,0,.22);
}

.site-footer, .site-footer *{box-sizing:border-box}
.site-footer{
  font-family:var(--ft-font);
  color:rgba(255,255,255,.92);
  background:var(--ft-bg);
  border-top:1px solid rgba(255,255,255,.10);
  box-shadow:0 -1px 0 rgba(255,255,255,.06) inset;
}

.footer-container{
  max-width:var(--ft-max);
  margin:0 auto;
  padding:58px 18px 36px;
  display:grid;
  grid-template-columns:1.25fr 1fr 1fr;
  gap:28px;
}

.footer-col h4{
  margin:0 0 14px;
  font-size:14px;
  letter-spacing:.22px;
  font-weight:950;
  color:rgba(255,255,255,.92);
}

.footer-brand{
  padding:18px;
  border-radius:var(--ft-radius);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border:1px solid var(--ft-line2);
  box-shadow:var(--ft-shadow);
}

.footer-logo{
  height:54px;
  width:auto;
  display:block;
  margin-bottom:12px;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.28));
}

.footer-tagline{
  margin:0 0 14px;
  color:rgba(255,255,255,.78);
  line-height:1.55;
  max-width:42ch;
}

.footer-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.footer-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:999px;
  text-decoration:none;
  color:rgba(255,255,255,.92);
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
  font-weight:900;
  letter-spacing:.12px;
  white-space:nowrap;
}

.footer-pill:hover{
  background:rgba(255,255,255,.16);
  border-color:rgba(31,111,235,.35);
  transform:translateY(-1px);
}

.site-footer a{
  color:rgba(255,255,255,.86);
  text-decoration:none;
}

.site-footer a:hover{opacity:.88}

.footer-col a{
  display:block;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid transparent;
  background:transparent;
  transition:background .18s ease, border-color .18s ease, transform .18s ease;
  font-weight:850;
  letter-spacing:.12px;
}

.footer-col a:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.10);
  transform:translateX(2px);
}

.footer-item{
  display:block;
  padding:10px 12px;
  color:rgba(255,255,255,.78);
  border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  margin-bottom:10px;
}

.footer-link-strong{
  background:linear-gradient(135deg, rgba(31,111,235,.28), rgba(43,196,227,.16));
  border:1px solid rgba(31,111,235,.30) !important;
}

.footer-link-strong:hover{
  background:linear-gradient(135deg, rgba(31,111,235,.34), rgba(43,196,227,.20));
}

/* Bottom bar */
.footer-bottom{
  max-width:var(--ft-max);
  margin:0 auto;
  padding:16px 18px 18px;
  border-top:1px solid var(--ft-line2);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  color:rgba(255,255,255,.72);
  font-size:13px;
}

.footer-bottom-links{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.footer-dot{opacity:.45}

.powered-by{
  font-weight:950;
  letter-spacing:.12px;
  color:rgba(255,255,255,.92);
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}

.powered-by:hover{
  background:rgba(255,255,255,.14);
  border-color:rgba(43,196,227,.30);
  transform:translateY(-1px);
}

/* Responsive */
@media (max-width:980px){
  .footer-container{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width:720px){
  .footer-container{
    grid-template-columns:1fr;
    padding:44px 16px 28px;
  }
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}
