:root{--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--r-sm:6px;--r-md:10px;--r-lg:16px;--r-pill:999px;--shadow-sm:0 1px 2px #0f172a0f;--shadow-md:0 6px 20px #0f172a1a;--shadow-lg:0 16px 48px #0f172a29;--ease:cubic-bezier(.2, .8, .2, 1);--p-high:#ef4444;--p-medium:#f59e0b;--p-low:#3b82f6;--p-none:#9ca3af}:root,[data-theme=light]{--bg:#f7f7f5;--bg-elev:#fff;--surface:#fff;--surface-hover:#f1f1ef;--surface-active:#ebebe8;--sidebar-bg:#fbfbfa;--border:#e7e7e4;--border-strong:#d8d8d4;--text:#2f2f2b;--text-soft:#6b6b66;--text-faint:#9a9a93;--accent:#4f46e5;--accent-soft:#eef0ff;--accent-text:#fff;--danger:#dc2626;--success:#16a34a;--overlay:#0f172a52}[data-theme=dark]{--bg:#16161a;--bg-elev:#1d1d22;--surface:#1d1d22;--surface-hover:#26262c;--surface-active:#2e2e35;--sidebar-bg:#141417;--border:#2c2c33;--border-strong:#3a3a42;--text:#ececef;--text-soft:#a9a9b2;--text-faint:#6f6f79;--accent:#7c79ff;--accent-soft:#26263a;--accent-text:#fff;--danger:#f87171;--success:#4ade80;--overlay:#0000008c}@media (prefers-color-scheme:dark){:root:not([data-theme]){--bg:#16161a;--bg-elev:#1d1d22;--surface:#1d1d22;--surface-hover:#26262c;--surface-active:#2e2e35;--sidebar-bg:#141417;--border:#2c2c33;--border-strong:#3a3a42;--text:#ececef;--text-soft:#a9a9b2;--text-faint:#6f6f79;--accent:#7c79ff;--accent-soft:#26263a;--danger:#f87171;--success:#4ade80;--overlay:#0000008c}}*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0}button{cursor:pointer;font-family:inherit}input,textarea{font-family:inherit}::selection{background:var(--accent-soft)}.app{grid-template-columns:264px 1fr;height:100%;display:grid;overflow:hidden}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);flex-direction:column;gap:4px;min-height:0;padding:18px 12px;display:flex}.brand{align-items:center;gap:10px;padding:6px 10px 16px;display:flex}.brand__logo{background:linear-gradient(135deg, var(--accent), #9d7bff);color:#fff;width:28px;height:28px;box-shadow:var(--shadow-sm);border-radius:8px;place-items:center;font-weight:700;display:grid}.brand__name{letter-spacing:-.01em;font-size:16px;font-weight:700}.nav{flex-direction:column;gap:2px;display:flex}.nav__label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);justify-content:space-between;align-items:center;padding:14px 10px 6px;font-size:11px;font-weight:600;display:flex}.nav__add{color:var(--text-faint);border-radius:var(--r-sm);width:22px;height:22px;transition:.15s var(--ease);background:0 0;border:none;place-items:center;display:grid}.nav__add:hover{background:var(--surface-hover);color:var(--text)}.nav-item{width:100%;color:var(--text-soft);border-radius:var(--r-md);text-align:left;transition:.15s var(--ease);background:0 0;border:none;align-items:center;gap:10px;padding:8px 10px;font-size:14px;font-weight:500;display:flex}.nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-item--active{background:var(--accent-soft);color:var(--accent);font-weight:600}.nav-item__icon{flex:none;place-items:center;width:18px;height:18px;display:grid}.nav-item__dot{border-radius:50%;flex:none;width:10px;height:10px}.nav-item__text{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.nav-item__count{color:var(--text-faint);background:var(--surface-hover);border-radius:var(--r-pill);text-align:center;min-width:22px;padding:1px 8px;font-size:12px;font-weight:600}.nav-item--active .nav-item__count{background:color-mix(in srgb, var(--accent) 18%, transparent);color:var(--accent)}.sidebar__footer{margin-top:auto;padding-top:12px}.main{background:var(--bg);flex-direction:column;min-width:0;min-height:0;display:flex}.topbar{align-items:center;gap:12px;padding:20px 32px 8px;display:flex}.topbar__title{letter-spacing:-.02em;margin:0;font-size:26px;font-weight:700}.topbar__subtitle{color:var(--text-soft);margin:2px 0 0;font-size:13px}.topbar__spacer{flex:1}.icon-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-soft);border-radius:var(--r-md);width:38px;height:38px;transition:.15s var(--ease);place-items:center;display:grid}.icon-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border-strong)}.content{flex:1;min-height:0;padding:12px 32px 48px;overflow-y:auto}.content__inner{max-width:720px;margin:0 auto}.quick-add{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:.15s var(--ease);align-items:center;gap:10px;margin:12px 0 18px;padding:10px 12px;display:flex}.quick-add:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.quick-add__plus{color:var(--accent);border-radius:var(--r-sm);transition:.15s var(--ease);background:0 0;border:none;flex:none;place-items:center;padding:0;display:grid}.quick-add__plus:hover{color:var(--text)}.quick-add__input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:4px 0;font-size:15px}.quick-add__input::placeholder{color:var(--text-faint)}.quick-add__controls{align-items:center;gap:6px;display:flex}.chip{border:1px solid var(--border);background:var(--surface);color:var(--text-soft);border-radius:var(--r-pill);transition:.15s var(--ease);align-items:center;gap:6px;padding:5px 11px;font-size:12.5px;font-weight:500;display:inline-flex}.chip:hover{background:var(--surface-hover);color:var(--text)}.chip--active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.chip select,.chip input[type=date]{color:inherit;font:inherit;cursor:pointer;background:0 0;border:none;outline:none}.task-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.list-section__head{letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint);margin:18px 0 6px;padding:0 4px;font-size:12px;font-weight:600}.task{border-radius:var(--r-md);transition:background .15s var(--ease), opacity .2s var(--ease);align-items:flex-start;gap:12px;padding:12px;display:flex;position:relative}.task:hover{background:var(--surface-hover)}.task:hover .task__delete{opacity:1}.task--completed .task__title{color:var(--text-faint);text-decoration:line-through}.task--completed{opacity:.7}.checkbox{appearance:none;border:2px solid var(--border-strong);width:20px;height:20px;transition:.15s var(--ease);border-radius:50%;flex:none;place-items:center;margin:1px 0 0;display:grid;position:relative}.checkbox:hover{border-color:var(--accent)}.checkbox--p-high{border-color:var(--p-high)}.checkbox--p-medium{border-color:var(--p-medium)}.checkbox--p-low{border-color:var(--p-low)}.checkbox:checked{background:var(--accent);border-color:var(--accent)}.checkbox:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:9px;transform:rotate(45deg)translate(-.5px,-1px)}.task__body{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.task__title{color:var(--text);word-break:break-word;font-size:14.5px;line-height:1.4}.task__meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.task__notes{color:var(--text-faint);text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:12.5px;overflow:hidden}.tag{border-radius:var(--r-pill);background:var(--surface-active);color:var(--text-soft);align-items:center;gap:5px;padding:2px 8px;font-size:11.5px;font-weight:600;display:inline-flex}.tag--due{color:var(--text-soft)}.tag--today{background:color-mix(in srgb, var(--accent) 14%, transparent);color:var(--accent)}.tag--overdue{background:color-mix(in srgb, var(--danger) 14%, transparent);color:var(--danger)}.tag__dot{border-radius:50%;width:7px;height:7px}.task__delete{color:var(--text-faint);opacity:0;border-radius:var(--r-sm);width:28px;height:28px;transition:.15s var(--ease);background:0 0;border:none;flex:none;place-items:center;display:grid}.task__delete:hover{background:color-mix(in srgb, var(--danger) 14%, transparent);color:var(--danger)}.empty{text-align:center;color:var(--text-soft);padding:72px 24px}.empty__art{border-radius:var(--r-lg);background:var(--accent-soft);width:64px;height:64px;color:var(--accent);place-items:center;margin:0 auto 16px;display:grid}.empty__title{color:var(--text);margin:0 0 4px;font-size:17px;font-weight:600}.empty__text{margin:0;font-size:13.5px}.sidebar__scrim{display:none}@media (width<=760px){.app{grid-template-columns:1fr}.sidebar{z-index:30;width:264px;transition:transform .25s var(--ease);box-shadow:var(--shadow-lg);position:fixed;inset:0 auto 0 0;transform:translate(-100%)}.app--drawer-open .sidebar{transform:translate(0)}.app--drawer-open .sidebar__scrim{background:var(--overlay);z-index:20;display:block;position:fixed;inset:0}.topbar,.content{padding-left:18px;padding-right:18px}.menu-btn{display:grid}}.menu-btn{display:none}.content__inner--wide{max-width:1080px}.icon-btn--sm{border-radius:var(--r-sm);width:32px;height:32px}.cal{flex-direction:column;gap:14px;display:flex}.cal-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:6px;display:flex}.cal-toolbar__nav{align-items:center;gap:8px;display:flex}.cal-toolbar__title{letter-spacing:-.01em;margin:0 0 0 6px;font-size:18px;font-weight:700}.cal-switch{background:var(--surface-active);border-radius:var(--r-md);gap:2px;padding:3px;display:inline-flex}.cal-switch__btn{color:var(--text-soft);transition:.15s var(--ease);background:0 0;border:none;border-radius:7px;padding:6px 14px;font-size:13px;font-weight:600}.cal-switch__btn:hover{color:var(--text)}.cal-switch__btn--active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.cal-event{background:color-mix(in srgb, var(--event-color) 14%, transparent);width:100%;color:var(--text);text-align:left;transition:.12s var(--ease);border:none;border-radius:6px;align-items:center;gap:6px;padding:3px 7px;font-size:12px;font-weight:500;display:flex}.cal-event:hover{background:color-mix(in srgb, var(--event-color) 26%, transparent)}.cal-event__dot{background:var(--event-color);border-radius:50%;flex:none;width:7px;height:7px}.cal-event__title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cal-event--done .cal-event__title{color:var(--text-faint);text-decoration:line-through}.cal-month{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);overflow:hidden}.cal-weekdays{background:var(--sidebar-bg);border-bottom:1px solid var(--border);grid-template-columns:repeat(7,1fr);display:grid}.cal-weekday{letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint);text-align:left;padding:8px 10px;font-size:11.5px;font-weight:600}.cal-month__grid{grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(104px,1fr);display:grid}.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s var(--ease);flex-direction:column;gap:4px;padding:6px;display:flex;overflow:hidden}.cal-cell:hover{background:var(--surface-hover)}.cal-cell:nth-child(7n){border-right:none}.cal-cell--muted{background:color-mix(in srgb, var(--sidebar-bg) 60%, transparent)}.cal-cell--muted .cal-cell__num{color:var(--text-faint)}.cal-cell__num{color:var(--text-soft);border-radius:50%;place-items:center;width:24px;height:24px;font-size:13px;font-weight:600;display:grid}.cal-cell__num--today{background:var(--accent);color:#fff}.cal-cell__events{flex-direction:column;gap:3px;min-height:0;display:flex}.cal-more{color:var(--text-faint);padding:1px 7px;font-size:11px;font-weight:600}.cal-week{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.cal-week__col{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;min-height:320px;display:flex;overflow:hidden}.cal-week__head{background:var(--sidebar-bg);border:none;border-bottom:1px solid var(--border);transition:.12s var(--ease);flex-direction:column;align-items:center;gap:2px;padding:8px;display:flex}.cal-week__head:hover{background:var(--surface-hover)}.cal-week__dow{text-transform:uppercase;color:var(--text-faint);font-size:11px;font-weight:600}.cal-week__day{color:var(--text);border-radius:50%;place-items:center;width:30px;height:30px;font-size:17px;font-weight:700;display:grid}.cal-week__head--today .cal-week__day{background:var(--accent);color:#fff}.cal-week__events{flex-direction:column;gap:4px;padding:8px;display:flex;overflow-y:auto}.cal-week__empty{color:var(--text-faint);text-align:center;padding:8px 0;font-size:13px}.cal-day{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:8px}.cal-year{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.cal-mini{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-md);text-align:left;transition:.15s var(--ease);padding:12px}.cal-mini:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.cal-mini__name{color:var(--text);margin-bottom:8px;font-size:13px;font-weight:700}.cal-mini__grid{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.cal-mini__day{color:var(--text-soft);aspect-ratio:1;border-radius:50%;place-items:center;font-size:10px;display:grid}.cal-mini__day--muted{color:#0000}.cal-mini__day--has{color:var(--accent);background:var(--accent-soft);font-weight:700}.cal-mini__day--today{background:var(--accent);color:#fff;font-weight:700}@media (width<=760px){.cal-year{grid-template-columns:repeat(2,1fr)}.cal-week{grid-template-columns:1fr}.cal-month__grid{grid-auto-rows:minmax(76px,1fr);font-size:12px}}.task__body--button{text-align:left;cursor:pointer;color:inherit;font:inherit;background:0 0;border:none;padding:0}.task__body--button:hover .task__title{color:var(--accent)}.tag--timer{font-variant-numeric:tabular-nums}.tag--running{background:color-mix(in srgb, var(--success) 16%, transparent);color:var(--success)}.detail__scrim{background:var(--overlay);z-index:40;border:none;position:fixed;inset:0}.detail{background:var(--bg-elev);border-left:1px solid var(--border);width:380px;max-width:100vw;box-shadow:var(--shadow-lg);z-index:41;animation:detail-in .2s var(--ease);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0}@keyframes detail-in{0%{opacity:0;transform:translate(16px)}}.detail__head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.detail__heading{letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint);font-size:13px;font-weight:600}.detail__body{flex-direction:column;gap:16px;padding:18px;display:flex;overflow-y:auto}.field{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.field__label{color:var(--text-soft);font-size:12px;font-weight:600}.field__input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:var(--r-md);transition:.15s var(--ease);outline:none;padding:9px 11px;font-size:14px}.field__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field__textarea{resize:vertical;line-height:1.5}.field-row{gap:12px;display:flex}.timer{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.timer__readout{flex-direction:column;display:flex}.timer__value{font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-size:22px;font-weight:700}.timer__sub{color:var(--text-faint);font-size:12px}.btn{border-radius:var(--r-md);transition:.15s var(--ease);border:none;align-items:center;gap:7px;padding:9px 16px;font-size:14px;font-weight:600;display:inline-flex}.btn--start{background:var(--accent);color:#fff}.btn--start:hover{filter:brightness(1.08)}.btn--stop{background:color-mix(in srgb, var(--danger) 16%, transparent);color:var(--danger)}.btn--stop:hover{background:color-mix(in srgb, var(--danger) 24%, transparent)}.detail__delete{border:1px solid var(--border);color:var(--danger);border-radius:var(--r-md);transition:.15s var(--ease);background:0 0;justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:9px 14px;font-size:13.5px;font-weight:600;display:inline-flex}.detail__delete:hover{background:color-mix(in srgb, var(--danger) 12%, transparent)}@media (width<=760px){.detail{width:100vw}}.deadline{flex-direction:column;display:flex}.deadline>.cal-switch{align-self:flex-start;margin:12px 0 10px}.deadline__section{margin-bottom:6px}.cd{flex-direction:column;display:flex}.cd__bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin:12px 0 14px;display:flex}.cd__holidays{align-items:center;gap:8px;display:flex}.cd__country{width:auto;padding:8px 10px}.cd__list{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin:0;padding:0;list-style:none;display:grid}.cd-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:.15s var(--ease);align-items:center;gap:12px;padding:14px 16px;display:flex}.cd-card:hover{border-color:var(--border-strong)}.cd-card:hover .cd-card__actions{opacity:1}.cd-card--past{opacity:.6}.cd-card__emoji{background:var(--surface-active);border-radius:var(--r-md);flex:none;place-items:center;width:40px;height:40px;font-size:26px;display:grid}.cd-card__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.cd-card__title{text-overflow:ellipsis;white-space:nowrap;font-size:14.5px;font-weight:600;overflow:hidden}.cd-card__date{color:var(--text-soft);font-size:12.5px}.cd-card__links{color:var(--accent);font-size:11.5px;font-weight:600}.cd-card__count{text-align:right;flex-direction:column;flex:none;line-height:1.05;display:flex}.cd-card__num{letter-spacing:-.02em;font-variant-numeric:tabular-nums;color:var(--accent);font-size:24px;font-weight:800}.cd-card--past .cd-card__num{color:var(--text-faint)}.cd-card__label{color:var(--text-faint);font-size:11px}.cd-card__actions{opacity:0;transition:.15s var(--ease);flex-direction:column;flex:none;gap:4px;display:flex}.cd-card__delete:hover{color:var(--danger);border-color:color-mix(in srgb, var(--danger) 40%, var(--border))}.emoji-row{flex-wrap:wrap;gap:6px;display:flex}.emoji-pick{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-md);width:38px;height:38px;transition:.12s var(--ease);place-items:center;font-size:20px;display:grid}.emoji-pick:hover{background:var(--surface-hover)}.emoji-pick--active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.link-list{border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;gap:2px;max-height:180px;padding:6px;display:flex;overflow-y:auto}.link-row{border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:8px;padding:6px 8px;font-size:13.5px;display:flex}.link-row:hover{background:var(--surface-hover)}@media (width<=760px){.cd__list{grid-template-columns:1fr}}.tag--estimate{color:var(--text-soft);background:var(--surface-active)}.task--overdue{box-shadow:inset 3px 0 0 var(--danger)}.task--overdue.task--active{box-shadow:inset 3px 0 0 var(--danger), inset 0 0 0 1.5px color-mix(in srgb, var(--accent) 55%, transparent)}.deadline__head{letter-spacing:.02em;color:var(--text-soft);justify-content:space-between;align-items:center;margin:18px 0 8px;padding:0 2px;font-size:13px;font-weight:700;display:flex}.deadline__count{color:var(--text-faint);background:var(--surface-active);border-radius:var(--r-pill);text-align:center;min-width:22px;padding:1px 9px;font-size:12px;font-weight:700}.deadline__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:6px}.cd-card{flex-direction:column;align-items:stretch}.cd-card__row{align-items:center;gap:12px;display:flex}.cd-tasks{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.cd-tasks__head{text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint);justify-content:space-between;align-items:center;margin-bottom:6px;font-size:11.5px;font-weight:700;display:flex}.cd-tasks__progress{color:var(--accent)}.cd-tasks__list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.cd-task{align-items:center;gap:9px;padding:4px 2px;display:flex}.cd-task__title{color:var(--text);font-size:13.5px}.cd-task__title--done{color:var(--text-faint);text-decoration:line-through}.checkbox--sm{width:17px;height:17px}.checkbox--sm:checked:after{width:4px;height:8px}.holiday-emoji{font-size:16px}.holiday-name{flex:1}.holiday-date{color:var(--text-faint);font-size:12px}.field__hint{color:var(--text-faint);margin:0 0 6px;font-size:12.5px;line-height:1.45}.btn:disabled{opacity:.5;cursor:not-allowed}.toast{background:var(--text);color:var(--bg-elev);border-radius:var(--r-pill);box-shadow:var(--shadow-lg);z-index:60;animation:toast-in .2s var(--ease);padding:10px 18px;font-size:13.5px;font-weight:600;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}}.subs{flex-direction:column;gap:6px;display:flex}.subs__bar{justify-content:space-between;align-items:center;gap:12px;margin:12px 0 14px;display:flex}.subs__total{align-items:baseline;gap:6px;display:flex}.subs__total-value{letter-spacing:-.01em;font-size:22px;font-weight:700}.subs__total-label{color:var(--text-faint);font-size:13px}.subs__list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.sub-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:.15s var(--ease);align-items:center;gap:12px;padding:14px 16px;display:flex}.sub-card:hover{border-color:var(--border-strong)}.sub-card__main{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.sub-card__top{align-items:center;gap:10px;display:flex}.sub-card__name{font-size:15px;font-weight:600}.sub-card__meta{color:var(--text-soft);flex-wrap:wrap;align-items:center;gap:6px;font-size:13px;display:flex}.sub-card__cost{color:var(--text);font-weight:600}.sub-card__sep{color:var(--text-faint)}.sub-card__actions{flex:none;gap:6px;display:flex}.sub-card__delete:hover{color:var(--danger);border-color:color-mix(in srgb, var(--danger) 40%, var(--border))}.sub-badge{border-radius:var(--r-pill);padding:2px 9px;font-size:11.5px;font-weight:700}.sub-badge--green{background:color-mix(in srgb, var(--success) 16%, transparent);color:var(--success)}.sub-badge--yellow{background:color-mix(in srgb, var(--p-medium) 18%, transparent);color:var(--p-medium)}.sub-badge--red{background:color-mix(in srgb, var(--danger) 16%, transparent);color:var(--danger)}.modal-scrim{background:var(--overlay);z-index:50;animation:view-in .15s var(--ease);place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);max-height:min(90vh,90dvh);overflow-y:auto}.modal__body{flex-direction:column;gap:14px;padding:18px;display:flex}.modal__footer{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.btn--ghost{border:1px solid var(--border);color:var(--text-soft);background:0 0}.btn--ghost:hover{background:var(--surface-hover);color:var(--text)}.form-error{color:var(--danger);margin:0;font-size:13px}.habits{flex-direction:column;display:flex}.habits__bar{justify-content:space-between;align-items:center;gap:12px;margin:12px 0 14px;display:flex}.habits__hint{color:var(--text-faint);font-size:13px;font-weight:600}.habits__list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.habit-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:.15s var(--ease);align-items:center;gap:10px;padding:10px 12px;display:flex}.habit-card:hover{border-color:var(--border-strong)}.habit-card--met{background:color-mix(in srgb, var(--success) 7%, var(--surface))}.habit-card__body{text-align:left;cursor:pointer;min-width:0;color:inherit;font:inherit;background:0 0;border:none;flex:1;align-items:center;gap:12px;padding:0;display:flex}.habit-card__emoji{border-radius:var(--r-md);flex:none;place-items:center;width:42px;height:42px;font-size:22px;display:grid}.habit-card__info{flex-direction:column;gap:3px;min-width:0;display:flex}.habit-card__name{font-size:14.5px;font-weight:600}.habit-card__body:hover .habit-card__name{color:var(--accent)}.habit-card__meta{color:var(--text-soft);align-items:center;gap:10px;font-size:12.5px;display:flex}.habit-streak{color:#ea580c;align-items:center;gap:3px;font-weight:700;display:inline-flex}.habit-card__progress{font-variant-numeric:tabular-nums}.habit-check{border:2px solid var(--border-strong);background:var(--surface);width:40px;height:40px;color:var(--text-faint);transition:.15s var(--ease);border-radius:50%;flex:none;place-items:center;display:grid}.habit-check:hover{border-color:var(--accent);color:var(--accent)}.habit-check:active{transform:scale(.92)}.habit-check--done{color:#fff}.habit-stats{gap:10px;display:flex}.habit-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);text-align:center;flex-direction:column;flex:1;gap:2px;padding:12px;display:flex}.habit-stat__value{letter-spacing:-.01em;color:var(--text);justify-content:center;align-items:center;gap:4px;font-size:19px;font-weight:800;display:inline-flex}.habit-stat:first-child .habit-stat__value{color:#ea580c}.habit-stat__label{color:var(--text-faint);font-size:11.5px}.habit-checkin{gap:8px;display:flex}.habit-checkin .field__input{flex:1}.habit-history{flex-direction:column;gap:2px;margin:6px 0 0;padding:0;list-style:none;display:flex}.habit-history__row{align-items:center;gap:10px;padding:5px 4px;font-size:13px;display:flex}.habit-history__date{min-width:92px;font-weight:600}.habit-history__note{color:var(--text-soft);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.task__icon{margin-right:6px}.tag__dot--bare{border-radius:50%;width:9px;height:9px;display:inline-block}.tag--label{background:var(--surface-active)}.tag-chips,.tag-filter{flex-wrap:wrap;gap:6px;display:flex}.tag-filter{margin:0 0 14px}.tag-chip{border:1px solid var(--border);background:var(--surface);color:var(--text-soft);border-radius:var(--r-pill);transition:.12s var(--ease);align-items:center;gap:6px;padding:4px 11px;font-size:12.5px;font-weight:600;display:inline-flex}.tag-chip:hover{background:var(--surface-hover)}.tag-new{gap:8px;margin-top:8px;display:flex}.link-btn{color:var(--accent);background:0 0;border:none;align-self:flex-start;margin-top:6px;padding:0;font-size:12.5px;font-weight:600}.link-btn:hover{text-decoration:underline}.swatch--input{border:1px solid var(--border);background:var(--surface);cursor:pointer;block-size:26px;inline-size:26px;padding:0}.swatch--input::-webkit-color-swatch-wrapper{padding:2px}.swatch--input::-webkit-color-swatch{border:none;border-radius:50%}.tags-page{flex-direction:column;gap:10px;margin-top:12px;display:flex}.tag-create{align-items:center;gap:8px;display:flex}.tag-create .field__input{flex:1}.tag-manage{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.tag-manage__row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);align-items:center;gap:10px;padding:8px 10px;display:flex}.tag-manage__row .field__input{flex:1}.cd-card__num--word{font-size:16px;font-weight:700}.tag-chip--manage{color:var(--text-faint);border-style:dashed}.tag-chip--manage:hover{color:var(--text);border-color:var(--border-strong)}.swatch--sm{width:20px;height:20px}.habit-history--scroll{max-height:320px;overflow-y:auto}.habit-log{flex-direction:column;gap:10px;display:flex}.habit-log__row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:12px 14px}.habit-log__head{align-items:center;gap:8px;margin-bottom:10px;display:flex}.habit-log__emoji{font-size:18px}.habit-log__name{flex:1;font-size:14px;font-weight:600}.habit-log__strip{flex-wrap:wrap;gap:4px;display:flex}.hl-day{border-radius:var(--r-sm);width:26px;height:26px;color:var(--text-faint);background:var(--surface-active);font-variant-numeric:tabular-nums;place-items:center;font-size:11px;font-weight:600;display:grid}.hl-day--today{outline:2px solid var(--accent);outline-offset:1px}.colorpick{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.colorpick__custom{border:1px solid var(--border-strong);cursor:pointer;width:26px;height:26px;transition:.12s var(--ease);background:conic-gradient(#ef4444,#f59e0b,#16a34a,#0891b2,#4f46e5,#db2777,#ef4444);border-radius:50%;display:inline-block;position:relative;overflow:hidden}.colorpick__custom:hover{transform:scale(1.08)}.colorpick__custom--active{box-shadow:0 0 0 2px var(--bg-elev), 0 0 0 4px var(--accent)}.colorpick__custom input{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.nav-item__emoji{text-align:center;flex:none;width:18px;font-size:14px;line-height:1}.proj-progress{flex-direction:column;gap:6px;display:flex}.proj-progress__bar{border-radius:var(--r-pill);background:var(--surface-active);height:8px;overflow:hidden}.proj-progress__fill{border-radius:var(--r-pill);background:linear-gradient(90deg, var(--accent), #9d7bff);height:100%;transition:width .3s var(--ease);display:block}.proj-progress__meta{color:var(--text-soft);justify-content:space-between;font-size:12.5px;font-weight:600;display:flex}.modal__footer-spacer{flex:1}.pwa-toast{left:50%;bottom:calc(18px + env(safe-area-inset-bottom,0px));z-index:60;background:var(--text);color:var(--bg);border-radius:var(--r-pill);box-shadow:var(--shadow-lg);animation:pwa-rise .3s var(--ease);align-items:center;gap:12px;padding:10px 12px 10px 16px;font-size:13px;font-weight:500;display:flex;position:fixed;transform:translate(-50%)}.pwa-toast__btn{background:var(--accent);color:#fff;border-radius:var(--r-pill);cursor:pointer;transition:.15s var(--ease);border:none;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;display:inline-flex}.pwa-toast__btn:hover{filter:brightness(1.08)}.pwa-install{right:calc(20px + env(safe-area-inset-right,0px));bottom:calc(20px + env(safe-area-inset-bottom,0px));z-index:55;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:min(380px,100vw - 32px);box-shadow:var(--shadow-lg);animation:pwa-rise .3s var(--ease);align-items:center;gap:14px;padding:14px 16px;display:flex;position:fixed}.pwa-install__logo{background:linear-gradient(135deg, var(--accent), #9d7bff);color:#fff;width:40px;height:40px;box-shadow:var(--shadow-sm);border-radius:10px;flex:none;place-items:center;font-size:18px;font-weight:800;display:grid}.pwa-install__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.pwa-install__title{font-size:14px;font-weight:700}.pwa-install__text{color:var(--text-soft);font-size:12px;line-height:1.4}.pwa-install__cta{flex:none}@keyframes pwa-rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.pwa-toast,.pwa-install{animation:none}}@media (width<=760px){.pwa-install{width:auto;left:16px;right:16px}}@media (width<=1080px){.detail{width:min(420px,42vw)}}@media (width<=480px){.topbar{padding:14px 16px 6px}.topbar__title{font-size:22px}.detail{width:100%}.cal-toolbar{gap:8px}.cal-switch{justify-content:space-between;width:100%}}@media (display-mode:standalone){.sidebar{padding-top:calc(18px + env(safe-area-inset-top,0px))}.topbar{padding-top:calc(20px + env(safe-area-inset-top,0px))}}.netbar{top:calc(12px + env(safe-area-inset-top,0px));z-index:58;border-radius:var(--r-pill);pointer-events:none;max-width:calc(100vw - 32px);box-shadow:var(--shadow-md);border:1px solid var(--border);animation:netbar-drop .28s var(--ease);align-items:center;gap:8px;padding:7px 14px;font-size:13px;font-weight:600;display:inline-flex;position:fixed;left:50%;transform:translate(-50%)}.netbar__dot{background:currentColor;border-radius:50%;flex:none;width:8px;height:8px}.netbar--offline{background:var(--surface);color:var(--text-soft)}.netbar--offline .netbar__dot{background:#d97706}.netbar--syncing{background:var(--accent-soft);color:var(--accent);border-color:#0000}.netbar--syncing .netbar__dot{animation:netbar-pulse 1s var(--ease) infinite}.netbar--synced{background:color-mix(in srgb, #16a34a 16%, var(--surface));color:#16a34a;border-color:#0000}@keyframes netbar-drop{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}@keyframes netbar-pulse{0%,to{opacity:1}50%{opacity:.35}}@media (prefers-reduced-motion:reduce){.netbar,.netbar--syncing .netbar__dot{animation:none}}.auth{background:var(--bg);grid-template-columns:1.05fr 1fr;min-height:100dvh;display:grid}.auth__aside{color:#fff;background:linear-gradient(150deg, var(--accent) 0%, #7c5cff 55%, #9d7bff 100%);flex-direction:column;justify-content:center;gap:18px;padding:64px;display:flex;position:relative;overflow:hidden}.auth__aside:after{content:"";filter:blur(8px);background:#ffffff1f;border-radius:50%;width:360px;height:360px;position:absolute;inset:auto -80px -120px auto}.auth__tagline{letter-spacing:-.02em;max-width:15ch;margin:0;font-size:30px;font-weight:700;line-height:1.2}.auth__sub{color:#ffffffd9;max-width:38ch;margin:0;font-size:15px;line-height:1.55}.auth__logo{color:#fff;background:#ffffff2e;border:1px solid #ffffff40;border-radius:14px;place-items:center;width:52px;height:52px;font-size:24px;font-weight:800;display:grid}.auth__logo--sm{color:#fff;background:linear-gradient(135deg, var(--accent), #9d7bff);width:44px;height:44px;box-shadow:var(--shadow-md);border:none;margin-bottom:18px;font-size:20px}.auth__card{flex-direction:column;justify-content:center;width:100%;max-width:380px;margin:0 auto;padding:48px 40px;display:flex}.auth__title{letter-spacing:-.02em;margin:0 0 4px;font-size:25px;font-weight:700}.auth__lede{color:var(--text-soft);margin:0 0 26px;font-size:14px}.auth__label{color:var(--text-soft);margin:14px 0 6px;font-size:12px;font-weight:600}.auth__input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:var(--r-md);transition:.15s var(--ease);padding:11px 13px;font-size:14px}.auth__input::placeholder{color:var(--text-faint)}.auth__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.auth__error{border-radius:var(--r-md);color:#b91c1c;background:#ef44441f;border:1px solid #ef44444d;margin:14px 0 0;padding:9px 12px;font-size:13px;font-weight:500}.auth__submit{border-radius:var(--r-md);color:#fff;background:linear-gradient(135deg, var(--accent), #7c5cff);cursor:pointer;transition:.15s var(--ease);border:none;margin-top:22px;padding:12px 16px;font-size:14px;font-weight:600}.auth__submit:hover:not(:disabled){filter:brightness(1.07)}.auth__submit:disabled{opacity:.6;cursor:default}.auth__switch{color:var(--text-soft);text-align:center;margin:18px 0 0;font-size:13px}.auth__toggle{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.auth__toggle:hover{text-decoration:underline}.auth-loading{min-height:100dvh;color:var(--text-soft);justify-content:center;align-items:center;gap:10px;font-size:14px;display:flex}.auth-loading__spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:16px;height:16px;animation:.7s linear infinite auth-spin}@keyframes auth-spin{to{transform:rotate(360deg)}}.usermenu{border-top:1px solid var(--border);align-items:center;gap:9px;padding:8px;display:flex}.usermenu__avatar{color:#fff;background:linear-gradient(135deg, var(--accent), #9d7bff);border-radius:50%;flex:none;place-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:grid}.usermenu__email{min-width:0;color:var(--text-soft);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:500;overflow:hidden}.usermenu__signout{color:var(--text-faint);border-radius:var(--r-sm);cursor:pointer;width:30px;height:30px;transition:.15s var(--ease);background:0 0;border:none;flex:none;place-items:center;display:grid}.usermenu__signout:hover{background:var(--surface-hover);color:#ef4444}@media (width<=760px){.auth{grid-template-columns:1fr}.auth__aside{display:none}.auth__card{padding:40px 24px}}.welcome{background:radial-gradient(1100px 520px at 50% -10%, var(--accent-soft), transparent 70%), var(--bg);flex-direction:column;min-height:100dvh;display:flex;overflow-y:auto}.welcome__nav{justify-content:space-between;align-items:center;padding:20px clamp(20px,6vw,64px);display:flex}.welcome__brand{align-items:center;gap:10px;display:flex}.welcome__logo{color:#fff;background:linear-gradient(135deg, var(--accent), #9d7bff);width:32px;height:32px;box-shadow:var(--shadow-sm);border-radius:9px;place-items:center;font-weight:800;display:grid}.welcome__brandname{letter-spacing:-.01em;font-size:18px;font-weight:700}.welcome__signin{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-md);cursor:pointer;transition:.15s var(--ease);padding:8px 16px;font-size:14px;font-weight:600}.welcome__signin:hover{background:var(--surface-hover)}.welcome__hero{text-align:center;flex-direction:column;align-items:center;gap:18px;padding:clamp(40px,9vw,96px) clamp(20px,6vw,64px) 40px;display:flex}.welcome__eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:0;font-size:13px;font-weight:700}.welcome__title{letter-spacing:-.03em;max-width:16ch;margin:0;font-size:clamp(34px,6vw,56px);font-weight:800;line-height:1.05}.welcome__lede{max-width:56ch;color:var(--text-soft);margin:0;font-size:clamp(15px,2.4vw,18px);line-height:1.6}.welcome__cta{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:10px;display:flex}.welcome__btn{border-radius:var(--r-md);cursor:pointer;transition:.15s var(--ease);border:none;padding:13px 22px;font-size:15px;font-weight:600}.welcome__btn--primary{color:#fff;background:linear-gradient(135deg, var(--accent), #7c5cff);box-shadow:var(--shadow-md)}.welcome__btn--primary:hover{filter:brightness(1.07)}.welcome__btn--ghost{background:var(--surface);color:var(--text);border:1px solid var(--border)}.welcome__btn--ghost:hover{background:var(--surface-hover)}.welcome__features{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;width:100%;max-width:1040px;margin:24px auto 0;padding:0 clamp(20px,6vw,64px) 56px;display:grid}.welcome__feature{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:.15s var(--ease);padding:22px}.welcome__feature:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.welcome__feature-icon{background:var(--accent-soft);border-radius:11px;place-items:center;width:40px;height:40px;margin-bottom:12px;font-size:19px;display:grid}.welcome__feature-title{margin:0 0 5px;font-size:16px;font-weight:700}.welcome__feature-text{color:var(--text-soft);margin:0;font-size:14px;line-height:1.5}.welcome__footer{text-align:center;color:var(--text-faint);margin-top:auto;padding:22px;font-size:13px}.auth__back{color:var(--text-soft);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0 0 14px;font-size:13px;font-weight:600}.auth__back:hover{color:var(--text)}.onb{z-index:80;background:var(--overlay);animation:onb-fade .2s var(--ease);place-items:center;padding:20px;display:grid;position:fixed;inset:0}.onb__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:min(420px,100%);box-shadow:var(--shadow-lg);text-align:center;animation:onb-rise .25s var(--ease);padding:32px 28px 24px;position:relative}.onb__skip{color:var(--text-faint);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:600;position:absolute;top:14px;right:16px}.onb__skip:hover{color:var(--text-soft)}.onb__icon{background:var(--accent-soft);border-radius:18px;place-items:center;width:64px;height:64px;margin-bottom:18px;font-size:30px;display:inline-grid}.onb__title{letter-spacing:-.02em;margin:0 0 8px;font-size:21px;font-weight:700}.onb__text{max-width:34ch;color:var(--text-soft);margin:0 auto;font-size:14px;line-height:1.6}.onb__dots{justify-content:center;gap:7px;margin:22px 0;display:flex}.onb__dot{background:var(--border-strong);width:7px;height:7px;transition:.2s var(--ease);border-radius:50%}.onb__dot--active{background:var(--accent);border-radius:var(--r-pill);width:20px}.onb__actions{justify-content:center;gap:10px;display:flex}.onb__btn{border-radius:var(--r-md);cursor:pointer;transition:.15s var(--ease);border:1px solid #0000;padding:11px 22px;font-size:14px;font-weight:600}.onb__btn--ghost{background:var(--surface);border-color:var(--border);color:var(--text)}.onb__btn--ghost:hover{background:var(--surface-hover)}.onb__btn--primary{background:linear-gradient(135deg, var(--accent), #7c5cff);color:#fff;box-shadow:var(--shadow-sm);min-width:120px}.onb__btn--primary:hover{filter:brightness(1.07)}@keyframes onb-fade{0%{opacity:0}}@keyframes onb-rise{0%{opacity:0;transform:translateY(12px)}}@media (prefers-reduced-motion:reduce){.onb,.onb__card{animation:none}}.welcome__navactions{align-items:center;gap:10px;display:flex}.langswitch{appearance:none;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-md);cursor:pointer;background-image:linear-gradient(45deg, transparent 50%, var(--text-faint) 50%), linear-gradient(135deg, var(--text-faint) 50%, transparent 50%);background-position:calc(100% - 16px),calc(100% - 11px);background-repeat:no-repeat;background-size:5px 5px,5px 5px;padding:8px 30px 8px 12px;font-size:13px;font-weight:600}.langswitch:hover{background-color:var(--surface-hover)}.langswitch:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.auth__forgot{color:var(--accent);cursor:pointer;background:0 0;border:none;align-self:flex-end;margin-top:12px;padding:0;font-size:13px;font-weight:600}.auth__forgot:hover{text-decoration:underline}.auth__notice{border-radius:var(--r-md);color:#166534;background:#16a34a1f;border:1px solid #16a34a4d;margin-top:18px;padding:12px 14px;font-size:14px;line-height:1.5}.sidebar__foot{flex-direction:column;gap:8px;display:flex}.langswitch--block{width:100%}.holiday-actions{gap:14px;margin:4px 0 8px;display:flex}.holiday-actions .link-btn{font-size:13px}html{-webkit-tap-highlight-color:transparent}.app{height:100dvh}.content{overscroll-behavior:contain;-webkit-overflow-scrolling:touch}button:focus-visible,.checkbox:focus-visible,input:focus-visible[type=checkbox]{outline:2px solid var(--accent);outline-offset:2px}.checkbox:checked{animation:check-pop .18s var(--ease)}@keyframes check-pop{0%{transform:scale(.85)}60%{transform:scale(1.1)}to{transform:scale(1)}}.task--reveal .task__delete{opacity:1}@keyframes sheet-up{0%{opacity:0;transform:translateY(28px)}}@media (hover:none){.task__delete{opacity:1;width:36px;height:36px}.cd-card__actions{opacity:1;flex-direction:row}.icon-btn{width:42px;height:42px}.icon-btn--sm{width:38px;height:38px}.nav-item{padding:11px 10px}.nav__add{width:32px;height:32px}.task{padding:14px 12px}.checkbox{width:22px;height:22px}.usermenu__signout{width:38px;height:38px}.habit-check{width:44px;height:44px}.chip{padding:7px 12px}.cal-switch__btn{padding:9px 14px}}.mobile-nav{display:none}@media (width<=760px){.mobile-nav{z-index:18;padding:6px 10px calc(6px + env(safe-area-inset-bottom,0px));background:var(--bg-elev);border-top:1px solid var(--border);align-items:stretch;gap:2px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0f172a0f}.mobile-nav__btn{min-height:48px;color:var(--text-faint);border-radius:var(--r-md);transition:.15s var(--ease);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:10.5px;font-weight:600;display:flex}.mobile-nav__btn:active{background:var(--surface-hover)}.mobile-nav__btn--active{color:var(--accent)}.content{padding-bottom:calc(88px + env(safe-area-inset-bottom,0px))}.quick-add__input,.field__input,.auth__input{font-size:16px}.quick-add{flex-wrap:wrap}.quick-add__input{min-width:140px}.detail{border-left:none;border-top:1px solid var(--border);width:100%;max-height:88dvh;padding-bottom:env(safe-area-inset-bottom,0px);animation:sheet-up .25s var(--ease);border-radius:20px 20px 0 0;inset:auto 0 0}.detail__head{padding-top:22px;position:relative}.detail__head:before{content:"";border-radius:var(--r-pill);background:var(--border-strong);width:40px;height:4px;position:absolute;top:8px;left:50%;transform:translate(-50%)}}@media (width<=480px){.cal-month__grid{grid-auto-rows:minmax(58px,1fr)}.cal-cell{gap:3px;padding:4px 3px}.cal-cell__num{width:22px;height:22px;font-size:12px}.cal-cell__events{flex-flow:wrap;gap:3px;padding:0 2px}.cal-event{background:0 0;width:auto;padding:2px}.cal-event__title{display:none}.cal-event__dot{width:8px;height:8px}.cal-more{padding:0 2px;font-size:10px}.field-row{flex-direction:column;gap:14px}.habit-stats{flex-wrap:wrap}.modal-scrim{place-items:end stretch;padding:0}.modal{max-width:none;max-height:92dvh;padding-bottom:env(safe-area-inset-bottom,0px);animation:sheet-up .25s var(--ease);border-bottom:none;border-radius:20px 20px 0 0}}@media (prefers-reduced-motion:reduce){.detail,.modal,.checkbox:checked{animation:none}}.auth__beta{align-items:center;gap:10px;margin:-16px 0 22px;display:flex}.auth__beta-badge{letter-spacing:.07em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);border-radius:var(--r-pill);align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.auth__beta-spots{color:var(--text-soft);font-size:12.5px;font-weight:600}.auth__input--code{letter-spacing:.08em;text-transform:uppercase;font-family:Courier New,monospace;font-weight:700}@media (width<=760px){.sidebar{width:min(86vw,340px);height:100dvh;padding:calc(16px + env(safe-area-inset-top,0px)) 14px calc(16px + env(safe-area-inset-bottom,0px)) calc(14px + env(safe-area-inset-left,0px));overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border-radius:0 22px 22px 0;overflow-y:auto}.sidebar .brand{padding-bottom:18px}.sidebar .brand__logo{width:32px;height:32px}.sidebar .nav-item{border-radius:12px;padding:12px;font-size:15px}.sidebar .nav-item__count{font-size:12.5px}.sidebar .nav__label{padding-top:18px;font-size:11.5px}.sidebar .nav__add{width:34px;height:34px}.sidebar__footer{padding-bottom:4px}.app--drawer-open .sidebar{box-shadow:0 0 0 1px var(--border), var(--shadow-lg)}}.swatch{cursor:pointer;width:26px;height:26px;transition:transform .12s var(--ease), box-shadow .12s var(--ease);border:none;border-radius:50%;padding:0;box-shadow:inset 0 0 0 1px #0f172a1f}.swatch:hover{transform:scale(1.12)}.swatch--active{box-shadow:0 0 0 2px var(--bg-elev), 0 0 0 4px var(--accent)}.subs__total-values{flex-wrap:wrap;align-items:baseline;gap:2px 10px;display:flex}.subs__total-values .subs__total-value:not(:last-child):after{content:"·";color:var(--text-faint);margin-left:10px;font-weight:400}.modal-scrim{padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));overflow-y:auto}@media (width<=760px){.quick-add{left:0;right:0;bottom:calc(60px + env(safe-area-inset-bottom,0px));z-index:17;border-left:none;border-right:none;border-radius:0;margin:0;position:fixed;box-shadow:0 -6px 20px #0f172a1a}.content{padding-bottom:calc(150px + env(safe-area-inset-bottom,0px))}}.recheck{background:var(--accent-soft);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);border-radius:var(--r-lg);margin:4px 0 14px;padding:14px 16px}.recheck__head{color:var(--text);margin:0 0 10px;font-size:14px;font-weight:700}.recheck__list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.recheck__row{justify-content:space-between;align-items:center;gap:12px;display:flex}.recheck__name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.recheck__actions{flex:none;gap:8px;display:flex}.btn--sm{padding:6px 12px;font-size:13px}.toggle-row{cursor:pointer;justify-content:space-between;align-items:center;gap:16px;display:flex}.toggle-row--compact{padding:4px 0}.toggle-row__text{flex-direction:column;gap:3px;display:flex}.toggle-row__label{color:var(--text);font-size:14px;font-weight:600}.toggle-row__hint{color:var(--text-soft);font-size:12.5px;line-height:1.5}.toggle{appearance:none;border-radius:var(--r-pill);background:var(--border-strong);cursor:pointer;width:40px;height:24px;transition:background .15s var(--ease);flex:none;position:relative}.toggle:after{content:"";width:18px;height:18px;box-shadow:var(--shadow-sm);transition:transform .15s var(--ease);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.toggle:checked{background:var(--accent)}.toggle:checked:after{transform:translate(16px)}.toggle:focus-visible{box-shadow:0 0 0 3px var(--accent-soft);outline:none}
