@import"https://fonts.googleapis.com/css2?family=Luckiest+Guy&display=swap";@import"https://fonts.googleapis.com/css2?family=Chewy&display=swap";body{margin:0;font-family:Segoe UI,Arial,sans-serif;box-sizing:border-box}.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;max-width:1600px;margin:0 auto;padding:2rem 1rem;box-sizing:border-box}main>h1{text-align:center;margin-bottom:2rem;font-size:2.2rem;font-weight:700;color:#1976d2;letter-spacing:1px}.navbar{background-color:#e628ec;padding:1rem 2rem;display:flex;flex-direction:column;align-items:center;box-shadow:0 2px 4px #0000001a;position:fixed;top:0;left:0;width:220px;height:100vh;z-index:300;animation:navbar-slide-in .2s}@keyframes navbar-slide-in{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.navbar-logo{margin-bottom:2rem}.navbar-logo a{color:#ecf0f1;font-size:1.5rem;font-weight:700;text-decoration:none}.navbar-links{display:flex;flex-direction:column;flex-wrap:wrap;list-style:none;gap:1rem;justify-content:center;padding:0;margin:0;width:100%}.navbar-links a{color:#ecf0f1;text-decoration:none;font-size:1.1rem;padding:.5rem .8rem;border:2px solid #c218c2;border-radius:5px;background-color:#d11ed1;transition:all .3s}.navbar-links a:hover{color:#fff;background-color:#b017b0;border-color:#b017b0}.navbar-dropdown{position:relative;display:inline-block}.navbar-dropdown-btn{background:#d11ed1;color:#fff;border:2px solid #c218c2;border-radius:5px;padding:.5rem 1.2rem;font-size:1rem;cursor:pointer;font-weight:700;transition:background .3s,border .3s}.navbar-dropdown-btn:hover,.navbar-dropdown-btn:focus{background:#b017b0;border-color:#b017b0}.navbar-dropdown-content{display:none;position:absolute;left:0;top:110%;background:#fff;min-width:180px;box-shadow:0 2px 8px #00000026;border-radius:6px;z-index:100;padding:.5rem 0}.navbar-dropdown-content a{display:block;color:#d11ed1;padding:.7rem 1.2rem;text-decoration:none;border:none;background:none;transition:background .2s,color .2s}.navbar-dropdown-content a:hover{background:#f3e6f7;color:#b017b0}.navbar-dropdown.open .navbar-dropdown-content{display:block}.navbar-hamburger{position:fixed;top:18px;left:18px;z-index:200;background:#d11ed1;border:none;border-radius:6px;padding:8px;display:flex;flex-direction:column;gap:4px;cursor:pointer;box-shadow:0 2px 8px #0000001f}.hamburger-bar{width:28px;height:4px;background:#fff;border-radius:2px;display:block;transition:all .3s}@media (max-width: 768px){.navbar{padding:1rem}.navbar-links{gap:.3rem}.navbar-links a{font-size:.9rem;padding:.4rem .8rem}.navbar-dropdown-content{min-width:140px}}@media (max-width: 480px){.navbar-links a{font-size:.8rem;padding:.3rem .6rem}}@media (min-width: 900px){.navbar-hamburger{top:24px;left:32px}.navbar{width:260px;padding-left:2.5rem}}.login-form{background:linear-gradient(120deg,#ede9fe,#a5b4fc);border-radius:28px;box-shadow:0 8px 48px #a5b4fc55;max-width:480px;width:95vw;margin:6vh auto 0;padding:3.5rem 2.5rem 2.5rem;display:flex;flex-direction:column;align-items:center;animation:loginFadeIn 1s cubic-bezier(.77,0,.18,1) both;box-sizing:border-box}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(60px) scale(.95)}to{opacity:1;transform:none}}.login-form h1{color:#5b21b6;font-size:2.7rem;font-weight:900;letter-spacing:3px;margin-bottom:1.2rem;text-shadow:0 4px 16px #a5b4fc44;text-align:center}.login-form h2{color:#3b3663;font-size:1.35rem;font-weight:700;margin-bottom:2rem;letter-spacing:1.5px;text-align:center}.login-form input{width:100%;padding:1.1rem 1.2rem;margin-bottom:1.3rem;border:none;border-radius:12px;background:#f3f4f6;font-size:1.18rem;color:#3b3663;box-shadow:0 2px 8px #a5b4fc22;transition:box-shadow .18s,background .18s;outline:none;box-sizing:border-box}.login-form input:focus{box-shadow:0 4px 24px #a5b4fc55;background:#ede9fe}.login-form button{width:100%;padding:1.1rem 0;background:linear-gradient(90deg,#6366f1,#5eead4);color:#fff;font-weight:800;font-size:1.18rem;border:none;border-radius:14px;box-shadow:0 4px 16px #6366f144;cursor:pointer;transition:background .18s,transform .13s;margin-top:.5rem;box-sizing:border-box}.login-form button:hover{background:linear-gradient(90deg,#5eead4,#6366f1);transform:scale(1.045)}.login-form div{color:#ef4444;margin-top:1rem;font-weight:700;text-align:center;letter-spacing:.7px;font-size:1.08rem}@media (max-width: 600px){.login-form{max-width:100vw;width:100vw;padding:1.2rem .3rem;border-radius:10px;margin:2vh auto 0;box-shadow:0 4px 18px #a5b4fc55}.login-form h1{font-size:1.45rem;margin-bottom:.7rem;letter-spacing:1.5px}.login-form h2{font-size:.98rem;margin-bottom:1.1rem;letter-spacing:.7px}.login-form input{font-size:.98rem;padding:.8rem .7rem;margin-bottom:.8rem;border-radius:9px}.login-form button{font-size:1rem;padding:.9rem .7rem;border-radius:9px;margin-top:.7rem}.login-form div{font-size:.98rem;margin-top:.7rem}}.teclado-container{background:#fff;border-radius:16px;box-shadow:0 2px 12px #a5b4fc22;padding:1.5rem 1rem 2rem;min-width:220px;max-width:340px;margin:0 auto;display:flex;flex-direction:column;align-items:center}.teclado-container h3{text-align:center;color:#5b21b6;font-weight:700;margin-bottom:1rem;letter-spacing:.5px}.teclado-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;width:100%;margin-bottom:1.2rem}.teclado-boton{background:linear-gradient(90deg,#f3f4f6,#e0e7ef);color:#3b3663;border:none;border-radius:8px;padding:0;font-size:1.08rem;font-weight:600;cursor:pointer;box-shadow:0 1px 4px #a5b4fc11;transition:background .18s,color .18s,transform .13s;outline:none;min-height:48px;min-width:0;width:100%;height:48px;display:flex;align-items:center;justify-content:center}.teclado-boton.coma{background:linear-gradient(90deg,#ede9fe,#a5b4fc);color:#5b21b6}.teclado-boton.operacion{background:linear-gradient(90deg,#a5b4fc,#6366f1);color:#fff}.teclado-boton.borrar{background:linear-gradient(90deg,#fca5a5,#ef4444);color:#fff}.teclado-boton.limpiar{background:linear-gradient(90deg,#ede9fe,#a5b4fc);color:#5b21b6}.teclado-boton:hover,.teclado-boton:focus{background:linear-gradient(90deg,#e0e7ef,#c7d2fe);color:#22223b;transform:scale(1.04)}.teclado-boton.operacion:hover,.teclado-boton.operacion:focus{background:linear-gradient(90deg,#6366f1,#a5b4fc);color:#fff}.teclado-boton.borrar:hover,.teclado-boton.borrar:focus{background:linear-gradient(90deg,#ef4444,#fca5a5)}.teclado-boton.limpiar:hover,.teclado-boton.limpiar:focus{background:linear-gradient(90deg,#a5b4fc,#ede9fe);color:#5b21b6}.teclado-boton-pasar{background:linear-gradient(90deg,#6366f1,#5eead4);color:#fff;border:none;border-radius:10px;padding:.7rem 0;font-size:1.08rem;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #6366f133;transition:background .18s,box-shadow .18s,transform .13s;width:100%;margin-top:1rem}.teclado-boton-pasar:disabled{opacity:.5;cursor:not-allowed}.teclado-boton-pasar:hover:enabled{background:linear-gradient(90deg,#5eead4,#6366f1);transform:scale(1.04)}.teclado-preview{background:#f4f6fb;border-radius:8px;padding:.7rem 1rem;margin-top:1rem;width:100%;box-shadow:0 1px 4px #a5b4fc11}.teclado-preview h4{margin:0 0 .4rem;color:#5b21b6;font-size:1rem;font-weight:600}.teclado-expresion{font-size:1.1rem;color:#333;min-height:1.3em;word-break:break-all}@media (max-width: 600px){.teclado-container{padding:1rem .3rem 1.2rem;min-width:0;max-width:100%}.teclado-grid{gap:.4rem}}.teclado-cantidad-container{background:#fff;border-radius:16px;box-shadow:0 4px 16px #00000014;padding:2rem;max-width:320px;margin:0 auto;font-family:Segoe UI,Arial,sans-serif}.teclado-cantidad-container h3{text-align:center;margin-bottom:1rem;color:#2c3e50;font-size:1.3rem;font-weight:600}.teclado-cantidad-display{background:#f4f6fa;border-radius:8px;font-size:2rem;text-align:right;padding:.75rem 1rem;margin-bottom:1.2rem;color:#34495e;border:1px solid #e1e4ea;min-height:2.5rem}.teclado-cantidad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem}.teclado-cantidad-grid button{background:#3498db;color:#fff;border:none;border-radius:8px;font-size:1.3rem;padding:.8rem 0;cursor:pointer;transition:background .2s;font-weight:500;box-shadow:0 2px 8px #3498db14}.teclado-cantidad-grid button:hover,.teclado-cantidad-grid button:focus{background:#217dbb;outline:none}.teclado-cantidad-grid button:last-child{grid-column:span 3;background:#27ae60}.teclado-cantidad-grid button:nth-last-child(2){background:#e67e22}.teclado-cantidad-grid button:nth-last-child(3){background:#e74c3c}.cuenta-container{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;background:#fff;border-radius:16px;box-shadow:0 2px 12px #a5b4fc22;padding:1.5rem 1rem 2rem;min-width:240px;max-width:340px;width:100%;box-sizing:border-box}.cuenta-container h3,.cuenta-total,.cuenta-lista{text-align:center}.cuenta-lista{margin:0 0 .5rem;padding:0;list-style:none;width:100%;padding:.2rem 0}.cuenta-lista li{padding:.5rem .3rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:.18rem .1rem;line-height:1.1;margin-bottom:.1rem}.cuenta-lista li:last-child{border-bottom:none}.eliminar-boton{background:#ef4444;color:#fff;border:none;border-radius:6px;padding:.3rem .7rem;font-size:.8rem;cursor:pointer;margin-left:.5rem;transition:background .18s}.eliminar-boton:hover{background:#dc2626}.cuenta-total{margin-top:1.2rem;font-weight:700;font-size:1.1rem}.finalizar-boton,.reiniciar-boton{margin-top:1rem;padding:.6rem 1.2rem;border:none;border-radius:8px;background:linear-gradient(90deg,#10b981,#0ea5e9);color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:background .18s,transform .13s}.finalizar-boton:hover,.reiniciar-boton:hover{background:linear-gradient(90deg,#0ea5e9,#10b981);transform:scale(1.04)}.mensaje-final{position:absolute;top:0;left:0;width:100%;height:100%;background:#f5f6faf7;border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;box-shadow:0 2px 24px #1db95444;padding:2rem 1.2rem 1.5rem;opacity:0;pointer-events:none;transition:opacity .35s}.mensaje-final.mostrar{opacity:1;pointer-events:auto}#ticket-print{background:#fff;font-family:Courier New,Courier,monospace;max-width:320px;margin:0 auto;padding:18px 12px;border-radius:12px;box-shadow:0 2px 16px #0002;color:#222;font-size:1.07em;letter-spacing:.5px}#ticket-print h1{font-size:1.5em;margin:0 0 8px;font-weight:700;letter-spacing:2px;text-align:center}#ticket-print h2{font-size:1.1em;margin:10px 0 0;text-align:center}#ticket-print ul{padding-left:18px;margin:0 0 8px}#ticket-print li{font-size:1em;margin-bottom:2px}#ticket-print hr{border:none;border-top:1px dashed #888;margin:8px 0 10px}#ticket-print .ticket-total{font-weight:700;margin-top:10px;text-align:right}#ticket-print .ticket-gracias{margin-top:18px;text-align:center;font-size:.97em;color:#1976d2}@media print{body *{visibility:hidden!important;height:0!important;margin:0!important;padding:0!important;overflow:hidden!important}#ticket-impresion,#ticket-impresion *{visibility:visible!important;height:auto!important;margin:0!important;padding:0!important;overflow:visible!important;page-break-inside:avoid!important;break-inside:avoid!important}#ticket-impresion{position:absolute!important;left:0!important;top:0!important;width:100vw!important;min-height:0!important;max-height:none!important;background:#fff!important;z-index:9999!important;box-sizing:border-box!important;page-break-after:avoid!important;page-break-before:avoid!important;page-break-inside:avoid!important}html,body{width:100vw!important;height:auto!important;margin:0!important;padding:0!important;overflow:visible!important}}@media (max-width: 600px){.cuenta-container{min-width:0;max-width:98vw;padding:1rem .3rem 1.2rem}.cuenta-lista li{font-size:.97rem;padding:.4rem .1rem}.cuenta-total{font-size:1rem}}.imprimir-boton{margin-top:.7rem;padding:.6rem 1.2rem;border:none;border-radius:8px;background:linear-gradient(90deg,#f59e42,#f43f5e);color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:background .18s,transform .13s;display:block;width:100%}.imprimir-boton:hover{background:linear-gradient(90deg,#f43f5e,#f59e42);transform:scale(1.04)}.imprimir-boton:disabled{background:#e5e7eb;color:#aaa;cursor:not-allowed;transform:none}.ticket-impresion{width:100%;max-width:280px;min-width:180px;margin:0 auto;background:#fff;border:none;border-radius:0;box-shadow:none;padding:.7em;font-family:Courier New,Courier,monospace;font-size:1em;color:#222;letter-spacing:.2px}.ticket-header{text-align:center;margin-bottom:.7em}.ticket-logo{font-size:1.1em;font-weight:700;letter-spacing:1.5px;color:#1976d2;margin-bottom:.2em}.ticket-info{font-size:.93em;color:#444;margin-bottom:.5em}.ticket-body ul{padding-left:0;margin:0 0 .7em}.ticket-body li{font-size:.97em;margin-bottom:.25em;padding-bottom:.12em;border-bottom:1px dotted #e0e7ef;display:flex;justify-content:space-between}.ticket-body li:last-child{border-bottom:none}.ticket-footer{margin-top:1em;font-size:.97em;color:#1976d2;text-align:center}.ticket-body hr,.ticket-header hr{border:none;border-top:1px dashed #888;margin:7px 0 8px}.ticket-body .ticket-total{font-weight:700;margin-top:8px;text-align:right;font-size:1em}body.productos-bg{background:linear-gradient(120deg,#f8fafc,#e0e7ef 60%,#f5e8c7);background-size:200% 200%;animation:productosBgMove 16s ease-in-out infinite alternate}@keyframes productosBgMove{0%{background-position:0% 50%}to{background-position:100% 50%}}.productos-layout{display:flex;justify-content:center;align-items:flex-start;width:100%;gap:2.5rem;box-sizing:border-box}.productos-container{flex:4 1 0;min-width:320px;max-width:1400px;margin:0 auto;background:#fff;border-radius:20px;box-shadow:0 2px 16px #b6c2d633;padding:2rem 1.5rem 2.5rem;display:flex;flex-direction:column}.cuenta-container,.teclado-container{flex:1 1 0;min-width:220px;max-width:340px}.productos-container h3{text-align:center;margin-bottom:1.5rem;color:#0e7490;font-weight:700;font-size:1.7rem;letter-spacing:1px}.filtros-productos{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.2rem}.categorias-botones{display:flex;gap:.5rem;flex-wrap:wrap;margin:.5rem 0;justify-content:flex-start}.categoria-boton{background:linear-gradient(90deg,#f43f5e,#fbbf24);color:#fff;border:none;border-radius:18px;padding:.5rem 1.1rem;font-size:.95rem;font-weight:800;letter-spacing:.5px;box-shadow:0 4px 18px #f43f5e33;cursor:pointer;margin-bottom:.3rem;position:relative;overflow:hidden;transition:background .18s cubic-bezier(.4,0,.2,1),color .18s cubic-bezier(.4,0,.2,1),box-shadow .18s,transform .13s;outline:none;border:2px solid transparent}.categoria-boton:hover,.categoria-boton:focus{background:linear-gradient(90deg,#fbbf24,#f43f5e);color:#fff;transform:scale(1.08) rotate(-1deg);box-shadow:0 8px 32px #f43f5e55;border:2px solid #fff}.categoria-boton.activa{background:linear-gradient(90deg,#6366f1,#06b6d4);color:#fff;font-weight:900;box-shadow:0 8px 32px #06b6d455;transform:scale(1.12);border:2px solid #6366f1;z-index:2}.producto-boton{background:linear-gradient(120deg,#06b6d4cc,#6366f1cc);color:#fff;border:none;border-radius:14px;padding:.55rem 1rem;font-size:.95rem;font-weight:700;cursor:pointer;box-shadow:0 4px 18px #6366f144;transition:background .18s cubic-bezier(.4,0,.2,1),color .18s cubic-bezier(.4,0,.2,1),box-shadow .18s,transform .13s;outline:none;margin-bottom:.4rem;display:flex;align-items:center;justify-content:center;min-height:36px;min-width:0;width:100%;box-sizing:border-box;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border:2px solid transparent}.producto-boton:hover,.producto-boton:focus{background:linear-gradient(120deg,#6366f1cc,#06b6d4cc);color:#fff;transform:scale(1.06) rotate(1deg);box-shadow:0 8px 32px #06b6d455;border:2px solid #fff}.producto-boton[disabled]{background:#f43f5e!important;color:#fff!important;opacity:1}.productos-grid{display:grid;grid-template-columns:repeat(6,minmax(100px,1fr));gap:.8rem;margin-top:1.2rem;width:100%}@media (max-width: 1400px){.productos-container{min-width:0;width:100%;max-width:100vw;padding:1.2rem .7rem 1.5rem}.productos-grid{grid-template-columns:repeat(4,minmax(100px,1fr));gap:.7rem}}@media (max-width: 900px){.productos-layout{flex-direction:column;align-items:center;gap:1.2rem}.productos-container{padding:1rem .3rem 1.2rem;min-width:0;max-width:98vw}.productos-grid{grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.7rem}.cuenta-container,.teclado-container{min-width:0;max-width:98vw;margin:0 auto}}@media (max-width: 700px){.productos-grid{grid-template-columns:repeat(2,minmax(90px,1fr));gap:.5rem}}.modal-pedido{background:#fff;border:2px solid #f43f5e;border-radius:16px;padding:2.2rem 2rem 1.5rem;position:fixed;top:24%;left:50%;transform:translate(-50%);z-index:1000;box-shadow:0 8px 32px #f43f5e33;min-width:320px;max-width:95vw;text-align:center}.modal-pedido h3{color:#f43f5e;margin-bottom:1.2rem;font-size:1.5rem;font-weight:800}.modal-pedido label{font-weight:700;margin:0 .7rem;color:#0e7490;font-size:1.1rem}.modal-pedido input[type=text]{margin-top:1rem;padding:.7rem 1.1rem;border-radius:8px;border:1.5px solid #f43f5e;width:96%;max-width:420px;font-size:1.08rem;margin-bottom:1.2rem;box-sizing:border-box;display:block;margin-left:auto;margin-right:auto;background:#f8fafc;transition:border .18s,box-shadow .18s}.modal-pedido input[type=text]:focus{border:2px solid #fbbf24;outline:none;background:#fffbe7;box-shadow:0 2px 8px #fbbf2433}.modal-pedido button{background:linear-gradient(90deg,#06b6d4,#6366f1);color:#fff;border:none;border-radius:14px;padding:.5rem 1.1rem;font-size:.95rem;font-weight:700;margin:.4rem .5rem 0;cursor:pointer;box-shadow:0 2px 8px #6366f144;transition:background .18s,transform .13s}.modal-pedido button:hover,.modal-pedido button:focus{background:linear-gradient(90deg,#6366f1,#06b6d4);transform:scale(1.06)}.crear-pedido-boton{background:linear-gradient(90deg,#f43f5e,#fbbf24);color:#fff;border:none;border-radius:16px;padding:.7rem 1.3rem;font-size:1rem;font-weight:900;letter-spacing:.5px;box-shadow:0 4px 18px #f43f5e33;cursor:pointer;margin-bottom:.7rem;margin-top:.7rem;transition:background .18s cubic-bezier(.4,0,.2,1),color .18s cubic-bezier(.4,0,.2,1),box-shadow .18s,transform .13s;outline:none;border:2px solid transparent}.crear-pedido-boton:hover,.crear-pedido-boton:focus{background:linear-gradient(90deg,#fbbf24,#f43f5e);color:#fff;transform:scale(1.07) rotate(-1deg);box-shadow:0 8px 32px #f43f5e55;border:2px solid #fff}.cambiar-teclado-boton{background:linear-gradient(90deg,#3498db,#6dd5fa);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;padding:.5rem 1rem;margin-bottom:.7rem;width:80%;box-shadow:0 2px 8px #3498db1f;cursor:pointer;transition:background .2s,transform .2s}.cambiar-teclado-boton:hover,.cambiar-teclado-boton:focus{background:linear-gradient(90deg,#217dbb,#43cea2);transform:translateY(-2px) scale(1.03);outline:none}.productos-page{max-width:1100px;margin:0 auto;padding:2rem 1rem 3rem;background:#fff;border-radius:18px;box-shadow:0 2px 16px #b6c2d633;min-height:90vh}.productos-page h1{text-align:center;color:#0e7490;font-size:2rem;margin-bottom:2rem;font-weight:700;letter-spacing:1px}.buscadores{display:flex;flex-wrap:wrap;gap:1.2rem;margin-bottom:2rem;justify-content:center}.buscador-categoria,.buscador-nombre{display:flex;align-items:center;gap:.7rem}.buscador-categoria select,.buscador-categoria input,.buscador-nombre input{padding:.5rem .8rem;border-radius:8px;border:1px solid #cbd5e1;font-size:1rem;background:#f8fafc}.limpiar-filtro{background:#fbbf24;color:#fff;border:none;border-radius:8px;padding:.4rem 1rem;font-size:.98rem;cursor:pointer;margin-left:.5rem;transition:background .18s}.limpiar-filtro:hover{background:#f59e42}.productos-form,.productos-edit-form{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1.5rem;align-items:center;justify-content:center}.productos-form input,.productos-edit-form input{padding:.5rem .8rem;border-radius:8px;border:1px solid #cbd5e1;font-size:1rem;background:#f8fafc;min-width:140px}.productos-form button,.productos-edit-form button{background:linear-gradient(90deg,#10b981,#fbbf24);color:#fff;border:none;border-radius:8px;padding:.5rem 1.2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .18s,transform .13s}.productos-form button:hover,.productos-edit-form button:hover{background:linear-gradient(90deg,#fbbf24,#10b981);transform:scale(1.04)}.productos-form label,.productos-edit-form label{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:500;color:#0e7490;margin-bottom:.2rem}.productos-form select[name=disponible_reparto],.productos-edit-form select[name=disponible_reparto]{padding:.45rem .8rem;border-radius:8px;border:1px solid #cbd5e1;font-size:1rem;background:#f8fafc;min-width:110px;font-weight:500;color:#334155;transition:border .18s}.productos-form select[name=disponible_reparto]:focus,.productos-edit-form select[name=disponible_reparto]:focus{border-color:#0ea5e9;outline:none}.productos-lista{list-style:none;padding:0;margin:0}.productos-lista li{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;background:#f8fafc;border-radius:12px;box-shadow:0 1px 6px #cbd5e122;margin-bottom:1.2rem;padding:1.1rem 1rem;gap:1.2rem}.producto-info{flex:2 1 300px;font-size:1rem;color:#334155}.producto-img{max-width:90px;max-height:90px;border-radius:8px;margin-top:.5rem;border:1px solid #e0e7ef;background:#fff}.producto-actions{display:flex;flex-direction:column;gap:.7rem;align-items:flex-end;min-width:120px}.producto-actions button{background:linear-gradient(90deg,#ef4444,#fbbf24);color:#fff;border:none;border-radius:8px;padding:.4rem 1.1rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .18s,transform .13s}.producto-actions button:hover{background:linear-gradient(90deg,#fbbf24,#ef4444);transform:scale(1.04)}@media (max-width: 900px){.productos-page{padding:1rem .3rem 2rem}.buscadores,.productos-form,.productos-edit-form{flex-direction:column;gap:.7rem}.productos-lista li{flex-direction:column;align-items:stretch;gap:.7rem;padding:.8rem .5rem}.producto-actions{flex-direction:row;gap:.7rem;align-items:center;justify-content:flex-end}}@media print{body *{visibility:hidden!important}#ticket-print,#ticket-print *{visibility:visible!important}#ticket-print{position:absolute;left:0;top:0;width:100vw;background:#fff;z-index:99999;padding:0;margin:0}}.pedidos-page{max-width:1200px;margin:0 auto;padding:2rem 1rem 3rem;background:#fff;border-radius:18px;box-shadow:0 2px 16px #b6c2d633;min-height:90vh}.pedidos-page h1{text-align:center;color:#0e7490;font-size:2rem;margin-bottom:2rem;font-weight:700;letter-spacing:1px}.pedidos-page form{margin-bottom:2rem;background:#f8fafc;border-radius:12px;padding:1.2rem 1rem;box-shadow:0 1px 6px #cbd5e122}.pedidos-page select,.pedidos-page input[type=text],.pedidos-page input[type=number]{padding:.5rem .8rem;border-radius:8px;border:1px solid #cbd5e1;font-size:1rem;background:#f8fafc;margin-right:.5rem}.pedidos-page button[type=submit]{background:linear-gradient(90deg,#10b981,#fbbf24);color:#fff;border:none;border-radius:8px;padding:.5rem 1.2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .18s,transform .13s;margin-left:.5rem}.pedidos-page button[type=submit]:hover{background:linear-gradient(90deg,#fbbf24,#10b981);transform:scale(1.04)}.productos-pedido{display:flex;flex-wrap:wrap;align-items:center;gap:.7rem;margin:1rem 0 .5rem}.productos-botones{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.4rem;align-items:center;width:100%}.lista-productos-pedido{list-style:none;padding:0;margin:.7rem 0}.lista-productos-pedido li{padding:.3rem 0;font-size:1rem;color:#334155}.pedidos-listas{display:flex;gap:2.5rem;margin-top:2.5rem;flex-wrap:wrap}.pedidos-col{flex:1 1 350px;background:#f8fafc;border-radius:12px;box-shadow:0 1px 6px #cbd5e122;padding:1.2rem 1rem;min-width:320px}.pedidos-col h2{text-align:center;color:#0e7490;font-size:1.2rem;margin-bottom:1.2rem;font-weight:700}.pedidos-col ul{list-style:none;padding:0;margin:0}.pedidos-col>ul>li{background:#fff;border-radius:10px;box-shadow:0 1px 4px #cbd5e122;margin-bottom:1.1rem;padding:1rem .7rem;font-size:1rem;color:#334155;position:relative}.pedidos-col select{margin:.5rem .5rem .5rem 0;padding:.3rem .7rem;border-radius:6px;border:1px solid #cbd5e1;background:#f1f5f9;font-size:1rem}.pedidos-col button{background:linear-gradient(90deg,#ef4444,#fbbf24);color:#fff;border:none;border-radius:8px;padding:.4rem 1.1rem;font-size:1rem;font-weight:600;cursor:pointer;margin-right:.5rem;margin-top:.5rem;transition:background .18s,transform .13s}.pedidos-col button:hover{background:linear-gradient(90deg,#fbbf24,#ef4444);transform:scale(1.04)}@media (max-width: 900px){.pedidos-page{padding:1rem .3rem 2rem}.pedidos-listas{flex-direction:column;gap:1.2rem}.pedidos-col{min-width:0;width:100%;padding:1rem .3rem}}@media (max-width: 600px){.productos-botones{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:.3rem}}@media print{body *{visibility:hidden!important}#ticket-impresion,#ticket-impresion *{visibility:visible!important}#ticket-impresion{position:absolute!important;left:0!important;right:0!important;top:0!important;margin:0 auto!important;width:58mm!important;min-width:0!important;max-width:none!important;background:#fff!important;z-index:9999!important;box-sizing:border-box!important;page-break-after:avoid!important;page-break-before:avoid!important;page-break-inside:avoid!important;padding:.5em .2em!important}@page{size:58mm auto;margin:0}}.clientes-layout{display:flex;flex-direction:row;justify-content:center;align-items:flex-start;width:100vw;min-height:100vh;background:linear-gradient(120deg,#f5f7fa,#c3cfe2);box-sizing:border-box;padding:2.5rem 2vw;overflow-x:hidden}.catalogo{flex:1 1 0;max-width:1200px;min-width:0;margin:0 auto;display:flex;flex-direction:column;align-items:center}.titulo-desavio{font-family:Chewy,cursive;font-size:3rem;text-align:center;text-transform:uppercase;color:#1976d2;letter-spacing:2px;text-shadow:0 2px 8px #42a5f5,0 4px 16px #f59e42,0 0px 0px #fff,0 6px 12px #b6e0fa;margin-bottom:2rem;position:relative;-webkit-user-select:none;user-select:none;animation:gomitaBounce 2.5s infinite alternate cubic-bezier(.6,0,.4,1)}@keyframes gomitaBounce{0%{transform:scaleY(1) scaleX(1)}60%{transform:scaleY(1.08) scaleX(.97)}to{transform:scaleY(.93) scaleX(1.05)}}.titulo-desavio:after{content:none;display:none}.piruleta-o{display:inline-block;position:relative;width:1em;height:1em;vertical-align:middle;margin-left:-.08em;margin-right:-.08em}.piruleta-circulo{display:block;width:1em;height:1em;background:radial-gradient(circle at 60% 40%,#f43f5e 70%,#f59e42);border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px #f43f5e55;position:relative;z-index:2}.piruleta-palo{position:absolute;left:50%;top:90%;width:.18em;height:.8em;background:linear-gradient(180deg,#fff 60%,#e0e0e0);border-radius:0 0 .2em .2em;transform:translate(-50%);z-index:1;box-shadow:0 2px 4px #f59e4244}.productos-catalogo{display:grid;grid-template-columns:repeat(5,minmax(140px,1fr));gap:1.2rem;width:100%;justify-items:center;transition:grid-template-columns .2s}@media (max-width: 1400px){.productos-catalogo{grid-template-columns:repeat(4,minmax(140px,1fr))}}@media (max-width: 1100px){.productos-catalogo{grid-template-columns:repeat(3,minmax(140px,1fr))}}@media (max-width: 800px){.productos-catalogo{grid-template-columns:repeat(2,minmax(120px,1fr))}}@media (max-width: 500px){.productos-catalogo{grid-template-columns:1fr}}.producto-card{background:#fff;border-radius:16px;box-shadow:0 4px 24px #b6e0fa33;padding:.7rem .4rem;display:flex;flex-direction:column;align-items:center;border:1.5px solid #e0e7ef;min-width:0;max-width:100%;width:100%;transition:transform .18s,box-shadow .18s;position:relative}.producto-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 32px #1976d244;border:1.5px solid #1976d2}.producto-card img{width:60px;height:60px;object-fit:cover;border-radius:10px;margin-bottom:.5rem;box-shadow:0 2px 10px #b6e0fa33;background:#fff}.producto-card .nombre{font-size:.98rem;font-weight:600;color:#222;margin-bottom:.12rem;text-align:center;letter-spacing:.5px}.producto-card .precio{color:#222;font-size:.93rem;font-weight:500;margin-bottom:.08rem;text-align:center}.producto-card .categoria{font-size:.85rem;color:#42a5f5;margin-bottom:.3rem}.producto-card .btn-add{margin-top:.3rem;background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;border:none;border-radius:7px;padding:.35rem .8rem;font-size:.93rem;font-weight:700;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;box-shadow:0 2px 10px #1976d233;width:100%;max-width:120px}.producto-card .btn-add:hover{background:linear-gradient(90deg,#42a5f5,#1976d2);color:#1976d2;box-shadow:0 4px 18px #1976d255}.carrito-fab-btn{display:flex!important;position:fixed;top:1.1rem;right:1.1rem;z-index:100;background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;border:none;border-radius:50%;width:44px;height:44px;align-items:center;justify-content:center;box-shadow:0 4px 18px #1976d255;font-size:1.5rem;cursor:pointer;transition:background .2s,box-shadow .2s,transform .15s}.carrito-fab-btn:active{background:linear-gradient(90deg,#42a5f5,#1976d2);transform:scale(.96)}.categorias-lateral{position:fixed;top:4.5rem;right:0;z-index:200;background:#fff;border-radius:18px 0 0 18px;box-shadow:-2px 8px 32px #b6e0fa55;padding:1.3rem 1.1rem 1.3rem 1.3rem;display:flex;flex-direction:column;align-items:flex-end;border:1.5px solid #e0e7ef;border-right:0;min-width:170px;max-width:220px;transition:transform .45s cubic-bezier(.4,2,.6,1),opacity .35s cubic-bezier(.4,2,.6,1),box-shadow .3s;opacity:1;pointer-events:auto}.categorias-lateral.oculto{transform:translate(120%);opacity:0;pointer-events:none}.categoria-btn{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;border:none;border-radius:10px;padding:.5rem 1.2rem;font-size:.97rem;width:100%;text-align:right;cursor:pointer;margin-bottom:.5rem;font-weight:700;box-shadow:0 2px 10px #1976d233;transition:background .28s,color .22s,box-shadow .22s,transform .15s;outline:none;letter-spacing:1px;white-space:normal;word-break:break-word;display:flex;align-items:center;justify-content:flex-end}.categoria-btn:hover,.categoria-btn.activa{background:linear-gradient(90deg,#42a5f5,#1976d2);color:#fff;box-shadow:0 4px 18px #1976d255;font-weight:700;transform:translateY(-2px) scale(1.07);border:none}.categorias-toggle{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;border:none;border-radius:0 16px 16px 0;padding:1rem 2.2rem 1rem 1.2rem;font-size:1.08rem;font-weight:700;cursor:pointer;box-shadow:2px 4px 16px #1976d244;transition:background .25s,color .2s,box-shadow .2s,transform .18s;outline:none;margin-bottom:.3rem;letter-spacing:1px;border-left:0}.categorias-toggle:hover,.categorias-toggle:focus{background:linear-gradient(90deg,#42a5f5,#1976d2);color:#fff;transform:translateY(-2px) scale(1.04);box-shadow:0 4px 18px #1976d255}.filtro-categorias{position:fixed;top:5.2rem;left:0;z-index:200;min-width:180px;max-width:270px;background:#fff;border-radius:0 18px 18px 0;box-shadow:2px 8px 32px #b6e0fa55;padding:1.3rem 1rem 1.3rem 1.3rem;display:flex;flex-direction:column;align-items:flex-start;border:1.5px solid #e0e7ef;border-left:0;transform:translate(-120%);opacity:0;pointer-events:none;transition:transform .45s cubic-bezier(.4,2,.6,1),opacity .35s cubic-bezier(.4,2,.6,1),box-shadow .3s;overflow-y:visible}.filtro-categorias.abierto{transform:translate(0);opacity:1;pointer-events:auto}.carrito-movil-panel{display:none;flex-direction:column;position:fixed;top:0;right:0;width:97vw;max-width:370px;height:100vh;background:#fff;box-shadow:-2px 0 32px #1976d244;z-index:101;padding:2rem 1.2rem;border-radius:0 0 0 22px;animation:slideInCarrito .28s cubic-bezier(.4,2,.6,1);overflow-y:auto}.carrito-movil-panel.visible{display:flex!important;animation:slideInCarrito .28s cubic-bezier(.4,2,.6,1)}@keyframes slideInCarrito{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.producto-card .nombre,.producto-card .precio{word-break:break-word;white-space:normal;text-align:center}.carrito-finalizar{background:linear-gradient(90deg,#f59e42,#f43f5e);color:#fff;border:none;border-radius:999px;padding:.9rem 2.2rem;font-size:1.08rem;font-weight:700;cursor:pointer;box-shadow:0 2px 12px #f59e4233;transition:background .18s,color .18s,box-shadow .18s,transform .13s;outline:none;width:100%;margin-top:1.1rem;letter-spacing:1px}.carrito-finalizar:disabled,.carrito-finalizar[aria-disabled=true]{background:#e5e7eb;color:#aaa;cursor:not-allowed;box-shadow:none}.carrito-finalizar:hover:not(:disabled){background:linear-gradient(90deg,#f43f5e,#f59e42);color:#fff;transform:scale(1.04);box-shadow:0 4px 18px #f43f5e44}.btn-mis-pedidos{background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;border:none;border-radius:999px;padding:.8rem 2rem;font-size:1.03rem;font-weight:700;cursor:pointer;box-shadow:0 2px 12px #1976d244;transition:background .18s,color .18s,box-shadow .18s,transform .13s;outline:none;width:100%;margin-top:.7rem;letter-spacing:1px}.btn-mis-pedidos:hover{background:linear-gradient(90deg,#42a5f5,#1976d2);color:#fff;transform:scale(1.04);box-shadow:0 4px 18px #1976d255}.carrito-movil-panel.visible{border:2.5px solid #1976d2;box-shadow:0 8px 32px #1976d244,0 0 0 4px #42a5f522;animation:slideInCarrito .28s cubic-bezier(.4,2,.6,1)}@media (max-width: 700px){.clientes-layout{flex-direction:column;align-items:center;padding:.7rem .2rem 1.2rem;min-width:0;width:100vw;box-sizing:border-box}.catalogo{width:100%;min-width:0;max-width:100vw;padding:0;margin:0 auto;align-items:center;display:flex;flex-direction:column}.productos-catalogo{grid-template-columns:repeat(3,1fr);gap:.7rem;padding:0 .2rem;width:100%;justify-items:center;align-items:stretch;margin:0 auto}.producto-card{min-width:0;max-width:100%;width:100%;padding:.4rem .1rem .7rem;border-radius:10px;box-shadow:0 2px 8px #b6e0fa22;margin:0;display:flex;flex-direction:column;align-items:center;border:1px solid #e0e7ef;background:#fff;position:relative}.producto-card img{width:40px;height:40px;border-radius:7px;margin-bottom:.25rem;object-fit:cover;box-shadow:0 1px 4px #b6e0fa33;background:#fff}.producto-card .nombre{font-size:.83rem;font-weight:600;margin-bottom:.07rem;line-height:1.1;min-height:1.7em;text-align:center;width:100%}.producto-card .precio{font-size:.77rem;margin-bottom:.07rem;line-height:1.1;text-align:center;width:100%}.producto-card .categoria{font-size:.68rem;margin-bottom:.13rem;color:#42a5f5;text-align:center;width:100%}.producto-card .btn-add{font-size:.78rem;padding:.18rem .5rem;border-radius:6px;margin-top:.13rem;max-width:70px;width:100%;min-width:0;align-self:center}.productos-catalogo{margin-bottom:1.2rem}}@media (max-width: 700px){.producto-card:not(:last-child){margin-bottom:.2rem}}@media (max-width: 700px){.categorias-toggle{position:fixed;left:.7rem;top:1.1rem;z-index:201;border-radius:16px 0 0 16px;padding:.7rem 1.3rem .7rem 1rem;font-size:1rem;box-shadow:2px 4px 16px #1976d244;margin-bottom:0;margin-left:0;margin-right:0}}@media (max-width: 700px){.clientes-layout{padding-top:3.5rem}}@media (max-width: 700px){.titulo-desavio{font-size:2.1rem;margin-bottom:1.3rem}.titulo-desavio:after{height:14px}}.modal-bg{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000008c;display:flex!important;align-items:center!important;justify-content:center!important;z-index:9999;padding:1.5rem;box-sizing:border-box}.modal-panel{background:linear-gradient(120deg,#f5f7fa,#c3cfe2);color:#1976d2;border-radius:20px;padding:2.2rem 2.7rem;min-width:320px;max-width:95vw;width:100%;max-width:420px;box-shadow:0 8px 32px #1976d255,0 1.5px 8px #42a5f555;position:relative;display:flex;flex-direction:column;align-items:center;animation:modalFadeIn .4s cubic-bezier(.4,2,.6,1);border:2.5px solid #42a5f533;margin:0 auto}@keyframes modalFadeIn{0%{transform:scale(.92) translateY(40px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#1976d2;font-size:2.1rem;cursor:pointer;transition:color .2s;z-index:2}.close-btn:hover{color:#e040fb}.modal-panel input{width:100%;margin:.5rem 0;padding:.7rem 1rem;border-radius:8px;border:1.5px solid #42a5f5;background:#fff;color:#1976d2;font-size:1rem;box-shadow:0 1px 4px #42a5f522;transition:border .2s}.modal-panel input:focus{border:1.5px solid #1976d2;outline:none}.modal-panel button:not(.close-btn){margin-top:1.2rem;background:linear-gradient(90deg,#1976d2,#42a5f5);color:#fff;border:none;border-radius:8px;padding:.9rem 1.7rem;font-size:1.13rem;font-weight:700;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s,transform .15s;box-shadow:0 2px 8px #1976d233;letter-spacing:1px;width:100%;max-width:100%;min-width:0;display:block}.modal-panel button:not(.close-btn):hover{background:linear-gradient(90deg,#42a5f5,#1976d2);color:#fff;box-shadow:0 4px 16px #1976d255;transform:translateY(-2px) scale(1.04)}.error{color:#ff5252;margin-top:1rem;font-weight:700;text-align:center;width:100%}.tipo-btn{background:#e3f2fd;color:#1976d2;border:2px solid #90caf9;font-weight:700;transition:background .2s,color .2s,border .2s,box-shadow .2s;box-shadow:0 2px 8px #1976d233;margin-right:.5rem}.tipo-btn.selected,.tipo-btn[aria-pressed=true]{background:linear-gradient(90deg,#ff9800,#d84315);color:#fff;border:2.5px solid #d84315;box-shadow:0 8px 24px #d8431588,0 0 0 2px #ff980055;transform:scale(1.12);z-index:1;filter:none}@media (max-width: 600px){.modal-bg{padding:.5rem}.modal-panel{padding:.7rem .5rem;min-width:0;max-width:94vw;width:95vw;border-radius:12px;box-shadow:0 4px 18px #1976d255,0 1.5px 8px #42a5f555;margin:0 auto;font-size:.97rem;align-items:stretch}.close-btn{top:.4rem;right:.4rem;font-size:2rem}.modal-panel input{font-size:1rem;padding:.7rem;margin:.3rem 0;width:90vw;max-width:90vw;box-sizing:border-box}.modal-panel button:not(.close-btn){padding:.85rem .5rem;font-size:1rem;border-radius:7px;margin-top:.7rem;width:100%;min-width:0;max-width:100%}.modal-panel h2,.modal-panel h3{font-size:1.08rem;margin:.6rem 0 .4rem}.error{font-size:.98rem;margin-top:.5rem}.tipo-btn{font-size:1.02rem;padding:.7rem;margin-bottom:.5rem;width:48%;min-width:0;max-width:100%;box-sizing:border-box}}.ventas-container{max-width:1200px;margin:0 auto;padding:2rem 1rem;font-family:Segoe UI,Arial,sans-serif;background:#f6f7fb}.ventas-resumen{background:#f3e8ff;border-radius:10px;padding:1.5rem 2rem;margin-bottom:2rem;box-shadow:0 2px 8px #d1c4e933;display:flex;flex-wrap:wrap;gap:2rem}.ventas-resumen-section{flex:1 1 220px;background:#fff;border-radius:8px;box-shadow:0 1px 4px #d1c4e922;padding:1rem 1.2rem;margin-bottom:.5rem}.ventas-resumen-section strong{display:block;margin-bottom:.5rem;color:#7c3aed}.ventas-resumen ul,.ventas-resumen ol{margin:.5rem 0 0 1rem;padding:0}.ventas-resumen-section:last-child{margin-bottom:0}.ventas-resumen-total{font-size:1.3rem;font-weight:700;color:#6d28d9;margin-bottom:1rem}.ventas-resumen-monto{font-size:1.1rem;color:#4b5563;margin-bottom:.7rem}.ventas-productos-filtros{margin:2rem 0 1.5rem;display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-start}.ventas-productos-filtros button{padding:.7rem 1.5rem;border-radius:6px;border:1px solid #c4b5fd;background:#ede9fe;color:#6d28d9;font-weight:600;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;font-size:1rem;box-shadow:0 1px 4px #d1c4e922}.ventas-productos-filtros button.activo,.ventas-productos-filtros button:hover{background:#6d28d9;color:#fff;border-color:#7c3aed;box-shadow:0 2px 8px #c4b5fd66}.ventas-productos-filtros button:focus{outline:2px solid #7c3aed}.ventas-productos-lista{background:#fff;border-radius:10px;box-shadow:0 2px 8px #d1c4e933;padding:1.5rem 2rem;margin-bottom:2rem;max-width:600px}.ventas-productos-lista h3{color:#6d28d9;margin-bottom:1rem}.ventas-productos-lista ol{margin:0;padding-left:1.2rem}.ventas-productos-lista li{font-size:1.05rem;margin-bottom:.5rem;color:#4b5563}.ventas-table{width:100%;border-collapse:collapse;margin-top:1rem;background:#fff;border-radius:8px;box-shadow:0 1px 4px #d1c4e922}.ventas-table th,.ventas-table td{padding:.8rem .5rem;border-bottom:1px solid #ede9fe;text-align:left;font-size:1rem}.ventas-table th{background:#ede9fe;color:#6d28d9;font-weight:600}.ventas-table tr:last-child td{border-bottom:none}@media (max-width: 900px){.ventas-resumen{flex-direction:column;gap:1rem;padding:1rem}.ventas-table th,.ventas-table td{font-size:.95rem;padding:.6rem .3rem}.ventas-productos-lista{padding:1rem}}@media (max-width: 600px){.ventas-container{padding:1rem .3rem}.ventas-resumen{padding:.7rem}.ventas-productos-lista{padding:.7rem;max-width:100%}.ventas-table th,.ventas-table td{font-size:.9rem;padding:.5rem .2rem}}
