:root{--bg:#0a0b0f;--panel:#0f1117;--card:#13161f;--line:#23272f;--line2:#30343f;--ink:#f4f6fb;--sub:#7b8194;--accent:#3d7bff;--accent2:#73a0ff;--gold:#ffb43d;--done:#22c07a;--danger:#ff5468;--mono:ui-monospace,"SF Mono","Roboto Mono",Menlo,monospace}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body{height:100%}body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}#app{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;position:relative;background:var(--bg)}header{padding:calc(env(safe-area-inset-top) + 22px) 22px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line)}.logo{font-size:26px;font-weight:900;letter-spacing:.04em;line-height:1}.logo small{color:var(--accent);font-weight:900;margin-left:1px}.date{font-family:var(--mono);font-size:11px;color:var(--sub);letter-spacing:.1em;text-transform:uppercase;font-weight:600}nav{display:flex;gap:0;padding:0 16px;border-bottom:1px solid var(--line)}nav button{flex:1;background:transparent;border:none;color:var(--sub);font-size:12.5px;font-weight:800;padding:16px 0 14px;border-radius:0;letter-spacing:0;font-family:inherit;position:relative;cursor:pointer;transition:color .2s;white-space:nowrap}nav button:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent);transform:scaleX(0);transition:transform .25s cubic-bezier(.2,.8,.2,1)}nav button.on{color:var(--ink)}nav button.on:after{transform:scaleX(1)}main{flex:1;padding:20px 22px 120px}.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.34em;color:var(--sub);font-weight:600;text-transform:uppercase}.kicker.accent{color:var(--accent2);margin-bottom:16px}.focus-wrap{display:flex;flex-direction:column;align-items:stretch;justify-content:center;min-height:64vh}.focus-card{width:100%;position:relative;border-radius:20px;padding:30px 26px 26px;background:linear-gradient(180deg,var(--card),var(--panel));border:1px solid var(--line2);box-shadow:0 24px 60px -34px #000000e6;animation:rise .4s cubic-bezier(.2,.8,.2,1) both}.focus-card+.focus-card{margin-top:14px}.focus-card:before{content:"";position:absolute;left:0;top:22px;bottom:22px;width:4px;border-radius:4px;background:var(--accent);box-shadow:0 0 16px #3d7bff99}.focus-card.card-routine:before{background:var(--gold);box-shadow:0 0 16px #ffb43d8c}.focus-card.card-task:before{background:var(--accent);box-shadow:0 0 16px #3d7bff99}.focus-tag{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.18em;padding:5px 10px;border-radius:6px;margin-bottom:18px;text-transform:uppercase}.tag-routine{background:#ffb43d1f;color:var(--gold);box-shadow:inset 0 0 0 1px #ffb43d4d}.tag-task{background:#3d7bff24;color:var(--accent2);box-shadow:inset 0 0 0 1px #3d7bff52}.focus-text{font-size:32px;font-weight:900;line-height:1.3;letter-spacing:-.01em;word-break:break-word}.focus-meta{margin-top:16px;font-family:var(--mono);font-size:12px;color:var(--sub);letter-spacing:.06em;font-weight:600}.focus-meta b{color:var(--gold);font-size:16px;font-weight:900;font-family:inherit}.done-btn{margin-top:28px;width:100%;border:none;font-family:inherit;cursor:pointer;position:relative;background:var(--accent);color:#fff;font-size:16px;font-weight:900;letter-spacing:.12em;padding:18px;border-radius:12px;transition:transform .1s,background .2s;box-shadow:0 12px 28px -12px #3d7bffe6}.done-btn:after{content:" →";font-weight:900}.done-btn:hover{background:var(--accent2)}.done-btn:active{transform:translateY(2px) scale(.99);box-shadow:0 4px 14px -10px #3d7bffe6}.skip-btn{margin-top:14px;width:100%;background:none;border:none;color:var(--sub);font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:8px;cursor:pointer;transition:color .2s}.skip-btn:hover{color:var(--ink)}.allclear{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:20px 10px;animation:rise .4s ease both}.allclear .mark{width:74px;height:74px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:38px;font-weight:300;color:var(--accent);margin-bottom:6px;border:1px solid var(--line2);background:var(--card);box-shadow:0 0 40px -10px #3d7bff80,inset 0 0 0 1px #3d7bff1f}.allclear .kicker{margin-bottom:2px}.allclear h2{font-size:26px;font-weight:900;letter-spacing:-.01em}.allclear p{color:var(--sub);font-size:14px;line-height:1.8}.progress-row{display:flex;align-items:center;gap:14px;width:100%;margin-top:26px}.bar{flex:1;height:4px;background:var(--line);border-radius:4px;overflow:hidden}.bar i{display:block;height:100%;background:var(--accent);border-radius:4px;transition:width .6s cubic-bezier(.2,.8,.2,1);box-shadow:0 0 10px #3d7bffb3}.progress-row span{font-family:var(--mono);font-size:12px;color:var(--ink);font-weight:700;letter-spacing:.04em;font-variant-numeric:tabular-nums}.sec-title{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--sub);font-weight:600;margin:26px 2px 12px;text-transform:uppercase}.sec-title:first-child{margin-top:4px}.row{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px 16px;margin-bottom:8px;transition:transform .14s,border-color .2s;animation:fadeUp .3s ease both}.row:active{transform:scale(.99)}.row:hover{border-color:var(--line2)}.row.is-done{opacity:.4}.check{width:26px;height:26px;border-radius:8px;border:2px solid var(--line2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff;transition:.18s cubic-bezier(.2,.9,.25,1.1);cursor:pointer}.check.on{background:var(--done);border-color:var(--done);box-shadow:0 0 14px #22c07a8c}.row .body{flex:1;min-width:0}.row .name{font-size:15px;font-weight:700;line-height:1.4;word-break:break-word}.row.is-done .name{text-decoration:line-through;color:var(--sub)}.row .streak{font-family:var(--mono);font-size:11px;color:var(--gold);font-weight:600;margin-top:4px;letter-spacing:.04em}.row .del{background:none;border:none;color:var(--sub);font-size:20px;padding:4px 8px;font-family:inherit;flex-shrink:0;cursor:pointer;transition:.18s}.row .del:active{color:var(--danger);transform:scale(1.2)}.reorder{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.rmove{background:var(--panel);border:1px solid var(--line2);color:var(--sub);width:30px;height:21px;border-radius:7px;font-size:10px;line-height:1;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}.rmove:hover:not(:disabled){color:var(--ink);border-color:var(--accent)}.rmove:active:not(:disabled){background:var(--accent);color:#fff}.rmove:disabled{opacity:.28;cursor:default}.empty{color:var(--sub);font-size:13px;text-align:center;padding:30px 14px;line-height:1.8;border:1px dashed var(--line2);border-radius:14px}.add-box{display:flex;gap:8px;margin-bottom:12px}.add-box input{flex:1;background:var(--panel);border:1px solid var(--line2);border-radius:12px;color:var(--ink);font-size:15px;padding:15px 16px;font-family:inherit;transition:.18s}.add-box input::placeholder{color:var(--sub)}.add-box input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3d7bff29}.add-box button{background:var(--accent);border:none;color:#fff;font-size:24px;font-weight:700;width:54px;border-radius:12px;font-family:inherit;flex-shrink:0;cursor:pointer;transition:transform .1s,background .2s}.add-box button:hover{background:var(--accent2)}.add-box button:active{transform:scale(.93)}.seg{display:flex;gap:8px;margin-bottom:12px}.seg button{flex:1;background:var(--panel);border:1px solid var(--line2);color:var(--sub);font-size:12px;font-weight:800;padding:12px 0;border-radius:10px;font-family:inherit;letter-spacing:.03em;cursor:pointer;transition:.16s}.seg button.on{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 20px -12px #3d7bffe6}.hint{font-size:11px;color:var(--sub);margin:-4px 2px 14px;line-height:1.7}.toast{position:fixed;left:50%;bottom:34px;transform:translate(-50%) translateY(20px);background:var(--done);color:#04150d;font-size:13px;font-weight:900;letter-spacing:.04em;padding:13px 24px;border-radius:12px;opacity:0;pointer-events:none;transition:.3s cubic-bezier(.2,.9,.25,1.1);z-index:50;white-space:nowrap;box-shadow:0 16px 40px -14px #22c07acc}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.burst{position:fixed;left:50%;top:44%;z-index:60;pointer-events:none}.burst i{position:absolute;left:0;top:0;width:8px;height:8px;border-radius:2px;animation:pop .8s cubic-bezier(.15,.7,.3,1) forwards}@keyframes pop{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(.2) rotate(200deg);opacity:0}}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.cal-nav{display:flex;align-items:center;justify-content:space-between;margin:2px 0 18px;animation:fadeUp .3s ease both}.cal-nav button{width:42px;height:38px;background:var(--card);border:1px solid var(--line2);border-radius:11px;color:var(--ink);font-size:20px;font-family:inherit;cursor:pointer;transition:.15s}.cal-nav button:hover:not(:disabled){border-color:var(--accent)}.cal-nav button:active:not(:disabled){transform:scale(.94)}.cal-nav button:disabled{opacity:.28;cursor:default}.cal-title{font-size:17px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:.02em}.ymaxis{display:flex;gap:4px;margin:0 0 9px}.ymaxis span{flex:1;text-align:center;font-family:var(--mono);font-size:9px;color:var(--sub)}.ymaxis span.now{color:var(--accent);font-weight:800}.ymrow{margin-bottom:15px;animation:fadeUp .3s ease both}.ymhead{display:flex;align-items:center;gap:8px;margin-bottom:6px}.ymhead .sw{width:12px;height:12px;border-radius:4px;flex-shrink:0}.ymn{font-size:14px;font-weight:700;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ympct{font-family:var(--mono);font-size:11px;color:var(--sub);font-weight:600;flex-shrink:0}.ymstrip{display:flex;gap:4px}.ym{flex:1;height:30px;border-radius:6px;background:var(--card);display:inline-block}.ym.off{background:#ffffff08}.ym.miss{background:transparent;box-shadow:inset 0 0 0 1px var(--line2)}.ym.now{outline:1.5px solid var(--accent);outline-offset:1px}.yr-leg{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;color:var(--sub);margin-top:10px}.yr-leg span{display:flex;align-items:center;gap:6px}.yr-leg .ym{flex:none;width:14px;height:14px;border-radius:4px}.yr-leg .ym.miss{box-shadow:inset 0 0 0 1px var(--line2)}.day{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:13px 14px;margin-bottom:8px;animation:fadeUp .3s ease both}.day-head{display:flex;align-items:baseline;gap:8px;margin-bottom:9px}.day-head b{font-size:15px;font-weight:900}.day-head>span{font-family:var(--mono);font-size:11px;color:var(--sub)}.day-head em{font-style:normal;font-size:9px;font-weight:800;color:#fff;background:var(--accent);padding:2px 7px;border-radius:6px;letter-spacing:.04em}.day-score{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink);font-weight:700}.day-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{font-size:11px;font-weight:600;padding:5px 9px;border-radius:8px;letter-spacing:.02em}.chip.ok{background:#22c07a24;color:var(--done)}.chip.ng{background:#ff54681a;color:#ff8593}.chip.task{background:#3d7bff24;color:var(--accent2)}.chip.none{background:transparent;color:var(--sub);box-shadow:inset 0 0 0 1px var(--line2)}@media(min-width:600px){body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;background:radial-gradient(60% 50% at 50% 0%,rgba(61,123,255,.1),transparent 70%),#060708;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.5;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:26px 26px;-webkit-mask:radial-gradient(70% 60% at 50% 40%,#000,transparent 80%);mask:radial-gradient(70% 60% at 50% 40%,#000,transparent 80%)}body:after{content:"ONE STRIKE A DAY";position:fixed;left:34px;top:50%;z-index:0;transform:translateY(-50%) rotate(180deg);writing-mode:vertical-rl;font-family:var(--mono);font-size:12px;letter-spacing:.5em;color:#ffffff24;text-transform:uppercase;pointer-events:none}#app{position:relative;z-index:1;width:400px;max-width:400px;min-height:auto;height:840px;max-height:90vh;border-radius:46px;overflow:hidden auto;border:1px solid var(--line2);box-shadow:0 0 0 11px #14151b,0 0 0 12px #2c2f38,0 60px 130px -30px #000000f2;scrollbar-width:none}#app::-webkit-scrollbar{display:none}header{position:sticky;top:0;background:#0a0b0fd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:5}nav{position:sticky;top:69px;background:#0a0b0fd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:5}}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
