/* ==========================================================================
   Sezione 8 — Footer (Figma 254:2205 / 192:1664)
   ========================================================================== */

.footer { background: var(--color-surface); padding-block: var(--space-section); }
.footer__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 416px;
  gap: 10px;
}

.footer__box {
  background: var(--color-surface-2);
  border-radius: 15px;
  padding: 40px;
  min-height: 500px;
  display: flex;
  flex-direction: column;
}

/* ---- Box sinistro ---- */
.footer__box--left { justify-content: space-between; }
.footer__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 21px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.footer__claim {
  font-size: var(--fs-h2);
  font-weight: var(--fw-light);
  line-height: var(--lh-h2);
  color: var(--color-text);
  opacity: 0.7;
}
.footer__claim strong { font-weight: var(--fw-bold); }

.footer__contact {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  flex-shrink: 0;
  height: 52px;
  padding: 8px 8px 8px 21px;
  background: #e2e2e2;
  border-radius: 999px;
  font-size: var(--fs-13);
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--color-text);
  transition: background-color 0.2s ease;
}
.footer__contact:hover { background: #d6d6d6; }
.footer__contact-ic {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 19px;
  background: var(--color-surface-3);
}
.footer__contact-ic svg { width: 18px; height: 18px; }

.footer__logo { width: 200px; height: auto; }

/* ---- Box destro ---- */
.footer__box--right { justify-content: space-between; gap: 40px; }
.footer__follow { display: flex; flex-direction: column; gap: 20px; }
.footer__follow-title { font-size: var(--fs-p28); color: var(--color-text); opacity: 0.7; }
.footer__social { display: flex; gap: 4px; }
.footer__social-link {
  display: inline-flex; align-items: center; justify-content: center;
  width: 50px; height: 50px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 25px;
  color: var(--color-text);
  transition: background-color 0.2s ease, color 0.2s ease;
}
.footer__social-link:hover { background: var(--color-text); color: #fff; }
.footer__social-link svg { width: 22px; height: 22px; }

.footer__bottom { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
.footer__meta { display: flex; flex-direction: column; gap: 5px; max-width: 260px; }
.footer__link {
  font-size: var(--fs-14);
  line-height: 1.6;
  color: var(--color-text-strong);
  text-decoration: underline;
  width: fit-content;
}
.footer__copy { margin-top: 24px; font-size: var(--fs-14); line-height: 1.2; color: var(--color-text-muted); }
.footer__iso { width: 168px; height: auto; flex-shrink: 0; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 900px) {
  .footer__grid { grid-template-columns: 1fr; }
  .footer__box { min-height: 0; }
  .footer__box--left { gap: 80px; }
}
@media (max-width: 480px) {
  .footer__head { flex-direction: column; gap: 24px; }
  .footer__box { padding: 28px; }
  .footer__bottom { flex-direction: column; align-items: flex-start; gap: 24px; }
}
