/* ============================================================
   AHR Cleaning — css/footer.css
   Footer styles
   ============================================================ */

.site-footer {
  background: var(--Linear, linear-gradient(180deg, #696969 0%, #1C1C1C 100%));
  padding: 68px 152px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 84px;
  width: 100%;
}

/* ---- Areas We Serve ---- */
.footer-areas {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 30px;
  width: 100%;

}

.footer-areas-heading {
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
  font-size: 32px;
  line-height: 1.09em;
  letter-spacing: -0.05em;
  color: #ffffff;
  text-align: left;
}
.areas-map{
  width: 100%;
  max-width: 1000px;
  padding-top: 40px;
}
.areas-map iframe {
    border: none;
    width: 100%;
    height: 304;
}

.cities-grid {
  display: grid;
  grid-template-columns: repeat(4, auto);
  grid-template-rows: repeat(9, auto);
  grid-auto-flow: column;
  column-gap: 48px;
  row-gap: 0;
  width: auto;
}

.city-item {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #ffffff;
  line-height: 1.2em;
  padding: 4px 0;
  white-space: nowrap;
}

/* ---- Footer Bottom (Logo + Columns) ---- */
.footer-bottom {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  gap: 60px;
  width: 100%;
}

.footer-logo {
  width: 228px;
  height: auto;
  object-fit: contain;
  display: block;
  flex-shrink: 0;
}
.footer-imgs{
  display: flex;
  flex-direction: column;
  align-items: center;
  
}
/* ---- Footer Columns ---- */
.footer-cols {
  display: flex;
  flex-direction: row;
  gap: 40px;
  flex: 1;
  justify-content: flex-end;
}

.footer-col {
  display: flex;
  flex-direction: column;
}

.footer-col-heading {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 12px;
  line-height: 1.3em;
  color: #ffffff;
  padding: 8px 0;
}

.footer-col-link {
  font-family: 'Montserrat', sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 1.5em;
  color: #ffffff;
  text-decoration: none;
  padding: 4px 0;
  transition: opacity 0.2s ease;
}

a.footer-col-link:hover { opacity: 0.65; }

/* ---- Copyright ---- */
.footer-copyright {
  font-family: 'Poppins', sans-serif;
  font-weight: 400;
  font-size: 14px;
  color: #ffffff;
  text-align: center;
  line-height: 1.4em;
  padding-bottom: 10px;
}

/* ---- Tablet (769px–1024px) ---- */
@media (min-width: 769px) and (max-width: 1024px) {
  .site-footer { padding: 60px 40px; gap: 60px; }
  .cities-grid { grid-template-columns: repeat(3, auto); grid-template-rows: repeat(12, auto); column-gap: 32px; }
  .footer-cols { gap: 32px; }
  .footer-logo { width: 180px; }
}

/* ---- Mobile (≤768px) ---- */
@media (max-width: 768px) {
  .site-footer { padding: 48px 24px; gap: 84px; }
  .cities-grid { grid-template-columns: repeat(2, auto); grid-template-rows: repeat(18, auto); column-gap: 44px; row-gap: 0; padding-left: 20px; }
  .city-item { font-size: 14px; }
  .footer-areas { align-items: center; }
  .footer-areas-heading { text-align: center; font-size: 22px; }
  .footer-bottom { flex-direction: column; align-items: center; gap: 50px; }
  .footer-cols { flex-direction: column; align-items: center; gap: 40px; }
  .footer-col { align-items: center; text-align: center; }
  .footer-logo { width: 228px; }
}
