:root{--bg:#F4F6F3;--surface:#FFFFFF;--ink:#182420;--muted:#5E6E67;--line:#E1E7E2;--green:#0E6B5C;--green-dark:#0A5245;--green-soft:#E3F0EC;--amber:#B97A1E;--amber-soft:#FBF0DC;--red:#B3402E;--radius:14px;--shadow:0 1px 3px rgba(24,36,32,.08),0 4px 14px rgba(24,36,32,.06);--nav-h:64px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);--page-pad:max(14px,var(--safe-left))}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5;min-height:100dvh;overflow-x:hidden;padding-bottom:calc(var(--nav-h) + var(--safe-bottom) + 12px);-webkit-tap-highlight-color:transparent;touch-action:manipulation}h1,h2,h3{font-family:Archivo,sans-serif}.mono{font-family:JetBrains Mono,monospace;font-variant-numeric:tabular-nums}img,svg{display:block;max-width:100%}button,input,select,textarea{font:inherit;color:inherit}.muted-text{font-size:13.5px;color:var(--muted);margin-bottom:10px;line-height:1.45}header{background:var(--green);color:#fff;padding:calc(14px + var(--safe-top)) calc(var(--page-pad) + var(--safe-right)) 14px calc(var(--page-pad) + var(--safe-left))}header .brand{display:flex;flex-wrap:wrap;align-items:center;gap:6px 10px;max-width:860px;margin:0 auto;width:100%}header h1{font-size:clamp(18px,5vw,20px);font-weight:800;letter-spacing:.5px}header .tag{font-size:11px;opacity:.8;font-weight:500;line-height:1.3}.today-strip{max-width:860px;margin:12px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}.today-strip .stat{display:flex;flex-direction:column;gap:2px;min-width:0}.today-strip .stat b{font-family:JetBrains Mono,monospace;font-size:clamp(14px,3.8vw,17px);font-weight:600;line-height:1.2;word-break:break-word}.today-strip .stat span{font-size:10px;text-transform:uppercase;letter-spacing:.06em;opacity:.75;line-height:1.25}main{max-width:860px;margin:0 auto;padding:14px calc(var(--page-pad) + var(--safe-right)) 14px calc(var(--page-pad) + var(--safe-left));width:100%}.view{display:none}.view.active{display:block;animation:fade .18s ease}@keyframes fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.view.active{animation:none}}nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);display:flex;justify-content:center;z-index:50;padding-bottom:var(--safe-bottom);box-shadow:0 -4px 20px #1824200f}nav .tabs{display:flex;width:100%;max-width:860px}nav button{flex:1;background:none;border:none;min-height:var(--nav-h);padding:8px 4px 6px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;-webkit-user-select:none;user-select:none}nav button svg{width:22px;height:22px;flex-shrink:0}nav button.on{color:var(--green)}nav button:focus-visible{outline:2px solid var(--green);outline-offset:-2px;border-radius:8px}nav button:active{opacity:.75}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:14px;width:100%}.card h2{font-size:16px;font-weight:700;margin-bottom:12px;line-height:1.3}label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:12px 0 6px}label:first-of-type{margin-top:0}input,select,textarea{width:100%;max-width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-family:Inter,sans-serif;font-size:16px;background:#fbfcfb;color:var(--ink);min-height:48px;-moz-appearance:none;appearance:none;-webkit-appearance:none}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235E6E67' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}textarea{resize:vertical;min-height:80px;line-height:1.45}input:focus,select:focus,textarea:focus{outline:2px solid var(--green);outline-offset:0;border-color:var(--green)}input[type=date]{min-height:48px}input[type=checkbox]{width:18px;height:18px;min-height:18px;min-width:18px;max-width:18px;padding:0;-moz-appearance:auto;appearance:auto;-webkit-appearance:auto;accent-color:var(--green);cursor:pointer;flex-shrink:0}.row2{display:grid;grid-template-columns:1fr;gap:0}.seg{display:flex;background:#edf1ee;border-radius:10px;padding:3px;gap:3px;width:100%}.seg button{flex:1;border:none;background:transparent;min-height:44px;padding:10px 8px;border-radius:8px;font-family:Inter,sans-serif;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;line-height:1.2;text-align:center}.seg button.on{background:var(--surface);color:var(--green);box-shadow:0 1px 3px #0000001a}.seg button:focus-visible{outline:2px solid var(--green)}.seg button:active{opacity:.8}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:10px;padding:12px 16px;min-height:48px;font-family:Inter,sans-serif;font-size:15px;font-weight:600;cursor:pointer;text-align:center;line-height:1.2;-webkit-user-select:none;user-select:none}.btn:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.btn-primary{background:var(--green);color:#fff;width:100%}.btn-primary:hover,.btn-primary:active{background:var(--green-dark)}.btn-ghost{background:var(--green-soft);color:var(--green);width:100%}.btn-danger{background:none;color:var(--red);padding:8px 12px;font-size:13px;min-height:40px}.btn-small{padding:10px 14px;font-size:13px;min-height:44px}.btn-edit{background:var(--green-soft);color:var(--green);padding:8px 12px;font-size:13px;min-height:40px}.photo-pick{border:2px dashed var(--line);border-radius:10px;padding:16px 12px;text-align:center;color:var(--muted);cursor:pointer;font-size:14px;background:#fbfcfb;line-height:1.4;min-height:56px;display:flex;align-items:center;justify-content:center}.photo-pick:active{border-color:var(--green);color:var(--green);background:var(--green-soft)}.photo-pick input{display:none}.photo-preview{margin-top:10px;position:relative;display:none}.photo-preview img{width:100%;max-height:min(50vh,280px);object-fit:cover;border-radius:10px;border:1px solid var(--line)}.photo-preview button{position:absolute;top:8px;right:8px;background:#182420cc;color:#fff;border:none;border-radius:8px;padding:8px 12px;font-size:12px;cursor:pointer;min-height:36px}.filters{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:14px}.filter-dates,.filter-dates label{margin-top:0}.exp-item{display:grid;grid-template-columns:48px 1fr;grid-template-rows:auto auto;gap:10px 12px;align-items:start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:12px;margin-bottom:10px}.exp-item .thumb{width:48px;height:48px;border-radius:10px;object-fit:cover;border:1px solid var(--line);grid-row:1/span 2;background:var(--green-soft)}.exp-item .thumb.empty{display:flex;align-items:center;justify-content:center;color:var(--green);font-size:18px}.exp-item .info{min-width:0;grid-column:2}.exp-item .name{font-weight:600;font-size:15px;line-height:1.3;word-break:break-word}.exp-item .meta{font-size:12px;color:var(--muted);display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.exp-item .exp-actions{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:10px;border-top:1px solid var(--line)}.exp-item .exp-actions .amt{font-family:JetBrains Mono,monospace;font-weight:600;font-size:16px;white-space:nowrap}.exp-item .exp-btns{display:flex;gap:6px;flex-shrink:0}.pill{font-size:10px;font-weight:600;padding:3px 8px;border-radius:99px;white-space:nowrap}.pill.daily{background:var(--green-soft);color:var(--green)}.pill.project{background:var(--amber-soft);color:var(--amber)}.group-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap;margin:16px 2px 8px}.group-head h3{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;line-height:1.3;flex:1;min-width:0}.group-head .total{font-family:JetBrains Mono,monospace;font-weight:600;font-size:13px;white-space:nowrap}.report-row{display:flex;flex-direction:column;align-items:stretch;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:10px}.report-row .report-main{flex:1;min-width:0}.report-row .d{font-weight:600;font-size:15px;line-height:1.3;word-break:break-word}.report-row .s{font-size:12.5px;color:var(--muted);margin-top:2px}.report-row .report-end{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.report-row .report-amt{font-family:JetBrains Mono,monospace;font-weight:600;font-size:15px}.prod-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:12px;display:flex;flex-direction:column;gap:12px}.prod-item .prod-media img,.prod-item .prod-media .ph{width:100%;height:min(42vw,180px);border-radius:10px;object-fit:cover;border:1px solid var(--line)}.prod-item .ph{background:var(--green-soft);display:flex;align-items:center;justify-content:center;color:var(--green);font-size:32px}.prod-item .prod-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}.prod-item .prod-body{flex:1;min-width:0}.prod-item .prod-btns{display:flex;gap:6px;flex-shrink:0}.var-line{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap;font-size:13px;padding:6px 0;color:var(--muted);border-bottom:1px solid var(--line)}.var-line:last-child{border-bottom:none}.var-line>span:first-child{flex:1;min-width:0;line-height:1.35;word-break:break-word}.var-line>span:last-child{display:flex;align-items:center;gap:4px;flex-shrink:0}.var-line b{font-family:JetBrains Mono,monospace;color:var(--ink);font-weight:600;white-space:nowrap}.var-row{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--line)}.var-row:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}.var-row button{border:none;background:#f2e4e1;color:var(--red);border-radius:8px;cursor:pointer;font-size:15px;min-height:44px;width:100%}.empty{padding:32px 12px;text-align:center;color:var(--muted)}.empty b{display:block;color:var(--ink);margin-bottom:4px;font-size:15px}.toast{position:fixed;bottom:calc(var(--nav-h) + var(--safe-bottom) + 12px);left:50%;transform:translate(-50%);max-width:calc(100vw - 32px);background:var(--ink);color:#fff;padding:12px 18px;border-radius:99px;font-size:14px;font-weight:500;text-align:center;opacity:0;pointer-events:none;transition:opacity .2s;z-index:99}.toast.show{opacity:1}.banner{background:var(--amber-soft);color:var(--amber);border:1px solid #EAD3A8;border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.45;margin-bottom:14px;display:none}.section-title{display:flex;flex-direction:column;align-items:stretch;gap:10px;margin:4px 0 12px}.section-title h2{font-size:clamp(17px,4.5vw,18px);font-weight:800;line-height:1.25}.btn-row{display:flex;flex-direction:column;gap:10px;margin-top:16px;width:100%}.btn-row .btn-primary,.btn-row .btn-ghost{flex:1;width:100%}.card-action{margin-top:14px}.cash-in{color:var(--green)}.cash-out{color:var(--amber)}.cash-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.btn-icon{min-height:36px;min-width:36px;padding:6px!important;font-size:14px}.ledger-msg{border-radius:10px;padding:10px 12px;font-weight:600;line-height:1.4;font-size:14px}.ledger-msg-wrap{margin:10px 0}.ledger-msg.pos{background:var(--green-soft);color:var(--green)}.ledger-msg.neg{background:var(--amber-soft);color:var(--amber)}@media(min-width:520px){:root{--page-pad:16px}.row2{grid-template-columns:1fr 1fr;gap:12px}.filters{grid-template-columns:1fr 1fr}.filters .span2{grid-column:1/-1}.exp-item{grid-template-columns:52px 1fr auto;grid-template-rows:auto;align-items:center}.exp-item .thumb{width:52px;height:52px;grid-row:auto}.exp-item .exp-actions{grid-column:auto;flex-direction:column;align-items:flex-end;border-top:none;padding-top:0;gap:6px}.exp-item .exp-actions .amt{font-size:15px}.prod-item{flex-direction:row}.prod-item .prod-media img,.prod-item .prod-media .ph{width:74px;height:74px}.var-row{grid-template-columns:2fr 1fr 40px;align-items:center;border-bottom:none;padding-bottom:0;margin-bottom:8px}.var-row button{width:auto;min-height:40px}.report-row{flex-direction:row;align-items:center;padding:14px 16px}.report-row .report-end{flex-direction:row;justify-content:flex-end}.section-title{flex-direction:row;align-items:center;justify-content:space-between}.section-title .btn{width:auto}.btn-row{flex-direction:row}.btn-ghost{width:auto}}@media(min-width:600px){.today-strip{display:flex;gap:18px}.today-strip .stat span{font-size:11px}nav button{font-size:12px;padding:12px 4px 10px}}@media(min-width:768px){body{padding-bottom:calc(80px + var(--safe-bottom))}.card{padding:18px;margin-bottom:16px}main{padding:16px calc(var(--page-pad) + var(--safe-right)) 16px calc(var(--page-pad) + var(--safe-left))}header{padding:calc(18px + var(--safe-top)) calc(20px + var(--safe-right)) 16px calc(20px + var(--safe-left))}.filters{grid-template-columns:1fr 1fr 1fr}.btn-danger,.btn-edit{background:none}.btn-edit,.btn-danger{padding:6px 10px;min-height:auto}}@media(hover:hover){.photo-pick:hover{border-color:var(--green);color:var(--green)}nav button:hover{color:var(--green)}}@media(max-width:380px){nav button{font-size:10px;gap:2px}nav button svg{width:20px;height:20px}.today-strip .stat span{font-size:9px}.seg button{font-size:12px;padding:8px 4px}}.view{display:block}.view.hidden{display:none}.photo-preview{display:block}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:40vh;color:var(--muted)}.storage-info{background:var(--green-soft);color:var(--green);border:1px solid #C5DDD6;border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.45;margin-bottom:14px}.storage-info strong{font-weight:700}.storage-meta{opacity:.85;font-size:12px}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(160deg,#f4faf7,#fff 45%)}.login-card{width:100%;max-width:380px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 22px;box-shadow:0 8px 32px #0000000f}.login-brand{text-align:center;margin-bottom:24px}.login-brand h1{font-size:28px;color:var(--green);margin:0 0 4px}.login-brand p{margin:0;color:var(--muted);font-size:14px}.login-card .field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.login-card .field span{font-size:13px;font-weight:600;color:var(--ink)}.login-card .field input,.login-card .password-field input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:16px}.password-field{position:relative}.password-field input{padding-right:46px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:none;color:var(--muted);padding:6px;cursor:pointer;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--green)}.login-remember{display:flex;align-items:center;gap:8px;margin:0 0 14px;font-size:13px;color:var(--ink);cursor:pointer;-webkit-user-select:none;user-select:none}.login-remember input[type=checkbox]{width:18px;height:18px;min-height:18px;min-width:18px;accent-color:var(--green);cursor:pointer}.login-error{color:#b42318;font-size:13px;margin:0 0 12px}header .btn-logout{margin-top:0;margin-left:auto;padding:6px 10px;border:1px solid rgba(255,255,255,.45);border-radius:8px;background:#ffffff1f;color:#fff;font-size:12px;font-weight:600;cursor:pointer;text-decoration:none;white-space:nowrap}header .btn-logout:hover{background:#ffffff38;color:#fff;border-color:#ffffffb3}.exp-item-photo{display:flex;flex-direction:column;gap:12px;grid-template-columns:1fr;grid-template-rows:auto}.exp-item-photo .exp-actions{grid-column:auto;border-top:1px solid var(--line);padding-top:10px}.exp-photo-wrap{width:100%;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#fbfcfb}.exp-photo-full{width:100%;max-height:min(55vh,320px);object-fit:contain;display:block;background:#fff}.entry-ref{background:#fbfcfb;border:1px solid var(--line);border-radius:10px;padding:12px}.entry-ref-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}.entry-ref-no{font-weight:700;font-size:14px;color:var(--green)}.entry-ref-date{font-size:12px;color:var(--muted)}.entry-ref-grid{display:grid;gap:6px}.entry-ref-row{display:flex;justify-content:space-between;gap:12px;font-size:13px;line-height:1.35}.entry-ref-row span{color:var(--muted);flex-shrink:0}.entry-ref-row b{text-align:right;word-break:break-word}.entry-ref-compact{font-size:11px;font-weight:600;color:var(--green);background:var(--green-soft);padding:2px 7px;border-radius:6px}.exp-item .info .entry-ref-compact{margin-bottom:4px;display:inline-block}
