/* ============================================================
   MOBILE RESPONSIVE OVERRIDES — loaded last to win specificity
   Tablet ≤ 900px, Phone ≤ 640px
   ============================================================ */

/* ---------- Prevent horizontal overflow globally ---------- */
html, body { max-width: 100vw; overflow-x: hidden; }
img, svg, video { max-width: 100%; }
.app { max-width: 100vw; overflow-x: hidden; }

/* ---------- LAPTOP (≤ 1200px) — hide big nav, shrink gaps ---------- */
@media (max-width: 1200px) {
  .topbar-inner { padding: 12px 20px; gap: 16px; }
  .navlinks { gap: 2px; }
  .navlink { padding: 7px 10px; font-size: 12.5px; }
  .navlink .ico { display: none; } /* text only → nav fits */
  .topbar-right { gap: 8px; }
  .topbar-right .btn { padding: 8px 12px; font-size: 12px; }

  .container, .container-narrow { padding: 0 24px; }
  .hero h1 { font-size: 64px; }
  .section-head h2 { font-size: 42px; }
}

/* ---------- TABLET/SMALL LAPTOP (≤ 1024px) — kill the 6-item nav entirely ---------- */
@media (max-width: 1024px) {
  .navlinks { display: none; } /* cleaner than cramming */
  .topbar-inner { gap: 12px; }
}

/* ============================================================
   TABLET (≤ 900px)
   ============================================================ */
@media (max-width: 900px) {
  .container,
  .container-narrow { padding: 0 18px; }

  /* Topbar — compact */
  .topbar-inner { padding: 10px 16px; gap: 12px; }
  .brand { font-size: 15px; }
  .brand img { width: 30px; height: 30px; }
  .navlinks { display: none; }
  .topbar-right { margin-left: auto; gap: 6px; }
  .topbar-right .btn { padding: 7px 12px; font-size: 12px; }
  .icon-btn { width: 34px; height: 34px; }
  .avatar-btn { width: 34px; height: 34px; }

  /* Hero */
  .hero { padding: 40px 0 56px; }
  .hero-grid { grid-template-columns: 1fr; gap: 28px; }
  .hero h1 { font-size: 48px; }
  .hero-sub { font-size: 16px; margin-bottom: 24px; }
  .hero-visual { max-width: 420px; margin: 0 auto; }
  .hero-meta { gap: 24px; margin-top: 32px; }
  .hero-meta .stat .n { font-size: 26px; }

  /* Section headers */
  .section { padding: 52px 0; }
  .section-head { flex-direction: column; align-items: flex-start; gap: 12px; margin-bottom: 24px; }
  .section-head h2 { font-size: 36px; }

  /* Grids: 3/4-up → 2-up */
  .feature-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .svc-grid { grid-template-columns: repeat(4, 1fr); }
  .product-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .provider-list { grid-template-columns: 1fr 1fr; }
  .portfolio-grid { grid-template-columns: repeat(3, 1fr); }
  .stat-grid { grid-template-columns: 1fr 1fr; }

  /* Explore — hide map on mobile, stack list */
  .explore-layout { grid-template-columns: 1fr; gap: 16px; }
  .map-wrap { display: none; }

  /* Profile */
  .profile-cover { height: 200px; margin: 0 -18px; }
  .profile-head { grid-template-columns: 1fr; text-align: left; gap: 16px; margin-top: -48px; padding-bottom: 20px; }
  .profile-avatar { width: 120px; height: 120px; border-width: 4px; }
  .profile-info h1 { font-size: 34px; }
  .profile-cta { padding-bottom: 0; flex-wrap: wrap; }
  .profile-grid { grid-template-columns: 1fr; gap: 24px; }
  .booking-rail { position: static; }

  /* Bookings / dashboards */
  .page-head { flex-direction: column; align-items: flex-start; padding: 24px 0 20px; }
  .page-head h1 { font-size: 38px; }
  .bookings-split { grid-template-columns: 1fr; gap: 20px; }
  .mini-cal { position: static; }
  .dash-grid { grid-template-columns: 1fr; gap: 18px; }
  .side-nav { position: static; display: flex; overflow-x: auto; padding: 8px; gap: 4px; }
  .side-nav .side-nav-label { display: none; }
  .side-nav-item { flex-shrink: 0; padding: 8px 14px; font-size: 12.5px; }
  .side-nav-item .c { margin-left: 6px; }

  /* Messages — stack list over chat */
  .msg-layout {
    grid-template-columns: 1fr;
    height: calc(100vh - 140px);
  }
  .conv-list { border-right: none; border-bottom: 1px solid var(--line); max-height: 240px; }
  .chat-body { padding: 16px 18px; }
  .chat-input { padding: 12px 16px; }

  /* Wizard */
  .wizard { grid-template-columns: 1fr; padding: 24px 0 60px; }
  .wiz-steps { position: static; display: flex; overflow-x: auto; gap: 8px; padding-bottom: 8px; }
  .wiz-step { flex-shrink: 0; padding: 10px 14px; min-width: 180px; }
  .wiz-panel { padding: 24px; }
  .wiz-panel h2 { font-size: 28px; }

  /* Product detail */
  .pd-layout { grid-template-columns: 1fr; gap: 24px; }
  .pd-info h1 { font-size: 30px; }
  .pd-price .p { font-size: 32px; }

  /* Checkout */
  .checkout-layout { grid-template-columns: 1fr; gap: 20px; }
  .checkout-card { padding: 22px; }

  /* Editor */
  .editor-layout { grid-template-columns: 1fr; gap: 20px; }
  .editor-main { padding: 22px; }
  .editor-preview { position: static; }

  /* Cart drawer */
  .cart-drawer { width: 100vw; }

  /* Auth */
  .auth-layout { grid-template-columns: 1fr; }
  .auth-visual { display: none; }
  .auth-side { padding: 32px 24px; }
  .auth-side h1 { font-size: 36px; }

  /* Footer */
  .footer { padding: 48px 0 28px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; margin-bottom: 32px; }
  .footer-tagline { font-size: 44px; margin-bottom: 32px; }
  .footer-bottom { flex-direction: column; gap: 8px; }

  /* Ticker */
  .ticker span { font-size: 30px; gap: 40px; }

  /* Search bar */
  .search-bar { flex-direction: column; border-radius: 20px; padding: 8px; align-items: stretch; }
  .search-cell { border-right: none; border-bottom: 1px solid var(--line); padding: 10px 16px; }
  .search-cell:last-of-type { border-bottom: none; }
  .search-submit { width: 100%; height: 44px; border-radius: 999px; margin: 6px 0 0; }

  /* Modal */
  .modal-overlay { padding: 16px; }
  .modal-head { padding: 20px 20px 0; }
  .modal-head h2 { font-size: 26px; }
  .modal-body { padding: 14px 20px 22px; }
  .time-grid { grid-template-columns: repeat(3, 1fr); }

  /* Tweaks panel — keep but smaller */
  .tweaks {
    width: calc(100vw - 24px);
    right: 12px;
    bottom: 12px;
    max-width: 320px;
  }

  /* Tables — horizontal scroll */
  .table { min-width: 620px; }
  .chart-card { overflow-x: auto; }

  /* Booking cards — allow wrapping */
  .booking-card {
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: 14px;
    padding: 16px;
  }
  .booking-card .price { grid-column: 1 / -1; font-size: 22px; }
  .booking-card > :nth-child(4) { grid-column: 1 / -1; }
}

