:root{--sage: #4E7E31;--sage-mid: #6FA040;--sage-light: #C8EE98;--bg: #F2F4EF;--card: #FFFFFF;--text: #243318;--text-muted: #6B7660;--border: #DDE3D5;--danger: #C0392B;--warning: #E67E22;--info: #2980B9;--success: #27AE60}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;overscroll-behavior:none}button{font-family:inherit;cursor:pointer;border:none;font-size:15px}input,select,textarea{font-family:inherit;font-size:16px;width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--sage-mid);box-shadow:0 0 0 3px #6fa04026}.app{min-height:100vh;min-height:100dvh;padding-bottom:80px;padding-top:env(safe-area-inset-top)}.header{position:sticky;top:0;z-index:10;background:linear-gradient(130deg,var(--sage),var(--sage-mid));color:#fff;padding:calc(env(safe-area-inset-top) + 14px) 18px 14px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0000001a}.header h1{margin:0;font-size:18px;font-weight:700}.header .back{color:#fff;background:transparent;padding:6px 10px;font-size:22px}.container{padding:16px}.card{background:var(--card);border-radius:14px;padding:16px;margin-bottom:12px;box-shadow:0 1px 4px #0000000a;border:1px solid var(--border)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 20px;border-radius:12px;font-weight:600;width:100%;min-height:50px;background:var(--sage);color:#fff;transition:background .15s}.btn:active{background:var(--sage-mid)}.btn:disabled{opacity:.5}.btn.secondary{background:#fff;color:var(--sage);border:1.5px solid var(--sage)}.btn.danger{background:var(--danger)}.btn.warning{background:var(--warning)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:8px 0 calc(env(safe-area-inset-bottom) + 6px);z-index:20}.bottom-nav a{flex:1;text-align:center;text-decoration:none;color:var(--text-muted);font-size:12px;padding:6px 0}.bottom-nav a.active{color:var(--sage);font-weight:700}.bottom-nav a .icon{display:block;font-size:24px;line-height:1;margin-bottom:2px}.bottom-nav-version{position:absolute;bottom:calc(env(safe-area-inset-bottom) + 2px);right:6px;font-size:9px;color:var(--text-muted);opacity:.45;pointer-events:none}.list-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:#fff;border-bottom:1px solid var(--border);cursor:pointer}.list-item:active{background:#f8f9f5}.list-item .left{flex:1;min-width:0}.list-item .left .title{font-weight:600;color:var(--text)}.list-item .left .subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.list-item .right{text-align:right;padding-left:12px}.list-item .right .amount{font-weight:700;color:var(--text)}.badge{display:inline-block;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase}.badge.pending{background:#fff3e0;color:#e67e22}.badge.ocr_done{background:#e3f2fd;color:#2980b9}.badge.ocr_failed{background:#ffebee;color:#c0392b}.badge.validated{background:#e8f5e9;color:#27ae60}.badge.paid{background:#e8f5e9;color:#1b5e20}.badge.cancelled{background:#eceff1;color:#607d8b}.field{margin-bottom:14px}.field label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.error{color:var(--danger);padding:12px;background:#ffebee;border-radius:10px;margin-bottom:12px}.info{color:var(--info);padding:12px;background:#e3f2fd;border-radius:10px;margin-bottom:12px}.success{color:var(--success);padding:12px;background:#e8f5e9;border-radius:10px;margin-bottom:12px}.spinner{display:inline-block;width:20px;height:20px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty .icon{font-size:64px;margin-bottom:16px;opacity:.5}
