/* Responsive CSS for EnjoyVideo Modern Theme */

/* Large Desktop */
@media only screen and (min-width: 1200px) {
  .container {
    max-width: 1400px;
  }
  
  .content-grid {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  }
  
  .hero-carousel {
  }
}

/* Desktop */
@media only screen and (min-width: 959px) and (max-width: 1199px) {
  .container {
    width: 98%;
  }

  .header-search {
    max-width: 500px;
  }

  #primary-menu li a {
    font-size: 0.9rem;
    padding: var(--spacing-sm) var(--spacing-sm);
  }

  .content-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }

  #primary {
    width: 70%;
  }

  .sidebar {
    width: 28%;
  }
}

/* Tablet and smaller desktop */
@media only screen and (max-width: 959px) {
  .mobile-menu-toggle {
    display: block;
  }

  .site-content:before {
    display: none;
    content: none;
  }

  .site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
  }

  .site-start {
    position: relative;
    padding: var(--spacing-sm) 0;
  }

  .header-search {
    order: 3;
    max-width: 100%;
    margin-top: var(--spacing-sm);
  }

  #page {
    width: 100%;
    margin-top: 80px;
  }

  .container {
    width: 96%;
    padding: 0 var(--spacing-md);
  }

  #primary,
  #secondary {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .site-footer {
    width: 100%;
  }

  #primary-bar,
  #secondary-nav {
    display: none;
  }

  .site-branding {
    padding-left: 1%;
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .site-branding #logo {
    margin: 0;
  }
  
  .site-branding img {
    width: auto;
    max-height: 50px;
  }
  
  .site-branding .site-title {
    font-size: 1.2em;
  }

  #primary-nav {
    display: none;
  }

  #primary {
    float: none;
  }

  #secondary {
    float: none;
    margin-top: 20px;
  }

  .sidebar .widget_ad,
  .site-footer .widget_ad {
    text-align: center;
  }

  #site-bottom {
    text-align: center;
  }
  
  #site-bottom .footer-nav {
    margin-top: var(--spacing-md);
  }
  
  #site-bottom .footer-nav ul li {
    margin: 0 var(--spacing-sm);
  }

  #back-top a span {
    width: 40px;
    height: 40px;
  }
}

/* Medium tablets */
@media only screen and (min-width: 768px) and (max-width: 959px) {
  .home .site-content {
    margin-top: 0;
  }

  .site-content {
    margin-top: 20px;
  }

  .hero-carousel {
    height: 60vh;
    min-height: 400px;
  }

  .content-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--spacing-md);
  }

  .movie-card .entry-title {
    font-size: 0.9rem;
  }

  .search-filters .filter-row {
    flex-direction: column;
    align-items: stretch;
  }

  .server-tabs {
    justify-content: center;
    flex-wrap: wrap;
  }
}

/* Mobile devices */
@media only screen and (max-width: 767px) {
  .top-menu {
    display: none;
  }

  .site-branding img {
    max-height: 40px;
  }

  .site-branding .site-title {
    font-size: 1.1em;
  }

  .site-branding .site-description {
    display: none;
  }

  .header-content {
    flex-wrap: wrap;
    gap: var(--spacing-sm);
  }

  .header-search {
    order: 3;
    width: 100%;
    max-width: 100%;
    margin-top: var(--spacing-sm);
  }

  .mobile-menu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    background: var(--tertiary-bg);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all var(--transition-fast);
  }

  .mobile-menu-toggle:hover {
    background: var(--accent-primary);
    border-color: var(--accent-primary);
  }

  .mobile-menu-toggle:hover .hamburger-line {
    background: var(--primary-bg);
  }

  /* Mobile Menu Responsive Adjustments */
  .mobile-menu-overlay {
    padding: var(--spacing-sm);
  }

  .mobile-menu-container {
    max-width: 100%;
    border-radius: 0;
    height: 100vh;
    max-height: 100vh;
  }

  .mobile-menu-header {
    padding: var(--spacing-md);
    min-height: 60px;
  }

  .mobile-search {
    padding: var(--spacing-md);
    top: 60px;
  }

  .mobile-navigation {
    padding: var(--spacing-md);
    flex: 1;
    min-height: 0;
  }

  .mobile-submenu-content {
    max-height: 45vh;
    border-radius: 0;
    margin: 0 calc(-1 * var(--spacing-md));
    padding: var(--spacing-md);
    overflow-y: auto;
  }

  .mobile-submenu-list {
    max-height: calc(45vh - 20px);
    overflow-y: auto;
  }
}

/* Small mobile devices */
@media only screen and (max-width: 480px) {
  .header-container {
    padding: 0 var(--spacing-md);
  }
  
  .header-content {
    padding: var(--spacing-sm) 0;
  }
  
  .site-title a {
    font-size: 1.3rem;
  }

  /* Mobile Menu Small Screen Adjustments */
  .mobile-menu-overlay {
    padding: 0;
  }

  .mobile-menu-container {
    border-radius: 0;
    border-left: none;
    border-right: none;
  }

  .mobile-menu-header {
    padding: var(--spacing-sm) var(--spacing-md);
  }

  .mobile-search {
    padding: var(--spacing-sm) var(--spacing-md);
  }

  .mobile-navigation {
    padding: var(--spacing-sm) var(--spacing-md);
  }

  .mobile-submenu-content {
    margin: 0 calc(-1 * var(--spacing-md));
    padding: var(--spacing-sm) var(--spacing-md);
  }


}

/* Very small mobile devices */
@media only screen and (max-width: 360px) {
  .mobile-menu-container {
    border-radius: 0;
    border: none;
    height: 100vh;
    max-height: 100vh;
  }

  .mobile-menu-header {
    padding: var(--spacing-sm);
    min-height: 50px;
  }

  .mobile-search {
    padding: var(--spacing-sm);
    top: 50px;
  }

  .mobile-navigation {
    padding: var(--spacing-sm);
    flex: 1;
    min-height: 0;
  }

  .mobile-submenu-content {
    max-height: 40vh;
    padding: var(--spacing-sm);
    overflow-y: auto;
  }

  .mobile-menu-link,
  .mobile-menu-accordion-toggle {
    padding: var(--spacing-sm);
    font-size: 0.9rem;
  }

  .mobile-submenu-link {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: 0.85rem;
  }

  .mobile-submenu-list {
    max-height: calc(40vh - 20px);
    overflow-y: auto;
  }
}



