/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 1024px) {
  .feat-grid, .prog-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 34px; }
  .ghar-grid { gap: 40px; }
  .rankings-grid { grid-template-columns: 1fr; gap: 14px; }
}
@media (max-width: 768px) {
  /* Logos */
  .nav-logo img { height: 38px; max-width: 160px; }
  .footer-logo  { height: 44px; max-width: 180px; }

  /* Hide the top info bar on mobile — its email/phone live on the floating
     call button + footer, and Apply Now is in the deadline bar & bottom nav.
     (Also fixes the Apply Now button overflowing the row on narrow screens.) */
  .topbar { display: none; }

  .topbar-contacts { font-size: 11.5px; gap: 12px; }

  /* FIX #1: Mobile nav drawer — use flex + off-screen position instead of
     display:none so the right transition actually animates the slide-in. */
  .nav-list {
    display: flex; position: fixed;
    top: 0; right: -310px; width: 310px; height: 100vh;
    background: var(--WHITE); flex-direction: column; align-items: flex-start;
    padding: 0; box-shadow: -8px 0 40px rgba(0,0,0,.18);
    overflow-y: auto; transition: right .38s var(--R); z-index: 920;
    visibility: hidden;
  }
  .nav-list.on { right: 0; visibility: visible; }
  /* drawer header */
  .nav-list::before {
    content: '';
    display: block; width: 100%;
    height: 70px; min-height: 70px;
    background: linear-gradient(135deg, var(--P-DK), var(--P));
    flex-shrink: 0;
  }
  .nav-item { width: 100%; border-bottom: 1px solid var(--BORDER); }
  .nav-item:last-child { border-bottom: none; }
  /* show close-button wrapper in mobile drawer */
  .mob-nav-close-wrap { display: block; border-bottom: none; position: absolute; top: 0; right: 0; width: auto; }
  .nav-link {
    width: 100%; padding: 14px 20px;
    font-size: 14.5px; font-weight: 600; color: var(--INK);
    display: flex; justify-content: space-between;
  }
  .nav-link::after { display: none; }
  .nav-link .chev { font-size: 11px; }
  .drop, .mega { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: none; border-radius: 0; background: var(--BG); border-top: 1px solid var(--BORDER); display: none; width: 100%; padding: 8px 0; }
  .drop a { padding: 10px 32px; font-size: 13.5px; }
  .nav-item.mob-open .drop, .nav-item.mob-open .mega { display: block; }
  .mega-grid { grid-template-columns: 1fr; gap: 0; }
  .mega-col { padding: 0 20px; }
  .mega-col ul li a { padding: 8px 12px; font-size: 13px; }
  .ham { display: flex; }
  .nav-apply { display: none; }
  /* close btn inside nav-list */
  .mob-nav-close {
    display: flex;
    position: absolute; top: 18px; right: 16px;
    width: 36px; height: 36px; border-radius: 50%;
    background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.3);
    color: #fff; font-size: 16px; cursor: pointer;
    align-items: center; justify-content: center;
    transition: background .2s;
  }
  .mob-nav-close:hover { background: rgba(255,255,255,.3); }

  .sgrid { grid-template-columns: repeat(2,1fr); }
  .scell { border-right: none; border-bottom: 1px solid rgba(255,255,255,.07); }
  .scell:nth-child(2) { border-right: none; }
  .scell:nth-child(3), .scell:nth-child(4) { border-bottom: none; }

  .feat-grid { grid-template-columns: 1fr; }
  .ghar-grid { grid-template-columns: 1fr; gap: 32px; }
  .ghar-photos { height: 300px; }
  .prog-grid { grid-template-columns: 1fr; }
  .place-grid { grid-template-columns: 1fr; gap: 36px; }
  .place-photo-box img { height: 280px; }
  .faq-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .mob-nav { display: block; }
  body { padding-bottom: 58px; }
  .sec { padding: 60px 0; }
  .cta-sec { padding: 60px 0; }

  /* FIX #13: deadline-bar responsive (merged from duplicate block) */
  .deadline-bar { padding: 8px 0; }
  .deadline-txt { font-size: 12.5px; }
  .deadline-inner { gap: 10px; }

  /* Floating buttons — offset above mobile bottom nav (58px) */
  .wa-fab { bottom: 74px; }
  .call-fab { bottom: 136px; }
  .scroll-top { left: 22px; bottom: 70px; }
}
@media (max-width: 480px) {
  /* Logos */
  .nav-logo img { height: 32px; max-width: 140px; }
  .footer-logo  { height: 38px; max-width: 160px; }

  .pstat-grid { grid-template-columns: 1fr 1fr; }
  .ghar-photos { height: 240px; grid-template-columns: 1fr; }
  .gp:first-child { grid-row: auto; }
}
