*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1D9E75;--primary-dark: #178a65;--navy: #0F2B4C;--danger: #dc2626;--bg: #f3f4f6;--card: #ffffff;--text: #1a1a2e;--muted: #6b7280;--border: #e5e7eb;--topbar-h: 56px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}#app{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);position:relative}.topbar{position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--topbar-h);background:var(--navy);color:#fff;display:flex;align-items:center;padding:0 4px;z-index:100}.topbar-btn{background:none;border:none;color:#fff;cursor:pointer;width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;border-radius:8px}.topbar-btn:hover{background:#ffffff1a}.topbar-btn.ghost{visibility:hidden}.topbar-title{flex:1;text-align:center;font-size:17px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page{min-height:100vh}.page-body{padding-top:var(--topbar-h);padding-bottom:32px;min-height:100vh}.menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200;display:none}.menu-overlay.open{display:block}.menu-drawer{position:absolute;left:0;top:0;bottom:0;width:270px;background:var(--navy);display:flex;flex-direction:column;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.menu-drawer-header{height:var(--topbar-h);display:flex;align-items:center;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.1)}.menu-brand{color:#fff;font-size:18px;font-weight:700}.menu-items{flex:1;padding:8px 0;overflow-y:auto}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:15px 20px;color:#cbd5e1;background:none;border:none;text-align:left;font-size:15px;cursor:pointer;text-decoration:none;transition:background .15s,color .15s}.menu-item:hover{background:#ffffff14;color:#fff}.menu-item-icon{font-size:18px;width:24px;text-align:center}.menu-footer{padding:8px 0 16px;border-top:1px solid rgba(255,255,255,.1)}.menu-item.danger{color:#fca5a5}.menu-item.danger:hover{background:#dc262626;color:#fca5a5}.page-section-title{padding:20px 16px 8px;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}.rend-card{background:var(--card);border-radius:12px;margin:0 12px 10px;padding:16px;box-shadow:0 1px 3px #00000014;cursor:pointer;transition:box-shadow .15s,transform .1s;-webkit-tap-highlight-color:transparent}.rend-card:active{transform:scale(.98);box-shadow:0 1px 2px #0000000f}.rend-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.rend-card-title{font-size:16px;font-weight:600;color:var(--text)}.rend-card-sub{font-size:13px;color:var(--muted);margin-top:3px}.rend-card-total{font-size:20px;font-weight:700;color:var(--navy)}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}.badge-borrador{background:#fef3c7;color:#92400e}.badge-cerrada{background:#d1fae5;color:#065f46}.empty-state{text-align:center;padding:60px 24px;color:var(--muted)}.empty-icon{font-size:52px;margin-bottom:14px}.empty-text{font-size:15px;line-height:1.5}.form-body{padding:16px;display:flex;flex-direction:column;gap:0}.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.field-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.optional{font-weight:400;text-transform:none}input[type=text],input[type=number],input[type=date],input[type=email],input[type=password],select,textarea{width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:16px;color:var(--text);background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:border-color .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}input:disabled,select:disabled{background:#f9fafb;color:var(--muted)}input[type=file]{font-size:14px;color:var(--text);padding:10px 14px;border:1.5px dashed var(--border);border-radius:10px;background:#fafafa}.file-hint{font-size:12px;color:var(--muted)}.tipo-tabs{display:flex;gap:8px}.tipo-tab{flex:1;padding:11px 6px;border:1.5px solid var(--border);border-radius:10px;background:#fff;font-size:13px;font-weight:600;cursor:pointer;text-align:center;color:var(--muted);transition:all .15s}.tipo-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.moneda-toggle{display:flex;gap:8px}.moneda-btn{flex:1;padding:11px;border:1.5px solid var(--border);border-radius:10px;background:#fff;font-size:14px;font-weight:700;cursor:pointer;color:var(--muted);transition:all .15s}.moneda-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}.monto-calc{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;background:#f9fafb;border-radius:10px;border:1px solid var(--border);margin-top:4px}.monto-calc.monto-total{background:#ecfdf5;border-color:#a7f3d0}.calc-label{font-size:13px;color:var(--muted)}.calc-value{font-size:15px;font-weight:700;color:var(--navy)}.monto-total .calc-value{color:#065f46}.form-error{font-size:14px;padding:11px 14px;background:#fee2e2;color:#991b1b;border-radius:10px;margin-bottom:16px}.form-error.hidden{display:none}.btn{display:flex;align-items:center;justify-content:center;padding:15px 20px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:all .15s;-webkit-tap-highlight-color:transparent;gap:8px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{background:#f9fafb}.btn-ghost{background:transparent;color:var(--danger);border:1.5px solid #fca5a5}.btn-ghost:hover{background:#fee2e2}.btn-full{width:100%}.bottom-actions{padding:8px 16px 16px;display:flex;flex-direction:column;gap:10px}.totals-strip{background:var(--navy);color:#fff;padding:20px 16px}.totals-label{font-size:12px;opacity:.65;text-transform:uppercase;letter-spacing:.6px}.totals-amount{font-size:32px;font-weight:700;margin-top:2px}.totals-count{font-size:13px;opacity:.65;margin-top:4px}.rend-info-card{background:var(--card);margin:12px 12px 0;border-radius:12px;padding:16px;box-shadow:0 1px 3px #00000012}.rend-info-numero{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}.rend-info-desc{font-size:17px;font-weight:600;color:var(--text);margin-bottom:10px}.rend-info-desc-input{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:16px;color:var(--text);background:#fff;margin-bottom:10px}.rend-info-desc-input:focus{outline:none;border-color:var(--primary)}.rend-info-bottom{display:flex;justify-content:space-between;align-items:center}.rend-info-fecha{font-size:13px;color:var(--muted)}.lines-section-title{padding:16px 16px 8px;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.line-item{background:var(--card);margin:0 12px 8px;border-radius:12px;padding:14px;box-shadow:0 1px 3px #0000000f;display:flex;align-items:center;gap:10px}.line-body{flex:1;min-width:0}.line-desc{font-size:15px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.line-meta{font-size:12px;color:var(--muted);margin-top:3px}.line-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}.line-monto{font-size:16px;font-weight:700;color:var(--navy)}.line-actions{display:flex;gap:2px}.line-btn{background:none;border:none;cursor:pointer;padding:4px 7px;font-size:16px;color:var(--muted);border-radius:6px;transition:background .15s;-webkit-tap-highlight-color:transparent}.line-btn:hover{background:#f3f4f6}.config-section{background:var(--card);border-radius:12px;margin:0 12px 12px;padding:16px;box-shadow:0 1px 3px #00000012}.config-section-title{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:14px}.inline-form{display:flex;gap:10px;align-items:flex-end}.inline-form input{flex:1;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:15px}.inline-form input:focus{outline:none;border-color:var(--primary)}.inline-form .btn{flex-shrink:0;padding:12px 18px;font-size:14px}.cat-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.cat-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#f9fafb;border-radius:8px;border:1px solid var(--border)}.cat-item.inactive{opacity:.45}.cat-item span{font-size:14px}.btn-toggle{font-size:12px;padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:#fff;cursor:pointer;font-weight:600;color:var(--muted);transition:all .15s}.btn-toggle:hover{background:#f3f4f6}.config-msg{font-size:13px;padding:8px 12px;border-radius:8px;margin-top:8px}.config-msg.hidden{display:none}.config-msg.success{background:#d1fae5;color:#065f46}.config-msg.error{background:#fee2e2;color:#991b1b}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--navy)}.login-card{background:#fff;border-radius:16px;padding:32px 24px;width:100%;max-width:360px}.login-title{font-size:26px;font-weight:700;color:var(--navy);margin-bottom:6px}.login-sub{font-size:14px;color:var(--muted);margin-bottom:24px}.login-msg{font-size:13px;padding:10px 14px;border-radius:8px;margin-top:8px}.login-msg.hidden{display:none}.login-msg.success{background:#d1fae5;color:#065f46}.login-msg.error{background:#fee2e2;color:#991b1b}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:500;display:flex;align-items:center;justify-content:center;padding:16px}.modal-inner{background:#fff;border-radius:12px;max-width:100%;max-height:90vh;overflow:auto;position:relative}.modal-close{position:absolute;top:8px;right:8px;background:#0000008c;color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:1}.modal-inner img{max-width:100%;display:block;border-radius:12px}
