/* =====================================================================
   mobile.css — Responsive / Mobile styles for Standard MI
   Cargado DESPUÉS del <style> embebido en cada template.
   ===================================================================== */

/* ─── Hamburger button (oculto en desktop) ─── */
.mobile-menu-btn {
  display: none;
  position: fixed;
  top: 14px;
  left: 14px;
  z-index: 1001;
  background: #0A0A0A;
  border: none;
  border-radius: 10px;
  padding: 10px 12px;
  cursor: pointer;
  color: #FFFFFF;
  line-height: 1;
  font-size: 18px;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
}

/* ─── Overlay detrás del drawer ─── */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 999;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.sidebar-overlay.open { display: block; }

/* ─── Botón cierre dentro del sidebar ─── */
.sidebar-close-btn {
  display: none;
  background: none;
  border: none;
  color: #6B7280;
  font-size: 20px;
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
  margin-left: auto;
}

/* ─── Mobile table cards (generadas por JS) ─── */
.mobile-table-cards {
  display: none; /* visible solo en mobile via media query */
}

/* =====================================================================
   BREAKPOINT MOBILE — ≤768px
   ===================================================================== */
@media (max-width: 768px) {

  /* ── Raíz: nada desborda horizontalmente ── */
  html, body {
    overflow-x: hidden;
    max-width: 100%;
  }

  .container {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  /* Inputs y selects no desbordan */
  input, select, textarea, button {
    max-width: 100%;
    box-sizing: border-box;
  }

  /* ── Hamburger visible ── */
  .mobile-menu-btn { display: flex; }
  .sidebar-close-btn { display: block; }

  /* ── Sidebar → off-canvas drawer ── */
  .sidebar {
    position: fixed !important;
    width: 220px !important;
    height: 100vh !important;
    transform: translateX(-100%);
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 1000;
  }
  .sidebar.open { transform: translateX(0); }

  /* Fila brand + botón cierre */
  .sidebar-brand {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    margin-bottom: 16px !important;
  }

  /* ── Main: sin margen izquierdo + espacio para hamburger ── */
  .main {
    margin-left: 0 !important;
    padding: 16px !important;
    padding-top: 58px !important;
  }

  /* ── Page header apilado ── */
  .page-header {
    flex-direction: column !important;
    gap: 14px !important;
    margin-bottom: 20px !important;
  }
  .page-header-left h1 { font-size: 22px !important; }
  .page-header-right { flex-wrap: wrap; gap: 8px !important; }

  /* ── Grids de KPIs → 2 columnas ── */
  .kpi-grid        { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .stats-bar       { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .metrics-grid    { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }

  /* ── Grids de cards → 1 columna ── */
  .creator-grid    { grid-template-columns: 1fr !important; gap: 12px !important; }
  .brands-grid     { grid-template-columns: 1fr !important; gap: 12px !important; }
  .company-grid    { grid-template-columns: 1fr !important; gap: 12px !important; }
  .agency-grid     { grid-template-columns: 1fr !important; gap: 12px !important; }

  /* ── Filtros wrap ── */
  .filter-row-top,
  .filter-row-bottom,
  .filter-row,
  .filter-bar { flex-wrap: wrap !important; gap: 8px !important; }

  .filter-search,
  .search-input,
  .filter-dropdown,
  .sort-dropdown,
  .filter-select,
  .advanced-search-toggle {
    max-width: 100% !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* ── Quick filter tabs (videos) — wrap en lugar de desbordar ── */
  .quick-filters { flex-wrap: wrap !important; gap: 8px !important; }
  .filter-tab    { font-size: 12px !important; padding: 6px 10px !important; }

  /* ── Card meta row — wrap ── */
  .card-meta { flex-wrap: wrap !important; gap: 6px !important; }

  /* ── Thumbnail de vídeo — más pequeño en mobile ── */
  .card-thumbnail {
    width: 120px !important;
    height: 68px !important;
    flex-shrink: 0 !important;
  }

  /* ── Tabs de navegación: scroll horizontal (aceptable para barra de tabs) ── */
  .tabs-row, .tab-strip, .tab-bar {
    overflow-x: auto;
    flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch;
  }
  .tab-btn, .tab-item { white-space: nowrap; flex-shrink: 0; }

  /* ── Layouts de detalle ── */
  .video-meta-grid  { grid-template-columns: 1fr !important; }
  .two-col-layout   { flex-direction: column !important; }
  .col-left, .col-right { width: 100% !important; }
  .workflow-grid, .pipeline-grid { grid-template-columns: 1fr !important; }
  .form-row  { flex-direction: column !important; gap: 10px !important; }
  .form-col  { width: 100% !important; }

  /* ── Tablas: ocultar, mostrar cards JS ── */
  .table-scroll table { display: none !important; }
  .mobile-table-cards { display: block !important; }

  /* ─── Estilos de las tarjetas generadas por JS ─── */
  .mobile-table-card {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    border-radius: 14px;
    padding: 14px 16px;
    margin-bottom: 10px;
  }

  .mtc-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 6px 0;
    border-bottom: 1px solid #F3F4F6;
    gap: 12px;
    min-height: 28px;
  }
  .mtc-row:last-child { border-bottom: none; }

  .mtc-label {
    font-size: 10px;
    font-weight: 700;
    color: #9CA3AF;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 80px;
    padding-top: 3px;
  }

  .mtc-value {
    font-size: 13px;
    color: #374151;
    text-align: right;
    flex: 1;
    word-break: break-word;
  }

  /* Celda de ancho completo (colspan, mensaje vacío, etc.) */
  .mtc-full {
    justify-content: center;
    color: #9CA3AF;
    font-size: 13px;
    text-align: center;
    padding: 10px 0;
  }

  /* Links dentro de values */
  .mtc-value a {
    color: #2563EB;
    text-decoration: none;
  }

  /* Badges y pills dentro de values */
  .mtc-value .badge,
  .mtc-value .score-pill,
  .mtc-value .tipo-badge,
  .mtc-value .conf-badge,
  .mtc-value .model-badge {
    display: inline-flex;
  }
}

/* =====================================================================
   BREAKPOINT TELÉFONO PEQUEÑO — ≤480px
   ===================================================================== */
@media (max-width: 480px) {
  .kpi-grid     { grid-template-columns: 1fr !important; }
  .stats-bar    { grid-template-columns: 1fr !important; }
  .metrics-grid { grid-template-columns: 1fr !important; }
  .page-header-left h1 { font-size: 19px !important; }
  .mtc-label { min-width: 70px; }
}
