html,body,#root{width:100%;height:100%;overflow:hidden}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{color:#e0e0e0;background:#1a1a2e;width:100%;height:100%;font-family:system-ui,sans-serif;overflow:hidden}.app{width:100vw;height:100vh;display:flex}.panel-izquierdo{background:#16213e;border-right:2px solid #2d2d4a;flex-direction:column;width:320px;min-width:280px;display:flex}.panel-derecho,.ticket-panel{flex-direction:column;flex:1;display:flex;overflow:hidden}.ticket-cabecera{background:#0f3460;border-bottom:2px solid #e94560;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.mesa-label{color:#a0aec0;font-size:1rem}.total{color:#48bb78;font-size:1.8rem;font-weight:700}.ticket-lineas{flex:1;padding:8px;overflow-y:auto}.ticket-vacio{text-align:center;color:#4a5568;margin-top:40px;font-size:.9rem}.linea-ticket{cursor:pointer;border:1px solid #0000;border-radius:6px;align-items:center;gap:8px;margin-bottom:4px;padding:8px 10px;transition:background .15s;display:flex}.linea-ticket:hover{background:#2d2d4a}.linea-ticket.seleccionada{background:#2d3748;border-color:#e94560}.linea-nombre{flex:1;font-size:.9rem}.linea-controles{align-items:center;gap:4px;display:flex}.btn-cantidad{color:#e0e0e0;cursor:pointer;background:#2d3748;border:1px solid #4a5568;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1rem;line-height:1;display:flex}.btn-cantidad:hover{background:#4a5568}.linea-cantidad{text-align:center;min-width:24px;font-weight:700}.linea-subtotal{text-align:right;color:#68d391;min-width:60px;font-size:.9rem}.botonera{background:#0f3460;border-top:2px solid #2d2d4a;grid-template-columns:1fr 1fr 1fr;gap:4px;padding:8px;display:grid}.btn-accion{cursor:pointer;color:#e0e0e0;text-transform:uppercase;letter-spacing:.03em;background:#2d3748;border:none;border-radius:6px;padding:14px 6px;font-size:.8rem;font-weight:600;transition:opacity .15s,transform .1s}.btn-accion:hover:not(:disabled){opacity:.85;transform:scale(.98)}.btn-accion:disabled{opacity:.35;cursor:default}.btn-cobrar{color:#fff;background:#276749}.btn-mesa{color:#fff;background:#2b6cb0}.btn-borrar-venta{color:#fff;background:#9b2c2c}.categoria-bar{scrollbar-width:thin;scrollbar-color:#4a5568 transparent;background:#0f3460;border-bottom:2px solid #2d2d4a;flex-wrap:wrap;gap:6px;max-height:148px;padding:10px 12px;display:flex;overflow-y:auto}.categoria-bar::-webkit-scrollbar{width:4px;height:0}.categoria-bar::-webkit-scrollbar-thumb{background:#4a5568;border-radius:2px}.btn-categoria{color:#a0aec0;cursor:pointer;white-space:nowrap;background:#2d3748;border:2px solid #0000;border-radius:8px;padding:10px 18px;font-size:.9rem;font-weight:600;transition:all .15s}.btn-categoria:hover{color:#e0e0e0;background:#3a3a5c}.btn-categoria.activa{color:#fff;background:#e94560;border-color:#e94560}.productos-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));align-content:start;gap:10px;padding:12px;display:grid;overflow-y:auto}.productos-grid.desactivado{opacity:.4;pointer-events:none}.btn-producto{color:#e0e0e0;cursor:pointer;background:#16213e;border:2px solid #2d2d4a;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;font-size:.85rem;transition:all .15s;display:flex}.btn-producto:hover:not(:disabled){background:#1a1a3e;border-color:#e94560;transform:scale(.97)}.btn-producto:active:not(:disabled){transform:scale(.94)}.producto-img{object-fit:cover;border-radius:6px;width:80px;height:80px}.producto-img-placeholder{background:#2d2d4a;border-radius:6px;width:80px;height:80px}.producto-nombre{text-align:center;font-weight:600;line-height:1.2}.producto-precio{color:#68d391;font-size:.95rem;font-weight:700}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#1a1a2e;border:2px solid #2d2d4a;border-radius:12px;min-width:360px;max-width:90vw;max-height:85vh;padding:28px;overflow-y:auto}.modal h2{color:#e94560;margin-bottom:20px;font-size:1.3rem}.mesas-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-bottom:20px;display:grid}.btn-mesa-modal{color:#e0e0e0;cursor:pointer;background:#16213e;border:2px solid #2d2d4a;border-radius:8px;padding:18px 10px;font-size:.9rem;font-weight:600;transition:all .15s;position:relative}.btn-mesa-modal:hover{border-color:#2b6cb0}.btn-mesa-modal.activa{background:#2d1a1a;border-color:#e94560}.btn-mesa-modal.ocupada{border-color:#744210}.punto-ocupada{background:#ed8936;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.modal-cobrar{min-width:420px}.cobrar-metodo{gap:10px;margin-bottom:20px;display:flex}.btn-metodo{color:#e2e8f0;cursor:pointer;background:#2d3748;border:2px solid #4a5568;border-radius:8px;flex:1;padding:12px;font-size:1rem;font-weight:600;transition:background .15s,border-color .15s}.btn-metodo.activo{color:#fff;background:#0f3460;border-color:#e94560}.btn-metodo:hover:not(.activo){background:#4a5568}.cobrar-total{color:#a0aec0;margin-bottom:20px;font-size:1.5rem}.cobrar-total strong{color:#48bb78}.cobrar-efectivo label{color:#a0aec0;margin-bottom:8px;font-size:.9rem;display:block}.cobrar-efectivo input{color:#e0e0e0;background:#16213e;border:2px solid #2d2d4a;border-radius:8px;width:100%;margin-bottom:12px;padding:12px;font-size:1.4rem}.btns-rapidos{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.btn-rapido{color:#e0e0e0;cursor:pointer;background:#2d3748;border:1px solid #4a5568;border-radius:6px;padding:8px 14px;font-size:.9rem}.btn-rapido:hover{background:#4a5568}.cobrar-cambio{color:#a0aec0;margin-bottom:20px;font-size:1.3rem}.cobrar-cambio strong{color:#63b3ed}.cobrar-acciones{justify-content:flex-end;gap:12px;display:flex}.btn-cancelar{color:#e0e0e0;cursor:pointer;background:#2d3748;border:1px solid #4a5568;border-radius:8px;padding:12px 24px;font-size:.95rem}.btn-confirmar{color:#fff;cursor:pointer;background:#276749;border:none;border-radius:8px;padding:12px 24px;font-size:.95rem;font-weight:600}.btn-confirmar:hover:not(:disabled){background:#2f855a}.btn-confirmar:disabled{opacity:.4;cursor:not-allowed}.btn-cancelar:hover{background:#4a5568}.cobrar-lineas-list{border:1px solid #2d2d4a;border-radius:8px;max-height:220px;margin-bottom:16px;overflow:hidden auto}.cobrar-lineas-header{background:#0f3460;border-bottom:1px solid #2d2d4a;justify-content:space-between;align-items:center;padding:8px 12px;display:flex;position:sticky;top:0}.cobrar-lineas-titulo{color:#a0aec0;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.btn-link{color:#63b3ed;cursor:pointer;background:0 0;border:none;padding:0;font-size:.8rem}.btn-link:hover{color:#90cdf4}.cobrar-linea-row{cursor:pointer;border-bottom:1px solid #1a1a3a;align-items:center;gap:10px;padding:10px 12px;transition:background .1s;display:flex}.cobrar-linea-row:last-child{border-bottom:none}.cobrar-linea-row:hover{background:#1e2d4a}.cobrar-linea-row.seleccionada{background:#162a40}.cobrar-linea-row input[type=checkbox]{cursor:pointer;accent-color:#e94560;flex-shrink:0;width:16px;height:16px}.cobrar-linea-nombre{cursor:pointer;flex:1;font-size:.9rem}.cobrar-linea-qty{color:#a0aec0;text-align:center;min-width:30px;font-size:.85rem}.cobrar-linea-qty-ctrl{align-items:center;gap:4px;display:flex}.btn-qty{color:#e0e0e0;cursor:pointer;background:#2d3748;border:1px solid #4a5568;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1rem;line-height:1;display:flex}.btn-qty:hover:not(:disabled){background:#4a5568}.btn-qty:disabled{opacity:.3;cursor:not-allowed}.cobrar-qty-display{text-align:center;color:#e2e8f0;min-width:28px;font-size:.9rem;font-weight:600}.cobrar-qty-max{color:#718096;font-size:.8rem;font-weight:400}.cobrar-linea-precio{color:#68d391;text-align:right;min-width:60px;font-size:.9rem;font-weight:600}.cobrar-historial{background:#0f1a2e;border:1px solid #2d2d4a;border-radius:8px;margin-bottom:16px;padding:10px 12px}.cobrar-historial-titulo{color:#a0aec0;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.75rem;font-weight:600}.cobrar-historial-item{border-bottom:1px solid #1a2a40;justify-content:space-between;align-items:center;padding:5px 0;display:flex}.cobrar-historial-item:last-child{border-bottom:none}.cobro-metodo{text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:.78rem;font-weight:600}.cobro-efectivo{color:#fff;background:#276749}.cobro-tarjeta{color:#fff;background:#2b6cb0}.cobro-importe{color:#68d391;font-size:.9rem;font-weight:600}.lineas-cobradas{border-top:1px dashed #2d2d4a;margin-top:6px;padding-top:2px}.lineas-cobradas-titulo{color:#4a5568;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;font-size:.72rem}.linea-cobrada{opacity:.38;cursor:default;pointer-events:none}.linea-cobrada .linea-nombre{text-decoration:line-through}.linea-cantidad-simple{color:#a0aec0;text-align:center;min-width:32px;font-size:.85rem}.modal-caja{min-width:340px}.caja-label{color:#a0aec0;margin-bottom:8px;font-size:.95rem}.caja-input{text-align:right;color:#e2e8f0;box-sizing:border-box;background:#0f3460;border:2px solid #2d2d4a;border-radius:8px;width:100%;margin-bottom:20px;padding:12px;font-size:1.4rem}.caja-input:focus{border-color:#e94560;outline:none}.caja-resumen{border-collapse:collapse;width:100%;margin-bottom:20px}.caja-resumen td{color:#e2e8f0;border-bottom:1px solid #2d2d4a;padding:8px 4px}.caja-resumen td:last-child{text-align:right;font-variant-numeric:tabular-nums}.caja-esperado td{color:#a0c4ff;font-weight:600}.caja-diferencia td{font-size:1.05rem;font-weight:700}.caja-diferencia.positiva td{color:#48bb78}.caja-diferencia.negativa td{color:#fc8181}.modal-manual{min-width:360px}.manual-campo{margin-bottom:16px}.manual-campo label{color:#a0aec0;margin-bottom:6px;font-size:.9rem;display:block}.manual-campo input{color:#e2e8f0;box-sizing:border-box;background:#0f3460;border:2px solid #2d2d4a;border-radius:8px;width:100%;padding:10px 12px;font-size:1rem}.manual-campo input:focus{border-color:#e94560;outline:none}.caja-aviso{color:#fc8181;margin-bottom:12px;font-size:.95rem}.caja-pendientes{margin:0 0 20px;padding:0;list-style:none}.caja-pendientes li{color:#e2e8f0;background:#2d2d4a;border-radius:6px;margin-bottom:6px;padding:8px 12px;font-weight:600}.btn-opciones-wrapper{position:relative}.opciones-menu{z-index:50;background:#1a1a2e;border:2px solid #4a5568;border-radius:8px;min-width:200px;position:absolute;bottom:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 -4px 16px #0006}.opciones-menu button{color:#e0e0e0;text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #2d2d4a;width:100%;padding:12px 16px;font-size:.9rem;display:block}.opciones-menu button:last-child{border-bottom:none}.opciones-menu button:hover{background:#2d3748}.gestion-vista{color:#e0e0e0;background:#1a1a2e;flex-direction:column;width:100vw;height:100vh;display:flex}.gestion-header{background:#0f3460;border-bottom:2px solid #2d2d4a;align-items:center;gap:16px;padding:16px 24px;display:flex}.gestion-header h1{color:#e0e0e0;flex:1;font-size:1.3rem}.btn-volver{color:#e0e0e0;cursor:pointer;background:#2d3748;border:1px solid #4a5568;border-radius:6px;padding:8px 16px;font-size:.9rem}.btn-volver:hover{background:#4a5568}.gestion-body{flex:1;padding:20px 24px;overflow-y:auto}.gestion-tabla{border-collapse:collapse;width:100%;font-size:.9rem}.gestion-tabla th{text-align:left;color:#a0aec0;background:#0f3460;border-bottom:2px solid #2d2d4a;padding:10px 12px;font-weight:600}.gestion-tabla td{vertical-align:middle;border-bottom:1px solid #2d2d4a;padding:10px 12px}.gestion-tabla tr:hover td{background:#16213e}.gestion-tabla input[type=text],.gestion-tabla input[type=number]{color:#e0e0e0;background:#16213e;border:1px solid #4a5568;border-radius:4px;width:100%;padding:6px 8px;font-size:.9rem}.gestion-tabla select{color:#e0e0e0;background:#16213e;border:1px solid #4a5568;border-radius:4px;padding:6px 8px;font-size:.9rem}.btn-tabla{cursor:pointer;border:none;border-radius:4px;padding:6px 12px;font-size:.8rem;font-weight:600}.btn-tabla-editar{color:#fff;background:#2b6cb0;margin-right:6px}.btn-tabla-editar:hover{background:#2c5282}.btn-tabla-guardar{color:#fff;background:#276749;margin-right:6px}.btn-tabla-guardar:hover{background:#22543d}.btn-tabla-cancelar{color:#fff;background:#4a5568;margin-right:6px}.btn-tabla-cancelar:hover{background:#2d3748}.btn-tabla-borrar{color:#fff;background:#9b2c2c}.btn-tabla-borrar:hover{background:#742a2a}.gestion-nueva-fila td{background:#16213e}.btn-agregar{color:#fff;cursor:pointer;background:#276749;border:none;border-radius:6px;margin-top:16px;padding:10px 20px;font-size:.9rem;font-weight:600}.btn-agregar:hover{background:#2f855a}.producto-thumb{object-fit:cover;border-radius:4px;width:48px;height:48px}.producto-thumb-placeholder{background:#2d2d4a;border-radius:4px;width:48px;height:48px;display:inline-block}.mobile-nav,.mobile-ticket-inline{display:none}@media (width<=1024px){.panel-izquierdo{width:260px;min-width:220px}.btn-accion{padding:10px 4px;font-size:.75rem}.productos-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}@media (width<=768px){html,body,#root{height:100dvh;overflow:hidden}.app{flex-direction:column;height:100dvh}.panel-izquierdo,.panel-derecho{width:100%;min-width:unset;border-right:none;flex:1;overflow:hidden}.panel-izquierdo.mobile-hidden,.panel-derecho.mobile-hidden{display:none}.panel-izquierdo.mobile-visible,.panel-derecho.mobile-visible{flex-direction:column;display:flex}.botonera{gap:3px;padding:6px}.btn-accion{padding:10px 4px;font-size:.72rem}.productos-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;padding:8px}.producto-img,.producto-img-placeholder{width:64px;height:64px}.btn-producto{padding:8px 6px;font-size:.78rem}.categoria-bar{max-height:unset;scrollbar-width:none;flex-wrap:nowrap;padding:8px 10px;overflow:auto hidden}.categoria-bar::-webkit-scrollbar{display:none}.btn-categoria{flex-shrink:0;padding:8px 14px;font-size:.85rem}.linea-ticket{padding:10px 8px}.btn-cantidad{width:30px;height:30px;font-size:1.1rem}.modal{min-width:unset;width:96vw;max-height:88vh;padding:20px 16px}.modal-cobrar{min-width:unset}.cobrar-metodo{flex-wrap:wrap}.cobrar-acciones{flex-direction:column-reverse}.btn-cancelar,.btn-confirmar{text-align:center;width:100%}.opciones-menu{min-width:160px}.mobile-ticket-inline{background:#16213e;border-top:2px solid #e94560;flex-direction:column;flex-shrink:0;max-height:38vh;display:flex}.mobile-ticket-inline-header{background:#0f3460;border-bottom:1px solid #2d2d4a;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.mobile-ticket-inline-header .total{font-size:1.3rem}.mobile-ticket-inline-lineas{padding:4px 8px;overflow-y:auto}.linea-ticket-mini{border-bottom:1px solid #2d2d4a;align-items:center;gap:8px;padding:6px 4px;font-size:.85rem;display:flex}.linea-ticket-mini .linea-nombre{flex:1}.linea-ticket-mini .linea-cantidad{color:#a0aec0;text-align:center;min-width:28px}.linea-ticket-mini .linea-subtotal{text-align:right;color:#68d391;min-width:54px;font-weight:600}.mobile-nav{background:#0f3460;border-top:2px solid #2d2d4a;flex-shrink:0;height:54px;display:flex}.mobile-nav-btn{color:#a0aec0;cursor:pointer;background:0 0;border:none;border-top:3px solid #0000;flex:1;font-size:.9rem;font-weight:600;transition:color .15s,border-color .15s}.mobile-nav-btn.activo{color:#e94560;border-top-color:#e94560}.mobile-nav-total{color:#48bb78}}
