/* ================================================
   LK Luxury Homes Kenya – Responsive Stylesheet
   ================================================ */

/* ---- 1200px ---- */
@media (max-width: 1200px) {
  :root { --container-max: 100%; }
  .container, .container-sm, .container-fluid { padding: 0 30px; }
  .properties-grid { grid-template-columns: repeat(2,1fr); }
  .properties-grid.cols-4 { grid-template-columns: repeat(3,1fr); }
  .services-grid { grid-template-columns: repeat(3,1fr); }
  .features-grid { grid-template-columns: repeat(3,1fr); }
  .testimonials-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1.4fr; gap: 30px; }
  .hero-title { font-size: clamp(2.2rem,5vw,3.6rem); }
  .stat-cards { grid-template-columns: repeat(2,1fr); }
  .service-detail-row { gap: 40px; }
  .location-detail-row { gap: 40px; }
}

/* ---- 992px ---- */
@media (max-width: 992px) {
  :root { --header-height: 70px; }
  section { padding: 80px 0; }
  .container, .container-sm, .container-fluid { padding: 0 24px; }

  /* Header – slide-in mobile nav */
  .main-nav {
    position: fixed; top: 0; right: -100%;
    width: 300px; height: 100vh;
    background: var(--primary-dark);
    flex-direction: column; align-items: flex-start;
    padding: 100px 24px 40px; gap: 4px;
    transition: right 0.4s cubic-bezier(0.4,0,0.2,1);
    box-shadow: -10px 0 40px rgba(0,0,0,0.3);
    z-index: 998; overflow-y: auto;
  }
  .main-nav.open { right: 0; }
  .nav-link { width: 100%; padding: 12px 16px; font-size: 0.82rem; border-radius: var(--radius); }
  .nav-link::after { display: none; }
  .nav-link:hover, .nav-link.active { background: rgba(255,255,255,0.07); }

  .header-actions {
    position: fixed; right: -100%; bottom: 40px;
    width: 300px; flex-direction: column;
    padding: 0 24px; margin: 0;
    z-index: 998;
    transition: right 0.4s cubic-bezier(0.4,0,0.2,1);
  }
  .header-actions.open { right: 0; }
  .header-actions .btn { width: 100%; justify-content: center; }

  .menu-toggle { display: flex; z-index: 999; }

  /* Hero */
  .hero-body { padding: 120px 0 60px; }
  .hero-content { max-width: 100%; }
  .hero-stats { gap: 30px; }
  .hero-search { position: relative; }
  .search-box { flex-wrap: wrap; }
  .search-field { flex: 1 1 45%; border-bottom: 1px solid var(--border-color); border-right: none; }
  .search-btn { width: 100%; justify-content: center; min-height: 56px; }

  /* Layouts */
  .about-preview { grid-template-columns: 1fr; gap: 50px; }
  .about-content { padding-right: 0; order: 2; }
  .about-image-wrap { order: 1; max-width: 500px; margin: 0 auto; }
  .about-image-accent { right: -10px; }
  .about-badge { left: -10px; }

  .properties-grid { grid-template-columns: repeat(2,1fr); gap: 20px; }
  .properties-grid.cols-4 { grid-template-columns: repeat(2,1fr); }
  .services-grid { grid-template-columns: repeat(2,1fr); }
  .features-grid { grid-template-columns: repeat(2,1fr); }
  .locations-grid { grid-template-columns: repeat(2,1fr); }
  .testimonials-grid { grid-template-columns: 1fr; }

  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .footer-brand { grid-column: 1 / -1; }

  .properties-layout { grid-template-columns: 1fr; }
  .filter-sidebar { position: static; }
  .property-details-layout { grid-template-columns: 1fr; }
  .property-info-grid { grid-template-columns: repeat(2,1fr); }
  .contact-layout { grid-template-columns: 1fr; }

  /* Dashboard */
  .dashboard-layout { grid-template-columns: 1fr; }
  .dashboard-sidebar { position: static; height: auto; padding: 0; display: flex; overflow-x: auto; overflow-y: hidden; }
  .sidebar-user { display: none; }
  .sidebar-menu-label { display: none; }
  .sidebar-signout { border-top: none; padding-top: 0; margin-top: 0; }
  .sidebar-nav-item { white-space: nowrap; border-left: none; border-bottom: 3px solid transparent; padding: 14px 20px; }
  .sidebar-nav-item:hover, .sidebar-nav-item.active { border-left: none; border-bottom-color: var(--secondary); padding-left: 20px; }
  .stat-cards { grid-template-columns: repeat(2,1fr); }

  /* Auth */
  .auth-page { grid-template-columns: 1fr; }
  .auth-image { display: none; }
  .auth-form-side { padding: 60px 40px; min-height: 100vh; }

  /* Service / location detail rows */
  .service-detail-row { grid-template-columns: 1fr; gap: 36px; }
  .service-detail-row.reverse { direction: ltr; }
  .location-detail-row { grid-template-columns: 1fr; gap: 36px; }
  .mission-grid { grid-template-columns: 1fr; }
  .quick-contact-grid { grid-template-columns: 1fr; }
}

