: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 rgba(15, 23, 42, .06);--shadow-md: 0 6px 20px rgba(15, 23, 42, .1);--shadow-lg: 0 16px 48px rgba(15, 23, 42, .16);--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: #ffffff;--surface: #ffffff;--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: #ffffff;--danger: #dc2626;--success: #16a34a;--overlay: rgba(15, 23, 42, .32)}[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: #ffffff;--danger: #f87171;--success: #4ade80;--overlay: rgba(0, 0, 0, .55)}@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: rgba(0, 0, 0, .55)}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}::selection{background:var(--accent-soft)}.app{display:grid;grid-template-columns:264px 1fr;height:100%;overflow:hidden}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0;padding:18px 12px;gap:4px}.brand{display:flex;align-items:center;gap:10px;padding:6px 10px 16px}.brand__logo{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#9d7bff);display:grid;place-items:center;color:#fff;font-weight:700;box-shadow:var(--shadow-sm)}.brand__name{font-weight:700;font-size:16px;letter-spacing:-.01em}.nav{display:flex;flex-direction:column;gap:2px}.nav__label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);padding:14px 10px 6px;display:flex;align-items:center;justify-content:space-between}.nav__add{border:none;background:transparent;color:var(--text-faint);width:22px;height:22px;border-radius:var(--r-sm);display:grid;place-items:center;transition:.15s var(--ease)}.nav__add:hover{background:var(--surface-hover);color:var(--text)}.nav-item{display:flex;align-items:center;gap:10px;width:100%;border:none;background:transparent;color:var(--text-soft);padding:8px 10px;border-radius:var(--r-md);font-size:14px;font-weight:500;text-align:left;transition:.15s var(--ease)}.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{display:grid;place-items:center;width:18px;height:18px;flex:none}.nav-item__dot{width:10px;height:10px;border-radius:50%;flex:none}.nav-item__text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item__count{font-size:12px;font-weight:600;color:var(--text-faint);background:var(--surface-hover);border-radius:var(--r-pill);padding:1px 8px;min-width:22px;text-align:center}.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{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--bg)}.topbar{display:flex;align-items:center;gap:12px;padding:20px 32px 8px}.topbar__title{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:0}.topbar__subtitle{color:var(--text-soft);font-size:13px;margin:2px 0 0}.topbar__spacer{flex:1}.icon-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-soft);width:38px;height:38px;border-radius:var(--r-md);display:grid;place-items:center;transition:.15s var(--ease)}.icon-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border-strong)}.content{flex:1;min-height:0;overflow-y:auto;padding:12px 32px 48px}.content__inner{max-width:720px;margin:0 auto}.quick-add{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px 12px;margin:12px 0 18px;box-shadow:var(--shadow-sm);transition:.15s var(--ease)}.quick-add:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.quick-add__plus{color:var(--accent);display:grid;place-items:center;flex:none;border:none;background:transparent;padding:0;border-radius:var(--r-sm);transition:.15s var(--ease)}.quick-add__plus:hover{color:var(--text)}.quick-add__input{flex:1;border:none;outline:none;background:transparent;color:var(--text);font-size:15px;padding:4px 0}.quick-add__input::placeholder{color:var(--text-faint)}.quick-add__controls{display:flex;gap:6px;align-items:center}.chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);border-radius:var(--r-pill);padding:5px 11px;font-size:12.5px;font-weight:500;transition:.15s var(--ease)}.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]{border:none;background:transparent;color:inherit;font:inherit;outline:none;cursor:pointer}.task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.list-section__head{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint);margin:18px 0 6px;padding:0 4px}.task{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:var(--r-md);transition:background .15s var(--ease),opacity .2s var(--ease);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{-moz-appearance:none;appearance:none;-webkit-appearance:none;margin:1px 0 0;width:20px;height:20px;border:2px solid var(--border-strong);border-radius:50%;flex:none;display:grid;place-items:center;transition:.15s var(--ease);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:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) translate(-.5px,-1px)}.task__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.task__title{font-size:14.5px;line-height:1.4;color:var(--text);word-break:break-word}.task__meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.task__notes{font-size:12.5px;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;border-radius:var(--r-pill);padding:2px 8px;background:var(--surface-active);color:var(--text-soft)}.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{width:7px;height:7px;border-radius:50%}.task__delete{border:none;background:transparent;color:var(--text-faint);opacity:0;width:28px;height:28px;border-radius:var(--r-sm);display:grid;place-items:center;transition:.15s var(--ease);flex:none}.task__delete:hover{background:color-mix(in srgb,var(--danger) 14%,transparent);color:var(--danger)}.empty{text-align:center;padding:72px 24px;color:var(--text-soft)}.empty__art{width:64px;height:64px;margin:0 auto 16px;border-radius:var(--r-lg);background:var(--accent-soft);color:var(--accent);display:grid;place-items:center}.empty__title{font-size:17px;font-weight:600;color:var(--text);margin:0 0 4px}.empty__text{font-size:13.5px;margin:0}.sidebar__scrim{display:none}@media(max-width:760px){.app{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:264px;z-index:30;transform:translate(-100%);transition:transform .25s var(--ease);box-shadow:var(--shadow-lg)}.app--drawer-open .sidebar{transform:translate(0)}.app--drawer-open .sidebar__scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);z-index:20}.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{width:32px;height:32px;border-radius:var(--r-sm)}.cal{display:flex;flex-direction:column;gap:14px}.cal-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:6px}.cal-toolbar__nav{display:flex;align-items:center;gap:8px}.cal-toolbar__title{font-size:18px;font-weight:700;letter-spacing:-.01em;margin:0 0 0 6px}.cal-switch{display:inline-flex;background:var(--surface-active);border-radius:var(--r-md);padding:3px;gap:2px}.cal-switch__btn{border:none;background:transparent;color:var(--text-soft);font-size:13px;font-weight:600;padding:6px 14px;border-radius:7px;transition:.15s var(--ease)}.cal-switch__btn:hover{color:var(--text)}.cal-switch__btn--active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.cal-event{display:flex;align-items:center;gap:6px;width:100%;border:none;background:color-mix(in srgb,var(--event-color) 14%,transparent);color:var(--text);border-radius:6px;padding:3px 7px;font-size:12px;font-weight:500;text-align:left;transition:.12s var(--ease)}.cal-event:hover{background:color-mix(in srgb,var(--event-color) 26%,transparent)}.cal-event__dot{width:7px;height:7px;border-radius:50%;background:var(--event-color);flex:none}.cal-event__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-event--done .cal-event__title{text-decoration:line-through;color:var(--text-faint)}.cal-month{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--surface)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--sidebar-bg);border-bottom:1px solid var(--border)}.cal-weekday{padding:8px 10px;font-size:11.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint);text-align:left}.cal-month__grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(104px,1fr)}.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:6px;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:background .12s var(--ease);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{font-size:13px;font-weight:600;color:var(--text-soft);width:24px;height:24px;display:grid;place-items:center;border-radius:50%}.cal-cell__num--today{background:var(--accent);color:#fff}.cal-cell__events{display:flex;flex-direction:column;gap:3px;min-height:0}.cal-more{font-size:11px;font-weight:600;color:var(--text-faint);padding:1px 7px}.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.cal-week__col{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);min-height:320px;display:flex;flex-direction:column;overflow:hidden}.cal-week__head{border:none;background:var(--sidebar-bg);border-bottom:1px solid var(--border);padding:8px;display:flex;flex-direction:column;align-items:center;gap:2px;transition:.12s var(--ease)}.cal-week__head:hover{background:var(--surface-hover)}.cal-week__dow{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-faint)}.cal-week__day{font-size:17px;font-weight:700;color:var(--text);width:30px;height:30px;display:grid;place-items:center;border-radius:50%}.cal-week__head--today .cal-week__day{background:var(--accent);color:#fff}.cal-week__events{display:flex;flex-direction:column;gap:4px;padding:8px;overflow-y:auto}.cal-week__empty{color:var(--text-faint);text-align:center;font-size:13px;padding:8px 0}.cal-day{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:8px}.cal-year{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.cal-mini{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-md);padding:12px;text-align:left;transition:.15s var(--ease)}.cal-mini:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.cal-mini__name{font-size:13px;font-weight:700;color:var(--text);margin-bottom:8px}.cal-mini__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.cal-mini__day{font-size:10px;color:var(--text-soft);aspect-ratio:1;display:grid;place-items:center;border-radius:50%}.cal-mini__day--muted{color:transparent}.cal-mini__day--has{font-weight:700;color:var(--accent);background:var(--accent-soft)}.cal-mini__day--today{background:var(--accent);color:#fff;font-weight:700}@media(max-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{border:none;background:transparent;text-align:left;padding:0;cursor:pointer;color:inherit;font:inherit}.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{position:fixed;top:0;right:0;bottom:0;left:0;border:none;background:var(--overlay);z-index:40}.detail{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:100vw;background:var(--bg-elev);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:41;display:flex;flex-direction:column;animation:detail-in .2s var(--ease)}@keyframes detail-in{0%{transform:translate(16px);opacity:0}}.detail__head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}.detail__heading{font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint)}.detail__body{padding:18px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}.field__label{font-size:12px;font-weight:600;color:var(--text-soft)}.field__input{width:100%;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-md);padding:9px 11px;font-size:14px;outline:none;transition:.15s var(--ease)}.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{display:flex;gap:12px}.timer{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px}.timer__readout{display:flex;flex-direction:column}.timer__value{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.timer__sub{font-size:12px;color:var(--text-faint)}.btn{display:inline-flex;align-items:center;gap:7px;border:none;border-radius:var(--r-md);padding:9px 16px;font-size:14px;font-weight:600;transition:.15s var(--ease)}.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{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);background:transparent;color:var(--danger);border-radius:var(--r-md);padding:9px 14px;font-size:13.5px;font-weight:600;margin-top:4px;transition:.15s var(--ease)}.detail__delete:hover{background:color-mix(in srgb,var(--danger) 12%,transparent)}@media(max-width:760px){.detail{width:100vw}}.deadline{display:flex;flex-direction:column}.deadline>.cal-switch{margin:12px 0 10px;align-self:flex-start}.deadline__section{margin-bottom:6px}.cd{display:flex;flex-direction:column}.cd__bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:12px 0 14px}.cd__holidays{display:flex;align-items:center;gap:8px}.cd__country{width:auto;padding:8px 10px}.cd__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.cd-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;box-shadow:var(--shadow-sm);transition:.15s var(--ease)}.cd-card:hover{border-color:var(--border-strong)}.cd-card:hover .cd-card__actions{opacity:1}.cd-card--past{opacity:.6}.cd-card__emoji{font-size:26px;flex:none;width:40px;height:40px;display:grid;place-items:center;background:var(--surface-active);border-radius:var(--r-md)}.cd-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.cd-card__title{font-size:14.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cd-card__date{font-size:12.5px;color:var(--text-soft)}.cd-card__links{font-size:11.5px;color:var(--accent);font-weight:600}.cd-card__count{text-align:right;flex:none;display:flex;flex-direction:column;line-height:1.05}.cd-card__num{font-size:24px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;color:var(--accent)}.cd-card--past .cd-card__num{color:var(--text-faint)}.cd-card__label{font-size:11px;color:var(--text-faint)}.cd-card__actions{display:flex;flex-direction:column;gap:4px;flex:none;opacity:0;transition:.15s var(--ease)}.cd-card__delete:hover{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,var(--border))}.emoji-row{display:flex;flex-wrap:wrap;gap:6px}.emoji-pick{width:38px;height:38px;font-size:20px;border:1px solid var(--border);background:var(--surface);border-radius:var(--r-md);display:grid;place-items:center;transition:.12s var(--ease)}.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{display:flex;flex-direction:column;gap:2px;max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--r-md);padding:6px}.link-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--r-sm);font-size:13.5px;cursor:pointer}.link-row:hover{background:var(--surface-hover)}@media(max-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{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--text-soft);margin:18px 0 8px;padding:0 2px}.deadline__count{font-size:12px;font-weight:700;color:var(--text-faint);background:var(--surface-active);border-radius:var(--r-pill);padding:1px 9px;min-width:22px;text-align:center}.deadline__card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:6px;box-shadow:var(--shadow-sm)}.cd-card{flex-direction:column;align-items:stretch}.cd-card__row{display:flex;align-items:center;gap:12px}.cd-tasks{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.cd-tasks__head{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint);margin-bottom:6px}.cd-tasks__progress{color:var(--accent)}.cd-tasks__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.cd-task{display:flex;align-items:center;gap:9px;padding:4px 2px}.cd-task__title{font-size:13.5px;color:var(--text)}.cd-task__title--done{text-decoration:line-through;color:var(--text-faint)}.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{font-size:12px;color:var(--text-faint)}.field__hint{margin:0 0 6px;font-size:12.5px;color:var(--text-faint);line-height:1.45}.btn:disabled{opacity:.5;cursor:not-allowed}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);background:var(--text);color:var(--bg-elev);font-size:13.5px;font-weight:600;padding:10px 18px;border-radius:var(--r-pill);box-shadow:var(--shadow-lg);z-index:60;animation:toast-in .2s var(--ease)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}}.subs{display:flex;flex-direction:column;gap:6px}.subs__bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0 14px}.subs__total{display:flex;align-items:baseline;gap:6px}.subs__total-value{font-size:22px;font-weight:700;letter-spacing:-.01em}.subs__total-label{font-size:13px;color:var(--text-faint)}.subs__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.sub-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;box-shadow:var(--shadow-sm);transition:.15s var(--ease)}.sub-card:hover{border-color:var(--border-strong)}.sub-card__main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.sub-card__top{display:flex;align-items:center;gap:10px}.sub-card__name{font-size:15px;font-weight:600}.sub-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:13px;color:var(--text-soft)}.sub-card__cost{font-weight:600;color:var(--text)}.sub-card__sep{color:var(--text-faint)}.sub-card__actions{display:flex;gap:6px;flex:none}.sub-card__delete:hover{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,var(--border))}.sub-badge{font-size:11.5px;font-weight:700;border-radius:var(--r-pill);padding:2px 9px}.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{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);z-index:50;display:grid;place-items:center;padding:16px;animation:view-in .15s var(--ease)}.modal{width:100%;max-width:440px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.modal__body{padding:18px;display:flex;flex-direction:column;gap:14px}.modal__footer{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.btn--ghost{background:transparent;border:1px solid var(--border);color:var(--text-soft)}.btn--ghost:hover{background:var(--surface-hover);color:var(--text)}.form-error{margin:0;font-size:13px;color:var(--danger)}.habits{display:flex;flex-direction:column}.habits__bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0 14px}.habits__hint{font-size:13px;color:var(--text-faint);font-weight:600}.habits__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.habit-card{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px 12px;box-shadow:var(--shadow-sm);transition:.15s var(--ease)}.habit-card:hover{border-color:var(--border-strong)}.habit-card--met{background:color-mix(in srgb,var(--success) 7%,var(--surface))}.habit-card__body{flex:1;min-width:0;display:flex;align-items:center;gap:12px;border:none;background:transparent;text-align:left;cursor:pointer;color:inherit;font:inherit;padding:0}.habit-card__emoji{width:42px;height:42px;border-radius:var(--r-md);display:grid;place-items:center;font-size:22px;flex:none}.habit-card__info{display:flex;flex-direction:column;gap:3px;min-width:0}.habit-card__name{font-size:14.5px;font-weight:600}.habit-card__body:hover .habit-card__name{color:var(--accent)}.habit-card__meta{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--text-soft)}.habit-streak{display:inline-flex;align-items:center;gap:3px;color:#ea580c;font-weight:700}.habit-card__progress{font-variant-numeric:tabular-nums}.habit-check{width:40px;height:40px;flex:none;border-radius:50%;border:2px solid var(--border-strong);background:var(--surface);color:var(--text-faint);display:grid;place-items:center;transition:.15s var(--ease)}.habit-check:hover{border-color:var(--accent);color:var(--accent)}.habit-check:active{transform:scale(.92)}.habit-check--done{color:#fff}.habit-stats{display:flex;gap:10px}.habit-stat{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px;text-align:center;display:flex;flex-direction:column;gap:2px}.habit-stat__value{font-size:19px;font-weight:800;letter-spacing:-.01em;display:inline-flex;align-items:center;justify-content:center;gap:4px;color:var(--text)}.habit-stat:first-child .habit-stat__value{color:#ea580c}.habit-stat__label{font-size:11.5px;color:var(--text-faint)}.habit-checkin{display:flex;gap:8px}.habit-checkin .field__input{flex:1}.habit-history{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:2px}.habit-history__row{display:flex;align-items:center;gap:10px;padding:5px 4px;font-size:13px}.habit-history__date{font-weight:600;min-width:92px}.habit-history__note{flex:1;color:var(--text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task__icon{margin-right:6px}.tag__dot--bare{display:inline-block;width:9px;height:9px;border-radius:50%}.tag--label{background:var(--surface-active)}.tag-chips,.tag-filter{display:flex;flex-wrap:wrap;gap:6px}.tag-filter{margin:0 0 14px}.tag-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-soft);border-radius:var(--r-pill);padding:4px 11px;font-size:12.5px;font-weight:600;transition:.12s var(--ease)}.tag-chip:hover{background:var(--surface-hover)}.tag-new{display:flex;gap:8px;margin-top:8px}.link-btn{align-self:flex-start;margin-top:6px;border:none;background:transparent;color:var(--accent);font-size:12.5px;font-weight:600;padding:0}.link-btn:hover{text-decoration:underline}.swatch--input{padding:0;border:1px solid var(--border);background:var(--surface);cursor:pointer;inline-size:26px;block-size:26px}.swatch--input::-webkit-color-swatch-wrapper{padding:2px}.swatch--input::-webkit-color-swatch{border:none;border-radius:50%}.tags-page{display:flex;flex-direction:column;gap:10px;margin-top:12px}.tag-create{display:flex;align-items:center;gap:8px}.tag-create .field__input{flex:1}.tag-manage{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.tag-manage__row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:8px 10px}.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{display:flex;flex-direction:column;gap:10px}.habit-log__row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:12px 14px;box-shadow:var(--shadow-sm)}.habit-log__head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.habit-log__emoji{font-size:18px}.habit-log__name{font-weight:600;font-size:14px;flex:1}.habit-log__strip{display:flex;flex-wrap:wrap;gap:4px}.hl-day{width:26px;height:26px;border-radius:var(--r-sm);display:grid;place-items:center;font-size:11px;font-weight:600;color:var(--text-faint);background:var(--surface-active);font-variant-numeric:tabular-nums}.hl-day--today{outline:2px solid var(--accent);outline-offset:1px}.colorpick{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.colorpick__custom{position:relative;width:26px;height:26px;border-radius:50%;border:1px solid var(--border-strong);background:conic-gradient(from 0deg,#ef4444,#f59e0b,#16a34a,#0891b2,#4f46e5,#db2777,#ef4444);cursor:pointer;overflow:hidden;display:inline-block;transition:.12s var(--ease)}.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{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;border:none;padding:0;cursor:pointer}.nav-item__emoji{width:18px;flex:none;text-align:center;font-size:14px;line-height:1}.proj-progress{display:flex;flex-direction:column;gap:6px}.proj-progress__bar{height:8px;border-radius:var(--r-pill);background:var(--surface-active);overflow:hidden}.proj-progress__fill{display:block;height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--accent),#9d7bff);transition:width .3s var(--ease)}.proj-progress__meta{display:flex;justify-content:space-between;font-size:12.5px;color:var(--text-soft);font-weight:600}.modal__footer-spacer{flex:1}.pwa-toast{position:fixed;left:50%;bottom:calc(18px + env(safe-area-inset-bottom,0px));transform:translate(-50%);z-index:60;display:flex;align-items:center;gap:12px;padding:10px 12px 10px 16px;background:var(--text);color:var(--bg);border-radius:var(--r-pill);box-shadow:var(--shadow-lg);font-size:13px;font-weight:500;animation:pwa-rise .3s var(--ease)}.pwa-toast__btn{display:inline-flex;align-items:center;gap:6px;border:none;background:var(--accent);color:#fff;padding:6px 12px;border-radius:var(--r-pill);font-size:13px;font-weight:600;cursor:pointer;transition:.15s var(--ease)}.pwa-toast__btn:hover{filter:brightness(1.08)}.pwa-install{position:fixed;right:calc(20px + env(safe-area-inset-right,0px));bottom:calc(20px + env(safe-area-inset-bottom,0px));z-index:55;display:flex;align-items:center;gap:14px;width:min(380px,calc(100vw - 32px));padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);animation:pwa-rise .3s var(--ease)}.pwa-install__logo{flex:none;width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#9d7bff);display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px;box-shadow:var(--shadow-sm)}.pwa-install__body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.pwa-install__title{font-size:14px;font-weight:700}.pwa-install__text{font-size:12px;color:var(--text-soft);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(max-width:760px){.pwa-install{left:16px;right:16px;width:auto}}@media(max-width:1080px){.detail{width:min(420px,42vw)}}@media(max-width:480px){.topbar{padding:14px 16px 6px}.topbar__title{font-size:22px}.detail{width:100%}.cal-toolbar{gap:8px}.cal-switch{width:100%;justify-content:space-between}}@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{position:fixed;top:calc(12px + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);z-index:58;display:inline-flex;align-items:center;gap:8px;max-width:calc(100vw - 32px);padding:7px 14px;border-radius:var(--r-pill);font-size:13px;font-weight:600;pointer-events:none;box-shadow:var(--shadow-md);border:1px solid var(--border);animation:netbar-drop .28s var(--ease)}.netbar__dot{width:8px;height:8px;border-radius:50%;flex:none;background:currentColor}.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:transparent}.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:transparent}@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{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:1.05fr 1fr;background:var(--bg)}.auth__aside{position:relative;display:flex;flex-direction:column;justify-content:center;gap:18px;padding:64px;color:#fff;background:linear-gradient(150deg,var(--accent) 0%,#7c5cff 55%,#9d7bff 100%);overflow:hidden}.auth__aside:after{content:"";position:absolute;inset:auto -80px -120px auto;width:360px;height:360px;border-radius:50%;background:#ffffff1f;filter:blur(8px)}.auth__tagline{font-size:30px;line-height:1.2;font-weight:700;letter-spacing:-.02em;margin:0;max-width:15ch}.auth__sub{font-size:15px;line-height:1.55;margin:0;max-width:38ch;color:#ffffffd9}.auth__logo{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-weight:800;font-size:24px;color:#fff;background:#ffffff2e;border:1px solid rgba(255,255,255,.25)}.auth__logo--sm{width:44px;height:44px;font-size:20px;color:#fff;background:linear-gradient(135deg,var(--accent),#9d7bff);border:none;box-shadow:var(--shadow-md);margin-bottom:18px}.auth__card{display:flex;flex-direction:column;justify-content:center;width:100%;max-width:380px;margin:0 auto;padding:48px 40px}.auth__title{font-size:25px;font-weight:700;letter-spacing:-.02em;margin:0 0 4px}.auth__lede{color:var(--text-soft);font-size:14px;margin:0 0 26px}.auth__label{font-size:12px;font-weight:600;color:var(--text-soft);margin:14px 0 6px}.auth__input{width:100%;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-md);padding:11px 13px;font-size:14px;transition:.15s var(--ease)}.auth__input::placeholder{color:var(--text-faint)}.auth__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.auth__error{margin:14px 0 0;padding:9px 12px;border-radius:var(--r-md);font-size:13px;font-weight:500;color:#b91c1c;background:color-mix(in srgb,#ef4444 12%,transparent);border:1px solid color-mix(in srgb,#ef4444 30%,transparent)}.auth__submit{margin-top:22px;border:none;border-radius:var(--r-md);padding:12px 16px;font-size:14px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--accent),#7c5cff);cursor:pointer;transition:.15s var(--ease)}.auth__submit:hover:not(:disabled){filter:brightness(1.07)}.auth__submit:disabled{opacity:.6;cursor:default}.auth__switch{margin:18px 0 0;font-size:13px;color:var(--text-soft);text-align:center}.auth__toggle{border:none;background:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;padding:0}.auth__toggle:hover{text-decoration:underline}.auth-loading{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text-soft);font-size:14px}.auth-loading__spinner{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--accent);animation:auth-spin .7s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.usermenu{display:flex;align-items:center;gap:9px;padding:8px;border-top:1px solid var(--border)}.usermenu__avatar{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),#9d7bff)}.usermenu__email{flex:1;min-width:0;font-size:13px;font-weight:500;color:var(--text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usermenu__signout{flex:none;border:none;background:transparent;color:var(--text-faint);width:30px;height:30px;border-radius:var(--r-sm);display:grid;place-items:center;cursor:pointer;transition:.15s var(--ease)}.usermenu__signout:hover{background:var(--surface-hover);color:#ef4444}@media(max-width:760px){.auth{grid-template-columns:1fr}.auth__aside{display:none}.auth__card{padding:40px 24px}}.welcome{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:radial-gradient(1100px 520px at 50% -10%,var(--accent-soft),transparent 70%),var(--bg);overflow-y:auto}.welcome__nav{display:flex;align-items:center;justify-content:space-between;padding:20px clamp(20px,6vw,64px)}.welcome__brand{display:flex;align-items:center;gap:10px}.welcome__logo{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--accent),#9d7bff);box-shadow:var(--shadow-sm)}.welcome__brandname{font-weight:700;font-size:18px;letter-spacing:-.01em}.welcome__signin{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-md);padding:8px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s var(--ease)}.welcome__signin:hover{background:var(--surface-hover)}.welcome__hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;padding:clamp(40px,9vw,96px) clamp(20px,6vw,64px) 40px}.welcome__eyebrow{margin:0;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.welcome__title{margin:0;max-width:16ch;font-size:clamp(34px,6vw,56px);line-height:1.05;font-weight:800;letter-spacing:-.03em}.welcome__lede{margin:0;max-width:56ch;font-size:clamp(15px,2.4vw,18px);line-height:1.6;color:var(--text-soft)}.welcome__cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:10px}.welcome__btn{border:none;border-radius:var(--r-md);padding:13px 22px;font-size:15px;font-weight:600;cursor:pointer;transition:.15s var(--ease)}.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{display:grid;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}.welcome__feature{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-sm);transition:.15s var(--ease)}.welcome__feature:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.welcome__feature-icon{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;font-size:19px;background:var(--accent-soft);margin-bottom:12px}.welcome__feature-title{margin:0 0 5px;font-size:16px;font-weight:700}.welcome__feature-text{margin:0;font-size:14px;line-height:1.5;color:var(--text-soft)}.welcome__footer{margin-top:auto;padding:22px;text-align:center;font-size:13px;color:var(--text-faint)}.auth__back{align-self:flex-start;border:none;background:none;color:var(--text-soft);font-size:13px;font-weight:600;cursor:pointer;padding:0 0 14px}.auth__back:hover{color:var(--text)}.onb{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:20px;background:var(--overlay);animation:onb-fade .2s var(--ease)}.onb__card{position:relative;width:min(420px,100%);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:32px 28px 24px;text-align:center;animation:onb-rise .25s var(--ease)}.onb__skip{position:absolute;top:14px;right:16px;border:none;background:none;color:var(--text-faint);font-size:13px;font-weight:600;cursor:pointer}.onb__skip:hover{color:var(--text-soft)}.onb__icon{display:inline-grid;place-items:center;width:64px;height:64px;border-radius:18px;font-size:30px;background:var(--accent-soft);margin-bottom:18px}.onb__title{margin:0 0 8px;font-size:21px;font-weight:700;letter-spacing:-.02em}.onb__text{margin:0 auto;max-width:34ch;font-size:14px;line-height:1.6;color:var(--text-soft)}.onb__dots{display:flex;justify-content:center;gap:7px;margin:22px 0}.onb__dot{width:7px;height:7px;border-radius:50%;background:var(--border-strong);transition:.2s var(--ease)}.onb__dot--active{background:var(--accent);width:20px;border-radius:var(--r-pill)}.onb__actions{display:flex;justify-content:center;gap:10px}.onb__btn{border-radius:var(--r-md);padding:11px 22px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:.15s var(--ease)}.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{display:flex;align-items:center;gap:10px}.langswitch{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--r-md);padding:8px 30px 8px 12px;font-size:13px;font-weight:600;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) 50%,calc(100% - 11px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.langswitch:hover{background-color:var(--surface-hover)}.langswitch:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.auth__forgot{align-self:flex-end;border:none;background:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;margin-top:12px;padding:0}.auth__forgot:hover{text-decoration:underline}.auth__notice{margin-top:18px;padding:12px 14px;border-radius:var(--r-md);font-size:14px;line-height:1.5;color:#166534;background:color-mix(in srgb,#16a34a 12%,transparent);border:1px solid color-mix(in srgb,#16a34a 30%,transparent)}.sidebar__foot{display:flex;flex-direction:column;gap:8px}.langswitch--block{width:100%}.holiday-actions{display:flex;gap:14px;margin:4px 0 8px}.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%{transform:translateY(28px);opacity:0}}@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(max-width:760px){.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:18;display:flex;align-items:stretch;gap:2px;padding:6px 10px calc(6px + env(safe-area-inset-bottom,0px));background:var(--bg-elev);border-top:1px solid var(--border);box-shadow:0 -4px 16px #0f172a0f}.mobile-nav__btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:48px;border:none;background:transparent;color:var(--text-faint);font-size:10.5px;font-weight:600;border-radius:var(--r-md);transition:.15s var(--ease)}.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{top:auto;left:0;right:0;bottom:0;width:100%;max-height:88dvh;border-left:none;border-top:1px solid var(--border);border-radius:20px 20px 0 0;padding-bottom:env(safe-area-inset-bottom,0px);animation:sheet-up .25s var(--ease)}.detail__head{position:relative;padding-top:22px}.detail__head:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;border-radius:var(--r-pill);background:var(--border-strong)}}@media(max-width:480px){.cal-month__grid{grid-auto-rows:minmax(58px,1fr)}.cal-cell{padding:4px 3px;gap:3px}.cal-cell__num{width:22px;height:22px;font-size:12px}.cal-cell__events{flex-direction:row;flex-wrap:wrap;gap:3px;padding:0 2px}.cal-event{width:auto;padding:2px;background:transparent}.cal-event__title{display:none}.cal-event__dot{width:8px;height:8px}.cal-more{font-size:10px;padding:0 2px}.field-row{flex-direction:column;gap:14px}.habit-stats{flex-wrap:wrap}.modal-scrim{place-items:end stretch;padding:0}.modal{max-width:none;border-radius:20px 20px 0 0;border-bottom:none;max-height:92dvh;padding-bottom:env(safe-area-inset-bottom,0px);animation:sheet-up .25s var(--ease)}}@media(prefers-reduced-motion:reduce){.detail,.modal,.checkbox:checked{animation:none}}.auth__beta{display:flex;align-items:center;gap:10px;margin:-16px 0 22px}.auth__beta-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;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);padding:3px 10px}.auth__beta-spots{font-size:12.5px;font-weight:600;color:var(--text-soft)}.auth__input--code{font-family:Courier New,monospace;font-weight:700;letter-spacing:.08em;text-transform:uppercase}@media(max-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));border-radius:0 22px 22px 0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.sidebar .brand{padding-bottom:18px}.sidebar .brand__logo{width:32px;height:32px}.sidebar .nav-item{padding:12px;font-size:15px;border-radius:12px}.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)}}
