/* ============================================
   Responsive — Mobile First
   Breakpoints: 480 / 768 / 1024
   ============================================ */

@media (max-width: 359px) {
  :root {
    --content-padding: 12px;
  }

  .phrase-card {
    min-height: 90px;
    padding: var(--space-md) var(--space-sm);
  }

  .phrase-emoji {
    font-size: 1.8rem;
  }

  .phrase-text {
    font-size: 0.95rem;
  }

  .pet-tab {
    padding: var(--space-sm) var(--space-md);
    font-size: 0.92rem;
  }

  .hero h1 {
    font-size: 1.8rem;
  }

  .hero p {
    font-size: 0.9rem;
  }
}

@media (min-width: 480px) {
  :root {
    --content-padding: 32px;
  }

  #phrase-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
  }

  .phrase-card {
    min-height: 130px;
  }
  .phrase-emoji {
    font-size: 2.4rem;
  }
}

@media (min-width: 768px) {
  :root {
    --content-padding: 48px;
  }

  .site-header {
    height: 72px;
  }
  .site-title {
    font-size: 1.3rem;
  }

  #phrase-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
  }

  .phrase-card {
    min-height: 140px;
    padding: var(--space-xl) var(--space-md);
  }

  .phrase-emoji {
    font-size: 2.6rem;
  }
  .phrase-text {
    font-size: 1.15rem;
  }

  .pet-tab {
    font-size: 1.1rem;
    padding: var(--space-lg) var(--space-xl);
  }

  .hero {
    padding: var(--space-4xl) var(--content-padding) var(--space-3xl);
  }

  .hero h1 {
    font-size: clamp(2.6rem, 5vw, 3.6rem);
  }

  .welcome-card {
    padding: var(--space-4xl) var(--space-2xl);
  }
}

@media (min-width: 1024px) {
  :root {
    --content-padding: 64px;
  }

  #phrase-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .phrase-card {
    min-height: 150px;
  }

  .phrase-card:hover {
    transform: translateY(-4px);
  }

  .knowledge-content.open {
    column-count: 2;
    column-gap: var(--space-xl);
  }

  .knowledge-item {
    break-inside: avoid;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
