/* ==========================================================================
   Best Hockey Gear — responsive.css
   Mobile-first media queries
   Breakpoints: 480px, 640px, 768px, 1024px, 1280px
   ========================================================================== */

/* --- Base (Mobile First: < 480px) --- */

.grid-2,
.grid-3,
.grid-4,
.grid-6 {
  grid-template-columns: 1fr;
}

.category-grid {
  grid-template-columns: 1fr;
}

.trust-grid {
  grid-template-columns: 1fr;
}

.review-preview-grid {
  grid-template-columns: 1fr;
}

.product-grid {
  grid-template-columns: 1fr;
}

.footer__grid {
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

.hero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.hero__stat-value {
  font-size: var(--text-2xl);
}

.nav__links {
  display: none;
}

.nav__hamburger {
  display: flex;
}

.email-form {
  flex-direction: column;
}

.cookie-banner {
  flex-direction: column;
  gap: var(--space-3);
  text-align: center;
}

.cookie-banner__actions {
  justify-content: center;
}

.pros-cons {
  grid-template-columns: 1fr;
}

.review-layout {
  grid-template-columns: 1fr;
}

.review-sidebar {
  position: static;
  order: -1;
}

.bestof-layout {
  grid-template-columns: 1fr;
}

.toc-sidebar {
  position: static;
  order: -1;
}

.winner-cards {
  grid-template-columns: 1fr;
}

.pick-entry__body {
  grid-template-columns: 1fr;
}

.pick-entry__img {
  height: 200px;
}

.related-grid {
  grid-template-columns: 1fr;
}

.mobile-buy-cta {
  display: flex;
}

.filter-bar__inner {
  gap: var(--space-3);
}

/* --- Small (≥ 480px) --- */
@media (min-width: 480px) {
  .container {
    padding-left: var(--space-5);
    padding-right: var(--space-5);
  }

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

  .winner-cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .pros-cons {
    grid-template-columns: 1fr 1fr;
  }
}

/* --- Tablet (≥ 640px) --- */
@media (min-width: 640px) {
  .container {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
  }

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

  .review-preview-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .footer__grid {
    grid-template-columns: 1fr 1fr;
  }

  .email-form {
    flex-direction: row;
  }

  .pick-entry__body {
    grid-template-columns: 180px 1fr;
  }
}

/* --- Medium (≥ 768px) --- */
@media (min-width: 768px) {
  .category-grid {
    grid-template-columns: repeat(3, 1fr);
  }

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

  .review-preview-grid {
    grid-template-columns: repeat(3, 1fr);
  }

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

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

  .footer__grid {
    grid-template-columns: 1.5fr 1fr 1fr;
  }

  .cookie-banner {
    flex-direction: row;
    text-align: left;
  }

  .cookie-banner__actions {
    justify-content: flex-start;
  }

  .nav__links {
    display: flex;
  }

  .nav__hamburger {
    display: none;
  }

  .nav__mobile-menu {
    display: none !important;
  }
}

/* --- Large (≥ 1024px) --- */
@media (min-width: 1024px) {
  .product-grid {
    grid-template-columns: repeat(3, 1fr);
  }

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

  .footer__grid {
    grid-template-columns: 2fr 1fr 1fr 1fr;
  }

  .review-layout {
    grid-template-columns: 1fr 340px;
  }

  .review-sidebar {
    position: sticky;
    top: 88px;
    order: 0;
  }

  .bestof-layout {
    grid-template-columns: 1fr 280px;
  }

  .toc-sidebar {
    position: sticky;
    top: 88px;
    order: 0;
  }

  .mobile-buy-cta {
    display: none;
  }
}

/* --- XL (≥ 1280px) --- */
@media (min-width: 1280px) {
  .container {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }

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

/* --- Navigation responsive tweaks --- */
@media (max-width: 1100px) {
  .nav__links a {
    padding: var(--space-2) var(--space-2);
    font-size: var(--text-xs);
  }
}

@media (max-width: 900px) {
  .nav__links {
    display: none;
  }

  .nav__hamburger {
    display: flex;
  }
}

/* --- Hero responsive --- */
@media (max-width: 600px) {
  .hero {
    padding: var(--space-16) 0;
  }

  .hero__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .hero__actions .btn {
    width: 100%;
    justify-content: center;
  }

  .hero__stats {
    gap: var(--space-3);
  }

  .hero__stat-value {
    font-size: var(--text-xl);
  }
}

/* --- Product card responsive --- */
@media (max-width: 480px) {
  .product-card__image {
    height: 180px;
  }

  .product-card__footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .product-card__footer .btn {
    width: 100%;
  }
}

/* --- Filter bar responsive --- */
@media (max-width: 640px) {
  .filter-bar {
    overflow-x: auto;
    padding: var(--space-3) 0;
  }

  .filter-bar__inner {
    flex-wrap: nowrap;
    padding: 0 var(--space-4);
    min-width: max-content;
  }
}

/* --- Review page responsive --- */
@media (max-width: 480px) {
  .review-header__meta {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* --- Category hero responsive --- */
@media (max-width: 600px) {
  .category-hero {
    padding: var(--space-10) 0;
  }
}

/* --- Best-of responsive --- */
@media (max-width: 600px) {
  .pick-entry__rank {
    font-size: var(--text-2xl);
    width: 36px;
  }

  .bestof-hero {
    padding: var(--space-10) 0;
  }
}

/* --- FAQ responsive --- */
@media (max-width: 600px) {
  .faq-question {
    padding: var(--space-4);
  }

  .faq-answer__inner {
    padding: 0 var(--space-4) var(--space-4);
  }
}

/* --- Footer responsive --- */
@media (max-width: 480px) {
  .footer__bottom {
    flex-direction: column;
    text-align: center;
  }

  .footer__legal-links {
    justify-content: center;
  }
}

/* --- Email form responsive --- */
@media (max-width: 480px) {
  .email-form .btn {
    width: 100%;
  }
}

/* --- Scroll top responsive --- */
@media (max-width: 600px) {
  .scroll-top {
    bottom: var(--space-20);
    right: var(--space-4);
  }
}

/* --- Print styles --- */
@media print {
  .site-header,
  .cookie-banner,
  .mobile-buy-cta,
  .scroll-top,
  .email-banner,
  .nav__mobile-menu {
    display: none !important;
  }

  .review-layout,
  .bestof-layout {
    grid-template-columns: 1fr;
  }

  a[href]::after {
    content: ' (' attr(href) ')';
    font-size: 0.8em;
    color: var(--color-gray-400);
  }

  .btn::after {
    content: none;
  }
}
