/**
 * Tema compartido para tablas DataTables (index de usuarios, videos, etc.)
 *
 * Uso en cualquier index:
 * 1. Este archivo se carga en el layout default; no hace falta incluirlo de nuevo.
 * 2. En tu vista, envuelve la tabla en:
 *    <div class="panel datatable-panel px-0 pb-0"> ... <div class="datatable-wrapper px-4 sm:px-6"> <table id="tuId"> ...
 * 3. Si tienes filtros (ej. usuarios), pon la sección de filtros en un div con class "datatable-filters".
 * 4. Incluye los CSS de DataTables en la vista: jquery.dataTables.min.css y buttons.dataTables.min.css.
 * 5. Inicializa DataTables con dom que use las clases dt-top-row y dt-bottom-row para el mismo layout.
 * Ver app/views/users/index.html.erb y app/views/videos/index.html.erb como referencia.
 */

/* Panel y contenedor */
.datatable-panel {
  border-radius: 1.25rem;
  box-shadow: 0 4px 24px rgba(228, 102, 102, 0.08), 0 2px 8px rgba(0,0,0,0.04);
  border: 1px solid rgba(228, 102, 102, 0.12);
}
.dark .datatable-panel {
  box-shadow: 0 4px 24px rgba(0,0,0,0.2);
  border-color: rgba(255,255,255,0.06);
}

/* Contenedor de la tabla - responsive */
.datatable-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-top: 1rem;
}
.datatable-wrapper .dataTables_wrapper {
  padding: 0;
}
/* Fila superior: botones izquierda, buscador derecha (sin "show entries") */
.datatable-wrapper .row.dt-top-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1.5rem;
  margin-bottom: 1rem;
  padding: 0 1.25rem;
}
.datatable-wrapper .row.dt-top-row .dt-buttons { order: 1; }
.datatable-wrapper .row.dt-top-row .dataTables_filter { order: 2; margin-left: auto; }
/* Fila inferior: "mostrar X entradas", info y paginación */
.datatable-wrapper .row.dt-bottom-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 1rem;
  padding: 0 1.25rem 1rem;
}
@media (max-width: 640px) {
  .datatable-wrapper .row.dt-top-row {
    flex-direction: column;
    align-items: stretch;
  }
  .datatable-wrapper .row.dt-top-row .dataTables_filter { margin-left: 0; }
  .datatable-wrapper .row.dt-bottom-row {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }
}

/* Tabla: cualquier table dentro de .datatable-wrapper */
.datatable-wrapper table {
  width: 100% !important;
  border-collapse: separate;
  border-spacing: 0;
}
.datatable-wrapper thead th {
  background: linear-gradient(180deg, rgba(228,102,102,0.12) 0%, rgba(228,102,102,0.06) 100%) !important;
  color: #9f4a4a !important;
  font-weight: 600;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 1rem 1.25rem !important;
  border: none !important;
  border-bottom: 2px solid rgba(228,102,102,0.25) !important;
  white-space: nowrap;
}
.dark .datatable-wrapper thead th {
  color: #e8a0a0 !important;
  background: linear-gradient(180deg, rgba(228,102,102,0.18) 0%, rgba(228,102,102,0.08) 100%) !important;
}
.datatable-wrapper tbody td {
  padding: 1rem 1.25rem !important;
  border: none !important;
  border-bottom: 1px solid rgba(0,0,0,0.05) !important;
  font-size: 0.9375rem;
  vertical-align: middle !important;
}
.dark .datatable-wrapper tbody td {
  border-bottom-color: rgba(255,255,255,0.06) !important;
}
.datatable-wrapper tbody tr:hover td {
  background: rgba(228,102,102,0.06) !important;
}
.dark .datatable-wrapper tbody tr:hover td {
  background: rgba(228,102,102,0.12) !important;
}
.datatable-wrapper tbody tr:nth-child(even) td {
  background: rgba(250, 240, 242, 0.5);
}
.dark .datatable-wrapper tbody tr:nth-child(even) td {
  background: rgba(228,102,102,0.04);
}
.datatable-wrapper tbody tr:nth-child(even):hover td {
  background: rgba(228,102,102,0.1) !important;
}
.dark .datatable-wrapper tbody tr:nth-child(even):hover td {
  background: rgba(228,102,102,0.16) !important;
}

/* Filtros (sección superior) */
.datatable-filters label.text-sm {
  color: #64748b;
}
.dark .datatable-filters label.text-sm {
  color: #94a3b8;
}

