*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0a0a;--surface: #141414;--surface-2: #1e1e1e;--surface-3: #252525;--border: #2a2a2a;--border-light: #333;--accent: #de8f00;--accent-dim: rgba(222, 143, 0, .15);--accent-light: #f7d24c;--text: #e8e8e8;--text-muted: #888;--text-dim: #555;--danger: #ef4444;--success: #22c55e;--sidebar-width: 220px;--radius: 8px;--radius-sm: 5px;--radius-lg: 12px;--mobile-nav-height: 56px}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;font-size:16px}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#333;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#444}@supports (padding: env(safe-area-inset-bottom)){:root{--safe-bottom: env(safe-area-inset-bottom);--safe-top: env(safe-area-inset-top)}}#root{height:100%}.app-shell{display:flex;height:100vh;height:100dvh;overflow:hidden;background:var(--bg)}.sidebar{width:var(--sidebar-width);flex-shrink:0;height:100vh;height:100dvh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;z-index:200}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;border-bottom:1px solid var(--border)}.sidebar-logo img{width:28px;height:28px;border-radius:6px}.sidebar-logo-name{font-size:1rem;font-weight:700;color:var(--accent);letter-spacing:-.02em}.sidebar-nav{flex:1;padding:10px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s;text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.7;transition:opacity .15s}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item:hover svg{opacity:1}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-item.active svg{opacity:1}.nav-item.ai-item{color:var(--accent);margin-top:2px}.nav-item.ai-item svg{opacity:1}.nav-item.ai-item:hover{background:var(--accent-dim)}.nav-item.ai-item.active{background:#de8f0040}.sidebar-divider{height:1px;background:var(--border);margin:6px 8px}.sidebar-bottom{border-top:1px solid var(--border);padding:12px 8px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#0a0a0a;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-email{flex:1;font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.signout-btn{background:none;border:none;color:var(--text-dim);padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s,background .15s;flex-shrink:0}.signout-btn:hover{color:var(--danger);background:#ef44441a}.app-main{flex:1;min-width:0;height:100vh;height:100dvh;overflow:hidden;display:flex;flex-direction:column}.mobile-tab-bar,.mobile-only{display:none}@media(max-width:768px){.desktop-only{display:none!important}.mobile-only{display:flex!important}.app-shell{flex-direction:column}.app-main{flex:1;height:auto;min-height:0;padding-bottom:var(--mobile-nav-height)}.mobile-tab-bar{display:flex!important;position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-height);background:var(--surface);border-top:1px solid var(--border);z-index:500;padding:0;padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-around;align-items:center}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:6px 0;color:var(--text-dim);text-decoration:none;transition:color .15s;-webkit-tap-highlight-color:transparent}.tab-item svg{width:20px;height:20px}.tab-item span{font-size:.62rem;font-weight:500;letter-spacing:.02em}.tab-item.active,.tab-item:active{color:var(--accent)}}.floating-lines-container{width:100%;height:100%;position:absolute;overflow:hidden}.page-loading{display:flex;align-items:center;justify-content:center;height:100%}.loading-spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-page{height:100%;overflow-y:auto;padding:32px 36px;display:flex;flex-direction:column;gap:24px}.dashboard-greeting{font-size:1.5rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.dashboard-date{font-size:.85rem;color:var(--text-muted);margin-top:3px}.dash-focus-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#de8f000f;border:1px solid rgba(222,143,0,.3);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s,background .15s;gap:16px}.dash-focus-bar:hover{border-color:#de8f008c;background:#de8f0017}.dash-focus-left{display:flex;align-items:center;gap:12px;min-width:0}.dash-focus-star{color:var(--accent);font-size:1rem;flex-shrink:0}.dash-focus-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}.dash-focus-goal{font-size:.9rem;color:var(--text);margin-top:2px;line-height:1.4}.dash-focus-link{font-size:.78rem;color:var(--accent);white-space:nowrap;flex-shrink:0}.dash-section{display:flex;flex-direction:column;gap:12px}.dash-section-header{display:flex;align-items:center;gap:10px}.dash-section-title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.dash-section-count{font-size:.72rem;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);padding:1px 8px;border-radius:10px}.dash-section-link{margin-left:auto;background:none;border:none;font-size:.78rem;color:var(--accent);cursor:pointer;padding:0}.dash-section-link:hover{opacity:.75}.dash-empty-section{font-size:.85rem;color:var(--text-dim);padding:16px 0}.dash-task-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.dash-project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column;gap:10px}.dash-project-card:hover{border-color:var(--border-light);background:var(--surface-2)}.dash-project-card.primary{border-color:#de8f004d;background:#de8f000a}.dash-project-card.primary:hover{border-color:#de8f0080;background:#de8f0012}.dash-project-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.dash-project-card-name{font-size:.85rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-project-card-star{color:var(--accent)}.dash-project-card-count{font-size:.7rem;font-weight:600;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);padding:1px 7px;border-radius:10px;flex-shrink:0}.dash-project-card-tasks{list-style:none;display:flex;flex-direction:column;gap:6px}.dash-project-card-tasks li{display:flex;align-items:center;gap:8px}.dash-task-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dash-task-text{font-size:.82rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;flex-direction:column;gap:14px;cursor:pointer;transition:border-color .15s,background .15s}.dash-card:hover{border-color:var(--border-light);background:var(--surface-2)}.dash-card-header{display:flex;align-items:center;justify-content:space-between}.dash-card-title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.dash-card-badge{font-size:.72rem;font-weight:600;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);padding:1px 8px;border-radius:10px}.dash-empty{font-size:.85rem;color:var(--text-dim);flex:1;display:flex;align-items:center}.dash-card-footer{font-size:.78rem;color:var(--accent);margin-top:auto}.dash-event-list{list-style:none;display:flex;flex-direction:column;gap:8px;flex:1}.dash-event-item{display:flex;align-items:flex-start;gap:10px}.dash-event-indicator{width:3px;height:100%;min-height:28px;border-radius:2px;background:var(--accent);flex-shrink:0}.dash-event-info{display:flex;flex-direction:column;gap:1px}.dash-event-title{font-size:.85rem;color:var(--text)}.dash-event-time{font-size:.75rem;color:var(--text-muted)}.dash-ai-card{border-color:#de8f0040;background:#de8f000a}.dash-ai-card:hover{border-color:#de8f0080;background:#de8f0014}.dash-ai-content{display:flex;align-items:center;gap:14px;flex:1}.dash-ai-icon{font-size:1.4rem;color:var(--accent)}.dash-ai-title{font-size:.95rem;font-weight:600;color:var(--text)}.dash-ai-sub{font-size:.8rem;color:var(--text-muted);margin-top:2px}@media(max-width:768px){.dashboard-page{padding:16px 14px;gap:18px}.dashboard-greeting{font-size:1.25rem}.dash-task-grid,.dashboard-bottom-grid{grid-template-columns:1fr;gap:10px}.dash-focus-bar{flex-direction:column;align-items:flex-start;padding:12px 16px}.dash-project-card{padding:14px 16px}.dash-card{padding:14px 16px;min-height:auto}}.pgrid{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;min-width:280px;max-width:520px}.pgrid-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.pgrid-title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.pgrid-count{font-size:.75rem;color:var(--text-dim)}.pgrid-list{display:flex;flex-direction:column}.pgrid-item{padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.pgrid-item:last-child{border-bottom:none}.pgrid-item:hover{background:var(--surface-2)}.pgrid-item.is-primary{border-left:2px solid var(--accent)}.pgrid-item-top{display:flex;align-items:center;gap:8px}.pgrid-item-name{font-size:.88rem;font-weight:500;color:var(--text)}.pgrid-primary-badge{font-size:.68rem;font-weight:600;color:var(--accent);background:#de8f001f;border:1px solid rgba(222,143,0,.3);border-radius:20px;padding:1px 7px}.pgrid-item-goal{font-size:.78rem;color:var(--accent);margin-top:3px;opacity:.85}.pgrid-item-desc{font-size:.78rem;color:var(--text-dim);margin-top:3px}.pgrid-empty{padding:16px;font-size:.85rem;color:var(--text-dim)}@media(max-width:768px){.pgrid{min-width:auto;max-width:100%}.pgrid-item{padding:10px 14px}}.elist{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;min-width:260px;max-width:480px}.elist-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.elist-title{font-size:.85rem;font-weight:600;color:var(--text)}.elist-project{font-size:.75rem;color:var(--text-dim)}.elist-body{padding:8px 0}.elist-section{padding:4px 0}.elist-section-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);padding:4px 16px}.elist-item{display:flex;align-items:flex-start;gap:10px;padding:8px 16px;transition:background .12s}.elist-item:hover{background:var(--surface-2)}.elist-item.past{opacity:.55}.elist-dot{width:6px;height:6px;border-radius:50%;background:var(--text-dim);flex-shrink:0;margin-top:5px}.elist-dot.upcoming{background:var(--accent)}.elist-event-title{font-size:.85rem;color:var(--text);font-weight:500}.elist-event-time{font-size:.75rem;color:var(--text-muted);margin-top:2px}.elist-event-desc{font-size:.72rem;color:var(--text-dim);margin-top:3px;white-space:pre-wrap;line-height:1.3}.elist-empty{padding:16px;font-size:.85rem;color:var(--text-dim)}@media(max-width:768px){.elist{min-width:auto;max-width:100%}.elist-item{padding:8px 12px}}.chat-shell{display:flex;height:100%;overflow:hidden;position:relative}.chat-history{width:240px;flex-shrink:0;height:100%;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width .2s ease,opacity .2s ease}.chat-history-top{display:flex;gap:6px;padding:12px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-new-btn{flex:1;padding:7px 10px;background:var(--accent-dim);border:1px solid rgba(222,143,0,.3);border-radius:var(--radius-sm);color:var(--accent);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.chat-new-btn:hover{background:#de8f0038}.chat-save-btn{padding:7px 12px;background:none;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .15s}.chat-save-btn:hover{border-color:var(--accent);color:var(--accent)}.chat-history-loading{display:flex;justify-content:center;padding:20px}.chat-history-empty{padding:16px 12px;font-size:.8rem;color:var(--text-dim)}.chat-section{flex-shrink:0}.chat-section-label{padding:10px 12px 4px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim)}.chat-section-toggle{background:none;border:none;cursor:pointer;width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center}.toggle-arrow{font-size:.85rem;color:var(--text-dim);transition:transform .15s;display:inline-block}.toggle-arrow.open{transform:rotate(90deg)}.chat-item{display:flex;align-items:center;gap:6px;padding:7px 10px;cursor:pointer;border-radius:0;transition:background .12s;position:relative}.chat-item:hover{background:var(--surface-2)}.chat-item.active{background:var(--surface-3)}.chat-item-name{flex:1;font-size:.82rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-item.active .chat-item-name{color:var(--text)}.chat-item-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s}.chat-item:hover .chat-item-actions,.chat-item.active .chat-item-actions{opacity:1}.chat-action-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 4px;font-size:.75rem;border-radius:3px;transition:all .12s}.chat-action-btn:hover{color:var(--text);background:var(--surface-3)}.chat-action-btn.danger:hover{color:var(--danger);background:#ef44441a}.chat-item-edit-input{flex:1;background:var(--surface-2);border:1px solid var(--accent);border-radius:3px;color:var(--text);font-size:.82rem;padding:2px 6px;outline:none}.chat-main{flex:1;min-width:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-topbar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.chat-history-toggle{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.chat-history-toggle:hover,.chat-history-toggle.active{border-color:var(--accent);color:var(--accent)}.chat-topbar-title{font-size:.875rem;color:var(--text-muted);font-weight:500}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:40px 20px;color:var(--text-muted)}.chat-empty-icon{font-size:2rem;color:var(--accent)}.chat-empty-title{font-size:1rem;font-weight:600;color:var(--text)}.chat-empty-sub{font-size:.85rem;max-width:300px;line-height:1.6}.msg-row{display:flex;flex-direction:column}.msg-row.msg-user{align-items:flex-end}.msg-row.msg-assistant{align-items:flex-start}.msg-row.msg-fc{align-items:center}.msg-bubble{max-width:72%;padding:10px 14px;border-radius:var(--radius);font-size:.875rem;line-height:1.6}.msg-bubble.user{background:var(--accent);color:#0a0a0a;border-bottom-right-radius:3px}.msg-bubble.assistant{background:var(--surface);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:3px}.msg-bubble.assistant p{margin:0 0 8px}.msg-bubble.assistant p:last-child{margin-bottom:0}.msg-bubble.assistant ul,.msg-bubble.assistant ol{margin:0 0 8px 16px}.msg-bubble.assistant li{margin:2px 0}.msg-bubble.assistant code{background:var(--surface-2);border:1px solid var(--border);padding:1px 5px;border-radius:3px;font-size:.82em;font-family:monospace}.msg-bubble.assistant pre{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;overflow-x:auto;margin:8px 0}.msg-bubble.assistant pre code{background:none;border:none;padding:0}.msg-bubble.assistant h1,.msg-bubble.assistant h2,.msg-bubble.assistant h3{margin:8px 0 4px;font-weight:600}.msg-typing{display:flex;align-items:center;gap:4px;padding:12px 16px}.msg-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-dim);animation:blink 1.2s ease-in-out infinite}.msg-typing span:nth-child(2){animation-delay:.2s}.msg-typing span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.msg-fc-badge{padding:3px 10px;background:var(--accent-dim);border:1px solid rgba(222,143,0,.25);border-radius:20px;color:var(--accent);font-size:.72rem;font-family:monospace}.msg-component{max-width:90%;width:100%}.chat-input-area{padding:12px 16px 16px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.chat-mode-pills{display:flex;gap:4px;margin-bottom:10px}.mode-pill{padding:3px 12px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s}.mode-pill:hover{border-color:var(--border-light);color:var(--text)}.mode-pill.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.chat-input-row{display:flex;gap:8px;align-items:flex-end}.chat-textarea{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;padding:10px 12px;resize:none;outline:none;transition:border-color .15s;min-height:42px;max-height:200px;line-height:1.5;font-size:16px}.chat-textarea:focus{border-color:var(--border-light)}.chat-textarea::placeholder{color:var(--text-dim)}.chat-send-btn{width:40px;height:40px;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#0a0a0a;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s;flex-shrink:0}.chat-send-btn:hover:not(:disabled){opacity:.85}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.chat-history{position:fixed;top:0;left:0;height:100vh;height:100dvh;z-index:150;width:280px;transform:translate(-100%);transition:transform .25s ease}.chat-history.open{transform:translate(0)}.chat-messages{padding:12px 10px}.msg-bubble{max-width:92%;font-size:.85rem}.msg-bubble.user,.msg-bubble.assistant{padding:8px 12px}.chat-input-area{padding:10px 12px 14px}.chat-textarea{font-size:16px;padding:10px 12px;min-height:44px}.chat-send-btn{width:44px;height:44px}.chat-mode-pills{gap:3px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.mode-pill{white-space:nowrap;padding:5px 12px}.chat-topbar{padding:8px 12px}.chat-new-btn{padding:8px 10px}.chat-empty{padding:20px 16px}.chat-empty-icon{font-size:1.5rem}.chat-empty-title{font-size:.9rem}}.rich-text-editor{display:flex;flex-direction:column;height:100%;background:#1a1a1a;border:1px solid #333}.editor-toolbar{display:flex;gap:.25rem;padding:.5rem;background:#0f0f0f;border-bottom:1px solid #333;flex-wrap:wrap}.editor-toolbar button{background:#ffffff0d;border:1px solid #444;color:#ccc;padding:.4rem .6rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;border-radius:0}.editor-toolbar button:hover:not(:disabled){background:#de8f0033;border-color:#de8f00;color:#de8f00}.editor-toolbar button.is-active{background:#de8f004d;border-color:#de8f00;color:#de8f00}.editor-toolbar button:disabled{opacity:.3;cursor:not-allowed}.toolbar-divider{width:1px;background:#444;margin:0 .25rem}.editor-content{flex:1;overflow-y:auto;padding:1rem;color:#fff;text-align:left}.editor-content .ProseMirror{outline:none;min-height:100%;text-align:left}.editor-content .ProseMirror h1{font-size:2em;font-weight:700;margin:1rem 0 .5rem;color:#de8f00;text-align:left}.editor-content .ProseMirror h2{font-size:1.5em;font-weight:700;margin:.8rem 0 .4rem;color:#de8f00;text-align:left}.editor-content .ProseMirror h3{font-size:1.25em;font-weight:600;margin:.6rem 0 .3rem;color:#de8f00;text-align:left}.editor-content .ProseMirror p{margin:.5rem 0;line-height:1.6;text-align:left}.editor-content .ProseMirror code{background:#0a0a0a;padding:.2rem .4rem;border:1px solid #333;font-family:Courier New,monospace;font-size:.9em}.editor-content .ProseMirror pre{background:#0a0a0a;padding:1rem;border:1px solid #333;overflow-x:auto;margin:.5rem 0}.editor-content .ProseMirror pre code{background:none;border:none;padding:0;color:#4ec9b0}.editor-content .ProseMirror blockquote{border-left:3px solid #de8f00;padding-left:1rem;margin:.5rem 0;color:#aaa;font-style:italic}.editor-content .ProseMirror ul,.editor-content .ProseMirror ol{padding-left:1.5rem;margin:.5rem 0}.editor-content .ProseMirror li{margin:.25rem 0}.editor-content .ProseMirror hr{border:none;border-top:1px solid #444;margin:1rem 0}.editor-content .ProseMirror strong{font-weight:700}.editor-content .ProseMirror em{font-style:italic}.editor-content .ProseMirror s{text-decoration:line-through}@media(max-width:768px){.editor-toolbar{padding:4px;gap:2px}.editor-toolbar button{padding:6px 8px;font-size:.78rem}.editor-content{padding:12px}.editor-content .ProseMirror h1{font-size:1.5em}.editor-content .ProseMirror h2{font-size:1.25em}.editor-content .ProseMirror h3{font-size:1.1em}}.projects-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.projects-header{padding:16px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.projects-title{display:flex;align-items:center;gap:10px}.projects-title h1{font-size:1.1rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.projects-container{display:flex;flex:1;overflow:hidden}.projects-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;overflow:hidden;position:relative}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);flex-shrink:0}.add-button{background:none;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;line-height:1;transition:all .15s}.add-button:hover{border-color:var(--accent);color:var(--accent)}.projects-list{flex:1;overflow-y:auto;padding:4px 0}.project-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .12s;border-left:2px solid transparent}.project-item:hover{background:var(--surface-2)}.project-item.active{background:var(--surface-3, var(--surface-2));border-left:3px solid var(--text);padding-left:11px}.project-item.active .project-name{color:var(--text);font-weight:600}.project-item.primary-top{background:#de8f000f;border-left:3px solid transparent;padding-left:11px;border-bottom:1px solid rgba(222,143,0,.2);margin-bottom:6px;padding-top:10px;padding-bottom:10px}.project-item.primary-top .project-name{color:var(--accent);font-weight:600;letter-spacing:-.01em}.project-item.primary-top .drag-handle{color:var(--accent);opacity:.4}.project-item.primary-top.active{background:#de8f001f;border-left-color:var(--accent);box-shadow:inset 0 0 0 1px #de8f0026}.project-item:not(.active):not(.primary-top){border-left-color:transparent}.project-item.dragging{opacity:.4}.project-item.drag-over{border-top:2px solid var(--accent);padding-top:6px}.drag-handle{color:var(--text-dim);font-size:.9rem;cursor:grab}.project-name{flex:1;font-size:.85rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-item.active .project-name{color:var(--text)}.delete-button{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.85rem;padding:2px;border-radius:3px;opacity:0;transition:all .12s}.project-item:hover .delete-button{opacity:1}.delete-button:hover{color:var(--danger);background:#ef44441a}.project-star-btn{background:none;border:none;cursor:pointer;font-size:.85rem;padding:2px;border-radius:3px;opacity:0;color:var(--text-dim);transition:all .12s;line-height:1}.project-item:hover .project-star-btn{opacity:1}.project-star-btn.active{opacity:1;color:var(--accent)}.project-star-btn:hover{color:var(--accent)}.projects-main{flex:1;overflow-y:auto;padding:24px 28px;min-width:0}.project-header{margin-bottom:20px}.project-header-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.project-header h2{font-size:1.2rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.project-type-icon{font-size:.75rem;flex-shrink:0;line-height:1}.type-badge{font-size:.68rem;font-weight:600;border-radius:20px;padding:2px 8px;letter-spacing:.02em;transition:all .15s}.type-badge-professional{color:#de8f00;background:#de8f001a;border:1px solid rgba(222,143,0,.25)}.type-badge-professional:hover{background:#de8f002e;border-color:#de8f0066}.type-badge-personal{color:#4ade80;background:#4ade8014;border:1px solid rgba(74,222,128,.2)}.type-badge-personal:hover{background:#4ade8026;border-color:#4ade8059}.primary-badge{font-size:.7rem;font-weight:600;color:var(--accent);background:#de8f001f;border:1px solid rgba(222,143,0,.3);border-radius:20px;padding:2px 8px;letter-spacing:.03em}.project-goal{font-size:.9rem;margin-top:6px;cursor:pointer;transition:color .15s;line-height:1.4}.project-goal.has-goal{color:var(--accent);font-weight:500}.project-goal.no-goal{color:var(--text-dim);font-style:italic}.project-goal:hover{opacity:.8}.project-header p{font-size:.85rem;color:var(--text-muted);margin-top:4px;cursor:pointer;transition:color .15s}.project-header p:hover{color:var(--text)}.sections-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:768px){.sections-grid{grid-template-columns:1fr}}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s,box-shadow .15s;cursor:pointer;border-left:3px solid var(--border)}.section-card:hover{border-color:var(--border-light);box-shadow:0 2px 8px #00000026}.section-accent-tasks{border-left-color:#de8f00}.section-accent-events{border-left-color:#3b82f6}.section-accent-notes{border-left-color:#10b981}.section-accent-chats{border-left-color:#8b5cf6}.section-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border)}.section-title{display:flex;align-items:center;gap:8px;cursor:pointer}.section-title h3{font-size:.82rem;font-weight:600;color:var(--text);margin:0}.section-count{font-size:.7rem;color:var(--text-dim);background:var(--bg);padding:1px 6px;border-radius:8px;font-weight:500}.add-icon-btn{background:none;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.95rem;transition:all .15s}.add-icon-btn:hover{border-color:var(--accent);color:var(--accent)}.section-card-content{padding:8px 14px 10px;display:flex;flex-direction:column;gap:2px}.overview-row{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:.8rem;color:var(--text-muted)}.overview-checkbox{accent-color:var(--accent);width:13px;height:13px;cursor:pointer;flex-shrink:0}.overview-priority{font-size:.65rem;font-weight:700;min-width:14px;flex-shrink:0}.overview-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overview-meta{font-size:.7rem;color:var(--text-dim);white-space:nowrap;flex-shrink:0}.overview-dot{width:6px;height:6px;border-radius:50%;background:#3b82f6;flex-shrink:0}.overview-dot-note{background:#10b981}.overview-dot-chat{background:#8b5cf6}.overview-empty{color:var(--text-dim);font-size:.78rem;padding:8px 0}.overview-more{font-size:.72rem;color:var(--text-dim);padding:2px 0;margin-top:2px}.task-item-preview{display:flex;align-items:center;gap:8px;padding:4px 0}.task-item-preview input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.task-priority-indicator{font-size:.7rem;font-weight:700;min-width:14px}.task-item-preview span{font-size:.82rem;color:var(--text-muted)}.task-item-preview span.completed{text-decoration:line-through;color:var(--text-dim)}.view-more-btn{background:none;border:none;color:var(--accent);font-size:.78rem;cursor:pointer;padding:2px 0}.event-item-preview{padding:4px 0}.event-title{font-size:.82rem;color:var(--text-muted)}.event-time{font-size:.74rem;color:var(--text-dim);margin-top:1px}.event-description{font-size:.74rem;color:var(--text-dim);margin-top:3px;white-space:pre-wrap;line-height:1.4}.note-item-preview{padding:6px 0;cursor:pointer;border-bottom:1px solid var(--border)}.note-item-preview:last-child{border-bottom:none}.note-title{font-size:.85rem;color:var(--text);font-weight:500}.note-preview{font-size:.75rem;color:var(--text-dim);margin-top:2px}.section-view{display:flex;flex-direction:column;gap:16px}.section-view-header{display:flex;align-items:center;gap:14px}.back-button-section{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);padding:5px 12px;font-size:.82rem;cursor:pointer;transition:all .15s}.back-button-section:hover{border-color:var(--border-light);color:var(--text)}.section-view-header h2{font-size:1rem;font-weight:600;color:var(--text)}.tasks-list{display:flex;flex-direction:column;gap:4px}.task-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s}.task-item:hover{border-color:var(--border-light)}.task-item input[type=checkbox]{accent-color:var(--accent)}.task-item span.completed{text-decoration:line-through;color:var(--text-dim)}.task-priority-buttons{display:flex;gap:3px;margin-left:auto}.priority-btn{padding:2px 6px;background:none;border:1px solid var(--border);border-radius:3px;font-size:.7rem;cursor:pointer;transition:all .12s}.priority-btn.active{background:#0003}.task-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1rem;padding:0 2px;opacity:0;transition:all .12s}.task-item:hover .task-delete{opacity:1}.task-delete:hover{color:var(--danger)}.add-task{display:flex;gap:8px;align-items:center;padding:10px 0;margin-top:4px}.priority-selector{display:flex;gap:3px}.priority-select-btn{padding:4px 8px;background:none;border:1px solid var(--border);border-radius:3px;font-size:.75rem;cursor:pointer;transition:all .12s}.priority-select-btn.active{background:#0003}.add-task input{flex:1;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;outline:none;transition:border-color .15s}.add-task input:focus{border-color:var(--border-light)}.add-task input::placeholder{color:var(--text-dim)}.add-task button{padding:8px 16px;background:var(--accent);color:#0a0a0a;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.add-task button:hover{opacity:.85}.events-list{display:flex;flex-direction:column;gap:4px}.event-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.event-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.1rem;opacity:0;transition:all .12s}.event-item:hover .event-delete{opacity:1}.event-delete:hover{color:var(--danger)}.notes-list{display:flex;flex-direction:column;gap:4px}.note-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s}.note-item:hover{border-color:var(--border-light)}.note-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.1rem;opacity:0;transition:all .12s}.note-item:hover .note-delete{opacity:1}.note-delete:hover{color:var(--danger)}.modal{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:0;width:100%;max-width:440px;overflow:hidden}.note-modal{max-width:680px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:.95rem;font-weight:600;color:var(--text)}.modal-header button{background:none;border:none;color:var(--text-dim);font-size:1.4rem;cursor:pointer;line-height:1}.modal-header button:hover{color:var(--text)}.modal-content{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.note-content{gap:12px}.modal-content input[type=text],.modal-content input[type=datetime-local]{width:100%;padding:9px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;outline:none;transition:border-color .15s}.modal-content input:focus{border-color:var(--accent)}.modal-content input::placeholder{color:var(--text-dim)}.note-title-input{font-size:1rem!important;font-weight:600;border:none!important;border-bottom:1px solid var(--border)!important;border-radius:0!important;padding:4px 0!important;background:none!important}.note-title-input:focus{border-bottom-color:var(--accent)!important}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border)}.save-button{padding:7px 18px;background:var(--accent);color:#0a0a0a;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.save-button:hover{opacity:.85}.cancel-button{padding:7px 14px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .15s}.cancel-button:hover{border-color:var(--border-light);color:var(--text)}.notes-tree{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;padding:6px 0;min-height:80px}.notes-tree-empty{padding:20px 16px;color:var(--text-dim);font-size:.82rem;text-align:center}.unfiled-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);padding:10px 12px 4px}.folder-row{display:flex;align-items:center;gap:6px;padding-top:5px;padding-bottom:5px;padding-right:8px;min-height:30px;cursor:default;transition:background .12s;position:relative}.folder-row:hover{background:var(--surface-2)}.folder-toggle{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:3px;transition:color .12s}.folder-toggle:hover{color:var(--accent)}.folder-icon-svg{flex-shrink:0}.folder-row-name{font-size:.83rem;color:var(--text-muted);font-weight:500;flex:1;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-row:hover .folder-row-name{color:var(--text)}.folder-rename-input{flex:1;background:var(--surface-3);border:1px solid var(--accent);border-radius:3px;color:var(--text);font-size:.83rem;padding:2px 6px;outline:none;min-width:0}.folder-count{font-size:.68rem;color:var(--text-dim);min-width:14px;text-align:right}.note-tree-row{display:flex;align-items:center;gap:7px;padding-top:4px;padding-bottom:4px;padding-right:8px;min-height:28px;transition:background .12s;position:relative}.note-tree-row:hover{background:var(--surface-2)}.note-icon-svg{flex-shrink:0;opacity:.6}.note-tree-title{font-size:.82rem;color:var(--text-muted);flex:1;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-tree-row:hover .note-tree-title{color:var(--text)}.item-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s;flex-shrink:0}.folder-row:hover .item-actions,.note-tree-row:hover .item-actions{opacity:1}.icon-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .12s;flex-shrink:0;padding:0}.icon-btn:hover{background:var(--surface-3);color:var(--text)}.icon-btn.danger:hover{background:#ef44441f;color:var(--danger)}.tree-header-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.78rem;cursor:pointer;transition:all .15s}.tree-header-btn:hover{border-color:var(--border-light);color:var(--text)}.tree-header-btn.accent{border-color:#de8f0059;color:var(--accent)}.tree-header-btn.accent:hover{background:#de8f0014;border-color:var(--accent)}.move-dropdown{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1100;background:var(--surface-2);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:0 12px 40px #0009;min-width:220px;max-width:300px;max-height:400px;overflow-y:auto;padding:4px 0}.move-dropdown-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);padding:8px 12px 4px}.move-option{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text-muted);font-size:.82rem;padding:6px 12px;cursor:pointer;transition:background .1s,color .1s}.move-option:hover{background:var(--surface-3);color:var(--text)}.move-option.active{color:var(--accent)}.task-deadline-badge{font-size:.68rem;font-weight:600;white-space:nowrap;flex-shrink:0}.overview-tree-content{padding:8px 12px!important}.overview-folder-row{display:flex;align-items:center;gap:5px;padding:3px 0;cursor:pointer;transition:background .12s;border-radius:4px;font-size:.8rem;color:var(--text-muted)}.overview-folder-row:hover{color:var(--text)}.overview-folder-name{font-size:.8rem;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overview-folder-count{font-size:.65rem;color:var(--text-dim);min-width:12px;text-align:right}.overview-item-row{display:flex;align-items:center;gap:5px;padding:2px 0;font-size:.78rem;color:var(--text-muted);cursor:pointer;transition:color .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overview-item-row:hover{color:var(--text)}.overview-task-row{display:flex;align-items:center;gap:5px;padding:2px 0;font-size:.78rem;color:var(--text-muted)}.no-project{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim);font-size:.9rem}.back-button,.mobile-projects-menu,.projects-overlay,.mobile-sidebar-close{display:none}@media(max-width:768px){.projects-page{height:100%;overflow:hidden}.projects-header{padding:12px 16px}.projects-container{flex-direction:column;overflow:hidden}.projects-sidebar{width:100%;height:auto;max-height:none;border-right:none;border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden}.sidebar-header{padding:8px 12px}.projects-list{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;padding:6px 8px;gap:0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.projects-list::-webkit-scrollbar{display:none}.project-item{flex-shrink:0;padding:6px 14px;border-left:none;border-bottom:2px solid transparent;border-radius:0;white-space:nowrap}.project-item.active{border-left:none;border-bottom:2px solid var(--text);padding-left:14px;background:var(--surface-2)}.project-item.primary-top{border-left:none;border-bottom:2px solid transparent;padding-left:14px;margin-bottom:0;margin-right:2px;padding-top:6px;padding-bottom:6px}.project-item.primary-top.active{border-left:none;border-bottom:2px solid var(--accent);box-shadow:none}.drag-handle,.delete-button,.project-star-btn{display:none}.projects-main{flex:1;padding:14px 16px;overflow-y:auto;min-height:0}.project-header{margin-bottom:14px}.project-header-top{flex-wrap:wrap;gap:6px}.project-header-top h2{font-size:1.05rem}.sections-grid{grid-template-columns:1fr;gap:10px}.section-view-header{flex-wrap:wrap;gap:8px}.section-view-header h2{font-size:.95rem;flex:1;min-width:0}.tree-header-btn{font-size:.72rem;padding:5px 10px}.back-button-section{padding:5px 10px;font-size:.78rem}.task-item{padding:8px 10px;gap:6px}.task-priority-buttons{gap:2px}.priority-btn{padding:2px 5px;font-size:.65rem}.add-task{flex-wrap:wrap;gap:6px}.add-task input{min-width:0}.notes-tree{padding:4px 0}.modal-overlay{padding:16px}.modal-overlay .modal,.modal-overlay .new-task-modal{max-width:100%;width:100%}.new-task-modal{max-width:100%;padding:18px}.new-task-modal-field input,.new-task-modal-field select{font-size:16px}.new-task-modal-priorities{flex-wrap:wrap}.no-project{font-size:.85rem;padding:24px}.rich-text-editor{min-height:280px}.editor-toolbar{padding:4px;gap:2px}.editor-toolbar button{padding:6px 8px;font-size:.78rem}}.new-task-modal{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:420px;display:flex;flex-direction:column;gap:18px}.new-task-modal h3{font-size:1.1rem;font-weight:600;color:var(--text);margin:0}.new-task-modal-field{display:flex;flex-direction:column;gap:6px}.new-task-modal-field label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.new-task-modal-field input[type=text],.new-task-modal-field input[type=datetime-local],.new-task-modal-field select{padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9rem;outline:none;transition:border-color .15s}.new-task-modal-field input:focus,.new-task-modal-field select:focus{border-color:var(--accent)}.new-task-modal-priorities{display:flex;gap:6px}.new-task-modal-priority{padding:5px 14px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--text-muted);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s}.new-task-modal-priority.active{border-color:var(--prio-color);color:var(--prio-color);background:#00000040}.new-task-modal-priority:hover{border-color:var(--prio-color);color:var(--prio-color)}.new-task-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.new-task-modal-cancel{padding:8px 16px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .15s}.new-task-modal-cancel:hover{border-color:var(--text-muted);color:var(--text)}.new-task-modal-save{padding:8px 20px;background:var(--accent);border:none;border-radius:var(--radius-sm);color:#0a0a0a;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.new-task-modal-save:hover{opacity:.85}.todos-page{height:100%;overflow-y:auto;padding:32px 36px;display:flex;flex-direction:column;gap:20px}.page-title{font-size:1.5rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.page-subtitle{font-size:.85rem;color:var(--text-muted);margin-top:3px}.todo-add-row{display:flex;gap:10px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;flex-wrap:wrap}.todo-input{flex:1;min-width:200px;background:none;border:none;outline:none;color:var(--text);font-size:.9rem}.todo-input::placeholder{color:var(--text-dim)}.priority-pills{display:flex;gap:4px}.priority-pill{padding:3px 10px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--text-muted);font-size:.72rem;font-weight:500;cursor:pointer;transition:all .15s}.priority-pill.active{border-color:var(--pill-color);color:var(--pill-color);background:#0000004d}.priority-pill:hover{border-color:var(--pill-color);color:var(--pill-color)}.btn-add{padding:6px 16px;background:var(--accent);color:#0a0a0a;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-add:hover{opacity:.85}.todos-toolbar{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.filter-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);padding-bottom:0}.task-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column;gap:12px}.task-card:hover{border-color:var(--border-light);background:var(--surface-2)}.task-card.primary{border-color:#de8f004d;background:#de8f000a}.task-card.primary:hover{border-color:#de8f0080;background:#de8f0012}.task-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.task-card-name{font-size:.9rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-card-star{color:var(--accent)}.task-card-count{font-size:.7rem;font-weight:500;color:var(--text-dim);white-space:nowrap}.task-card-list{list-style:none;display:flex;flex-direction:column;gap:6px}.task-card-list li{display:flex;align-items:center;gap:8px}.task-card-list li.completed{opacity:.4}.task-card-list li.completed .task-card-title{text-decoration:line-through}.task-card-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.task-card-title{font-size:.84rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.task-card-deadline{font-size:.68rem;color:var(--text-dim);white-space:nowrap}.task-card-deadline.overdue{color:var(--danger)}.task-card-more{font-size:.75rem;color:var(--text-dim)}.task-card-footer{font-size:.78rem;color:var(--accent);margin-top:auto}.standalone-section{display:flex;flex-direction:column;gap:10px}.standalone-header{display:flex;align-items:center;gap:10px}.standalone-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.standalone-count{font-size:.72rem;color:var(--text-dim)}.todos-empty{color:var(--text-dim);font-size:.9rem;padding:40px 0;text-align:center}.todo-list{list-style:none;display:flex;flex-direction:column;gap:2px}.todo-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background .12s}.todo-item:hover{background:var(--surface-2)}.todo-item.completed{opacity:.45}.todo-item.completed .todo-title{text-decoration:line-through}.todo-checkbox{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-light);background:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;color:var(--accent)}.todo-checkbox.checked{border-color:var(--accent);background:var(--accent-dim)}.todo-checkbox:hover{border-color:var(--accent)}.todo-priority-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.todo-title{flex:1;font-size:.875rem;color:var(--text)}.todo-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;padding:2px;border-radius:4px;opacity:0;transition:all .15s}.todo-item:hover .todo-delete{opacity:1}.todo-delete:hover{color:var(--danger);background:#ef44441a}@media(max-width:768px){.todos-page{padding:16px 14px;gap:16px}.page-title{font-size:1.25rem}.todo-add-row{padding:8px 12px;flex-wrap:nowrap}.todo-input{min-width:120px}.priority-pills{display:none}.task-card-grid{grid-template-columns:1fr;gap:10px}.task-card{padding:14px 16px}.task-card-name{font-size:.85rem}.todo-item{padding:10px 12px;gap:8px}.filter-tab{padding:8px 12px}}.calendar-page{height:100%;display:flex;flex-direction:column;overflow:hidden;padding:28px 32px 0}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-shrink:0}.cal-nav{display:flex;align-items:center;gap:12px}.cal-nav-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);width:30px;height:30px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:border-color .15s}.cal-nav-btn:hover{border-color:var(--accent);color:var(--accent)}.cal-month-label{font-size:.95rem;font-weight:600;color:var(--text);min-width:140px;text-align:center}.calendar-body{display:flex;gap:16px;flex:1;overflow:hidden;padding-bottom:20px}.cal-grid-wrap{flex:1;overflow-y:auto}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.cal-day-header{background:var(--surface);padding:8px 4px;text-align:center;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.cal-cell{background:var(--surface);min-height:90px;padding:6px 8px;cursor:pointer;transition:background .15s;display:flex;flex-direction:column;gap:3px}.cal-cell.empty{background:var(--bg);cursor:default}.cal-cell:not(.empty):hover{background:var(--surface-2)}.cal-cell.today .cal-day-num{background:var(--accent);color:#0a0a0a;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center}.cal-cell.selected{background:var(--surface-3)}.cal-day-num{font-size:.8rem;color:var(--text-muted);font-weight:500;width:22px;height:22px;display:flex;align-items:center;justify-content:center}.cal-event-dot-label{font-size:.67rem;background:var(--accent-dim);color:var(--accent);border-radius:3px;padding:1px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-more{font-size:.67rem;color:var(--text-dim)}.cal-side{width:0;overflow:hidden;transition:width .2s ease;flex-shrink:0}.cal-side.visible{width:240px}.cal-side-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;font-size:.85rem;font-weight:600;color:var(--text)}.btn-add-event{background:var(--accent-dim);border:1px solid rgba(222,143,0,.3);border-radius:var(--radius-sm);color:var(--accent);font-size:.75rem;font-weight:600;padding:4px 10px;cursor:pointer;transition:background .15s}.btn-add-event:hover{background:#de8f0040}.cal-no-events{font-size:.85rem;color:var(--text-dim)}.cal-event-list{list-style:none;display:flex;flex-direction:column;gap:8px}.cal-event-item{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.cal-event-time{font-size:.72rem;color:var(--text-muted);white-space:nowrap;margin-top:1px;min-width:52px}.cal-event-info{flex:1}.cal-event-title{font-size:.82rem;color:var(--text)}.cal-event-project{font-size:.72rem;color:var(--text-dim);margin-top:2px}.cal-event-desc{font-size:.72rem;color:var(--text-dim);margin-top:3px;white-space:pre-wrap;line-height:1.3}.cal-event-del{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px;opacity:0;transition:opacity .15s,color .15s}.cal-event-item:hover .cal-event-del{opacity:1}.cal-event-del:hover{color:var(--danger)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.cal-modal{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:360px}.cal-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cal-modal-header h3{font-size:.95rem;font-weight:600;color:var(--text)}.modal-close{background:none;border:none;color:var(--text-dim);font-size:1.3rem;cursor:pointer;line-height:1}.cal-modal-body{display:flex;flex-direction:column;gap:10px}.cal-input{width:100%;padding:9px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;outline:none;transition:border-color .15s}.cal-input:focus{border-color:var(--accent)}.cal-input option{background:var(--surface-2)}.cal-modal-footer{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.btn-save{padding:7px 18px;background:var(--accent);color:#0a0a0a;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-save:hover{opacity:.85}.btn-cancel{padding:7px 14px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:border-color .15s}.btn-cancel:hover{border-color:var(--border-light);color:var(--text)}@media(max-width:768px){.calendar-page{padding:12px 10px 0}.calendar-header{margin-bottom:12px;flex-wrap:wrap;gap:8px}.cal-month-label{font-size:.85rem;min-width:110px}.calendar-body{flex-direction:column;gap:0}.cal-cell{min-height:60px;padding:4px}.cal-day-num{font-size:.72rem;width:18px;height:18px}.cal-event-dot-label{font-size:.6rem;padding:0 3px}.cal-day-header{padding:6px 2px;font-size:.65rem}.cal-side.visible{width:100%;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:16px;z-index:100;height:50vh;max-height:50vh;overflow-y:auto}.cal-modal{max-width:calc(100vw - 32px);padding:20px}.cal-input{font-size:16px}}.budget-page{height:100%;overflow-y:auto;padding:32px 36px;display:flex;flex-direction:column;gap:20px}.budget-header{display:flex;align-items:flex-start;justify-content:space-between}.btn-add-item{padding:7px 16px;background:var(--accent);color:#0a0a0a;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s;margin-top:4px}.btn-add-item:hover{opacity:.85}.budget-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;gap:6px}.summary-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.summary-amount{font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.summary-card.income .summary-amount{color:var(--success)}.summary-card.expenses .summary-amount{color:#ff6b6b}.summary-card.positive .summary-amount{color:var(--success)}.summary-card.negative .summary-amount{color:var(--danger)}.filter-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border)}.filter-tab{padding:6px 14px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:color .15s;margin-bottom:-1px}.filter-tab:hover{color:var(--text)}.filter-tab.active{color:var(--text);border-bottom-color:var(--accent)}.budget-overview{display:flex;flex-direction:column;gap:20px}.budget-empty{color:var(--text-dim);font-size:.875rem;padding:12px 0}.daily-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.daily-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.daily-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.daily-value{font-size:1.15rem;font-weight:700;letter-spacing:-.01em;color:var(--text);display:flex;align-items:baseline;gap:2px}.daily-value.income{color:var(--success)}.daily-value.expenses{color:#ff6b6b}.daily-value.not-set{color:var(--text-dim);font-size:.82rem;font-weight:500;cursor:pointer}.daily-unit{font-size:.7rem;font-weight:500;color:var(--text-muted);margin-left:1px}.overview-section{display:flex;flex-direction:column;gap:10px}.ov-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.today-chips{display:flex;gap:8px;flex-wrap:wrap}.today-chip{padding:4px 12px;border-radius:20px;font-size:.82rem;font-weight:600}.today-chip.income{background:#22c55e1f;color:var(--success)}.today-chip.expenses{background:#ff6b6b1f;color:#ff6b6b}.category-list{display:flex;flex-direction:column;gap:10px}.category-row{display:flex;flex-direction:column;gap:5px}.category-info{display:flex;justify-content:space-between;align-items:center}.category-name{font-size:.85rem;color:var(--text)}.category-amount{font-size:.85rem;color:var(--text-muted)}.category-bar-bg{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden}.category-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}.recurring-list{display:flex;flex-direction:column;gap:4px}.recurring-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s}.recurring-item:hover{border-color:var(--border-light)}.recurring-amounts{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.recurring-monthly{font-size:.72rem;color:var(--text-dim)}.transactions-list{display:flex;flex-direction:column;gap:4px}.tx-group{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.tx-group-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:4px 0 2px}.transaction-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s}.transaction-item:hover{border-color:var(--border-light)}.tx-type-badge{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;flex-shrink:0}.tx-type-badge.income{background:#22c55e26;color:var(--success)}.tx-type-badge.expense{background:#ef444426;color:var(--danger)}.tx-info{flex:1;min-width:0}.tx-description{font-size:.875rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-meta{font-size:.75rem;color:var(--text-dim);margin-top:1px}.freq-badge{display:inline-block;padding:1px 6px;background:var(--surface-2);border-radius:3px;font-size:.7rem;color:var(--text-muted);font-weight:500}.tx-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.tx-monthly-equiv{font-size:.72rem;color:var(--text-dim)}.tx-amount{font-size:.875rem;font-weight:600}.tx-amount.income{color:var(--success)}.tx-amount.expense{color:#ff6b6b}.tx-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:3px;border-radius:4px;opacity:0;transition:all .15s;font-size:1.1rem;flex-shrink:0}.transaction-item:hover .tx-delete,.recurring-item:hover .tx-delete{opacity:1}.tx-delete:hover{color:var(--danger);background:#ef44441a}.savings-tab{display:flex;flex-direction:column;gap:16px}.finance-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.finance-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface-2)}.finance-card-title{font-size:.875rem;font-weight:600;color:var(--text)}.finance-card-quick{font-size:.875rem;font-weight:600;color:var(--accent);letter-spacing:-.01em}.finance-card-body{padding:16px 18px;display:flex;flex-direction:column;gap:14px}.finance-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.finance-field{display:flex;flex-direction:column;gap:5px}.finance-field label{font-size:.75rem;font-weight:500;color:var(--text-muted)}.finance-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;padding:7px 10px;transition:border-color .15s;width:100%;box-sizing:border-box}.finance-input:focus{outline:none;border-color:var(--accent)}.field-hint{font-size:.7rem;color:var(--text-dim);line-height:1.4}.finance-stats-row{display:flex;gap:24px}.finance-stat{display:flex;flex-direction:column;gap:2px}.finance-stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.finance-stat-val{font-size:1.1rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.finance-stat-val.pos{color:var(--success)}.finance-stat-val.neg{color:var(--danger)}.fin-bar-wrap{display:flex;flex-direction:column;gap:5px}.fin-bar-bg{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.fin-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.fin-bar-fill.tfsa{background:var(--accent)}.fin-bar-fill.rrsp{background:#818cf8}.fin-bar-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-dim)}.finance-calc-display{display:flex;flex-direction:column;gap:2px;padding:7px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;color:var(--text)}.finance-calc-note{font-size:.7rem;font-weight:400;color:var(--text-dim)}.finance-note{font-size:.75rem;color:var(--text-dim);line-height:1.5;margin:0}.pos{color:var(--success)}.neg{color:var(--danger)}.alloc-total{font-size:1rem;font-weight:700;padding:8px 10px;border-radius:var(--radius-sm)}.alloc-total span{font-size:.72rem;font-weight:400;margin-left:4px}.alloc-total.ok{color:var(--success);background:#22c55e1a}.alloc-total.warn{color:#de8f00;background:#de8f001a}.alloc-pct-check{justify-content:center}.alloc-buckets{display:flex;flex-direction:column;gap:14px}.alloc-bucket{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px}.alloc-bucket-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.alloc-bucket-info{display:flex;flex-direction:column;gap:2px}.alloc-bucket-label{font-size:.875rem;font-weight:600}.alloc-bucket-desc{font-size:.72rem;color:var(--text-dim)}.alloc-pct-wrap{display:flex;align-items:center;gap:2px;flex-shrink:0}.alloc-pct-input{width:52px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.875rem;font-weight:600;padding:5px 8px;text-align:right}.alloc-pct-input:focus{outline:none;border-color:var(--accent)}.alloc-pct-sym{font-size:.85rem;color:var(--text-muted);font-weight:600}.alloc-target-line{font-size:.78rem;color:var(--text-muted)}.alloc-target-line strong{color:var(--text)}.alloc-progress{display:flex;flex-direction:column;gap:5px}.tax-block{display:flex;flex-direction:column;gap:8px}.tax-block-title{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.tax-table{display:flex;flex-direction:column;gap:2px}.tax-row{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;border-radius:var(--radius-sm);font-size:.82rem}.tax-row:nth-child(odd){background:var(--surface-2)}.tax-range{color:var(--text)}.tax-rate{color:var(--accent);font-weight:600}.budget-modal{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:360px}.type-toggle{display:flex;gap:4px;background:var(--surface-2);padding:3px;border-radius:var(--radius-sm)}.type-btn{flex:1;padding:6px;border:none;border-radius:4px;font-size:.82rem;font-weight:500;cursor:pointer;background:none;color:var(--text-muted);transition:all .15s}.type-btn.active.expense{background:#ef444433;color:var(--danger)}.type-btn.active.income{background:#22c55e33;color:var(--success)}@media(max-width:768px){.budget-page{padding:16px 14px;gap:16px}.budget-header{flex-direction:column;gap:10px}.budget-summary{grid-template-columns:1fr;gap:10px}.summary-card{padding:14px 16px}.summary-amount{font-size:1.2rem}.daily-row{grid-template-columns:1fr;gap:8px}.daily-card{padding:12px 14px}.finance-row{grid-template-columns:1fr}.finance-stats-row{flex-wrap:wrap;gap:14px}.finance-card-body{padding:14px 16px}.finance-input{font-size:16px}.transaction-item,.recurring-item{padding:10px 12px;gap:10px}.tx-description,.tx-amount{font-size:.82rem}.budget-modal{max-width:calc(100vw - 32px);padding:20px}.alloc-bucket{padding:12px}.alloc-bucket-top{flex-direction:column;gap:8px}.tax-row{padding:6px 8px;font-size:.78rem}}
