:root{--bg:#0a0f1a;--bg-elevated:#111827;--bg-card:#ffffff0d;--bg-card-hover:#ffffff14;--bg-input:#ffffff12;--border:#ffffff14;--border-focus:#fff3;--text:#f1f5f9;--text-muted:#94a3b8;--text-dim:#ffffff59;--accent:#3b82f6;--accent-dim:#3b82f626;--accent-glow:#3b82f640;--green:#22c55e;--green-dim:#22c55e26;--amber:#f59e0b;--amber-dim:#f59e0b26;--red:#ef4444;--red-dim:#ef444426;--r-sm:8px;--r:12px;--r-lg:16px;--r-xl:20px;--r-full:9999px;--gap-xs:4px;--gap-sm:8px;--gap:16px;--gap-lg:24px;--gap-xl:32px;--nav-height:56px;--tab-height:60px;--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);--shadow-sm:0 1px 3px #0006;--shadow:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--t-fast:.15s ease;--t:.22s ease;--t-slow:.35s ease}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,system-ui,sans-serif;font-size:16px;line-height:1.5}#root{flex-direction:column;height:100%;display:flex}img,svg{display:block}button{cursor:pointer}input,textarea,select{font:inherit}.scroll-y{-webkit-overflow-scrolling:touch;overflow:hidden auto}.scroll-y::-webkit-scrollbar{display:none}.t-title{letter-spacing:-.5px;font-size:28px;font-weight:700}.t-heading{letter-spacing:-.3px;font-size:20px;font-weight:600}.t-body{font-size:16px;font-weight:400}.t-sub{color:var(--text-muted);font-size:14px;font-weight:400}.t-caption{color:var(--text-dim);letter-spacing:.3px;font-size:12px;font-weight:500}.t-label{font-size:13px;font-weight:600}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--gap-sm)}.gap{gap:var(--gap)}.page{background:var(--bg);flex-direction:column;height:100%;display:flex}.page-content{-webkit-overflow-scrolling:touch;padding:var(--gap) var(--gap) calc(var(--tab-height) + var(--safe-bottom) + var(--gap));flex:1;overflow:hidden auto}.page-content::-webkit-scrollbar{display:none}.section{margin-bottom:var(--gap-lg)}.section-header{margin-bottom:var(--gap-sm);justify-content:space-between;align-items:center;display:flex}.section-title{letter-spacing:.5px;text-transform:uppercase;color:var(--text-dim);font-size:13px;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(8px)}45%{transform:translate(-6px)}60%{transform:translate(6px)}75%{transform:translate(-4px)}90%{transform:translate(4px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}.anim-fade-in{animation:fadeIn var(--t-slow) both}.anim-slide-up{animation:slideUp var(--t-slow) both}.anim-scale-in{animation:fadeInScale var(--t) both}.anim-shake{animation:.5s shake}.stagger>:first-child{animation-delay:30ms}.stagger>:nth-child(2){animation-delay:60ms}.stagger>:nth-child(3){animation-delay:90ms}.stagger>:nth-child(4){animation-delay:.12s}.stagger>:nth-child(5){animation-delay:.15s}.stagger>:nth-child(6){animation-delay:.18s}.stagger>:nth-child(n+7){animation-delay:.21s}.btn{border-radius:var(--r);transition:opacity var(--t-fast), transform var(--t-fast);-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:12px 20px;font-size:15px;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:active{opacity:.75;transform:scale(.97)}.btn:disabled{opacity:.4;pointer-events:none}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-ghost{color:var(--accent);background:0 0;padding:8px 12px}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid #ef444433}.btn-icon{border-radius:var(--r);background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);transition:color var(--t-fast), background var(--t-fast), transform var(--t-fast);padding:10px;font-size:18px;line-height:1}.btn-icon:active{transform:scale(.93)}.btn-full{width:100%}.btn-sm{padding:8px 14px;font-size:13px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--gap);transition:background var(--t-fast)}.card-pressable{cursor:pointer;-webkit-user-select:none;user-select:none}.card-pressable:active{background:var(--bg-card-hover);transform:scale(.99)}.nav-bar{padding:0 var(--gap);padding-top:max(var(--safe-top), 12px);background:var(--bg);border-bottom:1px solid var(--border);min-height:calc(var(--nav-height) + var(--safe-top));justify-content:space-between;align-items:center;gap:var(--gap-sm);z-index:200;flex-shrink:0;padding-bottom:12px;display:flex;position:relative}.nav-title{letter-spacing:-.2px;text-align:center;flex:1;font-size:17px;font-weight:600}.nav-side{align-items:center;width:44px;display:flex}.nav-side-right{justify-content:flex-end}.nav-back{color:var(--accent);transition:opacity var(--t-fast);background:0 0;border:none;align-items:center;gap:4px;padding:6px 0;font-size:16px;font-weight:500;display:flex}.nav-back:active{opacity:.6}.tab-bar{-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);background:#0a0f1aeb;flex-shrink:0;align-items:stretch;display:flex}.tab-item{color:var(--text-dim);letter-spacing:.3px;transition:color var(--t-fast);min-height:var(--tab-height);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:10px 4px 8px;font-size:10px;font-weight:500;display:flex;position:relative}.tab-item.active{color:var(--accent)}.tab-item.active:before{content:"";background:var(--accent);border-radius:0 0 4px 4px;width:32px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%)}.tab-icon{transition:transform var(--t-fast);font-size:22px;line-height:1}.tab-item.active .tab-icon{transform:scale(1.05)}.form-group{margin-bottom:var(--gap)}.form-label{color:var(--text-muted);letter-spacing:.2px;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);width:100%;color:var(--text);transition:border-color var(--t-fast), background var(--t-fast);-webkit-appearance:none;outline:none;padding:12px 14px;font-size:16px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);background:#3b82f60d}.form-input::placeholder{color:var(--text-dim)}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.form-row{gap:var(--gap-sm);grid-template-columns:1fr 1fr;display:grid}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:100;background:#000000b3;align-items:flex-end;padding:0;animation:.2s both fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg-elevated);border-radius:var(--r-xl) var(--r-xl) 0 0;border-top:1px solid var(--border);width:100%;padding:0 var(--gap) calc(var(--safe-bottom) + var(--gap));-webkit-overflow-scrolling:touch;max-height:92vh;animation:.28s cubic-bezier(.32,.72,0,1) both slideUp;overflow-y:auto}.modal-sheet::-webkit-scrollbar{display:none}.modal-handle{border-radius:var(--r-full);background:#ffffff26;width:36px;height:4px;margin:12px auto 20px}.modal-title{margin-bottom:var(--gap);letter-spacing:-.3px;font-size:18px;font-weight:700}.modal-actions{gap:var(--gap-sm);margin-top:var(--gap);flex-direction:column;display:flex}.toast{bottom:calc(var(--tab-height) + var(--safe-bottom) + 16px);z-index:200;-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--r-full);color:var(--text);white-space:nowrap;box-shadow:var(--shadow-lg);background:#1e293bf2;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;animation:.24s cubic-bezier(.32,.72,0,1) both slideUp;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast.success:before{content:"✓";color:var(--green);font-weight:700}.toast.error:before{content:"✕";color:var(--red);font-weight:700}.toast.info:before{content:"i";color:var(--accent);font-weight:700}.empty-state{padding:60px var(--gap);text-align:center;justify-content:center;align-items:center;gap:var(--gap-sm);flex-direction:column;display:flex}.empty-icon{margin-bottom:var(--gap-sm);opacity:.5;font-size:48px}.empty-title{color:var(--text-muted);font-size:17px;font-weight:600}.empty-sub{color:var(--text-dim);max-width:240px;font-size:14px}.chip{border-radius:var(--r-full);border:1px solid #0000;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.chip-blue{background:var(--accent-dim);color:var(--accent);border-color:#3b82f633}.chip-green{background:var(--green-dim);color:var(--green);border-color:#22c55e33}.chip-amber{background:var(--amber-dim);color:var(--amber);border-color:#f59e0b33}.chip-red{background:var(--red-dim);color:var(--red);border-color:#ef444433}.chip-neutral{color:var(--text-muted);background:#ffffff0f}.search-bar{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-full);transition:border-color var(--t-fast);align-items:center;gap:10px;padding:10px 16px;display:flex}.search-bar:focus-within{border-color:var(--border-focus)}.search-bar input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:16px}.search-bar input::placeholder{color:var(--text-dim)}.search-icon{color:var(--text-dim);font-size:16px}.list-group{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.list-item{align-items:center;gap:var(--gap);padding:14px var(--gap);border-bottom:1px solid var(--border);transition:background var(--t-fast);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.list-item:last-child{border-bottom:none}.list-item:active{background:var(--bg-card-hover)}.list-item-icon{border-radius:var(--r);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.list-item-content{flex:1;min-width:0}.list-item-title{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.list-item-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:13px;overflow:hidden}.list-item-chevron{color:var(--text-dim);flex-shrink:0;font-size:14px}.fab{right:var(--gap);bottom:calc(var(--tab-height) + var(--safe-bottom) + var(--gap));border-radius:var(--r-full);background:var(--accent);color:#fff;width:56px;height:56px;box-shadow:0 4px 20px var(--accent-glow), var(--shadow);cursor:pointer;transition:transform var(--t-fast), box-shadow var(--t-fast);z-index:50;border:none;justify-content:center;align-items:center;font-size:24px;display:flex;position:fixed}.fab:active{box-shadow:0 2px 10px var(--accent-glow);transform:scale(.93)}.divider{background:var(--border);height:1px;margin:var(--gap) 0}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.confirm-overlay{-webkit-backdrop-filter:blur(4px);z-index:150;padding:var(--gap);background:#0009;justify-content:center;align-items:center;animation:.2s both fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--gap-lg);text-align:center;width:100%;max-width:320px;animation:.22s cubic-bezier(.32,.72,0,1) both fadeInScale}.confirm-title{margin-bottom:8px;font-size:17px;font-weight:700}.confirm-message{color:var(--text-muted);margin-bottom:var(--gap-lg);font-size:14px;line-height:1.5}.confirm-buttons{gap:var(--gap-sm);grid-template-columns:1fr 1fr;display:grid}.segmented{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);gap:2px;padding:3px;display:flex}.seg-item{border-radius:calc(var(--r) - 2px);color:var(--text-muted);transition:background var(--t-fast), color var(--t-fast);text-align:center;cursor:pointer;background:0 0;border:none;flex:1;padding:7px 4px;font-size:13px;font-weight:600}.seg-item.active{color:var(--text);background:#ffffff1a}.item-row-wrapper{border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent}.item-row-wrapper:last-of-type{border-bottom:none}.item-row-wrapper:active .item-row{opacity:.6}.item-row{align-items:center;gap:10px;padding:10px 4px;display:flex}.item-category-icon{text-align:center;flex-shrink:0;width:28px;font-size:20px}.item-details{flex:1;min-width:0}.item-name{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.item-meta{color:var(--text-muted);align-items:center;gap:6px;margin-top:2px;font-size:12px;display:flex}.item-qty{color:var(--text-muted);flex-shrink:0;font-size:13px}.compartment-add-btn{background:var(--accent-dim);border-radius:var(--r);width:100%;color:var(--accent);cursor:pointer;transition:opacity var(--t-fast);border:1px dashed #3b82f64d;margin-top:8px;padding:10px;font-family:inherit;font-size:14px;font-weight:500}.compartment-add-btn:active{opacity:.7}
