
        @media (max-width: 1100px) {
            body { flex-direction: column; overflow: auto; }

            nav {
                width: 100%;
                flex-direction: row;
                flex-wrap: wrap;
                gap: 8px;
                align-items: center;
                box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4);
            }

            .role-perm-grid {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }

            .role-perm-groups {
                max-height: none;
                overflow: visible;
                padding-right: 0;
            }

            .roles-layout {
                grid-template-columns: 1fr;
            }

            .roles-list-items {
                max-height: none;
            }

            .roles-form-col {
                max-height: none;
                overflow: visible;
            }

            .roles-form-top {
                flex-direction: column;
                align-items: stretch;
            }

            .roles-form-actions {
                flex-wrap: wrap;
            }

            #view-stats .stats-filtros-grid {
                grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
            }

            .stats-report-filters {
                grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
            }

            .stats-report-filters input[type="date"] {
                width: 100% !important;
                min-width: 0 !important;
            }

            .stats-report-filters-action {
                grid-column: 1 / -1;
                justify-content: flex-start;
            }

            #view-stats .stats-filtros-accion {
                grid-column: 1 / -1;
                justify-content: flex-start;
            }

            nav h3 { width: 100%; margin-bottom: 2px; }
            .nav-btn { width: calc(50% - 4px); justify-content: center; }
            .btn-logout { margin-top: 0; }
            main { padding: 14px; }
            #view-config .card { max-height: none; overflow: visible; }
            #view-config .card > div:first-child { position: static; margin: 0 0 10px 0; padding: 0; border-bottom: none; border-radius: 0; }
            #view-config #cfg-tabs-bar { position: static; top: auto; padding-top: 0; }
            #view-config .cfg-tab-action-bar { padding: 4px 0 10px 0; }
            .abm-layout { grid-template-columns: 1fr; }
            .stats-grid { grid-template-columns: repeat(2, minmax(160px, 1fr)); }
            .stats-panels { grid-template-columns: 1fr; }
        }

        @media (max-width: 760px) {
            .nav-btn { width: 100%; }
            .payment-grid { grid-template-columns: 1fr; }
            .bar-row { grid-template-columns: 96px 1fr 130px; }
            .modal-box { width: 94%; }
            .scan-bar { flex-direction: column; align-items: stretch; }

            #view-stats .stats-filtros-grid {
                grid-template-columns: 1fr !important;
            }

            .stats-report-filters {
                grid-template-columns: 1fr !important;
            }
        }

        @media (max-height: 820px) {
            nav {
                width: 220px;
                padding: 12px 10px;
            }

            .nav-btn {
                min-height: 36px;
                padding: 8px 10px;
                font-size: 0.81rem;
            }

            main {
                padding: 14px 16px;
            }

            .header-status {
                margin-bottom: 8px;
                padding: 8px 10px;
            }
        }

        /* Ajuste dedicado para notebooks 1366x768 */
        @media (max-width: 1366px) {
            body {
                height: 100vh;
                overflow: hidden;
            }

            main {
                height: 100vh;
                min-height: 0;
                overflow-y: auto;
                padding: 12px 14px;
            }

            nav {
                width: 214px;
                padding: 10px 8px;
                gap: 4px;
            }

            nav h3 {
                font-size: 0.95rem;
                padding-bottom: 8px;
                margin-bottom: 6px;
            }

            .nav-btn {
                min-height: 34px;
                padding: 7px 9px;
                font-size: 0.79rem;
                border-radius: 8px;
            }

            .btn-logout {
                margin-top: 8px;
            }

            .btn-salir,
            .btn-min {
                margin-top: 4px;
            }

            .header-status {
                margin-bottom: 8px;
                padding: 8px 10px;
            }

            #page-title {
                font-size: 1.12rem;
            }

            .card {
                padding: 14px;
                margin-bottom: 12px;
                border-radius: 12px;
            }

            table th,
            table td {
                padding: 7px 8px;
                font-size: 0.86rem;
            }

            .btn {
                min-height: 34px;
                padding: 7px 10px;
                font-size: 0.83rem;
            }

            /* Reducir max-height de tablas en ABM para que la paginación siempre sea visible */
            .abm-layout > div > div[style*="max-height:500px"],
            .abm-layout > div > div[style*="max-height: 500px"] {
                max-height: calc(100vh - 340px) !important;
            }

            /* Historial, auditoria, etc: contenedores tall */
            .card > div[style*="max-height:600px"],
            .card > div[style*="max-height: 600px"] {
                max-height: calc(100vh - 220px) !important;
            }
        }

        @media (max-height: 700px) {
            nav {
                width: 200px;
                padding: 8px 7px;
            }

            .nav-btn {
                min-height: 31px;
                padding: 6px 8px;
                font-size: 0.75rem;
            }

            #user-display {
                margin-bottom: 8px !important;
            }

            main {
                padding: 10px 12px;
            }
        }
        /* Nuevo Pedido: layout fixes to keep footer visible and avoid horizontal scroll */
        #modal-nuevo-pedido .modal-box { display:flex; flex-direction:column; height:86vh; }
        #modal-nuevo-pedido .modal-body { padding: 12px 18px 0 18px; overflow: hidden; flex:1 1 auto; }
            #modal-nuevo-pedido .nuevo-pedido-grid { display: grid; grid-template-columns: 1fr minmax(260px, 40%); gap: 12px; align-items: start; height: 100%; overflow-x: hidden; }
        @media (max-width: 900px) {
            #modal-nuevo-pedido .nuevo-pedido-grid { grid-template-columns: 1fr; }
        }
        #modal-nuevo-pedido .nuevo-pedido-left { background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:10px;padding:10px; display:flex; flex-direction:column; min-height:0; height:380px; flex-shrink:0; }
        #modal-nuevo-pedido .nuevo-pedido-items-wrap { overflow-y:auto; overflow-x:hidden; flex:1 1 auto; height:auto; min-height:0; min-width:0; }
        #modal-nuevo-pedido .nuevo-pedido-items-wrap table { width:100%; max-width:100%; box-sizing:border-box; table-layout: fixed; border-collapse: collapse; }
        #modal-nuevo-pedido .nuevo-pedido-items-wrap th, #modal-nuevo-pedido .nuevo-pedido-items-wrap td { white-space: normal; word-break: break-word; overflow-wrap:anywhere; padding:6px 8px; min-width:0; }
        #modal-nuevo-pedido .nuevo-pedido-items-wrap th:nth-child(3),
        #modal-nuevo-pedido .nuevo-pedido-items-wrap td:nth-child(3),
        #modal-nuevo-pedido .nuevo-pedido-items-wrap th:nth-child(4),
        #modal-nuevo-pedido .nuevo-pedido-items-wrap td:nth-child(4) {
            white-space: nowrap;
            word-break: normal;
            overflow-wrap: normal;
            font-variant-numeric: tabular-nums;
        }
        #modal-nuevo-pedido .nuevo-pedido-items-wrap th, #modal-nuevo-pedido .nuevo-pedido-items-wrap td { box-sizing:border-box; }
        #modal-nuevo-pedido .nuevo-pedido-items-wrap td input, #modal-nuevo-pedido .nuevo-pedido-items-wrap td button { max-width:100%; box-sizing:border-box; }
        /* footer fijo fuera del scroll principal */
        #modal-nuevo-pedido .nuevo-pedido-footer { display:flex; justify-content:space-between; align-items:center; gap:8px; padding:12px 18px; border-top:1px solid rgba(255,255,255,0.08); background: #0d1825; }
        #modal-nuevo-pedido .nuevo-pedido-footer .actions { display:flex; gap:8px; }
        /* Right panel: productos selector scrolls independently */
            #modal-nuevo-pedido .nuevo-pedido-right { background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:10px;padding:10px; display:flex; flex-direction:column; min-height:0; max-width:100%; min-width:0; flex:1 1 auto; min-height:360px; }
            #modal-nuevo-pedido .prod-panel-wrap { overflow-y:auto; overflow-x:hidden; flex:1 1 auto; min-width:0; }
            /* tarjetas y grid internals no deben forzar ancho */
            .prod-grid-selector { max-width:100%; box-sizing:border-box; }
            .prod-card-btn { max-width:100%; white-space:normal; }
            #modal-nuevo-pedido .nuevo-pedido-items-wrap th, #modal-nuevo-pedido .nuevo-pedido-items-wrap td { overflow-wrap:anywhere; }

            /* Reducir tipografía y paddings en lista de items para evitar scroll horizontal */
            #modal-nuevo-pedido .nuevo-pedido-items-wrap { font-size: 0.88rem; }
            #modal-nuevo-pedido .nuevo-pedido-items-wrap th, #modal-nuevo-pedido .nuevo-pedido-items-wrap td { padding: 4px 6px; font-size: 0.88rem; }
            #modal-nuevo-pedido .nuevo-pedido-items-wrap td > input[type="number"] { padding: 4px 6px; height: 28px; font-size: 0.85rem; }
            #modal-nuevo-pedido .nuevo-pedido-items-wrap td .btn-del { padding: 4px 6px; font-size: 0.85rem; }
            /* Asegurar que el footer no aumente de tamaño y ocupe solo lo necesario */
            #modal-nuevo-pedido .nuevo-pedido-footer { font-size: 0.95rem; }
            #modal-nuevo-pedido .nuevo-pedido-footer .actions .btn { padding: 8px 12px; font-size: 0.92rem; }
            /* Ajustes finos: anchos de columnas y botones del footer */
            #modal-nuevo-pedido .nuevo-pedido-items-wrap th:nth-child(1),
            #modal-nuevo-pedido .nuevo-pedido-items-wrap td:nth-child(1) {
                width: 8%; text-align: center; padding: 4px 6px;
            }
            #modal-nuevo-pedido .nuevo-pedido-items-wrap th:nth-child(2),
            #modal-nuevo-pedido .nuevo-pedido-items-wrap td:nth-child(2) {
                width: 44%; min-width: 0;
            }
            #modal-nuevo-pedido .nuevo-pedido-items-wrap th:nth-child(3),
            #modal-nuevo-pedido .nuevo-pedido-items-wrap td:nth-child(3) {
                width: 22%; text-align: right; padding-right: 6px;
            }
            #modal-nuevo-pedido .nuevo-pedido-items-wrap th:nth-child(4),
            #modal-nuevo-pedido .nuevo-pedido-items-wrap td:nth-child(4) {
                width: 22%; text-align: right; padding-right: 6px;
            }
            /* Footer buttons más consistentes y un poco más anchos */
            #modal-nuevo-pedido .nuevo-pedido-footer { overflow-x: hidden; }
            #modal-nuevo-pedido .nuevo-pedido-footer .actions .btn { padding: 6px 10px; font-size: 0.90rem; border-radius: 8px; }
        /* evitar cualquier overflow horizontal dentro del modal */
        #modal-nuevo-pedido, #modal-nuevo-pedido .modal-box, #modal-nuevo-pedido .modal-body, #modal-nuevo-pedido .nuevo-pedido-grid, #modal-nuevo-pedido .nuevo-pedido-left, #modal-nuevo-pedido .nuevo-pedido-right { overflow-x: hidden; }

        /* ===== PEDIDO MODAL DINÁMICO (.nuevo-pedido-modal) ===== */
        /* Modal box: columna flex, altura fija de ventana */
        .nuevo-pedido-modal .modal-box { display:flex; flex-direction:column; height:86vh; overflow:hidden; background: #0d1825; border-radius:20px; box-shadow: 0 28px 60px rgba(0,0,0,0.7); border:1px solid rgba(255,255,255,0.1); position:relative; overflow:hidden; }
        /* Barra decorativa superior — gradiente del design system */
        .nuevo-pedido-modal .modal-box::before { content:''; position:absolute; left:0; top:0; width:100%; height:5px; background: linear-gradient(90deg, #1a56db 0%, #7e3af2 50%, #1f9d55 100%); border-radius:20px 20px 0 0; z-index:1; }
        /* Header rediseñado */
        .nuevo-pedido-modal .modal-header { background:linear-gradient(135deg, #0a1422 0%, #060b14 100%); color: #f0f6ff; padding:12px 18px; flex:0 0 auto; display:flex; align-items:flex-start; gap:10px; margin-top:5px; border-bottom: 1px solid rgba(255,255,255,0.08); }
        .nuevo-pedido-modal .modal-header > .btn-close { flex:0 0 auto; margin-left:auto; align-self:center; }
        .nuevo-pedido-modal .pedido-header-top { flex:1 1 auto; min-width:0; }
        .nuevo-pedido-modal .modal-header h3 { color:#fff; font-family:'Space Grotesk', sans-serif; font-size:1.05rem; letter-spacing:0.4px; margin:0 0 6px 0; display:flex; align-items:center; gap:10px; }
        .nuevo-pedido-modal .pedido-nro-badge { font-size:0.78rem; font-weight:600; color:rgba(176,200,230,0.7); background:rgba(255,255,255,0.06); padding:3px 10px; border-radius:20px; letter-spacing:0.02em; }
        /* Meta bar — fila de chips */
        .nuevo-pedido-modal .pedido-meta-bar { flex:1 1 auto; display:flex; align-items:center; gap:7px; flex-wrap:wrap; min-width:0; }
        .nuevo-pedido-modal .pedido-meta-chip {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 4px 12px;
            border-radius: 20px;
            font-size: 0.78rem;
            font-weight: 600;
            line-height: 1.3;
            white-space: nowrap;
            border: 1px solid rgba(255,255,255,0.10);
            transition: background 0.15s ease, box-shadow 0.15s ease;
        }
        /* Mesa mode — chips más grandes */
        .nuevo-pedido-modal .pedido-meta-mesa .pedido-meta-chip {
            padding: 7px 16px;
            font-size: 0.92rem;
            border-radius: 24px;
        }
        /* Tipo chip — colores por data-tipo */
        .nuevo-pedido-modal .pedido-tipo-chip { color:#fff; font-weight:700; }
        .nuevo-pedido-modal .pedido-tipo-chip[data-tipo="mesa"] { background: linear-gradient(135deg, #1a56db 0%, #1443a8 100%); border-color: rgba(26,86,219,0.4); box-shadow: 0 2px 8px rgba(26,86,219,0.25); }
        .nuevo-pedido-modal .pedido-tipo-chip[data-tipo="takeaway"] { background: linear-gradient(135deg, #0f766e 0%, #0b5d58 100%); border-color: rgba(15,118,110,0.4); box-shadow: 0 2px 8px rgba(15,118,110,0.25); }
        .nuevo-pedido-modal .pedido-tipo-chip[data-tipo="delivery"] { background: linear-gradient(135deg, #d97706 0%, #b45309 100%); border-color: rgba(217,119,6,0.4); box-shadow: 0 2px 8px rgba(217,119,6,0.25); }
        /* Mozo & Comensales — botones interactivos */
        .nuevo-pedido-modal .pedido-mozo-chip,
        .nuevo-pedido-modal .pedido-comensales-chip {
            background: rgba(255,255,255,0.06);
            color: #c8daf0;
            cursor: pointer;
            border-color: rgba(255,255,255,0.12);
        }
        .nuevo-pedido-modal .pedido-mozo-chip:hover,
        .nuevo-pedido-modal .pedido-comensales-chip:hover {
            background: rgba(255,255,255,0.12);
            box-shadow: 0 2px 8px rgba(0,0,0,0.2);
        }
        /* Cliente chip */
        .nuevo-pedido-modal .pedido-cliente-label {
            color: #f0f6ff;
            background: linear-gradient(135deg, rgba(139,92,246,0.15) 0%, rgba(99,60,200,0.10) 100%);
            border-color: rgba(139,92,246,0.25);
            max-width: 360px;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        .nuevo-pedido-modal .modal-header .btn-model { background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15); color:#f0f6ff; font-size:0.8rem; padding:5px 10px; border-radius:8px; }
        .nuevo-pedido-modal .modal-header .btn-model:hover { background:rgba(255,255,255,0.15); }
        .nuevo-pedido-modal .modal-header .btn-cancel { background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); color:rgba(176,200,230,0.75); font-size:0.8rem; padding:5px 10px; border-radius:8px; }
        .nuevo-pedido-modal .modal-header .close-modal { background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.1); color:#f0f6ff; border-radius:8px; width:30px; height:30px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
        .nuevo-pedido-modal .modal-header .close-modal:hover { background:rgba(176,57,47,0.6); }
        /* Modal body: ocupa espacio restante, NO hace scroll propio */
        .nuevo-pedido-modal .modal-body { padding: 12px 18px 0 18px; overflow:hidden; flex:1 1 auto; display:flex; flex-direction:column; background: #0d1825; }
        /* Grid en dos columnas: items a la izquierda, botonera a la derecha */
        .nuevo-pedido-modal .nuevo-pedido-grid { display:grid; grid-template-columns: minmax(0, 64%) minmax(0, 36%); flex:1 1 auto; overflow:hidden; gap:10px; min-height:0; }
        /* Columna izquierda: items y resumen */
        .nuevo-pedido-modal .nuevo-pedido-left { background: rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08); border-radius:14px; padding:12px; display:flex; flex-direction:column; overflow:hidden; box-shadow: 0 4px 14px rgba(0,0,0,0.4); min-width:0; min-height:0; }
        /* Tabla de items: altura fija para ~5 productos, luego scroll */
        .nuevo-pedido-modal .nuevo-pedido-items-wrap { overflow-y:auto; overflow-x:hidden; min-height:0; flex:1 1 auto; }
        .nuevo-pedido-modal .nuevo-pedido-items-wrap table { width:100%; box-sizing:border-box; table-layout:fixed; border-collapse:collapse; }
        .nuevo-pedido-modal .nuevo-pedido-items-wrap thead tr { background: rgba(255,255,255,0.04); }
        .nuevo-pedido-modal .nuevo-pedido-items-wrap th { padding:6px 8px; font-size:0.78rem; font-weight:700; letter-spacing:0.4px; text-transform:uppercase; color:rgba(176,200,230,0.75); border-bottom: 2px solid rgba(255,255,255,0.08); }
        .nuevo-pedido-modal .nuevo-pedido-items-wrap td { padding:5px 8px; font-size:0.88rem; box-sizing:border-box; word-break:break-word; border-bottom: 1px solid rgba(255,255,255,0.05); color: #f0f6ff; }
        .nuevo-pedido-modal .nuevo-pedido-items-wrap th:nth-child(3),
        .nuevo-pedido-modal .nuevo-pedido-items-wrap td:nth-child(3),
        .nuevo-pedido-modal .nuevo-pedido-items-wrap th:nth-child(4),
        .nuevo-pedido-modal .nuevo-pedido-items-wrap td:nth-child(4) {
            white-space: nowrap;
            word-break: normal;
            overflow-wrap: normal;
            text-align: right;
            font-variant-numeric: tabular-nums;
        }
        .nuevo-pedido-modal .nuevo-pedido-items-wrap tbody tr:hover { background: rgba(59,130,246,0.08); }
        /* Resumen (subtotal, desc, total, botones): fijo debajo de la tabla */
        .nuevo-pedido-modal .pedido-summary { flex:0 0 auto; padding-top:10px; border-top: 1px solid rgba(255,255,255,0.08); margin-top:6px; display:flex; flex-direction:column; gap:10px; }
        .nuevo-pedido-modal .pedido-summary-totals { width:100%; }
        .nuevo-pedido-modal .pedido-totals-row {
            display: flex;
            align-items: stretch;
            gap: 0;
            width: 100%;
            border-radius: 10px;
            overflow: hidden;
            background: rgba(15,25,41,0.50);
            border: 1px solid rgba(255,255,255,0.07);
        }
        .nuevo-pedido-modal .pedido-totals-chip {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 6px 14px;
            gap: 1px;
            flex: 1 1 0;
            min-width: 0;
        }
        .nuevo-pedido-modal .pedido-chip-label {
            font-size: 0.67rem;
            font-weight: 600;
            letter-spacing: 0.06em;
            text-transform: uppercase;
            color: #8b9bb4;
        }
        .nuevo-pedido-modal .pedido-chip-value {
            font-size: 0.95rem;
            font-weight: 700;
            color: #e8eef6;
            letter-spacing: -0.01em;
        }
        .nuevo-pedido-modal .pedido-chip-subtotal {
            background: rgba(255,255,255,0.04);
        }
        .nuevo-pedido-modal .pedido-chip-desc {
            background: rgba(34,197,94,0.10);
            border-left: 1px solid rgba(255,255,255,0.06);
            border-right: 1px solid rgba(255,255,255,0.06);
        }
        .nuevo-pedido-modal .pedido-chip-desc .pedido-chip-label,
        .nuevo-pedido-modal .pedido-chip-desc .pedido-desc-label {
            color: #6ec97a;
            font-size: 0.76rem;
            font-weight: 700;
        }
        .nuevo-pedido-modal .pedido-chip-total {
            background: rgba(43,127,255,0.10);
        }
        .nuevo-pedido-modal .pedido-chip-total .pedido-chip-label {
            color: #7fb3ff;
        }
        .nuevo-pedido-modal .pedido-chip-total .pedido-chip-value {
            color: #fff;
            font-size: 1.02rem;
        }
        .nuevo-pedido-modal .pedido-summary-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            align-items: stretch;
            justify-content: flex-end;
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn {
            min-height: 32px;
            padding: 5px 13px;
            border-radius: 8px;
            font-size: 0.78rem;
            font-weight: 600;
            letter-spacing: 0.01em;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 4px;
            border: none;
            color: #fff;
            box-shadow: 0 2px 6px rgba(0,0,0,0.22);
            transition: transform 0.12s ease, box-shadow 0.12s ease, filter 0.12s ease;
            white-space: nowrap;
            flex: 1 1 auto;
            min-width: 0;
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn:hover {
            transform: translateY(-1px);
            filter: brightness(1.12);
            box-shadow: 0 4px 10px rgba(0,0,0,0.30);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-asignar {
            background: linear-gradient(135deg, #2b7fff 0%, #1f63cc 100%);
            box-shadow: 0 2px 6px rgba(43,127,255,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-marchar-global {
            background: linear-gradient(135deg, #e67e22 0%, #c0601a 100%);
            box-shadow: 0 2px 6px rgba(230,126,34,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-art-inex {
            background: linear-gradient(135deg, #6f59b7 0%, #58449b 100%);
            box-shadow: 0 2px 6px rgba(92,61,143,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-obs {
            background: linear-gradient(135deg, #3b82a0 0%, #2a6880 100%);
            box-shadow: 0 2px 6px rgba(59,130,160,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-control-mesa {
            background: linear-gradient(135deg, #0ea5ba 0%, #0b8494 100%);
            box-shadow: 0 2px 6px rgba(14,165,186,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-descuento {
            background: linear-gradient(135deg, #8b5cf6 0%, #7040d4 100%);
            box-shadow: 0 2px 6px rgba(139,92,246,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-transferir-mesa {
            background: linear-gradient(135deg, #64748b 0%, #4b5c72 100%);
            box-shadow: 0 2px 6px rgba(100,116,139,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-anular {
            background: linear-gradient(135deg, #b0392f 0%, #8f2a22 100%);
            box-shadow: 0 2px 6px rgba(176,57,47,0.28);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-row-top {
            min-height: 36px;
            padding: 6px 15px;
            font-size: 0.82rem;
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-row-bottom {
            min-height: 28px;
            padding: 4px 10px;
            font-size: 0.72rem;
        }
        .nuevo-pedido-modal .pedido-summary-actions .pedido-actions-break {
            flex-basis: 100%;
            height: 0;
        }
        /* Outer wrapper: actions on left, numpad on right */
        .nuevo-pedido-modal .pedido-actions-outer {
            display: flex;
            gap: 6px;
            align-items: stretch;
        }
        .nuevo-pedido-modal .pedido-actions-outer .pedido-summary-actions {
            flex: 1 1 0;
            min-width: 0;
        }
        /* Numpad: right side, fills full height of actions area */
        .nuevo-pedido-modal .pedido-qty-pad {
            flex: 0 0 110px;
            display: flex;
            flex-direction: column;
            align-items: stretch;
            gap: 4px;
            background: rgba(255,255,255,0.04);
            border: 1px solid rgba(255,255,255,0.10);
            border-radius: 10px;
            padding: 6px;
        }
        .nuevo-pedido-modal .pedido-qty-display {
            font-size: 0.65rem;
            font-weight: 700;
            color: rgba(176,200,230,0.65);
            text-align: center;
            letter-spacing: 0.05em;
            text-transform: uppercase;
            flex: 0 0 auto;
        }
        .nuevo-pedido-modal .pedido-qty-val {
            display: block;
            font-size: 1.5rem;
            font-weight: 900;
            color: #f0f6ff;
            line-height: 1;
        }
        .nuevo-pedido-modal .pedido-qty-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            grid-template-rows: repeat(3, 1fr) auto;
            gap: 3px;
            flex: 1 1 auto;
            min-height: 0;
        }
        .nuevo-pedido-modal .btn-qty-zero {
            aspect-ratio: unset;
            height: auto;
            padding: 4px 0;
        }
        .nuevo-pedido-modal .btn-qty-clear {
            grid-column: span 2;
            height: auto;
            padding: 4px 0;
            border: 1px solid rgba(255,100,100,0.25);
            border-radius: 7px;
            background: rgba(180,50,50,0.12);
            color: #f87171;
            font-size: 1rem;
            font-weight: 700;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: background 0.12s, border-color 0.12s;
        }
        .nuevo-pedido-modal .btn-qty-clear:hover {
            background: rgba(180,50,50,0.28);
            border-color: rgba(255,100,100,0.5);
        }
        .nuevo-pedido-modal .btn-qty {
            width: 100%;
            height: 100%;
            border: 1px solid rgba(255,255,255,0.14);
            border-radius: 7px;
            background: rgba(255,255,255,0.07);
            color: #c8d8f0;
            font-size: 1.05rem;
            font-weight: 700;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: background 0.12s, border-color 0.12s, color 0.12s;
            padding: 0;
            min-height: 0;
        }
        .nuevo-pedido-modal .btn-qty:hover {
            background: rgba(43,127,255,0.22);
            border-color: rgba(43,127,255,0.5);
            color: #fff;
        }
        .nuevo-pedido-modal .btn-qty.active {
            background: linear-gradient(135deg, #2b7fff 0%, #1f63cc 100%);
            border-color: #2b7fff;
            color: #fff;
            box-shadow: 0 2px 6px rgba(43,127,255,0.4);
        }
        .nuevo-pedido-modal .pedido-summary-actions .btn-cobrar {
            flex: 1 0 100%;
            background: linear-gradient(135deg,#169b52 0%,#127a40 100%) !important;
            color: #fff !important;
            border: none !important;
            box-shadow: 0 4px 12px rgba(22,155,82,0.35) !important;
            font-size: 0.88rem !important;
            font-weight: 700 !important;
            min-height: 34px !important;
            padding: 6px 16px !important;
        }
        /* Columna derecha: scan + buscar + productos con scroll */
        .nuevo-pedido-modal .nuevo-pedido-right { background: rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08); border-radius:14px; padding:12px; display:flex; flex-direction:column; min-height:0; overflow:hidden; box-shadow: 0 4px 14px rgba(0,0,0,0.4); min-width:0; position:relative; }
        /* Handle de resize en el borde izquierdo del panel de productos */
        .pedido-right-resizer { position:absolute; left:0; top:0; bottom:0; width:7px; cursor:col-resize; z-index:10; background:transparent; border-radius:14px 0 0 14px; transition:background 0.15s; }
        .pedido-right-resizer:hover, .pedido-right-resizer.rsz-active { background:rgba(56,189,248,0.35); }
        /* Inputs scan y buscar: estilo dark */
        .nuevo-pedido-modal .pedido-scan-input,
        .nuevo-pedido-modal .filtro-pedido { flex:0 0 auto; border:1px solid rgba(255,255,255,0.12); border-radius:10px; padding:8px 12px; background: rgba(255,255,255,0.06); color: #f0f6ff; font-size:0.88rem; transition:border-color 0.15s, box-shadow 0.15s; }
        .nuevo-pedido-modal .pedido-scan-input:focus,
        .nuevo-pedido-modal .filtro-pedido:focus { outline:none; border-color:#3b82f6; box-shadow:0 0 0 3px rgba(59,130,246,0.18); }
        /* Panel de productos: ocupa todo el espacio disponible, SOLO ESTE TIENE SCROLL */
        .nuevo-pedido-modal .prod-panel-wrap { flex:1 1 auto; overflow-y:auto; overflow-x:hidden; min-height:0; margin-top:4px; }
        .nuevo-pedido-modal .pedido-products.prod-grid-selector { grid-template-columns: repeat(3, minmax(0,1fr)); gap: 6px; }
        .nuevo-pedido-modal .pedido-products { overflow:visible !important; }
        /* Accordion de rubros */
        .nuevo-pedido-modal .btn-item-del-nuevo { background:none; border:1px solid rgba(176,57,47,0.4); color: rgba(220,80,70,0.9); border-radius:6px; padding:3px 8px; font-size:0.78rem; cursor:pointer; transition:0.15s; line-height:1; }
        .nuevo-pedido-modal .btn-item-del-nuevo:hover { background: rgba(176,57,47,0.15); border-color:#b0392f; color:#ef4444; box-shadow:0 2px 6px rgba(176,57,47,0.2); }
        .nuevo-pedido-modal tr.pedido-item-row { cursor:pointer; transition:background 0.12s; }
        .nuevo-pedido-modal tr.pedido-item-row:hover { background:rgba(255,255,255,0.04); }
        .nuevo-pedido-modal tr.row-selected { background:rgba(37,99,235,0.18) !important; }
        .nuevo-pedido-modal .btn-editar-precio { background:none; border:1px solid rgba(100,160,255,0.45); color:rgba(147,197,253,0.9); border-radius:5px; padding:2px 7px; font-size:0.72rem; cursor:pointer; margin-left:5px; transition:0.15s; line-height:1; }
        .nuevo-pedido-modal .btn-editar-precio:hover { background:rgba(37,99,235,0.2); border-color:#3b82f6; color:#93c5fd; }
        .nuevo-pedido-modal .precio-edit-input { width:88px; }
        .nuevo-pedido-modal .pedido-desc-val::-webkit-inner-spin-button,
        .nuevo-pedido-modal .pedido-desc-val::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
        .nuevo-pedido-modal .pedido-desc-val { appearance: textfield; -moz-appearance: textfield; }
        .nuevo-pedido-modal .pedido-accordion { display:flex !important; flex-direction:column; gap:5px; }
        .nuevo-pedido-modal .pedido-rubro-wrap { border-radius:10px; overflow:hidden; border:1px solid rgba(255,255,255,0.08); }
        /* Header de rubro: dark premium + clickeable */
        .nuevo-pedido-modal .pedido-rubro { background: rgba(126,58,242,0.12); color: rgba(176,200,230,0.9); border-radius:0; padding:8px 12px; font-size:0.82rem; font-weight:800; letter-spacing:0.5px; text-transform:uppercase; border-left:3px solid #7e3af2; }
        .nuevo-pedido-modal .pedido-rubro-header { display:flex; align-items:center; justify-content:space-between; cursor:pointer; user-select:none; grid-column:unset !important; }
        .nuevo-pedido-modal .pedido-rubro-header:hover { background: rgba(126,58,242,0.2); }
        .nuevo-pedido-modal .pedido-rubro-arrow { font-size:0.72rem; display:inline-block; transition:transform 0.2s; margin-left:6px; }
        /* Drag handle de rubro */
        .nuevo-pedido-modal .pedido-rubro-drag-handle { font-size:1rem; cursor:grab; padding:0 6px 0 0; opacity:0.45; color:rgba(176,200,230,0.9); line-height:1; flex-shrink:0; }
        .nuevo-pedido-modal .pedido-rubro-drag-handle:hover { opacity:0.9; }
        .nuevo-pedido-modal .pedido-rubro-drag-handle:active { cursor:grabbing; }
        /* Estados de arrastre — rubros */
        .nuevo-pedido-modal .pedido-rubro-wrap.pedido-rubro-dragging { opacity:0.4; }
        .nuevo-pedido-modal .pedido-rubro-wrap.pedido-rubro-drag-over > .pedido-rubro-header { background: rgba(59,130,246,0.3) !important; border-left-color:#3b82f6 !important; box-shadow:0 0 0 2px rgba(59,130,246,0.4); }
        /* Estados de arrastre — botones de producto */
        .nuevo-pedido-modal .prod-card-btn.prod-btn-dragging { opacity:0.45; transform:scale(0.96); box-shadow:0 0 0 2px #3b82f6; cursor:grabbing !important; z-index:10; }
        .nuevo-pedido-modal .prod-card-btn.prod-btn-drag-over { box-shadow:0 0 0 2px #60a5fa, 0 4px 16px rgba(59,130,246,0.35) !important; transform:scale(1.04); transition:transform 0.1s, box-shadow 0.1s; }
        .nuevo-pedido-modal .pedido-rubro-header.open .pedido-rubro-arrow { transform:rotate(180deg); }
        /* Pin button de rubro */
        .nuevo-pedido-modal .pedido-rubro-pin-btn { font-size:0.75rem; cursor:pointer; opacity:0.3; transition:opacity 0.15s, filter 0.15s; margin-left:4px; flex-shrink:0; line-height:1; filter:grayscale(1); }
        .nuevo-pedido-modal .pedido-rubro-pin-btn:hover { opacity:0.75; }
        .nuevo-pedido-modal .pedido-rubro-pin-btn.pinned { opacity:1; filter:none; }
        /* Lock button de rubro */
        .nuevo-pedido-modal .pedido-rubro-lock-btn { font-size:0.72rem; cursor:pointer; opacity:0.25; transition:opacity 0.15s; margin-left:3px; flex-shrink:0; line-height:1; user-select:none; }
        .nuevo-pedido-modal .pedido-rubro-lock-btn:hover { opacity:0.7; }
        .nuevo-pedido-modal .pedido-rubro-lock-btn.locked { opacity:0.85; }
        .nuevo-pedido-modal .pedido-rubro-header > span:nth-child(2) { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
        /* Grid de productos dentro del acordeón: auto-fill para adaptarse al ancho del panel */
        .nuevo-pedido-modal .pedido-rubro-products { display:none; grid-template-columns:repeat(auto-fill,minmax(88px,1fr)); gap:6px; padding:8px; background: rgba(255,255,255,0.02); }
        .nuevo-pedido-modal .pedido-rubro-products.open { display:grid; }
        /* Botones de productos: dark premium */
        .nuevo-pedido-modal .prod-card-btn { background: rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:10px; box-shadow: 0 2px 8px rgba(0,0,0,0.3); transition:0.12s ease; color: #f0f6ff; }
        .nuevo-pedido-modal .prod-card-btn:hover { border-color:#3b82f6; background: rgba(59,130,246,0.12); box-shadow: 0 4px 14px rgba(59,130,246,0.2); transform:translateY(-2px); }
        #promo-items-grid .prod-card-btn { background: rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:10px; box-shadow: 0 2px 8px rgba(0,0,0,0.3); color: #f0f6ff; }
        #promo-items-grid .prod-card-btn:hover { border-color:#3b82f6; background: rgba(59,130,246,0.12); box-shadow: 0 4px 14px rgba(59,130,246,0.2); transform:translateY(-2px); }
        /* Sin overflow horizontal en nada dentro del modal */
        .nuevo-pedido-modal, .nuevo-pedido-modal .modal-box, .nuevo-pedido-modal .modal-body,
        .nuevo-pedido-modal .nuevo-pedido-grid, .nuevo-pedido-modal .nuevo-pedido-left,
        .nuevo-pedido-modal .nuevo-pedido-right { overflow-x:hidden; }

        @media (max-width: 1180px) {
            .nuevo-pedido-modal .nuevo-pedido-grid { grid-template-columns: 1fr; }
            .nuevo-pedido-modal .nuevo-pedido-left { min-height: 220px; }
            .nuevo-pedido-modal .pedido-products.prod-grid-selector { grid-template-columns: repeat(4, minmax(0,1fr)); }
        }

        @media (max-height: 768px) {
            .nuevo-pedido-modal .modal-box { height: 90vh !important; }
            .nuevo-pedido-modal .pedido-summary { margin-top: 8px; gap: 8px !important; }
            .nuevo-pedido-modal .btn-cobrar { padding: 7px 14px !important; font-size: 0.93rem !important; }
        }

/* ================================================
   RESPONSIVE: NOTEBOOKS Y PANTALLAS INTERMEDIAS
   ================================================ */

/* Clases para layouts que antes eran solo inline */
.stats-filtros-grid {
    grid-template-columns: repeat(6, 1fr);
}

.dbconsole-layout {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
}

/* Lista de pedidos activos: auto-fill para que adapte columnas */
#lista-pedidos {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
}

/* ─── 1280px: notebooks medianos ─── */
@media (max-width: 1280px) {
    /* Stats KPIs: 2 columnas */
    .stats-grid {
        grid-template-columns: repeat(2, minmax(160px, 1fr));
    }

    /* Stats filtros: 3 columnas */
    .stats-filtros-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    /* DB Console: columna lateral más angosta */
    .dbconsole-layout {
        grid-template-columns: 200px minmax(0, 1fr);
    }

    /* Botones de productos: más angostos */
    #view-productos .abm-toolbar .btn-prod-action,
    #view-productos .abm-toolbar .btn-prod-nav {
        width: auto !important;
        min-width: 148px !important;
    }

    #view-productos .abm-toolbar .btn-prod-action {
        min-width: 178px !important;
    }

}

/* ─── 1100px: solapamiento nav→fila ya activo, layouts internos ─── */
@media (max-width: 1100px) {
    /* Stats filtros: 2 columnas */
    .stats-filtros-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* DB Console: una columna */
    .dbconsole-layout {
        grid-template-columns: 1fr;
    }

    /* Auditoria: filtros de 6 columnas → 3 */
    #view-auditoria .card > div:first-child[style*="repeat(6"] {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    /* Caja header row de 3 columnas → 2 */
    #caja-header-row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    /* Caja movimiento form (1.3fr 1fr 1fr auto) → colapsa */
    #view-caja .card > div[style*="1.3fr"] {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-historial .historial-filtros {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-historial .historial-filtros input[type="date"] {
        width: 100% !important;
        min-width: 0 !important;
    }

    #view-historial .historial-filtros .btn {
        justify-self: stretch;
    }

    #view-historial-ventas .historial-ventas-filtros {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-historial-ventas .historial-ventas-filtro-buscar {
        grid-column: 1 / -1;
    }

    #view-historial-ventas .historial-ventas-filtro-actions {
        grid-column: 1 / -1;
        justify-content: flex-end;
    }

    #view-historial-ventas .historial-ventas-filtro-actions .btn {
        flex: 0 0 auto;
        min-width: 108px;
    }

    /* Caja movimientos filtros de 4 → 2 */
    #view-caja .card > div[style*="repeat(4"] {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    /* Kardex filtros de 4 → 2 */
    #view-kardex .card > div[style*="repeat(4"] {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    /* Botones prod: flexible */
    #view-productos .abm-toolbar .btn-prod-action,
    #view-productos .abm-toolbar .btn-prod-nav {
        width: auto !important;
        min-width: 120px;
        flex: 1 1 auto;
    }

}

/* ─── 760px: pantallas muy pequeñas ─── */
@media (max-width: 760px) {
    /* Stats filtros: 1 columna */
    .stats-filtros-grid {
        grid-template-columns: 1fr;
    }

    /* DB Console: una columna */
    .dbconsole-layout {
        grid-template-columns: 1fr;
    }

    /* KPIs: 1 columna */
    .stats-grid {
        grid-template-columns: 1fr;
    }

    /* Lista pedidos: 2 columnas mínimo */
    #lista-pedidos {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Auditoria y caja filtros: 1 columna */
    #view-auditoria .card > div:first-child[style*="repeat(6"] {
        grid-template-columns: 1fr 1fr !important;
    }
}

/* ======================================================================
   TELÉFONO (<=600px): nav como cajón (drawer) + base usable.
   Va al final para ganar a los breakpoints anteriores.
   ====================================================================== */
@media (max-width: 600px) {
    /* La barra de título de escritorio no aplica en celular */
    body {
        padding-top: 0;
        height: 100vh;
        overflow: hidden;
        flex-direction: row;
    }
    body::before { display: none; } /* orbes de fondo: pesados en mobile */

    /* Barra de ventana falsa (min/cerrar/tema) oculta en celular */
    .window-chrome { display: none !important; }

    /* ---- Nav como cajón lateral deslizable ---- */
    nav {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        height: 100vh;
        width: 82%;
        max-width: 300px;
        flex-direction: column !important;
        flex-wrap: nowrap !important;
        overflow-y: auto;
        transform: translateX(-100%);
        transition: transform .25s ease;
        z-index: 1200;
        box-shadow: 6px 0 28px rgba(0, 0, 0, 0.5);
    }
    body.nav-open nav { transform: translateX(0); }
    body.nav-open::after {
        content: '';
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 1100;
    }
    .nav-btn { width: 100%; }

    /* Botón hamburguesa (fijo arriba a la izquierda) */
    .mobile-nav-toggle {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        position: fixed;
        top: 8px;
        left: 8px;
        width: 42px;
        height: 42px;
        z-index: 1000;
        border: 1px solid var(--line);
        border-radius: 10px;
        background: var(--surface-soft);
        color: var(--ink-700);
        font-size: 1.3rem;
        cursor: pointer;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
    }

    /* ---- Contenido a pantalla completa ---- */
    main {
        width: 100%;
        height: 100vh;
        padding: 56px 10px 14px;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Header de cada vista compacto */
    .header-status {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
        padding: 8px 10px;
        margin-bottom: 10px;
    }
    #page-title { font-size: 1.1rem; }

    /* Grillas genéricas a una columna */
    .payment-grid,
    .stats-filtros-grid,
    .stats-report-filters,
    .form-grid,
    .abm-form-grid,
    .stats-grid {
        grid-template-columns: 1fr !important;
    }

    /* Modales casi a pantalla completa */
    .modal-box,
    .modal-content {
        width: 96vw !important;
        max-width: 96vw !important;
        max-height: 92vh !important;
        overflow-y: auto;
    }

    /* Tablas anchas: scroll horizontal en su contenedor */
    .table-wrap,
    .tabla-scroll,
    .table-responsive {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    table { font-size: 0.82rem; }
    table th, table td { padding: 6px 7px; }

    /* Cards full width compactas */
    .card {
        padding: 12px;
        border-radius: 12px;
        margin-bottom: 10px;
    }

    /* Botoneras de acción que se desbordan: que envuelvan */
    .scan-bar,
    .toolbar,
    .abm-form-actions,
    .roles-form-actions {
        flex-wrap: wrap;
    }

    /* Toolbar de Ventas y fila de estado: envolver en vez de desbordar/cortar */
    .ventas-toolbar { flex-wrap: wrap !important; }
    .ventas-op-status { flex-wrap: wrap; row-gap: 4px; }

    /* Red de seguridad: nada empuja scroll horizontal en el contenido */
    main { max-width: 100vw; }
    main .card { max-width: 100%; box-sizing: border-box; }

    /* Tablas: sus contenedores ya tienen overflow-y; habilitamos scroll horizontal
       para que no se corten (en vez de desbordar la pantalla). */
    main [style*="overflow-y"] {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Grids de filtros/forms con columnas fijas (repeat(3..6)) → una sola columna. */
    main [style*="grid-template-columns:repeat(3"],
    main [style*="grid-template-columns:repeat(4"],
    main [style*="grid-template-columns:repeat(5"],
    main [style*="grid-template-columns:repeat(6"],
    main [style*="grid-template-columns: repeat(3"],
    main [style*="grid-template-columns: repeat(4"],
    main [style*="grid-template-columns: repeat(5"],
    main [style*="grid-template-columns: repeat(6"] {
        grid-template-columns: 1fr !important;
    }

    /* Filtros de Comprobantes: apilar en vez de desbordar (es grid de 4 cols) */
    #view-historial .historial-filtros,
    .historial-filtros {
        display: grid;
        grid-template-columns: 1fr !important;
        align-items: stretch;
        gap: 8px;
    }
    .historial-filtros > * { width: 100%; }
    .historial-filtros input,
    .historial-filtros select {
        min-width: 0 !important;
        width: 100%;
        box-sizing: border-box;
    }
}