/* ============================================================
   PHONE (≤ 640px)
   ============================================================ */
@media (max-width: 640px) {
  body { font-size: 13.5px; }
  .container, .container-narrow { padding: 0 14px; }

  /* Topbar */
  .topbar-inner { padding: 9px 12px; gap: 8px; }
  .brand span { display: none; } /* logo only on very small screens */
  .topbar-right .btn { padding: 6px 10px; font-size: 11.5px; }
  .topbar-right { gap: 4px; }

  /* Hero */
  .hero { padding: 28px 0 40px; }
  .hero h1 { font-size: 38px; line-height: 1; }
  .hero-sub { font-size: 15px; margin-bottom: 20px; }
  .hero-ctas { flex-direction: column; align-items: stretch; }
  .hero-ctas .btn { width: 100%; }
  .hero-card-float { display: none; } /* floating cards get cramped */
  .hero-visual { max-width: 320px; aspect-ratio: 1 / 1; }
  .hero-meta { gap: 20px; margin-top: 24px; }
  .hero-meta .stat .n { font-size: 22px; }

  /* Sections */
  .section { padding: 40px 0; }
  .section-head h2 { font-size: 28px; }

  /* Single-column grids */
  .feature-grid { grid-template-columns: 1fr; }
  .svc-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .svc-tile { font-size: 11px; padding: 10px; }
  .svc-tile .g { width: 34px; height: 34px; font-size: 16px; }
  .product-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .provider-list { grid-template-columns: 1fr; }
  .portfolio-grid { grid-template-columns: 1fr 1fr; }
  .stat-grid { grid-template-columns: 1fr; }

  /* Feature cards */
  .feature-card { padding: 22px 18px 20px; }
  .feature-card h3 { font-size: 26px; }

  /* Profile */
  .profile-cover { height: 160px; margin: 0 -14px; border-radius: 0 0 18px 18px; }
  .profile-avatar { width: 96px; height: 96px; }
  .profile-info h1 { font-size: 26px; }
  .profile-info .meta { gap: 10px; font-size: 12.5px; }
  .profile-tabs { overflow-x: auto; }
  .profile-tabs button { padding: 12px 12px; font-size: 13px; }

  /* Page head */
  .page-head h1 { font-size: 30px; }
  .market-head h1 { font-size: 30px; }

  /* Booking cards */
  .booking-card {
    grid-template-columns: auto 1fr;
    padding: 14px;
    gap: 10px;
  }
  .booking-card .date-block { width: 58px; padding: 8px; }
  .booking-card .date-block .d { font-size: 24px; }
  .booking-card .info .svc { font-size: 14px; }
  .booking-card .price { font-size: 20px; }

  /* Messages */
  .msg-layout { height: calc(100vh - 120px); border-radius: 12px; }
  .conv-list { max-height: 200px; }
  .conv-item { padding: 10px 14px; }
  .chat-body { padding: 14px; }
  .msg-bubble { max-width: 80%; }
  .chat-head { padding: 10px 14px; }
  .chat-head .actions { display: none; }

  /* Filters */
  .filters-row { gap: 6px; }
  .view-toggle { margin-left: 0; }
  .chip { padding: 6px 11px; font-size: 12px; }

  /* Status filters */
  .status-filters { overflow-x: auto; padding: 8px 0 14px; }
  .status-filters button { flex-shrink: 0; white-space: nowrap; }

  /* Product detail */
  .pd-thumbs { grid-template-columns: repeat(4, 1fr); }
  .pd-info h1 { font-size: 26px; }

  /* Checkout */
  .checkout-card { padding: 18px; }
  .checkout-card h2 { font-size: 24px; }

  /* Wizard */
  .wiz-panel { padding: 20px; }
  .wiz-panel h2 { font-size: 24px; }
  .wiz-step { min-width: 140px; }

  /* Cart drawer — full screen */
  .cart-drawer { width: 100vw; }
  .cart-head h3 { font-size: 22px; }
  .cart-item { grid-template-columns: 60px 1fr auto; gap: 10px; }

  /* Auth */
  .auth-side { padding: 24px 18px; }
  .auth-side h1 { font-size: 30px; }
  .auth-side .sub { font-size: 14px; margin-bottom: 22px; }
  .auth-social { grid-template-columns: 1fr; }

  /* OTP */
  .otp-cell { font-size: 22px; border-radius: 10px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 22px; margin-bottom: 28px; }
  .footer-tagline { font-size: 34px; }

  /* Ticker */
  .ticker span { font-size: 22px; gap: 28px; }

  /* Modal */
  .modal-overlay { padding: 8px; align-items: flex-end; }
  .modal { max-height: 92vh; border-radius: 22px 22px 0 0; }
  .modal-head h2 { font-size: 22px; }
  .step-dots { padding: 0 18px 12px; }
  .time-grid { grid-template-columns: repeat(3, 1fr); }

  /* Tweaks panel — bottom sheet style */
  .tweaks {
    width: calc(100vw - 16px);
    right: 8px;
    bottom: 8px;
    padding: 14px 16px;
  }

  /* Toast */
  .toast { bottom: 16px; font-size: 12.5px; padding: 10px 16px; max-width: calc(100vw - 32px); }

  /* Track steps */
  .track-steps { grid-template-columns: 1fr 1fr; gap: 16px; }
  .track-steps::before { display: none; }

  /* Time slots */
  .time-slot { padding: 8px; font-size: 12px; }

  /* Date picker */
  .date-picker .dp { font-size: 12px; }

  /* Service rows — vertical */
  .service-row { flex-wrap: wrap; gap: 10px; }
  .service-row .p { font-size: 20px; }

  /* Editor */
  .editor-row-2 { grid-template-columns: 1fr; }
  .editor-main { padding: 18px; }

  /* Phone preview — scale down the device frame so it fits */
  .phone-wrap { padding: 20px 10px; }
  .phone {
    width: min(390px, calc(100vw - 24px));
    height: min(780px, calc(100vh - 120px));
    border-radius: 40px;
    padding: 10px;
  }
  .phone-screen { border-radius: 30px; }

  /* Balance card / chart */
  .balance-card { padding: 22px; }
  .balance-card .big { font-size: 36px; }

  /* Avail row */
  .avail-row { grid-template-columns: 90px 1fr auto; gap: 10px; }
}

/* ============================================================
   VERY SMALL PHONE (≤ 380px) — final squeeze
   ============================================================ */
@media (max-width: 380px) {
  .hero h1 { font-size: 32px; }
  .section-head h2 { font-size: 24px; }
  .page-head h1 { font-size: 26px; }
  .product-grid { gap: 8px; }
  .svc-grid { grid-template-columns: 1fr 1fr; }
  .topbar-right .btn { padding: 5px 9px; font-size: 11px; }
  .icon-btn, .avatar-btn { width: 32px; height: 32px; }
  .otp-cell { font-size: 20px; }
}

/* ============================================================
   TOUCH — larger hit targets
   ============================================================ */
@media (hover: none) and (pointer: coarse) {
  .btn { min-height: 40px; }
  .btn-sm { min-height: 36px; }
  .chip { min-height: 34px; }
  .navlink, .side-nav-item, .mob-tab, .cal-cell, .time-slot { min-height: 36px; }
  .product-card .qadd { opacity: 1; transform: translateY(0); } /* always visible on touch */
}
