/* styles.css - Styling for Attic Study Place - Multi-Section Responsive */

/* 7 Different Screen Sizes */

/* Extra Small (320px - 480px) - Mobile */
@media (max-width: 480px) {
  :root {
    --navbar-height: 70px;
  }

  .nav-links,
  .nav-auth {
    display: none !important;
  }

  .mobile-menu-btn {
    display: flex !important;
  }

  .hero-title {
    font-size: 1.75rem;
  }

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

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

  .hero-logo-display {
    min-height: 200px;
  }

  .section-title {
    font-size: 1.75rem;
  }

  .section-description {
    font-size: 0.9rem;
  }

  .amenities-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .amenity-card {
    padding: 1.5rem;
  }

  .gallery-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

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

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

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

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

  .footer-brand {
    grid-column: 1;
  }

  .contact-form {
    padding: 1.5rem;
  }

  .modal-content {
    padding: 1.5rem;
  }

  section {
    padding: 2.5rem 0;
  }
}

/* Small (481px - 640px) - Small Mobile */
@media (min-width: 481px) and (max-width: 640px) {
  :root {
    --navbar-height: 75px;
  }

  .nav-links,
  .nav-auth {
    display: none !important;
  }

  .mobile-menu-btn {
    display: flex !important;
  }

  .hero-title {
    font-size: 2rem;
  }

  .section-title {
    font-size: 1.9rem;
  }

  .amenities-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.25rem;
  }

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

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

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

  .about-image-display {
    min-height: 250px;
  }

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

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

  section {
    padding: 3rem 0;
  }
}

/* Medium (641px - 768px) - Tablet */
@media (min-width: 641px) and (max-width: 768px) {
  :root {
    --navbar-height: 80px;
  }

  .nav-links {
    display: flex !important;
    gap: 1.5rem;
  }

  .nav-auth {
    display: flex !important;
    gap: 0.75rem;
  }

  .mobile-menu-btn {
    display: none !important;
  }

  .hero-title {
    font-size: 2.25rem;
  }

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

  .section-title {
    font-size: 2rem;
  }

  .amenities-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }

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

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

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

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

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

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

  .footer-brand {
    grid-column: 1 / -1;
  }

  section {
    padding: 3.5rem 0;
  }
}

/* Large (769px - 1024px) - Large Tablet/Small Desktop */
@media (min-width: 769px) and (max-width: 1024px) {
  .hero-title {
    font-size: 2.5rem;
  }

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

  .section-title {
    font-size: 2.25rem;
  }

  .amenities-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.75rem;
  }

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

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

  .about-grid {
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
  }

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

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

  .footer-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .footer-brand {
    grid-column: 1 / -1;
  }

  section {
    padding: 4rem 0;
  }
}

/* Extra Large (1025px - 1440px) - Desktop */
@media (min-width: 1025px) and (max-width: 1440px) {
  .hero-title {
    font-size: 2.75rem;
  }

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

  .section-title {
    font-size: 2.5rem;
  }

  .amenities-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
  }

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

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

  .about-grid {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }

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

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

  .footer-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  section {
    padding: 4rem 0;
  }
}

/* 2K (1441px - 1920px) - Large Desktop */
@media (min-width: 1441px) and (max-width: 1920px) {
  .hero-title {
    font-size: 3rem;
  }

  .section-title {
    font-size: 2.75rem;
  }

  .amenities-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 2.25rem;
  }

  .gallery-grid {
    grid-template-columns: repeat(4, 1fr);
  }

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

  .about-grid {
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
  }

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

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

  .footer-grid {
    grid-template-columns: repeat(5, 1fr);
  }

  section {
    padding: 5rem 0;
  }
}

/* 4K+ (1921px+) - Ultra HD */
@media (min-width: 1921px) {
  :root {
    --container-width: 1400px;
  }

  .hero-title {
    font-size: 3.5rem;
  }

  .section-title {
    font-size: 3rem;
  }

  .section-description {
    font-size: 1.2rem;
  }

  .hero-description {
    font-size: 1.3rem;
  }

  .amenities-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 2.5rem;
  }

  .gallery-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .reviews-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .policy-grid {
    grid-template-columns: repeat(4, 1fr);
  }

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

  section {
    padding: 6rem 0;
  }
}
