.phone-shell{min-height:100dvh}.phone-screen{position:relative;overflow:hidden;height:100dvh;background:var(--bg-page);display:flex;flex-direction:column}.phone-notch{display:none}@media(min-width:521px){.phone-shell{display:flex;align-items:center;justify-content:center;padding:24px;background:#ecebe8}.phone-screen{width:390px;height:min(780px,calc(100dvh - 48px));border:10px solid #1f1e1c;border-radius:40px;box-shadow:0 24px 60px #1f1e1c38}.phone-notch{display:block;position:absolute;top:10px;left:50%;transform:translate(-50%);width:106px;height:22px;background:#1f1e1c;border-radius:12px;z-index:5}}.app{flex:1;overflow-y:auto;padding:32px 16px 28px}.app,.habit-form{scrollbar-width:thin;scrollbar-color:rgba(31,30,28,.18) transparent}.app::-webkit-scrollbar,.habit-form::-webkit-scrollbar{width:5px}.app::-webkit-scrollbar-track,.habit-form::-webkit-scrollbar-track{background:transparent}.app::-webkit-scrollbar-thumb,.habit-form::-webkit-scrollbar-thumb{background:#1f1e1c2e;border-radius:999px}.app::-webkit-scrollbar-thumb:hover,.habit-form::-webkit-scrollbar-thumb:hover{background:#1f1e1c52}@media(min-width:521px){.app{padding-top:52px}}.day-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px}.day-title{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:1px;min-width:0;padding:0 0 0 4px;border:none;background:none;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.day-date-row{display:flex;align-items:center;gap:4px;max-width:100%}.day-caret{flex-shrink:0;color:var(--text-muted)}.day-label{font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted)}.day-label.today{color:var(--accent-dark)}.day-date{font-size:21px;font-weight:800;color:var(--text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.streak-badge{flex-shrink:0;display:flex;align-items:center;gap:6px;padding:0 4px;font-size:17px;font-weight:800;color:var(--text-muted);transition:color .2s ease,transform .2s ease}.streak-fire{display:block;transform-origin:50% 80%}.streak-badge.lit .streak-fire{animation:fire-settle .46s cubic-bezier(.2,.8,.2,1) both}@keyframes fire-settle{0%{opacity:.72;transform:translateY(3px) scale(.86)}58%{opacity:1;transform:translateY(-2px) scale(1.08)}to{opacity:1;transform:translateY(0) scale(1)}}.streak-badge.lit{color:var(--accent)}.day-arrow{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent}.day-arrow:disabled{opacity:.35;cursor:default}.day-arrow:not(:disabled):active{transform:translateY(1px)}.paper{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:18px;box-shadow:0 10px 28px #1f1e1c0f;padding:16px 16px 24px;min-height:340px;display:flex;flex-direction:column}.add-form{display:flex;gap:8px;margin:2px 0 22px}.free-limit-note{display:block;width:100%;margin:-14px 0 18px;padding:10px 12px;font:inherit;font-size:13px;line-height:1.4;text-align:left;color:var(--accent-dark);background:#58cc0214;border:1px dashed rgba(88,204,2,.4);border-radius:12px;cursor:pointer;-webkit-tap-highlight-color:transparent}.add-input{flex:1;min-width:0;padding:12px 14px;font-size:15px;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:12px;outline:none;transition:border-color .15s}.add-input:focus{border-color:var(--accent)}.add-input::placeholder{color:var(--text-muted)}.add-button{min-height:44px;padding:0 18px;font-size:15px;font-weight:700;color:#fff;background:var(--accent);border:none;border-radius:12px;box-shadow:0 4px 0 var(--accent-dark);cursor:pointer;transition:transform .05s,box-shadow .05s}.add-button:active{transform:translateY(4px);box-shadow:0 0 0 var(--accent-dark)}.plus-button{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:#fff;background:var(--accent);border:none;border-radius:14px;box-shadow:0 4px 0 var(--accent-dark);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .05s,box-shadow .05s}.plus-button:active{transform:translateY(4px);box-shadow:0 0 0 var(--accent-dark)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;color:var(--text-muted);font-size:14px;padding:24px 0}.empty-state p{margin:0}.empty-mascot-wrap{width:54%;max-width:190px;animation:empty-mascot-in .42s cubic-bezier(.2,.85,.25,1.2) both}.empty-mascot{display:block;width:100%;filter:drop-shadow(0 12px 18px rgba(31,30,28,.1));transform-origin:52% 88%;animation:empty-mascot-idle 3.4s ease-in-out .45s infinite}@keyframes empty-mascot-in{0%{opacity:0;transform:translate(14px) translateY(8px) rotate(3deg) scale(.92)}to{opacity:1;transform:translate(0) translateY(0) rotate(0) scale(1)}}@keyframes empty-mascot-idle{0%,to{transform:translateY(0) rotate(0) scale(1)}18%{transform:translateY(-2px) rotate(-1.8deg) scale(1.01)}34%{transform:translateY(0) rotate(1.2deg) scale(.995)}55%{transform:translateY(-4px) rotate(0) scale(1.012)}}.task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.task-item{display:flex;align-items:center;gap:12px;min-height:50px;padding:8px 2px;border-bottom:1px solid var(--border)}.task-item:last-child{border-bottom:none}.task-text-wrap{flex:1;min-width:0;position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.task-text{display:inline-block;max-width:100%;font-size:15px;transition:color .25s ease}.task-item.done .task-text{color:var(--text-muted)}.delete-button{flex-shrink:0;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-muted);width:40px;min-height:44px;padding:0;border-radius:10px;cursor:pointer;opacity:.55;transition:opacity .15s,color .15s;-webkit-tap-highlight-color:transparent}.task-item:hover .delete-button,.delete-button:focus-visible{opacity:1}.delete-button:hover{color:var(--danger)}.strike-overlay{position:absolute;left:0;top:0;height:100%;width:var(--strike-width);pointer-events:none}.strike-line{position:absolute;left:-3px;top:0;width:calc(100% + 6px);height:100%;overflow:visible}.strike-line path{fill:none;stroke:var(--accent);stroke-width:5;stroke-linecap:round;opacity:.9;stroke-dasharray:1 3;stroke-dashoffset:0}.strike-overlay.striking .strike-line path{animation:line-draw 1.4s linear both}@keyframes line-draw{0%,32%{stroke-dashoffset:1.02}68%,to{stroke-dashoffset:0}}.strike-hand{position:absolute;left:-3px;top:50%;width:0;height:0;z-index:2;will-change:transform;animation:hand-strike 1.4s both}.strike-hand svg{position:absolute;overflow:visible;width:208px;height:160px;left:-16px;top:-144px}@keyframes hand-strike{0%{transform:translate(var(--enter-x),calc(var(--enter-x) * .35)) rotate(-6deg);animation-timing-function:cubic-bezier(.16,.8,.35,1)}32%{transform:translateY(3px) rotate(-3deg);animation-timing-function:linear}44%{transform:translate(calc(var(--strike-width) * .34),-2px) rotate(2deg);animation-timing-function:linear}56%{transform:translate(calc(var(--strike-width) * .67),2px) rotate(-2deg);animation-timing-function:linear}68%{transform:translate(var(--strike-width)) rotate(0);animation-timing-function:cubic-bezier(.55,0,.85,.4)}to{transform:translate(calc(var(--enter-x) + var(--strike-width)),calc(var(--enter-x) * .35)) rotate(-4deg)}}.checkbox{flex-shrink:0;width:28px;height:28px;padding:0;border:none;background:none;cursor:pointer;border-radius:8px;-webkit-tap-highlight-color:transparent}.checkbox:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.checkbox svg{display:block;width:100%;height:100%}.checkbox-box{fill:var(--bg);stroke:#c9c8c6;stroke-width:2;transition:fill .15s ease,stroke .15s ease}.checkbox.checked .checkbox-box{fill:var(--accent);stroke:var(--accent)}.checkbox-mark{fill:none;stroke:#fff;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1;stroke-dashoffset:1}.checkbox.checked .checkbox-mark{animation:draw-check .16s ease-out forwards}@keyframes draw-check{to{stroke-dashoffset:0}}.stamp{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;pointer-events:none;z-index:3}.stamp-mascot{width:42%;max-width:148px;margin-bottom:-6px;filter:drop-shadow(0 14px 18px rgba(31,30,28,.12));transform-origin:50% 92%}.paper.slamming .stamp-mascot{animation:win-mascot-pop 1.35s linear both}@keyframes win-mascot-pop{0%,38%{opacity:0;transform:translateY(18px) scale(.78) rotate(-2deg)}48%{opacity:1;transform:translateY(-8px) scale(1.08) rotate(2deg)}62%{transform:translateY(3px) scale(.97) rotate(-1deg)}78%{transform:translateY(-2px) scale(1.02) rotate(.6deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}.stamp-mark{display:flex;flex-direction:column;align-items:center;transform:rotate(-12deg);color:#d8453a;border:4px solid #d8453a;outline:2px solid #d8453a;outline-offset:-12px;border-radius:12px;padding:12px 26px 14px;opacity:.92}.stamp-word{font-size:38px;font-weight:800;letter-spacing:5px;line-height:1.05}.stamp-streak{font-size:13px;font-weight:800;letter-spacing:3px;margin-top:3px}.paper.slamming .stamp-mark{animation:mark-appear 1.2s linear both}@keyframes mark-appear{0%,39%{opacity:0;transform:rotate(-12deg) scale(1.06)}46%{opacity:.92;transform:rotate(-12deg) scale(.97)}58%{transform:rotate(-11.5deg) scale(1.01)}to{opacity:.92;transform:rotate(-12deg) scale(1)}}.stamp-tool{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:4}.stamp-tool svg{width:248px;height:114px;animation:stamp-press 1.2s both}@keyframes stamp-press{0%{opacity:0;transform:rotate(-12deg) scale(1.7);filter:drop-shadow(0 26px 28px rgba(31,30,28,0));animation-timing-function:ease-out}25%{opacity:1;transform:rotate(-12deg) scale(1.55);filter:drop-shadow(0 22px 24px rgba(31,30,28,.32));animation-timing-function:cubic-bezier(.55,0,.8,.4)}40%{transform:rotate(-12deg) scale(1);filter:drop-shadow(0 2px 3px rgba(31,30,28,.35));animation-timing-function:ease-out}55%{transform:rotate(-12deg) scale(1);filter:drop-shadow(0 2px 3px rgba(31,30,28,.35));animation-timing-function:ease-in-out}78%{opacity:1;transform:rotate(-12deg) scale(1.42);filter:drop-shadow(0 18px 22px rgba(31,30,28,.28))}to{opacity:0;transform:rotate(-12deg) scale(1.7);filter:drop-shadow(0 26px 28px rgba(31,30,28,0))}}.paper.slamming{animation:paper-squash .45s ease-out .44s}@keyframes paper-squash{0%{transform:scale(1)}35%{transform:scale(.965) translateY(2px)}70%{transform:scale(1.012)}to{transform:scale(1)}}.phone-screen:has(.paper.slamming){animation:screen-bounce .5s ease-out .44s}@keyframes screen-bounce{0%{transform:translateY(0)}30%{transform:translateY(6px) scale(.996)}65%{transform:translateY(-2px)}to{transform:translateY(0)}}.tab-bar{flex-shrink:0;display:flex;background:var(--bg);border-top:1px solid var(--border);padding:6px 8px calc(6px + env(safe-area-inset-bottom))}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0 4px;border:none;background:none;color:var(--text-muted);font-size:11px;font-weight:700;cursor:pointer;border-radius:12px;-webkit-tap-highlight-color:transparent;transition:color .15s}.tab.active{color:var(--accent-dark)}.tab:active{transform:translateY(1px)}.page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.page-title{font-size:22px;font-weight:800;margin:0}.profile-page .page-title{margin-bottom:14px}.view-toggle{display:flex;gap:4px;padding:4px;background:#1f1e1c0f;border-radius:12px;margin-bottom:16px}.view-toggle button{flex:1;padding:8px 0;border:none;border-radius:9px;background:none;color:var(--text-muted);font-size:13px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}.view-toggle button.active{background:var(--bg);color:var(--text);box-shadow:0 1px 3px #1f1e1c1f}.habit-list{display:flex;flex-direction:column;gap:14px}.habit-card{background:var(--bg);border:1px solid var(--border);border-radius:18px;box-shadow:0 10px 28px #1f1e1c0f;padding:14px}.habit-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.habit-info{flex:1;min-width:0;display:flex;align-items:center;gap:12px;padding:0;border:none;background:none;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.habit-chip{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:13px}.habit-titles{min-width:0;display:flex;flex-direction:column;gap:1px}.habit-name{font-size:16px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-desc{font-size:12.5px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-check{flex-shrink:0;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border:none;border-radius:14px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s}.habit-check:active{transform:scale(.94)}.habit-check.popping{animation:habit-pop .45s ease-out}@keyframes habit-pop{0%{transform:scale(1)}40%{transform:scale(1.22) rotate(4deg)}70%{transform:scale(.94)}to{transform:scale(1)}}.habit-grid-scroll{overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(31,30,28,.18) transparent}.habit-grid-scroll::-webkit-scrollbar{height:4px}.habit-grid-scroll::-webkit-scrollbar-track{background:transparent}.habit-grid-scroll::-webkit-scrollbar-thumb{background:#1f1e1c2e;border-radius:999px}.habit-grid{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,1fr);grid-template-columns:repeat(var(--weeks, 26),1fr);gap:3px;min-width:calc(var(--weeks, 26) * 12.5px)}.grid-cell{aspect-ratio:1;border-radius:2.5px;background:#1f1e1c14}.grid-cell.future{background:transparent}.habit-week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.week-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;border-radius:10px;background:#1f1e1c14;color:var(--text-muted);font-size:12px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s}.week-cell:not(:disabled):active{transform:scale(.92)}.week-cell:disabled{opacity:.35;cursor:default}.modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;display:flex;align-items:flex-end;background:#1f1e1c66;animation:overlay-in .2s ease-out}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.habit-form{width:100%;max-height:88%;overflow-y:auto;background:var(--bg);border-radius:24px 24px 0 0;padding:20px 18px calc(20px + env(safe-area-inset-bottom));animation:sheet-up .25s ease-out}@keyframes sheet-up{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.habit-form h2{margin:0 0 14px;font-size:18px;font-weight:800}.form-label{display:block;margin:14px 0 6px;font-size:12.5px;font-weight:700;color:var(--text-muted)}.habit-form .add-input{width:100%;box-sizing:border-box}.icon-picker{display:grid;grid-template-columns:repeat(8,1fr);gap:6px}.icon-option{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;border-radius:10px;background:#1f1e1c0f;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-option{width:34px;height:34px;border:none;border-radius:50%;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s}.color-option.selected{outline:3px solid var(--text);outline-offset:2px;transform:scale(1.05)}.form-actions{display:flex;align-items:center;gap:8px;margin-top:20px}.form-actions .add-button{flex:1}.form-actions .add-button:disabled{opacity:.5;cursor:default}.ghost-button{min-height:44px;padding:0 16px;border:1px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:15px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}.delete-habit-button{min-height:44px;padding:0 14px;border:none;border-radius:12px;background:#e55b5b1f;color:var(--danger);font-size:14px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}.calendar-panel{width:100%;background:var(--bg);border-radius:24px 24px 0 0;padding:18px 18px calc(22px + env(safe-area-inset-bottom));animation:sheet-up .25s ease-out}.calendar-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}.calendar-title{flex:1;margin:0;text-align:center;font-size:16px;font-weight:800;text-transform:capitalize}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px;font-size:11px;font-weight:700;color:var(--text-muted);text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;border-radius:12px;background:none;font-size:14px;font-weight:700;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent}.cal-cell:disabled{opacity:.3;cursor:default}.cal-cell.today{box-shadow:inset 0 0 0 2px var(--accent)}.cal-cell.active{background:var(--accent);color:#fff}.cal-dot{width:5px;height:5px;border-radius:50%;background:transparent}.cal-dot.filled{background:#1f1e1c47}.cal-dot.stamped{background:var(--accent)}.cal-cell.active .cal-dot.filled,.cal-cell.active .cal-dot.stamped{background:#fff}.login-page{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 28px;text-align:center}.login-mascot-wrap{width:46%;max-width:176px;margin-bottom:4px;animation:empty-mascot-in .42s cubic-bezier(.2,.85,.25,1.2) both}.login-mascot{display:block;width:100%;filter:drop-shadow(0 12px 24px rgba(31,30,28,.12));transform-origin:52% 88%;animation:empty-mascot-idle 3.4s ease-in-out .45s infinite}.google-button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;max-width:300px;min-height:50px;margin-top:28px;padding:0 20px;font-size:15px;font-weight:700;color:var(--text);background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 3px #1f1e1c1f;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .05s,box-shadow .05s}.google-button:active{transform:translateY(3px);box-shadow:0 0 #1f1e1c1f}.webview-note{margin-top:28px;padding:14px 16px;border-radius:14px;background:#f490001f;color:var(--text);font-size:13.5px;line-height:1.5}.webview-note p{margin:0}.login-footnote{margin:14px 0 0;font-size:12px;color:var(--text-muted)}.paywall-sub{margin:-6px 0 14px;font-size:13.5px;color:var(--text-muted)}.plan-list{display:flex;flex-direction:column;gap:10px}.plan-card{display:flex;flex-direction:column;gap:2px;padding:14px 16px;text-align:left;background:var(--bg);border:2px solid var(--border);border-radius:16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .15s,background .15s}.plan-card.selected{border-color:var(--accent);background:#58cc0212}.plan-label{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--text)}.plan-tag{font-size:10.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#fff;background:var(--accent);padding:2px 8px;border-radius:999px}.plan-price{font-size:20px;font-weight:800;color:var(--text)}.plan-permonth{font-size:12px;color:var(--text-muted)}.paywall-error{margin:10px 0 0;font-size:13px;color:var(--danger)}.premium-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:#faf9f7f0;cursor:pointer}.premium-mark{animation:mark-appear 1.2s linear both}.premium-note{margin:0;font-size:13.5px;font-weight:600;color:var(--text-muted)}.avatar-photo{object-fit:cover;border:none}.account-card{display:flex;align-items:center;gap:14px;background:var(--bg);border:1px solid var(--border);border-radius:18px;box-shadow:0 10px 28px #1f1e1c0f;padding:16px;margin-bottom:14px}.avatar{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent);color:#fff;font-size:24px;font-weight:800}.account-info{min-width:0}.account-name{margin:0;font-size:16px;font-weight:800}.account-email{margin:1px 0 6px;font-size:13px;color:var(--text-muted)}.google-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:#3b53b5;background:#4a66d81f;padding:3px 9px;border-radius:999px}.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}.stat{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:12px 8px}.stat-value{font-size:22px;font-weight:800;color:var(--accent-dark)}.stat-label{font-size:11.5px;color:var(--text-muted);text-align:center}.premium-card{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#4a66d8,#3b53b5);border-radius:18px;padding:16px;margin-bottom:14px;color:#fff}.premium-text{flex:1;min-width:0}.premium-title{margin:0;font-size:15px;font-weight:800}.premium-desc{margin:3px 0 0;font-size:12.5px;opacity:.85}.premium-button{flex-shrink:0;min-height:42px;padding:0 16px;border:none;border-radius:12px;background:#f49000;color:#fff;font-size:14px;font-weight:800;box-shadow:0 4px #c67400;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .05s,box-shadow .05s}.premium-button:active{transform:translateY(4px);box-shadow:0 0 #c67400}.backup-card{background:var(--bg);border:1px solid var(--border);border-radius:18px;padding:16px;margin-bottom:14px}.backup-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.backup-confirm{display:flex;flex-direction:column;gap:8px;width:100%;font-size:13px;color:var(--text-muted)}.backup-confirm-buttons{display:flex;gap:10px}.backup-status{margin:10px 0 0;font-size:12.5px}.backup-status.ok{color:var(--accent-dark)}.backup-status.err{color:var(--danger)}.backup-status.info{color:var(--text-muted)}.settings-list{background:var(--bg);border:1px solid var(--border);border-radius:18px;padding:4px 16px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:52px;border-bottom:1px solid var(--border);font-size:15px;color:var(--text)}.setting-row:last-child{border-bottom:none}.setting-value{font-size:14px;color:var(--text-muted)}.setting-action{width:100%;border-left:none;border-right:none;border-top:none;background:none;padding:0;font-weight:700;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.setting-action.danger{color:var(--danger)}.time-input{border:1px solid var(--border);border-radius:10px;padding:6px 10px;font:inherit;font-size:14px;font-weight:700;color:var(--text);background:var(--bg);outline:none}.time-input:focus{border-color:var(--accent)}.switch{flex-shrink:0;position:relative;width:48px;height:28px;border:none;border-radius:999px;background:#1f1e1c2e;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s}.switch.on{background:var(--accent)}.switch-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #1f1e1c40;transition:transform .18s}.switch.on .switch-knob{transform:translate(20px)}.splash{position:absolute;top:0;right:0;bottom:0;left:0;z-index:9;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-page)}.splash.leaving{animation:splash-out .35s ease-in both}@keyframes splash-out{to{opacity:0}}.splash-cat{width:46%;max-width:176px;animation:empty-mascot-in .42s cubic-bezier(.2,.85,.25,1.2) both}.splash-cat img{display:block;width:100%;filter:drop-shadow(0 12px 24px rgba(31,30,28,.12));transform-origin:52% 88%;animation:empty-mascot-idle 3.4s ease-in-out .45s infinite}.splash-greeting{margin:22px 0 0;font-size:25px;font-weight:800;color:var(--text);animation:splash-up .4s ease-out .45s both}.splash-wordmark{margin:22px 0 0;font-size:27px;font-weight:800;letter-spacing:.5px;color:var(--text);animation:splash-up .4s ease-out .45s both}.splash-wordmark span{color:var(--accent)}.splash-tagline{margin:6px 0 0;font-size:13px;color:var(--text-muted);animation:splash-up .4s ease-out .62s both}@keyframes splash-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.splash-cat,.splash-wordmark,.splash-greeting,.splash-tagline{animation:none;opacity:1;transform:none}.splash-cat img,.login-mascot-wrap,.login-mascot{animation:none}}@media(prefers-reduced-motion:reduce){.strike-hand{display:none}.paper.slamming .stamp-mark,.stamp-mascot,.empty-mascot-wrap,.empty-mascot,.paper.slamming,.phone-screen:has(.paper.slamming){animation:none}.stamp-tool{display:none}.strike-overlay.striking .strike-line path{animation:none;stroke-dashoffset:0}.checkbox.checked .checkbox-mark{animation:none;stroke-dashoffset:0}.habit-check.popping,.modal-overlay,.habit-form{animation:none}}.add-button,.plus-button,.day-arrow,.tab,.plan-card,.setting-row,.habit-info,.habit-check{transition-duration:.18s;transition-timing-function:ease}.add-button,.plus-button,.premium-button{transition-property:transform,box-shadow,opacity}.day-arrow,.plan-card,.setting-row,.habit-card,.paper,.account-card,.premium-card{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.day-arrow:not(:disabled):active,.plan-card:active,.setting-action:active,.habit-info:active{transform:translateY(1px) scale(.985)}.tab svg{transition:transform .18s ease}.tab.active svg{transform:translateY(-2px) scale(1.04)}@media(prefers-reduced-motion:reduce){.streak-badge.lit .streak-fire,.empty-mascot-wrap,.empty-mascot,.stamp-mascot{animation:none;opacity:1;transform:none}}:root{--text: #37352f;--text-muted: #9b9a97;--border: #e3e2e0;--bg: #ffffff;--bg-page: #f7f7f5;--accent: #58cc02;--accent-dark: #46a302;--danger: #e55b5b}*{box-sizing:border-box}body{margin:0;font-family:ui-sans-serif,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg-page);-webkit-font-smoothing:antialiased}button{font-family:inherit}
