:root{--primary:#7C3AED;--primary-strong:#6D28D9;--primary-soft:#A78BFA;--grad: linear-gradient(135deg, #8B5CF6 0%, #7C3AED 100%);--tint:#F3EFFC;--tint-2:#EFE9FB;--green:#22C55E;--amber:#F59E0B;--blue:#3B82F6;--red:#EF4444;--green-ink:#16A34A;--r-xl:26px;--r-lg:20px;--r-md:14px;--r-sm:10px;--fz:16px;--safe-bottom: env(safe-area-inset-bottom, 16px);font-family:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root,[data-theme=light]{--bg:#F3F3F6;--surface:#FFFFFF;--surface-2:#F6F6F9;--text:#181820;--text-2:#8B8B98;--text-3:#B6B6C1;--border:rgba(20,20,40,.06);--border-2:rgba(20,20,40,.08);--shadow: 0 6px 24px rgba(30,20,60,.06);--shadow-sm: 0 2px 10px rgba(30,20,60,.05);--track:#ECECF1;--page:#E7E7EC}[data-theme=dark]{--bg:#0E0E13;--surface:#1A1A22;--surface-2:#22222D;--tint:#211C30;--tint-2:#2A2340;--text:#F2F2F6;--text-2:#9696A6;--text-3:#62626F;--border:rgba(255,255,255,.07);--border-2:rgba(255,255,255,.1);--shadow: 0 8px 28px rgba(0,0,0,.45);--shadow-sm: 0 2px 12px rgba(0,0,0,.35);--track:#2C2C38;--page:#070709}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;height:100%}body{background:var(--bg);color:var(--text);font-size:var(--fz);transition:background .3s ease}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font-family:inherit}.app{position:relative;max-width:480px;margin:0 auto;min-height:100%;background:var(--bg)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:var(--text-2);font-weight:600;padding:24px;text-align:center}.boot-spinner{width:46px;height:46px;border-radius:50%;border:4px solid var(--track);border-top-color:var(--primary);animation:spin .8s linear infinite;margin-bottom:14px}.screen{overflow-y:auto;overflow-x:hidden;padding:22px 20px calc(110px + var(--safe-bottom));-webkit-overflow-scrolling:touch;scrollbar-width:none}.screen::-webkit-scrollbar{display:none}.card{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:background .35s ease,border-color .35s ease,box-shadow .35s ease}.h-title{font-size:30px;font-weight:800;letter-spacing:-.5px;margin:0}.sec-title{font-size:21px;font-weight:800;letter-spacing:-.3px;margin:0}.muted{color:var(--text-2)}.row-between{display:flex;align-items:center;justify-content:space-between}.pill-pro{display:inline-flex;align-items:center;font-size:12px;font-weight:800;letter-spacing:.6px;color:var(--primary);background:var(--tint-2);padding:3px 9px;border-radius:8px}.chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-md);padding:9px 13px;font-weight:700;font-size:15px;box-shadow:var(--shadow-sm);color:var(--text)}.chip svg{color:var(--text-2)}.icon-btn{width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);color:var(--text)}.dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:0 0 auto}.c-green{color:var(--green)}.c-amber{color:var(--amber)}.c-blue{color:var(--blue)}.c-primary{color:var(--primary)}.btn-primary{width:100%;height:60px;border-radius:18px;background:var(--grad);color:#fff;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;gap:11px;box-shadow:0 12px 26px -8px #7c3aed99;transition:transform .12s ease,filter .12s ease}.btn-primary:active{transform:scale(.98);filter:brightness(1.05)}.btn-primary:disabled{opacity:.7}.photo-slot{background:var(--surface-2);border:1px dashed var(--border-2);display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--text-3);position:relative}.photo-slot img{width:100%;height:100%;object-fit:cover;display:block}.photo-slot .ph-emoji{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--tint)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:34px 20px;color:var(--text-2)}.empty-state .es-icon{width:72px;height:72px;border-radius:50%;background:var(--tint);color:var(--primary);display:flex;align-items:center;justify-content:center}.empty-state .es-title{font-size:17px;font-weight:800;color:var(--text)}.empty-state .es-sub{font-size:14.5px;max-width:260px;line-height:1.45}.tabbar{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:480px;height:calc(74px + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:color-mix(in srgb,var(--surface) 90%,transparent);-webkit-backdrop-filter:saturate(1.4) blur(14px);backdrop-filter:saturate(1.4) blur(14px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:40}[data-theme=dark] .tabbar{background:color-mix(in srgb,var(--surface) 82%,transparent)}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--text-3);font-size:11.5px;font-weight:700;height:74px;justify-content:center}.tab.active{color:var(--primary)}.tab svg{width:25px;height:25px}.fab{position:absolute;left:50%;top:8px;transform:translate(-50%);width:60px;height:60px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 26px -6px color-mix(in srgb,var(--primary) 55%,transparent);border:4px solid var(--surface);z-index:41;transition:transform .14s ease}.fab:active{transform:translate(-50%) scale(.92)}.fab:disabled{opacity:.8}.fab svg{width:27px;height:27px}.hist-row{width:100%;display:flex;align-items:center;gap:14px;padding:13px 18px;background:none}.hist-row:active{background:var(--surface-2)}.hist-div{height:1px;background:var(--border);margin:0 18px}.day-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:9px 0 7px;border-radius:18px;min-height:74px;border:none}.day-cell.active{background:var(--grad);box-shadow:0 10px 22px -8px #7c3aed99}.filter-scroll{display:flex;gap:10px;overflow-x:auto;padding:2px 20px 4px;scrollbar-width:none;margin:0 -20px}.filter-scroll::-webkit-scrollbar{display:none}.filter-chip{flex:0 0 auto;min-width:84px;text-align:center;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-md);padding:11px 14px;box-shadow:var(--shadow-sm)}.filter-chip.active{background:var(--tint);border-color:transparent}.seg{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:5px;gap:4px;box-shadow:var(--shadow-sm)}.seg-btn{flex:1;padding:11px 0;border-radius:12px;font-weight:700;font-size:15.5px;color:var(--text-2);transition:all .18s ease}.seg-btn.active{background:var(--grad);color:#fff;box-shadow:0 8px 18px -8px #7c3aed99}.list-row{width:100%;display:flex;align-items:center;gap:14px;padding:13px 16px;background:none;border-bottom:1px solid var(--border)}.list-row.last{border-bottom:none}.list-row:active{background:var(--surface-2)}.list-ic{width:38px;height:38px;border-radius:11px;flex:0 0 38px;background:var(--tint);color:var(--primary);display:flex;align-items:center;justify-content:center}.tap{transition:transform .13s ease}.tap:active{transform:scale(.97)}.list-row,.hist-row,.filter-chip,.chip,.seg-btn,.card-press{cursor:pointer}.card-press{transition:transform .14s ease,box-shadow .14s ease}.card-press:active{transform:scale(.985)}.sheet-back{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#08061280;display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .26s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sheet-back.in{opacity:1}.sheet{width:100%;max-width:480px;background:var(--surface);color:var(--text);border-radius:30px 30px 0 0;padding:8px 22px calc(22px + var(--safe-bottom));box-shadow:0 -16px 50px #0000004d;transform:translateY(102%);transition:transform .42s cubic-bezier(.18,.9,.28,1);max-height:90%;overflow-y:auto;scrollbar-width:none}.sheet::-webkit-scrollbar{display:none}.sheet-back.in .sheet{transform:none}.grip{width:42px;height:5px;border-radius:3px;background:var(--track);margin:6px auto 16px}.sheet-h{font-size:23px;font-weight:800;letter-spacing:-.4px;margin:0 0 4px}.sheet-sub{color:var(--text-2);font-size:15px;margin:0 0 18px}.opt{width:100%;display:flex;align-items:center;gap:14px;padding:15px 16px;border-radius:16px;background:var(--surface-2);font-size:16.5px;font-weight:700;margin-bottom:10px;text-align:left;border:2px solid transparent;transition:border-color .15s,background .15s,transform .12s;color:var(--text)}.opt:active{transform:scale(.98)}.opt.sel{border-color:var(--primary);background:var(--tint)}.opt .opt-ic{width:40px;height:40px;border-radius:11px;flex:0 0 40px;display:flex;align-items:center;justify-content:center;background:var(--tint);color:var(--primary)}.opt .check{margin-left:auto;color:var(--primary);display:flex}.stepper{display:flex;align-items:center;justify-content:center;gap:22px;margin:8px 0 22px}.step-btn{width:58px;height:58px;border-radius:50%;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:30px;font-weight:700;transition:transform .12s,background .15s}.step-btn:active{transform:scale(.9);background:var(--tint)}.step-val{min-width:130px;text-align:center}.step-num{font-size:46px;font-weight:800;letter-spacing:-1px;line-height:1;color:var(--text);padding:0}.step-input{width:100%;text-align:center;border:none;outline:none;background:none;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.step-input::-webkit-outer-spin-button,.step-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.step-unit{font-size:15px;color:var(--text-2);font-weight:600;margin-top:4px}.sw-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:6px 0 22px}.sw{aspect-ratio:1;border-radius:16px;position:relative;transition:transform .14s;border:3px solid transparent}.sw:active{transform:scale(.9)}.sw.sel{box-shadow:0 0 0 3px var(--surface),0 0 0 6px currentColor}.sw .sw-ck{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff}.sheet-input{width:100%;border:2px solid var(--border-2);background:var(--surface-2);border-radius:16px;padding:16px 18px;font-size:18px;font-weight:700;color:var(--text);font-family:inherit;margin:4px 0 22px;outline:none;transition:border-color .15s}.sheet-input:focus{border-color:var(--primary)}.sheet-btn{width:100%;height:58px;border-radius:18px;background:var(--grad);color:#fff;font-size:17.5px;font-weight:800;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 12px 26px -10px var(--primary);transition:transform .12s,filter .12s}.sheet-btn:active{transform:scale(.98);filter:brightness(1.06)}.sheet-btn:disabled{opacity:.6}.sheet-btn.ghost{background:var(--surface-2);color:var(--text);box-shadow:none;margin-top:10px}.toast-wrap{position:fixed;left:0;right:0;bottom:calc(92px + var(--safe-bottom));display:flex;flex-direction:column-reverse;align-items:center;gap:8px;z-index:70;pointer-events:none}.toast{background:var(--text);color:var(--surface);font-weight:700;font-size:15px;padding:13px 20px;border-radius:14px;box-shadow:0 10px 30px #0000004d;display:flex;align-items:center;gap:9px;transform:translateY(20px);opacity:0;transition:transform .3s cubic-bezier(.2,1,.3,1),opacity .3s;max-width:90%}.toast.in{transform:none;opacity:1}.scan-back{position:fixed;top:0;right:0;bottom:0;left:0;z-index:65;background:#0806129e;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;opacity:0;transition:opacity .3s}.scan-back.in{opacity:1}.scan-box{width:230px;height:230px;border-radius:28px;position:relative;overflow:hidden;background:var(--surface-2);box-shadow:0 20px 60px #0006}.scan-corner{position:absolute;width:34px;height:34px;border:3px solid #fff}.scan-line{position:absolute;left:8px;right:8px;height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,#fff,transparent);box-shadow:0 0 14px 3px #fff9;animation:scanmove 1.5s ease-in-out infinite}@keyframes scanmove{0%{top:10%}50%{top:86%}to{top:10%}}.scan-txt{color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;gap:10px}.scan-dot{width:9px;height:9px;border-radius:50%;background:#fff;animation:scanpulse 1s infinite}@keyframes scanpulse{0%,to{opacity:.3}50%{opacity:1}}.bar-grow{animation:barGrow .7s cubic-bezier(.2,.9,.3,1) both}@keyframes barGrow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}.flame-pulse{display:inline-block;animation:flameP 1.8s ease-in-out infinite}@keyframes flameP{0%,to{transform:scale(1) rotate(-2deg)}50%{transform:scale(1.12) rotate(2deg)}}.add-btn{transition:transform .14s ease,background .15s ease}.card-press:active .add-btn{transform:scale(1.18);background:var(--primary);color:#fff}.ai-card{width:100%;text-align:left;padding:18px 20px;display:flex;align-items:center;gap:16px;background:var(--tint);border:1.5px dashed color-mix(in srgb,var(--primary) 40%,transparent)}.ai-spark{width:52px;height:52px;border-radius:15px;flex:0 0 52px;display:flex;align-items:center;justify-content:center;background:var(--grad);box-shadow:0 10px 22px -8px var(--primary);color:#fff}.spinner{width:46px;height:46px;border-radius:50%;border:4px solid var(--track);border-top-color:var(--primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ex-chip{flex:0 0 auto;padding:10px 15px;border-radius:13px;background:var(--surface-2);font-size:14.5px;font-weight:600;color:var(--text);border:1px solid var(--border-2);transition:transform .12s,background .15s;white-space:nowrap}.ex-chip:active{transform:scale(.95);background:var(--tint)}.pop-in{animation:popIn .4s cubic-bezier(.2,1.2,.4,1) both}@keyframes popIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.fade-in{animation:fade .4s cubic-bezier(.4,0,.2,1)}@keyframes fade{0%{transform:translateY(10px)}to{transform:none}}@media (prefers-reduced-motion: reduce){.bar-grow,.flame-pulse,.fade-in,.pop-in{animation:none}}
