/* ============================================
   THE FENCE PEOPLE — Responsive Styles
   Breakpoints match Oxygen Builder:
   Desktop: ≥1200px
   Large tablet: ≤1440px
   Tablet: ≤991px
   Small tablet: ≤767px
   Mobile: ≤479px
   ============================================ */

@media (max-width: 1440px) {
  .nav-list {
    display: none;
  }

  .hamburger {
    display: flex;
  }

  .nav-menu.open .nav-list {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--navy);
    padding: 22px;
    z-index: 9998;
  }

  .nav-menu.open .nav-list > li > a {
    padding: 12px 20px;
    color: var(--green);
    border-bottom: none;
  }

  .nav-menu.open .nav-list > li > a:hover {
    color: var(--white);
  }

  .nav-menu.open .sub-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    min-width: 100%;
    background-color: rgba(0,0,0,0.15);
  }

  .product-card {
    width: 50%;
  }

  h1 { font-size: 48px; }
  h2 { font-size: 36px; }

  .section-title {
    font-size: 36px;
  }
}

@media (max-width: 991px) {
  .two-col > .col {
    width: 100% !important;
  }

  .col-image-bg {
    min-height: 350px;
  }

  .hero-slider .swiper-slide {
    height: 500px;
  }

  .section-inner {
    padding: 60px 20px;
  }
}

@media (max-width: 767px) {
  .header-top .header-container {
    flex-direction: column;
    gap: 8px;
  }

  .header-main .header-container {
    flex-direction: column;
  }

  .header-logo {
    margin-top: 12px;
    margin-bottom: 24px;
  }

  .footer-columns {
    flex-direction: column;
  }

  .footer-col {
    width: 100%;
    padding-right: 0;
    margin-bottom: 30px;
  }

  .footer-bottom {
    flex-direction: column;
    gap: 12px;
    text-align: center;
  }

  .gallery-item {
    flex: 0 0 calc(50% - 4px);
  }

  .hero-slider .swiper-slide {
    height: 400px;
  }

  h1 { font-size: 36px; }
  h2 { font-size: 28px; }
  h3 { font-size: 24px; }

  .section-title {
    font-size: 28px;
  }

  .section-inner {
    padding: 40px 16px;
  }
}

@media (max-width: 479px) {
  .section-title {
    text-align: center;
  }

  .section-label {
    text-align: center;
  }

  .gallery-tabs {
    flex-direction: column;
  }

  .gallery-item {
    flex: 0 0 100%;
  }

  .product-card {
    width: 100%;
  }

  .footer-col {
    text-align: center;
    align-items: center;
    display: flex;
    flex-direction: column;
  }

  .hero-slider .swiper-slide {
    height: 300px;
  }
}
