*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--bg: #1e1e1e;--bg-elev: #2a2a2a;--bg-elev-2: #353535;--border: #3a3a3a;--text: #f0f0f0;--text-muted: #9b9b9b;--text-dim: #6b6b6b;--primary: #ff6363;--primary-hover: #ff7676;--success: #4caf50;--error: #f44336;--warning: #ff9800;--radius: 10px;--radius-sm: 6px;--gap: 14px;--safe-top: env(safe-area-inset-top, 0);--safe-bottom: env(safe-area-inset-bottom, 0)}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Inter,system-ui,sans-serif;font-size:16px;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;cursor:pointer}input,textarea,select{font-family:inherit;font-size:16px;color:var(--text);background:transparent;border:none;outline:none}input::placeholder,textarea::placeholder{color:var(--text-dim)}hr{border:none;border-top:1px solid var(--border);margin:8px 0}.muted{color:var(--text-muted)}.small{font-size:13px}code{background:var(--bg-elev);padding:2px 5px;border-radius:4px;font-size:13px}.setup-warning{background:#ff98001a;border:1px solid var(--warning);border-radius:var(--radius);padding:14px 16px;font-size:14px;line-height:1.45;margin-bottom:8px}.setup-warning strong{display:block;margin-bottom:6px}.setup-warning p{margin:6px 0}.setup-warning ol{padding-left:18px;margin:8px 0}.setup-warning li{margin-bottom:4px}.setup-share-url{margin-top:16px;padding:12px 14px;background:var(--bg-elev);border-radius:8px;display:flex;flex-direction:column;gap:8px}.setup-share-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.setup-share-row{display:flex;gap:8px;align-items:stretch}.setup-share-code{flex:1;background:var(--bg-elev-2);padding:8px 10px;border-radius:6px;font-size:11px;overflow-x:auto;white-space:nowrap;-webkit-user-select:all;user-select:all}.setup-share-row button{background:var(--bg-elev-2);border-radius:6px;padding:0 14px;font-size:16px}.setup{padding:calc(20px + var(--safe-top)) 20px calc(20px + var(--safe-bottom));max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.setup h1{margin:8px 0 0;font-size:28px}.setup label{display:flex;flex-direction:column;gap:6px}.setup label span{font-size:13px;color:var(--text-muted)}.setup input{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.form{display:flex;flex-direction:column;flex:1;min-height:0}.form-header{position:sticky;top:0;z-index:5;background:var(--bg);padding:calc(12px + var(--safe-top)) 16px 12px;border-bottom:1px solid var(--border)}.form-body{flex:1;padding:16px;display:flex;flex-direction:column;gap:var(--gap);overflow-y:auto}.form-footer{position:sticky;bottom:0;margin:auto -16px -16px;z-index:2;background:linear-gradient(to top,var(--bg) 70%,transparent);padding:12px 16px calc(16px + var(--safe-bottom))}.form-footer .primary{width:100%}.field{display:flex;flex-direction:column;gap:6px}.field-row{flex-direction:row;align-items:center;gap:12px}.field-label{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted)}.field-required{color:var(--primary);margin-left:2px}.drafts-banner{margin:0 16px 8px;background:#ff980014;border:1px solid rgba(255,152,0,.3);border-radius:8px;overflow:hidden}.drafts-banner-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:transparent;color:var(--warning);font-size:13px;font-weight:500;border:none;cursor:pointer}.drafts-banner-caret{font-size:11px;opacity:.7}.drafts-list{list-style:none;margin:0;padding:0 8px 8px}.drafts-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-top:1px solid var(--border)}.drafts-item-text{flex:1;min-width:0}.drafts-item-title{font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drafts-item-snippet{font-size:12px;color:var(--text-muted);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drafts-item-actions{display:flex;gap:4px;flex-shrink:0}.drafts-item-btn{width:32px;height:32px;border-radius:6px;background:var(--bg-elev);color:var(--text);border:none;font-size:14px;cursor:pointer}.drafts-item-btn:active{background:var(--bg-elev-2)}.drafts-item-btn-danger{color:var(--error)}.ptr-wrapper{position:relative;display:flex;flex-direction:column;flex:1;min-height:0}.ptr-indicator{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;height:50px;z-index:5;pointer-events:none}.ptr-icon{font-size:20px;color:var(--text-muted);display:inline-block;transition:transform .2s}.ptr-icon.spinning{animation:ptr-spin .8s linear infinite}@keyframes ptr-spin{to{transform:rotate(360deg)}}.offline-banner{background:#ff980029;color:var(--warning);border-bottom:1px solid var(--warning);padding:calc(8px + var(--safe-top)) 16px 8px;font-size:13px;text-align:center;position:sticky;top:0;z-index:50}.field input[type=text],.field input[type=number],.field input[type=url],.field input[type=email],.field input[type=tel],.field textarea{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;width:100%}.field input[type=checkbox]{width:22px;height:22px;accent-color:var(--primary)}.field textarea{resize:vertical;min-height:80px;font-family:inherit}.field input:focus,.field textarea:focus{border-color:var(--primary)}.field-hint{font-size:12px;color:var(--text-muted)}.dropdown-trigger{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;width:100%;min-height:48px;text-align:left;gap:8px}.dropdown-trigger:disabled{opacity:.5}.dropdown-value{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.dropdown-value>span:not(.opt-icon){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-caret{color:var(--text-muted);font-size:12px}.opt-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;font-size:14px;flex-shrink:0}.opt-icon-img{width:20px;height:20px;border-radius:4px;object-fit:cover}.sheet-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-trigger{align-items:flex-start;padding:8px 14px}.tags{display:flex;flex-wrap:wrap;gap:6px;flex:1;min-width:0}.tag{display:inline-flex;align-items:center;gap:4px;background:var(--bg-elev-2);border-radius:4px;padding:4px 8px;font-size:14px;cursor:pointer}.tag-x{margin-left:2px;color:var(--text-muted);font-size:14px}.sheet-overlay{position:fixed;top:0;left:0;right:0;bottom:calc(60px + var(--safe-bottom));background:#000000d9;z-index:150;display:flex;align-items:flex-end;animation:fade-in .18s ease-out;overscroll-behavior:contain;touch-action:pan-y;padding-top:calc(var(--safe-top) + 60px)}.sheet{background:var(--bg-elev);border-top-left-radius:16px;border-top-right-radius:16px;width:100%;max-height:100%;flex:1 1 auto;display:flex;flex-direction:column;animation:slide-up .22s ease-out;overscroll-behavior:contain;overflow:hidden;min-height:0;transform:translateZ(0);isolation:isolate}.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg-elev);flex-shrink:0}.sheet-close{color:var(--primary);font-size:16px;padding:4px 8px}.sheet-header-editable{gap:10px;padding:10px 12px}.page-icon-btn{flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--bg-elev-2);border-radius:8px;cursor:pointer;transition:background .12s}.page-icon-btn:hover{background:var(--bg-elev)}.sheet-header-title-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--text);font-size:16px;font-weight:500;padding:6px 4px;border-radius:4px}.sheet-header-title-input:focus{background:var(--bg-elev-2)}.page-icon-picker{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-elev-2);border-bottom:1px solid var(--border);flex-shrink:0}.page-icon-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);font-size:18px}.page-icon-remove{padding:6px 12px;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:6px;font-size:13px;cursor:pointer}.sheet-search{margin:10px 16px 4px;padding:10px 12px;background:var(--bg-elev-2);border-radius:var(--radius-sm);flex-shrink:0}.sheet-paste{display:flex;gap:8px;margin:10px 16px 4px;flex-shrink:0;flex-wrap:wrap}.sheet-paste input{flex:1;min-width:0;padding:10px 12px;background:var(--bg-elev-2);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:16px}.sheet-paste .primary{padding:10px 14px!important;font-size:14px!important;min-height:auto!important}.sheet-paste-error{width:100%;font-size:12px;color:var(--error)}.sheet-list{overflow-y:auto;flex:1;min-height:0;padding:4px 0 8px;overscroll-behavior:contain}.sheet-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;text-align:left;min-height:48px}.sheet-item:active,.sheet-item.active{background:var(--bg-elev-2)}.sheet-check{width:18px;color:var(--primary);font-size:16px}.sheet-empty{padding:24px 16px;text-align:center;color:var(--text-muted)}button.primary{background:var(--primary);color:#fff;font-weight:600;padding:14px 20px;border-radius:var(--radius);min-height:50px}button.primary:hover{background:var(--primary-hover)}button.primary:disabled{opacity:.4;cursor:not-allowed}.toast{position:fixed;bottom:calc(74px + var(--safe-bottom));left:16px;right:16px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 8px 24px #0006;z-index:250;animation:slide-up .22s ease-out}.toast-loading{border-left:3px solid var(--warning)}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--error)}.toast-icon{font-size:18px}.toast-body{flex:1;display:flex;flex-direction:column}.toast-msg{font-size:13px;color:var(--text-muted)}.toast-actions{display:flex;gap:8px}.toast-actions button{background:var(--bg-elev-2);padding:6px 10px;border-radius:6px;font-size:13px}.toast-close{color:var(--text-muted);padding:4px 8px}.loading{padding:24px;text-align:center;color:var(--text-muted)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.habit-screen{display:flex;flex-direction:column;flex:1;min-height:0;padding:8px 8px 0;overflow:hidden}.habit-header{display:flex;justify-content:space-between;align-items:baseline;padding:4px 8px 6px}.habit-header h2{margin:0;font-size:18px}.habit-grid{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain}.habit-row{display:flex;align-items:center;height:40px;border-bottom:1px solid rgba(255,255,255,.04);flex-shrink:0}.habit-row-head{position:sticky;top:0;background:var(--bg);z-index:2;height:36px;border-bottom:1px solid var(--border)}.habit-label-cell{flex:1;display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);min-width:0;padding-left:6px}.habit-row.important{background:#ffffff0d}.habit-emoji{font-size:14px;flex-shrink:0}.habit-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.habit-day-head{width:32px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;font-size:11px;color:var(--text-muted)}.habit-day-head.today{color:var(--primary);font-weight:700}.habit-day-letter{font-weight:600;text-transform:uppercase}.habit-day-num{font-size:12px}.habit-cell{width:32px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;padding:0}.habit-dot{width:16px;height:16px;border-radius:50%;border:1.5px solid #555;display:block;transition:background .12s,border-color .12s}.habit-cell.checked .habit-dot{background:#daef05;border-color:#daef05}.habit-cell:active .habit-dot{transform:scale(.85)}.habit-cell.today{background:#ffffff0a}.habit-day-head.today{background:#ffffff0f;border-radius:6px}.habit-label-btn{border:none;background:transparent;cursor:pointer;text-align:left;user-select:none;-webkit-user-select:none;touch-action:manipulation}.habit-label-btn:active{background:#ffffff08}.habit-streak{margin-left:auto;padding-right:6px;font-size:11px;color:#ffb547;font-weight:600;flex-shrink:0}.habit-screen.overview .habit-streak{font-size:9px}.people-filter-row{display:flex;gap:6px;padding:0 12px 10px;overflow-x:auto;scrollbar-width:none;scroll-snap-type:x proximity}.people-filter-row::-webkit-scrollbar{display:none}.people-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;font-size:13px;color:var(--text);flex-shrink:0;scroll-snap-align:start;cursor:pointer;white-space:nowrap}.people-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.people-pill-avatar{width:18px;height:18px;border-radius:50%;object-fit:cover}.habit-screen.overview .habit-grid{overflow:hidden}.habit-screen.overview .habit-row:not(.habit-row-head){height:auto;flex:1 1 0;min-height:0}.habit-screen.overview .habit-row-head{height:30px;flex:0 0 30px}.habit-screen.overview .habit-cell{height:auto;align-self:stretch}.habit-screen.overview .habit-label-cell{font-size:10px;padding-left:4px;gap:3px}.habit-screen.overview .habit-emoji{font-size:11px}.habit-screen.overview .habit-dot{width:10px;height:10px;border-width:1px}.habit-screen.overview .habit-day-head{font-size:9px}.habit-screen.overview .habit-day-num{font-size:10px}.habit-header-right{display:flex;align-items:center;gap:8px}.habit-zoom-btn{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;width:32px;height:28px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);cursor:pointer}.habit-zoom-btn:active{background:var(--bg-elev-2)}.voice-fab{position:fixed;right:16px;bottom:calc(76px + var(--safe-bottom));width:52px;height:52px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;z-index:180}.voice-fab:active{transform:scale(.92)}.voice-trigger-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;margin-bottom:12px;border-radius:12px;background:var(--primary);color:#fff;font-weight:600;font-size:15px;border:none;cursor:pointer;transition:transform .1s,opacity .1s}.voice-trigger-btn:active{transform:scale(.98);opacity:.9}.create-quick-popup{padding:14px 14px 16px;position:relative;overflow-y:auto}.create-quick-expand,.quick-expand{position:absolute;top:8px;right:8px;width:36px;height:36px;border-radius:8px;background:var(--bg-elev-2);color:var(--primary);font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;z-index:2}.create-quick-mic-area{padding-top:8px}.create-quick-db{margin-bottom:10px;padding-right:44px}.create-quick-mic{height:64px;font-size:17px}.create-quick-mic svg{width:26px;height:26px}.voice-preview-content{padding-top:4px;padding-right:50px}.voice-mic-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:14px 20px;font-size:15px;font-weight:500;min-height:52px}.voice-mic-btn:active{background:var(--bg-elev)}.voice-mic-btn.recording{background:#ff636326;border-color:var(--primary);color:var(--primary);font-weight:600}.voice-mic-btn.busy{opacity:.7;cursor:wait}.voice-mic-btn:disabled{opacity:.5}.voice-mic-pulse{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--primary);animation:voice-pulse 1.1s infinite}@keyframes voice-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.3)}}.voice-mic-stage{color:var(--text-muted)}.voice-mic-cancel{display:block;width:100%;padding:8px 20px;margin-top:4px;color:var(--text-muted);font-size:14px}.voice-error{background:#f443361a;border:1px solid var(--error);color:var(--error);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px}.voice-preview{padding:16px 16px calc(16px + var(--safe-bottom))}.voice-preview-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.voice-preview-title{flex:1;font-size:16px;font-weight:600;line-height:1.3;word-break:break-word}.voice-preview-title-input{flex:1;font-size:16px;font-weight:600;line-height:1.3;background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 10px;min-width:0;font-family:inherit}.voice-preview-title-input:focus{outline:none;border-color:var(--primary)}.voice-preview-actions{display:flex;gap:8px;flex-shrink:0}.voice-action-btn{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--bg-elev-2);color:var(--text);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600}.voice-action-btn.voice-send{background:var(--primary);color:#fff}.voice-action-btn:active{transform:scale(.95)}.voice-action-btn:disabled{opacity:.5}.voice-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.voice-chip{background:var(--bg-elev-2);color:var(--text);padding:6px 10px;border-radius:6px;font-size:13px}.voice-raw{margin-top:10px;font-style:italic;font-size:12px}.voice-secondary-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.voice-secondary-btn{background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;cursor:pointer}.voice-secondary-btn:active{background:var(--bg-elev-2)}.voice-secondary-btn.voice-reparse{color:var(--primary);border-color:var(--primary);margin-left:auto}.voice-chip-btn{cursor:pointer;border:none;font-family:inherit;transition:background .12s}.voice-chip-btn:active{transform:scale(.95)}.voice-chip-btn.active{background:var(--primary);color:#fff}.voice-chip-add{background:transparent;color:var(--text-muted);border:1px dashed var(--border);cursor:pointer}.voice-add-menu{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;padding:8px;background:var(--bg-elev-2);border-radius:8px}.voice-add-menu-item{padding:6px 10px;background:var(--bg-elev);color:var(--text);border-radius:6px;font-size:13px;border:none;cursor:pointer}.voice-add-menu-item:active{background:var(--primary);color:#fff}.voice-field-editor{margin-top:10px;padding:10px;background:var(--bg-elev-2);border-radius:8px;display:flex;flex-direction:column;gap:8px;position:relative}.voice-field-close{position:absolute;top:4px;right:4px;width:28px;height:28px;border-radius:50%;background:transparent;color:var(--text-muted);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1}.voice-field-close:active{background:var(--bg-elev)}.voice-field-quick{display:flex;flex-wrap:wrap;gap:6px}.voice-field-input{background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:14px;color:var(--text)}.voice-field-list{display:flex;flex-wrap:wrap;gap:6px;max-height:200px;overflow-y:auto}.voice-field-option{padding:6px 10px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;cursor:pointer}.voice-field-option.active{background:var(--primary);color:#fff;border-color:var(--primary)}.voice-field-cancel{align-self:flex-end;padding:6px 12px;color:var(--text-muted);font-size:13px;background:transparent;border:none;cursor:pointer}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.tabs{position:sticky;top:0;z-index:10;display:flex;background:var(--bg);padding:calc(8px + var(--safe-top)) 8px 0;border-bottom:1px solid var(--border);gap:4px}.tabs button{flex:1;padding:12px 8px;font-size:15px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;border-radius:0;min-height:48px}.tabs button.active{color:var(--text);border-bottom-color:var(--primary)}.tabs-bottom{position:fixed;top:auto;bottom:0;left:0;right:0;z-index:200;background:var(--bg);border-bottom:none;border-top:1px solid var(--border);padding:0 8px var(--safe-bottom) 8px;flex-shrink:0;pointer-events:auto}.tabs-bottom button{pointer-events:auto}.tabs-bottom button{border-bottom:none;border-top:2px solid transparent;padding-top:14px;padding-bottom:14px}.tabs-bottom button.active{border-top-color:var(--primary);border-bottom-color:transparent;background:#ff636314;transform:scale(1.1)}.tabs-bottom button{font-size:22px;line-height:1}.tabs-bottom button.tab-create{color:#ff8a8a;font-weight:800;font-size:26px}.tabs-bottom button.tab-create.active{color:var(--primary)}.app-main{flex:1;min-height:0;display:flex;flex-direction:column;padding-top:var(--safe-top);padding-bottom:calc(60px + var(--safe-bottom))}.app-main .form-header{display:none}.app-main .form{min-height:auto}.app-main .form .form-header{display:block;padding-top:12px;position:static}.app-main .form>header.form-header{display:block;padding-top:12px;position:static;border-bottom:none}.tasks-screen{display:flex;flex-direction:column;flex:1;min-height:0}.tasks-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px 6px;gap:12px}.tasks-header>div:first-child{display:flex;align-items:baseline;gap:10px;flex:1;min-width:0}.tasks-header h2{margin:0;font-size:18px}.tasks-header .icon-btn{width:32px;height:32px;font-size:14px;flex-shrink:0}.icon-btn{width:40px;height:40px;border-radius:50%;background:var(--bg-elev);font-size:18px;display:flex;align-items:center;justify-content:center}.task-list{list-style:none;margin:0;padding:0 0 calc(80px + var(--safe-bottom));display:flex;flex-direction:column}.task-row{display:flex;align-items:stretch;gap:4px;padding:4px 12px;border-bottom:1px solid var(--border)}.task-check{display:flex;align-items:center;justify-content:center;width:44px;flex-shrink:0}.task-check-circle{display:block;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--text-muted);transition:background .15s,border-color .15s}.task-check:active .task-check-circle{background:var(--success);border-color:var(--success)}.task-body{flex:1;text-align:left;padding:12px 8px;display:flex;flex-direction:column;gap:6px;min-width:0}.task-check:focus-visible,.task-body:focus-visible{outline:2px solid #daef05;outline-offset:-2px;border-radius:6px}.task-body:focus-visible{background:#daef050d}.task-title-row{display:flex;align-items:center;gap:6px}.task-title{font-size:15px;line-height:1.35;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-recurring{font-size:12px;opacity:.7}.task-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.task-when{font-size:12px;color:var(--text-muted);font-weight:500}.task-when.overdue{color:var(--error)}.task-empty{padding:80px 24px 60px;text-align:center;color:var(--text-muted);font-size:15px;display:flex;flex-direction:column;gap:8px;align-items:center}.task-empty-emoji{font-size:48px;line-height:1;opacity:.9}.task-empty-msg{font-size:15px;font-weight:500}.task-empty-hint{font-size:12px;opacity:.7}.chip{display:inline-block;font-size:11px;padding:3px 8px;border-radius:4px;background:var(--bg-elev-2);color:var(--text);line-height:1.2}.chip-dim{color:var(--text-muted);background:var(--bg-elev)}.edit-title{padding:14px 16px 4px;font-weight:500}.edit-current{padding:0 16px 12px}.quick-actions{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 12px}.chip-btn{background:var(--bg-elev-2);padding:10px 14px;border-radius:8px;font-size:14px;font-weight:500;min-height:40px}.chip-btn:active{background:var(--primary);color:#fff}.natural-input{display:flex;gap:8px;padding:8px 16px 4px}.natural-input input{flex:1;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;font-size:16px}.natural-input .primary{padding:12px 18px;font-size:14px;min-height:auto}.natural-hint{padding:0 16px 12px;font-size:12px;color:var(--text-muted)}.sheet-action{display:block;width:100%;text-align:center;padding:14px 16px;border-top:1px solid var(--border);color:var(--primary);font-weight:500}.edit-sheet-footer{display:flex;flex-direction:column;border-top:1px solid var(--border)}.edit-sheet-footer .sheet-action{border-top:none;border-bottom:1px solid var(--border)}.edit-sheet-footer .sheet-action:last-child{border-bottom:none}.sheet-action-revert{color:var(--warning);font-size:14px}.sheet-action-revert:disabled{opacity:.5}.edit-sheet{max-height:100%;height:100%}.edit-scroll{overflow-y:auto;flex:1;min-height:0;overscroll-behavior:contain;touch-action:pan-y}.edit-section-sticky{position:sticky;top:0;z-index:5;background:var(--bg-elev);border-bottom:1px solid var(--border)}.edit-section{padding:12px 16px;border-top:1px solid var(--border)}.edit-section:first-of-type{border-top:none}.edit-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}.editable-prop{position:relative;margin-bottom:12px}.editable-prop:last-child{margin-bottom:0}.editable-prop .field{margin:0}.prop-saving,.prop-saved{position:absolute;top:0;right:0;font-size:11px;padding:2px 6px;border-radius:4px}.prop-saving{color:var(--text-muted);background:var(--bg-elev-2)}.prop-saved{color:#1ed8a3;background:#1ed8a31f;animation:fade-in .2s ease-out}.quick-overlay{z-index:180;background:#00000026}.voice-quick-overlay{position:fixed;top:0;left:0;right:0;bottom:0;padding:0;margin:0;background:#00000040;z-index:200;display:flex;align-items:flex-end;animation:fade-in .18s ease-out}.voice-quick-overlay .sheet.create-quick-popup{flex:0 0 auto;max-height:90dvh;min-height:0;width:100%;border-top-left-radius:16px;border-top-right-radius:16px;background:var(--bg-elev);animation:slide-up .22s ease-out;margin-bottom:calc(60px + var(--safe-bottom))}body:has(.voice-quick-overlay) .sheet-overlay:not(.voice-quick-overlay){z-index:230}.quick-sheet{position:relative}.quick-title{padding:16px 56px 4px 16px;font-weight:500;font-size:16px}.quick-bottom{display:flex;border-top:1px solid var(--border)}.quick-bottom .quick-link{flex:1;padding:14px;color:var(--primary);font-weight:500;font-size:14px}.quick-bottom .quick-link:not(:last-child){border-right:1px solid var(--border)}.quick-bottom .quick-link.quick-link-done{color:#1ed8a3;font-weight:600}.skeleton-field{height:56px;background:linear-gradient(90deg,var(--bg-elev),var(--bg-elev-2),var(--bg-elev));background-size:200% 100%;border-radius:6px;margin-bottom:12px;animation:skeleton-shimmer 1.4s ease-in-out infinite}.skeleton-field.skeleton-field-tall{height:96px}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.sheet-back{color:var(--primary);font-size:16px;padding:4px 8px}.sheet-header-title{text-align:center;flex:1;margin:0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px}.when-row{display:flex;gap:6px;align-items:center;margin-top:4px}.when-row input[type=text]{flex:1;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:16px}.when-ok{padding:10px 14px!important;font-size:14px!important;min-height:auto!important}.calendar-btn{position:relative;display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-elev-2);border-radius:var(--radius-sm);cursor:pointer;font-size:20px;flex-shrink:0}.calendar-btn input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.when-quick-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.when-quick-btn{padding:6px 10px;font-size:12px;min-height:auto}.others-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 0;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.content-actions{display:flex;align-items:center;gap:10px;margin-top:8px;margin-bottom:16px}.content-add{padding:10px 14px!important;font-size:14px!important;min-height:auto!important}.icon-btn.spinning{animation:spin .6s linear}@keyframes spin{to{transform:rotate(360deg)}}.content-label-row{display:flex;justify-content:space-between;align-items:center}.content-expand-btn{width:28px;height:28px;border-radius:6px;background:var(--bg-elev-2);color:var(--primary);font-size:14px;font-weight:600}.fullscreen-editor{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:var(--bg);display:flex;flex-direction:column;padding-top:var(--safe-top)}.fullscreen-editor-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.fullscreen-editor-title{flex:1;margin:0 8px;text-align:center;font-size:15px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fullscreen-editor-save{color:var(--primary);font-weight:600;font-size:15px;padding:4px 12px}.fullscreen-editor-save:disabled{opacity:.4}.fullscreen-editor-textarea{flex:1;width:100%;border:none;background:var(--bg);color:var(--text);padding:16px;font-size:16px;font-family:inherit;resize:none;outline:none;line-height:1.5}.fullscreen-editor-error{padding:12px 16px;color:var(--error);font-size:13px;border-top:1px solid var(--border)}.fmt-toolbar{display:flex;align-items:center;gap:2px;padding:6px 8px;background:var(--bg-elev);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;flex-shrink:0}.fmt-toolbar::-webkit-scrollbar{display:none}.fmt-btn{flex-shrink:0;min-width:30px;height:32px;padding:0 4px;border-radius:6px;background:transparent;color:var(--text);font-size:14px;font-weight:500;font-family:inherit;display:inline-flex;align-items:center;justify-content:center}.fmt-btn:active{background:var(--bg-elev-2)}.fmt-btn b,.fmt-btn i,.fmt-btn u,.fmt-btn s{display:inline-block;line-height:1}.fmt-btn.fmt-red{color:#e96f5a}.fmt-btn.fmt-yellow{background:#f7da4040;color:#f7da40}.fmt-sep{width:1px;height:18px;background:var(--border);margin:0 4px;flex-shrink:0}@media (min-width: 600px){body{background:#0a0a0a}.app{max-width:1400px;width:100%;margin:0 auto;min-height:100vh;min-height:100dvh;box-shadow:0 0 60px #0006}.tabs-bottom{left:50%;right:auto;transform:translate(-50%);max-width:1400px;width:100%}.voice-quick-overlay,.sheet-overlay,.fullscreen-editor{max-width:1400px;width:100%;left:50%;right:auto;transform:translate(-50%)}}.groceries-screen{display:flex;flex-direction:column;flex:1;min-height:0}.groceries-list{padding:0 0 calc(80px + var(--safe-bottom))}.groceries-section{border-bottom:1px solid var(--border)}.groceries-section-header{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;background:var(--bg-elev);border-left:3px solid var(--border);text-align:left;cursor:pointer;font-size:14px;font-weight:600}.groceries-section-header:active{background:var(--bg-elev-2)}.groceries-section-caret{font-size:11px;color:var(--text-muted);width:12px}.groceries-section-name{flex:1}.groceries-section-count{font-size:12px;color:var(--text-muted);background:var(--bg-elev-2);padding:2px 8px;border-radius:10px}.groceries-items{list-style:none;margin:0;padding:0}.grocery-row-wrap{position:relative;overflow:hidden}.grocery-swipe-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:flex-start;padding-left:24px;background:#1ed8a3;color:#fff;font-size:24px;font-weight:700;pointer-events:none}.grocery-row{display:flex;align-items:center;background:var(--bg);border-bottom:1px solid rgba(255,255,255,.03);position:relative;z-index:1}.grocery-body{flex:1;text-align:left;padding:14px 12px;font-size:15px;color:var(--text);min-width:0}.grocery-title{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-section-header{list-style:none;display:flex;align-items:center;gap:8px;padding:12px 16px 6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:transparent}.task-section-count{font-size:11px;color:var(--text-dim);background:var(--bg-elev);padding:1px 6px;border-radius:8px}.task-row-recent{position:relative}.task-recent-dot{position:absolute;top:14px;left:38px;width:6px;height:6px;border-radius:50%;background:#1ed8a3;box-shadow:0 0 0 2px var(--bg);pointer-events:none}.tasks-search-row{display:flex;align-items:center;gap:6px;padding:0 16px 8px}.tasks-search-input{flex:1;background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:14px;color:var(--text)}.tasks-search-input:focus{border-color:var(--primary)}.tasks-search-clear{width:28px;height:28px;border-radius:50%;background:var(--bg-elev-2);color:var(--text-muted);font-size:13px}html.app-compact-root,body.app-compact-body{background:transparent!important;overflow:hidden;margin:0;padding:0}body.app-compact-body{display:flex;align-items:flex-start;justify-content:center;min-height:100vh}body.app-compact-body>#root{width:auto}.app-compact{background:#1c1c20eb;backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border-radius:14px;border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 60px #0000008c,0 0 0 1px #0006;overflow:hidden;width:560px;max-width:100vw;height:auto;position:relative}.app-compact:before{content:"";position:absolute;top:0;left:0;right:0;height:24px;-webkit-app-region:drag;app-region:drag;pointer-events:none;z-index:100}.app-compact .app-main{padding-top:0;padding-bottom:0}.app-compact .form-header,.app-compact .form-body>.field,.app-compact .form-body>hr,.app-compact .form-body>.field-hint,.app-compact .form-body label,.app-compact .form-footer,.app-compact .voice-trigger-btn{display:none!important}.app-compact .form-body{padding:0;overflow:visible}.app-compact .voice-quick-overlay{position:relative;width:100%;height:auto;max-width:none;left:0;transform:none;background:transparent;display:block;padding:28px 18px 18px}.app-compact .voice-quick-overlay .create-quick-popup{margin:0;width:100%;border-radius:10px;border:none;box-shadow:none;background:transparent;padding:0}.app-compact .create-quick-expand{background:#daef0526;color:#daef05}.app-compact .create-quick-mic{font-size:16px;padding:18px;border-radius:12px}.create-quick-unified{display:flex;flex-direction:column;gap:10px;padding:8px 4px 4px}.unified-input-wrap{position:relative;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:12px;transition:border-color .15s,background .15s}.unified-input-wrap:focus-within{border-color:#daef0580;background:#ffffff14}.unified-input-wrap.recording{border-color:#ff505099;background:#ff505014}.unified-input-wrap.busy{opacity:.7}.unified-input{width:100%;background:transparent;border:none;outline:none;resize:none;padding:12px 110px 12px 14px;color:var(--text);font:inherit;font-size:15px;line-height:1.4;min-height:60px;max-height:160px;overflow-y:auto}.unified-input::placeholder{color:var(--text-muted)}.unified-input:disabled{cursor:not-allowed}.unified-input-actions{position:absolute;right:8px;bottom:8px;display:flex;gap:6px;align-items:center}.unified-mic-btn,.unified-send-btn,.unified-cancel-btn{background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:8px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--text);cursor:pointer;transition:background .12s,border-color .12s,color .12s;padding:0}.unified-mic-btn:hover:not(:disabled),.unified-send-btn:hover:not(:disabled),.unified-cancel-btn:hover:not(:disabled){background:#ffffff14}.unified-mic-btn.recording{background:#ff505040;border-color:#ff505099;color:#ff7070}.unified-send-btn:not(:disabled){background:#daef0526;border-color:#daef0566;color:#daef05}.unified-send-btn:disabled{opacity:.4;cursor:not-allowed}.unified-mic-btn:disabled{opacity:.5;cursor:not-allowed}.unified-cancel-btn{color:var(--text-muted);font-size:14px}.app-compact .create-quick-unified{gap:8px;padding:4px 0 0}.app-compact .unified-input{min-height:50px;font-size:14px;padding:10px 110px 10px 12px}.pre-parse-chips{display:flex;flex-direction:column;gap:8px;padding-top:4px}.pre-parse-chips .voice-chips{display:flex;flex-wrap:wrap;gap:6px}.app-compact .voice-preview-title-input{font-size:18px;padding:12px}.habit-cell-num{padding:0;overflow:hidden}.habit-num-input{width:100%;height:100%;border:none;background:transparent;color:var(--text-muted);text-align:center;font-size:14px;font-weight:600;font-variant-numeric:tabular-nums;padding:0;-webkit-appearance:none;-moz-appearance:textfield;appearance:textfield}.habit-num-input::-webkit-outer-spin-button,.habit-num-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.habit-num-input:focus{outline:none}.habit-cell-num.habit-num-good .habit-num-input{color:#5eb3ff;font-weight:600}.habit-cell-num.habit-num-bad .habit-num-input{color:#f7c843;font-weight:600}.swipe-wrap{position:relative;overflow:hidden}.swipe-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;color:#fff;font-size:14px;font-weight:600;padding:0 24px;pointer-events:none}.swipe-bg-right{justify-content:flex-start}.swipe-bg-left{justify-content:flex-end}.swipe-content{position:relative;background:var(--bg);z-index:1}
