.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}@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-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:900px}.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}.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)}.project-detail-title{font-family:var(--font-serif);font-size:1.25rem;color:var(--color-text-primary);margin:0}.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-content{display:block;width:100%;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);resize:vertical}.notes-form-actions{display:flex;gap:var(--spacing-sm)}.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:column;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-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-snippet{font-size:.9rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-xs) 0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4}.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: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-dropdown-wrap{position:relative;margin-left:auto}.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.25rem;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}}.app-header{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)}: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}*,*: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}
