:root{--bg:#0f172a;--surface:#1e293b;--surface2:#334155;--border:#475569;--text:#f1f5f9;--text-muted:#94a3b8;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#3b82f61f;--success:#22c55e;--success-light:#22c55e1f;--warning:#f59e0b;--warning-light:#f59e0b1f;--danger:#ef4444;--danger-light:#ef44441f;--radius:.75rem;--radius-sm:.5rem;--header-h:60px;--bottomnav-h:64px}[data-theme=light]{--bg:#f8fafc;--surface:#fff;--surface2:#f1f5f9;--border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;--accent-light:#3b82f61a;--success-light:#22c55e1a;--warning-light:#f59e0b1a;--danger-light:#ef44441a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background-color:var(--bg);color:var(--text);font-family:system-ui,Segoe UI,Roboto,sans-serif;line-height:1.5;overflow-x:hidden}html{overflow-x:hidden}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul,ol{list-style:none}a{color:inherit;text-decoration:none}#root,.app-layout{flex-direction:column;width:100%;min-height:100dvh;display:flex;overflow-x:hidden}.page{padding:1.5rem;padding-bottom:calc(var(--bottomnav-h) + 1.5rem);flex:1}.page-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.page-title{color:var(--text);font-size:1.5rem;font-weight:700}.top-header{z-index:50;height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:1rem;padding:0 1.25rem;display:flex;position:sticky;top:0}.top-header-brand{color:var(--accent);margin-right:auto;font-size:1.1rem;font-weight:700}.top-header-info{align-items:center;gap:.75rem;display:flex}.bottom-nav{height:var(--bottomnav-h);background:var(--surface);border-top:1px solid var(--border);z-index:50;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.25rem;padding:.5rem;font-size:.7rem;font-weight:500;text-decoration:none;transition:color .2s;display:flex}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item-center{background:var(--accent);color:#fff;border-radius:50%;flex:none;justify-content:center;align-self:center;align-items:center;width:48px;height:48px;margin:auto;display:flex;box-shadow:0 4px 12px #3b82f666}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:1.25rem}.card-sm{padding:1rem}.card-hover{cursor:pointer;transition:border-color .2s,transform .1s}.card-hover:hover{border-color:var(--accent)}.card-hover:active{transform:scale(.99)}.stat-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);flex-direction:column;gap:.5rem;padding:1.25rem;display:flex}.stat-card-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:.25rem;display:flex}.stat-card-value{color:var(--text);word-break:break-all;overflow-wrap:anywhere;font-size:1.75rem;font-weight:700;line-height:1}.stat-card-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.action-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:1.5rem 1rem;text-decoration:none;transition:all .2s;display:flex}.action-card:hover{border-color:var(--accent);background:var(--surface2)}.action-card-icon{background:var(--accent-light);width:48px;height:48px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;display:flex}.action-card-label{text-align:center;font-size:.875rem;font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;transition:background-color .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface2);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-outline{color:var(--accent);border:1px solid var(--accent);background:0 0}.btn-outline:hover:not(:disabled){background:var(--accent-light)}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface2);color:var(--text)}.btn-sm{padding:.4rem .875rem;font-size:.8rem}.btn-lg{padding:.875rem 2rem;font-size:1rem}.btn-icon{border-radius:var(--radius-sm);padding:.5rem}.btn-full{justify-content:center;width:100%}.form-group{flex-direction:column;gap:.4rem;display:flex}.label{color:var(--text-muted);font-size:.8rem;font-weight:500;display:block}.input,.select,.textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:.625rem .875rem;font-size:.9rem;transition:border-color .2s}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}.textarea{resize:vertical;min-height:80px}.select option{background:var(--surface2);color:var(--text)}.input-icon-wrap{position:relative}.input-icon{color:var(--text-muted);pointer-events:none;display:flex;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.input-with-icon{padding-left:2.5rem}.badge{white-space:nowrap;border-radius:100px;align-items:center;gap:.25rem;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--accent-light);color:#60a5fa}.badge-green{background:var(--success-light);color:#4ade80}.badge-red{background:var(--danger-light);color:#f87171}.badge-yellow{background:var(--warning-light);color:#fbbf24}.badge-gray{color:var(--text-muted);background:#94a3b81a}.divider{border:none;border-top:1px solid var(--border);margin:1rem 0}.sync-banner{align-items:center;gap:.75rem;padding:.625rem 1.25rem;font-size:.85rem;font-weight:500;display:flex}.sync-banner-offline{background:var(--warning-light);color:var(--warning);border-bottom:1px solid #f59e0b33}.sync-banner-syncing{background:var(--accent-light);color:var(--accent);border-bottom:1px solid #3b82f633}.sync-banner-pending{background:var(--danger-light);color:#f87171;border-bottom:1px solid #ef444426}.product-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;box-sizing:border-box;flex-direction:column;gap:.5rem;width:100%;min-width:0;height:160px;min-height:160px;max-height:160px;padding:1rem;transition:border-color .2s,transform .1s;display:flex;overflow:hidden}.product-card:hover{border-color:var(--accent)}.product-card:active{transform:scale(.99)}.product-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.product-card-code{color:var(--text-muted);font-family:monospace;font-size:.72rem}.product-card-name{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.85rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.product-card-marca{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.product-card-price{color:var(--accent);text-overflow:ellipsis;white-space:nowrap;margin-top:auto;font-size:1rem;font-weight:700;overflow:hidden}.venta-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.venta-card-header{cursor:pointer;justify-content:space-between;align-items:center;padding:1rem 1.25rem;transition:background .15s;display:flex}.venta-card-header:hover{background:var(--surface2)}.venta-card-body{border-top:1px solid var(--border);padding:0 1.25rem 1rem}.bar-chart{flex-direction:column;gap:.75rem;display:flex}.bar-row{align-items:center;gap:.75rem;display:flex}.bar-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;width:160px;min-width:160px;font-size:.8rem;overflow:hidden}.bar-track{background:var(--surface2);border-radius:100px;flex:1;height:10px;overflow:hidden}.bar-fill{background:var(--accent);border-radius:100px;height:100%;transition:width .4s}.bar-fill-green{background:var(--success)}.bar-fill-yellow{background:var(--warning)}.bar-value{color:var(--text-muted);text-align:right;min-width:80px;font-size:.8rem}.cart-item{background:var(--surface2);border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.75rem;display:flex}.cart-item-info{flex:1;min-width:0}.cart-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.cart-item-price{color:var(--text-muted);font-size:.8rem}.qty-control{align-items:center;gap:.25rem;display:flex}.qty-btn{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);width:28px;height:28px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;transition:background .15s;display:flex}.qty-btn:hover{background:var(--border)}.qty-value{text-align:center;width:32px;font-size:.9rem;font-weight:600}.chips{flex-wrap:wrap;gap:.5rem;display:flex}.chip{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:100px;padding:.35rem .875rem;font-size:.8rem;font-weight:500;transition:all .15s}.chip:hover{border-color:var(--accent);color:var(--text)}.chip.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;padding:2.5rem 2rem}.login-logo{align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.login-logo-icon{background:var(--accent);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.login-steps{gap:.5rem;margin-bottom:1.75rem;display:flex}.login-step{background:var(--surface2);border-radius:100px;flex:1;height:3px;transition:background .3s}.login-step.done{background:var(--accent)}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 1.5rem;display:flex}.empty-state-icon{background:var(--surface2);opacity:.6;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;display:grid}@media (width<=767px){.page{padding:1rem;padding-bottom:calc(var(--bottomnav-h) + 1rem);box-sizing:border-box;max-width:100vw}.card,.product-card,.stat-card,.action-card,.venta-card{box-sizing:border-box;max-width:100%}.truncate,.cart-item-name,.product-card-name{max-width:100%}.chips{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;max-width:100%;padding-bottom:.5rem;overflow-x:auto}.grid-3{grid-template-columns:1fr;justify-items:center}.grid-3>*,.grid-3 .product-card{width:80vw;max-width:80vw}.page-title{font-size:1.2rem}.grid-2{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}.bar-label{width:90px;min-width:90px}.stat-card-value{font-size:1.1rem}.stat-card{padding:1rem}.stat-card-icon{width:32px;height:32px}}@media (width<=479px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}.venta-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.venta-grid-single{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width<=767px){.venta-grid,.venta-grid-single{grid-template-columns:1fr}.venta-product-list{max-height:45vh;overflow-x:hidden}.venta-product-list .card{box-sizing:border-box;width:100%;min-width:0}}@media (width<=640px){.cart-item{flex-wrap:wrap;gap:.5rem}.cart-item-info{flex:none;width:100%}.cart-item-footer{align-items:center;gap:.5rem;width:100%;display:flex}.cart-item-subtotal{text-align:right;margin-left:auto}.top-header-name{display:none}.top-header{height:var(--header-h);flex-wrap:nowrap;gap:.4rem;padding:0 .75rem;overflow:hidden}.top-header-brand{white-space:nowrap;font-size:.9rem}.top-header-info{flex-shrink:0;gap:.4rem}.btn-sm{padding:.35rem .6rem;font-size:.75rem}}.flex{display:flex}.flex-col{flex-direction:column}.flex-center{justify-content:center;align-items:center}.flex-between{justify-content:space-between;align-items:center}.flex-start{align-items:flex-start}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.w-full{width:100%}.min-w-0{min-width:0}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-right{text-align:right}.text-center{text-align:center}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.mono{font-family:monospace}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tag{background:var(--surface2);color:var(--text-muted);border-radius:.25rem;padding:.15rem .5rem;font-size:.75rem;display:inline-block}.separator{color:var(--border)}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot-green{background:var(--success)}.dot-red{background:var(--danger)}.dot-yellow{background:var(--warning)}.carousel-item{flex:0 0 62%}@media (width>=480px){.carousel-item{flex:0 0 42%}}@media (width>=768px){.carousel-item{flex:0 0 28%}}@media (width>=1100px){.carousel-item{flex:0 0 20%}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border)}
