/* ═══════════════════════════════════════════════════════════════
   IDONEA DataTable — Estilo compartido para TODAS las tablas admin
   Basado en el estilo de NC Referencias (referencia aprobada)
   ═══════════════════════════════════════════════════════════════ */

:root {
    --idt-primary: #c41230;
    --idt-primary-dk: #a50f28;
    --idt-primary-soft: rgba(196, 18, 48, 0.06);
    --idt-primary-border: rgba(196, 18, 48, 0.12);
    --idt-ink: #1f2937;
    --idt-ink-50: #6b7280;
    --idt-ink-30: #9ca3af;
    --idt-border: #e5e7eb;
    --idt-surface: #f9fafb;
    --idt-blue: #1a56db;
    --idt-blue-soft: #e8f0fe;
    --idt-blue-border: #c3d3fc;
    --idt-red: #c81e1e;
    --idt-red-soft: #fde8e8;
    --idt-red-border: #f8b4b4;
    --idt-green: #15803d;
    --idt-green-soft: #e6f4ea;
    --idt-green-border: #a7d9b8;
    --idt-purple: #6d28d9;
    --idt-purple-soft: #ede9fe;
    --idt-purple-border: #c4b5fd;
    --idt-orange: #ea580c;
    --idt-orange-soft: rgba(234, 88, 12, 0.08);
}

/* ── Card container ── */
.idt-table-card {
    border-radius: 14px;
    border: 1px solid var(--idt-primary-border);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
    background: #fff;
    overflow: hidden;
}

.idt-table-card .card-header {
    background: var(--idt-primary-soft);
    border-bottom: 1px solid var(--idt-primary-border);
    padding: 14px 18px;
}

.idt-table-card .card-body {
    padding: 16px;
}

/* ── Tabla base ── */
.idt-table {
    width: 100% !important;
    margin-bottom: 0 !important;
    border-collapse: collapse !important;
}

.idt-table thead th {
    padding: 12px 14px !important;
    background: var(--idt-primary-soft) !important;
    color: var(--idt-ink) !important;
    font-weight: 600 !important;
    font-size: 0.82rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    border-bottom: 2px solid var(--idt-primary-border) !important;
    border-top: none !important;
    white-space: nowrap;
}

.idt-table tbody td {
    padding: 11px 14px !important;
    vertical-align: middle !important;
    font-size: 0.88rem !important;
    border-bottom: 1px solid #f0f0f0 !important;
    border-top: none !important;
    color: var(--idt-ink);
}

.idt-table tbody tr:hover td {
    background: rgba(196, 18, 48, 0.03) !important;
}

/* ── Botones de accion icon-only ── */
.idt-actions {
    display: flex;
    gap: 6px;
    justify-content: center;
    align-items: center;
}

.idt-btn-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: 0.88rem;
    border: 1px solid;
    cursor: pointer;
    transition: all 0.18s ease;
    text-decoration: none;
    padding: 0;
    line-height: 1;
}

.idt-btn-action:hover {
    transform: scale(1.1);
    text-decoration: none;
}

/* Ver */
.idt-btn-view {
    background: var(--idt-green-soft);
    color: var(--idt-green);
    border-color: var(--idt-green-border);
}
.idt-btn-view:hover {
    background: var(--idt-green);
    color: #fff;
    border-color: var(--idt-green);
    box-shadow: 0 2px 8px rgba(21, 128, 61, 0.28);
}

/* Editar */
.idt-btn-edit {
    background: var(--idt-blue-soft);
    color: var(--idt-blue);
    border-color: var(--idt-blue-border);
}
.idt-btn-edit:hover {
    background: var(--idt-blue);
    color: #fff;
    border-color: var(--idt-blue);
    box-shadow: 0 2px 8px rgba(26, 86, 219, 0.28);
}

/* Eliminar */
.idt-btn-delete {
    background: var(--idt-red-soft);
    color: var(--idt-red);
    border-color: var(--idt-red-border);
}
.idt-btn-delete:hover {
    background: var(--idt-red);
    color: #fff;
    border-color: var(--idt-red);
    box-shadow: 0 2px 8px rgba(200, 30, 30, 0.28);
}

/* Descargar */
.idt-btn-download {
    background: var(--idt-green-soft);
    color: var(--idt-green);
    border-color: var(--idt-green-border);
}
.idt-btn-download:hover {
    background: var(--idt-green);
    color: #fff;
    border-color: var(--idt-green);
    box-shadow: 0 2px 8px rgba(21, 128, 61, 0.28);
}

/* Reasignar */
.idt-btn-reassign {
    background: var(--idt-purple-soft);
    color: var(--idt-purple);
    border-color: var(--idt-purple-border);
}
.idt-btn-reassign:hover {
    background: var(--idt-purple);
    color: #fff;
    border-color: var(--idt-purple);
    box-shadow: 0 2px 8px rgba(109, 40, 217, 0.28);
}

/* Revisar */
.idt-btn-review {
    background: var(--idt-blue-soft);
    color: var(--idt-blue);
    border-color: var(--idt-blue-border);
}
.idt-btn-review:hover {
    background: var(--idt-blue);
    color: #fff;
    border-color: var(--idt-blue);
    box-shadow: 0 2px 8px rgba(26, 86, 219, 0.28);
}

