/* ============================================
   MONIXI RESPONSIVE + ACCESSIBILITY LAYER
   Mobile-first, conflict-safe overrides
   ============================================ */

/* Base mobile defaults (<= 768 by default) */
.container {
  max-width: 100%;
  padding: 0 12px;
}

.topbar__inner {
  grid-template-columns: auto 1fr auto;
  gap: 6px;
  padding: 6px 8px;
}

.nav {
  display: none;
}

.desktop-only {
  display: none !important;
}

.mobile-only,
.mobilemenu-toggle,
.mobile-search-toggle {
  display: inline-flex !important;
}

.search.desktop-search {
  display: none;
}

.topbar.search-active .search.desktop-search {
  display: flex;
}

.topbar.search-active .brand--center {
  opacity: 0;
  visibility: hidden;
  width: 0;
  pointer-events: none;
}

.topbar.search-active .mobile-search-toggle {
  display: none !important;
}

.page {
  padding-top: calc(56px + env(safe-area-inset-top));
}

.results-grid,
.movies-grid,
.tv-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 8px;
}

.hero {
  min-height: 250px;
  padding: 14px 0;
}

.h1 {
  font-size: clamp(1.45rem, 6vw, 1.8rem);
}

body {
  font-size: 14px;
}

.h2 {
  font-size: clamp(1.05rem, 4.3vw, 1.35rem);
}

.p {
  font-size: 0.9rem;
}

.card {
  width: 148px;
}

/* .card__img height removed - now aspect-ratio controlled */

.card__title {
  font-size: 0.8rem;
}

.card__metaMini {
  font-size: 0.72rem;
}

.card__singleBtn,
.watch-linkbtn,
.btn {
  min-height: 34px;
  font-size: 0.78rem;
  padding: 0 10px;
}

.search-dropdown {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}

.footer__inner {
  flex-direction: column;
  gap: 14px;
}

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

/* Keep floating actions fixed on viewport */
.chat-float,
.scroll-top {
  position: fixed !important;
  left: auto !important;
  top: auto !important;
}

.chat-float {
  right: 14px !important;
  bottom: 14px !important;
}

.scroll-top {
  right: 14px !important;
  bottom: 70px !important;
}

/* --------------------------------------------
   Small phones (<= 420px)
   -------------------------------------------- */
@media (max-width: 420px) {
  .container {
    padding: 0 10px;
  }

  .topbar__inner {
    gap: 5px;
    padding: 5px 6px;
  }

  .page {
    padding-top: calc(52px + env(safe-area-inset-top));
  }

  .iconbtn {
    width: 34px;
    height: 34px;
    min-width: 34px;
  }

  .pill__btn {
    min-width: 30px;
    height: 30px;
    padding: 0 6px;
    font-size: 10px;
  }

  .search__input {
    min-width: 145px;
    font-size: 0.85rem;
  }

  .results-grid,
  .movies-grid,
  .tv-grid {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: 220px;
    padding: 12px 0;
  }

  .h1 {
    font-size: clamp(1.2rem, 6vw, 1.55rem);
  }

  .h2 {
    font-size: clamp(0.95rem, 4.5vw, 1.15rem);
  }

  .card {
    width: 138px;
  }

/* .card__img height removed - now aspect-ratio controlled */
}

/* --------------------------------------------
   Ultra small phones (<= 360px)
   -------------------------------------------- */
@media (max-width: 360px) {
  .topbar__inner {
    padding: 4px 5px;
    gap: 4px;
  }

  .search__input {
    min-width: 132px;
    font-size: 0.8rem;
  }

  .modal__card {
    width: min(460px, calc(100vw - 12px));
  }

  .hero {
    min-height: 200px;
  }

  .h1 {
    font-size: clamp(1.08rem, 5.8vw, 1.38rem);
  }

  .card {
    width: 130px;
  }

  .card__img {
    height: 182px;
  }
}

/* --------------------------------------------
   Tablets (>= 481px)
   -------------------------------------------- */
@media (min-width: 481px) {
  .container {
    padding: 0 20px;
  }

  .topbar__inner {
    padding: 10px 14px;
    gap: 10px;
  }

  .results-grid,
  .movies-grid,
  .tv-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px 12px;
  }

  .hero {
    min-height: 340px;
  }
}

/* --------------------------------------------
   Small laptops / landscape tablets (>= 769px)
   -------------------------------------------- */
@media (min-width: 769px) {
  .container {
    max-width: 1180px;
    padding: 0 24px;
  }

  .topbar__inner {
    grid-template-columns: min-content minmax(280px, 1fr) auto;
    gap: 14px;
    padding: 12px 18px;
  }

  .desktop-only {
    display: inline-flex !important;
  }

  .mobile-only,
  .mobilemenu-toggle,
  .mobile-search-toggle {
    display: none !important;
  }

  .nav {
    display: flex;
  }

  .search.desktop-search {
    display: flex;
    opacity: 1;
    visibility: visible;
  }

  .page {
    padding-top: calc(58px + env(safe-area-inset-top));
  }

  .results-grid,
  .movies-grid,
  .tv-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px 14px;
  }

  .chat-float {
    right: 18px !important;
    bottom: 18px !important;
  }

  .scroll-top {
    right: 20px !important;
    bottom: 80px !important;
  }
}

/* --------------------------------------------
   Desktop (>= 1025px)
   -------------------------------------------- */
@media (min-width: 1025px) {
  .container {
    max-width: 1320px;
    padding: 0 30px;
  }

  .results-grid,
  .movies-grid,
  .tv-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 22px 18px;
  }

  .hero {
    min-height: 430px;
  }
}

/* --------------------------------------------
   Large desktop (>= 1441px)
   -------------------------------------------- */
@media (min-width: 1441px) {
  .container {
    max-width: 1680px;
    padding: 0 40px;
  }

  .results-grid,
  .movies-grid,
  .tv-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 26px 22px;
  }
}

/* --------------------------------------------
   Landscape low-height devices
   -------------------------------------------- */
@media (max-height: 520px) and (orientation: landscape) {
  .topbar__inner {
    padding: 6px 10px;
  }

  .hero {
    min-height: 240px;
    padding: 14px 0;
  }

  .page {
    padding-top: calc(60px + env(safe-area-inset-top));
  }
}

/* --------------------------------------------
   Accessibility: reduced motion / touch size
   -------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

@media (hover: none) and (pointer: coarse) {
  button,
  a,
  .search-result-item,
  .card__singleBtn,
  .watch-linkbtn {
    min-height: 44px;
  }
}

/* --------------------------------------------
   Global accessibility for worldwide users
   1) RTL support
   2) Reduced data mode
   -------------------------------------------- */
html[dir="rtl"] .topbar__inner,
html[dir="rtl"] .section__head,
html[dir="rtl"] .section__head--home,
html[dir="rtl"] .watch-topbar,
html[dir="rtl"] .controls__row {
  direction: rtl;
}

html[dir="rtl"] .nav,
html[dir="rtl"] .topbar__right,
html[dir="rtl"] .topbar__left {
  flex-direction: row-reverse;
}

@media (prefers-reduced-data: reduce) {
  .hero__media,
  video,
  .player video {
    filter: none !important;
  }

  .hero::before,
  .details-hero::before,
  .player::after {
    display: none !important;
  }
}

/* --------------------------------------------
   Print
   -------------------------------------------- */
@media print {
  .topbar,
  .footer,
  .search-dropdown,
  .mobilemenu,
  .wa,
  .chat-float,
  .scroll-top {
    display: none !important;
  }

  .page {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .container {
    max-width: 100% !important;
    padding: 0 !important;
  }
}
