/* ============================================
   Footer Component
   Created: 2025-01-27
   Purpose: フッターコンポーネントのスタイル（デザイントークン活用）
   ============================================ */

.footer {
  background-color: var(--color-primary);
  color: var(--text-inverse);
  margin-top: var(--space-10);
  padding: var(--space-10) 0 var(--space-5) 0;
}

.footer-container {
  max-width: var(--container-xl);
  margin: 0 auto;
  padding: 0 var(--space-5);
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-8);
  margin-bottom: var(--space-8);
}

.footer-section-title {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-4);
  font-weight: var(--font-weight-bold);
}

.footer-section-description {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: rgba(255, 255, 255, 0.9);
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-link-item {
  margin-bottom: var(--space-3);
}

.footer-link {
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  font-size: var(--font-size-base);
  transition: color var(--transition-fast);
}

.footer-link:hover {
  color: var(--text-inverse);
}

.footer-divider {
  border-top: var(--border-width-1) solid rgba(255, 255, 255, 0.3);
  padding-top: var(--space-5);
  margin-top: var(--space-5);
}

.footer-copyright {
  margin: 0;
  font-size: var(--font-size-sm);
  color: rgba(255, 255, 255, 0.8);
  text-align: center;
}

/* ============================================
   Responsive Design
   ============================================ */

@media (max-width: 768px) {
  .footer {
    padding: var(--space-6) 0 var(--space-4) 0;
    margin-top: var(--space-6);
  }

  .footer-grid {
    gap: var(--space-6);
    margin-bottom: var(--space-6);
  }
}

