/* =========================================================
   FOOTER
   ========================================================= */

.site-footer {
  background: var(--teal-deep);
  color: rgba(255,255,255,.78);
  padding: var(--sp-xl) 0 0;
  font-size: var(--fs-small);
}
.site-footer a { color: rgba(255,255,255,.78); }
.site-footer a:hover { color: var(--gold); }

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-lg);
  padding-bottom: var(--sp-lg);
}
@media (min-width: 768px) {
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: var(--sp-md); }
}

.footer-brand .site-logo { color: #fff; margin-bottom: var(--sp-sm); }
.footer-brand .site-logo .logo-text small { color: rgba(255,255,255,.6); }
.footer-brand p { max-width: 36ch; color: rgba(255,255,255,.65); }

.footer-social { display: flex; gap: 10px; margin-top: var(--sp-sm); }
.footer-social a {
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: #fff;
  transition: background var(--t-fast) var(--ease);
}
.footer-social a:hover { background: var(--teal); color: #fff; }

.footer-col h4 { color: #fff; font-size: 1rem; margin-bottom: var(--sp-sm); }
.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col li { margin-bottom: 8px; }

.footer-contact li { display: flex; align-items: flex-start; gap: 10px; }
.footer-contact .ico { color: var(--gold); flex-shrink: 0; margin-top: 2px; }

.footer-hours-table { width: 100%; border-collapse: collapse; }
.footer-hours-table td { padding: 4px 0; }
.footer-hours-table td:last-child { text-align: left; font-weight: 700; color: #fff; }

/* ── Footer bottom bar ────────────────────────────────── */
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding: var(--sp-sm) 0;
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: 10px;
  font-size: var(--fs-tiny);
  color: rgba(255,255,255,.5);
}
.footer-bottom-links { display: flex; gap: var(--sp-sm); flex-wrap: wrap; }
.footer-bottom-links a { color: rgba(255,255,255,.5); }
.footer-bottom-links a:hover { color: var(--gold); }

/* ── Sticky mobile CTA bar ─────────────────────────────── */
.mobile-cta-bar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 998;
  background: var(--white);
  border-top: 1px solid var(--line);
  box-shadow: 0 -4px 20px rgba(31,77,75,.08);
  display: flex; gap: 8px; padding: 10px var(--sp-sm);
  padding-bottom: max(10px, env(safe-area-inset-bottom));
}
.mobile-cta-bar .btn { flex: 1; padding: 13px 10px; font-size: .9rem; }
@media (min-width: 1024px) { .mobile-cta-bar { display: none; } }

body { padding-bottom: 70px; }
@media (min-width: 1024px) { body { padding-bottom: 0; } }