/* Ocultar/Habilitar */
.idt-btn-toggle {
    background: var(--idt-orange-soft);
    color: var(--idt-orange);
    border-color: rgba(234, 88, 12, 0.25);
}
.idt-btn-toggle:hover {
    background: var(--idt-orange);
    color: #fff;
    border-color: var(--idt-orange);
    box-shadow: 0 2px 8px rgba(234, 88, 12, 0.28);
}

/* Seguimiento */
.idt-btn-track {
    background: var(--idt-purple-soft);
    color: var(--idt-purple);
    border-color: var(--idt-purple-border);
}
.idt-btn-track:hover {
    background: var(--idt-purple);
    color: #fff;
    border-color: var(--idt-purple);
    box-shadow: 0 2px 8px rgba(109, 40, 217, 0.28);
}

/* ── Badges de estado ── */
.idt-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-weight: 700;
    font-size: 0.75rem;
    padding: 4px 11px;
    border-radius: 999px;
    border: 1px solid;
    white-space: nowrap;
}

.idt-badge-success { background: rgba(34, 197, 94, 0.10); border-color: rgba(34, 197, 94, 0.25); color: #15803d; }
.idt-badge-danger  { background: rgba(239, 68, 68, 0.10); border-color: rgba(239, 68, 68, 0.25); color: #b91c1c; }
.idt-badge-warning { background: rgba(245, 158, 11, 0.12); border-color: rgba(245, 158, 11, 0.22); color: #b45309; }
.idt-badge-info    { background: rgba(59, 130, 246, 0.10); border-color: rgba(59, 130, 246, 0.25); color: #1d4ed8; }
.idt-badge-gray    { background: rgba(148, 163, 184, 0.10); border-color: rgba(148, 163, 184, 0.25); color: #64748b; }

/* ── DataTables wrapper overrides ── */
.idt-table-card .dataTables_wrapper {
    padding: 0;
}

.idt-table-card .dataTables_filter input,
.idt-table-card .dt-search input {
    border-radius: 8px !important;
    border: 1px solid #ddd !important;
    padding: 6px 12px !important;
    font-size: 0.88rem !important;
    transition: border-color 0.2s;
}

.idt-table-card .dataTables_filter input:focus,
.idt-table-card .dt-search input:focus {
    border-color: var(--idt-primary) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(196, 18, 48, 0.08) !important;
}

.idt-table-card .dataTables_length select,
.idt-table-card .dt-length select {
    border-radius: 8px !important;
    border: 1px solid #ddd !important;
    padding: 4px 8px !important;
    font-size: 0.88rem !important;
}

.idt-table-card .dataTables_info,
.idt-table-card .dt-info {
    font-size: 0.82rem !important;
    color: #888 !important;
    padding: 8px 0 !important;
}

/* ── Paginacion ── */
.idt-table-card .dataTables_wrapper .dt-layout-row:last-child {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 0 4px;
}

.idt-table-card .dt-paging ul.pagination,
.idt-table-card .dataTables_paginate ul.pagination {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 3px !important;
    margin: 0 !important;
    padding-left: 0 !important;
    list-style: none !important;
}

.idt-table-card .dt-paging .page-item,
.idt-table-card .dataTables_paginate .page-item {
    display: list-item !important;
}

.idt-table-card .dt-paging .page-link,
.idt-table-card .dataTables_paginate .page-link {
    display: block !important;
    padding: 0.35rem 0.7rem !important;
    font-size: 0.82rem !important;
    line-height: 1.5 !important;
    border-radius: 6px !important;
    border: 1px solid #dee2e6 !important;
    color: var(--idt-primary) !important;
    background-color: #fff !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: background-color 0.15s, border-color 0.15s, color 0.15s;
    white-space: nowrap;
    user-select: none;
    font-weight: 500;
}

.idt-table-card .dt-paging .page-link:hover,
.idt-table-card .dataTables_paginate .page-link:hover {
    background-color: rgba(196, 18, 48, 0.06) !important;
    border-color: var(--idt-primary) !important;
    color: var(--idt-primary) !important;
}

.idt-table-card .dt-paging .page-item.active .page-link,
.idt-table-card .dt-paging .page-item.current .page-link,
.idt-table-card .dataTables_paginate .page-item.active .page-link {
    background-color: var(--idt-primary) !important;
    border-color: var(--idt-primary) !important;
    color: #fff !important;
    font-weight: 600 !important;
}

.idt-table-card .dt-paging .page-item.disabled .page-link,
.idt-table-card .dataTables_paginate .page-item.disabled .page-link {
    color: #adb5bd !important;
    pointer-events: none !important;
    background-color: #f8f9fa !important;
    border-color: #e9ecef !important;
}

/* ── Tags de datos inline ── */
.idt-tag-blue {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 8px;
    font-size: 0.78rem;
    font-weight: 600;
    background: #f0f4ff;
    color: #3b5998;
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.idt-tag-purple {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    background: #f5f3ff;
    color: #6d28d9;
}

.idt-tag-green {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    background: #ecfdf5;
    color: #15803d;
}

/* ── Responsive ── */
@media (max-width: 768px) {
    .idt-table thead th {
        font-size: 0.75rem !important;
        padding: 10px 10px !important;
    }
    .idt-table tbody td {
        font-size: 0.82rem !important;
        padding: 9px 10px !important;
    }
    .idt-btn-action {
        width: 28px;
        height: 28px;
        font-size: 0.78rem;
    }
}
