*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #ffffff;--bg-surface: #fafbfc;--bg-hover: #f3f4f6;--bg-active: #eef0f4;--border: #e5e7eb;--border-light: #f0f1f3;--text: #111827;--text-secondary: #4b5563;--text-muted: #9ca3af;--primary: #2563eb;--primary-light: #eff6ff;--primary-hover: #1d4ed8;--danger: #ef4444;--danger-light: #fef2f2;--success: #10b981;--slot-hover: rgba(37, 99, 235, .06);--radius: 8px;--radius-sm: 6px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--transition: .15s ease}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;height:100vh;height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100vh;height:100dvh}.app{display:flex;height:100vh}.sidebar{width:var(--sidebar-width, 360px);min-width:0;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;padding:24px 20px;padding-top:calc(24px + env(safe-area-inset-top));transition:background var(--transition)}.sidebar-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.sidebar-title{font-size:1.4rem;font-weight:600;letter-spacing:.04em;color:var(--text);margin-bottom:4px}.sidebar-title-separator{color:#4f46e5;font-weight:600}.sidebar-top-actions{display:flex;align-items:center;gap:4px}.settings-btn{color:var(--text-muted)}.sidebar-close-btn{display:none;color:var(--text-muted)}.search-bar{position:relative;margin-bottom:12px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 32px 7px 30px;color:var(--text);font-size:.8125rem;font-family:inherit;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}.search-input::placeholder{color:var(--text-muted)}.search-clear{position:absolute;right:4px;top:50%;transform:translateY(-50%)}.voice-bar{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;margin-bottom:12px;background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8125rem;font-family:inherit;cursor:pointer;transition:all var(--transition)}.voice-bar:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.voice-bar.voice-listening{border-color:var(--danger);border-style:solid;color:var(--danger);background:var(--danger-light);animation:voice-pulse 1s ease-in-out infinite}.voice-bar.voice-processing{border-color:var(--primary);border-style:solid;color:var(--primary);background:var(--primary-light)}@keyframes voice-pulse{0%,to{opacity:1}50%{opacity:.7}}.voice-error-msg{font-size:.6875rem;color:var(--danger);margin-top:-8px;margin-bottom:8px}.settings-api-key-row{display:flex;align-items:center;gap:6px}.settings-api-key-row .input{font-family:monospace;font-size:.75rem}.settings-key-field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.settings-key-field:last-child{margin-bottom:0}.add-todo-form{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.add-todo-row{display:flex;gap:8px}.add-todo-row .select-sm{flex:1}.add-todo-row .btn{min-width:72px}.textarea-sm{resize:vertical;min-height:36px;max-height:80px;font-family:inherit;line-height:1.4}.input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;color:var(--text);font-size:.8125rem;font-family:inherit;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}.input::placeholder{color:var(--text-muted)}.select-sm{padding:6px 28px 6px 10px;font-size:.8125rem;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239CA3AF' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 14px;color:var(--text-secondary);font-size:.8125rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn:hover{background:var(--bg-hover);border-color:#d1d5db}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:var(--danger-light)}.btn-nav{padding:6px 8px;color:var(--text-muted)}.btn-nav:hover{color:var(--text)}.btn-today{font-weight:500;padding:6px 16px}.btn-today-active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.btn-sm{padding:4px 10px;font-size:.75rem}.btn-icon{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);line-height:0;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{color:var(--text);background:var(--bg-hover)}.btn-delete:hover{color:var(--danger);background:var(--danger-light)}.quick-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.chip{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:500;font-family:inherit;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap}.chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.chip-active{background:var(--primary);border-color:var(--primary);color:#fff}.chip-active:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}.chip-clear{background:none;border-color:transparent;color:var(--text-muted);font-size:.6875rem;padding:4px 8px}.chip-clear:hover{color:var(--danger);background:var(--danger-light);border-color:transparent}.chip-dot:after{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--primary);margin-left:4px;vertical-align:middle}.chip-active.chip-dot:after{background:#fff}.chip-divider{width:1px;height:16px;background:var(--border);align-self:center;flex-shrink:0}.chip svg{vertical-align:-1px}.filter-section{margin-bottom:16px}.btn-filter{width:100%;justify-content:flex-start;background:var(--bg);font-size:.8125rem;color:var(--text-muted)}.btn-filter:hover{color:var(--text-secondary)}.btn-filter-active{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.filter-clear{margin-left:auto;background:none;border:none;color:var(--primary);font-size:.75rem;font-weight:500;cursor:pointer;font-family:inherit}.filter-panel{margin-top:8px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:10px}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.filter-row{display:flex;align-items:center;gap:6px}.filter-row .input{flex:1}.filter-sep{color:var(--text-muted);font-size:.75rem}.category-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.category-header h2{font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600}.add-category-form{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.color-picker{display:flex;gap:6px}.color-dot{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition)}.color-dot:hover{transform:scale(1.15)}.color-dot.selected{box-shadow:0 0 0 2px #fff,0 0 0 4px currentColor;transform:scale(1.15)}.category-group{margin-bottom:12px;border-radius:var(--radius);padding:2px;transition:background var(--transition),box-shadow var(--transition)}.category-drop-over{background:var(--primary-light);box-shadow:inset 0 0 0 1.5px var(--primary)}.category-label{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.category-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.category-count{color:var(--text-muted);font-size:.6875rem;font-weight:400;background:var(--bg-hover);padding:1px 6px;border-radius:10px;margin-left:auto}.category-label .btn-delete{opacity:0;transition:opacity var(--transition)}.category-label:hover .btn-delete{opacity:1}.empty-state{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:.8125rem}.todo-card{border-radius:var(--radius-sm);padding:8px 10px;margin:3px 0;cursor:grab;transition:box-shadow var(--transition),filter var(--transition);-webkit-user-select:none;user-select:none;border:1px solid transparent}.todo-card:hover{box-shadow:var(--shadow);filter:brightness(.95)}.todo-card.completed .todo-title{text-decoration:line-through;color:var(--text-muted)}.todo-card.compact{padding:3px 6px;margin:1px 0;font-size:.7rem}.todo-card.compact .todo-card-main{align-items:center;gap:4px}.todo-card.compact .todo-title{font-size:.7rem;white-space:normal;word-break:break-word}.todo-card.compact .todo-actions{display:none}.todo-card-main{display:flex;align-items:flex-start;gap:8px}.todo-check{width:18px;height:18px;border-radius:50%;border:1.5px solid rgba(0,0,0,.2);background:#fff9;color:#fff;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition);margin-top:1px}.todo-check:hover{border-color:var(--primary);background:var(--primary-light)}.todo-check.checked{background:var(--success);border-color:var(--success);color:#fff}.todo-content{flex:1;min-width:0}.todo-title{font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;color:var(--text);line-height:1.3}.todo-meta{display:flex;align-items:center;gap:8px;margin-top:2px}.priority-badge{font-size:.6875rem;font-weight:600;letter-spacing:.01em}.effort-badge{font-size:.6875rem;color:var(--text-muted);font-weight:500}.todo-card.overdue{border-color:#ef44444d}.overdue-badge{color:var(--danger)!important;font-weight:700}.recurrence-badge{display:inline-flex;align-items:center;gap:3px;font-size:.625rem;color:var(--text-muted);font-weight:500;text-transform:capitalize}.recurrence-badge svg{flex-shrink:0}.chip-overdue{background:var(--danger-light);border-color:var(--danger);color:var(--danger);font-weight:600}.chip-overdue:hover{background:var(--danger);border-color:var(--danger);color:#fff}.todo-description{font-size:.75rem;color:var(--text-muted);line-height:1.4;margin-top:2px;white-space:pre-wrap;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.todo-meeting{position:relative;border-left:3px solid #8b5cf6}.meeting-badge{position:absolute;top:4px;right:6px;color:#8b5cf6;line-height:0;opacity:.7}.meeting-check-label{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:.8125rem;color:var(--text-muted);-webkit-user-select:none;user-select:none}.meeting-check-label:hover{color:var(--text-secondary)}.meeting-check{width:16px;height:16px;border-radius:3px;border:1.5px solid var(--border);display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0;background:var(--bg)}.meeting-check:hover{border-color:#8b5cf6}.meeting-check-active{background:#8b5cf6;border-color:#8b5cf6;color:#fff}.todo-card-editing{padding:10px;display:flex;flex-direction:column;gap:8px;border:1px solid var(--primary);box-shadow:0 0 0 3px #2563eb14;cursor:default}.edit-title-input{font-size:.8125rem;font-weight:500;padding:6px 8px}.edit-desc-input{font-size:.8125rem;padding:6px 8px}.edit-row{display:flex;gap:6px}.edit-row .input{flex:1}.edit-field{flex:1;display:flex;flex-direction:column;gap:3px}.edit-category-label{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--text-secondary)}.edit-actions{display:flex;gap:6px;justify-content:flex-end}.priority-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.todo-compact-meta{display:flex;align-items:center;gap:4px;margin-top:1px}.todo-actions{display:flex;align-items:center;gap:1px;opacity:0;transition:opacity var(--transition);flex-shrink:0}.todo-card:hover .todo-actions{opacity:1}.effort-select{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);font-size:.6875rem;padding:2px 4px;cursor:pointer;font-family:inherit}.calendar{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;padding-top:calc(14px + env(safe-area-inset-top));border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg)}.calendar-nav{display:flex;align-items:center;gap:4px}.calendar-date{font-size:1rem;font-weight:600;margin-left:12px;color:var(--text);letter-spacing:-.01em}.view-toggle{display:flex;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:2px}.view-btn{background:none;border:none;padding:5px 16px;font-size:.8125rem;font-weight:500;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);font-family:inherit}.view-btn:hover{color:var(--text-secondary)}.view-btn.active{background:var(--bg);color:var(--text);box-shadow:var(--shadow-sm)}.day-view{flex:1;overflow-y:auto}.day-grid{position:relative;padding:0 24px}.time-row{display:flex;border-bottom:1px solid var(--border-light);position:relative}.time-label{width:72px;min-width:72px;font-size:.6875rem;color:var(--text-muted);padding:4px 12px 4px 0;text-align:right;flex-shrink:0;font-weight:500;font-variant-numeric:tabular-nums}.time-slot-container{flex:1;display:flex;flex-direction:column;cursor:pointer}.five-min-slot{transition:background var(--transition)}.five-min-slot.slot-over{background:var(--slot-hover);border-radius:2px}.day-todos-overlay{position:absolute;top:0;left:96px;right:24px;pointer-events:none}.scheduled-todo{position:absolute;z-index:1;pointer-events:auto;padding:0 1px}.scheduled-todo:has(.todo-card-editing){z-index:50}.scheduled-todo .todo-card{height:100%;display:flex;flex-direction:column;justify-content:flex-start;box-shadow:var(--shadow-sm);overflow:hidden;padding:2px 8px;margin:0}.scheduled-todo .todo-title{font-size:.75rem}.scheduled-todo .todo-card-editing{height:auto;position:absolute;top:0;left:0;right:0;z-index:50;background:#fff!important;box-shadow:var(--shadow-lg);overflow:visible;padding:10px;min-width:280px}.scheduled-todo-time{position:absolute;top:2px;right:8px;font-size:.625rem;color:var(--text-muted);font-weight:500;pointer-events:none;z-index:2;font-variant-numeric:tabular-nums}.current-time-line{position:absolute;left:0;right:24px;z-index:5;pointer-events:none;display:flex;align-items:center}.current-time-text{width:64px;min-width:64px;text-align:right;padding-right:6px;font-size:.625rem;font-weight:700;color:var(--danger);font-variant-numeric:tabular-nums;line-height:1}.current-time-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);margin-left:-1px;flex-shrink:0}.current-time-rule{flex:1;height:1.5px;background:var(--danger)}.week-current-time-line{position:absolute;left:0;right:0;z-index:8;pointer-events:none;display:flex;align-items:center}.hover-time-indicator{position:absolute;left:0;right:0;z-index:10;pointer-events:none;display:flex;align-items:center;height:0}.hover-time-label{width:72px;min-width:72px;text-align:right;padding-right:8px;font-size:.6875rem;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums;line-height:1}.hover-time-rule{flex:1;height:1.5px;background:var(--primary);opacity:.5}.week-view{flex:1;overflow:hidden;display:flex;flex-direction:column}.week-header{display:flex;border-bottom:1px solid var(--border);padding:8px 0;flex-shrink:0;background:var(--bg);z-index:10}.time-label-header{width:72px;min-width:72px}.week-day-header{flex:1;text-align:center;cursor:pointer;padding:6px 4px;border-radius:var(--radius);transition:background var(--transition)}.week-day-header:hover{background:var(--bg-hover)}.week-day-name{display:block;font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:500;margin-bottom:2px}.week-day-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:.8125rem;font-weight:600;border-radius:50%;color:var(--text)}.today-num{background:var(--primary);color:#fff}.week-grid{flex:1;overflow-y:auto;padding:0}.week-row{display:flex;border-bottom:1px solid var(--border-light)}.week-slot{flex:1;border-left:1px solid var(--border-light);display:flex;flex-direction:column;overflow:hidden}.week-mini-slot{transition:background var(--transition)}.week-mini-slot.slot-over{background:var(--slot-hover)}.week-grid-inner{position:relative}.week-hover-time{position:absolute;z-index:9999;display:flex;align-items:center;pointer-events:none;height:0;overflow:visible}.week-hover-time .hover-time-label{font-size:.6875rem;color:#fff;background:var(--primary);padding:2px 6px;border-radius:4px;white-space:nowrap;font-weight:700;box-shadow:0 2px 6px #00000026}.week-hover-time .hover-time-rule{flex:1;height:2px;background:var(--primary)}.week-todo-positioned{position:absolute;z-index:1;pointer-events:auto;margin-left:72px}.week-todo-positioned .todo-card{height:100%;overflow:hidden;box-shadow:var(--shadow-sm)}.week-todo-time{position:absolute;top:1px;right:4px;font-size:.5625rem;color:var(--text-muted);pointer-events:none;z-index:2;line-height:1}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex;align-items:center;justify-content:center;overflow-y:auto;overscroll-behavior:contain}.settings-panel{background:var(--bg);border-radius:12px;box-shadow:0 20px 60px #0000001f;width:480px;max-height:80vh;overflow-y:auto;overscroll-behavior:contain}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.settings-header h2{font-size:1.125rem;font-weight:700;letter-spacing:-.02em}.settings-content{padding:8px 0}.settings-section{padding:20px 24px;border-bottom:1px solid var(--border-light)}.settings-section:last-child{border-bottom:none}.settings-section h3{font-size:.875rem;font-weight:600;margin-bottom:6px;color:var(--text)}.settings-description{font-size:.8125rem;color:var(--text-muted);margin-bottom:12px;line-height:1.5}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.settings-row label{font-size:.8125rem;color:var(--text-secondary)}.settings-row-inner{display:flex;align-items:center;gap:8px;font-size:.8125rem;color:var(--text-muted)}.settings-btn-row{display:flex;gap:8px}.settings-account-info{display:flex;align-items:center;gap:12px}.settings-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.settings-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;font-weight:600;font-size:1rem}.settings-account-name{font-weight:600;font-size:.875rem;color:var(--text)}.settings-account-email{font-size:.8125rem;color:var(--text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}.backlog-list{flex:1;overflow-y:auto}.popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex;align-items:center;justify-content:center}.popup{background:var(--bg);border-radius:16px;box-shadow:0 24px 80px #00000024;width:500px;max-height:85vh;overflow-y:auto}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.popup-header h3{font-size:1.0625rem;font-weight:600;letter-spacing:-.01em}.popup-form{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.popup-form .input{padding:10px 14px;font-size:.875rem}.popup-form .textarea-sm{min-height:44px}.popup-row{display:flex;gap:12px}.popup-field{flex:1;display:flex;flex-direction:column;gap:6px}.popup-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:8px}.popup-actions .btn{padding:9px 20px;font-size:.875rem}.todo-detail-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.todo-detail-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.todo-detail-category{display:flex;align-items:center;gap:5px;font-size:.8125rem;color:var(--text-secondary)}.todo-detail-description{font-size:.8125rem;color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;margin:0}.todo-detail-empty{font-size:.8125rem;color:var(--text-muted);font-style:italic;margin:0}.todo-detail-actions{display:flex;gap:8px;padding-top:4px}.settings-project-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.settings-project-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);transition:background var(--transition)}.settings-project-row:hover{background:var(--bg-hover)}.settings-project-name{flex:1;font-size:.8125rem;font-weight:500}.settings-project-edit{display:flex;flex-direction:column;gap:8px;width:100%}.settings-project-edit .input{font-size:.85rem}.settings-edit-actions{display:flex;gap:6px}.settings-confirm-delete{display:flex;align-items:center;gap:6px;margin-left:auto}.settings-confirm-text{font-size:.75rem;color:var(--danger);font-weight:500}.settings-add-project{display:flex;flex-direction:column;gap:8px;padding:10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius)}.settings-add-row{display:flex;align-items:center;gap:8px}.settings-color-preview{width:24px;height:24px;border-radius:50%;border:2px solid rgba(0,0,0,.08);cursor:pointer;flex-shrink:0;transition:transform var(--transition),box-shadow var(--transition)}.settings-color-preview:hover{transform:scale(1.1);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--border)}.settings-add-btn{padding:8px 14px;font-size:.8125rem}.settings-color-dropdown{display:flex;gap:6px;padding:8px 4px 4px;flex-wrap:wrap}.sidebar-resize-handle{position:absolute;top:0;right:-3px;width:6px;height:100%;cursor:col-resize;z-index:10}.sidebar-resize-handle:hover,.sidebar-resize-handle:active{background:var(--primary);opacity:.3;border-radius:3px}.sidebar-wrapper{display:flex;position:relative}.sidebar-overlay,.sidebar-toggle,.fab-add{display:none}.undo-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:10px 20px;border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:14px;font-size:.8125rem;z-index:200;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.undo-toast-btn{background:none;border:none;color:#93c5fd;font-weight:600;font-size:.8125rem;cursor:pointer;font-family:inherit;padding:0}.undo-toast-btn:hover{color:#bfdbfe}.effort-summary{display:flex;align-items:center;gap:8px;padding:6px 24px 6px 96px;border-bottom:1px solid var(--border-light);font-size:.75rem}.effort-summary-label{color:var(--text-muted);font-weight:500}.effort-summary-value{color:var(--primary);font-weight:700;font-variant-numeric:tabular-nums}@media (max-width: 1024px){.sidebar-wrapper{display:block;position:fixed;top:0;left:0;bottom:0;width:360px;z-index:50;transform:translate(-100%);transition:transform .25s ease}.sidebar-wrapper.sidebar-open{transform:translate(0)}.sidebar-wrapper .sidebar{width:100%;min-width:0;height:100%}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:49}.sidebar-toggle{display:inline-flex}.sidebar-resize-handle{display:none}.sidebar-close-btn{display:inline-flex}}@media (max-width: 768px){.sidebar-wrapper{width:100%}.view-toggle{display:none}.calendar-header{padding:10px 12px;padding-top:calc(10px + env(safe-area-inset-top))}.calendar-date{font-size:.875rem;margin-left:8px}.day-grid{padding:0 8px}.fab-add{display:flex;position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));right:24px;width:56px;height:56px;border-radius:50%;background:var(--primary);border:none;color:#fff;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb4d;cursor:pointer;z-index:40;transition:transform var(--transition),box-shadow var(--transition)}.fab-add:hover{transform:scale(1.05);box-shadow:0 6px 16px #2563eb66}.popup{width:calc(100% - 32px);max-width:420px}.settings-panel{width:calc(100% - 32px);max-width:480px}}.login-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);padding:24px}.login-card{width:100%;max-width:400px;background:var(--bg);border-radius:20px;box-shadow:0 8px 40px #00000014;padding:40px 36px}.login-brand{text-align:center;margin-bottom:32px}.login-logo{font-size:2rem;font-weight:600;letter-spacing:.04em;color:var(--text)}.login-logo-colon{color:#4f46e5;font-weight:600}.login-tagline{font-size:.875rem;color:var(--text-muted);margin-top:6px;letter-spacing:.01em}.login-social{display:flex;flex-direction:column;gap:10px}.btn-social{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 16px;border-radius:var(--radius);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition)}.btn-apple{background:#000;color:#fff;border:1px solid #000}.btn-apple:hover{background:#1a1a1a}.btn-google{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-google:hover{background:var(--bg-hover);border-color:#d1d5db}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:.75rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.login-field .input{padding:10px 14px;font-size:.875rem}.login-forgot{background:none;border:none;color:var(--primary);font-size:.8125rem;font-weight:500;cursor:pointer;font-family:inherit;text-align:right;margin-top:-8px;padding:0}.login-forgot:hover{color:var(--primary-hover)}.login-submit{padding:11px 16px;font-size:.9375rem;font-weight:600;margin-top:4px}.login-error{background:var(--danger-light);color:var(--danger);padding:8px 12px;border-radius:var(--radius-sm);font-size:.8125rem;margin-bottom:8px}.login-success{background:#ecfdf5;color:var(--success);padding:8px 12px;border-radius:var(--radius-sm);font-size:.8125rem;margin-bottom:8px}.login-switch{text-align:center;margin-top:24px;font-size:.8125rem;color:var(--text-muted)}.login-switch button{background:none;border:none;color:var(--primary);font-weight:600;font-size:.8125rem;cursor:pointer;font-family:inherit;padding:0}.login-switch button:hover{color:var(--primary-hover)}@media (max-width: 768px){.login-card{padding:32px 24px;border-radius:16px}.login-logo{font-size:1.75rem}}.quick-add-container{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background:transparent;-webkit-app-region:drag}.quick-add-form{display:flex;align-items:center;gap:10px;width:100%;max-width:480px;padding:14px 18px;background:#1e293b;border-radius:14px;box-shadow:0 8px 32px #0006,0 0 0 1px #ffffff14;-webkit-app-region:no-drag}.quick-add-icon{flex-shrink:0;opacity:.5}.quick-add-input{flex:1;background:none;border:none;outline:none;color:#f1f5f9;font-size:15px;font-family:inherit}.quick-add-input::placeholder{color:#64748b}.quick-add-check{flex-shrink:0;animation:quick-add-pop .3s ease}@keyframes quick-add-pop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}
