/* ============================================
   NeoVids Responsive CSS
   Works alongside style.css
   ============================================ */

/* ------------------------------- */
/* Mobile Phones – ≤ 600px */
/* ------------------------------- */

@media (max-width: 600px) {
  main {
    padding: 88px 12px 32px;
  }

  .nv-header {
    height: 56px;
    padding: 0 10px;
  }

  .logo a {
    font-size: 1.2rem;
  }

  .header-search input {
    min-width: 90px;
    max-width: 120px;
    padding: 6px 10px;
    font-size: 0.75rem;
  }

  .nv-header nav {
    gap: 6px;
  }

  .nv-header nav a {
    padding: 6px 10px;
    font-size: 0.75rem;
  }

  /* Grid becomes single-column */
  .layout-grid,
  .watch-page {
    grid-template-columns: 1fr !important;
  }

  .video-grid {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  }

  .sidebar {
    order: -1;
  }

  .sidebar-card {
    padding: 12px;
    border-radius: 16px;
  }

  /* Video titles smaller */
  .video-card h2 {
    font-size: 0.85rem;
  }

  /* Watch page video scaling */
  .watch-page video {
    border-radius: 14px;
  }

  /* Forms smaller */
  .form-card {
    padding: 18px 16px;
  }

  .form-field input,
  .form-field textarea,
  .form-field select {
    font-size: 0.85rem;
  }

  /* Channel header */
  .channel-header {
    flex-direction: column;
    text-align: center;
    gap: 14px;
  }

  .channel-actions {
    margin-left: 0;
  }
}

/* ------------------------------- */
/* Tablets – 600px to 992px */
/* ------------------------------- */

@media (min-width: 600px) and (max-width: 992px) {
  .layout-grid {
    grid-template-columns: 1fr 0.9fr;
  }

  .video-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }

  .nv-header {
    height: 60px;
  }

  .watch-page {
    grid-template-columns: 1.7fr 1fr;
  }

  .form-card {
    max-width: 520px;
  }
}

/* ------------------------------- */
/* Small Laptops – 992px to 1400px */
/* ------------------------------- */

@media (min-width: 992px) and (max-width: 1400px) {
  .layout-grid {
    grid-template-columns: minmax(0, 2.3fr) minmax(260px, 1fr);
  }

  .video-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
}

/* ------------------------------- */
/* Large Monitors – 1400px+ */
/* ------------------------------- */

@media (min-width: 1400px) {

  main {
    max-width: 1600px;
  }

  .layout-grid {
    grid-template-columns: minmax(0, 3fr) minmax(320px, 1.2fr);
    gap: 28px;
  }

  .video-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 22px;
  }

  /* More breathing room */
  .sidebar-card {
    padding: 20px;
    border-radius: 24px;
  }

  /* Bigger watch page */
  .watch-page {
    grid-template-columns: minmax(0, 2.9fr) minmax(300px, 1.1fr);
    padding: 22px;
  }

  .watch-page video {
    border-radius: 18px;
  }

  /* Super wide screens get extra polish */
  body {
    background-size: 200% 200%;
  }
}

/* ------------------------------- */
/* Ultra-Wide & 4K (1800px+) */
/* ------------------------------- */

@media (min-width: 1800px) {
  main {
    max-width: 1900px;
    padding-top: 110px;
  }

  .layout-grid {
    grid-template-columns: minmax(0, 3.2fr) minmax(380px, 1.2fr);
  }

  .video-grid {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  }

  .nv-header {
    height: 72px;
    padding: 0 24px;
  }

  .logo a {
    font-size: 2rem;
  }

  .header-search input {
    min-width: 240px;
    font-size: 1rem;
  }
}
