
:root{--g:#1C3D2B;--gl:#2C5F2E;--bg:#F5F2EC;--bd:#EDE9E0;--tx:#1A1A1A;--mu:#9CA3AF;--sab:env(safe-area-inset-bottom,0px);--sat:env(safe-area-inset-top,0px)}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;font-family:-apple-system,'Segoe UI',sans-serif;background:var(--bg);color:var(--tx)}
#app{height:100dvh;display:flex;flex-direction:column;overflow:hidden}

/* Header */
.hdr{background:var(--g);padding:12px 14px;padding-top:calc(12px + var(--sat));display:flex;align-items:center;gap:8px;flex-shrink:0}
.hdr-title{font-size:18px;font-weight:700;color:#fff;flex:1;letter-spacing:-.3px}
.hdr-sub{font-size:10px;color:rgba(255,255,255,.4);font-weight:400;margin-left:2px}
.hbtn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:8px;padding:7px 10px;font-size:18px;cursor:pointer;line-height:1;transition:background .15s;min-width:36px;text-align:center}
.hbtn:active{background:rgba(255,255,255,.25)}

/* Add bar (top, lista view) */
.add-bar{background:#fff;border-bottom:1px solid var(--bd);padding:10px 13px 8px;flex-shrink:0}
.add-bar-row{display:grid;grid-template-columns:1fr 100px auto;gap:7px;align-items:center}
.add-bar-right{display:flex;align-items:center;gap:5px}
/* Category dropdown */
.cat-drop-wrap{position:relative;margin-top:7px}
.cat-drop-btn{width:100%;display:flex;align-items:center;gap:8px;padding:8px 12px;border:1.5px solid #DDD8CE;border-radius:9px;background:#FAFAF7;cursor:pointer;font-family:inherit;font-size:14px;color:#374151;transition:border-color .15s;text-align:left}
.cat-drop-btn:active,.cat-drop-btn.open{border-color:var(--gl);background:#F0FDF4}
.cat-drop-label{flex:1;font-weight:500}
.cat-drop-arrow{font-size:11px;color:var(--mu);transition:transform .2s}
.cat-drop-arrow.open{transform:rotate(180deg)}
.cat-drop-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1.5px solid #DDD8CE;border-radius:11px;z-index:50;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.12);max-height:280px;overflow-y:auto;animation:dropIn .15s ease}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.cat-drop-item{display:flex;align-items:center;gap:9px;padding:11px 13px;cursor:pointer;transition:background .1s;border-bottom:1px solid #F5F1EC;font-size:14px}
.cat-drop-item:last-child{border-bottom:none}
.cat-drop-item:active,.cat-drop-item.on{background:#F0FDF4}
.cat-drop-item.on .cat-drop-name{color:var(--gl);font-weight:700}
.cat-drop-name{flex:1;color:#374151}
.cat-drop-count{font-size:11px;color:var(--mu);background:#F3F4F6;border-radius:10px;padding:1px 7px}
.cat-drop-add{color:var(--gl);font-weight:600;border-top:2px dashed #DDD8CE}
.cat-drop-add:active{background:#F0FDF4}
.mini-step{display:flex;align-items:center;border:1.5px solid #DDD8CE;border-radius:8px;overflow:hidden;background:#FAFAF7;height:44px}
.mini-step-btn{background:none;border:none;width:32px;height:100%;font-size:19px;cursor:pointer;color:#6B7280;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:inherit;transition:background .1s}
.mini-step-btn:active{background:var(--bd)}
.mini-step-val{font-size:14px;font-weight:700;min-width:22px;text-align:center;color:var(--tx)}
.add-btn{background:var(--gl);color:#fff;border:none;border-radius:8px;height:44px;padding:0 13px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s;flex-shrink:0}
.add-btn:active{background:#1F4422}
.add-btn:disabled{background:#C8C0B8;cursor:not-allowed}

/* Budget bars */
.bbars{background:#162E20;padding:8px 14px 9px;flex-shrink:0;border-top:1px solid rgba(255,255,255,.06)}
.bbar-lbl{font-size:9.5px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
.bbar-track{height:4px;background:rgba(255,255,255,.12);border-radius:2px;overflow:hidden;margin-bottom:3px}
.bbar-fill{height:100%;border-radius:2px;background:#4ADE80;transition:width .5s,background .3s}
.bbar-fill.near{background:#FBBF24}.bbar-fill.over{background:#F87171}
.bbar-row{display:flex;justify-content:space-between;font-size:10.5px;color:rgba(255,255,255,.48);margin-bottom:4px}
.bbar-row.hi{color:#FCA5A5}.bbar-row.dim{color:rgba(255,255,255,.32);font-size:10px}
.bbar-sep{height:1px;background:rgba(255,255,255,.07);margin:4px 0 7px}

/* Main view */
.view{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}

/* Nav */
.nav{background:var(--g);display:flex;flex-shrink:0;border-top:1px solid rgba(255,255,255,.1);padding-bottom:var(--sab)}
.nbtn{flex:1;padding:9px 4px;background:none;border:none;color:rgba(255,255,255,.45);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;font-family:inherit;transition:color .15s}
.nbtn.on{color:#fff}.nbtn .ni{font-size:20px}.nbtn .nl{font-size:10px;font-weight:500}

/* Total bar \002014  sits above nav, no FAB overlap */
.tbar{background:var(--g);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;border-top:1px solid rgba(255,255,255,.08)}
.tbar.over{background:#7F1D1D}
.tlbl{font-size:10px;font-weight:600;color:rgba(255,255,255,.5);letter-spacing:.12em}
.tcnt{font-size:11px;color:rgba(255,255,255,.35);margin-top:1px}
.tamt{font-size:26px;font-weight:700;color:#fff}
.tbar.over .tamt{color:#FCA5A5}

/* Cards */
.card{background:#fff;border-radius:12px;border:1px solid var(--bd);overflow:hidden;margin:10px 13px}
.cg-hdr{display:flex;align-items:center;gap:7px;padding:8px 14px;background:var(--cbg);border-bottom:1px solid var(--cbd)}
.cg-e{font-size:15px}.cg-n{font-size:11px;font-weight:700;color:var(--ctx);flex:1;text-transform:uppercase;letter-spacing:.05em}.cg-s{font-size:14px;font-weight:700;color:var(--ctx)}
.pr{display:flex;align-items:center;padding:11px 14px;border-bottom:1px solid #F5F1EC;gap:6px;cursor:pointer;transition:background .1s}
.pr:last-child{border-bottom:none}.pr:active{background:#FAFAF7}
.pr-ico{font-size:12px;opacity:.3;flex-shrink:0}.pr:active .pr-ico{opacity:.7}
.pr-nm{flex:1;font-size:15px}.pr-qty{font-size:11px;background:#F3F4F6;color:#6B7280;border-radius:4px;padding:2px 6px;font-weight:500;flex-shrink:0}
.pr-unit{font-size:11px;color:#B0A898;flex-shrink:0}.pr-price{font-size:15px;font-weight:600;min-width:65px;text-align:right;flex-shrink:0}

/* Compare bar \002014  fixed between total and nav */
.cmp-bar{background:#1A2F20;padding:7px 14px;display:flex;align-items:center;gap:9px;flex-shrink:0;border-top:1px solid rgba(255,255,255,.07)}
.cmp-bar-lbl{font-size:11px;color:rgba(255,255,255,.45);white-space:nowrap;flex-shrink:0}
.cmp-bar-inp-w{position:relative;flex:1}
.cmp-bar-pfx{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.4);font-size:13px;pointer-events:none}
.cmp-bar-inp{width:100%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:6px 8px 6px 22px;color:#fff;font-size:14px;font-family:inherit;outline:none;-webkit-appearance:none}
.cmp-bar-inp:focus{border-color:rgba(255,255,255,.4)}
.cmp-bar-inp::placeholder{color:rgba(255,255,255,.3)}
.cmp-badge{font-size:12px;font-weight:700;padding:4px 9px;border-radius:6px;white-space:nowrap;flex-shrink:0}
.cmp-badge.ov{background:#FEF2F2;color:#DC2626}
.cmp-badge.un{background:#F0FDF4;color:#16A34A}
.cmp-badge.eq{background:#F0FDF4;color:#16A34A}

/* Empty */
.empty{text-align:center;padding:64px 20px;color:#B0A898}
.empty-ico{font-size:50px;margin-bottom:14px;opacity:.65}
.empty p{font-size:16px}.empty small{font-size:13px;color:#C8BEB4;margin-top:6px;display:block}

/* Inputs */
.inp{width:100%;border:1.5px solid #DDD8CE;border-radius:10px;padding:12px 13px;font-size:16px;font-family:inherit;background:#FAFAF7;outline:none;color:var(--tx);transition:border-color .2s;-webkit-appearance:none}
.inp:focus{border-color:var(--gl);background:#fff}.inp::placeholder{color:#B8B0A4}
.inp-w{position:relative;display:flex;align-items:center}
.inp-pfx{position:absolute;left:12px;color:var(--mu);font-size:15px;pointer-events:none;z-index:1}
.inp-w .inp{padding-left:26px}
.inp-sm{padding:9px 11px;font-size:15px;border-radius:9px}

/* Buttons */
.btn{border:none;border-radius:10px;padding:13px 16px;font-size:15px;font-family:inherit;font-weight:700;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn:active{transform:scale(.96)}.btn-p{background:var(--gl);color:#fff}.btn-p:active{background:#1F4422}
.btn-d{background:#EF4444;color:#fff}.btn-d:active{background:#DC2626}
.btn-g{background:#F5F2EC;color:#6B7280}.btn-g:active{background:var(--bd)}
.btn-full{width:100%}.btn-sm{padding:10px 14px;font-size:14px;border-radius:9px}

/* Sheet stepper (edit product \002014  no re-render) */
.stepper{display:flex;align-items:center;border:1.5px solid #DDD8CE;border-radius:10px;overflow:hidden;background:#FAFAF7}
.step-btn{background:none;border:none;width:46px;height:46px;font-size:22px;cursor:pointer;color:#6B7280;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:inherit;transition:background .1s}
.step-btn:active{background:var(--bd)}.step-val{flex:1;text-align:center;font-size:17px;font-weight:700}

/* Category grid */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.cat-btn{padding:9px 4px;border:1.5px solid #DDD8CE;border-radius:10px;background:#FAFAF7;font-size:12px;font-family:inherit;cursor:pointer;text-align:center;transition:all .15s;line-height:1.5;color:#374151}
.cat-btn.on{border-color:var(--gl);background:#F0FDF4;color:#1A1A1A;font-weight:700}
.cat-btn.custom{border-style:dashed}
.new-cat-btn{grid-column:1/-1;padding:9px;border:1.5px dashed #DDD8CE;border-radius:10px;background:transparent;color:var(--mu);font-size:13px;cursor:pointer;font-family:inherit;transition:all .15s;text-align:center}
.new-cat-btn:active{border-color:var(--gl);color:var(--gl)}

/* New category form */
.nc-form{background:#F5F2EC;border-radius:11px;padding:14px;margin-top:8px;border:1px solid var(--bd)}
.nc-row{display:grid;grid-template-columns:72px 1fr;gap:8px;align-items:center;margin-bottom:8px}
.nc-lbl{font-size:12.5px;color:#6B7280}
.emoji-pick{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.emoji-opt{width:36px;height:36px;border:1.5px solid #DDD8CE;border-radius:8px;background:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.emoji-opt.on{border-color:var(--gl);background:#F0FDF4}
.color-pick{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.color-opt{width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:border-color .15s;flex-shrink:0}
.color-opt.on{border-color:#333}

/* Sheet overlay */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100;display:flex;align-items:flex-end;animation:fadeIn .15s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-height:92dvh;overflow-y:auto;animation:slideUp .22s ease;padding-bottom:max(16px,var(--sab))}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sh-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 13px;border-bottom:1px solid var(--bd);position:sticky;top:0;background:#fff;z-index:1}
.sh-title{font-size:17px;font-weight:700}
.sh-close{background:#F5F2EC;border:none;width:30px;height:30px;border-radius:50%;font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6B7280}
.sh-body{padding:16px 18px}
.sh-lbl{font-size:12px;font-weight:600;color:var(--mu);text-transform:uppercase;letter-spacing:.07em;margin:14px 0 6px}
.sh-lbl:first-child{margin-top:0}

/* Promos */
.promo-row{display:flex;align-items:center;gap:8px;padding:10px 13px;border:1.5px solid #DDD8CE;border-radius:10px;background:#FAFAF7;margin-bottom:6px;cursor:pointer;transition:all .15s}
.promo-row.on{border-color:var(--gl);background:#F0FDF4}
.promo-dot{width:16px;height:16px;border-radius:50%;border:2px solid #DDD8CE;flex-shrink:0;transition:all .15s}
.promo-dot.on{border-color:var(--gl);background:var(--gl)}
.promo-nm{flex:1;font-size:14px}.promo-row.on .promo-nm{font-weight:600}
.promo-tag{font-size:11px;padding:2px 7px;border-radius:5px;background:#F0FDF4;color:#166534;border:1px solid #86EFAC;white-space:nowrap}
.promo-tag.ci{background:#FFF7ED;color:#9A3412;border-color:#FDBA74}
.promo-del-btn{background:none;border:none;color:#D1C5BB;font-size:19px;cursor:pointer;padding:2px 5px;line-height:1}
.add-promo-btn{width:100%;padding:10px;border:1.5px dashed #DDD8CE;border-radius:10px;background:transparent;color:var(--mu);font-size:13.5px;cursor:pointer;font-family:inherit;margin-top:4px}
.np-form{background:#F5F2EC;border-radius:11px;padding:14px;margin-top:8px;border:1px solid var(--bd)}
.np-row{display:grid;grid-template-columns:76px 1fr;gap:8px;align-items:center;margin-bottom:8px}
.np-lbl{font-size:12.5px;color:#6B7280}
.np-tipos{display:flex;gap:6px}
.np-tipo{flex:1;padding:9px;border:1.5px solid #DDD8CE;border-radius:9px;background:#fff;color:#6B7280;font-size:13px;font-family:inherit;cursor:pointer;text-align:center;transition:all .15s}
.np-tipo.on{border-color:var(--gl);background:#F0FDF4;color:#1F4422;font-weight:600}

/* Preview */
.prev{background:#F0FDF4;border:1px solid #86EFAC;border-radius:10px;padding:10px 13px;margin-top:10px}
.prev-row{display:flex;justify-content:space-between;font-size:13px;line-height:2}
.prev-row strong{color:#166534;font-weight:700}
.prev-note{font-size:11px;color:var(--mu);margin-top:3px;line-height:1.5}

/* Info boxes */
.ibox{border-radius:10px;padding:10px 13px;font-size:13px;line-height:1.9;margin-bottom:8px}
.ibox.ok{background:#F0FDF4;border:1px solid #86EFAC}.ibox.warn{background:#FEF2F2;border:1px solid #FCA5A5}
.irow{display:flex;justify-content:space-between;gap:8px}.irow strong{font-weight:700}

/* Budget cards */
.bcard{background:#fff;border-radius:13px;border:1px solid var(--bd);overflow:hidden;margin:10px 13px}
.bcard-hdr{padding:14px 15px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}
.bcard-hdr:active{background:#FAFAF7}
.bcard-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:7px}
.bcard-sub{font-size:12px;color:var(--mu);margin-top:3px}
.bcard-right{display:flex;align-items:center;gap:6px}
.bcard-amount{font-size:19px;font-weight:700;color:var(--g)}
.bcard-unit{font-size:11px;color:var(--mu)}
.bcard-ico{font-size:12px;color:var(--mu);transition:transform .2s}
.bcard-ico.open{transform:rotate(180deg)}
.bcard-body{border-top:1px solid var(--bd);padding:14px 15px}

/* History */
.hist-entry{background:#fff;border-radius:12px;border:1px solid var(--bd);margin:0 13px 9px;overflow:hidden}
.hist-hdr{display:flex;align-items:center;gap:8px;padding:12px 14px;cursor:pointer}
.hist-hdr:active{background:#FAFAF7}
.hist-info{flex:1}.hist-nota{font-size:14px;font-weight:700}
.hist-date{font-size:11px;color:var(--mu);margin-top:2px}
.hist-total{font-size:17px;font-weight:700;color:var(--g)}
.hist-arrow{font-size:12px;color:#B0A898;transition:transform .2s;margin-left:4px}
.hist-arrow.open{transform:rotate(180deg)}
.hist-detail{border-top:1px solid var(--bd);padding:12px 14px}
.hist-row{display:flex;justify-content:space-between;font-size:13px;color:#6B7280;padding:2px 0}
.hist-prods{margin-top:9px;border-top:1px solid #F5F1EC;padding-top:9px}
.hist-cat-lbl{font-size:11px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.05em;margin:7px 0 3px}
.hist-cat-lbl:first-child{margin-top:0}
.hist-prod-row{display:flex;justify-content:space-between;font-size:13px;color:#374151;padding:2px 0}
.hist-del-btn{display:inline-flex;align-items:center;gap:5px;margin-top:11px;padding:7px 13px;border:1px solid #FCA5A5;border-radius:8px;background:none;color:#EF4444;font-size:13px;cursor:pointer;font-family:inherit}

/* Summary */
.saved-badge{background:#F0FDF4;border:1px solid #86EFAC;border-radius:10px;padding:12px;text-align:center;font-size:14px;color:#166534;font-weight:600;margin-top:8px}
.sum-cg{margin-bottom:10px}
.sum-ch{display:flex;align-items:center;gap:6px;padding:6px 9px;border-radius:8px;margin-bottom:3px}
.sum-ch-name{font-size:12px;font-weight:700;flex:1}.sum-ch-sub{font-size:13px;font-weight:700}
.sum-item{display:flex;align-items:center;padding:3px 9px;font-size:13px;gap:5px}
.sum-item-name{flex:1;color:#374151}.sum-item-u{font-size:11px;color:#B0A898}
.sum-item-p{font-weight:600;min-width:55px;text-align:right}
hr.div{border:none;border-top:1px solid var(--bd);margin:12px 0}
.sum-total-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:10px}
.sum-tlbl{font-size:10px;color:#6B7280;text-transform:uppercase;letter-spacing:.1em}
.sum-tamt{font-size:24px;font-weight:700;color:var(--g)}
.sum-cuota{text-align:right}.sum-cuota-amt{font-size:15px;font-weight:700;color:var(--g)}
.sum-cuota-lbl{font-size:11px;color:#6B7280}

/* Snack */
.snack{position:fixed;bottom:calc(110px + var(--sab));left:50%;transform:translateX(-50%);background:#1A1A1A;color:#fff;padding:10px 18px;border-radius:22px;font-size:13px;white-space:nowrap;z-index:200;pointer-events:none;animation:snkIn .2s ease}
@keyframes snkIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* Utils */
.flex{display:flex;gap:8px}.mt8{margin-top:8px}.mt12{margin-top:12px}
.sect-lbl{font-size:12px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.08em;margin:14px 14px 8px}
.clr-btn{display:block;margin:4px auto 12px;background:none;border:1px solid var(--bd);color:#B0A898;border-radius:9px;padding:8px 18px;font-size:13px;cursor:pointer;font-family:inherit}
.clr-btn:active{border-color:#FCA5A5;color:#EF4444}
.del-sep{margin-top:12px;padding-top:12px;border-top:1px solid var(--bd)}
