.app{max-width:600px;margin:0 auto;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.page-loading{display:flex;align-items:center;justify-content:center;min-height:50vh}.init-spinner{width:36px;height:36px;border:3px solid color-mix(in srgb,var(--accent) 20%,transparent);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-header{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:12px 20px;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--border)}.header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.header-actions{display:flex;align-items:center;gap:6px}.app-header h1{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.3px}.theme-btn,.settings-btn{width:38px;height:38px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:transparent;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--text-2)}.theme-btn:hover,.settings-btn:hover{background:var(--hover);color:var(--text);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:19}.settings-menu{position:absolute;top:100%;right:20px;background:var(--bg-modal);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-strong);border-radius:var(--radius-lg);overflow:hidden;z-index:20;min-width:160px;animation:fadeIn .15s ease;box-shadow:var(--shadow-lg)}.settings-item{display:block;width:100%;padding:13px 18px;border:none;background:transparent;font-size:14px;text-align:left;color:var(--text-2);transition:all .15s}.settings-item:hover{background:var(--hover);color:var(--text)}.settings-group{padding:4px 0}.settings-group+.settings-group{border-top:1px solid var(--border-strong)}.settings-group-label{padding:8px 18px 4px;font-size:11px;font-weight:600;color:var(--text-3);letter-spacing:.5px;text-transform:uppercase}.settings-version{padding:6px 18px 8px;font-size:11px;color:var(--text-3);text-align:center}.app-bottom-nav{display:flex;flex-shrink:0;width:100%;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-strong);z-index:50;padding:4px 8px;padding-bottom:calc(4px + env(safe-area-inset-bottom,0));gap:4px}.app-bottom-nav .nav-btn{flex:1;padding:6px 8px 5px;border:none;background:transparent;font-size:11px;color:var(--text-3);transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;display:flex;flex-direction:column;align-items:center;gap:2px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:12px;position:relative}.app-bottom-nav .nav-btn.active{color:var(--accent);font-weight:600;background:color-mix(in srgb,var(--accent) 10%,transparent)}.app-bottom-nav .nav-icon{display:flex;align-items:center;justify-content:center;height:22px;transition:transform .2s ease}.app-bottom-nav .nav-btn.active .nav-icon{transform:scale(1.1)}.app-bottom-nav .nav-label{line-height:1;font-size:10px;letter-spacing:.2px}@media(hover:hover){.app-bottom-nav .nav-btn:hover:not(.active){color:var(--text-2);background:var(--hover)}}.app-main{flex:1;padding:20px;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}button,.tg-slot,.bar-slot,.sq,.activity-item{touch-action:manipulation}.category-picker{display:flex;gap:8px;flex-wrap:wrap}.cat-btn{display:flex;align-items:center;gap:4px;padding:8px 16px;border:1.5px solid var(--cat-color);border-radius:var(--radius-md);background:transparent;font-size:14px;color:var(--cat-color);transition:all .2s}.cat-btn:hover{transform:translateY(-1px)}.cat-btn.active{background:var(--cat-color);color:var(--btn-text);box-shadow:0 2px 8px color-mix(in srgb,var(--cat-color) 40%,transparent)}.cat-emoji{font-size:14px}.cm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:flex-end;justify-content:center;background:var(--overlay);animation:fadeIn .15s ease}.cm-card{background:var(--bg-modal);border:1px solid var(--border-strong);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:600px;max-height:80vh;overflow-y:auto;animation:slideUp .25s ease;padding-bottom:calc(16px + var(--kb-h, 0px));box-shadow:var(--shadow-lg)}.cm-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-modal);z-index:1}.cm-title{font-size:17px;font-weight:700;color:var(--text)}.cm-close{width:30px;height:30px;border:none;border-radius:50%;background:var(--hover);color:var(--text-2);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}.cm-close:hover{background:var(--hover-strong);color:var(--text)}.cm-body{padding:18px;display:flex;flex-direction:column;gap:12px}.cm-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--border)}.cm-row.archived{opacity:.5}.cm-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.cm-emoji{font-size:16px;flex-shrink:0}.cm-label{flex:1;font-size:14px;color:var(--text)}.cm-edit-btn,.cm-del-btn{width:36px;height:36px;border:none;border-radius:var(--radius-md);background:transparent;font-size:15px;color:var(--text-3);display:flex;align-items:center;justify-content:center;transition:all .15s}.cm-edit-btn:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.cm-del-btn:hover{background:var(--hover);color:var(--text)}.cm-sort-btns{display:flex;flex-direction:column;gap:0;margin-right:4px}.cm-sort-btn{width:22px;height:18px;border:none;border-radius:3px;background:transparent;font-size:10px;color:var(--text-3);display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1}.cm-sort-btn:hover{background:var(--hover);color:var(--text)}.cm-restore-btn{padding:3px 10px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:transparent;font-size:12px;color:var(--text-2);transition:all .15s}.cm-restore-btn:hover{border-color:var(--text-3);color:var(--text)}.cm-archived{font-size:13px;color:var(--text-3);padding:8px 0}.cm-archived summary{cursor:pointer;color:var(--text-2)}.cm-add-btn{width:100%;padding:12px;border:1.5px dashed var(--border-strong);border-radius:var(--radius-md);background:transparent;font-size:14px;color:var(--text-2);transition:all .15s}.cm-add-btn:hover{border-color:var(--text-3);color:var(--text)}.cm-add-form{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--hover);border-radius:var(--radius-md)}.cm-input{padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:16px;background:var(--input-bg);color:var(--text);transition:border-color .15s}.cm-input:focus{outline:none;border-color:var(--accent)}.cm-colors{display:flex;gap:6px;flex-wrap:wrap}.cm-color-btn{width:28px;height:28px;border:2px solid transparent;border-radius:50%;transition:transform .15s}.cm-color-btn.selected{border-color:var(--text);transform:scale(1.2)}.cm-emojis{display:flex;gap:6px;flex-wrap:wrap}.cm-emoji-btn{width:32px;height:32px;border:1.5px solid transparent;border-radius:var(--radius-sm);background:transparent;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}.cm-emoji-btn.selected{border-color:var(--text-3);background:var(--hover)}.cm-add-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.cm-edit-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:210;display:flex;align-items:center;justify-content:center;background:var(--overlay)}.cm-edit-card{background:var(--bg-modal);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:18px;width:300px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-lg)}.cm-edit-card h4{font-size:16px;font-weight:700;margin:0;color:var(--text)}.pref-section{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.pref-label{font-size:15px;font-weight:600;color:var(--text)}.pref-desc{font-size:13px;color:var(--text-3);margin:0}.pref-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.pref-tab-btn{padding:10px;border:1.5px solid var(--border-strong);border-radius:var(--radius-md);background:transparent;font-size:14px;color:var(--text-2);transition:all .15s;font-family:inherit}.pref-tab-btn.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 20%,transparent)}.pref-tab-btn:hover:not(.active){border-color:var(--text-3);color:var(--text)}.pref-toggle{width:44px;height:24px;border-radius:12px;border:none;padding:2px;background:var(--border);cursor:pointer;transition:background .2s;position:relative;align-self:flex-start}.pref-toggle.on{background:var(--accent)}.pref-toggle-knob{display:block;width:20px;height:20px;border-radius:50%;background:var(--bg-card);transition:transform .2s;box-shadow:var(--shadow-sm)}.pref-toggle.on .pref-toggle-knob{transform:translate(20px)}.goal-settings{display:flex;flex-direction:column;gap:8px}.goal-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--hover);transition:opacity .2s}.goal-row-off{opacity:.4}.goal-toggle{width:34px;height:18px;border-radius:9px;border:none;background:var(--border);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;padding:0}.goal-toggle.on{background:var(--accent)}.goal-toggle-knob{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--bg-card);box-shadow:var(--shadow-sm);transition:transform .2s}.goal-toggle.on .goal-toggle-knob{transform:translate(16px)}.goal-row-label{font-size:14px;color:var(--text);flex:1;flex-shrink:0}.goal-row-input{width:56px;padding:6px 8px;text-align:center;border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text);font-size:16px;font-family:inherit}.goal-row-input:focus{border-color:var(--accent);outline:none}.goal-row-input:disabled{opacity:.4;cursor:not-allowed}.goal-row-unit{font-size:12px;color:var(--text-3);flex-shrink:0}.backup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:flex-end;justify-content:center;background:var(--overlay);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.backup-card{background:var(--bg-modal);border:1px solid var(--border-strong);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:600px;overflow:hidden;animation:slideUp .25s ease;box-shadow:var(--shadow-lg)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.backup-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}.backup-title{font-size:17px;font-weight:700;color:var(--text)}.backup-close{width:30px;height:30px;border:none;border-radius:50%;background:var(--hover);color:var(--text-2);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}.backup-close:hover{background:var(--hover-strong)}.backup-body{padding:18px}.backup-desc{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:16px}.backup-actions{display:flex;flex-direction:column;gap:10px}.backup-action-btn{width:100%;padding:14px;border:none;border-radius:var(--radius-md);font-size:15px;font-weight:500;transition:all .2s}.backup-action-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.export-btn{background:var(--accent-gradient);color:var(--btn-text)}.export-btn:hover{opacity:.95}.import-btn{background:var(--hover);color:var(--text)}.import-btn:hover{background:var(--hover-strong)}.backup-msg{margin-top:12px;padding:10px;border-radius:var(--radius-sm);font-size:13px;text-align:center}.backup-msg.success{background:var(--success-bg);color:var(--success-text)}.backup-msg.error{background:var(--danger-bg);color:var(--danger-text)}.cat-picker{display:flex;flex-wrap:wrap;gap:6px}.cat-pick-btn{padding:6px 14px;border:1.5px solid var(--cat-color);border-radius:var(--radius-md);background:transparent;font-size:13px;font-weight:500;color:var(--cat-color);transition:all .15s;white-space:nowrap;opacity:.65}.cat-pick-btn.active{opacity:1;background:color-mix(in srgb,var(--cat-color) 12%,transparent)}.date-nav{display:flex;align-items:center;justify-content:space-between;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:5px 6px}.date-btn{width:36px;height:36px;border:none;background:var(--hover);border-radius:var(--radius-md);font-size:15px;color:var(--text-2);display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:pointer;font-weight:600}.date-btn:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.date-btn:active{transform:scale(.92)}.date-btn:disabled{opacity:.2;pointer-events:none;background:transparent}.date-info{display:flex;align-items:center;gap:10px}.date-text{font-size:15px;font-weight:700;color:var(--text);transition:color .2s}.date-text-btn{background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.date-text-btn:hover .date-text{color:var(--accent)}.date-text.historical{color:var(--text-2)}.today-btn{font-size:11px;padding:5px 14px;border:1.5px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:20px;background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--accent);transition:all .25s;font-weight:700;letter-spacing:.5px}.today-btn:hover{background:var(--accent);color:var(--btn-text);border-color:var(--accent)}.plan-page{display:flex;flex-direction:column;gap:14px;background:linear-gradient(180deg,var(--plan-accent-glow) 0%,transparent 120px);margin:-20px;padding:14px 20px 20px;border-radius:0}.plan-summary{display:flex;gap:8px;background:var(--plan-card-bg);border:1px solid var(--plan-card-border);border-radius:var(--radius-xl);padding:12px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.plan-summary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 0%,var(--accent) 0%,transparent 70%);opacity:.04;pointer-events:none}.plan-summary-item{text-align:center;position:relative;flex:1}.plan-summary-divider{display:none}.plan-filter-btn{background:transparent;border:1.5px solid transparent;padding:10px 6px;border-radius:var(--radius-lg);cursor:pointer;transition:all .25s;width:100%}.plan-filter-btn:hover{background:var(--hover)}.plan-filter-btn.active{background:color-mix(in srgb,var(--accent) 8%,transparent);border-color:color-mix(in srgb,var(--accent) 20%,transparent);box-shadow:0 2px 12px color-mix(in srgb,var(--accent) 10%,transparent)}.plan-summary-val{font-size:26px;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.5px;line-height:1;transition:all .3s}.plan-filter-btn.active .plan-summary-val{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transform:scale(1.05)}.plan-summary-lbl{font-size:11px;color:var(--text-3);margin-top:6px;font-weight:600;letter-spacing:.5px;transition:color .2s}.plan-filter-btn.active .plan-summary-lbl{color:var(--accent)}.plan-sticky-bar{display:flex;flex-direction:column;gap:4px;padding:2px 0}.plan-date-filter{display:flex;align-items:center;gap:2px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:4px}.plan-date-btn,.plan-date-pick-btn{flex:1;padding:7px 10px;border:none;border-radius:14px;background:transparent;font-size:12px;color:var(--text-2);font-weight:600;cursor:pointer;transition:all .25s;white-space:nowrap;letter-spacing:.3px;text-align:center;display:flex;align-items:center;justify-content:center;gap:4px}.plan-date-btn:hover,.plan-date-pick-btn:hover{background:var(--hover);color:var(--text)}.plan-date-btn.active,.plan-date-pick-btn.active{color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);box-shadow:0 1px 6px color-mix(in srgb,var(--accent) 12%,transparent)}.plan-date-clear{width:28px;height:28px;border:none;border-radius:50%;background:var(--hover);color:var(--text-3);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;margin-left:2px}.plan-date-clear:hover{background:var(--danger-bg);color:var(--danger-text)}.plan-tools{display:flex;gap:6px;align-items:center;margin-top:10px;width:100%}.plan-search-box{flex:1;min-width:0;display:flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--border);border-radius:20px;background:var(--bg-card);color:var(--text-3);transition:border-color .2s,box-shadow .2s}.plan-search-box:focus-within{border-color:color-mix(in srgb,var(--accent) 40%,var(--border));box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 8%,transparent)}.plan-search-input{flex:1;border:none;background:transparent;font-size:16px;color:var(--text);font-family:inherit;outline:none;min-width:0}.plan-search-input::placeholder{color:var(--empty);font-size:12px;font-weight:500}.plan-search-clear{width:20px;height:20px;border:none;border-radius:50%;background:var(--hover);color:var(--text-3);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.plan-sort-btn{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--bg-card);font-size:12px;color:var(--text-2);font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;letter-spacing:.2px;flex-shrink:0}.plan-sort-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,transparent)}.plan-sort-btn.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.plan-copy-btn{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--bg-card);font-size:12px;color:var(--text-2);font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0;letter-spacing:.2px;margin-left:auto}.plan-copy-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,transparent)}.pin-separator{display:flex;align-items:center;gap:10px;padding:8px 0 4px}.pin-separator:first-child{padding-top:0}.pin-separator:after{content:"";flex:1;height:1px;background:var(--border)}.pin-separator-label{font-size:11px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.plan-task-list{display:flex;flex-direction:column;gap:8px;padding-bottom:80px}.plan-empty{text-align:center;color:var(--empty);font-size:14px;padding:48px 0;font-weight:500}.task-card{background:var(--plan-card-bg);border:1px solid var(--plan-card-border);border-radius:var(--radius-lg);padding:16px;display:flex;align-items:flex-start;gap:10px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm),inset 0 1px #fff6;position:relative;overflow:hidden}.task-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--card-accent, var(--accent));border-radius:0 3px 3px 0;opacity:.4;transition:opacity .2s,width .2s}.task-card:hover{border-color:color-mix(in srgb,var(--accent) 20%,var(--border));transform:translateY(-2px);box-shadow:var(--shadow-md),0 4px 16px color-mix(in srgb,var(--accent) 8%,transparent)}.task-card:hover:before{opacity:.8;width:3px}.task-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.task-card-meta{display:flex;align-items:center;gap:6px}.task-meta-spacer{flex:1}.task-title-row{display:flex;align-items:flex-start;flex-wrap:wrap;gap:2px}.task-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.task-title{font-size:15px;color:var(--text);white-space:pre-wrap;word-break:break-word;line-height:1.5}.task-title.done{text-decoration:line-through;color:var(--text-3)}.task-priority{font-size:10px;font-weight:600;padding:2px 6px;border:1px solid var(--text-3);border-radius:var(--radius-sm);flex-shrink:0;line-height:1.4}.task-date{font-size:10px;color:var(--text-3);background:var(--tag-bg);padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0;white-space:nowrap}.task-insight{font-size:10px;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0;white-space:nowrap;color:var(--color-warning);border:1px solid var(--color-warning);background:var(--color-warning-light)}.task-timestamp{font-size:10px;color:var(--accent-text);background:var(--accent-light);padding:2px 6px;border-radius:var(--radius-sm);flex-shrink:0;white-space:nowrap;font-variant-numeric:tabular-nums}.task-meta{font-size:12px;color:var(--text-3);white-space:nowrap;flex-shrink:0}.task-copy-btn{width:24px;height:24px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-3);display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.task-copy-btn:hover{background:var(--hover);color:var(--text)}.task-pin-btn{width:24px;height:24px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-3);display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;margin-right:8px}.task-pin-btn:hover:not(:disabled){background:var(--hover);color:var(--text)}.task-pin-btn.pinned{color:var(--accent)}.task-pin-btn:disabled{opacity:.3;cursor:default}.task-check{width:24px;height:24px;border:2px solid var(--text-3);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;color:transparent;transition:all .2s}.task-check.checked{background:var(--color-success);border-color:transparent;color:var(--btn-text);box-shadow:0 2px 8px #22c55e4d}.task-form-overlay{position:fixed;top:var(--vv-top, 0px);left:0;right:0;height:var(--vv-height, 100dvh);z-index:150;display:flex;flex-direction:column;background:var(--bg);animation:fadeIn .15s ease;transition:height .28s ease-out;padding-top:56px}.task-form-card{flex:1;display:flex;flex-direction:column;background:var(--bg);overflow:hidden;animation:slideUp .25s ease}.task-form-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:18px 20px;padding-top:max(18px,env(safe-area-inset-top));border-bottom:1px solid var(--border)}.task-form-title{font-size:17px;font-weight:700;color:var(--text)}.task-form-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px;-webkit-overflow-scrolling:touch;padding-bottom:calc(max(18px,env(safe-area-inset-bottom)) + var(--kb-h, 0px))}.task-form-body input,.task-form-body select,.task-form-body textarea{width:100%;padding:12px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-md);font-size:16px;background:var(--input-bg);color:var(--text);transition:border-color .15s,box-shadow .15s;font-family:inherit}.task-form-body input:focus,.task-form-body select:focus,.task-form-body textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent)}.task-title-input{resize:none;overflow:hidden;min-height:52px;max-height:200px;line-height:1.5;font-family:inherit;overflow-y:auto;-webkit-overflow-scrolling:touch}.task-form-body label{font-size:13px;color:var(--text-2);display:block;margin-bottom:6px;font-weight:500}.task-form-body .form-group{display:flex;flex-direction:column}.task-form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.priority-picker{display:flex;gap:8px}.priority-btn{flex:1;padding:10px;border:1.5px solid var(--border-strong);border-radius:var(--radius-md);background:transparent;font-size:14px;font-weight:600;color:var(--text-2);transition:all .2s}.priority-btn.active{color:var(--pri-color);border-color:var(--pri-color);background:color-mix(in srgb,var(--pri-color) 10%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--pri-color) 20%,transparent)}.priority-btn:hover:not(.active){border-color:var(--text-3);color:var(--text);transform:translateY(-1px)}.emotion-picker{display:flex;flex-wrap:wrap;gap:6px}.emotion-btn{padding:6px 12px;border:1.5px solid var(--border-strong);border-radius:20px;background:transparent;font-size:13px;font-weight:600;color:var(--text-2);transition:all .15s;white-space:nowrap}.emotion-btn.active{color:var(--emo-color);border-color:var(--emo-color);background:var(--emo-bg);box-shadow:0 0 0 1px color-mix(in srgb,var(--emo-color) 20%,transparent)}.emotion-btn:hover:not(.active){border-color:var(--text-3);background:var(--hover)}.task-emotion-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.emotion-tag{font-size:10px;font-weight:600;padding:2px 8px;border-radius:12px;white-space:nowrap}.emotion-report{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm)}.recycle-list{display:flex;flex-direction:column;gap:6px;margin-top:10px;max-height:200px;overflow-y:auto}.recycle-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--hover);border-radius:var(--radius-md);gap:8px}.recycle-item-info{display:flex;flex-direction:column;min-width:0;flex:1}.recycle-item-title{font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recycle-item-date{font-size:11px;color:var(--text-3);margin-top:2px}.dp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:var(--overlay);animation:fadeIn .15s ease}.dp-card{background:var(--bg-modal);border:1px solid var(--border-strong);border-radius:var(--radius-xl);width:320px;max-width:90vw;padding:20px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.dp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.dp-nav{width:36px;height:36px;border:1px solid var(--border);border-radius:50%;background:var(--bg-card);font-size:18px;color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.dp-nav:hover{background:var(--hover);border-color:var(--border-strong);color:var(--text)}.dp-title{font-size:16px;font-weight:700;color:var(--text)}.dp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}.dp-weekday{text-align:center;font-size:11px;font-weight:600;color:var(--text-3);padding:4px 0}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dp-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:14px;border-radius:50%;border:none;background:transparent;color:var(--text);cursor:pointer;transition:all .12s;font-family:inherit}.dp-empty{cursor:default}.dp-day:hover{background:var(--hover)}.dp-day.today{font-weight:700;color:var(--accent);border:1.5px solid color-mix(in srgb,var(--accent) 40%,transparent)}.dp-day.selected{background:var(--accent);color:var(--btn-text);font-weight:700;box-shadow:0 2px 8px color-mix(in srgb,var(--accent) 40%,transparent)}.dp-day.selected:hover{opacity:.9}.fab{position:fixed;bottom:max(96px,calc(76px + env(safe-area-inset-bottom,0px)));left:0;right:0;margin:0 auto;width:54px;height:54px;border:none;border-radius:50%;background:var(--accent-gradient);color:var(--btn-text);font-size:26px;font-weight:300;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px color-mix(in srgb,var(--accent) 35%,transparent),var(--shadow-md);z-index:50;transition:all .2s;transform:translateZ(0);-webkit-transform:translateZ(0)}.fab:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 8px 30px color-mix(in srgb,var(--accent) 40%,transparent),var(--shadow-lg)}.scroll-top-btn{position:fixed;bottom:max(78px,calc(58px + env(safe-area-inset-bottom,0px)));left:20px;width:40px;height:40px;border:1px solid var(--border);border-radius:50%;background:var(--bg-card);color:var(--text-2);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);z-index:49;transition:all .2s;animation:fadeIn .2s ease;transform:translateZ(0);-webkit-transform:translateZ(0)}.scroll-top-btn:hover{background:var(--hover);color:var(--text);transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media(max-width:420px){.app-header{padding:10px 14px}.app-header h1{font-size:18px}.header-top{margin-bottom:0}.settings-btn,.theme-btn{width:34px;height:34px;font-size:16px}.app-main{padding:14px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.settings-menu{right:14px}.plan-page{margin:-14px;padding:10px 14px 14px}.plan-summary{padding:10px;gap:4px}.plan-summary-val{font-size:22px}.plan-filter-btn{padding:8px 4px}.task-card{padding:14px}.task-title{font-size:14px}.fab{width:48px;height:48px;font-size:22px}.cat-btn{padding:7px 14px;font-size:13px}.scroll-top-btn{left:14px;width:36px;height:36px}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--bg: #f4f5f8;--bg-card: #ffffff;--bg-modal: #ffffff;--text: #0f172a;--text-2: #64748b;--text-3: #94a3b8;--border: rgba(0,0,0,.06);--border-light: rgba(0,0,0,.03);--border-strong: rgba(0,0,0,.08);--overlay: rgba(15,23,42,.45);--input-bg: #f8fafc;--btn: #0f172a;--btn-text: #ffffff;--btn-cancel-bg: #f1f5f9;--btn-cancel-text: #475569;--btn-danger-bg: #fee2e2;--btn-danger-hover: #fecaca;--btn-disabled: #e2e8f0;--btn-disabled-text: #94a3b8;--accent: #6366f1;--accent-gradient: linear-gradient(135deg, #6366f1, #818cf8);--accent-light: rgba(99,102,241,.08);--accent-text: #6366f1;--color-success: #22c55e;--color-success-light: rgba(34,197,94,.08);--color-success-text: #16a34a;--color-danger: #ef4444;--color-danger-light: rgba(239,68,68,.08);--color-danger-text: #dc2626;--color-warning: #f59e0b;--color-warning-light: rgba(245,158,11,.08);--color-warning-text: #d97706;--color-info: #3b82f6;--color-info-light: rgba(59,130,246,.08);--hover: rgba(99,102,241,.06);--hover-strong: rgba(99,102,241,.12);--pressed: rgba(99,102,241,.18);--tag-bg: #e2e8f0;--tag-text: #475569;--scrollbar: rgba(0,0,0,.08);--shadow-sm: 0 1px 2px rgba(15,23,42,.04), 0 1px 1px rgba(15,23,42,.02);--shadow-md: 0 4px 12px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);--shadow-lg: 0 12px 32px rgba(15,23,42,.1), 0 2px 8px rgba(15,23,42,.04);--shadow: var(--shadow-sm);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--empty: #cbd5e1;--glass-bg: rgba(255,255,255,.82);--danger-bg: #fee2e2;--danger-text: #dc2626;--success-bg: #dcfce7;--success-text: #16a34a;--plan-card-bg: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);--plan-card-border: rgba(99,102,241,.06);--plan-accent-glow: rgba(99,102,241,.04)}[data-theme=dark]{--bg: #050507;--bg-card: #0f0f12;--bg-modal: #141418;--text: #e4e4e7;--text-2: #71717a;--text-3: #52525b;--border: rgba(255,255,255,.08);--border-light: rgba(255,255,255,.04);--border-strong: rgba(255,255,255,.12);--overlay: rgba(0,0,0,.7);--input-bg: rgba(255,255,255,.05);--btn: #e4e4e7;--btn-text: #0a0a0c;--btn-cancel-bg: rgba(255,255,255,.06);--btn-cancel-text: #e4e4e7;--btn-danger-bg: #ef4444;--btn-danger-hover: #dc2626;--btn-disabled: rgba(255,255,255,.1);--btn-disabled-text: rgba(255,255,255,.25);--accent: #818cf8;--accent-gradient: linear-gradient(135deg, #818cf8, #a78bfa);--accent-light: rgba(129,140,248,.12);--accent-text: #818cf8;--color-success: #4ade80;--color-success-light: rgba(34,197,94,.1);--color-success-text: #4ade80;--color-danger: #f87171;--color-danger-light: rgba(239,68,68,.12);--color-danger-text: #f87171;--color-warning: #fbbf24;--color-warning-light: rgba(245,158,11,.15);--color-warning-text: #fbbf24;--color-info: #60a5fa;--color-info-light: rgba(59,130,246,.15);--hover: rgba(129,140,248,.08);--hover-strong: rgba(129,140,248,.14);--pressed: rgba(129,140,248,.2);--tag-bg: #27272a;--tag-text: #a1a1aa;--scrollbar: rgba(255,255,255,.08);--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 0 1px rgba(255,255,255,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.4), 0 0 1px rgba(255,255,255,.05);--shadow-lg: 0 12px 40px rgba(0,0,0,.5), 0 0 1px rgba(255,255,255,.05);--shadow: var(--shadow-sm);--empty: #3f3f46;--glass-bg: rgba(18,18,24,.92);--danger-bg: rgba(239,68,68,.12);--danger-text: #f87171;--success-bg: rgba(34,197,94,.1);--success-text: #4ade80;--plan-card-bg: linear-gradient(135deg, #141418 0%, #0f0f12 100%);--plan-card-border: rgba(129,140,248,.1);--plan-accent-glow: rgba(129,140,248,.06)}input,textarea,select{font-size:16px;-webkit-appearance:none}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Helvetica Neue,sans-serif;color:var(--text);background:var(--bg);transition:background .3s ease,color .3s ease}body{background:var(--bg);overscroll-behavior:none;overflow-x:hidden}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:4px}::-webkit-scrollbar-track{background:transparent}
