/* ============================================================
   SchoolFMS — css/footer.css
   ============================================================ */

.site-footer { background:var(--navy-deep); padding:72px 0 0; }
.footer-inner { max-width:1280px; margin:0 auto; padding:0 6%; }

/* Top grid */
.footer-top {
  display:grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1.4fr;
  gap:44px;
  padding-bottom:52px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}

/* Brand */
.footer-logo-link { display:inline-block; margin-bottom:16px; }
.footer-logo-img { height:44px; width:auto; object-fit:contain; filter:drop-shadow(0 0 8px rgba(56,189,248,0.1)); }
.footer-tagline { color:rgba(255,255,255,0.32); font-size:0.83rem; line-height:1.8; max-width:240px; margin-bottom:10px; }
.footer-company { font-size:0.76rem; color:rgba(255,255,255,0.2); }
.footer-company a { color:rgba(255,255,255,0.44); font-weight:600; transition:color 0.2s; }
.footer-company a:hover { color:var(--sky); }
.footer-socials { display:flex; gap:8px; margin-top:18px; }
.footer-social {
  width:32px; height:32px; border-radius:8px;
  border:1px solid rgba(255,255,255,0.1);
  display:flex; align-items:center; justify-content:center;
  font-size:0.7rem; font-weight:700; color:rgba(255,255,255,0.32); transition:all 0.22s;
}
.footer-social:hover { border-color:var(--sky); color:var(--sky); background:rgba(56,189,248,0.07); }

/* Columns */
.footer-col-title { font-family:var(--font-display); font-size:0.82rem; font-weight:700; color:rgba(255,255,255,0.52); margin-bottom:18px; }
.footer-col-links { display:flex; flex-direction:column; gap:10px; }
.footer-col-links a { color:rgba(255,255,255,0.3); font-size:0.83rem; transition:color 0.2s; }
.footer-col-links a:hover { color:rgba(255,255,255,0.75); }

/* Contact items */
.footer-contact-col { gap:12px; }
.footer-contact-item {
  display:flex !important; align-items:center; gap:8px;
  color:rgba(255,255,255,0.3) !important; font-size:0.82rem; transition:color 0.2s;
}
.footer-contact-item:hover { color:var(--sky) !important; }
.footer-contact-item svg { flex-shrink:0; opacity:0.55; }

/* Bottom bar */
.footer-bottom {
  padding:24px 0;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:10px;
}
.footer-copy { color:rgba(255,255,255,0.2); font-size:0.77rem; }
.footer-copy strong { color:rgba(255,255,255,0.44); }
.footer-dev { font-size:0.77rem; color:rgba(255,255,255,0.18); }
.footer-dev a { color:var(--sky); font-weight:600; }
.footer-dev a:hover { text-decoration:underline; }

/* Responsive */
@media (max-width:1100px) {
  .footer-top { grid-template-columns:1.6fr 1fr 1fr 1fr; }
  .footer-brand { grid-column:1 / -1; display:grid; grid-template-columns:auto 1fr; gap:16px 32px; align-items:start; }
  .footer-logo-link { grid-column:1/-1; }
  .footer-tagline { max-width:100%; }
}
@media (max-width:760px) {
  .footer-top { grid-template-columns:1fr 1fr; gap:32px; }
  .footer-brand { grid-column:1/-1; display:block; }
}
@media (max-width:480px) {
  .footer-top { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
}
