:root{--bg:#f2f1f8;--panel:#fff;--ink:#191926;--muted:#8b8b9e;--faint:#b7b7c6;--line:#ececf1;--accent:#5b5bd6;--accent2:#8168f2;--accent-soft:#edeafd;--accent-ink:#4a3ec2;--green:#1fa572;--green-soft:#e2f6ee;--green-ink:#137a53;--amber:#dd8a1a;--amber-soft:#fdf1dc;--rose:#d9556f;--rose-soft:#fce8ec;--routine:#2c9bc7;--routine-soft:#e2f2fa;--routine-ink:#1c7ba1;--r-lg:20px;--r-md:15px;--r-sm:11px;--shadow-sm:0 2px 8px #1c16400f;--shadow-md:0 8px 22px #1c16401a;--shadow-lg:0 14px 34px #5b5bd64d;--safe-b:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;overscroll-behavior-y:none;font-family:Pretendard,Pretendard Variable,Apple SD Gothic Neo,system-ui,-apple-system,Malgun Gothic,sans-serif}button,input{font-family:inherit}.app{background:radial-gradient(120% 55% at 50% -8%, #efe9ff 0%, transparent 60%), var(--bg);flex-direction:column;max-width:480px;height:100%;margin:0 auto;display:flex;position:relative;overflow:hidden}.loading{color:var(--muted);flex:1;justify-content:center;align-items:center;font-weight:700;display:flex}.screen{min-height:0;padding:14px 16px calc(120px + var(--safe-b));scrollbar-width:none;flex:1;overflow-y:auto}.screen::-webkit-scrollbar{display:none}.appbar{justify-content:space-between;align-items:baseline;margin:6px 2px 14px;display:flex}.appbar .hi{color:var(--muted);font-size:13px;font-weight:600}.appbar .dt{color:var(--faint);font-size:13px;font-weight:700}.sc-title{letter-spacing:-.03em;margin:2px 2px 3px;font-size:25px;font-weight:800}.sc-sub{color:var(--muted);margin:0 2px 14px;font-size:13px;font-weight:600}.ritual-banner{cursor:pointer;color:#8a5713;border-radius:var(--r-md);box-shadow:var(--shadow-sm);background:linear-gradient(120deg,#fff4e0,#fdead0);border:1px solid #f4d9a6;align-items:center;gap:10px;margin-bottom:12px;padding:12px 14px;font-size:13px;font-weight:700;display:flex}.ritual-banner .go{opacity:.7;margin-left:auto;font-size:12px}.nowcard{color:#fff;border-radius:var(--r-lg);background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:var(--shadow-lg);margin-bottom:14px;padding:16px 17px 15px;position:relative;overflow:hidden}.nowcard:after{content:"";background:radial-gradient(circle,#fff3,#0000 70%);width:150px;height:150px;position:absolute;top:-40px;right:-40px}.now-top{opacity:.92;justify-content:space-between;align-items:center;font-size:12px;display:flex;position:relative}.now-live{align-items:center;gap:6px;font-weight:800;display:flex}.now-live i{background:#8dffca;border-radius:50%;width:7px;height:7px;animation:1.8s infinite pulse;box-shadow:0 0 #8dffcab3}@keyframes pulse{0%{box-shadow:0 0 #8dffca8c}70%{box-shadow:0 0 0 9px #8dffca00}to{box-shadow:0 0 #8dffca00}}.now-label{opacity:.85;letter-spacing:.02em;margin:12px 0 3px;font-size:11.5px;font-weight:700}.now-title{letter-spacing:-.02em;font-size:20px;font-weight:800;line-height:1.25}.now-meta{opacity:.92;margin-top:6px;font-size:12.5px}.now-prog{background:#ffffff47;border-radius:99px;height:5px;margin:13px 0;overflow:hidden}.now-prog i{background:#fff;border-radius:99px;height:100%;transition:width .4s;display:block}.now-actions{gap:8px;display:flex}.now-actions button{cursor:pointer;color:#fff;background:#fff3;border:0;border-radius:12px;flex:1;padding:10px 0;font-size:13px;font-weight:800;transition:transform .1s}.now-actions button:active{transform:scale(.96)}.now-actions button.primary{color:var(--accent-ink);background:#fff}.nowcard.calm{background:linear-gradient(135deg,#1fa572,#37bd86);box-shadow:0 14px 34px #1fa57247}.goalbar{cursor:pointer;background:var(--accent-soft);color:var(--accent-ink);border-radius:var(--r-sm);align-items:center;gap:10px;margin-bottom:12px;padding:10px 13px;font-size:13px;font-weight:800;display:flex}.goalbar .track{background:#dcd6f8;border-radius:99px;flex:1;height:6px;overflow:hidden}.goalbar .track i{background:var(--accent);border-radius:99px;height:100%;display:block}.seg{background:#eceaf3;border-radius:12px;gap:3px;margin:4px 0 14px;padding:3px;display:flex}.seg button{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:9px;flex:1;padding:8px 0;font-size:13px;font-weight:800}.seg button.on{color:var(--ink);background:#fff;box-shadow:0 1px 5px #00000014}.sec{align-items:center;gap:9px;margin:16px 2px 10px;display:flex}.sec .st{letter-spacing:-.01em;font-size:13.5px;font-weight:800}.sec .sc{color:var(--muted);background:#eceaf3;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:800}.sec.routine .st{color:var(--routine-ink)}.sec .bar{background:var(--line);flex:1;height:1px}.task{border-radius:var(--r-md);border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;align-items:flex-start;gap:12px;margin-bottom:8px;padding:12px 13px;transition:transform .1s,opacity .2s;display:flex}.task:active{transform:scale(.992)}.task.routine{background:var(--routine-soft);border-color:#d3ecf5}.task.event{background:#fbfbfe;border-style:dashed}.chk{cursor:pointer;background:#fff;border:2px solid #ccccd9;border-radius:7px;flex:none;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;transition:all .15s;display:flex}.task.routine .chk{border-color:#9dd1e6;border-radius:50%}.chk svg{opacity:0;width:13px;height:13px;transition:all .15s;transform:scale(.6)}.task.done .chk{background:var(--green);border-color:var(--green)}.task.routine.done .chk{background:var(--routine);border-color:var(--routine)}.task.done .chk svg{opacity:1;transform:scale(1)}.task.done .t-title{color:var(--muted);text-decoration:line-through}.task.done{opacity:.72}.t-body{flex:1;min-width:0}.t-title{word-break:break-word;font-size:14.5px;font-weight:600;line-height:1.35}.t-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.time{color:var(--accent-ink);background:var(--accent-soft);border-radius:6px;padding:2px 7px;font-size:12px;font-weight:800}.time.r{color:var(--routine-ink);background:#d6ecf6}.pill{border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.pill.goal{background:var(--green-soft);color:var(--green-ink)}.pill.streak{color:#c6771a;background:#fff1e0}.pill.freq{color:var(--routine-ink);background:#d6ecf6}.pill.due{background:var(--amber-soft);color:var(--amber)}.pill.overdue{background:var(--rose-soft);color:var(--rose)}.pill.event{color:var(--muted);border:1px solid var(--line);background:#fff}.planday{border-radius:var(--r-md);text-align:center;color:var(--muted);cursor:pointer;background:#faf9ff;border:1.5px dashed #cfcadf;margin-top:8px;padding:13px;font-size:13px;font-weight:800}.donecount{text-align:center;color:var(--muted);margin:16px 0 2px;font-size:12.5px;font-weight:700}.donecount b{color:var(--green)}.empty{text-align:center;color:var(--faint);padding:16px 10px;font-size:13px;font-weight:600;line-height:1.6}.tl-note{color:var(--routine-ink);background:var(--routine-soft);border-radius:10px;margin:2px 0 12px;padding:9px 11px;font-size:11.5px;font-weight:700}.tl-row{gap:10px;min-height:46px;display:flex}.tl-h{width:42px;color:var(--faint);text-align:right;flex:none;padding-top:3px;font-size:11px;font-weight:800}.tl-c{border-top:1px solid var(--line);flex:1;padding:5px 0}.block{color:#fff;border-radius:11px;margin-bottom:5px;padding:8px 11px;font-size:12.5px;font-weight:800}.block small{opacity:.9;margin-top:1px;font-size:11px;font-weight:600;display:block}.b-accent{background:linear-gradient(135deg,var(--accent),var(--accent2))}.b-green{background:linear-gradient(135deg,var(--green),#37bd86)}.b-routine{background:linear-gradient(135deg,var(--routine),#4fb6d8)}.b-event{color:var(--accent-ink);background:#eeeefc;border:1px dashed #bcb6ea}.cal-nav{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.cal-nav button{border:1px solid var(--line);width:34px;height:32px;color:var(--muted);cursor:pointer;background:#fff;border-radius:10px;font-size:16px;font-weight:800}.cal-nav .rng{font-size:14px;font-weight:800}.cal-head{grid-template-columns:34px repeat(7,1fr);gap:3px;margin-bottom:5px;display:grid}.cal-head div{text-align:center;color:var(--muted);padding:4px 0;font-size:11px;font-weight:800}.cal-head div.today{color:#fff;background:var(--accent);border-radius:8px}.cal-grid{grid-template-columns:34px repeat(7,1fr);display:grid;position:relative}.cal-hours{color:var(--faint);text-align:right;flex-direction:column;justify-content:space-between;padding-top:2px;padding-right:5px;font-size:10px;font-weight:800;display:flex}.cal-col{background:#faf9ff;border:1px solid #f0eff7;border-radius:6px;min-height:300px;margin:0 1px;position:relative}.cal-col.today{background:#f4f1ff;border-color:#ddd6fa}.cal-blk{color:#fff;border-radius:5px;padding:2px 3px;font-size:9px;font-weight:800;line-height:1.15;position:absolute;left:2px;right:2px;overflow:hidden}.card{border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);background:#fff;margin-bottom:13px;padding:15px}.card h3{align-items:center;gap:7px;margin:0 0 3px;font-size:14.5px;font-weight:800;display:flex}.card h3 .r{color:var(--muted);margin-left:auto;font-size:12px;font-weight:800}.card .cap{color:var(--muted);margin:0 0 12px;font-size:11.5px}.goal-item{align-items:flex-start;gap:11px;margin-bottom:13px;display:flex}.goal-item:last-child{margin-bottom:0}.goal-item .gc{flex:1;min-width:0}.goal-item .g-top{justify-content:space-between;gap:8px;margin-bottom:6px;font-size:13.5px;font-weight:700;display:flex}.goal-item .g-top .pct{color:var(--muted);flex:none;font-size:12px;font-weight:800}.goal-item.done .g-top span:first-child{color:var(--muted);text-decoration:line-through}.gtrack{background:#eee;border-radius:99px;height:7px;overflow:hidden}.gtrack i{background:linear-gradient(90deg,var(--green),#37bd86);border-radius:99px;height:100%;display:block}.gtrack.a i{background:linear-gradient(90deg,var(--accent),var(--accent2))}.del{color:var(--faint);cursor:pointer;background:0 0;border:0;flex:none;padding:0 2px;font-size:16px}.boxrow{border-bottom:1px solid var(--line);align-items:center;gap:11px;padding:12px 4px;font-size:14px;font-weight:600;display:flex}.boxrow:last-child{border-bottom:0}.boxrow .ic{border-radius:9px;justify-content:center;align-items:center;width:31px;height:31px;font-size:15px;display:flex}.boxrow .cnt{color:var(--muted);background:#f1f0f7;border-radius:99px;margin-left:auto;padding:2px 9px;font-size:12px;font-weight:800}.month-note{color:var(--muted);text-align:center;background:#f6f5fb;border-radius:10px;padding:10px 12px;font-size:11.5px;line-height:1.5}.btn{cursor:pointer;border:0;border-radius:12px;width:100%;padding:12px;font-size:14px;font-weight:800}.btn.primary{background:var(--accent);color:#fff}.btn.ghost{color:var(--ink);background:#f1f0f7}.btn.line{border:1px solid var(--line);color:var(--ink);background:#fff}.btn-row{gap:9px;display:flex}.field{border:1.5px solid var(--line);border-radius:12px;outline:none;width:100%;margin-bottom:10px;padding:12px 13px;font-size:15px}.field:focus{border-color:var(--accent)}.addrow{gap:8px;display:flex}.addrow .field{margin-bottom:0}.version{text-align:center;color:var(--faint);margin:6px 0 2px;font-size:11px;font-weight:700}.nav{height:calc(60px + var(--safe-b));padding-bottom:var(--safe-b);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);background:#fffffff0;align-items:stretch;display:flex}.nav button{color:var(--faint);cursor:pointer;background:0 0;border:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:11px;font-weight:800;display:flex}.nav button .ni{filter:grayscale()opacity(.6);font-size:20px;line-height:1}.nav button.on{color:var(--accent)}.nav button.on .ni{filter:none}.fabwrap{left:50%;bottom:calc(70px + var(--safe-b));z-index:30;flex-direction:column;align-items:center;gap:11px;display:flex;position:absolute;transform:translate(-50%)}.speed{pointer-events:none;flex-direction:column;align-items:center;gap:10px;display:flex}.sd{color:#fff;cursor:pointer;box-shadow:var(--shadow-md);opacity:0;border:0;border-radius:99px;align-items:center;gap:9px;padding:10px 16px 10px 12px;font-size:13.5px;font-weight:800;transition:all .2s;display:flex;transform:translateY(16px)scale(.9)}.sd .ic{background:#ffffff40;border-radius:50%;justify-content:center;align-items:center;width:23px;height:23px;font-size:13px;display:flex}.sd.todo{background:linear-gradient(135deg,var(--accent),var(--accent2))}.sd.routine{background:linear-gradient(135deg,var(--routine),#4fb6d8)}.fabwrap.open .speed{pointer-events:auto}.fabwrap.open .sd{opacity:1;transform:none}.fabwrap.open .sd.todo{transition-delay:40ms}.fab{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;width:58px;height:58px;box-shadow:var(--shadow-lg);cursor:pointer;border:0;border-radius:50%;justify-content:center;align-items:center;font-size:30px;font-weight:300;transition:all .24s;display:flex}.fabwrap.open .fab{background:#2a2a3a;transform:rotate(135deg)}.fab-scrim{opacity:0;pointer-events:none;z-index:29;background:#1412284d;transition:all .24s;position:absolute;inset:0}.fab-scrim.on{opacity:1;pointer-events:auto}.overlay{opacity:0;pointer-events:none;z-index:40;background:#14122870;align-items:flex-end;transition:all .24s;display:flex;position:absolute;inset:0}.overlay.open{opacity:1;pointer-events:auto}.sheet{width:100%;padding:18px 18px calc(20px + var(--safe-b));background:#fff;border-radius:24px 24px 0 0;max-height:88%;transition:transform .28s cubic-bezier(.2,.9,.3,1);overflow-y:auto;transform:translateY(100%)}.overlay.open .sheet{transform:none}.grip{background:#dbdbe6;border-radius:99px;width:42px;height:4px;margin:0 auto 15px}.sheet h3{margin:0 0 3px;font-size:17px;font-weight:800}.sheet .sub{color:var(--muted);margin:0 0 15px;font-size:12.5px}.flabel{color:var(--muted);margin:12px 2px 8px;font-size:11.5px;font-weight:800}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--line);color:var(--muted);cursor:pointer;background:#faf9ff;border-radius:99px;padding:8px 14px;font-size:12.5px;font-weight:800}.chip.on{background:var(--accent-soft);color:var(--accent-ink);border-color:#cfc9f5}.chip.r.on{color:var(--routine-ink);background:#d6ecf6;border-color:#a9d8e8}.qhint{color:var(--muted);text-align:center;margin-top:12px;font-size:11.5px;line-height:1.5}.startbtn{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:13px;width:100%;margin-top:15px;padding:15px;font-size:15px;font-weight:800}.startbtn:disabled{opacity:.45}.startbtn.r{background:var(--routine)}.ritual-step{border:1px solid var(--line);border-radius:14px;margin-bottom:10px;padding:13px 14px}.ritual-step .rs-t{align-items:center;gap:7px;margin-bottom:5px;font-size:13px;font-weight:800;display:flex}.ritual-step .rs-d{color:#4a4a58;font-size:12.5px;line-height:1.55}.roll-item{align-items:center;gap:8px;margin-top:9px;display:flex}.roll-item .rt{flex:1;font-size:13px;font-weight:700}.roll-actions{gap:6px;display:flex}.roll-actions button{border:1px solid var(--line);cursor:pointer;color:var(--ink);background:#faf9ff;border-radius:9px;padding:6px 10px;font-size:11.5px;font-weight:800}.roll-actions button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.sheet-actions{flex-direction:column;gap:9px;margin-top:4px;display:flex}.sheet-actions button{border:1px solid var(--line);cursor:pointer;text-align:left;color:var(--ink);background:#fff;border-radius:12px;padding:13px;font-size:14px;font-weight:800}.sheet-actions button.danger{color:var(--rose)}@media (width>=600px){body{background:radial-gradient(1100px 560px at 12% -6%,#efe9ff,#0000 60%),radial-gradient(900px 560px at 106% 110%,#e3ecfb,#0000 55%),#e9e8f2;min-height:100dvh}.app{max-width:560px;height:100%;margin:0 auto;box-shadow:0 0 0 1px #3c326e0d,0 10px 40px #281e5a14}}@media (width>=700px) and (pointer:coarse){.app{max-width:600px}}@media (width>=600px) and (pointer:fine){body{background:radial-gradient(1100px 520px at 12% -6%,#efe9ff,#0000 60%),radial-gradient(900px 540px at 106% 110%,#e3ecfb,#0000 55%),#e6e5ef}#root{justify-content:center;align-items:center;padding:28px 16px;display:flex}.app{border:1px solid #ffffffa6;border-radius:42px;width:410px;max-width:410px;height:min(900px,100vh - 56px);margin:0;box-shadow:0 34px 90px #261c5647,0 6px 18px #261c561f}}@media (hover:hover){.task:hover{border-color:#dcd8ee}.nav button:hover{color:var(--accent)}.now-actions button:hover,.startbtn:hover,.btn:hover{filter:brightness(1.03)}}
