:root {
    --bg-primary: #1D1E1F;
    --bg-panel: #292a2a;
    --border: #4e453e;
    --accent: #bda38c;
    --accent-hover: #a89178;
    --accent-text: #4c3928;
    --text-muted: #9a8f86;
    --text-faint: #5a5a5a;
    --status-ok: #4ade80;
    --status-warn: #fbbf24;
    --status-bad: #f87171;
    --status-info: #60a5fa;
}

* { box-sizing: border-box; }
body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", sans-serif; -webkit-font-smoothing: antialiased; }

.sidebar { width: 14rem; background: var(--bg-primary); border-right: 1px solid var(--border); display: flex; flex-direction: column; flex-shrink: 0; }
.topbar { height: 3.5rem; background: var(--bg-panel); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; padding: 0 1rem; flex-shrink: 0; }

.nav-item { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 6px; color: #fff; font-size: 13px; text-decoration: none; border: 1px solid transparent; transition: background-color .15s, border-color .15s; }
.nav-item i { font-size: 16px; color: var(--text-muted); }
.nav-item:hover { background: var(--bg-panel); border-color: var(--border); }
.nav-item.active { background: var(--accent); color: var(--accent-text); font-weight: 500; }
.nav-item.active i { color: var(--accent-text); }

.panel { background: var(--bg-panel); border: 1px solid var(--border); border-radius: 8px; padding: 16px; }
.panel-titulo { color: #fff; font-size: 14px; font-weight: 500; margin: 0 0 12px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.form-input { width: 100%; background: var(--bg-primary); border: 1px solid var(--border); border-radius: 6px; color: #fff; padding: 8px 10px; font-size: 13px; outline: none; }
.form-input:focus { border-color: var(--accent); }
.btn-primary { background: var(--accent); color: var(--accent-text); border-radius: 6px; padding: 8px 12px; font-size: 13px; font-weight: 600; transition: background-color .15s; display: inline-flex; align-items: center; justify-content: center; gap: 6px; }
.btn-primary:hover { background: var(--accent-hover); }
.btn-primary:disabled { opacity: .65; cursor: not-allowed; }
.btn-secondary { background: var(--border); color: #fff; border-radius: 6px; padding: 7px 10px; font-size: 12px; font-weight: 500; display: inline-flex; align-items: center; gap: 6px; text-decoration: none; }
.btn-secondary:hover { background: #5f544b; }
.kpi-card { background: var(--bg-panel); border: 1px solid var(--border); border-radius: 10px; padding: 16px; }
.kpi-label { color: var(--text-muted); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; }
.kpi-value { color: #fff; font-size: 24px; line-height: 1.2; font-weight: 700; margin-top: 6px; }
.kpi-help { color: var(--text-faint); font-size: 11px; margin-top: 4px; }
.pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 2px 8px; font-size: 11px; font-weight: 600; }
.pill-ok { background: rgba(74, 222, 128, .15); color: var(--status-ok); }
.pill-info { background: rgba(96, 165, 250, .15); color: var(--status-info); }
.pill-muted { background: rgba(154, 143, 134, .15); color: var(--text-muted); }
.pill-bad { background: rgba(248, 113, 113, .15); color: var(--status-bad); }
.table-wrap { overflow-x: auto; }
table.dataTable { color: #fff; font-size: 12px; }
table.dataTable thead th { color: var(--text-muted); border-bottom: 1px solid var(--border) !important; }
table.dataTable tbody td { border-bottom: 1px solid rgba(78, 69, 62, .55) !important; }
.dt-container .dt-input, .dt-container .dt-select { background: var(--bg-primary) !important; border: 1px solid var(--border) !important; color: #fff !important; border-radius: 6px !important; }
.dt-container .dt-search label, .dt-container .dt-length label, .dt-container .dt-info { color: var(--text-muted) !important; font-size: 12px; }
.empty-state { text-align: center; color: var(--text-muted); padding: 30px 15px; }

@media (max-width: 768px) {
    .sidebar { width: 4.25rem; }
    .nav-item { justify-content: center; }
    .nav-item span, .sidebar .text-sm, .sidebar .text-[10px] { display: none; }
    .topbar { padding: 0 .75rem; }
}

/* DataTables homologado con el patrón visual del CRM principal */
.tabla-responsive {
    width: 100%;
    overflow-x: auto;
}

.tabla-crm {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    color: #fff;
    font-size: 12px;
}

.tabla-crm thead th {
    background: rgba(29, 30, 31, .65);
    color: var(--text-muted);
    border-bottom: 1px solid var(--border) !important;
    font-weight: 600;
    white-space: nowrap;
    padding: 10px 12px;
}

.tabla-crm tbody td {
    border-bottom: 1px solid rgba(78, 69, 62, .55) !important;
    padding: 10px 12px;
    vertical-align: middle;
}

.tabla-crm tbody tr:hover {
    background: rgba(189, 163, 140, .06);
}

.producto-thumb {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    object-fit: cover;
    border: 1px solid rgba(189, 163, 140, .35);
    background: var(--bg-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
}

.producto-thumb-empty i {
    font-size: 20px;
}

.dt-container {
    color: #fff !important;
}

.dt-container .dt-layout-row {
    gap: 12px;
    margin: 10px 0;
}

.dt-container .dt-input,
.dt-container .dt-select {
    background: var(--bg-primary) !important;
    border: 1px solid var(--border) !important;
    color: #fff !important;
    border-radius: 6px !important;
    padding: 6px 8px !important;
}

.dt-container .dt-search label,
.dt-container .dt-length label,
.dt-container .dt-info {
    color: var(--text-muted) !important;
    font-size: 12px;
}

.dt-container .dt-paging .dt-paging-button {
    color: #fff !important;
    border: 1px solid transparent !important;
    border-radius: 6px !important;
    padding: 4px 8px !important;
}

.dt-container .dt-paging .dt-paging-button.current,
.dt-container .dt-paging .dt-paging-button.current:hover {
    background: var(--accent) !important;
    color: var(--accent-text) !important;
    border-color: var(--accent) !important;
}

.dt-container .dt-paging .dt-paging-button:hover {
    background: var(--border) !important;
    color: #fff !important;
    border-color: var(--border) !important;
}

.dt-container .dt-empty {
    color: var(--text-muted) !important;
    padding: 30px 15px !important;
    text-align: center !important;
}

/* Fase 2: consulta robusta y detalles solo lectura */
.kpi-icon {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: rgba(189, 163, 140, .13);
    color: var(--accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}

.pill-warn {
    background: rgba(251, 191, 36, .15);
    color: var(--status-warn);
}

.btn-icon {
    background: rgba(189, 163, 140, .12);
    color: var(--accent);
    border: 1px solid rgba(189, 163, 140, .3);
    border-radius: 6px;
    padding: 5px 8px;
    font-size: 11px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap;
}

.btn-icon:hover {
    background: rgba(189, 163, 140, .2);
}

.btn-icon:disabled {
    opacity: .6;
    cursor: wait;
}

.mini-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    color: #fff;
    font-size: 12px;
}

.mini-table th {
    color: var(--text-muted);
    background: rgba(29, 30, 31, .55);
    font-weight: 600;
    text-align: left;
    padding: 8px 10px;
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
}

.mini-table td {
    padding: 8px 10px;
    border-bottom: 1px solid rgba(78, 69, 62, .45);
    vertical-align: middle;
}

.detail-modal {
    color: #fff;
    font-size: 13px;
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 14px;
    margin-bottom: 16px;
}

.detail-section {
    border-top: 1px solid rgba(78, 69, 62, .75);
    padding-top: 14px;
    margin-top: 14px;
}

.detail-section h3 {
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    margin: 0 0 10px;
}

.detail-section p {
    color: var(--text-muted);
    line-height: 1.5;
    margin: 0;
}

.detail-images {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.detail-image {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    color: var(--text-muted);
    font-size: 11px;
}

.logo-preview {
    min-height: 190px;
    border: 1px dashed rgba(189, 163, 140, .35);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(29, 30, 31, .45);
    overflow: hidden;
}

.logo-preview img {
    max-width: 100%;
    max-height: 180px;
    object-fit: contain;
}

.logo-empty {
    color: var(--text-muted);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    font-size: 12px;
}

.logo-empty i {
    font-size: 32px;
}

.swal2-popup .swal2-title {
    color: #fff;
    font-size: 18px;
}

@media (max-width: 768px) {
    .detail-grid {
        grid-template-columns: 1fr;
    }
}

.form-section-title {
    color: #bda38c;
    font-size: 0.82rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    letter-spacing: 0.02em;
}

.form-label {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    color: #9a8f86;
    font-size: 0.75rem;
}

.form-input {
    width: 100%;
    border: 1px solid #4e453e;
    background: #1d1e1f;
    color: #fff;
    border-radius: 0.65rem;
    padding: 0.62rem 0.75rem;
    outline: none;
    font-size: 0.82rem;
}

.form-input:focus {
    border-color: #bda38c;
    box-shadow: 0 0 0 2px rgba(189, 163, 140, 0.16);
}

.form-help {
    color: #9a8f86;
    font-size: 0.72rem;
    margin-top: 0.6rem;
    line-height: 1.45;
}

.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border-radius: 0.65rem;
    background: #bda38c;
    color: #4c3928;
    font-weight: 700;
    font-size: 0.78rem;
    padding: 0.68rem 0.95rem;
}

.btn-primary:hover {
    background: #a89178;
}

.tabla-acciones-proveedor {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: center;
    justify-content: center;
}

.panel-alert,
.panel-note {
    display: flex;
    gap: 0.65rem;
    align-items: flex-start;
    border: 1px solid rgba(189, 163, 140, 0.34);
    background: rgba(189, 163, 140, 0.08);
    color: #d6c8b9;
    border-radius: 0.85rem;
    padding: 0.8rem;
    font-size: 0.78rem;
    line-height: 1.45;
}

.panel-alert strong {
    color: #fff;
    display: block;
    margin-bottom: 0.15rem;
}

.panel-alert i,
.panel-note i {
    color: #bda38c;
    font-size: 1.1rem;
    margin-top: 0.1rem;
}

.panel-header-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 0.85rem;
}

.productos-check-list {
    max-height: 58vh;
    overflow: auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 0.7rem;
    padding-right: 0.2rem;
}

.producto-check-item {
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: center;
    gap: 0.75rem;
    border: 1px solid #3a3531;
    background: #202122;
    border-radius: 0.95rem;
    padding: 0.75rem;
    cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease;
}

.producto-check-item:hover {
    border-color: #bda38c;
    background: #272829;
}

.producto-check-item input {
    accent-color: #bda38c;
}

.producto-check-item strong {
    display: block;
    color: #fff;
    font-size: 0.86rem;
    line-height: 1.25;
}

.producto-check-item small {
    display: block;
    color: #9a8f86;
    font-size: 0.72rem;
    margin-top: 0.15rem;
}

.producto-lote-card {
    border: 1px solid #3a3531;
    background: #202122;
    border-radius: 1rem;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.producto-lote-head {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    border-bottom: 1px solid #35302c;
    padding-bottom: 0.8rem;
}

.producto-lote-head h3 {
    color: #fff;
    font-weight: 700;
    font-size: 1rem;
    margin: 0;
}

.producto-lote-head p {
    color: #9a8f86;
    font-size: 0.74rem;
    margin: 0.15rem 0 0;
}

/* Solicitudes de imágenes dentro de bloques de productos */
.producto-imagenes-solicitud {
    margin-top: 16px;
    border: 1px solid rgba(189, 163, 140, 0.22);
    border-radius: 16px;
    padding: 14px;
    background: rgba(255,255,255,0.025);
}
.producto-imagenes-solicitud h4 {
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    margin: 0;
}
.producto-imagenes-solicitud p {
    color: #9a8f86;
    font-size: 12px;
    margin: 3px 0 0;
}
 .producto-imagenes-grid {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
    margin-top: 12px;
}
.producto-imagenes-grid.nuevas {
    margin-top: 10px;
}
.producto-imagen-edit-card {
    position: relative;
    width: 124px;
    border: 1px solid #4e453e;
    border-radius: 12px;
    padding: 8px;
    background: rgba(0,0,0,0.18);
}
.producto-imagen-edit-card.nueva {
    border-color: rgba(22, 163, 74, 0.5);
}
.producto-imagen-frame {
    position: relative;
    width: 96px;
    height: 96px;
    margin: 0 auto;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #4e453e;
    background: #1d1e1f;
}
.producto-imagen-frame.is-principal {
    border-color: #bda38c;
}
.producto-imagen-edit-card .producto-thumb {
    width: 100%;
    height: 100%;
    border-radius: 0;
    object-fit: cover;
}
.img-badge {
    position: absolute;
    top: 4px;
    left: 4px;
    border-radius: 5px;
    padding: 2px 5px;
    font-size: 9px;
    font-weight: 700;
    line-height: 1;
    z-index: 2;
}
.img-badge.principal {
    background: #bda38c;
    color: #4c3928;
}
.img-badge.nueva {
    background: rgba(22, 163, 74, 0.88);
    color: #ecfdf5;
}
.img-badge.eliminar {
    background: rgba(220, 38, 38, 0.9);
    color: #fff;
}
.img-badge.hidden {
    display: none;
}
.producto-imagen-edit-info {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-top: 7px;
    font-size: 11px;
    color: #d6c8b9;
}
.inline-check {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
}


/* Checkbox visual unificado para edición de imágenes */
.inline-check input[type="checkbox"],
.producto-check-item input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    min-width: 16px;
    border: 1px solid #6b5d52;
    border-radius: 5px;
    background: #171819;
    display: inline-grid;
    place-content: center;
    cursor: pointer;
    transition: background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, opacity 0.16s ease;
    vertical-align: middle;
    margin: 0;
}

.inline-check input[type="checkbox"]::before,
.producto-check-item input[type="checkbox"]::before {
    content: "";
    width: 9px;
    height: 9px;
    transform: scale(0);
    transition: transform 0.12s ease-in-out;
    clip-path: polygon(14% 44%, 0 62%, 42% 100%, 100% 16%, 82% 0, 38% 62%);
    background: #1f1b17;
}

.inline-check input[type="checkbox"]:checked,
.producto-check-item input[type="checkbox"]:checked {
    background: #bda38c;
    border-color: #bda38c;
    box-shadow: 0 0 0 3px rgba(189, 163, 140, 0.16);
}

.inline-check input[type="checkbox"]:checked::before,
.producto-check-item input[type="checkbox"]:checked::before {
    transform: scale(1);
}

.inline-check input[type="checkbox"]:focus-visible,
.producto-check-item input[type="checkbox"]:focus-visible {
    outline: none;
    border-color: #d7c1aa;
    box-shadow: 0 0 0 3px rgba(189, 163, 140, 0.22);
}

.inline-check input[type="checkbox"]:disabled,
.producto-check-item input[type="checkbox"]:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    background: #272829;
    border-color: #4e453e;
    box-shadow: none;
}

.inline-check input[type="checkbox"]:disabled::before,
.producto-check-item input[type="checkbox"]:disabled::before {
    background: #9a8f86;
}

.inline-check {
    user-select: none;
}

.inline-check:has(input[type="checkbox"]:disabled) {
    cursor: not-allowed;
    color: #7f746c;
}

.inline-check.text-red-300 input[type="checkbox"]:checked {
    background: #dc2626;
    border-color: #ef4444;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.16);
}

.inline-check.text-red-300 input[type="checkbox"]:checked::before {
    background: #fff;
}

.form-input-xs {
    min-height: 32px !important;
    padding: 6px 8px !important;
    font-size: 12px !important;
}
.btn-mini-danger {
    border: 1px solid rgba(220, 38, 38, 0.55);
    color: #fecaca;
    border-radius: 10px;
    padding: 5px 8px;
    font-size: 12px;
    background: rgba(220,38,38,0.08);
}
.empty-state.compact {
    padding: 16px;
    font-size: 12px;
}
.solicitud-img-preview {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.solicitud-img-preview img {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid #4e453e;
    background: #1f2020;
}
.solicitud-img-preview small {
    display: block;
    color: #9a8f86;
    margin-top: 2px;
}
.paste-drop-zone {
    border: 1px dashed rgba(189, 163, 140, 0.65);
    border-radius: 14px;
    padding: 18px 16px;
    margin-top: 12px;
    min-height: 118px;
    color: #d6c8b9;
    background: rgba(189, 163, 140, 0.08);
    font-size: 12px;
    outline: none;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    text-align: center;
}
.paste-drop-zone:focus {
    border-color: #bda38c;
    box-shadow: 0 0 0 3px rgba(189, 163, 140, 0.15);
}
.paste-drop-zone i {
    font-size: 24px;
    color: #bda38c;
}
.paste-drop-zone strong {
    color: #fff;
    font-size: 13px;
}
.paste-drop-zone span {
    color: #9a8f86;
    font-size: 12px;
}
.form-select-imagen {
    width: 100%;
    border: 1px solid #4e453e;
    background: #1d1e1f;
    color: #fff;
    border-radius: 0.65rem;
    padding: 0.52rem 0.68rem;
    outline: none;
    font-size: 0.78rem;
}
.form-select-imagen:focus {
    border-color: #bda38c;
    box-shadow: 0 0 0 2px rgba(189, 163, 140, 0.16);
}
.form-select-imagen:disabled {
    opacity: 0.65;
    cursor: not-allowed;
}
.form-select-xs {
    min-height: 34px !important;
    padding: 6px 8px !important;
    font-size: 12px !important;
}
.form-label.compact {
    margin-bottom: -2px;
    font-size: 11px;
    color: #9a8f86;
}
.paste-drop-zone.is-dragover,
.paste-drop-zone.is-loading {
    border-color: #bda38c;
    background: rgba(189, 163, 140, 0.16);
    box-shadow: 0 0 0 3px rgba(189, 163, 140, 0.12);
}
.paste-drop-zone.is-loading {
    cursor: progress;
    opacity: 0.85;
}

.producto-imagen-edit-card.is-deleting {
    opacity: 0.62;
    border-color: rgba(220, 38, 38, 0.65);
}
.producto-imagen-edit-card.is-deleting .producto-imagen-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.38);
    z-index: 1;
}
.producto-imagen-edit-card.is-deleting [data-principal-control] {
    cursor: not-allowed;
}

/* Alta de productos por proveedor */
.producto-nuevo-card { border-color: rgba(189, 163, 140, 0.45); }
.producto-nuevo-variantes { margin-top: 1rem; padding: .9rem; border: 1px solid rgba(78,69,62,.75); border-radius: 14px; background: rgba(21,22,22,.32); }
.producto-nuevo-variantes h4 { color:#fff; font-weight:700; font-size:.95rem; }
.variante-nueva-row { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)) auto; gap:.55rem; align-items:center; }
@media (max-width: 780px){ .variante-nueva-row { grid-template-columns: 1fr 1fr; } .variante-nueva-row .btn-mini-danger { grid-column: 1 / -1; } }

.btn-icon-warn {
    border-color: rgba(245, 158, 11, 0.45);
    color: #f8d38a;
    background: rgba(245, 158, 11, 0.08);
}
.btn-icon-warn:hover {
    border-color: rgba(245, 158, 11, 0.75);
    background: rgba(245, 158, 11, 0.16);
}

/* Solicitud de publicación ecommerce */
.productos-bloqueados-publicacion {
    border: 1px solid rgba(78, 69, 62, 0.75);
    border-radius: 14px;
    padding: .8rem;
    background: rgba(17, 17, 17, 0.35);
}
.productos-bloqueados-publicacion summary {
    cursor: pointer;
    color: #cdb7a2;
    font-weight: 700;
    font-size: .86rem;
}
.productos-bloqueados-list {
    display: grid;
    gap: .55rem;
    margin-top: .75rem;
    max-height: 260px;
    overflow: auto;
}
.producto-bloqueado-item {
    display: grid;
    grid-template-columns: 46px 1fr;
    gap: .7rem;
    align-items: center;
    padding: .55rem;
    border: 1px solid rgba(78, 69, 62, .55);
    border-radius: 12px;
    background: rgba(0, 0, 0, .18);
    opacity: .78;
}
.producto-bloqueado-item strong {
    color: #f4eee8;
    display: block;
    font-size: .84rem;
}
.producto-bloqueado-item small {
    color: #f59e9e;
    font-size: .74rem;
}


/* Select2 para campos con catálogos variables/largos (POS local). */
.select2-container {
    width: 100% !important;
    font-size: 0.82rem;
}

.select2-container--default .select2-selection--single {
    min-height: 42px;
    border: 1px solid #4e453e;
    background: #1d1e1f;
    border-radius: 0.65rem;
    display: flex;
    align-items: center;
    color: #fff;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #fff;
    line-height: 40px;
    padding-left: 0.75rem;
    padding-right: 2rem;
}

.select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #9a8f86;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 40px;
    right: 0.55rem;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: #bda38c transparent transparent transparent;
}

.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--single {
    border-color: #bda38c;
    box-shadow: 0 0 0 2px rgba(189, 163, 140, 0.16);
}

.select2-dropdown {
    background: #1d1e1f;
    border: 1px solid #4e453e;
    color: #fff;
    border-radius: 0.65rem;
    overflow: hidden;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    background: #292a2a;
    border: 1px solid #4e453e;
    border-radius: 0.5rem;
    color: #fff;
    outline: none;
    padding: 0.48rem 0.6rem;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus {
    border-color: #bda38c;
}

.select2-results__option {
    padding: 0.55rem 0.75rem;
    color: #e8ded5;
}

.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background: #bda38c;
    color: #4c3928;
}

.select2-container--default .select2-results__option--selected {
    background: rgba(189, 163, 140, 0.18);
    color: #fff;
}

.select2-results__message {
    color: #9a8f86;
}

/* POS local refinado */
.pos-producto-info {
    border: 1px solid rgba(78, 69, 62, .72);
    border-radius: 14px;
    padding: .85rem 1rem;
    margin-bottom: 1rem;
    background: rgba(17, 17, 17, .32);
}
.pos-producto-info strong {
    display: block;
    color: #f4eee8;
    font-size: .95rem;
}
.pos-producto-info span {
    color: #9a8f86;
    font-size: .78rem;
}
.pos-producto-info-kpis {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: .55rem;
}
.pos-producto-info-kpis span {
    border: 1px solid rgba(189, 163, 140, .25);
    border-radius: 999px;
    padding: .28rem .65rem;
    background: rgba(189, 163, 140, .08);
}
.pos-cantidad-control {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    justify-content: center;
}
.pos-cantidad-control span {
    min-width: 2.1rem;
    text-align: center;
    color: #fff;
    font-weight: 700;
}
.pos-cantidad-control .btn-icon {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
.pos-cantidad-control .btn-icon:disabled,
button[disabled] {
    opacity: .45;
    cursor: not-allowed;
}

/* POS local - descuento */
.pos-descuento-box {
  display: grid;
  grid-template-columns: minmax(160px, .8fr) minmax(160px, 1fr) minmax(160px, 1fr);
  gap: .75rem;
  align-items: end;
  padding: .85rem;
  border: 1px solid rgba(177, 149, 120, .22);
  border-radius: 16px;
  background: rgba(255, 255, 255, .025);
}
.pos-descuento-box .check-line {
  min-height: 44px;
  align-items: center;
}
@media (max-width: 768px) {
  .pos-descuento-box { grid-template-columns: 1fr; }
}

/* Finanzas proveedor: separación local/ecommerce */
.panel-finanzas-local,
.panel-finanzas-ecommerce {
    position: relative;
    overflow: hidden;
}
.panel-finanzas-local::before,
.panel-finanzas-ecommerce::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    opacity: .9;
}
.panel-finanzas-local::before { background: #c5a46d; }
.panel-finanzas-ecommerce::before { background: #7aa38b; }
.panel-finanzas-local .kpi,
.panel-finanzas-ecommerce .kpi {
    min-height: 112px;
}
@media (max-width: 768px) {
    .panel-finanzas-local .kpi,
    .panel-finanzas-ecommerce .kpi {
        min-height: auto;
    }
}

/* R9 Categorías proveedor */
.categoria-lista { display: grid; gap: 12px; }
.categoria-grupo-card { border: 1px solid #4e453e; background: rgba(255,255,255,.025); border-radius: 14px; padding: 14px; }
.categoria-grupo-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.categoria-grupo-head strong { color: #fff; font-size: 14px; }
.categoria-grupo-head small { display: block; color: #9a8f86; font-size: 11px; margin-top: 2px; }
.categoria-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.categoria-tags span { border: 1px solid #5d5148; color: #d8c7b8; background: rgba(189,163,140,.08); border-radius: 999px; padding: 5px 9px; font-size: 11px; }
.categoria-tags em { color: #7f746c; font-size: 12px; }
.categoria-propuesta-row { display: grid; grid-template-columns: 160px 1fr 1fr 1fr auto; gap: 8px; align-items: center; padding: 10px; border: 1px solid #4e453e; border-radius: 12px; background: rgba(255,255,255,.025); }
@media (max-width: 900px) { .categoria-propuesta-row { grid-template-columns: 1fr; } }

/* Carga masiva de productos locales */
.excel-template-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid #4e453e;
    border-radius: 1rem;
    background: rgba(189, 163, 140, 0.08);
}
.input-file-proveedor {
    width: 100%;
    border: 1px dashed #6d5f54;
    border-radius: .9rem;
    padding: .85rem;
    background: #202122;
    color: #cfc0b1;
}
.excel-error-list {
    max-height: 220px;
    overflow: auto;
    padding-left: 1rem;
    color: #fecaca;
    font-size: .82rem;
    line-height: 1.45;
}
.panel-note.danger {
    border-color: rgba(239, 68, 68, .4);
    background: rgba(127, 29, 29, .25);
    color: #fecaca;
}
@media (max-width: 640px) {
    .excel-template-box {
        align-items: stretch;
        flex-direction: column;
    }
}

/* Previsualización de carga masiva proveedores */
.excel-preview-wrap {
    max-height: 360px;
    overflow: auto;
    padding-right: 4px;
}
.excel-preview-cat {
    border: 1px solid #4e453e;
    border-radius: 14px;
    margin-top: 12px;
    background: rgba(255,255,255,.02);
    overflow: hidden;
}
.excel-preview-cat-title,
.excel-preview-sub-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
}
.excel-preview-cat-title {
    padding: 10px 12px;
    background: rgba(189,163,140,.12);
    color: #f5eee8;
}
.excel-preview-sub {
    padding: 10px 12px 12px;
    border-top: 1px solid rgba(78,69,62,.7);
}
.excel-preview-sub-title {
    color: #d9c8b8;
    font-size: 13px;
    margin-bottom: 8px;
}
.excel-preview-product {
    border: 1px solid rgba(78,69,62,.65);
    border-radius: 12px;
    padding: 10px;
    margin-top: 8px;
    background: rgba(0,0,0,.12);
}
.excel-preview-product-head {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: flex-start;
}
.excel-preview-product-head strong {
    color: #fff;
    display: block;
    font-size: 13px;
}
.excel-preview-product-head small {
    display: block;
    color: #9a8f86;
    font-size: 11px;
    margin-top: 2px;
}
.excel-preview-variants {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}
.excel-preview-variants span {
    color: #d8c7b8;
    background: rgba(189,163,140,.08);
    border: 1px solid rgba(189,163,140,.18);
    border-radius: 999px;
    padding: 4px 8px;
    font-size: 11px;
}
@media (max-width: 640px) {
    .excel-preview-product-head { flex-direction: column; }
}

/* Notificaciones internas */
.notificaciones-wrap { position: relative; }
.btn-notificaciones {
    position: relative;
    background: var(--border);
    color: #fff;
    border-radius: 8px;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background-color .15s;
}
.btn-notificaciones:hover { background: #5f544b; }
.badge-notificaciones {
    position: absolute;
    top: -5px;
    right: -5px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: var(--status-bad);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--bg-panel);
}
.panel-notificaciones {
    position: absolute;
    top: 42px;
    right: 0;
    width: min(360px, 92vw);
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0,0,0,.35);
    z-index: 80;
    overflow: hidden;
}
.notificaciones-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
}
.notificaciones-link { color: var(--accent); font-size: 11px; }
.notificaciones-lista { max-height: 420px; overflow-y: auto; }
.notificacion-item {
    width: 100%;
    text-align: left;
    padding: 11px 14px;
    border-bottom: 1px solid rgba(78,69,62,.55);
    display: block;
    background: transparent;
}
.notificacion-item:hover { background: rgba(189,163,140,.08); }
.notificacion-item.no-leida { background: rgba(96,165,250,.08); }
.notificacion-titulo { display: block; color: #fff; font-size: 12px; font-weight: 700; }
.notificacion-msg { display: block; color: var(--text-muted); font-size: 11px; margin-top: 3px; line-height: 1.35; }
.notificacion-fecha { display: block; color: var(--text-faint); font-size: 10px; margin-top: 5px; }
.notificacion-empty { color: var(--text-muted); font-size: 12px; padding: 18px; text-align: center; }


/* Centro de solicitudes proveedor */
.solicitud-mini-resumen { display: flex; flex-direction: column; gap: 2px; font-size: 11px; }
.solicitud-modal { text-align: left; max-height: 68vh; overflow-y: auto; padding-right: 4px; }
.solicitud-modal-resumen { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; color: #d8d1c8; font-size: 13px; }
.solicitud-grupo { border: 1px solid var(--border); border-radius: 10px; padding: 12px; background: rgba(29,30,31,.68); }
.solicitud-grupo.aprobado { border-color: rgba(74,222,128,.35); }
.solicitud-grupo.rechazado { border-color: rgba(248,113,113,.35); }
.solicitud-grupo.parcial { border-color: rgba(251,191,36,.35); }
.solicitud-grupo-head { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; margin-bottom: 10px; }
.solicitud-detalles { display: grid; gap: 8px; }
.solicitud-detalle { border: 1px solid rgba(78,69,62,.75); border-radius: 8px; padding: 10px; background: rgba(41,42,42,.65); }
.solicitud-detalle.aprobado { background: rgba(34,197,94,.08); }
.solicitud-detalle.rechazado { background: rgba(239,68,68,.08); }
.solicitud-detalle-title { display: flex; justify-content: space-between; gap: 10px; align-items: center; color: #fff; font-size: 13px; margin-bottom: 8px; }
.solicitud-valores { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.solicitud-valores small { display: block; color: var(--text-muted); font-size: 10px; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 3px; }
.solicitud-valores > div { border: 1px solid rgba(78,69,62,.55); border-radius: 6px; padding: 8px; color: #d8d1c8; font-size: 12px; min-width: 0; overflow-wrap: anywhere; }
.solicitud-json { max-height: 180px; overflow: auto; white-space: pre-wrap; font-size: 11px; color: #d8d1c8; margin: 0; }
.solicitud-motivo { margin-top: 8px; color: #fecaca; font-size: 12px; background: rgba(239,68,68,.12); border: 1px solid rgba(248,113,113,.25); border-radius: 6px; padding: 8px; }
.panel-note-danger { border-color: rgba(248,113,113,.35); color: #fecaca; background: rgba(127,29,29,.18); }

@media (max-width: 700px) {
    .solicitud-valores { grid-template-columns: 1fr; }
    .solicitud-grupo-head { flex-direction: column; }
}

/* =========================================================
   AJUSTE UX — Scroll interno del sidebar
   Mantiene logo/footer visibles y desplaza solo el menú.
========================================================= */
.sidebar {
    height: 100vh;
    max-height: 100vh;
    position: sticky;
    top: 0;
    overflow: hidden;
}

#sidebarNav {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
    padding-bottom: 12px;
}

#sidebarNav::-webkit-scrollbar {
    width: 6px;
}

#sidebarNav::-webkit-scrollbar-track {
    background: transparent;
}

#sidebarNav::-webkit-scrollbar-thumb {
    background-color: rgba(189, 163, 140, .35);
    border-radius: 999px;
}

#sidebarNav::-webkit-scrollbar-thumb:hover {
    background-color: rgba(189, 163, 140, .55);
}

@media (max-width: 768px) {
    .sidebar {
        height: 100vh;
        max-height: 100vh;
    }
}

.stock-input-modal {
    width: 88px;
    margin: 0 auto;
    text-align: center;
}

.stock-modal-table th,
.stock-modal-table td {
    vertical-align: middle;
}

.stock-toolbar {
    display: grid;
    grid-template-columns: minmax(220px, .7fr) minmax(240px, 1fr);
    gap: 12px;
    margin-bottom: 14px;
}

.stock-products-list {
    display: grid;
    gap: 12px;
}

.stock-product-card {
    border: 1px solid var(--border);
    border-radius: 14px;
    background: rgba(29,30,31,.72);
    overflow: hidden;
}

.stock-product-head {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 12px;
    text-align: left;
    cursor: pointer;
}

.stock-product-head:hover {
    background: rgba(189,163,140,.06);
}

.stock-product-main {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.stock-product-totals {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--text-muted);
    font-size: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.stock-product-totals b {
    color: #fff;
    font-weight: 700;
}

.stock-product-head .ti-chevron-down {
    transition: transform .18s ease;
}

.stock-product-head.is-open .ti-chevron-down {
    transform: rotate(180deg);
}

.stock-product-body {
    border-top: 1px solid var(--border);
    padding: 12px;
    background: rgba(14,15,16,.35);
}

.stock-inline-input {
    width: 96px;
    text-align: center;
    margin: 0 auto;
}

.stock-input-changed {
    border-color: rgba(189,163,140,.9) !important;
    box-shadow: 0 0 0 2px rgba(189,163,140,.14);
}

.stock-summary-group {
    border: 1px solid rgba(78,69,62,.75);
    border-radius: 10px;
    padding: 10px;
    margin-bottom: 8px;
    background: rgba(20,21,22,.48);
}

.stock-summary-group h4 {
    margin: 0 0 8px;
    color: #fff;
    font-size: 14px;
}

.stock-summary-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #d8d1c8;
    font-size: 13px;
    padding: 5px 0;
    border-top: 1px solid rgba(78,69,62,.35);
}

.stock-summary-item:first-of-type {
    border-top: 0;
}

@media (max-width: 820px) {
    .stock-toolbar { grid-template-columns: 1fr; }
    .stock-product-head { align-items: flex-start; flex-direction: column; }
    .stock-product-totals { justify-content: flex-start; }
}

/* Fase UX proveedores: ayudas contextuales y simplificación visual */
.inline-help-wrap {
    display: inline-flex;
    align-items: center;
    position: relative;
    vertical-align: middle;
}
.info-help-btn {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    border: 1px solid rgba(189, 163, 140, .45);
    background: rgba(189, 163, 140, .12);
    color: var(--accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    line-height: 1;
    margin-left: 5px;
    vertical-align: middle;
    cursor: help;
    position: relative;
    flex-shrink: 0;
}
.info-help-btn:hover,
.info-help-btn:focus,
.info-help-btn.is-open {
    background: rgba(189, 163, 140, .22);
    border-color: rgba(189, 163, 140, .75);
    outline: none;
}
.info-help-btn:hover::after,
.info-help-btn:focus::after {
    content: attr(data-help-popover);
    position: absolute;
    z-index: 40;
    left: 50%;
    bottom: calc(100% + 8px);
    transform: translateX(-50%);
    width: max-content;
    max-width: min(300px, 80vw);
    padding: 8px 10px;
    border-radius: 8px;
    background: #111214;
    border: 1px solid var(--border);
    color: #fff;
    font-size: 11px;
    font-weight: 500;
    line-height: 1.4;
    text-align: left;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .35);
    white-space: normal;
}
.inline-help-popover {
    position: absolute;
    z-index: 45;
    left: 50%;
    bottom: calc(100% + 8px);
    transform: translateX(-50%);
    width: max-content;
    max-width: min(300px, 82vw);
    padding: 8px 10px;
    border-radius: 8px;
    background: #111214;
    border: 1px solid var(--border);
    color: #fff;
    font-size: 11px;
    font-weight: 500;
    line-height: 1.4;
    text-align: left;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .35);
    white-space: normal;
}
.label-help-wrap {
    display: inline-flex;
    align-items: center;
    gap: 3px;
}
.ux-guide-card {
    border: 1px solid rgba(189, 163, 140, .28);
    background: rgba(189, 163, 140, .08);
    border-radius: 10px;
    padding: 12px 14px;
    margin: 0 0 14px;
    color: #d6c8b9;
    font-size: 12px;
}
.ux-guide-title {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #fff;
    margin-bottom: 4px;
}
.ux-guide-title i { color: var(--accent); font-size: 17px; }
.ux-guide-card p { margin: 0; }
.ux-guide-card ul {
    margin: 8px 0 0;
    padding-left: 18px;
    display: grid;
    gap: 4px;
}
.inline-details {
    margin-top: 8px;
    color: #d6c8b9;
    font-size: 11px;
}
.inline-details summary {
    cursor: pointer;
    color: var(--accent);
    font-weight: 600;
    list-style: none;
}
.inline-details summary::-webkit-details-marker { display: none; }
.inline-details summary::before {
    content: '+';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 15px;
    height: 15px;
    border-radius: 5px;
    margin-right: 5px;
    background: rgba(189, 163, 140, .15);
}
.inline-details[open] summary::before { content: '−'; }
.inline-details-grid {
    margin-top: 8px;
    padding: 10px;
    border: 1px solid rgba(78, 69, 62, .75);
    border-radius: 8px;
    background: rgba(29, 30, 31, .45);
    display: grid;
    gap: 7px;
    min-width: 260px;
}
.stock-mini-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(80px, 1fr));
    gap: 8px;
    min-width: 260px;
}
.stock-mini-grid > div {
    border: 1px solid rgba(78, 69, 62, .65);
    background: rgba(29, 30, 31, .35);
    border-radius: 8px;
    padding: 8px;
    text-align: center;
}
.stock-mini-grid span {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    font-size: 10px;
    line-height: 1.2;
    margin-bottom: 5px;
}
.stock-mini-grid strong {
    display: block;
    font-size: 15px;
    color: #fff;
}
.tabla-productos-simple tbody td:nth-child(2) { min-width: 280px; }
.tabla-productos-simple tbody td:nth-child(3) { min-width: 280px; }

@media (max-width: 768px) {
    .stock-mini-grid { grid-template-columns: 1fr; min-width: 190px; }
    .inline-details-grid { min-width: 200px; }
    .info-help-btn:hover::after,
    .info-help-btn:focus::after { display: none; }
    .inline-help-popover {
        left: auto;
        right: -6px;
        transform: none;
        max-width: min(270px, 78vw);
    }
    .ux-guide-card { font-size: 11px; padding: 10px 12px; }
}

.ux-guide-card {
    margin: 0 0 16px;
}
.ux-guide-card ul {
    margin-top: 8px;
}

/* Filtro y selección visible en productos */
.product-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0.75rem 0 1rem;
}

.product-filter-btn {
    border: 1px solid rgba(189, 163, 140, .28);
    background: rgba(189, 163, 140, .08);
    color: #d6c8b9;
    border-radius: 999px;
    padding: 0.42rem 0.8rem;
    font-size: 0.78rem;
    font-weight: 700;
    cursor: pointer;
    transition: background .18s ease, border-color .18s ease, color .18s ease;
}

.product-filter-btn:hover,
.product-filter-btn.active {
    background: rgba(189, 163, 140, .2);
    border-color: rgba(189, 163, 140, .65);
    color: #fff;
}

.btn-icon-link {
    text-decoration: none;
}

.productos-seleccion-resumen {
    border: 1px solid rgba(189, 163, 140, .28);
    background: rgba(189, 163, 140, .08);
    border-radius: 0.95rem;
    padding: 0.75rem;
    color: #d6c8b9;
}


.productos-seleccion-resumen--top {
    position: sticky;
    top: 0;
    z-index: 5;
    background: rgba(54, 44, 35, .96);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .18);
}

.productos-seleccion-resumen.is-empty {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    color: #9a8f86;
    font-size: 0.82rem;
}

.productos-seleccion-resumen .resumen-title {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    color: #fff;
    font-weight: 800;
    margin-bottom: 0.5rem;
}

.resumen-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    max-height: 8.5rem;
    overflow: auto;
}

.resumen-chip {
    border: 1px solid rgba(189, 163, 140, .24);
    background: rgba(20, 20, 20, .28);
    color: #d6c8b9;
    border-radius: 999px;
    padding: 0.26rem 0.58rem;
    font-size: 0.74rem;
    line-height: 1.2;
}

.pending-cut-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    border: 1px solid rgba(189, 163, 140, 0.24);
    background: rgba(255, 255, 255, 0.035);
    border-radius: 0.75rem;
    padding: 0.65rem 0.75rem;
}

.pending-cut-row .btn-sm {
    padding: 0.45rem 0.7rem;
    font-size: 0.72rem;
    white-space: nowrap;
}

@media (max-width: 640px) {
    .pending-cut-row {
        align-items: flex-start;
        flex-direction: column;
    }
}
