:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;--color-bg: #ffffff;--color-bg-elevated: #f8fafc;--color-fg: #0f172a;--color-fg-muted: #475569;--color-border: #e2e8f0;--color-primary: #2563eb;--color-primary-fg: #ffffff;--color-success: #15803d;--color-danger: #b91c1c;--color-warning: #ca8a04;--shadow-card: 0 1px 3px rgba(0, 0, 0, .1);--radius-card: 8px;--radius-btn: 6px}[data-theme=gray]{--color-bg: #e5e7eb;--color-bg-elevated: #d1d5db;--color-fg: #111827;--color-fg-muted: #4b5563;--color-border: #9ca3af;--color-primary: #1e40af;--color-primary-fg: #ffffff;--color-success: #14532d;--color-danger: #991b1b;--shadow-card: 0 1px 3px rgba(0, 0, 0, .15)}[data-theme=dark]{--color-bg: #0f172a;--color-bg-elevated: #1e293b;--color-fg: #f1f5f9;--color-fg-muted: #94a3b8;--color-border: #334155;--color-primary: #60a5fa;--color-primary-fg: #0f172a;--color-success: #4ade80;--color-danger: #f87171;--color-warning: #fcd34d;--shadow-card: 0 1px 3px rgba(0, 0, 0, .5)}*{box-sizing:border-box}body{margin:0;background-color:var(--color-bg);color:var(--color-fg);transition:background-color .2s ease,color .2s ease}.app-container{padding:2rem;max-width:960px;margin:0 auto}.app-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.app-header h1{margin:0;font-size:1.5rem}.card{background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-card);padding:1rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-card)}.card p{margin:.5rem 0}.badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.875rem;font-weight:600}.badge-success{background-color:var(--color-success);color:var(--color-primary-fg)}.badge-danger{background-color:var(--color-danger);color:var(--color-primary-fg)}.theme-toggle{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius-btn);overflow:hidden;background-color:var(--color-bg-elevated)}.theme-btn{background:transparent;border:none;padding:.5rem .875rem;font-size:.875rem;cursor:pointer;color:var(--color-fg-muted);border-right:1px solid var(--color-border);transition:all .15s ease}.theme-btn:last-child{border-right:none}.theme-btn:hover{background-color:var(--color-bg);color:var(--color-fg)}.theme-btn.active{background-color:var(--color-primary);color:var(--color-primary-fg);font-weight:600}code{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;padding:.125rem .375rem;font-family:Consolas,Monaco,monospace;font-size:.875em}.theme-toggle-floating{position:fixed;top:.5rem;right:.5rem;z-index:1000;display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius-btn);background-color:var(--color-bg-elevated);opacity:.85}.theme-toggle-floating:hover{opacity:1}.btn{background:var(--color-bg-elevated);color:var(--color-fg);border:1px solid var(--color-border);border-radius:var(--radius-btn);padding:.5rem 1rem;cursor:pointer;font-size:.95rem;font-weight:500;transition:background .15s ease}.btn:hover:not(:disabled){background:var(--color-bg)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-primary-fg);border-color:var(--color-primary)}.btn-sm{padding:.25rem .625rem;font-size:.85rem}.btn-icon{background:transparent;border:none;color:var(--color-fg-muted);cursor:pointer;padding:.25rem .5rem;border-radius:4px}.btn-icon:hover{color:var(--color-danger);background:var(--color-bg)}.num{text-align:right;font-variant-numeric:tabular-nums}.small{font-size:.85rem;color:var(--color-fg-muted)}.label{font-size:.85rem;color:var(--color-fg-muted);font-weight:600}.error-box{background:var(--color-danger);color:#fff;padding:.5rem .75rem;border-radius:var(--radius-btn);margin:.5rem 0;font-size:.9rem}.text-danger{color:var(--color-danger);font-weight:600}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-form{width:100%;max-width:360px;background:var(--color-bg-elevated);padding:2rem;border-radius:var(--radius-card);border:1px solid var(--color-border);box-shadow:var(--shadow-card)}.login-form h1{margin:0;font-size:1.5rem}.login-tenant{margin:.25rem 0 1.5rem}.login-form label{display:block;margin-bottom:1rem;font-size:.9rem;color:var(--color-fg-muted)}.login-form input{width:100%;padding:.5rem;font-size:1rem;border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-bg);color:var(--color-fg);margin-top:.25rem}.login-form .btn-primary{width:100%;padding:.75rem}.apertura-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.apertura-form{width:100%;max-width:480px;background:var(--color-bg-elevated);padding:2rem;border-radius:var(--radius-card);border:1px solid var(--color-border)}.apertura-form h1{margin:0}.apertura-form label{display:block;margin:1rem 0 0;font-size:.9rem;color:var(--color-fg-muted)}.apertura-form input,.apertura-form textarea{width:100%;padding:.5rem;font-size:1rem;border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-bg);color:var(--color-fg);margin-top:.25rem;font-family:inherit}.apertura-form .btn-primary{margin-top:1.5rem;width:100%;padding:.75rem}.pos-pantalla{height:100vh;display:flex;flex-direction:column;overflow:hidden}.pos-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);font-size:.9rem}.pos-header-left,.pos-header-right{display:flex;align-items:center;gap:1rem}.pos-header-meta{color:var(--color-fg-muted)}.pos-body{flex:1;display:grid;grid-template-columns:1fr 360px;gap:0;overflow:hidden}.pos-cart-side{display:flex;flex-direction:column;padding:.75rem;overflow:hidden}.pos-scanner{position:relative;margin-bottom:.75rem}.pos-scanner-input{width:100%;padding:.875rem 1rem;font-size:1.1rem;border:2px solid var(--color-primary);border-radius:var(--radius-btn);background:var(--color-bg);color:var(--color-fg)}.pos-error{background:var(--color-danger);color:#fff;padding:.5rem;border-radius:4px;margin-top:.5rem;font-size:.9rem}.pos-sugerencias{position:absolute;top:100%;left:0;right:0;margin:0;padding:0;list-style:none;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-btn);max-height:280px;overflow-y:auto;z-index:10}.pos-sugerencias li{padding:.5rem .75rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--color-border)}.pos-sugerencias li:hover{background:var(--color-bg)}.pos-sugerencia-precio{font-weight:600;color:var(--color-primary)}.pos-carrito{flex:1;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-bg-elevated)}.pos-carrito-header{display:grid;grid-template-columns:32px 1fr 80px 80px 100px 32px;gap:.5rem;padding:.5rem;background:var(--color-bg);border-bottom:1px solid var(--color-border);font-size:.8rem;font-weight:600;color:var(--color-fg-muted)}.pos-carrito-vacio{padding:3rem 1rem;text-align:center;color:var(--color-fg-muted)}.pos-linea{display:grid;grid-template-columns:32px 1fr 80px 80px 100px 32px;gap:.5rem;padding:.5rem;align-items:center;border-bottom:1px solid var(--color-border)}.pos-linea:hover{background:var(--color-bg)}.pos-linea-num{color:var(--color-fg-muted);text-align:center}.pos-linea-desc{overflow:hidden}.pos-linea-desc>div:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pos-totales-side{background:var(--color-bg-elevated);border-left:1px solid var(--color-border);padding:1rem;display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.pos-cliente{background:var(--color-bg);padding:.75rem;border-radius:var(--radius-btn)}.pos-cliente .cliente-nombre{font-weight:600;margin-top:.25rem}.pos-totales{padding:0}.pos-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.9rem}.pos-total-final{display:flex;justify-content:space-between;align-items:baseline;border-top:2px solid var(--color-border);padding-top:.75rem;margin-top:.5rem;font-weight:700;font-size:1rem}.pos-total-final .total-monto{font-size:1.8rem;color:var(--color-primary)}.pos-acciones{display:flex;flex-direction:column;gap:.5rem;margin-top:auto}.btn-cobrar{padding:1rem;font-size:1.1rem;font-weight:700}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal-content{background:var(--color-bg-elevated);border-radius:var(--radius-card);border:1px solid var(--color-border);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0}.modal-body{padding:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem;border-top:1px solid var(--color-border)}.cobrar-total{text-align:center;margin-bottom:1.5rem;padding:1rem;background:var(--color-bg);border-radius:var(--radius-btn)}.cobrar-total .monto{display:block;font-size:2.25rem;font-weight:700;color:var(--color-primary);margin-top:.25rem}.cobrar-cai{margin-bottom:1rem}.cobrar-cai label,.cobrar-pagos .label{display:block;margin-bottom:.25rem}.cobrar-cai select,.pago-row select,.pago-row input{padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-bg);color:var(--color-fg);font-size:1rem;width:100%}.pago-row{display:grid;grid-template-columns:1fr 120px 32px;gap:.5rem;margin:.5rem 0}.cobrar-resumen{margin-top:1rem;padding:.75rem;background:var(--color-bg);border-radius:var(--radius-btn)}.cobrar-resumen .row{display:flex;justify-content:space-between;margin:.25rem 0}.cobrar-resumen .vuelto{font-weight:700;color:var(--color-success);font-size:1.1rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.signup-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:2rem 1rem 3rem;gap:1.5rem}.signup-header{text-align:center;max-width:420px}.signup-header h1{margin:0;font-size:1.75rem;color:var(--color-fg)}.signup-header p{margin:.25rem 0 0;color:var(--color-fg-muted)}.signup-steps{list-style:none;margin:0;padding:0;display:flex;gap:.5rem;width:100%;max-width:420px}.signup-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;font-size:.8rem;color:var(--color-fg-muted)}.signup-step-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-bg-elevated);border:2px solid var(--color-border);font-weight:700;font-size:.85rem}.signup-step-current .signup-step-num{background:var(--color-primary, #2563eb);border-color:var(--color-primary, #2563eb);color:#fff}.signup-step-current .signup-step-label{color:var(--color-fg);font-weight:600}.signup-step-done .signup-step-num{background:var(--color-success, #16a34a);border-color:var(--color-success, #16a34a);color:#fff}.signup-step-done .signup-step-num:after{content:""}.signup-card{width:100%;max-width:420px;background:var(--color-bg-elevated);padding:2rem;border-radius:var(--radius-card);border:1px solid var(--color-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:.85rem}.signup-card h2{margin:0;font-size:1.25rem;color:var(--color-fg)}.signup-card .small{color:var(--color-fg-muted);font-size:.85rem}.signup-card label{display:block;font-size:.9rem;color:var(--color-fg-muted)}.signup-card input[type=text],.signup-card input[type=email],.signup-card input[type=password],.signup-card input[type=tel]{width:100%;padding:.6rem .75rem;font-size:1rem;border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-bg);color:var(--color-fg);margin-top:.3rem}.signup-card .opcional{color:var(--color-fg-muted);font-weight:400;font-size:.8rem}.signup-card .hint{display:block;margin-top:.25rem;font-size:.75rem}.signup-card .checkbox-row{display:flex;gap:.5rem;align-items:flex-start;margin-top:.5rem}.signup-card .checkbox-row input[type=checkbox]{margin-top:.2rem;width:18px;height:18px;flex-shrink:0}.signup-card .checkbox-row span{font-size:.85rem;color:var(--color-fg);line-height:1.4}.signup-card .checkbox-row a{color:var(--color-primary, #2563eb);text-decoration:underline}.signup-card .btn{margin-top:.5rem;padding:.75rem;font-size:1rem}.signup-actions{display:flex;gap:.75rem;margin-top:.5rem}.signup-actions .btn{flex:1}.signup-footer-link{text-align:center;margin:0;font-size:.9rem;color:var(--color-fg-muted)}.signup-footer-link a{color:var(--color-primary, #2563eb);text-decoration:underline}.signup-success,.signup-error,.signup-loading{text-align:center;align-items:center}.signup-success-icon{font-size:3rem;color:var(--color-success, #16a34a);line-height:1}.signup-error-icon{font-size:3rem;color:var(--color-warning, #f59e0b);line-height:1}.signup-tenant-url{display:inline-block;padding:.25rem .5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-btn);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.85rem;word-break:break-all}.signup-cta{width:100%;text-align:center;text-decoration:none;display:inline-block}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary, #2563eb);border-radius:50%;animation:signup-spin .8s linear infinite;margin-bottom:.5rem}@keyframes signup-spin{to{transform:rotate(360deg)}}
