:root{--green: #16a34a;--green-dark: #15803d;--green-darker: #14532d;--green-light: #dcfce7;--green-tint: #f0fdf4;--red: #dc2626;--red-light: #fee2e2;--amber: #d97706;--amber-light: #fef3c7;--blue: #2563eb;--blue-light: #dbeafe;--gray: #6b7280;--gray-light: #9ca3af;--bg: #f4f5f7;--card: #ffffff;--border: #e8eaed;--ink: #111827;--r-sm: 10px;--r: 14px;--r-lg: 18px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .05);--shadow: 0 2px 8px rgba(16, 24, 40, .08), 0 1px 3px rgba(16, 24, 40, .04);--shadow-lg: 0 12px 32px rgba(16, 24, 40, .16);--t: .18s cubic-bezier(.4, 0, .2, 1);--safe-b: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--bg);color:var(--ink);line-height:1.45;overscroll-behavior-y:none}h1,h2,h3{letter-spacing:-.02em}.app{max-width:640px;margin:0 auto;min-height:100vh;padding-bottom:calc(80px + var(--safe-b));background:var(--bg)}.topbar{background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);color:#fff;padding:16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20;box-shadow:0 2px 12px #15803d40}.topbar h1{font-size:18px;font-weight:700}.topbar .sub{font-size:12px;opacity:.9;margin-top:1px}.topbar button{background:#ffffff2e;color:#fff;border:none;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;transition:var(--t);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.topbar button:active{background:#ffffff4d;transform:scale(.96)}.content{padding:14px;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.card{background:var(--card);border-radius:var(--r);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-sm);border:1px solid transparent;transition:var(--t)}.card h3{font-size:15px;margin-bottom:8px}.row{display:flex;align-items:center;justify-content:space-between;gap:8px}.muted{color:var(--gray);font-size:13px}.spacer{height:8px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.stat{background:var(--card);border-radius:var(--r);padding:16px;box-shadow:var(--shadow-sm);transition:var(--t)}.stat .num{font-size:28px;font-weight:800;color:var(--green-dark);letter-spacing:-.03em;line-height:1.1}.stat .label{font-size:13px;color:var(--gray);margin-top:2px}button.stat:active{transform:scale(.98);box-shadow:var(--shadow)}label{display:block;font-size:13px;color:var(--gray);font-weight:500;margin:12px 0 5px}input,select,textarea{width:100%;padding:12px 13px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:16px;background:#fff;color:var(--ink);font-family:inherit;transition:var(--t)}textarea{resize:vertical}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px #16a34a1f}input:disabled,select:disabled{background:#f3f4f6;color:var(--gray-light)}input[type=checkbox]{width:auto;accent-color:var(--green)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--green);color:#fff;border:none;padding:13px 16px;border-radius:var(--r-sm);font-size:15px;font-weight:700;width:100%;cursor:pointer;transition:var(--t);box-shadow:0 1px 2px #16a34a4d}.btn:active{transform:scale(.975)}.btn:disabled{opacity:.45;box-shadow:none}.btn.secondary{background:#fff;color:var(--green-dark);border:1.5px solid var(--green);box-shadow:none}.btn.secondary:active{background:var(--green-tint)}.btn.danger{background:var(--red);box-shadow:0 1px 2px #dc26264d}.btn.amber{background:var(--amber);box-shadow:0 1px 2px #d977064d}.btn.small{padding:9px 13px;font-size:13px;width:auto;border-radius:9px}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.badge.gray{background:#f1f3f5;color:var(--gray)}.badge.green{background:var(--green-light);color:var(--green-dark)}.badge.amber{background:var(--amber-light);color:var(--amber)}.badge.red{background:var(--red-light);color:var(--red)}.badge.blue{background:var(--blue-light);color:var(--blue)}.list-item{padding:12px 0;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}.nav{position:fixed;bottom:0;left:0;right:0;max-width:640px;margin:0 auto;background:#ffffffeb;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:8px 4px calc(8px + var(--safe-b));z-index:20}.nav a{flex:1;text-align:center;text-decoration:none;color:var(--gray-light);font-size:11px;font-weight:600;padding:4px 0;display:flex;flex-direction:column;align-items:center;gap:3px;transition:var(--t);border-radius:12px}.nav a .icon{font-size:21px;transition:var(--t);filter:grayscale(.4) opacity(.75)}.nav a.active{color:var(--green-dark)}.nav a.active .icon{filter:none;transform:translateY(-1px) scale(1.08)}.login-wrap{max-width:400px;margin:0 auto;padding:56px 22px;animation:fadeIn .3s ease}.login-wrap .logo{text-align:center;margin-bottom:28px}.login-wrap .logo .emoji{font-size:52px;display:inline-block;animation:pop .4s ease}.login-wrap h1{color:var(--green-dark);font-size:24px;margin-top:6px}@keyframes pop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.error,.warn,.ok{padding:11px 13px;border-radius:var(--r-sm);font-size:14px;margin:8px 0;font-weight:500;animation:fadeIn .2s ease}.error{background:var(--red-light);color:var(--red)}.warn{background:var(--amber-light);color:#92400e}.ok{background:var(--green-light);color:var(--green-dark)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182780;display:flex;align-items:flex-end;justify-content:center;z-index:50;animation:fadeIn .2s ease}.modal{background:#fff;width:100%;max-width:640px;border-radius:22px 22px 0 0;padding:8px 18px calc(20px + var(--safe-b));max-height:92vh;overflow-y:auto;position:relative;animation:slideUp .28s cubic-bezier(.2,.8,.2,1);box-shadow:var(--shadow-lg)}.modal:before{content:"";display:block;width:40px;height:4px;border-radius:999px;background:#d1d5db;margin:8px auto 14px}.modal h2{font-size:18px;margin-bottom:4px}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:none}}.line-card{border:1.5px solid var(--border);border-radius:var(--r-sm);padding:12px;margin-bottom:8px;background:#fcfcfd}.consume-list{max-height:46vh;overflow-y:auto;margin:10px -4px;padding:0 4px;-webkit-overflow-scrolling:touch}.consume-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-radius:var(--r-sm);border-bottom:1px solid var(--border);transition:var(--t)}.consume-row:last-child{border-bottom:none}.consume-row.filled{background:var(--green-tint);box-shadow:inset 3px 0 0 var(--green)}.consume-row input{padding:9px 10px}.modal-footer{position:sticky;bottom:0;background:#fff;padding-top:12px;margin-top:4px;box-shadow:0 -8px 12px -8px #0000001f}.fab{position:fixed;bottom:calc(86px + var(--safe-b));right:calc(50% - 304px);z-index:15}@media (max-width: 672px){.fab{right:16px}}.fab button,.fab .btn{width:58px;height:58px;border-radius:50%;font-size:28px;padding:0;box-shadow:var(--shadow-lg);transition:var(--t)}.fab button:active{transform:scale(.92)}.empty{text-align:center;color:var(--gray);padding:48px 20px;font-size:14px}.empty .big{font-size:40px;display:block;margin-bottom:10px;opacity:.8}.skeleton{background:linear-gradient(90deg,#eceef1 25%,#f4f5f7,#eceef1 75%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sk-card{height:76px;margin-bottom:12px;border-radius:var(--r)}.toast-wrap{position:fixed;top:calc(env(safe-area-inset-top,0px) + 12px);left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:100;pointer-events:none}.toast{pointer-events:auto;max-width:440px;width:calc(100% - 28px);padding:13px 16px;border-radius:var(--r);font-size:14px;font-weight:600;color:#fff;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;animation:toastIn .3s cubic-bezier(.2,.8,.2,1)}.toast.ok{background:var(--green-dark)}.toast.error{background:var(--red)}.toast.warn{background:var(--amber)}.toast.info{background:#1f2937}@keyframes toastIn{0%{transform:translateY(-120%);opacity:0}to{transform:none;opacity:1}}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:9px 6px;border-bottom:1px solid var(--border)}th{color:var(--gray);font-weight:600;font-size:12px}a{color:var(--green-dark)}