/* ---- 768px ---- */
@media (max-width: 768px) {
  section { padding: 60px 0; }
  .container, .container-sm, .container-fluid { padding: 0 20px; }

  .logo-text { display: none; }

  .hero-title { font-size: clamp(2rem,8vw,2.8rem); }
  .hero-stats { gap: 24px; flex-wrap: wrap; }
  .hero-stat .stat-number { font-size: 1.8rem; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn { width: 100%; justify-content: center; }

  .search-field { flex: 1 1 100%; }

  .properties-grid { grid-template-columns: 1fr; }
  .properties-grid.cols-2 { grid-template-columns: 1fr; }
  .featured-header { flex-direction: column; align-items: flex-start; gap: 16px; }
  .services-grid { grid-template-columns: 1fr; }
  .locations-grid { grid-template-columns: 1fr; }
  .features-grid { grid-template-columns: 1fr; gap: 0; }

  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer-brand { grid-column: 1; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }

  .property-info-grid { grid-template-columns: repeat(2,1fr); }
  .gallery-main { height: 280px; }
  .gallery-thumbs { grid-template-columns: repeat(4,1fr); }
  .amenities-grid { grid-template-columns: 1fr 1fr; }
  .property-details-meta { flex-direction: column; align-items: flex-start; }

  .form-row { grid-template-columns: 1fr; }
  .cta-actions { flex-direction: column; align-items: center; }

  .stat-cards { grid-template-columns: repeat(2,1fr); }
  .dashboard-content { padding: 24px 20px; }
  .add-property-form { padding: 24px 20px; }

  .data-table-wrap { overflow-x: auto; }
  .data-table { min-width: 700px; }

  .page-hero { padding: 130px 0 60px; }
  .auth-form-side { padding: 40px 24px; }

  .location-stats { flex-wrap: wrap; gap: 20px; }
  .profile-avatar-section { flex-direction: column; text-align: center; }
}

/* ---- 480px ---- */
@media (max-width: 480px) {
  h1{font-size:1.9rem} h2{font-size:1.6rem} h3{font-size:1.3rem}
  .container, .container-sm, .container-fluid { padding: 0 16px; }

  .btn { padding: 12px 24px; font-size: 0.72rem; }
  .btn-lg { padding: 14px 30px; }
  section { padding: 50px 0; }
  .section-header { margin-bottom: 40px; }

  .hero-body { padding: 110px 0 40px; }
  .hero-stats { flex-direction: column; gap: 20px; padding-top: 28px; }

  .property-card-image { height: 200px; }
  .property-features { gap: 12px; flex-wrap: wrap; }

  .property-info-grid { grid-template-columns: 1fr 1fr; gap: 14px; padding: 20px; }
  .amenities-grid { grid-template-columns: 1fr; }

  .about-badge { display: none; }
  .about-image-accent { display: none; }

  .stat-cards { grid-template-columns: 1fr 1fr; gap: 14px; }
  .footer-social { flex-wrap: wrap; }
  .scroll-top { bottom: 20px; right: 20px; width: 42px; height: 42px; }

  .gallery-thumbs { grid-template-columns: repeat(4,1fr); gap: 5px; }
  .gallery-thumb { height: 60px; }
  .location-card { aspect-ratio: 3/2; }
  .agent-card-header { padding: 20px 18px; }
  .inquiry-form { padding: 20px 18px; }
  .sidebar-nav-item { padding: 12px 14px; font-size: 0.82rem; gap: 8px; }

  .quick-contact-grid { grid-template-columns: 1fr; }
  .auth-stats-strip { flex-direction: column; gap: 20px; }
}

@media print {
  .site-header, .site-footer, .scroll-top { display: none; }
  body { padding-top: 0; }
}
