@media (min-width: 700px) {
  .section,
  .section-bleed {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .section-heading h2,
  .content-copy h2 {
    font-size: 2.45rem;
  }

  .hero-copy h1 {
    font-size: 3.85rem;
  }

  .hero-subtitle {
    font-size: 1.04rem;
  }

  .forecast-form {
    grid-template-columns: minmax(10rem, 1fr) minmax(12rem, 1fr);
    align-items: center;
  }

  .search-button {
    grid-column: auto;
  }

  .metrics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .battle-grid,
  .accuracy-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .personality-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .share-layout {
    grid-template-columns: minmax(0, 1.35fr) minmax(15rem, 0.65fr);
  }

  .content-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2rem;
  }

  .tool-info-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 900px) {
  .hero-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(22rem, 0.9fr);
    align-items: center;
    gap: 1.5rem;
  }

  .hero-copy {
    justify-items: start;
    text-align: left;
  }

  .hero-copy h1 {
    margin: 0;
  }

  .hero-subtitle {
    margin-left: 0;
    margin-right: 0;
  }

  .trust-badges {
    justify-content: flex-start;
  }

  .form-note {
    margin-left: 0;
    margin-right: 0;
    text-align: left;
  }

  .hero {
    min-height: min(76svh, 43rem);
    padding-top: 1.55rem;
    padding-bottom: 1.8rem;
  }

  .forecast-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
  }

  .location-button,
  .search-button {
    width: 100%;
  }

  .search-button {
    min-width: 0;
  }

  .prediction-dock {
    padding: 1.2rem;
  }

  .result-summary {
    grid-template-columns: minmax(0, 1.04fr) minmax(23rem, 0.96fr);
    align-items: center;
    padding: 1.35rem;
  }

  .summary-data-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .metrics-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .reasoning-layout,
  .personality-layout {
    grid-template-columns: minmax(0, 0.9fr) minmax(24rem, 1.1fr);
    align-items: center;
    gap: 2rem;
  }

  .storm-core h2 {
    font-size: 4.6rem;
  }
}

@media (min-width: 1180px) {
  .hero-copy h1 {
    font-size: 4.85rem;
  }

  .probability-ring {
    --ring-size: 17.75rem;
  }

  .ring-percent {
    font-size: 4.1rem;
  }

  .storm-ring {
    --ring-size: 24rem;
  }
}

@media (max-width: 420px) {
  .section,
  .section-bleed {
    padding-top: 2.25rem;
    padding-bottom: 2.25rem;
  }

  .hero {
    padding-top: 1.1rem;
    padding-bottom: 1.35rem;
  }

  .hero-copy h1 {
    font-size: 2.35rem;
    max-width: 10ch;
  }

  .hero-subtitle {
    font-size: 0.95rem;
  }

  .forecast-form {
    margin-top: 1rem;
  }

  .prediction-dock {
    padding: 0.9rem;
  }

  .share-card h3 {
    font-size: 2.25rem;
  }

  .ring-percent {
    font-size: 3.15rem;
  }

  .probability-ring {
    --ring-size: 14.5rem;
  }

  .dock-stats {
    grid-template-columns: 1fr;
  }

  .summary-data-grid {
    grid-template-columns: 1fr;
  }

  .city-nav-header {
    display: grid;
    gap: 0.65rem;
  }

  .city-pill {
    width: 100%;
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .storm-ring {
    --ring-size: 16rem;
  }

  .storm-ring .ring-percent {
    font-size: 3.7rem;
  }
}

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

  #snow-canvas {
    opacity: 0.35;
  }
}
