/* ══════════════════════════════════════════════════════════════
   FACCO — footer.css  v6.0  |  Dark zone
══════════════════════════════════════════════════════════════ */

.site-footer {
  background: var(--dk-0);
  border-top: 1px solid rgba(138,110,56,.10);
  padding: 52px 0 26px;
}

.footer-grid {
  max-width: var(--mw); margin: 0 auto; padding: 0 var(--g);
  display: grid; grid-template-columns: 1.7fr .9fr .9fr 1.15fr;
  gap: 32px; margin-bottom: 32px;
}

.footer-brand {
  font-family: var(--fd); font-size: 26px; font-weight: 600;
  letter-spacing: .24em; color: var(--dk-t); margin-bottom: 10px;
}
.footer-intro {
  max-width: 34ch;
  font-family: var(--fb); font-size: 14px; font-weight: 300;
  color: var(--dk-d); margin-bottom: 18px; line-height: 1.68;
}

.footer-contact-item { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 10px; }
.footer-contact-item svg { width: 11px; height: 11px; margin-top: 3px; fill: var(--red); flex-shrink: 0; }
.footer-contact-item span,
.footer-contact-item a {
  font-family: var(--fb); font-size: 13px; letter-spacing: .01em;
  color: var(--dk-m); line-height: 1.70; transition: color var(--tf);
}
.footer-contact-item a:hover,
.footer-links a:hover { color: var(--gold-l); }

.footer-col-title {
  font-family: var(--fb); font-size: 10px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--dk-d); margin-bottom: 14px;
  padding-bottom: 10px; border-bottom: 1px solid rgba(138,110,56,.11);
}

.footer-links li { margin-bottom: 9px; }
.footer-links a  { font-family: var(--fb); font-size: 13px; color: var(--dk-m); transition: color var(--tf); }

.newsletter-form {
  display: flex; border: 1px solid rgba(138,110,56,.26);
  margin-top: 4px; border-radius: var(--r-full); overflow: hidden;
}
.newsletter-form input {
  flex: 1; background: transparent; border: none; outline: none;
  padding: 11px 14px; font-family: var(--fb); font-size: 13px; color: var(--dk-t);
}
.newsletter-form input::placeholder { color: var(--dk-m); }
.newsletter-form button { background: var(--red); padding: 0 14px; transition: background var(--tf); cursor: pointer; }
.newsletter-form button:hover { background: var(--red-d); }
.newsletter-form button svg { width: 13px; height: 13px; fill: white; display: block; }

.social-links { display: flex; gap: 9px; margin-top: 16px; }
.social-link {
  width: 34px; height: 34px; border-radius: var(--r-full);
  border: 1px solid rgba(138,110,56,.24);
  display: flex; align-items: center; justify-content: center;
  transition: border-color var(--tf), transform var(--tf);
}
.social-link:hover { border-color: var(--gold-w); transform: translateY(-2px); }
.social-link svg { width: 13px; height: 13px; fill: var(--dk-m); }

.footer-note {
  margin-top: 16px;
  font-family: var(--fb); font-size: 10px; line-height: 1.80;
  letter-spacing: .11em; color: var(--dk-m); text-transform: uppercase;
}
.footer-note span { color: var(--red-s); }

.footer-bottom {
  max-width: var(--mw); margin: 0 auto; padding: 20px var(--g) 0;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  border-top: 1px solid rgba(138,110,56,.09);
}
.footer-copy { font-family: var(--fb); font-size: 10px; letter-spacing: .12em; color: var(--dk-m); text-transform: uppercase; }
.footer-jp   { font-family: var(--fj); font-size: 10px; letter-spacing: .18em; color: var(--gold-m); }


.newsletter-message {
  min-height: 20px;
  margin-top: 8px;
  font-family: var(--fb);
  font-size: 12px;
  line-height: 1.5;
  color: var(--dk-d);
}
.newsletter-message.is-success { color: var(--gold-w); }
.newsletter-message.is-error { color: var(--red-s); }

@media (max-width: 900px) {
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}
