/* ============================================================
   PropNest — Responsive Stylesheet
   responsive.css
   Breakpoints: 576px | 768px | 992px | 1200px | 1400px
   ============================================================ */

/* ======================================
   Large Desktops (1400px+)
====================================== */
@media (min-width: 1400px) {
  :root {
    --container-max: 1360px;
  }
}

/* ======================================
   Desktops (1200px–1399px)
====================================== */
@media (max-width: 1399px) {
  :root { --container-max: 1200px; }
}

/* ======================================
   Laptops / Small Desktops (992px–1199px)
====================================== */
@media (max-width: 1199px) {
  :root { --container-max: 960px; }

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

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

  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }

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

  .footer-top {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10);
  }

  .property-gallery {
    height: 400px;
  }

  .property-detail-layout {
    grid-template-columns: 1fr 340px;
    gap: var(--space-8);
  }

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

  .dashboard-layout {
    grid-template-columns: 240px 1fr;
  }

  .cta-inner {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .cta-actions {
    justify-content: center;
  }
}

/* ======================================
   Tablets (768px–991px)
====================================== */
@media (max-width: 991px) {
  :root {
    --navbar-height: 64px;
    --container-pad: 1.25rem;
  }

  /* Navbar */
  .navbar-nav,
  .navbar-actions {
    display: none;
  }

  .navbar-toggle {
    display: flex;
  }

  /* Hero */
  .hero-title {
    font-size: clamp(2rem, 5.5vw, 3rem);
  }

  .hero-search-box {
    flex-wrap: wrap;
    border-radius: var(--radius-lg);
    gap: var(--space-2);
    padding: var(--space-3);
  }

  .search-field {
    flex: 1 1 calc(50% - var(--space-2));
    min-width: 140px;
  }

  .search-divider {
    display: none;
  }

  .search-submit {
    width: 100%;
    justify-content: center;
    padding: var(--space-3);
  }

  .hero-stats {
    flex-wrap: wrap;
    gap: var(--space-6);
  }

  /* Categories */
  .categories-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
  }

  /* Featured */
  .featured-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .featured-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }

  /* How It Works */
  .steps-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin-inline: auto;
  }

  .steps-grid::before {
    display: none;
  }

  /* Testimonials */
  .testimonials-grid {
    grid-template-columns: 1fr;
    max-width: 560px;
    margin-inline: auto;
  }

  /* Auth page */
  .auth-page {
    grid-template-columns: 1fr;
  }

  .auth-hero-side {
    display: none;
  }

  .auth-form-side {
    padding: var(--space-8) var(--space-6);
    min-height: 100vh;
  }

  /* Property detail */
  .property-gallery {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    height: auto;
  }

  .property-gallery-main {
    grid-row: auto;
    height: 320px;
  }

  .property-gallery-thumb {
    height: 160px;
  }

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

  .booking-widget {
    position: static;
  }

  /* Dashboard */
  .dashboard-layout {
    grid-template-columns: 1fr;
    padding-top: var(--navbar-height);
  }

  .dashboard-sidebar {
    position: static;
    height: auto;
    border-right: none;
    border-bottom: 1px solid var(--color-border);
  }

  /* Footer */
  .footer-top {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }

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

  /* Grid adjustments */
  .grid-2 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }

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

  .filter-sidebar {
    width: 100%;
  }
}

/* ======================================
   Mobile (576px–767px)
====================================== */
@media (max-width: 767px) {
  :root {
    --space-20: 4rem;
    --space-16: 3.5rem;
    --space-12: 2.5rem;
    --space-10: 2rem;
  }

  .section-padding {
    padding-block: 4rem;
  }

  .section-padding-lg {
    padding-block: 4.5rem;
  }

  /* Hero */
  .hero-section {
    min-height: auto;
    padding-bottom: 4rem;
  }

  .hero-content {
    padding-block: 5rem 3rem;
  }

  .hero-subtitle {
    font-size: var(--text-base);
  }

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

  .hero-stat-divider {
    display: none;
  }

  /* Categories */
  .categories-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Featured Listings */
  .featured-grid {
    grid-template-columns: 1fr;
  }

  /* Stats */
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Testimonials */
  .testimonials-grid {
    grid-template-columns: 1fr;
  }

  /* CTA */
  .cta-actions {
    flex-direction: column;
    width: 100%;
  }

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

  /* Auth */
  .auth-form-side {
    padding: var(--space-6) var(--space-5);
  }

  /* Property Gallery on Mobile */
  .property-gallery {
    height: auto;
    display: flex;
    flex-direction: column;
  }

  .property-gallery-main {
    height: 260px;
  }

  .property-gallery-thumb {
    display: none;
  }

  /* Amenities */
  .amenities-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Grids */
  .grid-3, .grid-4 { grid-template-columns: 1fr; }

  /* Footer */
  .footer-top {
    grid-template-columns: 1fr;
  }

  /* Property features - limit visible */
  .property-features {
    gap: var(--space-3);
  }

  /* Booking dates */
  .booking-dates {
    grid-template-columns: 1fr;
  }

  /* Dashboard stats */
  .dashboard-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Data table scrollable */
  .table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Pagination */
  .pagination {
    flex-wrap: wrap;
    gap: var(--space-2);
  }
}

/* ======================================
   Small Mobile (max-width: 575px)
====================================== */
@media (max-width: 575px) {
  :root {
    --container-pad: 1rem;
  }

  h1 { font-size: 2rem; }
  h2 { font-size: 1.5rem; }

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

  .categories-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
  }

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

  .hero-search-box {
    flex-direction: column;
  }

  .search-field {
    width: 100%;
    flex: unset;
  }

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

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

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

  .footer-social {
    justify-content: flex-start;
  }

  .back-to-top {
    bottom: var(--space-4);
    right: var(--space-4);
  }

  .property-card-image {
    height: 200px;
  }

  .property-features {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .page-hero-title {
    font-size: 1.6rem;
  }

  .btn-lg {
    font-size: var(--text-sm);
    padding: 0.8rem 1.5rem;
  }

  .cta-text h2 {
    font-size: 1.5rem;
  }

  /* Booking widget full width on detail */
  .booking-widget {
    padding: var(--space-4);
  }
}

/* ======================================
   Print Styles
====================================== */
@media print {
  .navbar,
  .footer,
  .back-to-top,
  .booking-widget,
  .filter-sidebar,
  .hero-section,
  .cta-section {
    display: none !important;
  }

  body {
    color: #000;
    background: #fff;
  }

  a { text-decoration: underline; }
  img { max-width: 100%; }
}
