:root{--finca-red: #b50938;--finca-red-dark: #9e0831;--finca-red-light: #fdeef0;--finca-blue: #123a5f;--green: #1e7d43;--green-light: #e7f5ec;--orange: #c96a11;--orange-light: #fdf1e3;--ink: #22252a;--ink-soft: #5c636e;--line: #e3e0dc;--bg: #faf8f6;--card: #ffffff;--radius: 14px;--shadow: 0 1px 3px rgba(34, 37, 42, .08);--nav-height: 64px;--tap: 48px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink);font-size:16px;-webkit-tap-highlight-color:transparent}button,input,select,textarea{font:inherit;color:inherit}.app-shell{display:flex;flex-direction:column;height:100%;max-width:520px;margin:0 auto;background:var(--bg)}.app-header{display:flex;align-items:center;gap:10px;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top));background:var(--finca-red);color:#fff;position:sticky;top:0;z-index:10}.app-header .brand{font-weight:800;font-size:18px;letter-spacing:.2px;flex:1}.app-main{flex:1;overflow-y:auto;padding:16px;padding-bottom:calc(var(--nav-height) + 24px)}.page-title{font-size:20px;font-weight:800;margin:0 0 12px}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;height:calc(var(--nav-height) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);display:flex;background:var(--card);border-top:1px solid var(--line);z-index:10}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-decoration:none;color:var(--ink-soft);font-size:11px;font-weight:600}.bottom-nav a .icon{font-size:22px;line-height:1}.bottom-nav a.active{color:var(--finca-red)}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:12px}.list-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.list-row:last-child{border-bottom:none}.list-row .grow{flex:1;min-width:0}.list-row .title{font-weight:700}.muted{color:var(--ink-soft);font-size:13.5px}.amount{font-weight:800;white-space:nowrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:var(--tap);padding:0 18px;border:none;border-radius:var(--radius);font-weight:700;font-size:16px;cursor:pointer;background:var(--finca-red);color:#fff}.btn:active{background:var(--finca-red-dark)}.btn:disabled{opacity:.45;cursor:default}.btn.secondary{background:#fff;color:var(--finca-red);border:2px solid var(--finca-red)}.btn.ghost{background:transparent;color:var(--ink-soft);border:1.5px solid var(--line)}.btn.block{width:100%}.btn.big{min-height:56px;font-size:18px}.field{margin-bottom:14px}.field label{display:block;font-weight:700;font-size:14px;margin-bottom:6px}.field input,.field select,.field textarea{width:100%;min-height:var(--tap);padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;background:#fff}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--finca-red);border-color:transparent}.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.segments{display:flex;gap:8px;flex-wrap:wrap}.segments button{flex:1;min-height:var(--tap);border:1.5px solid var(--line);border-radius:10px;background:#fff;font-weight:700;cursor:pointer}.segments button.on{border-color:var(--finca-red);background:var(--finca-red-light);color:var(--finca-red)}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.numpad button{min-height:60px;font-size:24px;font-weight:700;border:none;border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow);cursor:pointer}.numpad button:active{background:var(--finca-red-light)}.numpad-display{text-align:center;font-size:34px;font-weight:800;padding:12px 0;min-height:64px}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}.badge.green{background:var(--green-light);color:var(--green)}.badge.orange{background:var(--orange-light);color:var(--orange)}.badge.red{background:var(--finca-red-light);color:var(--finca-red)}.badge.grey{background:#eeeceb;color:var(--ink-soft)}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}.stat{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 10px;text-align:center}.stat .label{font-size:12px;color:var(--ink-soft);font-weight:600}.stat .value{font-size:16px;font-weight:800;margin-top:4px}.stat .sub{font-size:11.5px;color:var(--ink-soft);margin-top:2px}.stat .balance{font-size:13px;font-weight:800;margin-top:2px}.stat .balance.pos{color:var(--green)}.stat .balance.neg{color:var(--finca-red)}.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cat-grid button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:64px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-weight:700;font-size:12.5px;cursor:pointer;padding:6px 4px}.cat-grid button .icon{font-size:22px;line-height:1}.cat-grid button.on{border-color:var(--finca-red);background:var(--finca-red-light);color:var(--finca-red)}.empty{text-align:center;color:var(--ink-soft);padding:32px 16px}.empty .icon{font-size:40px;margin-bottom:8px}.pin-dots{display:flex;justify-content:center;gap:14px;margin:20px 0}.pin-dots span{width:16px;height:16px;border-radius:50%;border:2px solid var(--finca-red)}.pin-dots span.full{background:var(--finca-red)}.center-screen{min-height:100%;display:flex;flex-direction:column;justify-content:center;padding:24px;max-width:420px;margin:0 auto}.online-dot{width:10px;height:10px;border-radius:50%;background:#7fe0a0}.online-dot.off{background:#f0b8c0}.fab-space{height:70px}.toast{position:fixed;bottom:calc(var(--nav-height) + 16px);left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:12px 20px;border-radius:999px;font-weight:600;z-index:50;max-width:90%;text-align:center;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.bar-chart{display:flex;align-items:flex-end;gap:4px;height:120px;padding-top:8px}.bar-chart .bar{flex:1;background:var(--finca-red);border-radius:4px 4px 0 0;min-height:2px;opacity:.85}
