:root{--bg:#faf6ef;--surface:#fff;--surface-2:#f3ede2;--text:#2b2620;--text-2:#8a8174;--text-3:#b3aa9b;--border:#ece5d8;--line:#efe9dd;--ink:#2b2620;--shadow-sm:0 1px 2px #3c321e0f;--shadow:0 8px 24px -12px #3c2d1438;--shadow-lg:0 18px 40px -16px #3c2d1447;--radius:18px;--sans:-apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Segoe UI", Roboto, system-ui, sans-serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;overscroll-behavior-y:none;margin:0;font-size:16px;line-height:1.5}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}.app{background:var(--bg);flex-direction:column;max-width:520px;min-height:100%;margin:0 auto;display:flex;position:relative}.view{flex:1;padding:20px 18px 124px;overflow-x:hidden}.topbar{padding:14px 18px 4px}.topbar .date{color:var(--text-3);font-size:13px}.topbar h1{letter-spacing:-.3px;margin:2px 0 0;font-size:26px;font-weight:800}.nav{z-index:40;pointer-events:none;justify-content:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-inner{width:100%;max-width:520px;padding:10px 18px calc(10px + env(safe-area-inset-bottom));background:linear-gradient(to top, var(--bg) 62%, #faf6ef00);pointer-events:auto;gap:6px;display:flex}.nav-btn{color:var(--text-3);border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:8px 0;font-size:12px;font-weight:600;display:flex}.nav-btn.active{color:var(--text)}.nav-btn svg{width:22px;height:22px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card.flush .task+.task{border-top:1px solid var(--line)}.section-title{color:var(--text-2);letter-spacing:.3px;align-items:center;gap:8px;margin:22px 2px 10px;font-size:13px;font-weight:700;display:flex}.section-title .count{color:var(--text-3);font-weight:600}.bean{background:radial-gradient(circle at 32% 28%,#fff9,#fff0 45%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;position:relative;box-shadow:0 4px 10px -4px #00000040}.bean:after{content:"";border-radius:50%;position:absolute;inset:0;box-shadow:inset 0 -3px 6px #0000001f}.bean .emoji{z-index:1;position:relative}.bean.sm{width:14px;height:14px}.bean.md{width:34px;height:34px}.bean.lg{width:46px;height:46px}.bean.lg .emoji{font-size:22px}.btn{border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:14px 18px;font-size:16px;font-weight:700;transition:transform 80ms,box-shadow .15s,background .15s;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background:var(--ink);color:#fff;box-shadow:var(--shadow)}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-block{width:100%}.btn-sm{border-radius:12px;padding:9px 14px;font-size:14px}.btn-danger{color:#d24b4b}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{background:var(--surface);border:1px solid var(--border);color:var(--text-2);border-radius:999px;padding:9px 14px;font-size:14px;font-weight:600;transition:all .12s}.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}.task{align-items:center;gap:13px;padding:14px;display:flex}.task .meta{flex:1;min-width:0}.task .title{white-space:nowrap;text-overflow:ellipsis;font-size:15.5px;font-weight:600;overflow:hidden}.task .sub{color:var(--text-2);align-items:center;gap:8px;margin-top:3px;font-size:12.5px;display:flex}.task .sub .dot{background:var(--text-3);border-radius:50%;width:3px;height:3px}.due-soon{color:#d24b4b;font-weight:700}.check{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.check svg{opacity:0;width:15px;height:15px}.task.done .check{border-color:var(--ink);background:var(--ink)}.task.done .check svg{opacity:1}.task.done .title{color:var(--text-3);text-decoration:line-through}.task.done .bean{opacity:.45;filter:grayscale(.3)}.task-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.del-btn{width:28px;height:28px;color:var(--text-3);border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.del-btn:active{color:#d24b4b;transform:scale(.9)}.title-add-btn{width:26px;height:26px;color:var(--text-2);background:var(--surface-2);border-radius:50%;justify-content:center;align-items:center;margin-left:auto;transition:all .12s;display:flex}.title-add-btn:active{transform:scale(.9)}.timer-btn{border:2px solid var(--border);width:28px;height:28px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.timer-btn.active{border-color:var(--tc,var(--ink));background:var(--tc,var(--ink));color:#fff;animation:1.6s ease-in-out infinite timer-pulse}@keyframes timer-pulse{0%,to{box-shadow:0 0 0 0 var(--tc,var(--ink))}50%{box-shadow:0 0 0 5px #0000}}.timer-live{font-variant-numeric:tabular-nums;color:var(--text-1);font-weight:700}.task.timing{background:var(--surface-2);border-radius:12px}.hero-card{text-align:center;padding:24px 20px 22px}.hero-card .beans-row{justify-content:center;align-items:center;gap:10px;min-height:46px;margin-bottom:18px;display:flex}.hero-card h2{margin:0 0 6px;font-size:20px;font-weight:800}.hero-card p{color:var(--text-2);margin:0 0 18px;font-size:14px}.progress{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.progress .big{letter-spacing:-.5px;font-size:28px;font-weight:800}.progress .big span{color:var(--text-3);font-size:15px;font-weight:600}.progress .time{color:var(--text-2);font-size:13px}.bar{background:var(--surface-2);border-radius:999px;height:8px;overflow:hidden}.bar>i{background:var(--ink);border-radius:999px;height:100%;transition:width .3s;display:block}.empty{text-align:center;color:var(--text-2);padding:40px 24px}.empty .emoji{opacity:.7;margin-bottom:10px;font-size:40px;display:block}.sheet-mask{z-index:60;background:#231c1266;animation:.18s fade;position:fixed;inset:0}.sheet{z-index:61;background:var(--surface);max-width:520px;padding:8px 20px calc(24px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0;max-height:90vh;margin:0 auto;animation:.22s cubic-bezier(.2,.8,.2,1) rise;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.sheet .grip{background:var(--border);border-radius:999px;width:38px;height:4px;margin:6px auto 16px}.sheet h3{margin:0 0 16px;font-size:18px;font-weight:800}.field{margin-bottom:16px}.field label{color:var(--text-2);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.input,.textarea{border:1px solid var(--border);background:var(--surface-2);border-radius:13px;outline:none;width:100%;padding:13px 14px;transition:border .12s,background .12s}.input:focus,.textarea:focus{border-color:var(--ink);background:var(--surface)}.textarea{resize:none;min-height:64px}.cat-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.cat-opt{border:1.5px solid var(--border);background:var(--surface);border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;transition:all .12s;display:flex}.cat-opt.active{border-color:var(--ink);background:var(--surface-2)}.cat-opt .lbl{color:var(--text-2);font-size:12.5px;font-weight:600}.cat-opt.active .lbl{color:var(--text)}.seg{background:var(--surface-2);border-radius:12px;gap:2px;padding:3px;display:flex}.seg button{color:var(--text-2);border-radius:10px;flex:1;padding:9px 0;font-size:14px;font-weight:600}.seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.fab{z-index:45;right:max(18px,50% - 242px);bottom:calc(78px + env(safe-area-inset-bottom));background:var(--ink);color:#fff;width:54px;height:54px;box-shadow:var(--shadow-lg);border-radius:50%;justify-content:center;align-items:center;transition:transform .12s;display:flex;position:fixed}.fab:active{transform:scale(.92)}.fab svg{width:26px;height:26px}.sound-toggle{z-index:44;top:calc(10px + env(safe-area-inset-top));background:var(--card);width:34px;height:34px;color:var(--text-2);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;transition:transform .12s,color .12s;display:flex;position:fixed;right:max(14px,50% - 246px)}.sound-toggle:active{transform:scale(.9)}.sound-toggle.is-off{color:var(--text-3)}.legend{flex-wrap:wrap;gap:6px 14px;padding:14px 16px;display:flex}.legend .item{color:var(--text-2);align-items:center;gap:6px;font-size:13px;display:flex}.row-link{text-align:left;width:100%}@keyframes fade{0%{opacity:0}}@keyframes rise{0%{transform:translateY(100%)}}@keyframes pop{0%{opacity:0;transform:scale(.4)}70%{transform:scale(1.12)}to{opacity:1;transform:scale(1)}}.pop{animation:.32s cubic-bezier(.2,.9,.3,1.2) pop}@media (width>=600px){.fab{right:calc(50% - 242px)}}.draw-overlay{z-index:90;background:#faf6eff7;justify-content:center;align-items:center;animation:.2s fade;display:flex;position:fixed;inset:0}.chaos-stage{width:240px;height:240px;position:relative}.chaos-bean{margin:-17px 0 0 -17px;animation:.9s ease-in-out infinite tumble;position:absolute;top:50%;left:50%}@keyframes tumble{0%{transform:translate(0)rotate(0)scale(1)}25%{transform:translate(var(--x1), var(--y1)) rotate(180deg) scale(1.15)}50%{transform:translate(var(--x2), var(--y2)) rotate(360deg) scale(.85)}75%{transform:translate(var(--x3), var(--y3)) rotate(540deg) scale(1.2)}to{transform:translate(0)rotate(720deg)scale(1)}}.chaos-text{text-align:center;color:var(--text-2);font-size:14px;font-weight:600;position:absolute;bottom:-34px;left:0;right:0}.reveal-stage{flex-direction:column;align-items:center;gap:18px;animation:.25s fade;display:flex}.reveal-title{margin:0;font-size:20px;font-weight:800}.reveal-row{flex-wrap:wrap;justify-content:center;gap:12px;max-width:340px;padding:0 16px;display:flex}.reveal-item{flex-direction:column;align-items:center;gap:5px;width:92px;display:flex}.reveal-cat{color:var(--text-2);font-size:12px;font-weight:700}.reveal-name{color:var(--text-3);text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:1.3;display:-webkit-box;overflow:hidden}.reveal-empty{color:var(--text-2);font-size:15px;font-weight:600}.task-bar{background:var(--surface-2);border-radius:999px;height:5px;margin-top:8px;display:block;overflow:hidden}.task-bar>i{border-radius:999px;height:100%;transition:width .5s cubic-bezier(.2,.8,.2,1);display:block}.task.done .task-bar>i{background:var(--ink)!important}.task-slider{appearance:none;cursor:pointer;background:0 0;width:100%;height:28px;margin-top:6px;padding:0}.task-slider::-webkit-slider-runnable-track{background:linear-gradient(to right, var(--c,var(--ink)) var(--p,0%), var(--surface-2) var(--p,0%));border-radius:999px;height:6px}.task-slider::-moz-range-track{background:var(--surface-2);border-radius:999px;height:6px}.task-slider::-moz-range-progress{background:var(--c,var(--ink));border-radius:999px;height:6px}.task-slider::-webkit-slider-thumb{appearance:none;border:2.5px solid var(--c,var(--ink));background:#fff;border-radius:50%;width:18px;height:18px;margin-top:-6px;transition:transform 80ms;box-shadow:0 2px 5px #0000002e}.task-slider::-webkit-slider-thumb:active{transform:scale(1.25)}.task-slider::-moz-range-thumb{border:2.5px solid var(--c,var(--ink));background:#fff;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 5px #0000002e}.task.done .task-slider{opacity:.5}.task-slider:disabled{opacity:.65;cursor:not-allowed}.title-row{align-items:center;gap:8px;display:flex}.title-row .input{flex:1}.voice-btn{border:1px solid var(--border);background:var(--surface-2);width:44px;height:44px;color:var(--text-2);border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.voice-btn.rec{color:#fff;background:#ef4444;border-color:#ef4444;animation:1.1s ease-in-out infinite mic-pulse}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ef444459}50%{box-shadow:0 0 0 8px #ef444400}}.custom-time{justify-content:center;align-items:center;gap:16px;margin-top:12px;display:flex}.ct-field{color:var(--text-2);align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.ct-field input{text-align:center;border:1px solid var(--border);background:var(--surface-2);width:56px;color:var(--text);border-radius:10px;outline:none;padding:8px;font-size:16px;font-weight:700}.ct-field input:focus{border-color:var(--ink);background:var(--surface)}.draw-actions{gap:12px;margin-top:4px;display:flex}.draw-actions .btn{min-width:120px}.mini-sum{text-align:right;color:var(--text-3);margin:6px 4px 0;font-size:12px}.draw-sum{color:var(--text-2);justify-content:center;align-items:center;gap:10px;font-size:13px;font-weight:600;display:flex}.draw-sum .dot{background:var(--text-3);border-radius:50%;width:3px;height:3px}.hero-stat{align-items:center;gap:14px;padding:18px;display:flex}.hero-stat .emoji{background:var(--surface-2);width:48px;height:48px;color:var(--ink);border-radius:14px;justify-content:center;align-items:center;display:flex}.hero-stat .big{letter-spacing:-.3px;font-size:22px;font-weight:800}.hero-stat .big span{color:var(--text-3);font-size:14px;font-weight:600}.hero-stat .sub{color:var(--text-2);margin-top:2px;font-size:13px}.reward-card{text-align:left;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);padding:16px;transition:transform 80ms}.reward-card:active{transform:scale(.99)}.reward-card.achieved{background:linear-gradient(#f0fbf3,#fff 60%);border-color:#22c55e}.rc-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.rc-title{color:var(--text);align-items:center;gap:7px;font-size:16px;font-weight:700;display:flex}.rc-period{color:var(--text-3);background:var(--surface-2);border-radius:999px;padding:3px 9px;font-size:12px;font-weight:600}.rc-bar{background:var(--surface-2);border-radius:999px;height:8px;margin:12px 0 10px;overflow:hidden}.rc-bar>i{background:var(--ink);border-radius:999px;height:100%;transition:width .4s;display:block}.reward-card.achieved .rc-bar>i{background:#22c55e}.rc-foot{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.rc-count{color:var(--text-2);font-size:13px;font-weight:700}.rc-reward{color:var(--text-3);text-align:right;font-size:13px}.rc-done{color:#1f9d52;margin-top:10px;font-size:13px;font-weight:700}.freq-row{align-items:center;gap:10px;margin-top:10px;display:flex}.freq-row .freq-pre{color:var(--text-2);font-size:14px;font-weight:600}.freq-count{flex:0 0 110px}.freq-hint{color:var(--text-3);margin:10px 0 0;font-size:12.5px}.freq-tag{color:#2f9e3e;font-weight:700}.review-seg{margin-bottom:0}.review-sum .rs-row{justify-content:space-between;align-items:baseline;display:flex}.review-sum .rs-big{letter-spacing:-.5px;font-size:30px;font-weight:800}.review-sum .rs-side{color:var(--text-2);flex-direction:column;align-items:flex-end;gap:2px;font-size:13px;font-weight:600;display:flex}.review-sum .rs-foot{color:var(--text-3);margin-top:12px;font-size:12.5px}.heat-week{grid-template-columns:repeat(7,1fr);gap:6px;padding:14px;display:grid}.hw-cell{flex-direction:column;align-items:center;gap:4px;display:flex}.hw-cell .hw-wd{color:var(--text-3);font-size:11px;font-weight:600}.hw-bean{aspect-ratio:1;border-radius:12px;justify-content:center;align-items:center;width:100%;min-height:36px;transition:background .2s;display:flex}.hw-pct{color:#fff;text-shadow:0 1px 2px #00000040;font-size:12px;font-weight:800}.hw-cell .hw-date{color:var(--text-2);font-size:12px;font-weight:700}.hw-cell .hw-mini{color:var(--text-3);font-size:10px}.hw-cell.is-today .hw-date{color:var(--ink)}.hw-cell.is-today .hw-bean{outline:2px solid var(--ink);outline-offset:1px}.heat-month{padding:14px}.hm-head{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px;display:grid}.hm-head span{text-align:center;color:var(--text-3);font-size:11px;font-weight:700}.hm-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.hm-cell{aspect-ratio:1;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:1px;transition:background .2s;display:flex}.hm-cell.out{opacity:.25}.hm-day{color:var(--text-2);font-size:11px;font-weight:700}.hm-frac{color:var(--text-2);opacity:.85;font-size:9px}.hm-cell.is-today{outline:2px solid var(--ink);outline-offset:1px}.heat-year{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;padding:14px;display:flex}.hy-month{align-items:center;gap:8px;display:flex}.hy-label{color:var(--text-2);flex:0 0 34px;font-size:11px;font-weight:700}.hy-cells{flex:1;grid-template-columns:repeat(31,1fr);gap:2px;display:grid}.hy-cell{aspect-ratio:1;border-radius:3px;transition:background .2s}.hy-cell.is-today{outline:1.5px solid var(--ink);outline-offset:.5px}.heat-legend{color:var(--text-3);justify-content:flex-end;align-items:center;gap:4px;margin-top:14px;font-size:11px;display:flex}.heat-legend i{border-radius:4px;width:14px;height:14px;display:inline-block}.picker-overlay{z-index:60;background:#0006;justify-content:center;align-items:flex-end;animation:.2s fade;display:flex;position:fixed;inset:0}.picker-sheet{background:var(--card);width:100%;max-width:520px;max-height:70vh;padding-bottom:env(safe-area-inset-bottom);border-radius:18px 18px 0 0;flex-direction:column;animation:.25s slide-up;display:flex}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.picker-header{justify-content:space-between;align-items:center;padding:18px 20px 8px;display:flex}.picker-header h3{margin:0;font-size:17px;font-weight:800}.picker-close{width:30px;height:30px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;display:flex}.picker-search{border:1px solid var(--border);background:var(--surface-2);border-radius:10px;outline:none;margin:4px 20px 10px;padding:10px 14px;font-size:14px}.picker-search:focus{border-color:var(--ink)}.picker-list{flex:1;padding:0 12px 16px;overflow-y:auto}.picker-empty{text-align:center;color:var(--text-3);padding:30px 0;font-size:14px}.picker-item{text-align:left;border-radius:10px;align-items:center;gap:12px;width:100%;padding:11px 10px;transition:background .1s;display:flex}.picker-item:active{background:var(--surface-2)}.picker-bean{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.picker-info{flex-direction:column;gap:2px;min-width:0;display:flex}.picker-title{white-space:nowrap;text-overflow:ellipsis;font-size:14.5px;font-weight:600;overflow:hidden}.picker-sub{color:var(--text-3);font-size:12px}.auth-screen{min-height:100%;padding:32px 20px calc(32px + env(safe-area-inset-bottom));background:radial-gradient(120% 80% at 50% -10%, #fff7e9 0%, #fff7e900 60%), var(--bg);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--surface);border-radius:var(--radius);width:100%;max-width:360px;box-shadow:var(--shadow-lg);text-align:center;padding:30px 24px 24px}.auth-logo{margin-bottom:10px;font-size:44px;line-height:1}.auth-title{letter-spacing:.5px;margin:0 0 4px;font-size:22px;font-weight:700}.auth-sub{color:var(--text-2);margin:0 0 18px;font-size:13px;line-height:1.5}.auth-seg{background:var(--surface-2);border-radius:999px;margin-bottom:18px;padding:4px;display:flex}.auth-seg button{color:var(--text-2);cursor:pointer;background:0 0;border:0;border-radius:999px;flex:1;padding:8px 0;font-size:14px;font-weight:600;transition:all .18s}.auth-seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.auth-form{text-align:left;flex-direction:column;gap:12px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field span{color:var(--text-2);font-size:12px;font-weight:600}.auth-field input{border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:12px;outline:none;padding:12px 14px;font-size:15px;transition:border-color .18s,box-shadow .18s}.auth-field input:focus{background:var(--surface);border-color:#d9c9a8;box-shadow:0 0 0 3px #d9c9a840}.auth-error{color:#c0392b;background:#fbeae7;border-radius:10px;padding:9px 12px;font-size:13px}.auth-submit{margin-top:4px;font-size:15px;font-weight:700}.auth-hint{color:var(--text-3);margin:16px 0 0;font-size:12px}.signout-btn{top:calc(12px + env(safe-area-inset-top));z-index:30;border:1px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:999px;padding:5px 11px;font-size:12px;position:fixed;left:12px}
