.page-footer {
  width: 100%;
  background: var(--bg-page);
  border-top: 1px solid var(--border-color);
  display: flex;
  flex-direction: column;
  scroll-margin-top: 74px;
}

.footer-stack {
  width: 100%;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.footer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.footer-title {
  font-size: 15px;
  font-weight: bold;
  color: var(--text-primary);
}

.footer-note,
.footer-text {
  color: var(--text-muted);
  font-size: 12px;
}

.footer-grid {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 12px;
}

.footer-card {
  width: 100%;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  background: var(--surface-subtle);
  padding: 12px;
}

.footer-card-title {
  font-weight: bold;
  font-size: 15px;
  color: var(--text-primary);
  margin-bottom: 10px;
}

.footer-links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.footer-link {
  width: 100%;
  padding: 12px;
  background: var(--surface-subtle);
  color: var(--text-primary);
  border-radius: 12px;
  border: 1px solid var(--border-color);
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.footer-link-phone {
  background: var(--social-location-bg);
  color: var(--social-location-fg);
  border-color: var(--social-location-border);
}

.footer-link-whatsapp {
  background: var(--social-whatsapp-bg);
  color: var(--social-whatsapp-fg);
  border-color: var(--social-whatsapp-border);
}

.footer-link-instagram {
  background: var(--social-phone-bg);
  color: var(--social-instagram-fg);
  border-color: var(--social-instagram-border);
}

.policy-list {
  padding-right: 18px;
  list-style: disc;
  display: flex;
  flex-direction: column;
  color: var(--text-muted);
  font-size: 12px;
}

.map-container-iframe {
  width: 100%;
  height: 240px;
  border-radius: 12px;
  border: 1px solid var(--border-color);
  overflow: hidden;
}

:root[data-theme="dark"] .map-container-iframe {
  filter: brightness(0.82) contrast(1.08) saturate(0.9);
}

.footer-copy,
.footer-sign {
  width: 100%;
  height: auto;
  padding: 12px;
  background: var(--footer-copy-bg);
  color: var(--text-muted);
  border-top: 1px solid var(--border-color);
  font-size: 14px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 5px;
}

.heart-icon {
  color: var(--heart-color);
}

.footer-sign a {
  text-decoration: underline;
}
