/**
 * Responsive layout: laptop, tablet, smartphone
 * Load after all other stylesheets.
 */

/* --- Global --- */
html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  overflow-x: hidden;
}

img,
video {
  max-width: 100%;
  height: auto;
}

iframe {
  max-width: 100%;
}

/* --- Header & primary nav --- */
@media (max-width: 1024px) {
  .header-inner {
    padding: 1rem 1.25rem;
  }

  nav {
    gap: 1rem 1.25rem;
  }

  nav a {
    font-size: 0.9rem;
  }
}

@media (max-width: 768px) {
  .header-inner {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
  }

  .logo {
    width: 100%;
    text-align: center;
    font-size: 1.35rem;
  }

  nav {
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    gap: 0.5rem 0.75rem;
  }

  nav a {
    padding: 0.5rem 0.35rem;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

@media (max-width: 520px) {
  .header-inner {
    flex-direction: column;
    align-items: stretch;
    padding: 0.85rem 0.75rem;
    padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
  }

  nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem;
  }

  nav a {
    font-size: 0.78rem;
    padding: 0.65rem 0.4rem;
    text-align: center;
    border: 1px solid rgba(28, 26, 24, 0.18);
    border-radius: 6px;
    background: var(--color-white);
    line-height: 1.25;
  }

  nav a:hover,
  nav a.active {
    background: rgba(139, 105, 20, 0.12);
    border-color: var(--color-gold);
  }

  nav a.active {
    color: var(--color-amber);
    font-weight: 600;
  }
}

/* --- Main content --- */
@media (max-width: 768px) {
  main {
    padding: 1.25rem 1rem;
    padding-left: max(1rem, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, env(safe-area-inset-right, 0px));
  }
}

@media (max-width: 480px) {
  main {
    padding: 1rem 0.75rem;
  }
}

/* --- Footer --- */
@media (max-width: 768px) {
  .footer-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1.5rem;
  }

  .footer-links {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.65rem 1rem;
  }
}

@media (max-width: 480px) {
  footer {
    padding: 2rem 1rem 1.25rem;
    padding-left: max(1rem, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, env(safe-area-inset-right, 0px));
  }

  .footer-links {
    flex-direction: column;
    gap: 0.6rem;
    align-items: center;
  }

  .footer-links a {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

/* --- Home / hero (index) --- */
@media (max-width: 768px) {
  .hero {
    padding: 2.5rem 0.5rem;
  }

  .hero p {
    font-size: 1.05rem;
  }

  .hero-actions {
    flex-direction: column;
    align-items: stretch;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }

  .btn-primary,
  .btn-secondary {
    width: 100%;
    text-align: center;
    padding: 0.85rem 1.25rem;
  }
}

@media (max-width: 480px) {
  .hero h1 {
    font-size: clamp(1.75rem, 8vw, 2.5rem);
  }

  .hero p {
    font-size: 1rem;
  }
}

/* --- Top picks / category nav & products --- */
@media (max-width: 1024px) {
  .page-header {
    padding: 2rem 0 1.5rem;
  }

  .category-nav {
    gap: 0.5rem;
  }

  .category-btn {
    white-space: normal;
    text-align: center;
    line-height: 1.3;
    min-height: 2.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.65rem;
    font-size: 0.82rem;
  }
}

@media (max-width: 640px) {
  .collection {
    padding: 1.25rem 1rem;
  }

  .collection-title {
    font-size: 1.25rem;
  }

  .products {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .category-nav {
    flex-direction: column;
    align-items: stretch;
  }

  .category-btn {
    width: 100%;
  }
}

/* --- Guides hub & articles --- */
@media (max-width: 768px) {
  .guides-categories {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .page-header h1,
  .page-header h2 {
    font-size: clamp(1.65rem, 6vw, 2.25rem);
  }

  .page-header p {
    font-size: 1rem;
  }

  .popular-topics {
    padding: 1.25rem 1rem;
  }

  .topic-links a {
    word-break: break-word;
  }

  .guide-article h2 {
    font-size: 1.25rem;
  }

  .breadcrumb {
    font-size: 0.85rem;
    line-height: 1.4;
  }
}

/* --- About / shared content blocks --- */
@media (max-width: 768px) {
  .content .block h2 {
    font-size: 1.3rem;
  }
}

/* --- Contact --- */
@media (max-width: 768px) {
  .contact-iframe {
    min-height: 70vh;
    min-height: min(600px, 85vh);
  }

  .form-wrapper {
    border-radius: 6px;
  }
}

@media (max-width: 480px) {
  .contact-iframe {
    min-height: 500px;
  }

  .info {
    padding: 1.1rem;
  }
}

/* --- Gallery embed --- */
@media (max-width: 768px) {
  .gallery-embed {
    padding: 1rem 0;
    min-height: 280px;
  }
}

/* --- Skip link stays usable on small screens --- */
@media (max-width: 480px) {
  .skip-link:focus {
    left: max(1rem, env(safe-area-inset-left, 0px));
  }
}

/* --- Reduced motion --- */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