/* Length select y search (fila inferior) */
.datatable-wrapper .dt-bottom-row .dataTables_length label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: #64748b;
}
.dark .datatable-wrapper .dataTables_length label { color: #94a3b8; }
.datatable-wrapper .dataTables_length select {
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(228,102,102,0.25);
  background: #fff;
  color: #334155;
  font-size: 0.875rem;
  min-width: 4.5rem;
}
.dark .datatable-wrapper .dataTables_length select {
  background: #1e293b;
  border-color: rgba(228,102,102,0.35);
  color: #e2e8f0;
}
.datatable-wrapper .dataTables_filter label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
}
.datatable-wrapper .dataTables_filter input {
  padding: 0.5rem 1rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(228,102,102,0.25);
  font-size: 0.875rem;
  min-width: 10rem;
}
.datatable-wrapper .dataTables_filter input:focus {
  outline: none;
  border-color: #E46666;
  box-shadow: 0 0 0 3px rgba(228,102,102,0.15);
}
.dark .datatable-wrapper .dataTables_filter input {
  background: #1e293b;
  border-color: rgba(228,102,102,0.35);
  color: #e2e8f0;
}

/* Botones de export (Copy, CSV, Excel, Print, Visibilidad) */
.datatable-wrapper .dt-buttons {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem 0.5rem;
}
.datatable-wrapper .dt-buttons .dt-button,
.datatable-wrapper .dt-buttons .btn {
  padding: 0.35rem 0.6rem !important;
  font-size: 0.875rem !important;
  font-weight: 500;
  background: transparent !important;
  border: none !important;
  color: #E46666 !important;
  border-radius: 0.375rem;
  transition: background 0.2s, color 0.2s;
}
.datatable-wrapper .dt-buttons .dt-button:hover,
.datatable-wrapper .dt-buttons .btn:hover {
  background: rgba(228,102,102,0.1) !important;
  color: #C45C4A !important;
}
.datatable-wrapper .dt-buttons .dt-button:first-child { margin-left: 0 !important; }
.datatable-wrapper .dt-button:before,
.datatable-wrapper .dt-button:after { content: none !important; }
.datatable-wrapper .dt-button-colvis {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.datatable-wrapper .dt-button-colvis::after {
  content: '';
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  margin-left: 2px;
}
.datatable-wrapper .dt-button-collection {
  border-radius: 0.5rem !important;
  border: 1px solid rgba(228,102,102,0.2) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1) !important;
  padding: 0.25rem !important;
}
.datatable-wrapper .dt-button-collection .dt-button {
  color: #334155 !important;
  padding: 0.4rem 0.75rem !important;
  border-radius: 0.375rem !important;
}
.datatable-wrapper .dt-button-collection .dt-button:hover {
  background: rgba(228,102,102,0.1) !important;
  color: #E46666 !important;
}

/* Paginación */
.datatable-wrapper .dataTables_paginate {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  justify-content: center;
}
.datatable-wrapper .dataTables_paginate .paginate_button {
  padding: 0.5rem 0.75rem !important;
  border-radius: 0.5rem !important;
  border: 1px solid rgba(228,102,102,0.25) !important;
  background: #fff !important;
  color: #64748b !important;
  font-size: 0.875rem !important;
  margin: 0 !important;
}
.dark .datatable-wrapper .dataTables_paginate .paginate_button {
  background: #1e293b !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #94a3b8 !important;
}
.datatable-wrapper .dataTables_paginate .paginate_button.current {
  background: linear-gradient(135deg, #E46666 0%, #C45C4A 100%) !important;
  border-color: transparent !important;
  color: #fff !important;
}
.datatable-wrapper .dataTables_paginate .paginate_button:hover {
  background: rgba(228,102,102,0.1) !important;
  border-color: #E46666 !important;
  color: #E46666 !important;
}
.datatable-wrapper .dataTables_info {
  font-size: 0.875rem;
  color: #64748b;
}
.dark .datatable-wrapper .dataTables_info { color: #94a3b8; }

/* Processing overlay */
.datatable-wrapper .dataTables_processing {
  border-radius: 1rem;
  background: linear-gradient(135deg, rgba(228,102,102,0.95) 0%, rgba(196,92,74,0.95) 100%) !important;
  color: #fff !important;
  border: none !important;
  padding: 1rem 1.5rem !important;
  font-weight: 500;
}
