@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Crimson+Pro:wght@400;500;600&display=swap";:root{--accent: #0f6cbd;--accent-hover: #0d5ba3;--accent-pale: rgba(15, 108, 189, .08);--accent-light: rgba(15, 108, 189, .15);--bg: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #ebebeb;--surface: #ffffff;--surface-hover: #f5f5f5;--surface-active: #ebebeb;--card: #ffffff;--card-hover: #fafafa;--text: #1a1a1a;--text-secondary: #616161;--text-muted: #9e9e9e;--text-on-accent: #ffffff;--border: #e0e0e0;--border-strong: #c4c4c4;--divider: #f0f0f0;--danger: #d13438;--danger-bg: #fdf3f4;--success: #107c10;--success-bg: #f1faf1;--warning: #ffb900;--warning-bg: #fff8e1;--color-outlook: #d13438;--color-google: #0f6cbd;--color-task: #ffb900;--color-habit: #107c10;--color-food: #881798;--priority-urgent: #ffb900;--priority-important: #f7630c;--font-ui: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Crimson Pro", Georgia, serif;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-base: 15px;--font-size-lg: 17px;--font-size-xl: 20px;--font-size-2xl: 24px;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 2px 8px rgba(0,0,0,.08);--shadow-lg: 0 4px 16px rgba(0,0,0,.12);--shadow-xl: 0 8px 32px rgba(0,0,0,.16);--nav-height: 56px;--sidebar-width: 64px;--sidebar-expanded: 220px;--header-height: 48px;--max-width: 800px;--transition-fast: .12s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}.theme-dark{--bg: #1a1a1a;--bg-secondary: #252525;--bg-tertiary: #333333;--surface: #252525;--surface-hover: #2d2d2d;--surface-active: #383838;--card: #2d2d2d;--card-hover: #333333;--text: #e5e5e5;--text-secondary: #b0b0b0;--text-muted: #757575;--text-on-accent: #ffffff;--border: #404040;--border-strong: #555555;--divider: #333333;--danger-bg: #3b1c1d;--success-bg: #1a2e1a;--warning-bg: #2e2a1a;--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 2px 8px rgba(0,0,0,.3);--shadow-lg: 0 4px 16px rgba(0,0,0,.4);--shadow-xl: 0 8px 32px rgba(0,0,0,.5);--accent-pale: rgba(15, 108, 189, .12);--accent-light: rgba(15, 108, 189, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-text-size-adjust:100%}body{height:100%;font-family:var(--font-ui);font-size:var(--font-size-base);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}#root{height:100%}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.app-shell{display:flex;height:100%;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.app-content{flex:1;overflow-y:auto;overflow-x:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:var(--space-sm) 0;flex-shrink:0;z-index:10}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:var(--space-sm) 0;flex:1}.sidebar-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);position:relative}.sidebar-btn:hover{background:var(--surface-hover);color:var(--text)}.sidebar-btn.active{color:var(--accent);background:var(--accent-pale)}.sidebar-btn .sidebar-label{position:absolute;left:calc(100% + 8px);background:var(--text);color:var(--bg);font-size:var(--font-size-xs);padding:4px 8px;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition-fast)}.sidebar-btn:hover .sidebar-label{opacity:1}.sidebar-bottom{padding:var(--space-sm) 0;display:flex;flex-direction:column;gap:4px;align-items:center}.bottom-nav{display:none;height:var(--nav-height);background:var(--bg);border-top:1px solid var(--border);padding:0 var(--space-lg);flex-shrink:0;z-index:100}.bottom-nav-inner{display:flex;align-items:center;justify-content:space-around;height:100%;max-width:500px;margin:0 auto}.bottom-nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;border-radius:var(--radius-md);color:var(--text-muted);font-size:10px;font-weight:500;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.bottom-nav-btn.active{color:var(--accent)}.bottom-nav-btn:active{transform:scale(.95)}.nav-badge{position:absolute;top:-4px;right:-6px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}@media (max-width: 768px){.sidebar{display:none}.bottom-nav{display:flex}}.page-header{height:var(--header-height);display:flex;align-items:center;padding:0 var(--space-lg);border-bottom:1px solid var(--divider);flex-shrink:0;gap:var(--space-md)}.page-header-title{font-size:var(--font-size-lg);font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-header-actions{display:flex;align-items:center;gap:var(--space-xs)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn-primary{background:var(--accent);color:var(--text-on-accent)}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-secondary{background:var(--bg-secondary);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-tertiary)}.btn-ghost{color:var(--text-secondary);padding:6px 10px}.btn-ghost:hover{background:var(--surface-hover);color:var(--text)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-bg)}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--surface-hover);color:var(--text)}.btn-sm{padding:4px 10px;font-size:var(--font-size-xs)}.input{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text);outline:none;transition:border-color var(--transition-fast)}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}.textarea{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text);outline:none;resize:vertical;min-height:80px;transition:border-color var(--transition-fast)}.textarea:focus{border-color:var(--accent)}.field-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:6px}.select{padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text);outline:none;cursor:pointer}.select:focus{border-color:var(--accent)}.checkbox-row{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;padding:4px 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);animation:fadeIn .15s ease}.modal-panel{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--divider);gap:var(--space-md)}.modal-header-title{font-size:var(--font-size-lg);font-weight:600;flex:1}.modal-body{flex:1;overflow-y:auto;padding:var(--space-lg)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--divider)}.modal-full{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:1000;display:flex;flex-direction:column;animation:slideUp .2s ease}@media (min-width: 769px){.modal-full{inset:0 0 0 var(--sidebar-width)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.toast{position:fixed;bottom:calc(var(--nav-height) + 16px);left:50%;transform:translate(-50%);background:var(--text);color:var(--bg);padding:10px 20px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;z-index:2000;animation:toastIn .2s ease;box-shadow:var(--shadow-lg)}@media (min-width: 769px){.toast{bottom:24px}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}}.confirm-body{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5}.save-indicator{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--text-muted);transition:color var(--transition-normal)}.save-indicator.saving{color:var(--accent)}.save-indicator.saved{color:var(--success)}.save-indicator.error{color:var(--danger)}.save-dot{width:6px;height:6px;border-radius:50%;background:currentColor;transition:background var(--transition-normal)}.nb-home{padding:var(--space-lg);max-width:var(--max-width);margin:0 auto}.nb-category{margin-bottom:var(--space-lg)}.nb-category-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;cursor:pointer;-webkit-user-select:none;user-select:none}.nb-category-header .nb-cat-actions{opacity:0;transition:opacity var(--transition-fast)}.nb-category-header:hover .nb-cat-actions{opacity:1}.nb-category-name{font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);flex:1}.nb-category-chevron{color:var(--text-muted);transition:transform var(--transition-fast)}.nb-category-chevron.collapsed{transform:rotate(-90deg)}.nb-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.nb-item:hover{background:var(--surface-hover)}.nb-item:active{background:var(--surface-active)}.nb-item .nb-item-actions{opacity:0;transition:opacity var(--transition-fast)}.nb-item:hover .nb-item-actions{opacity:1}.nb-item-icon{color:var(--text-muted);flex-shrink:0}.nb-item-name{flex:1;font-size:var(--font-size-sm);font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nb-item-count{font-size:var(--font-size-xs);color:var(--text-muted);flex-shrink:0}.nb-master-section{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--divider)}.nb-view{display:flex;flex-direction:column;height:100%}.nb-view-content{flex:1;overflow-y:auto;padding:var(--space-lg);max-width:var(--max-width);margin:0 auto;width:100%}.nb-section{margin-bottom:var(--space-xl)}.nb-section-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;cursor:pointer;-webkit-user-select:none;user-select:none}.nb-section-name{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);flex:1}.nb-section-count{font-size:var(--font-size-xs);color:var(--text-muted);background:var(--bg-secondary);padding:2px 8px;border-radius:var(--radius-full)}.nb-section-actions{display:flex;gap:2px}.quick-add-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--divider)}.quick-add-input{flex:1;border:none;outline:none;font-size:var(--font-size-sm);font-family:var(--font-ui);color:var(--text);background:transparent;padding:6px 0}.quick-add-input::placeholder{color:var(--text-muted)}.task-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.task-card:hover{background:var(--surface-hover)}.task-card.completed .task-title{text-decoration:line-through;color:var(--text-muted)}.task-checkbox{width:20px;height:20px;border:2px solid var(--border-strong);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;cursor:pointer;transition:all var(--transition-fast)}.task-checkbox:hover{border-color:var(--accent)}.task-checkbox.checked{background:var(--accent);border-color:var(--accent);color:#fff}.task-checkbox.priority-urgent{border-color:var(--priority-urgent)}.task-checkbox.priority-important{border-color:var(--priority-important)}.task-body{flex:1;min-width:0}.task-title{font-size:var(--font-size-sm);font-weight:500;line-height:1.4}.task-subtitle{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}.task-meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:4px}.task-meta-tag{font-size:10px;color:var(--text-muted);background:var(--bg-secondary);padding:1px 6px;border-radius:var(--radius-sm)}.task-priority{flex-shrink:0;font-size:14px}.note-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.note-card:hover{background:var(--surface-hover)}.note-card.selected{background:var(--accent-pale)}.note-select-box{width:20px;height:20px;border:2px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.note-select-box.checked{background:var(--accent);border-color:var(--accent);color:#fff}.note-body{flex:1;min-width:0}.note-title{font-size:var(--font-size-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-subtitle{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-date{font-size:var(--font-size-xs);color:var(--text-muted);flex-shrink:0}.sort-bar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0}.sort-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast)}.sort-chip:hover{border-color:var(--accent);color:var(--accent)}.sort-chip.active{background:var(--accent-pale);border-color:var(--accent);color:var(--accent)}.search-inline{display:flex;align-items:center;gap:var(--space-sm);padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);flex:1;max-width:300px}.search-inline input{border:none;background:transparent;outline:none;font-size:var(--font-size-xs);flex:1;min-width:0}.note-editor{display:flex;flex-direction:column;height:100%}.note-editor-header{display:flex;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--divider);gap:var(--space-sm)}.note-editor-title{flex:1;border:none;background:transparent;font-size:var(--font-size-xl);font-weight:600;outline:none;min-width:0}.note-editor-title::placeholder{color:var(--text-muted)}.note-editor-body{flex:1;overflow-y:auto;padding:var(--space-lg)}.note-editor-body .ProseMirror{outline:none;min-height:200px;font-family:var(--font-body);font-size:var(--font-size-lg);line-height:1.7;color:var(--text)}.note-editor-body .ProseMirror p{margin-bottom:.75em}.note-editor-body .ProseMirror h2{font-size:1.4em;font-weight:600;margin:1em 0 .5em}.note-editor-body .ProseMirror h3{font-size:1.15em;font-weight:600;margin:.8em 0 .4em}.note-editor-body .ProseMirror ul,.note-editor-body .ProseMirror ol{padding-left:1.5em;margin-bottom:.75em}.note-editor-body .ProseMirror li{margin-bottom:.25em}.note-editor-body .ProseMirror a{color:var(--accent);text-decoration:underline}.note-editor-body .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none;float:left;height:0}.editor-toolbar{display:flex;align-items:center;gap:2px;padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--divider);flex-shrink:0;flex-wrap:wrap}.editor-toolbar .btn-icon{width:32px;height:32px}.editor-toolbar .btn-icon.active{color:var(--accent);background:var(--accent-pale)}.toolbar-divider{width:1px;height:20px;background:var(--border);margin:0 4px}.toolbar-word-count{font-size:var(--font-size-xs);color:var(--text-muted);padding:0 var(--space-sm);white-space:nowrap}.task-editor{padding:var(--space-lg)}.task-editor-title{width:100%;border:none;background:transparent;font-size:var(--font-size-xl);font-weight:600;outline:none;margin-bottom:var(--space-lg)}.task-editor-title::placeholder{color:var(--text-muted)}.task-field{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--divider)}.task-field-label{font-size:var(--font-size-sm);color:var(--text-secondary);width:80px;flex-shrink:0}.task-field-value{flex:1;font-size:var(--font-size-sm);min-width:0}.subtask-list{padding:var(--space-sm) 0}.subtask-item{display:flex;align-items:center;gap:var(--space-sm);padding:4px 0}.subtask-item input[type=text]{flex:1;border:none;background:transparent;outline:none;font-size:var(--font-size-sm)}.subtask-item.done input[type=text]{text-decoration:line-through;color:var(--text-muted)}.day-view{display:flex;flex-direction:column;height:100%}.day-header{display:flex;align-items:center;padding:var(--space-md) var(--space-lg);gap:var(--space-md);border-bottom:1px solid var(--divider);flex-shrink:0}.day-title{font-size:var(--font-size-base);font-weight:600;display:flex;flex-direction:column;align-items:center}.day-today-label{font-size:var(--font-size-xs);color:var(--accent);font-weight:500}.day-grid{flex:1;overflow-y:auto;position:relative;padding:0 var(--space-lg)}.day-hour-row{display:flex;align-items:flex-start;min-height:48px;position:relative}.day-hour-label{width:48px;font-size:var(--font-size-xs);color:var(--text-muted);text-align:right;padding-right:var(--space-sm);padding-top:2px;flex-shrink:0}.day-hour-line{flex:1;border-top:1px solid var(--divider);min-height:48px;position:relative}.day-now-line{position:absolute;left:48px;right:0;height:2px;background:var(--danger);z-index:5;pointer-events:none}.day-now-dot{position:absolute;left:44px;width:10px;height:10px;border-radius:50%;background:var(--danger);transform:translateY(-4px);z-index:5}.day-block{position:absolute;left:56px;right:var(--space-sm);border-radius:var(--radius-sm);padding:4px 8px;font-size:var(--font-size-xs);font-weight:500;overflow:hidden;cursor:pointer;z-index:2;transition:opacity var(--transition-fast);border-left:3px solid}.day-block.past{opacity:.5}.day-block.past.incomplete{opacity:1}.day-block-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center}.day-block-time{font-size:10px;opacity:.8}.day-section-label{font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-sm)}.day-agenda-item{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-md);border-radius:var(--radius-md);background:var(--card);border:1px solid var(--border);margin-bottom:4px;cursor:pointer;transition:background var(--transition-fast)}.day-agenda-item:hover{background:var(--card-hover)}.day-agenda-item.done{opacity:.6}.day-agenda-time{font-size:var(--font-size-xs);color:var(--text-muted);min-width:52px;flex-shrink:0}.day-agenda-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.day-agenda-title{font-size:var(--font-size-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.day-habit-chip{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--card);cursor:pointer;font-size:var(--font-size-xs);font-weight:500;transition:all var(--transition-fast)}.day-habit-chip:hover{opacity:.8}.day-unscheduled{display:flex;align-items:center;padding:var(--space-sm) var(--space-lg);border-bottom:1px solid var(--divider);background:var(--bg-secondary);flex-shrink:0;overflow:hidden}.day-mini-task{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--font-size-xs);white-space:nowrap;cursor:pointer;flex-shrink:0}.day-mini-task:hover{background:var(--card-hover)}.habits-home{padding:var(--space-lg);max-width:var(--max-width);margin:0 auto}.habit-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-md);cursor:pointer;transition:all var(--transition-fast)}.habit-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.habit-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.habit-info{flex:1;min-width:0}.habit-name{font-size:var(--font-size-sm);font-weight:600}.habit-stat{font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:2px}.habit-streak{display:flex;gap:3px}.streak-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-tertiary)}.streak-dot.filled{background:var(--color-habit)}.tab-bar{display:flex;gap:var(--space-xs);padding:0 var(--space-lg);border-bottom:1px solid var(--divider);flex-shrink:0}.tab-bar-item{padding:10px 16px;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;background:none;border-top:none;border-left:none;border-right:none;cursor:pointer;transition:all .12s ease}.tab-bar-item:hover{color:var(--text)}.tab-bar-item.active{color:var(--accent);border-bottom-color:var(--accent)}.food-home{padding:var(--space-lg);max-width:var(--max-width);margin:0 auto}.meal-day{margin-bottom:var(--space-xl)}.meal-day-header{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);padding:var(--space-sm) 0;border-bottom:1px solid var(--divider);margin-bottom:var(--space-sm)}.meal-slot{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.meal-slot:hover{background:var(--surface-hover)}.meal-time{font-size:var(--font-size-xs);color:var(--text-muted);width:60px;flex-shrink:0}.meal-name{font-size:var(--font-size-sm);flex:1}.meal-cals{font-size:var(--font-size-xs);color:var(--text-muted)}.draft-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:900;animation:fadeIn .15s ease}.draft-drawer{position:fixed;top:0;right:0;bottom:0;width:min(400px,90vw);background:var(--bg);box-shadow:var(--shadow-xl);z-index:901;display:flex;flex-direction:column;animation:slideInRight .2s ease}.draft-drawer-header{display:flex;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--divider);gap:var(--space-sm)}.draft-drawer-body{flex:1;padding:var(--space-lg)}.draft-drawer-body textarea{width:100%;height:100%;border:none;background:transparent;outline:none;font-family:var(--font-ui);font-size:var(--font-size-sm);line-height:1.6;resize:none;color:var(--text)}.draft-drawer-footer{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--divider)}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:none}}.settings-page{padding:var(--space-lg);max-width:var(--max-width);margin:0 auto}.settings-section{margin-bottom:var(--space-xl)}.settings-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-md)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0;border-bottom:1px solid var(--divider)}.settings-row-label{font-size:var(--font-size-sm)}.settings-row-desc{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}.toggle{width:40px;height:22px;border-radius:11px;background:var(--border-strong);position:relative;cursor:pointer;transition:background var(--transition-fast)}.toggle.on{background:var(--accent)}.toggle-thumb{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform var(--transition-fast);box-shadow:0 1px 3px #0003}.toggle.on .toggle-thumb{transform:translate(18px)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1100;display:flex;align-items:flex-start;justify-content:center;padding:80px var(--space-lg) var(--space-lg);animation:fadeIn .15s ease}.search-panel{width:100%;max-width:600px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;animation:slideUp .2s ease}.search-input-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--divider)}.search-input-row input{flex:1;border:none;background:transparent;outline:none;font-size:var(--font-size-lg)}.search-filters{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-bottom:1px solid var(--divider);flex-wrap:wrap}.search-results{max-height:400px;overflow-y:auto}.search-result-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);cursor:pointer;transition:background var(--transition-fast)}.search-result-item:hover,.search-result-item.selected{background:var(--accent-pale)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.text-muted{color:var(--text-muted)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex-1{flex:1;min-width:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.dropdown-menu{position:absolute;right:0;top:calc(100% + 4px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;z-index:100;padding:4px 0;animation:fadeIn .1s ease}.dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:8px 16px;font-size:var(--font-size-sm);color:var(--text);background:none;border:none;border-radius:0;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--surface-hover)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:var(--danger-bg)}.dropdown-divider{height:1px;background:var(--divider);margin:4px 0}.dropdown-label{padding:4px 16px 2px;font-size:var(--font-size-xs);color:var(--text-muted);font-weight:600}.dropdown-info{padding:6px 16px;font-size:var(--font-size-xs);color:var(--text-muted)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:focus-visible,.btn-icon:focus-visible,.sort-chip:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.input:focus-visible,.textarea:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-pale)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-muted);text-align:center;gap:var(--space-md)}.empty-state-icon{font-size:32px;opacity:.5}.empty-state-text{font-size:var(--font-size-sm)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:var(--space-lg)}.auth-card{background:var(--surface);padding:var(--space-2xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:400px}.auth-logo{width:48px;height:48px;background:var(--accent-pale);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:var(--space-lg)}.auth-title{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-xs)}.auth-subtitle{font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--space-xl)}.auth-label{display:block;font-size:var(--font-size-xs);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.auth-submit{width:100%;padding:12px;font-size:var(--font-size-md)}.auth-msg{margin-top:var(--space-md);padding:12px 14px;border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1.5}.auth-msg.success{background:var(--success-bg);color:var(--success)}.auth-msg.error{background:var(--danger-bg);color:var(--danger)}.auth-footer{margin-top:var(--space-xl);font-size:var(--font-size-xs);color:var(--text-muted);text-align:center;line-height:1.6}.run-stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center}.run-stat-value{font-size:var(--font-size-2xl);font-weight:700;font-variant-numeric:tabular-nums;font-family:var(--font-ui);color:var(--text)}.run-stat-label{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}.run-control-btn{width:72px;height:72px;border-radius:50%;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s ease,opacity .15s ease}.run-control-btn:active{transform:scale(.93)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.cal-event{display:flex;align-items:center;gap:var(--space-sm);padding:8px var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);border-left:3px solid;background:var(--card);cursor:default}.cal-event .cal-time{font-size:var(--font-size-xs);color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:52px}.cal-event .cal-title{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-event .cal-source{font-size:10px;padding:1px 6px;border-radius:var(--radius-full);font-weight:600}@media (max-width: 768px){.nb-item:active,.task-card:active,.note-card:active{background:var(--surface-active)}.habit-card:active{transform:scale(.99)}.day-agenda-item:active{background:var(--surface-active)}.nb-cat-actions,.nb-item-actions{opacity:1!important}.page-header{padding:0 var(--space-md)}.food-home{padding:var(--space-md)}.habits-home{padding:0}.tab-bar{padding:0 var(--space-md)}.tab-bar-item{padding:10px 12px}.meal-slot{padding:var(--space-sm) var(--space-md)}.dropdown-menu{min-width:180px}.editor-toolbar{gap:2px}.editor-toolbar .toolbar-divider{margin:0 2px}.task-editor{padding:0}.sort-bar{gap:4px}.sort-chip{padding:4px 10px;font-size:var(--font-size-xs)}}@media print{.sidebar,.bottom-nav,.page-header,.editor-toolbar{display:none!important}.app-content{overflow:visible!important}}
