/* =============================================================
   FOOTER
   ============================================================= */
#site-footer { background: #0e213f; color: rgba(255,255,255,.75); }
.footer-main { padding: 56px 0 40px; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 48px; }

.footer-logo          { margin-bottom: 16px; }
.footer-logo a        { display: inline-flex; align-items: center; }
.footer-logo img      { height: 40px; width: auto; filter: brightness(0) invert(1); }
.footer-logo-text     { font-size: 1.7rem; font-weight: 900; color: #fff; }
.footer-logo-text span { color: var(--green-light); }
.footer-desc          { font-size: .85rem; line-height: 1.7; margin-bottom: 18px; }

address.footer-contact-list { font-style: normal; display: flex; flex-direction: column; gap: 8px; }
.footer-contact-list li,
address.footer-contact-list span {
  display: flex; align-items: center; gap: 8px;
  font-size: .82rem; margin-bottom: 8px; color: rgba(255,255,255,.8);
}
.footer-contact-list li svg,
address.footer-contact-list span svg { color: var(--green-light); flex-shrink: 0; }
.footer-contact-list li a,
address.footer-contact-list span a  { color: rgba(255,255,255,.8); }
.footer-contact-list li a:hover,
address.footer-contact-list span a:hover { color: #fff; }

.footer-social   { display: flex; gap: 10px; margin-top: 18px; }
.footer-social a {
  width: 34px; height: 34px; background: rgba(255,255,255,.1); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.7); transition: all var(--transition);
}
.footer-social a:hover { background: var(--green); color: #fff; }
.footer-social a svg { width: 15px; height: 15px; }

.footer-col h4 {
  font-size: .8rem; font-weight: 800; color: #fff; text-transform: uppercase;
  letter-spacing: .07em; margin-bottom: 16px; padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.footer-links li { margin-bottom: 8px; }
.footer-links li a {
  font-size: .85rem; color: rgba(255,255,255,.65);
  display: flex; align-items: center; gap: 6px;
}
.footer-links li a:hover { color: #fff; }
.footer-links li a::before { content: '›'; color: var(--green-light); font-size: 1rem; }

.footer-newsletter p { font-size: .85rem; color: rgba(255,255,255,.65); margin-bottom: 14px; line-height: 1.6; }
.footer-nl-form  { display: flex; border-radius: 8px; overflow: hidden; margin-bottom: 14px; }
.footer-nl-input {
  flex: 1; padding: 11px 14px; border: none;
  background: rgba(255,255,255,.1); color: #fff; font-size: .875rem; outline: none;
}
.footer-nl-input::placeholder { color: rgba(255,255,255,.4); }
.footer-nl-btn   { padding: 11px 14px; background: var(--green); border: none; cursor: pointer; color: #fff; flex-shrink: 0; }

.footer-certs  { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 12px; }
.footer-cert   {
  padding: 4px 10px; background: rgba(255,255,255,.08); border-radius: 20px;
  font-size: .72rem; color: rgba(255,255,255,.7); border: 1px solid rgba(255,255,255,.1);
}

.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); padding: 18px 0; }
.footer-bottom-inner {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px; font-size: .78rem; color: rgba(255,255,255,.45);
}
.footer-bottom-links { display: flex; gap: 18px; }
.footer-bottom-links a { color: rgba(255,255,255,.45); }
.footer-bottom-links a:hover { color: #fff; }

/* Responsive */
@media (max-width: 1024px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 768px)  { .footer-grid { grid-template-columns: 1fr; gap: 28px; } }
