.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:var(--color-background)}.auth-card{width:100%;max-width:400px;padding:var(--spacing-xl);background:var(--color-surface);border:1px solid var(--color-warm-gray);border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000000f}.auth-title{margin:0 0 var(--spacing-xs) 0;font-family:var(--font-serif);font-size:1.75rem;color:var(--color-text-primary);text-align:center}.auth-subtitle{margin:0 0 var(--spacing-md) 0;font-size:.95rem;color:var(--color-text-secondary);text-align:center}.auth-disabled{margin:0;font-size:.9rem;color:var(--color-text-secondary);text-align:center}.auth-disabled code{padding:0 2px;font-size:.85em;background:var(--color-light-gray);border-radius:var(--radius-sm)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.auth-input{padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:1rem;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary)}.auth-input:focus{outline:none;border-color:var(--color-primary)}.auth-input::placeholder{color:var(--color-text-secondary)}.auth-error{margin:0;font-size:.9rem;color:#c44}.auth-message{margin:0;font-size:.9rem;color:var(--color-text-secondary)}.auth-submit{margin-top:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:1rem;font-weight:500;color:var(--color-text-light);background:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.auth-submit:hover:not(:disabled){background:var(--color-primary-dark)}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-switch{margin:var(--spacing-md) 0 0 0;font-size:.9rem;color:var(--color-text-secondary);text-align:center}.auth-link{padding:0;font-size:inherit;font-family:inherit;background:none;border:none;color:var(--color-primary);cursor:pointer;text-decoration:underline}.auth-link:hover{color:var(--color-primary-dark)}.auth-password-wrap{position:relative;display:flex;align-items:stretch}.auth-input-password{flex:1;padding-right:3.25rem}.auth-password-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--color-text-secondary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition-fast)}.auth-password-toggle:hover{color:var(--color-primary)}.auth-password-icon{display:block;flex-shrink:0}.planner{display:flex;min-height:calc(100vh - 70px);background:var(--color-background)}.planner-sidebar{width:220px;flex-shrink:0;padding:var(--spacing-lg);background:var(--color-surface);border-right:1px solid var(--color-warm-gray)}.planner-sidebar-title{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.planner-nav{display:flex;flex-direction:column;gap:var(--spacing-xs)}.planner-nav-item{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-family:var(--font-body);font-size:1rem;color:var(--color-text-primary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.planner-nav-item:hover{background:var(--color-light-gray);color:var(--color-primary-dark)}.planner-nav-item.active{background:var(--color-primary);color:var(--color-text-light)}.planner-content{flex:1;padding:var(--spacing-lg);overflow:auto}.planner-view-panel{height:100%;min-height:0}@media (max-width: 768px){.planner{flex-direction:column;min-height:auto}.planner-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-warm-gray);padding:var(--spacing-md)}.planner-nav{flex-direction:row;flex-wrap:wrap}.planner-nav-item{flex:1 1 auto;min-width:100px}}.calendar-view{max-width:100%}.calendar-heading{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.calendar-controls{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.calendar-nav{padding:var(--spacing-sm) var(--spacing-md);font-size:1.2rem;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.calendar-nav:hover{background:var(--color-light-gray)}.calendar-select{padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:1rem;color:var(--color-text-primary);background:var(--color-background);border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.calendar-select-month{min-width:120px}.calendar-select-year{min-width:80px}.calendar-month-label{font-family:var(--font-serif);font-size:1.25rem;color:var(--color-text-primary);min-width:180px;text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--spacing-lg)}.calendar-weekday{padding:var(--spacing-xs);font-size:.85rem;font-weight:600;color:var(--color-text-secondary);text-align:center}.calendar-cell{min-height:72px;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;padding:var(--spacing-xs);font-family:var(--font-body);font-size:.9rem;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-light-gray);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);text-align:left}.calendar-cell:hover{background:var(--color-light-gray)}.calendar-cell.selected{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}.calendar-cell.selected .calendar-cell-task{color:#fffffff2}.calendar-cell-empty{background:var(--color-off-white);cursor:default}.calendar-cell-day{display:block;font-weight:600;flex-shrink:0}.calendar-cell-preview{display:flex;flex-direction:column;gap:1px;margin-top:2px;overflow:hidden;flex:1;min-height:0}.calendar-cell-task{font-size:.7rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-secondary)}.calendar-cell-more{font-size:.65rem;opacity:.85}.calendar-detail{padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-warm-gray)}.calendar-detail-placeholder{margin:0;color:var(--color-text-secondary);font-style:italic;padding:var(--spacing-sm) 0}.calendar-detail-title{font-family:var(--font-serif);font-size:1.1rem;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.calendar-detail-form{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.calendar-detail-form .task-input{flex:1}.calendar-detail-list{list-style:none;margin:0;padding:0}.calendar-detail-empty{padding:var(--spacing-sm);color:var(--color-text-secondary);font-style:italic}.calendar-detail-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;border-bottom:1px solid var(--color-light-gray)}.calendar-detail-item-num{flex-shrink:0;font-size:.9rem;color:var(--color-text-secondary);min-width:1.5em}.calendar-detail-item-check{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0;cursor:pointer}.calendar-detail-item-check input{flex-shrink:0}.calendar-detail-item-title{flex:1;min-width:0}.calendar-detail-item-actions{display:flex;gap:var(--spacing-xs);flex-shrink:0}.calendar-detail-item-edit{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);width:100%}.calendar-detail-edit-input{flex:1;min-width:120px}.calendar-detail-item .task-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;font-family:var(--font-body);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.calendar-detail-item .task-btn:hover{background:var(--color-light-gray);color:var(--color-text-primary)}.calendar-detail-item .task-btn-edit:hover{border-color:var(--color-primary);color:var(--color-primary)}.calendar-detail-item .task-btn-delete:hover{border-color:#c44;color:#c44}.calendar-detail-item .task-btn-save{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}.calendar-detail-item .task-btn-cancel{background:var(--color-surface)}.calendar-detail-item[draggable=true]{cursor:grab}.calendar-detail-item[draggable=true]:active{cursor:grabbing}.calendar-detail-item.drag-over{outline:2px dashed var(--color-primary);outline-offset:2px;background:var(--color-light-gray)}.calendar-detail-item.completed .calendar-detail-item-title{text-decoration:line-through;color:var(--color-text-secondary)}.calendar-detail-item:last-child{border-bottom:none}@media (max-width: 768px){.calendar-cell{min-height:56px}.calendar-cell-preview{display:none}}.task-list{max-width:640px}.task-list-heading{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.task-form{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.task-input{flex:1;min-width:160px;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:1rem;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary)}.task-date{padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:.95rem;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary)}.task-submit{padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-body);font-size:1rem;background:var(--color-primary);color:var(--color-text-light);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.task-submit:hover{background:var(--color-primary-dark)}.task-filters{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.task-filter-btn{padding:var(--spacing-xs) var(--spacing-sm);font-family:var(--font-body);font-size:.9rem;background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.task-filter-btn:hover,.task-filter-btn.active{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}.task-groups{display:flex;flex-direction:column;gap:var(--spacing-md)}.task-date-group{border:1px solid var(--color-light-gray);border-radius:var(--radius-md);overflow:hidden}.task-date-header{display:flex;align-items:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:.95rem;font-weight:600;color:var(--color-text-primary);background:var(--color-off-white);border:none;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.task-date-header:hover{background:var(--color-light-gray)}.task-date-header-icon{font-size:.75rem;color:var(--color-text-secondary)}.task-date-header-label{flex:1}.task-date-header-count{font-size:.85rem;font-weight:500;color:var(--color-text-secondary)}.task-date-group .task-ul{margin:0;padding:var(--spacing-xs);border-top:1px solid var(--color-light-gray);background:var(--color-surface)}.task-ul{list-style:none;margin:0;padding:0}.task-item{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-light-gray)}.task-item.completed .task-title{text-decoration:line-through;color:var(--color-text-secondary)}.task-check-label{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0;cursor:pointer}.task-check-label input{flex-shrink:0}.task-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.task-due{font-size:.9rem;color:var(--color-text-secondary)}.task-actions{display:flex;gap:var(--spacing-xs)}.task-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;font-family:var(--font-body);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.task-btn:hover{background:var(--color-light-gray);color:var(--color-text-primary)}.task-btn-edit:hover{border-color:var(--color-primary);color:var(--color-primary)}.task-btn-delete:hover{border-color:#c44;color:#c44}.task-btn-save{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}.task-btn-cancel{background:var(--color-surface)}.task-edit{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);width:100%}.task-edit .task-input{flex:1;min-width:120px}.task-empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-secondary);font-style:italic}.projects-view{max-width:1200px;width:100%}.projects-view-header{margin-bottom:var(--spacing-md)}.projects-view-heading{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary);margin:0}.projects-layout{display:flex;gap:var(--spacing-lg);align-items:flex-start;flex-wrap:wrap}.projects-list-panel{width:240px;flex-shrink:0;padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-warm-gray)}.projects-add-btn{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:1rem;background:var(--color-primary);color:var(--color-text-light);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);margin-bottom:var(--spacing-sm)}.projects-add-btn:hover{background:var(--color-primary-dark)}.projects-inline-form{margin-bottom:var(--spacing-sm)}.projects-inline-form .project-input{width:100%;margin-bottom:var(--spacing-xs)}.projects-inline-actions{display:flex;gap:var(--spacing-xs)}.project-input{padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:.95rem;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary)}.projects-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.projects-empty{padding:var(--spacing-md);color:var(--color-text-secondary);font-style:italic;text-align:center}.projects-list-item{background:var(--color-off-white);border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.projects-list-item:hover{border-color:var(--color-pink);box-shadow:0 2px 6px #0000000f}.project-name-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);text-align:left;font-family:var(--font-body);font-size:.95rem;color:var(--color-text-primary);background:transparent;border:none;border-radius:0;cursor:pointer;transition:background var(--transition-fast)}.project-name-btn:hover{background:var(--color-light-gray)}.project-name-btn.active{background:var(--color-primary);color:var(--color-text-light)}.projects-list-item:has(.project-name-btn.active){border-color:var(--color-primary);box-shadow:0 2px 6px #00000014}.project-note-count{font-size:.8rem;opacity:.9}.project-item-actions{display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md) var(--spacing-sm);border-top:1px solid var(--color-light-gray)}.project-action{padding:2px 6px;font-size:.75rem;background:transparent;color:var(--color-text-secondary);border:none;cursor:pointer}.project-action:hover{color:var(--color-primary)}.project-action-delete:hover{color:#c44}.projects-edit-row{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center;padding:var(--spacing-md)}.projects-edit-row .project-input{flex:1;min-width:0}.project-detail{flex:1;min-width:280px;width:100%}.project-detail-placeholder{padding:var(--spacing-xl);color:var(--color-text-secondary);font-style:italic}.project-detail-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);width:100%}.project-detail-title{font-family:var(--font-serif);font-size:1.25rem;color:var(--color-text-primary);margin:0}.project-detail-header-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.project-detail-header-actions .notes-add-btn,.project-detail-header-actions .task-submit,.project-detail-header-actions .task-btn-cancel{margin:0;padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem}.notes-form{padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-warm-gray)}.notes-form-title{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);font-family:var(--font-serif);font-size:1.25rem;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary)}.notes-form-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:0;padding:0;margin-bottom:var(--spacing-sm);border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.notes-toolbar-btn{padding:var(--spacing-xs) var(--spacing-md);font-family:var(--font-body);font-size:.9rem;background:var(--color-surface);color:var(--color-text-primary);border:none;border-radius:0;cursor:pointer;transition:background var(--transition-fast)}.notes-toolbar-btn:hover{background:var(--color-light-gray)}.notes-toolbar-sep{width:1px;height:1.25rem;background:var(--color-warm-gray);margin:0;flex-shrink:0}.notes-toolbar-size-arrow{font-size:.7em;vertical-align:top}.notes-form-content-editable{display:block;width:100%;min-height:320px;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);font-family:var(--font-body);font-size:1rem;line-height:1.5;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary);overflow-y:auto;outline:none}.notes-form-content-editable:empty:before{content:attr(data-placeholder);color:var(--color-text-secondary)}.notes-form-actions{display:flex;gap:var(--spacing-sm)}.notes-preview{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);background:var(--color-surface);border:1px solid var(--color-warm-gray);border-radius:var(--radius-lg)}.notes-preview-title{margin:0 0 var(--spacing-md) 0;font-family:var(--font-serif);font-size:1.25rem;color:var(--color-text-primary)}.notes-preview-content{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--color-text-primary)}.notes-preview-content p{margin:0 0 var(--spacing-sm) 0}.notes-preview-content p:last-child{margin-bottom:0}.notes-preview-content ul,.notes-preview-content ol{margin:0 0 var(--spacing-sm) 0;padding-left:var(--spacing-lg)}.notes-add-btn{padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-body);font-size:1rem;background:var(--color-primary);color:var(--color-text-light);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.notes-add-btn:hover{background:var(--color-primary-dark)}.notes-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-md)}.notes-empty{grid-column:1 / -1;padding:var(--spacing-xl);text-align:center;color:var(--color-text-secondary)}.notes-card{display:flex;flex-direction:row;align-items:stretch;background:var(--color-surface);border:1px solid var(--color-light-gray);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.notes-card:hover{border-color:var(--color-warm-gray);box-shadow:0 2px 8px #0000000f}.notes-card-drag-over{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary)}.notes-card-drag-handle{display:flex;align-items:center;justify-content:center;padding:0 var(--spacing-sm);color:var(--color-text-secondary);cursor:grab;flex-shrink:0;font-size:.9rem;-webkit-user-select:none;user-select:none}.notes-card-drag-handle:active{cursor:grabbing}.notes-card-body{flex:1;display:flex;flex-direction:column;min-width:0}.notes-card-inner{flex:1;padding:var(--spacing-md);text-align:left;background:none;border:none;cursor:pointer;font-family:inherit}.notes-card-title{font-family:var(--font-serif);font-size:1.1rem;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notes-card-date{font-size:.8rem;color:var(--color-text-secondary)}.notes-card-delete{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;background:transparent;color:var(--color-text-secondary);border:none;border-top:1px solid var(--color-light-gray);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.notes-card-delete:hover{background:var(--color-light-gray);color:#c44}@media (max-width: 768px){.projects-layout{flex-direction:column}.projects-list-panel{width:100%}.project-detail{min-width:0}}.goals-view{max-width:640px}.goals-heading{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.goals-form{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.goals-input{flex:1;min-width:160px}.goals-target{min-width:120px}.goals-list{list-style:none;margin:0;padding:0}.goals-empty{padding:var(--spacing-md);color:var(--color-text-secondary);font-style:italic}.goals-item{padding:.75rem var(--spacing-md);margin-bottom:var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-light-gray);border-radius:var(--radius-lg)}.goals-item-header{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.goals-name-edit{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-xs);width:100%}.goals-name-edit .goals-name-input{flex:1;min-width:160px}.goals-name-edit .task-btn-save{background:var(--color-primary);color:var(--color-text-light);border:1px solid var(--color-primary);padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;border-radius:var(--radius-sm);cursor:pointer}.goals-name-edit .task-btn-cancel{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;background:var(--color-surface);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer}.goals-status-wrap{margin-left:auto;flex-shrink:0}.goals-status-select{padding:var(--spacing-xs) var(--spacing-sm);font-family:var(--font-body);font-size:.9rem;color:var(--color-text-primary);background:var(--color-background);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer;min-width:110px}.goals-status-select:focus{outline:none;border-color:var(--color-primary)}.goals-status-select.goals-status-completed{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}.goals-status-select.goals-status-in-progress{background:var(--color-pink-soft);color:var(--color-text-primary);border-color:var(--color-pink)}.goals-dropdown-wrap{position:relative;flex-shrink:0}.goals-dropdown-trigger{padding:var(--spacing-xs) var(--spacing-sm);font-size:1.1rem;line-height:1;background:transparent;color:var(--color-text-secondary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.goals-dropdown-trigger:hover{background:var(--color-light-gray);color:var(--color-text-primary)}.goals-dropdown-menu{position:absolute;right:0;top:100%;margin-top:2px;min-width:140px;padding:var(--spacing-xs);background:var(--color-off-white);border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;z-index:10}.goals-dropdown-menu button{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-family:var(--font-body);font-size:.9rem;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-primary)}.goals-dropdown-menu button:hover:not(:disabled){background:var(--color-light-gray)}.goals-dropdown-menu button:disabled{opacity:.5;cursor:not-allowed}.goals-dropdown-delete{color:#c44!important;border-top:1px solid var(--color-light-gray);margin-top:var(--spacing-xs);padding-top:var(--spacing-sm)!important}.goals-dropdown-delete:hover{background:var(--color-light-gray)!important}.goals-item-title{font-family:var(--font-serif);font-size:1.125rem;color:var(--color-text-primary);font-weight:600}.goals-item-target{font-size:.9rem;color:var(--color-text-secondary)}.goals-item-actions{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.goals-notes-list{margin-top:var(--spacing-sm)}.goals-note-card{padding:var(--spacing-sm);margin-bottom:var(--spacing-xs);background:var(--color-off-white);border:1px solid var(--color-light-gray);border-radius:var(--radius-md)}.goals-note-card-row{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.goals-note-card-row .goals-note-card-body{flex:1;min-width:0}.goals-note-dropdown-wrap{position:relative;flex-shrink:0}.goals-note-dropdown-trigger{padding:2px 6px;font-size:1rem}.goals-note-dropdown-menu{min-width:100px}.goals-note-card-body{margin-bottom:var(--spacing-xs)}.goals-note-card-title{font-size:.95rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.goals-note-text{font-size:.9rem;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0;white-space:pre-wrap}.goals-note-date{font-size:.8rem;color:var(--color-text-secondary)}.goals-add-note-inline{padding:var(--spacing-xs) 0;font-size:.9rem;font-family:var(--font-body);background:none;border:none;color:var(--color-primary);cursor:pointer}.goals-add-note-inline:hover{text-decoration:underline}.goals-note-title-input{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);font-family:var(--font-body);font-size:.95rem;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary)}.goals-note-edit{margin-bottom:var(--spacing-sm)}.goals-note-textarea{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);font-family:var(--font-body);font-size:.95rem;line-height:1.4;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary);resize:vertical}.goals-note-actions{display:flex;gap:var(--spacing-xs)}.goals-note-actions .task-btn-save{background:var(--color-primary);color:var(--color-text-light);border:1px solid var(--color-primary);padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;border-radius:var(--radius-sm);cursor:pointer}.goals-note-actions .task-btn-cancel{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;background:var(--color-surface);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer}.goals-item .task-btn-delete{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer}.goals-item .task-btn-delete:hover{border-color:#c44;color:#c44}.habits-view{max-width:900px}.habits-heading{font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.habits-form{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.habits-input{flex:1;min-width:160px}.habits-target{min-width:120px}.habits-layout{display:flex;gap:var(--spacing-lg);align-items:flex-start;flex-wrap:wrap}.habits-main{flex:1;min-width:280px}.habits-list{list-style:none;margin:0;padding:0}.habits-empty{padding:var(--spacing-md);color:var(--color-text-secondary);font-style:italic}.habits-item{padding:var(--spacing-md);margin-bottom:var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-light-gray);border-radius:var(--radius-lg)}.habits-item.selected{border-color:var(--color-primary);box-shadow:0 2px 6px #0000000f}.habits-item-header{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.habits-dropdown-wrap{position:relative;margin-left:auto}.habits-dropdown-trigger{padding:var(--spacing-xs) var(--spacing-sm);font-size:1.1rem;line-height:1;background:transparent;color:var(--color-text-secondary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.habits-dropdown-trigger:hover{background:var(--color-light-gray);color:var(--color-text-primary)}.habits-dropdown-menu{position:absolute;right:0;top:100%;margin-top:2px;min-width:140px;padding:var(--spacing-xs);background:var(--color-off-white);border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;z-index:10}.habits-dropdown-menu button{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-family:var(--font-body);font-size:.9rem;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-primary)}.habits-dropdown-menu button:hover:not(:disabled){background:var(--color-light-gray)}.habits-dropdown-delete{color:#c44!important;border-top:1px solid var(--color-light-gray);margin-top:var(--spacing-xs);padding-top:var(--spacing-sm)!important}.habits-dropdown-delete:hover{background:var(--color-light-gray)!important}.habits-name-edit{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-xs);width:100%}.habits-name-edit .habits-name-input{flex:1;min-width:160px}.habits-name-edit .task-btn-save{background:var(--color-primary);color:var(--color-text-light);border:1px solid var(--color-primary);padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;border-radius:var(--radius-sm);cursor:pointer}.habits-name-edit .task-btn-cancel{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;background:var(--color-surface);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer}.habits-item-title{font-family:var(--font-serif);font-size:1.25rem;color:var(--color-text-primary);font-weight:600}.habits-item-target{font-size:.9rem;color:var(--color-text-secondary)}.habits-item-progress{font-size:.95rem;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.habits-item-actions{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap}.habits-log-btn{padding:var(--spacing-xs) var(--spacing-md);font-family:var(--font-body);font-size:.9rem;background:var(--color-primary);color:var(--color-text-light);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.habits-log-btn:hover:not(:disabled){background:var(--color-primary-dark)}.habits-log-btn:disabled{opacity:.7;cursor:default}.habits-select-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem;font-family:var(--font-body);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.habits-select-btn:hover{background:var(--color-light-gray);color:var(--color-primary)}.habits-history-panel{width:260px;flex-shrink:0;padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-warm-gray);border-radius:var(--radius-lg);position:sticky;top:var(--spacing-md)}.habits-history-title{font-family:var(--font-serif);font-size:1rem;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.habits-history-list{list-style:none;margin:0;padding:0}.habits-history-empty{padding:var(--spacing-sm);color:var(--color-text-secondary);font-style:italic}.habits-history-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;border-bottom:1px solid var(--color-light-gray);font-size:.9rem}.habits-history-item:last-child{border-bottom:none}.habits-history-date{color:var(--color-text-primary)}.habits-history-value{font-size:.85rem;color:var(--color-text-secondary)}.habits-history-placeholder{margin:0;color:var(--color-text-secondary);font-size:.9rem;font-style:italic}@media (max-width: 768px){.habits-layout{flex-direction:column}.habits-history-panel{width:100%;position:static}}.personal-info-view{max-width:480px;padding:var(--spacing-lg) 0}.personal-info-back{margin-bottom:var(--spacing-md);padding:0;font-family:var(--font-body);font-size:.95rem;color:var(--color-primary);background:none;border:none;cursor:pointer;text-decoration:none;transition:color var(--transition-fast)}.personal-info-back:hover{color:var(--color-primary-dark);text-decoration:underline}.personal-info-heading{margin:0 0 var(--spacing-lg) 0;font-family:var(--font-serif);font-size:1.5rem;color:var(--color-text-primary)}.personal-info-section{margin-bottom:var(--spacing-xl)}.personal-info-label{margin:0 0 var(--spacing-xs) 0;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--color-text-secondary)}.personal-info-value{margin:0;font-size:1rem;color:var(--color-text-primary)}.personal-info-hint{margin:0 0 var(--spacing-sm) 0;font-size:.9rem;color:var(--color-text-secondary)}.personal-info-form{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.personal-info-input{padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:1rem;border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);background:var(--color-off-white);color:var(--color-text-primary)}.personal-info-input:focus{outline:none;border-color:var(--color-primary)}.personal-info-error{margin:0;font-size:.9rem;color:#c44}.personal-info-message{margin:0;font-size:.9rem;color:var(--color-text-secondary)}.personal-info-submit{align-self:flex-start;margin-top:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:1rem;color:var(--color-text-light);background:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.personal-info-submit:hover:not(:disabled){background:var(--color-primary-dark)}.personal-info-submit:disabled{opacity:.7;cursor:not-allowed}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:1.1rem;color:var(--color-text-secondary)}.app-supabase-banner{padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-body);font-size:.9rem;color:var(--color-text-primary);background:var(--color-pink-soft);border-bottom:1px solid var(--color-warm-gray)}.app-supabase-banner code{padding:0 4px;font-size:.85em;background:var(--color-surface);border-radius:var(--radius-sm)}.app-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border-bottom:1px solid var(--color-warm-gray)}.app-title{margin:0;font-family:var(--font-serif);font-size:1.75rem;color:var(--color-text-primary)}.app-header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.app-theme-dropdown{position:relative}.app-theme-trigger{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-family:var(--font-body);font-size:.9rem;color:var(--color-text-light);background:var(--color-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.app-theme-trigger:hover{background:var(--color-primary-dark)}.app-theme-trigger:focus{outline:none;box-shadow:0 0 0 2px var(--color-primary-dark)}.app-theme-chevron{font-size:.65rem;opacity:.9}.app-theme-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;white-space:nowrap;margin:0;padding:var(--spacing-xs);list-style:none;background:var(--color-surface);border:1px solid var(--color-warm-gray);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001f;z-index:10}.app-theme-menu li{margin:0;padding:0}.app-theme-option{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-family:var(--font-body);font-size:.9rem;color:var(--color-text-primary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.app-theme-option:hover{background:var(--color-light-gray)}.app-theme-option.selected{background:var(--color-light-gray);color:var(--color-primary)}.app-theme-check{display:inline-block;width:1.25rem;flex-shrink:0;font-size:.9rem;color:var(--color-primary)}.app-user-trigger{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-light);background:var(--color-primary);border:none}.app-user-trigger:hover{background:var(--color-primary-dark)}.app-user-trigger:focus{outline:none;box-shadow:0 0 0 2px var(--color-primary-dark)}.app-user-menu{min-width:160px}.app-user-name{font-size:.95rem;color:var(--color-text-secondary)}.app-signout{padding:var(--spacing-xs) var(--spacing-sm);font-family:var(--font-body);font-size:.9rem;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-warm-gray);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.app-signout:hover{background:var(--color-light-gray);color:var(--color-primary)}:root{--color-pink-light: #FFE4EC;--color-pink: #F8B4C4;--color-pink-soft: #FADADD;--color-pink-dark: #C71585;--color-pink-darker: #A0126A;--color-blue-light: #B8D4E8;--color-blue-soft: #A8D8EA;--color-green-light: #B8E0B0;--color-green-soft: #A8D5A2;--color-cream: #FDF6F8;--color-sand: #FFF0F5;--color-warm-gray: #E8DDE3;--color-light-gray: #F0E6EA;--color-off-white: #FFFAFC;--color-ivory: #FFFBF7;--color-charcoal: #5C4B7A;--color-text-primary: #4A3D6B;--color-text-secondary: #6B5B7B;--color-text-light: #FFFBF7;--color-primary: var(--color-pink-dark);--color-primary-dark: var(--color-pink-darker);--color-accent: var(--color-blue-soft);--color-background: var(--color-off-white);--color-surface: var(--color-pink-light);--color-dark: var(--color-pink-dark);--color-success: var(--color-green-soft);--font-serif: "Cormorant", serif;--font-body: "Lora", serif;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--spacing-2xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .2s ease;--transition-normal: .3s ease}[data-theme=night]{--color-pink-light: #2d2444;--color-pink: #3b3255;--color-pink-soft: #1e2340;--color-pink-dark: #c9b8d8;--color-pink-darker: #b8a9c9;--color-blue-light: #252d4a;--color-blue-soft: #2a3655;--color-green-light: #1e3a2e;--color-green-soft: #2d4a3a;--color-cream: #1a2342;--color-sand: #1e2744;--color-warm-gray: #3b3255;--color-light-gray: #252d4a;--color-off-white: #1e2744;--color-ivory: #222c48;--color-charcoal: #a8b4d0;--color-text-primary: #f0f4ff;--color-text-secondary: #a8b4d0;--color-text-light: #0d1220;--color-primary: #c9b8d8;--color-primary-dark: #b8a9c9;--color-accent: #6b7aa0;--color-background: #0d1220;--color-surface: #1a2342;--color-dark: #c9b8d8;--color-success: #4a6b5a}[data-theme=night] .auth-error{color:#e8a0a8}[data-theme=notebook]{--color-pink-light: #faf8f3;--color-pink: #f5f0e6;--color-pink-soft: #f0ebe0;--color-pink-dark: #6b5344;--color-pink-darker: #5c4a3d;--color-blue-light: #e8e4dc;--color-blue-soft: #e0dcd2;--color-green-light: #d8e4d0;--color-green-soft: #c8d8c0;--color-cream: #faf8f3;--color-sand: #f5f0e6;--color-warm-gray: #c4b8a8;--color-light-gray: #e8e2d8;--color-off-white: #faf8f3;--color-ivory: #fdfcf9;--color-charcoal: #4a3f35;--color-text-primary: #3d3229;--color-text-secondary: #5c5248;--color-text-light: #faf8f3;--color-primary: #6b5344;--color-primary-dark: #5c4a3d;--color-accent: #8b7355;--color-background: #f5f0e6;--color-surface: #faf8f3;--color-dark: #5c4a3d;--color-success: #5a6b4a}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--color-text-primary);background:var(--color-background)}#root{min-height:100vh}
