@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--bg-deep:#f0faf4;--bg-base:#f5fdf8;--bg-elevated:#fff;--bg-primary:#f5fdf8;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#eef9f2;--bg-input:#f0faf4;--summary-h:52px;--bg-glass:#ffffffd9;--border:#d4e8dc;--border-focus:#16a34a;--text-primary:#1a2e23;--text-secondary:#4a6b57;--text-muted:#7d9a8a;--accent:#16a34a;--accent-light:#22c55e;--accent-dark:#15803d;--accent-glow:#16a34a26;--green:#16a34a;--green-bg:#16a34a14;--red:#dc2626;--red-bg:#dc262612;--amber:#d97706;--amber-bg:#d9770612;--cyan:#0891b2;--purple:#7c3aed;--pink:#db2777;--radius:16px;--radius-sm:10px;--radius-lg:20px;--shadow:0 4px 24px #0000000f;--shadow-sm:0 1px 8px #0000000a;--transition:.2s cubic-bezier(.16, 1, .3, 1);--nav-h:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:15px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100dvh;font-family:Mulish,-apple-system,sans-serif;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.app-layout{flex-direction:column;min-height:100dvh;display:flex}.app-header{z-index:50;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.app-header h1{color:var(--accent-dark);letter-spacing:-.2px;align-items:center;gap:8px;font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700;display:flex}.app-header h1 svg{color:var(--accent)}.app-main{padding:16px;padding-bottom:calc(var(--nav-h) + 20px);flex:1;width:100%;max-width:600px;margin:0 auto}.bottom-nav{z-index:60;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);height:var(--nav-h);padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);cursor:pointer;transition:all var(--transition);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:12px;flex-direction:column;align-items:center;gap:3px;padding:6px 12px;font-family:inherit;font-size:.65rem;font-weight:600;display:flex}.nav-item:active{transform:scale(.92)}.nav-item.active{color:var(--accent)}.nav-item.active svg{filter:drop-shadow(0 0 4px var(--accent-glow))}.nav-dot{background:var(--accent);opacity:0;width:4px;height:4px;transition:opacity var(--transition);border-radius:50%}.nav-item.active .nav-dot{opacity:1}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;align-items:center;gap:6px;padding:10px 18px;font-family:inherit;font-size:.85rem;font-weight:600;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark);box-shadow:0 4px 16px var(--accent-glow)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent)}.btn-danger{background:var(--red-bg);color:var(--red)}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px}.btn-ghost:hover{color:var(--accent);background:var(--green-bg)}.btn-sm{padding:6px 12px;font-size:.78rem}.btn-icon{border-radius:var(--radius-sm);padding:8px}.btn-fab{bottom:calc(var(--nav-h) + 16px);z-index:55;background:linear-gradient(135deg, var(--accent), #10b981);color:#fff;cursor:pointer;width:52px;height:52px;transition:all var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;right:16px;box-shadow:0 6px 20px #16a34a4d}.btn-fab:active{transform:scale(.9)}.status-btns{flex-wrap:nowrap;gap:5px;display:flex}.status-btn{cursor:pointer;border:1.5px solid var(--border);transition:all var(--transition);background:var(--bg-elevated);color:var(--text-muted);white-space:nowrap;-webkit-tap-highlight-color:transparent;border-radius:999px;align-items:center;gap:4px;padding:5px 10px;font-family:inherit;font-size:.7rem;font-weight:600;display:flex}.status-btn:active{transform:scale(.95)}.status-btn.active{border-color:currentColor}.status-btn.s-active{color:var(--green);background:var(--green-bg);border-color:#0000}.status-btn.s-active.active{border-color:var(--green)}.status-btn.s-done{color:var(--cyan);background:#0891b212;border-color:#0000}.status-btn.s-done.active{border-color:var(--cyan)}.status-btn.s-paid{color:var(--amber);background:var(--amber-bg);border-color:#0000}.status-btn.s-paid.active{border-color:var(--amber)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);box-shadow:var(--shadow-sm);padding:16px}.card-flat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:3px 0 0 3px;width:3px;height:100%;position:absolute;top:0;left:0}.stat-card.accent:before{background:var(--accent)}.stat-card.green:before{background:var(--green)}.stat-card.red:before{background:var(--red)}.stat-card.amber:before{background:var(--amber)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;font-size:.68rem;font-weight:600}.stat-value{font-variant-numeric:tabular-nums;text-align:right;font-size:1rem;font-weight:800}.stat-sub{color:var(--text-secondary);white-space:nowrap;font-size:.7rem}.form-group{margin-bottom:12px}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px;font-size:.72rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:border-color var(--transition);-webkit-appearance:none;padding:11px 14px;font-family:inherit;font-size:1rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-input::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.form-stack{flex-direction:column;gap:10px;display:flex}.inline-form{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;padding:14px}.inline-form-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.inline-form-header h3{color:var(--accent-dark);font-size:.85rem;font-weight:600}.inline-form-actions{gap:8px;margin-top:10px;display:flex}.cost-list{flex-direction:column;gap:10px;display:flex}.cost-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);box-shadow:var(--shadow-sm);padding:14px}.cost-item:active{background:var(--bg-card-hover)}.cost-item-header{justify-content:space-between;align-items:flex-start;margin-bottom:6px;display:flex}.cost-item-name{color:var(--text-primary);font-size:.9rem;font-weight:700}.cost-item-desc{color:var(--text-muted);margin-top:2px;font-size:.75rem}.cost-item-details{flex-wrap:wrap;gap:16px;margin-top:8px;display:flex}.cost-detail{font-size:.78rem}.cost-detail .dl{color:var(--text-muted);text-transform:uppercase;font-size:.68rem}.cost-detail .dv{margin-top:1px;font-weight:700}.cost-item-total{color:var(--accent-dark);text-align:right;font-variant-numeric:tabular-nums;font-size:1rem;font-weight:800}.cost-item-badge{background:var(--green-bg);color:var(--accent-dark);border-radius:6px;padding:2px 8px;font-size:.68rem;font-weight:600;display:inline-block}.tabs-v{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.tabs-h{-webkit-overflow-scrolling:touch;gap:4px;margin-bottom:16px;padding-bottom:4px;display:flex;overflow-x:auto}.tabs-h::-webkit-scrollbar{display:none}.tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:1px solid #0000;justify-content:space-between;align-items:center;padding:10px 14px;font-family:inherit;font-size:.82rem;font-weight:600;display:flex}.tab:active{transform:scale(.98)}.tab:hover{color:var(--text-primary);background:var(--green-bg)}.tab.active{color:var(--accent-dark);background:var(--green-bg);border-color:#16a34a33}.tab-count{background:var(--border);min-width:18px;height:18px;color:var(--text-secondary);border-radius:9px;justify-content:center;align-items:center;margin-left:6px;padding:0 5px;font-size:.68rem;display:inline-flex}.tab.active .tab-count{background:var(--accent);color:#fff}.tab-amount{color:var(--text-muted);font-size:.72rem;font-weight:500}.tab.active .tab-amount{color:var(--accent-dark)}.projects-list{flex-direction:column;gap:10px;display:flex}.projects-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-sm);min-width:0;padding:12px}.project-card:active{background:var(--bg-card-hover);transform:scale(.97)}.project-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.project-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:700;line-height:1.3;overflow:hidden}.project-card-customer{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:.72rem;overflow:hidden}.project-card-stats{grid-template-columns:1fr 1fr;gap:6px;margin-top:6px;display:grid}.project-mini-stat .label{color:var(--text-muted);text-transform:uppercase;font-size:.6rem}.project-mini-stat .value{font-variant-numeric:tabular-nums;font-size:.82rem;font-weight:700}.badge{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:.68rem;font-weight:600;display:inline-flex}.badge-active{background:var(--green-bg);color:var(--green)}.badge-done{color:var(--cyan);background:#0891b212}.badge-paid{background:var(--amber-bg);color:var(--amber)}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000004d;justify-content:center;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:20px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0));width:100%;max-width:560px;max-height:90vh;animation:.25s cubic-bezier(.16,1,.3,1) slideUp;overflow-y:auto;box-shadow:0 -8px 40px #0000001a}.modal-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.modal h2{color:var(--accent-dark);align-items:center;gap:8px;margin-bottom:16px;font-size:1.05rem;font-weight:700;display:flex}.modal-actions{gap:10px;margin-top:16px;display:flex}.modal-actions .btn{flex:1;justify-content:center}.summary-bar{bottom:var(--nav-h);z-index:30;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);height:var(--summary-h);justify-content:space-between;align-items:center;gap:8px;padding:8px 16px;display:flex;position:fixed;left:0;right:0}.summary-item{text-align:center;flex:1}.summary-item .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.62rem}.summary-item .value{font-variant-numeric:tabular-nums;font-size:.9rem;font-weight:800}.note-section{margin-top:16px}.note-section h3{color:var(--amber);align-items:center;gap:8px;margin-bottom:8px;font-size:.9rem;font-weight:700;display:flex}.note-tags{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.note-tag{cursor:pointer;transition:all var(--transition);-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;border-radius:999px;padding:5px 14px;font-size:.75rem;font-weight:600}.note-tag:active{transform:scale(.95)}.note-tag.good{background:var(--green-bg);color:var(--green)}.note-tag.improve{background:var(--amber-bg);color:var(--amber)}.note-tag.critical{background:var(--red-bg);color:var(--red)}.note-tag.active{border-color:currentColor}.flow-list{flex-direction:column;gap:8px;display:flex}.flow-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:center;gap:12px;padding:12px 14px;display:flex}.flow-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;display:flex}.flow-icon.in{background:var(--green-bg);color:var(--green)}.flow-icon.out{background:var(--red-bg);color:var(--red)}.flow-info{flex:1;min-width:0}.flow-desc{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.flow-date{color:var(--text-muted);font-size:.7rem}.flow-amount{text-align:right;font-variant-numeric:tabular-nums;font-size:.95rem;font-weight:800}.flow-amount.in{color:var(--green)}.flow-amount.out{color:var(--red)}.product-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.product-info{flex:1}.product-name{font-size:.88rem;font-weight:700}.product-meta{color:var(--text-muted);margin-top:2px;font-size:.72rem}.product-price{color:var(--accent-dark);text-align:right;font-variant-numeric:tabular-nums;font-size:.95rem;font-weight:800}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px}.empty-state svg{opacity:.3;margin-bottom:12px}.empty-state h3{color:var(--text-secondary);margin-bottom:6px;font-size:1rem}.empty-state p{margin-bottom:16px;font-size:.82rem}.search-box{position:relative}.search-box input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);box-shadow:var(--shadow-sm);padding:10px 12px 10px 36px;font-family:inherit;font-size:.88rem}.search-box input:focus{border-color:var(--accent);outline:none}.search-box svg{color:var(--text-muted);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:.72rem;font-weight:700}.back-btn{color:var(--text-secondary);cursor:pointer;transition:color var(--transition);background:0 0;border:none;align-items:center;gap:6px;margin-bottom:12px;padding:6px 0;font-family:inherit;font-size:.85rem;display:inline-flex}.back-btn:active{color:var(--accent)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:.3s cubic-bezier(.16,1,.3,1) slideIn}.cf-sort-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);touch-action:none;box-shadow:var(--shadow-sm);grid-template-columns:20px 1fr 60px 54px 36px;align-items:center;gap:4px;padding:9px 8px;transition:box-shadow .15s;display:grid}.cf-sort-row[data-done=true]{background:var(--green-bg);border-color:#16a34a33}.cf-sort-row:active{box-shadow:0 4px 16px #0000001a}.cf-sort-handle{color:var(--text-muted);cursor:grab;touch-action:none;justify-content:center;align-items:center;display:flex}.cf-sort-handle:active{cursor:grabbing}.cf-sort-body{min-width:0}.cf-sort-name{white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.cf-sort-amount{text-align:right;font-variant-numeric:tabular-nums;font-size:.8rem;font-weight:800}.cf-sort-amount.in{color:var(--green)}.cf-sort-amount.out{color:var(--red)}.cf-sort-balance{text-align:right;font-variant-numeric:tabular-nums;border-radius:6px;padding:2px 5px;font-size:.72rem;font-weight:700}.cf-sort-balance[data-pos=true]{background:var(--green-bg);color:var(--green)}.cf-sort-balance[data-pos=false]{background:var(--red-bg);color:var(--red)}.cf-sort-actions{justify-content:flex-end;align-items:center;gap:3px;display:flex}.cf-act-btn{background:var(--bg-input);border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);-webkit-tap-highlight-color:transparent;border-radius:7px;justify-content:center;align-items:center;min-width:26px;height:26px;padding:4px 5px;font-family:inherit;font-size:.65rem;transition:all .12s;display:flex}.cf-act-btn:hover{background:var(--bg-card-hover)}.cf-act-btn:active{transform:scale(.92)}.cf-tick-btn{border:1.5px solid var(--border);background:var(--bg-input);cursor:pointer;width:24px;height:24px;color:var(--text-muted);-webkit-tap-highlight-color:transparent;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.cf-tick-btn[data-done=true]{background:var(--green);border-color:var(--green);color:#fff}.cf-tick-btn:active{transform:scale(.85)}.cf-expand-panel{background:var(--bg-input);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);border-top:none;padding:10px}.cf-block-tag{border-radius:4px;padding:1px 5px;font-size:.6rem;display:inline-block}.cf-block-tag.recurring{background:var(--amber-bg);color:var(--amber)}@media (width>=641px){.app-main{max-width:560px;padding:20px}.stats-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=640px){.form-row-3{grid-template-columns:1fr}}@media (width<=380px){html{font-size:13px}.form-row{grid-template-columns:1fr}}
