/* ============================================================
   Footer
   ============================================================ */
.footer {
  background: #1a2330;
  color: rgba(255, 255, 255, 0.7);
  padding: clamp(48px, 6vw, 72px) 0 clamp(24px, 3vw, 32px);
}

.footer__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 32px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 48px);
  align-items: start;
}

.footer__brand {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.footer__logo {
  font-family: "Nunito", "Noto Sans JP", sans-serif;
  font-weight: 900;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.01em;
}

/* GOAL/S/kill colors inside footer logo:
   GOAL stays brand-blue, S stays brand-orange, kill desaturated for dark bg */
.footer__logo .site-logo__kill {
  color: #eaa152;
  font-weight: 800;
}

.footer__company {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.88);
  margin-top: 8px;
  letter-spacing: 0.02em;
}

.footer__company a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.35);
  padding-bottom: 1px;
}

.footer__address {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.7;
}

.footer__nav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px 24px;
}

.footer__nav a {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.02em;
  transition: color 0.2s ease;
}

.footer__nav a:hover {
  color: #ffffff;
}

.footer__copy {
  grid-column: 1 / -1;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: clamp(20px, 2vw, 24px);
  margin-top: clamp(20px, 2vw, 24px);
  font-size: 12px;
  color: rgba(255, 255, 255, 0.45);
  text-align: center;
  letter-spacing: 0.04em;
}

@media (max-width: 768px) {
  .footer__inner {
    grid-template-columns: 1fr;
  }
}
