.circular-progress{position:relative;display:inline-block}.circular-progress svg{transform:rotate(-90deg)}.progress-bg{fill:none;stroke:var(--color-bg-tertiary)}.progress-bar{fill:none;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center}.progress-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);line-height:1}.progress-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:4px}.goal-card{background-color:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--spacing-lg);text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:var(--spacing-md);transition:all var(--transition-normal);border:1px solid var(--color-border);cursor:pointer}.goal-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-accent-blue)}.goal-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md)}.goal-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);margin:0;flex:1;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.goal-type-badge{padding:var(--spacing-xs) var(--spacing-md);border-radius:999px;font-size:var(--font-size-xs);font-weight:600;white-space:nowrap;flex-shrink:0}.badge-financial{background-color:#10b98126;color:#059669}.badge-spiritual{background-color:#8b5cf626;color:#7c3aed}.badge-health{background-color:#ef444426;color:#dc2626}.badge-fitness{background-color:#3b82f626;color:#2563eb}.badge-education,.badge-career{background-color:#f59e0b26;color:#d97706}.goal-card-body{display:flex;justify-content:center;align-items:center;padding:var(--spacing-md) 0}.goal-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-md);border-top:1px solid var(--color-border);gap:var(--spacing-md)}.goal-stat{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.goal-stat svg{color:var(--color-text-secondary);width:16px;height:16px}.goal-stat .urgent{color:var(--color-accent-red);font-weight:600}@media (max-width: 768px){.goal-card{padding:var(--spacing-lg)}.goal-card-footer{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.goal-title{font-size:var(--font-size-lg)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast)}.modal-content{background-color:var(--color-bg-card);border-radius:var(--radius-xl);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl) var(--spacing-xl) 0}.modal-header h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);margin:0}.modal-close{background:none;border:none;font-size:2rem;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.modal-body{padding:var(--spacing-xl)}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:var(--radius-xl)}.modal-content::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-sm)}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--color-bg-hover)}.add-goal-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.goal-type-selector{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.goal-type-btn{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);border:2px solid transparent;background-color:var(--color-bg-secondary);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.goal-type-btn:hover{background-color:var(--color-bg-hover);transform:translateY(-1px)}.goal-type-btn.active{color:#fff}.goal-type-btn[data-type=financial].active{background-color:var(--color-financial);border-color:var(--color-financial)}.goal-type-btn[data-type=spiritual].active{background-color:var(--color-spiritual);border-color:var(--color-spiritual)}.goal-type-btn[data-type=health].active{background-color:var(--color-health);border-color:var(--color-health)}.goal-type-btn[data-type=fitness].active{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue)}.goal-type-btn[data-type=education].active{background-color:var(--color-education);border-color:var(--color-education)}.goal-type-btn[data-type=career].active{background-color:var(--color-accent-orange);border-color:var(--color-accent-orange)}.btn-block{width:100%;margin-top:var(--spacing-md)}.error-message{padding:var(--spacing-md);background-color:#ef44441a;border:1px solid var(--color-accent-red);border-radius:var(--radius-md);color:var(--color-accent-red);font-size:var(--font-size-sm)}textarea.input{resize:vertical;min-height:100px;font-family:var(--font-family-base)}.goals-overview{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl)}.page-header h1{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text-primary);margin:0}.page-header .btn{display:flex;align-items:center;gap:var(--spacing-sm)}.goals-controls{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.search-box{display:flex;align-items:center;gap:var(--spacing-sm);background-color:var(--color-bg-secondary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);border:1px solid var(--color-border);flex:0 0 auto;min-width:300px}.search-box svg{color:var(--color-text-tertiary);flex-shrink:0}.search-input{background:none;border:none;outline:none;color:var(--color-text-primary);font-size:var(--font-size-base);width:100%}.search-input::placeholder{color:var(--color-text-tertiary)}.filter-tabs{display:flex;gap:var(--spacing-lg);flex-wrap:wrap;margin-top:var(--spacing-md)}.filter-tab{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-lg);border:none;background-color:var(--color-bg-secondary);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.filter-tab:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.filter-tab.active{background-color:var(--color-accent-blue);color:#fff}.goals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl);animation:fadeIn var(--transition-normal)}@media (max-width: 1200px){.goals-grid{grid-template-columns:repeat(2,1fr)}}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-4xl) var(--spacing-xl);text-align:center;color:var(--color-text-secondary)}.loading-state .spinner{width:48px;height:48px;border:4px solid var(--color-bg-tertiary);border-top-color:var(--color-accent-blue);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-lg)}.empty-state svg{color:var(--color-text-tertiary);margin-bottom:var(--spacing-lg)}.empty-state h3{font-size:var(--font-size-xl);color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.empty-state p{margin:0 0 var(--spacing-xl) 0;max-width:400px}@media (max-width: 768px){.search-filter-group{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.goals-overview{padding:var(--spacing-lg);padding-top:70px}.page-header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding-left:0;text-align:center}.page-header h1{font-size:var(--font-size-2xl);margin:0}.page-header .btn{width:100%;max-width:300px}.goals-controls{display:flex;flex-direction:column;align-items:center;width:100%}.goals-grid{grid-template-columns:1fr}.search-box{max-width:100%;width:100%;margin-bottom:var(--spacing-md)}.filter-tabs-mobile{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-xs);width:100%;margin-bottom:var(--spacing-lg)}.filter-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-xs);width:100%;margin-bottom:var(--spacing-lg)}.filter-tab{flex:1 1 40%;min-width:120px;text-align:center;margin-bottom:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);background:var(--color-bg-secondary);color:var(--color-text-secondary);border:none;font-size:var(--font-size-base);font-weight:600;box-shadow:var(--shadow-sm);transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.filter-tab.active,.filter-tab:focus{background:var(--color-accent-blue);color:#fff;box-shadow:var(--shadow-md)}.filter-tab:hover{background:var(--color-bg-hover);color:var(--color-text-primary);box-shadow:var(--shadow-md)}}.goal-detail-page{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto}.breadcrumb-nav{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.breadcrumb-nav a{color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.breadcrumb-nav a:hover{color:var(--color-accent-blue)}.breadcrumb-nav span:last-child{color:var(--color-text-primary);font-weight:500}.goal-detail-header{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.goal-icon-large{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.goal-header-info h1{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.goal-tags{display:flex;gap:var(--spacing-sm)}.tag{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:999px;font-size:var(--font-size-xs);font-weight:600}.tag-financial{background-color:#10b98126;color:#059669}.tag-spiritual{background-color:#8b5cf626;color:#7c3aed}.tag-health{background-color:#ef444426;color:#dc2626}.tag-fitness{background-color:#3b82f626;color:#2563eb}.tag-education,.tag-career{background-color:#f59e0b26;color:#d97706}.tag-skill{background-color:#10b98126;color:#059669}.goal-detail-content{display:grid;grid-template-columns:1fr 350px;gap:var(--spacing-2xl)}.goal-main-content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.progress-card,.description-card,.steps-card{background-color:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--color-border)}.progress-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.progress-card-header h3,.description-card h3,.steps-card-header h3{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin:0}.progress-percent{font-size:var(--font-size-2xl);font-weight:800}.progress-bar-wrapper{margin-bottom:var(--spacing-sm)}.progress-bar-track{height:8px;background-color:var(--color-bg-tertiary);border-radius:var(--radius-lg);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-lg);transition:width .5s ease}.progress-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.description-card h3{margin-bottom:var(--spacing-md)}.description-card p{color:var(--color-text-secondary);line-height:1.6;margin:0}.steps-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.btn-text{display:flex;align-items:center;gap:var(--spacing-xs);background:none;border:none;color:var(--color-accent-blue);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.btn-text:hover{background-color:#3b82f61a}.steps-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.step-item-wrapper{background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.step-item-wrapper:hover{background-color:var(--color-bg-hover)}.step-item-wrapper.completed .step-text{text-decoration:line-through;opacity:.6}.step-item-content{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);min-height:48px}.step-label{flex:1;display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;margin:0}.step-actions{display:flex;gap:var(--spacing-xs);opacity:0;transition:opacity var(--transition-fast)}.step-item-wrapper:hover .step-actions{opacity:1}.btn-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.delete-btn:hover{background-color:#ef44441a;color:var(--color-health)}.save-btn:hover{background-color:#10b9811a;color:var(--color-financial)}.step-item-wrapper input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;width:0;height:0}.step-checkbox{width:20px;height:20px;border:2px solid var(--color-accent-blue);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.step-item-wrapper input:checked+.step-checkbox{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue)}.step-item-wrapper input:checked+.step-checkbox:after{content:"✓";color:#fff;font-size:14px;font-weight:700}.step-text{color:var(--color-text-primary);font-size:var(--font-size-base)}.edit-step-form{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.edit-step-input{flex:1;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-base);height:32px}.edit-step-actions{display:flex;gap:var(--spacing-xs)}.add-step-form{margin-top:var(--spacing-sm)}.goal-sidebar{display:flex;flex-direction:column;gap:var(--spacing-lg)}.sidebar-card{background-color:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--color-border)}.sidebar-card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);color:var(--color-text-secondary)}.sidebar-card-header h4{font-size:var(--font-size-base);font-weight:700;color:var(--color-text-primary);margin:0}.deadline-date{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:var(--spacing-sm) 0}.deadline-days{font-size:var(--font-size-sm);font-weight:600;margin:0}.no-deadline{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.reward-card{text-align:center;background-color:var(--color-bg-secondary);transition:all var(--transition-normal)}.reward-card.unlocked{background-color:#fff;border:2px solid #F59E0B;box-shadow:0 4px 20px #f59e0b26}.reward-card.unlocked .sidebar-card-header{color:#92400e;justify-content:center}.reward-card.unlocked .sidebar-card-header h4{color:#92400e}.reward-header-icon{font-size:18px;color:#f59e0b}.reward-content-box{background-color:#fffbeb;border:1px solid #FEF3C7;border-radius:var(--radius-lg);padding:var(--spacing-lg);margin:var(--spacing-sm) 0 var(--spacing-lg) 0}.reward-card.unlocked .reward-icon{font-size:48px;margin:0 0 var(--spacing-sm) 0;filter:none;color:#f59e0b}.reward-card.unlocked .reward-title{color:#78350f;font-size:1.75rem;margin:var(--spacing-xs) 0;font-weight:800}.reward-card.unlocked .reward-subtitle{color:#b45309;font-size:1.1rem;font-weight:600;margin:0}.claim-reward-btn{background-color:#f59e0b;border:none;color:#fff;width:100%;padding:var(--spacing-md);font-size:1.25rem;font-weight:700;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);box-shadow:0 4px 6px -1px #f59e0b4d;transition:all var(--transition-fast);cursor:pointer}.claim-reward-btn:hover{background-color:#d97706;transform:translateY(-1px);box-shadow:0 6px 8px -1px #f59e0b66}.btn-icon-wrapper{font-size:1.5rem}.reward-card.claimed{background-color:#f0fdf4;border:2px solid #86EFAC;box-shadow:none}.reward-card.claimed .sidebar-card-header{justify-content:center;color:#166534}.reward-card.claimed .sidebar-card-header h4{color:#14532d;font-size:var(--font-size-base)}.claimed-content{background-color:#dcfce7;border:1px solid #BBF7D0}.claimed-big-icon{display:flex;justify-content:center;margin:var(--spacing-sm) 0;filter:none}.reward-card.claimed .reward-title{color:#14532d;font-size:1.5rem;font-weight:700;margin:var(--spacing-xs) 0}.reward-card.claimed .reward-subtitle{color:#16a34a;font-size:1rem;font-weight:500}.claimed-btn{background-color:#4ade80!important;opacity:1!important;cursor:default!important;box-shadow:none!important;transform:none!important;pointer-events:none;font-size:1.25rem}.reward-card.locked{border:1px solid var(--color-border);box-shadow:none}.reward-card.locked .sidebar-card-header{color:#4b5563}.reward-card.locked .sidebar-card-header h4{color:#374151;font-weight:600}.locked-header-icon{color:#9ca3af;display:flex;align-items:center}.locked-content{background-color:#f3f4f6;border:none;margin-top:var(--spacing-md);padding:32px 24px}.locked-icon{font-size:56px;margin:0 0 var(--spacing-sm) 0;filter:grayscale(1) opacity(.5);color:#6b7280}.reward-card.locked .reward-title{color:#4b5563;font-size:1.125rem;font-weight:600;margin:var(--spacing-sm) 0 var(--spacing-xs)}.reward-card.locked .reward-subtitle{color:#9ca3af;font-size:.875rem;font-weight:400;margin:0}.celebration-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;pointer-events:none;display:flex;align-items:center;justify-content:center}.confetti-container{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden}.confetti{position:absolute;width:10px;height:10px;top:-10px;opacity:0;animation:confetti-fall 3s linear forwards}@keyframes confetti-fall{0%{top:-10px;opacity:1;transform:translate(0) rotate(0)}to{top:100vh;opacity:0;transform:translate(calc(100vw * (var(--random, .5) - .5))) rotate(720deg)}}.celebration-message{background:#fff;border-radius:20px;padding:40px;text-align:center;box-shadow:0 25px 50px -12px #00000040;animation:celebration-pop .5s cubic-bezier(.68,-.55,.265,1.55);pointer-events:all;max-width:450px;width:90%;position:relative;border:none}@keyframes celebration-pop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.celebration-icon-circle{width:80px;height:80px;background-color:#fef3c7;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:celebration-bounce 2s infinite}.celebration-trophy{font-size:40px;color:#f59e0b}@keyframes celebration-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.celebration-message h2{font-size:28px;font-weight:800;color:#111827;margin:0 0 12px}.celebration-subtitle{font-size:16px;color:#4b5563;margin:0 0 24px;line-height:1.5}.celebration-reward-box{background-color:#f9fafb;border:1px solid #E5E7EB;border-radius:12px;padding:16px;margin-bottom:32px;position:relative}.celebration-reward-box p{font-size:18px;font-weight:700;color:#111827;margin:0}.celebration-box-decor{position:absolute;top:-10px;right:-5px;font-size:20px;transform:rotate(15deg)}.celebration-done-btn{background-color:#fcd34d;color:#111827;border:none;width:100%;padding:14px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.celebration-done-btn:hover{background-color:#fbbf24;transform:translateY(-2px);box-shadow:0 4px 12px #fbbf2466}.celebration-decor-left{position:absolute;top:60px;left:40px;font-size:24px;transform:rotate(-15deg);animation:decor-float 3s ease-in-out infinite}.celebration-decor-right{position:absolute;top:80px;right:40px;font-size:20px;transform:rotate(15deg);animation:decor-float 3s ease-in-out infinite 1.5s}@keyframes decor-float{0%,to{transform:translateY(0) rotate(var(--rot))}50%{transform:translateY(-10px) rotate(var(--rot))}}.daily-actions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.daily-actions-header h4{font-size:var(--font-size-base);font-weight:700;color:var(--color-text-primary);margin:0}.daily-actions-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0 0 var(--spacing-lg) 0}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-bg-tertiary);transition:var(--transition-fast);border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:var(--transition-fast);border-radius:50%}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.daily-actions-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.daily-action-item{padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-border)}.daily-action-item:last-child{border-bottom:none;padding-bottom:0}.action-header{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-md)}.action-header svg{color:var(--color-text-tertiary)}.week-tracker{display:flex;gap:var(--spacing-xs);justify-content:space-between}.day-dot{width:32px;height:32px;border-radius:50%;border:2px solid;background:none;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;padding:0}.day-dot:hover{transform:scale(1.1)}.day-dot.completed{border-color:transparent!important}.goal-detail-loading,.goal-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--spacing-lg)}.goal-detail-loading .spinner{width:48px;height:48px;border:4px solid var(--color-bg-tertiary);border-top-color:var(--color-accent-blue);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 1024px){.goal-detail-content{grid-template-columns:1fr}.goal-sidebar{order:-1}}@media (max-width: 768px){.goal-detail-page{padding:var(--spacing-lg)}.goal-detail-header{flex-direction:column;align-items:flex-start}.goal-header-info h1{font-size:var(--font-size-2xl)}.week-tracker{gap:var(--spacing-xs)}.day-dot{width:28px;height:28px}}.daily-checklist-page{padding:3rem;max-width:1000px;margin:0 auto;font-family:Inter,sans-serif}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:800;color:var(--color-text-primary);margin:0 0 .25rem}.date-subtitle{color:var(--color-text-tertiary);font-size:1rem;font-weight:500;margin:0}.progress-card{background:#fff;border-radius:var(--radius-xl);padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid var(--color-border);width:100%;position:relative}.daily-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;width:100%}.daily-progress-text{text-align:left}.daily-progress-text h3{font-size:1.125rem;font-weight:700;color:var(--color-text-primary)}.daily-progress-text p{color:var(--color-text-secondary);font-size:.875rem;margin:0}.daily-progress-percentage{font-size:2rem;font-weight:800;color:var(--color-accent-blue);line-height:1}.progress-bar-container{height:12px;background-color:#f3f4f6;border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background-color:var(--color-accent-blue);border-radius:999px;transition:width .5s ease-out}.habits-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.habit-card{background:#fff;border-radius:var(--radius-lg);padding:1rem 1.5rem;border:1px solid var(--color-border);transition:all .2s ease}.habit-card:hover{box-shadow:0 2px 8px #0000000d}.habit-card.completed{border-color:transparent;box-shadow:none}.habit-content-wrapper{display:flex;justify-content:space-between;align-items:center}.habit-checkbox-label{display:flex;align-items:center;gap:1rem;cursor:pointer;flex:1}.habit-checkbox-label input{position:absolute;opacity:0;width:0;height:0}.custom-checkbox{width:24px;height:24px;border:2px solid var(--color-border);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff;flex-shrink:0}.habit-checkbox-label input:checked+.custom-checkbox{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue)}.habit-checkbox-label:hover .custom-checkbox{border-color:var(--color-accent-blue)}.habit-title{font-weight:500;font-size:1rem;color:var(--color-text-primary);transition:color .2s}.habit-card.completed .habit-title{color:var(--color-text-tertiary);text-decoration:line-through}.habit-meta{display:flex;align-items:center;gap:1.5rem}.streak-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background-color:#fff7ed;border-radius:6px;font-size:.75rem;font-weight:700;color:#c2410c}.streak-badge .fire-icon{font-size:1rem;line-height:1}.streak-badge.empty .fire-icon{filter:grayscale(1);opacity:.5}.habit-status-text{font-size:.75rem;font-weight:500;min-width:80px;text-align:right}.reset-text,.done-text{color:var(--color-text-tertiary)}.delete-habit-btn{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:4px;border-radius:4px;opacity:0;transition:all .2s}.habit-card:hover .delete-habit-btn{opacity:1}.add-habit-dashed-btn{width:100%;background:#f9fafb;border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;color:var(--color-text-secondary);font-weight:500;cursor:pointer;transition:all .2s}.add-habit-dashed-btn:hover{background:#f3f4f6;border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.plus-circle{width:32px;height:32px;border-radius:50%;border:1px solid var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.add-habit-dashed-btn:hover .plus-circle{border-color:var(--color-text-primary);color:var(--color-text-primary)}.habit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000}.habit-modal{background:#fff;width:100%;max-width:500px;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:0;animation:modalSlideUp .3s ease-out;display:flex;flex-direction:column}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #E5E7EB;margin-bottom:0}.modal-header h3{margin:0;font-size:1.125rem;font-weight:700;color:#111827}.close-btn{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;display:flex;transition:color .2s}.close-btn:hover{color:#4b5563}.habit-modal form{padding:1.5rem}.modal-input{width:100%;padding:.75rem 1rem;border:1px solid #E5E7EB;border-radius:8px;font-size:.95rem;background:#fff;transition:all .2s;color:#374151}.modal-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group{margin-bottom:1.25rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.875rem;color:#374151}.optional-text{font-weight:400;color:#9ca3af}.reminder-input-wrapper{position:relative}.clock-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;display:flex}.time-input{padding-left:2.75rem}.modal-footer{display:flex;justify-content:flex-end;align-items:center;gap:1rem;padding:1rem 1.5rem;border-top:1px solid #E5E7EB;background-color:#fff;border-radius:0 0 12px 12px;margin-top:0}.cancel-btn{padding:.6rem 1rem;background:none;border:none;color:#4b5563;font-weight:600;cursor:pointer;border-radius:6px;margin-right:.5rem}.cancel-btn:hover{color:#111827;background:#f3f4f6}.submit-btn{padding:.6rem 1.5rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s;box-shadow:0 1px 2px #0000000d}.submit-btn:hover{background:#1d4ed8}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.habit-edit-input{flex:1;font-size:1rem;padding:.5rem;border:1px solid var(--color-accent-blue);border-radius:var(--radius-md);margin-right:1rem;outline:none;background:#fff;color:var(--color-text-primary);min-width:200px}.action-buttons-wrapper{display:flex;align-items:center;gap:.25rem}.btn-icon{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:0}.habit-card:hover .btn-icon,.edit-actions .btn-icon{opacity:1}.btn-icon:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.save-icon{color:#10b981}.save-icon:hover{background-color:#d1fae5;color:#059669}.cancel-icon:hover{background-color:#fee2e2;color:#ef4444}.delete-habit-btn:hover{color:#ef4444;background-color:#fef2f2}.edit-actions{display:flex;gap:.5rem}@media (max-width: 640px){.daily-checklist-page{padding:1.5rem}.habit-content-wrapper{align-items:flex-start}.habit-meta{flex-direction:column;gap:.5rem;align-items:flex-end;margin-left:.5rem}}.dashboard-page{padding:2rem;max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2.25rem;font-weight:800;color:var(--color-text-primary)}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.dashboard-card{background:#fff;border-radius:1rem;padding:1.25rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid var(--color-border);display:flex;flex-direction:column}.card-title{font-size:1rem;font-weight:700;color:var(--color-text-primary);margin-bottom:1rem}.tasks-content{display:flex;align-items:center;gap:1rem;margin-top:0}.tasks-list{flex:1;display:flex;flex-direction:column;gap:.5rem}.task-item{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:var(--color-text-primary)}.task-item.completed{text-decoration:line-through;color:var(--color-text-tertiary)}.task-checkbox-custom{width:18px;height:18px;border:2px solid #E5E7EB;border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:#fff}.task-item.completed .task-checkbox-custom{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue)}.habits-banner{background-color:#eff6ff;border-radius:.5rem;padding:.6rem .875rem;display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;font-size:.9rem}.streak-info{display:flex;align-items:center;gap:.5rem;font-weight:700;color:var(--color-text-primary)}.fire-icon{color:var(--color-accent-blue)}.habits-progress-text{color:var(--color-accent-blue);font-weight:700}.habits-list{display:flex;flex-direction:column;gap:.75rem}.habit-item{display:flex;align-items:center;gap:.6rem;font-size:.9rem}.check-circle{width:20px;height:20px;border-radius:50%;border:2px solid #E5E7EB;display:flex;align-items:center;justify-content:center;color:#fff}.habit-item.completed .check-circle{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue)}.goal-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.active-goals-count{font-size:.8rem;color:var(--color-text-secondary);font-weight:600}.goals-list{display:flex;flex-direction:column;gap:1.25rem}.goal-item{display:flex;flex-direction:column;gap:.5rem}.goal-info{display:flex;justify-content:space-between;font-size:.9rem;font-weight:500;color:var(--color-text-primary)}.goal-percentage{color:var(--color-text-secondary)}.linear-progress-bg{height:8px;background-color:#f3f4f6;border-radius:4px;overflow:hidden}.linear-progress-fill{height:100%;background-color:var(--color-accent-blue);border-radius:4px}.reflection-content{display:flex;flex-direction:column;height:100%}.rating-display{display:flex;align-items:center;gap:.5rem;font-weight:600;margin-bottom:.75rem;font-size:.95rem}.rating-emoji{font-size:1.1rem}.reflection-quote-box{background-color:#f9fafb;border:1px solid #E5E7EB;border-radius:.75rem;padding:.75rem;font-style:italic;color:var(--color-text-secondary);font-size:.9rem;line-height:1.5;margin-bottom:1.25rem;flex:1}.view-entry-link{color:var(--color-accent-blue);font-weight:600;font-size:.9rem;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.view-entry-link:hover{text-decoration:underline}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr}}.all-tasks-page{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto}.tasks-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem}.current-date{color:var(--color-text-secondary);font-size:1rem;margin:0}.task-textarea{resize:vertical;min-height:80px;font-family:inherit}.header-controls{display:flex;gap:1rem}.search-wrapper{position:relative;width:280px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary)}.search-wrapper input{width:100%;padding:.625rem 1rem .625rem 2.5rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:.875rem;background:#fff;transition:all .2s}.search-wrapper input:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 2px #3b82f61a}.btn-filter,.btn-add-task{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-filter{background:#fff;border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-filter:hover{background:var(--color-bg-tertiary)}.btn-add-task{background:var(--color-accent-blue);border:none;color:#fff}.btn-add-task:hover{background:#2563eb}.tasks-table-container{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.tasks-table{width:100%;border-collapse:collapse}.tasks-table th{text-align:left;padding:1rem 1.5rem;font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);background:#fafafa}.task-row td{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:.875rem;vertical-align:middle}.task-row:last-child td{border-bottom:none}.task-row:hover{background:#f9fafb}.td-task{width:35%}.th-actions,.td-actions{width:100px;text-align:right}.checkbox-wrapper{display:flex;align-items:center;gap:1rem;cursor:pointer}.checkbox-wrapper input{position:absolute;opacity:0;width:0;height:0}.checkbox-custom{width:20px;height:20px;border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all .2s;background:#fff}.checkbox-wrapper:hover .checkbox-custom{border-color:var(--color-text-tertiary)}.checkbox-wrapper input:checked+.checkbox-custom{background:var(--color-accent-blue);border-color:var(--color-accent-blue);background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 6L5 9L10 3' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.task-title{font-weight:500;color:var(--color-text-primary)}.page-badge{display:inline-flex;padding:.25rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:600}.priority-cell{display:flex;align-items:center;gap:.5rem}.priority-dot{width:8px;height:8px;border-radius:50%}.status-badge{display:inline-flex;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.action-buttons{display:flex;justify-content:flex-end;gap:.5rem;opacity:1!important;visibility:visible!important;transition:opacity .2s}.task-row:hover .action-buttons{opacity:1}.task-row .action-buttons{opacity:1!important}.action-buttons .btn-icon{opacity:1!important;color:#6b7280}.action-buttons:not(.hover-show){opacity:1}.btn-icon{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .2s}.save-icon:hover{color:#10b981}.cancel-icon:hover{color:var(--color-text-secondary)}.edit-task-inline{width:100%}.edit-task-input{width:100%;padding:.25rem .5rem;border:1px solid var(--color-accent-blue);border-radius:var(--radius-md);font-size:.875rem;outline:none;background:#fff}.empty-state-cell{padding:3rem;border-bottom:none!important}.empty-state-content{display:flex;justify-content:center;align-items:center;width:100%;color:var(--color-text-tertiary);text-align:center}.done-section{margin-top:3rem}.done-section h3{font-size:1.125rem;font-weight:700;margin-bottom:1rem;color:var(--color-text-primary)}.done-list{display:flex;flex-direction:column;gap:1rem}.done-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem 1.5rem;border-radius:var(--radius-xl);border:1px solid var(--color-border);transition:all .2s}.done-item:hover{box-shadow:0 2px 8px #0000000d}.done-item-left{display:flex;align-items:center;gap:1rem}.done-title{color:var(--color-text-tertiary);text-decoration:line-through;font-weight:500}.done-check-icon{display:flex;align-items:center;color:#10b981}.no-done-tasks{color:var(--color-text-tertiary);font-style:italic}@media (max-width: 1024px){.tasks-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-controls{width:100%;overflow-x:auto}.tasks-table-container{overflow-x:auto}.tasks-table{min-width:800px}}@media (max-width: 768px){.all-tasks-page{padding:1rem}.tasks-header{margin-bottom:1.25rem}.header-title h1{font-size:1.75rem;margin:0 0 .25rem}.current-date{font-size:.875rem}.header-controls{flex-direction:column;gap:.75rem;width:100%}.search-wrapper{width:100%}.btn-filter,.btn-add-task{width:100%;justify-content:center;padding:.75rem 1rem}.tasks-table-container{background:transparent;border:none;border-radius:0;overflow:visible}.tasks-table thead{display:none}.tasks-table,.tasks-table tbody,.tasks-table tr{display:block;width:100%}.task-row{display:block;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);margin-bottom:1rem;padding:1rem;box-shadow:0 1px 3px #0000000d}.task-row:hover{background:#fff;box-shadow:0 4px 6px #00000012}.task-row td{display:block;padding:0;border:none}.td-task{width:100%;margin-bottom:.75rem}.task-cell-content{align-items:flex-start}.btn-expand{margin-top:2px}.task-info{flex:1}.task-title{font-size:1rem;font-weight:600;line-height:1.4}.task-meta-preview{margin-top:.5rem}.td-page,.td-status{display:inline-block;width:auto;margin-right:.5rem;margin-bottom:.75rem}.td-due,.td-priority{display:none}.td-actions{display:flex;justify-content:flex-end;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.page-badge,.status-badge{font-size:.75rem;padding:.375rem .75rem}.subtasks-row{display:block;background:#f9fafb;border-radius:0 0 var(--radius-xl) var(--radius-xl);margin-top:-.5rem;margin-bottom:1rem}.subtasks-container{padding:1rem}.task-description-view{font-size:.8125rem;padding-bottom:.75rem;margin-bottom:.75rem}.subtask-item{padding:.75rem}.subtask-title{font-size:.8125rem}.edit-task-input,.edit-description-input{font-size:.9375rem}.modal-content{width:95%;padding:1.5rem;max-height:90vh;overflow-y:auto}.modal-content h3{font-size:1.25rem;margin-bottom:1.25rem}.form-group{margin-bottom:1.25rem}.modal-actions{flex-direction:column-reverse;gap:.75rem}.btn-cancel,.btn-save{width:100%;text-align:center;justify-content:center}.task-detail-modal{max-width:95%;max-height:90vh}.detail-title{font-size:1.25rem;margin-bottom:1rem}.detail-meta-row{flex-direction:column;gap:.75rem;padding-bottom:1rem;margin-bottom:1rem}.detail-description{font-size:.9375rem}.detail-tags{flex-wrap:wrap;gap:.5rem}.done-section{margin-top:2rem}.done-section h3{font-size:1rem;margin-bottom:.75rem}.done-item{padding:.875rem 1rem;flex-direction:column;align-items:flex-start;gap:.75rem}.done-item-left{width:100%}.action-buttons{margin-top:.5rem;width:100%;justify-content:flex-end}.toast-notification{bottom:1rem;left:1rem;right:1rem;transform:none;width:auto;min-width:unset}@keyframes slideUpToast{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.add-subtask-form{flex-direction:column;gap:.625rem}.add-subtask-form button{width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-content{background:#fff;padding:2rem;border-radius:var(--radius-xl);width:90%;max-width:500px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-content h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.task-input,.goal-select{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:1rem;transition:all .2s;background-color:#fff}.task-input:focus,.goal-select:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 3px #3b82f61a}.btn-cancel{padding:.75rem 1.5rem;border:1px solid var(--color-border);background:#fff;border-radius:var(--radius-lg);font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.btn-save{padding:.75rem 1.5rem;background:var(--color-accent-blue);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;cursor:pointer;transition:all .2s}.subtasks-row{background-color:#f9fafb}.subtasks-row td{padding:0!important;border-bottom:1px solid var(--color-border)}.subtasks-container{padding:1rem 1.5rem 1.5rem 3.5rem}.task-description-view{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px dashed var(--color-border);line-height:1.5}.subtasks-list{display:flex;flex-direction:column;gap:.75rem}.subtask-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all .2s}.subtask-item:hover{border-color:var(--color-accent-blue);background-color:#f9fafb}.subtask-checkbox{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;align-items:center!important;flex:1;margin-bottom:0;cursor:pointer;gap:12px!important}.subtask-checkbox input{position:absolute;opacity:0;width:0;height:0}.subtask-checkbox .checkbox-custom{display:block;flex-shrink:0;width:18px!important;height:18px!important;min-width:18px;min-height:18px;border:2px solid var(--color-border);border-radius:4px;background-color:#fff;transition:all .2s}.subtask-checkbox:hover .checkbox-custom{border-color:var(--color-accent-blue)}.subtask-checkbox input:checked+.checkbox-custom{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-size:80%;background-position:center;background-repeat:no-repeat}.subtask-title{font-size:.875rem;font-weight:500;color:var(--color-text-primary);line-height:1.2;word-break:break-word;margin-top:1px}.subtask-title.completed{text-decoration:line-through;color:var(--color-text-tertiary)}.btn-icon.small{padding:2px;width:24px;height:24px}.add-subtask-form{display:flex;gap:.5rem;margin-top:.75rem}.add-subtask-form input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;outline:none;transition:border-color .2s}.add-subtask-form input:focus{border-color:var(--color-accent-blue);box-shadow:0 0 0 3px #3b82f61a}.add-subtask-form button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;background:var(--color-accent-blue);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .2s;font-size:.875rem;font-weight:500}.add-subtask-form button:hover{background:#2563eb}.add-subtask-form button:disabled{background:var(--color-border);opacity:.7;cursor:not-allowed}.btn-expand{background:none;border:none;padding:4px;cursor:pointer;color:var(--color-text-tertiary);transition:transform .2s,color .2s;margin-right:.5rem;display:flex;align-items:center}.btn-expand:hover{color:var(--color-text-primary);background-color:#0000000d;border-radius:4px}.btn-expand.active svg{transform:rotate(90deg)}.task-cell-content{display:flex;align-items:flex-start}.task-cell-content .checkbox-wrapper{align-items:flex-start}.task-cell-content .checkbox-custom{margin-top:2px}.task-info{display:flex;flex-direction:column}.task-meta-preview{display:flex;gap:.75rem;margin-top:.25rem;font-size:.75rem;color:var(--color-text-tertiary)}.subtask-count,.has-desc-icon{display:flex;align-items:center;gap:.25rem}.edit-task-container{display:flex;flex-direction:column;gap:.5rem;width:100%}.edit-description-input{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-family:inherit;resize:vertical;outline:none}.edit-description-input:focus{border-color:var(--color-accent-blue)}.small{padding:4px}.btn-undo-list{background:#fff;border:1px solid var(--color-border);padding:.25rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);cursor:pointer;transition:all .2s}.btn-undo-list:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-text-secondary)}.toast-notification{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:.75rem 1.25rem;border-radius:var(--radius-lg);display:flex;align-items:center;gap:1.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;z-index:2000;animation:slideUpToast .3s cubic-bezier(.16,1,.3,1);min-width:300px;justify-content:space-between}.toast-message{font-size:.875rem;font-weight:500}.toast-undo-btn{background:none;border:none;color:var(--color-accent-blue);font-weight:700;font-size:.875rem;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-sm);transition:background .2s}.toast-undo-btn:hover{background:#ffffff1a}.toast-close{background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:50%;transition:all .2s}.toast-close:hover{color:#fff;background:#ffffff1a}@keyframes slideUpToast{0%{transform:translate(-50%,20px);opacity:0}to{transform:translate(-50%);opacity:1}}.checkbox-only-wrapper{display:flex;align-items:center;justify-content:center;position:relative;margin-right:1rem;cursor:pointer;width:20px;height:20px;margin-top:2px}.checkbox-only-wrapper input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;z-index:10}.clickable-info{flex:1;cursor:pointer;display:flex;flex-direction:column}.clickable-info:hover .task-title{color:var(--color-accent-blue)}.task-detail-modal{max-width:600px;width:95%;max-height:85vh;overflow-y:auto}.modal-header-actions{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.detail-tags{display:flex;gap:.5rem;flex-wrap:wrap}.detail-title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 1.5rem;line-height:1.3}.detail-meta-row{display:flex;gap:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border);margin-bottom:1.5rem}.meta-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.meta-item .label{color:var(--color-text-tertiary);font-weight:500}.meta-item .value{color:var(--color-text-primary);font-weight:600}.detail-section{margin-bottom:2rem}.detail-section label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);font-weight:700;margin-bottom:.75rem}.detail-description{font-size:1rem;line-height:1.6;color:var(--color-text-secondary);white-space:pre-wrap}.detail-description .placeholder{font-style:italic;color:var(--color-text-tertiary)}.modal-actions.left{justify-content:flex-start;margin-top:1rem;border-top:1px solid var(--color-border);padding-top:1rem}.btn-delete-text{background:none;border:none;color:#ef4444;font-size:.875rem;font-weight:600;cursor:pointer;padding:0}.btn-delete-text:hover{text-decoration:underline}.editable{cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-md);transition:all .2s;position:relative}.editable:hover{background-color:var(--color-bg-tertiary)}.editable:hover:after{content:"✎";position:absolute;right:-20px;color:var(--color-text-tertiary);font-size:.875rem}.detail-description.editable{padding:.75rem;border:1px dashed transparent;min-height:60px}.detail-description.editable:hover{border-color:var(--color-border)}.inline-edit-group{display:flex;align-items:center;gap:.5rem}.inline-edit-group.description-edit{flex-direction:column;align-items:stretch}.inline-edit-input,.inline-edit-select,.inline-edit-textarea{padding:.5rem .75rem;border:2px solid var(--color-accent-blue);border-radius:var(--radius-md);font-size:.875rem;font-family:inherit;outline:none;transition:all .2s}.inline-edit-input:focus,.inline-edit-select:focus,.inline-edit-textarea:focus{box-shadow:0 0 0 3px #3b82f61a}.inline-edit-textarea{width:100%;resize:vertical;font-size:1rem;line-height:1.6}.inline-edit-select{min-width:140px;padding:.5rem 2rem .5rem .75rem}.inline-edit-actions{display:flex;gap:.5rem;margin-top:.5rem}.btn-save-inline,.btn-cancel-inline{padding:.375rem .75rem;border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;gap:.25rem}.btn-save-inline{background:var(--color-accent-blue);color:#fff}.btn-save-inline:hover{background:#2563eb}.btn-cancel-inline{background:#fff;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-cancel-inline:hover{background:var(--color-bg-tertiary)}.priority-display{display:flex;align-items:center;gap:.5rem}.priority-display.editable:hover:after{content:"▼";font-size:.625rem}.settings-page{padding:var(--spacing-2xl);max-width:900px;margin:0 auto}.settings-header{margin-bottom:var(--spacing-2xl)}.settings-header h1{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.settings-header p{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0}.settings-content{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.settings-section{background-color:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--spacing-xl);border:1px solid var(--color-border)}.settings-section h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) 0;border-bottom:1px solid var(--color-border)}.setting-item:last-child{border-bottom:none;padding-bottom:0}.setting-item:first-of-type{padding-top:0}.setting-info{flex:1}.setting-info h3{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.setting-info p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.theme-toggle{display:flex;gap:var(--spacing-sm);background-color:var(--color-bg-secondary);padding:var(--spacing-xs);border-radius:var(--radius-lg)}.theme-option{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:none;background:none;color:var(--color-text-secondary);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.theme-option:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.theme-option.active{background-color:var(--color-accent-blue);color:#fff}.theme-option svg{width:20px;height:20px}.toggle-switch{position:relative;display:inline-block;width:60px;height:32px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-bg-tertiary);transition:var(--transition-fast);border-radius:32px}.toggle-slider:before{position:absolute;content:"";height:24px;width:24px;left:4px;bottom:4px;background-color:#fff;transition:var(--transition-fast);border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-accent-blue)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(28px)}.toggle-icon{position:absolute;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;transition:opacity var(--transition-fast)}.toggle-icon.sun{left:8px;opacity:1}.toggle-icon.moon{right:8px;opacity:.3}.toggle-switch input:checked+.toggle-slider .sun{opacity:.3}.toggle-switch input:checked+.toggle-slider .moon{opacity:1}.btn-secondary{background-color:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-bg-hover);border-color:var(--color-accent-blue)}.btn-danger{background-color:var(--color-accent-red);color:#fff}.btn-danger:hover{background-color:#dc2626}.select-input{min-width:200px;cursor:pointer}.danger-zone{border-color:var(--color-accent-red)}.danger-zone h2{color:var(--color-accent-red);border-color:var(--color-accent-red)}@media (max-width: 768px){.settings-page{padding:var(--spacing-lg)}.setting-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.theme-toggle{width:100%}.theme-option{flex:1;justify-content:center}.select-input,.btn-secondary,.btn-danger{width:100%}}.calendar-page{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto;min-height:100vh}.calendar-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem;gap:1rem}.current-view-title{color:var(--color-text-secondary);font-size:1rem;margin:0}.header-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.btn-today{padding:.625rem 1rem;border:1px solid var(--color-border);background:#fff;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;color:var(--color-text-primary)}.btn-today:hover{background:var(--color-bg-tertiary);border-color:var(--color-text-tertiary)}.navigation-buttons{display:flex;gap:.5rem}.btn-nav{padding:.625rem;border:1px solid var(--color-border);background:#fff;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary)}.btn-nav:hover{background:var(--color-bg-tertiary);border-color:var(--color-text-tertiary)}.view-switcher{display:flex;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.25rem;gap:.25rem}.view-btn{padding:.5rem 1rem;border:none;background:transparent;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;color:var(--color-text-secondary)}.view-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.view-btn.active{background:var(--color-accent-blue);color:#fff}.calendar-content{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2rem;min-height:600px}.month-view{display:grid;grid-template-columns:1fr 320px;gap:2rem}.calendar-grid{display:flex;flex-direction:column}.weekday-header{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;margin-bottom:1rem}.weekday-name{text-align:center;font-size:.875rem;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:.75rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.calendar-day{background:#fff;min-height:100px;padding:.75rem;cursor:pointer;transition:all .2s;position:relative}.calendar-day:hover:not(.empty){background:#f9fafb}.calendar-day.empty{background:#fafafa;cursor:default}.calendar-day.today{background:#3b82f60d}.calendar-day.selected{background:#3b82f61a;border:2px solid var(--color-accent-blue)}.calendar-day .day-number{font-weight:600;font-size:.875rem;color:var(--color-text-primary);margin-bottom:.5rem}.calendar-day.today .day-number{background:var(--color-accent-blue);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}.day-tasks{display:flex;gap:.375rem;flex-wrap:wrap}.task-dot{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .5rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:700;min-width:24px}.task-dot.incomplete{background:#3b82f633;color:#2563eb}.task-dot.completed{background:#10b98133;color:#059669}.selected-day-panel{border-left:1px solid var(--color-border);padding-left:2rem}.selected-day-panel h3{font-size:1.125rem;font-weight:700;color:var(--color-text-primary);margin:0 0 1.5rem}.selected-day-tasks{display:flex;flex-direction:column;gap:.75rem}.task-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#f9fafb;border-radius:var(--radius-lg);transition:all .2s}.task-item:hover{background:#f3f4f6}.task-item.completed{opacity:.6}.task-checkbox{flex-shrink:0}.checkbox-indicator{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:2px solid var(--color-border);border-radius:var(--radius-md);background:#fff;transition:all .2s}.checkbox-indicator.checked{background:var(--color-accent-blue);border-color:var(--color-accent-blue)}.task-content{flex:1}.task-title{font-weight:600;font-size:.875rem;color:var(--color-text-primary);margin-bottom:.375rem;line-height:1.4}.task-item.completed .task-title{text-decoration:line-through;color:var(--color-text-tertiary)}.task-meta{display:flex;gap:.5rem;font-size:.75rem}.task-page{padding:.25rem .5rem;background:#3b82f61a;color:#2563eb;border-radius:var(--radius-sm);font-weight:600}.task-priority{padding:.25rem .5rem;background:#f59e0b1a;color:#d97706;border-radius:var(--radius-sm);font-weight:600}.no-tasks{text-align:center;color:var(--color-text-tertiary);font-style:italic;padding:2rem}.week-view{display:flex;flex-direction:column;gap:1rem}.week-header{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.week-day-header{background:#fff;padding:1rem;text-align:center}.week-day-header.today{background:#3b82f60d}.day-name{font-size:.75rem;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.day-number{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:.5rem}.week-day-header.today .day-number{color:var(--color-accent-blue)}.day-task-count{font-size:.75rem;color:var(--color-text-tertiary)}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;min-height:400px}.week-day-column{background:#fff;padding:1rem .75rem;display:flex;flex-direction:column;gap:.5rem}.week-day-column.today{background:#3b82f605}.week-task{padding:.5rem .75rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.5rem;background:#3b82f61a;color:#2563eb;transition:all .2s;cursor:pointer}.week-task:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.week-task.completed{background:#10b9811a;color:#059669;opacity:.7}.task-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.day-view{display:grid;grid-template-columns:1fr 320px;gap:2rem}.day-header{margin-bottom:1.5rem}.day-header h2{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem}.task-summary{display:flex;gap:1.5rem;font-size:.875rem;color:var(--color-text-secondary)}.task-count,.completed-count{display:flex;align-items:center;gap:.375rem}.day-timeline{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.hour-slot{display:grid;grid-template-columns:80px 1fr;border-bottom:1px solid var(--color-border)}.hour-slot:last-child{border-bottom:none}.hour-label{padding:1rem;font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);background:#fafafa;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--color-border)}.hour-content{padding:1rem;min-height:60px;background:#fff}.day-tasks-list{border-left:1px solid var(--color-border);padding-left:2rem}.day-tasks-list h3{font-size:1.125rem;font-weight:700;color:var(--color-text-primary);margin:0 0 1.5rem}.year-view{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.year-month{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem;background:#fafafa}.month-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.month-header h4{margin:0;font-size:1rem;font-weight:700;color:var(--color-text-primary)}.month-task-count{background:var(--color-accent-blue);color:#fff;padding:.25rem .625rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:700}.mini-calendar{background:#fff;border-radius:var(--radius-md);padding:.75rem}.mini-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.mini-weekday{text-align:center;font-size:.625rem;font-weight:700;color:var(--color-text-tertiary);padding:.25rem}.mini-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.mini-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--color-text-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;position:relative}.mini-day:hover:not(.empty){background:var(--color-bg-hover)}.mini-day.empty{cursor:default}.mini-day.today{background:var(--color-accent-blue);color:#fff}.mini-day.has-tasks{background:#3b82f61a}.mini-task-indicator{position:absolute;bottom:2px;display:flex;gap:2px;justify-content:center}.mini-task-indicator .dot{width:4px;height:4px;border-radius:50%}.mini-task-indicator .dot.incomplete{background:#3b82f6}.mini-task-indicator .dot.completed{background:#10b981}.calendar-legend{display:flex;justify-content:center;gap:2rem;margin-top:2rem;padding:1rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-secondary)}.legend-dot{width:16px;height:16px;border-radius:50%}.legend-dot.incomplete{background:#3b82f6}.legend-dot.completed{background:#10b981}@media (max-width: 1024px){.calendar-header{flex-direction:column;align-items:flex-start}.month-view,.day-view{grid-template-columns:1fr}.selected-day-panel,.day-tasks-list{border-left:none;border-top:1px solid var(--color-border);padding-left:0;padding-top:2rem;margin-top:2rem}.year-view{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width: 768px){.calendar-page{padding:1rem}.calendar-header{margin-bottom:1.5rem;gap:1rem}.header-title h1{font-size:1.75rem;margin-bottom:.25rem}.current-view-title{font-size:.875rem}.header-controls{width:100%;flex-direction:column;gap:.75rem}.btn-today{width:100%;justify-content:center;order:3}.navigation-buttons{width:100%;justify-content:center;gap:.75rem;order:2}.btn-nav{flex:1;max-width:120px}.view-switcher{width:100%;order:1}.view-btn{flex:1;padding:.625rem .5rem;font-size:.8125rem}.calendar-content{padding:1rem;min-height:auto}.calendar-day{min-height:70px;padding:.5rem}.calendar-day .day-number{font-size:.8125rem}.task-dot{font-size:.625rem;padding:.1875rem .375rem;min-width:20px}.weekday-name{font-size:.75rem;padding:.5rem}.selected-day-panel h3{font-size:1rem;margin-bottom:1rem}.task-item{padding:.75rem}.task-title{font-size:.8125rem}.week-header{gap:0}.week-day-header{padding:.75rem .5rem}.day-name{font-size:.625rem;margin-bottom:.375rem}.week-day-header .day-number{font-size:1.125rem;margin-bottom:.25rem}.day-task-count{font-size:.625rem}.week-grid{grid-template-columns:repeat(7,1fr);min-height:250px;gap:0}.week-day-column{padding:.5rem .25rem}.week-task{font-size:.625rem;padding:.375rem .5rem;flex-direction:column;align-items:flex-start;gap:.25rem}.week-task .task-indicator{width:6px;height:6px}.week-task .task-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.day-view{display:block}.day-header h2{font-size:1.25rem;margin-bottom:.375rem}.task-summary{font-size:.8125rem;gap:1rem}.day-timeline{display:none}.day-tasks-list{border-left:none;padding-left:0;margin-top:1rem}.day-tasks-list h3{font-size:1rem;margin-bottom:1rem}.year-view{grid-template-columns:1fr;gap:1rem}.year-month{padding:.875rem}.month-header h4{font-size:.9375rem}.mini-calendar{padding:.625rem}.mini-weekday{font-size:.625rem;padding:.1875rem}.mini-day{font-size:.6875rem}.calendar-legend{flex-direction:row;gap:1rem;padding:.875rem;margin-top:1rem}.legend-item{font-size:.8125rem;gap:.375rem}.legend-dot{width:12px;height:12px}}.projects-page{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto;min-height:100vh}.projects-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem;gap:1rem}.btn-add-project{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--color-accent-blue);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #3b82f633}.btn-add-project:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.projects-content{display:flex;flex-direction:column;gap:3rem}.projects-section{display:flex;flex-direction:column;gap:1.5rem}.section-title{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin:0}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.project-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.5rem;transition:all .3s;position:relative;display:flex;flex-direction:column;gap:1rem}.project-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:var(--color-accent-blue)}.project-card.achieved{background:linear-gradient(135deg,#dcfce7,#f0fdf4);border-color:#10b981}.project-card.achieved:hover{border-color:#059669;box-shadow:0 12px 24px #10b98133}.achievement-badge{position:absolute;top:-12px;right:20px;background:#fff;border-radius:50%;padding:4px;box-shadow:0 4px 8px #0000001a}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.project-name{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin:0;line-height:1.3;flex:1}.project-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-icon{background:none;border:none;padding:.375rem;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-icon:hover{color:var(--color-text-primary);background-color:var(--color-bg-hover)}.edit-icon:hover{color:var(--color-accent-blue)}.delete-icon:hover{color:#ef4444}.project-description{color:var(--color-text-secondary);font-size:.9375rem;line-height:1.6;margin:0}.project-details{display:flex;flex-direction:column;gap:1rem}.detail-section h4{font-size:.75rem;font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.detail-text{color:var(--color-text-secondary);font-size:.875rem;line-height:1.6;margin:0;white-space:pre-line}.btn-achieve{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;margin-top:auto}.btn-achieve:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.achieved-date{color:#059669;font-size:.875rem;font-weight:600;margin:0;display:flex;align-items:center;gap:.375rem}.project-modal{padding:2rem}.empty-state p{font-size:1rem;color:var(--color-text-secondary);margin:0 0 2rem;max-width:400px}.achievement-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease-out}.achievement-animation{position:relative;z-index:2001}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden}.confetti{position:absolute;width:10px;height:10px;top:-10px;animation:confetti-fall 3s linear forwards;transform-origin:center}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.achievement-content{background:#fff;padding:3rem;border-radius:var(--radius-xl);text-align:center;animation:scaleIn .5s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 25px 50px -12px #00000040}@keyframes scaleIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.achievement-icon{margin:0 auto 1.5rem;animation:bounce .6s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.achievement-content h2{font-size:2rem;font-weight:800;color:var(--color-text-primary);margin:0 0 .75rem}.achievement-content p{font-size:1.125rem;color:var(--color-text-secondary);margin:0}@media (max-width: 1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width: 768px){.projects-page{padding:1rem}.projects-header{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:2rem}.header-title h1{font-size:1.75rem;margin-bottom:.375rem}.subtitle{font-size:.875rem}.btn-add-project{width:100%;justify-content:center;padding:.875rem 1.5rem}.projects-content{gap:2rem}.projects-section{gap:1.25rem}.section-title{font-size:1.125rem}.projects-grid{grid-template-columns:1fr;gap:1.25rem}.project-card{padding:1.25rem}.project-name{font-size:1.125rem}.project-description{font-size:.875rem}.detail-section h4{font-size:.6875rem}.detail-text{font-size:.8125rem}.btn-achieve{padding:.875rem 1rem;font-size:.8125rem}.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-width:100%;width:100%;margin:0;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92vh;animation:slideUpMobile .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.project-modal{padding:1.5rem;padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}.modal-header{margin-bottom:1.5rem}.modal-header h3{font-size:1.25rem}.form-group{margin-bottom:1.25rem}.form-group label{font-size:.8125rem;margin-bottom:.375rem}.form-group input,.form-group textarea{font-size:.875rem;padding:.625rem .875rem}.modal-actions{flex-direction:column-reverse;gap:.75rem;margin-top:1.5rem}.btn-cancel,.btn-save{width:100%;justify-content:center;padding:.875rem 1rem}.achievement-content{padding:2rem 1.5rem;margin:0 1rem}.achievement-content h2{font-size:1.5rem}.achievement-content p{font-size:1rem}.achievement-icon svg{width:60px;height:60px}.empty-state{padding:4rem 1.5rem}.empty-icon{margin-bottom:1.25rem}.empty-state h3{font-size:1.25rem;margin-bottom:.625rem}.empty-state p{font-size:.9375rem;margin-bottom:0;line-height:1.6}.achievement-badge{top:-10px;right:15px}.achievement-badge svg{width:20px;height:20px}.achieved-date{font-size:.8125rem}.project-actions{gap:.375rem}.btn-icon{padding:.5rem}}.vision-board-page{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto;min-height:100vh}.vision-board-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.5rem;gap:1rem}.header-title h1{font-size:2rem;font-weight:800;color:var(--color-text-primary);margin:0 0 .5rem}.subtitle{color:var(--color-text-secondary);font-size:1rem;margin:0}.btn-add-vision{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--color-accent-blue);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #3b82f633}.btn-add-vision:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.vision-board-content{display:flex;flex-direction:column}.visions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.vision-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all .3s;cursor:pointer;display:flex;flex-direction:column}.vision-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:var(--color-accent-blue)}.vision-image{position:relative;width:100%;padding-top:66.67%;overflow:hidden;background:#f3f4f6}.vision-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.vision-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;gap:1rem;opacity:0;transition:opacity .3s}.vision-card:hover .vision-overlay{opacity:1}.btn-icon-hover{background:#fff;border:none;padding:.75rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--color-text-primary)}.btn-icon-hover:hover{background:var(--color-accent-blue);color:#fff;transform:scale(1.1)}.btn-icon-hover.delete:hover{background:#ef4444}.vision-content{padding:1.5rem;flex:1}.vision-title{font-size:1.125rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .5rem;line-height:1.4}.vision-description{color:var(--color-text-secondary);font-size:.875rem;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out;padding:1rem}.modal-content{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.vision-modal{padding:2rem}.vision-view-modal{max-width:800px;padding:0}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.modal-header h3{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.btn-close{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-close:hover{color:var(--color-text-primary);background-color:var(--color-bg-hover)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:.9375rem;transition:all .2s;background-color:#fff;font-family:inherit;color:var(--color-text-primary)}.form-group textarea{resize:vertical;min-height:80px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 3px #3b82f61a}.image-preview{margin-top:1rem;border-radius:var(--radius-lg);overflow:hidden;max-height:300px}.image-preview img{width:100%;height:auto;display:block}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.btn-cancel{padding:.75rem 1.5rem;border:1px solid var(--color-border);background:#fff;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-save{padding:.75rem 1.5rem;background:var(--color-accent-blue);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-save:hover{background:#2563eb}.btn-save:disabled{opacity:.5;cursor:not-allowed}.vision-view-image{width:100%;max-height:500px;overflow:hidden;background:#f3f4f6}.vision-view-image img{width:100%;height:auto;display:block}.vision-view-content{padding:2rem}.vision-view-content h2{font-size:1.75rem;font-weight:800;color:var(--color-text-primary);margin:0 0 1rem}.vision-view-description{color:var(--color-text-secondary);font-size:1rem;line-height:1.8;margin:0 0 2rem;white-space:pre-line}.vision-view-actions{display:flex;gap:1rem}.btn-edit,.btn-delete{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:none}.btn-edit{background:var(--color-accent-blue);color:#fff}.btn-edit:hover{background:#2563eb}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#ef4444;color:#fff}.empty-icon{color:var(--color-text-tertiary);margin-bottom:1.5rem;opacity:.5}.empty-state h3{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .75rem}.empty-state p{font-size:1rem;color:var(--color-text-secondary);margin:0;max-width:500px;line-height:1.6}.loading-container{display:flex;justify-content:center;align-items:center;min-height:60vh}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 1024px){.visions-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width: 768px){.vision-board-page{padding:1rem}.vision-board-header{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:2rem}.header-title h1{font-size:1.75rem;margin-bottom:.375rem}.subtitle{font-size:.875rem}.btn-add-vision{width:100%;justify-content:center;padding:.875rem 1.5rem}.visions-grid{grid-template-columns:1fr;gap:1.25rem}.vision-content{padding:1.25rem}.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-width:100%;width:100%;margin:0;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92vh;animation:slideUpMobile .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.vision-modal{padding:1.5rem;padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}.vision-view-modal{max-width:100%}.vision-view-content{padding:1.5rem}.vision-view-content h2{font-size:1.5rem}.modal-header{margin-bottom:1.5rem}.modal-header h3{font-size:1.25rem}.form-group{margin-bottom:1.25rem}.form-group label{font-size:.8125rem;margin-bottom:.375rem}.form-group input,.form-group textarea{font-size:.875rem;padding:.625rem .875rem}.modal-actions{flex-direction:column-reverse;gap:.75rem;margin-top:1.5rem}.btn-cancel,.btn-save{width:100%;justify-content:center;padding:.875rem 1rem}.vision-view-actions{flex-direction:column}.btn-edit,.btn-delete{width:100%;justify-content:center}.empty-state{padding:4rem 1.5rem}.empty-state h3{font-size:1.25rem}.empty-state p{font-size:.9375rem}}.today-page{padding:2rem;max-width:1200px;margin:0 auto}.today-header{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.today-title-section h1{font-size:2.25rem;font-weight:800;margin:0 0 .25rem;color:var(--color-text-primary)}.today-date{font-size:.9375rem;color:var(--color-text-secondary);margin:0}.today-stats-card{display:flex;align-items:center;gap:1.5rem;background:#fff;padding:1.25rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid var(--color-border)}.stats-circle{position:relative;width:80px;height:80px}.stats-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.stats-info{display:flex;flex-direction:column;gap:.25rem}.stats-label{font-size:.875rem;color:var(--color-text-secondary);font-weight:500}.stats-count{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.today-filters{display:flex;gap:0;margin-bottom:1.5rem;background:#fff;border-radius:.5rem;padding:.25rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid var(--color-border)}.filter-btn{flex:1;padding:.625rem 1rem;border:none;background:transparent;color:var(--color-text-secondary);border-radius:.375rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.filter-btn:hover{color:var(--color-text-primary);background:#00000008}.filter-btn.active{background:var(--color-bg-primary);color:var(--color-text-primary);box-shadow:0 1px 2px #0000000d}.today-content{display:flex;flex-direction:column;gap:2rem}.today-section{background:#fff;border-radius:1rem;padding:1.25rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;border:1px solid var(--color-border)}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;margin:0 0 1rem;color:var(--color-text-primary)}.section-title svg{color:var(--primary-color)}.today-items{display:flex;flex-direction:column;gap:1rem}.today-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all .2s ease}.today-item:hover{box-shadow:0 2px 8px #0000000d}.today-item.completed{border-color:transparent;box-shadow:none}.item-checkbox-wrapper{flex-shrink:0}.item-checkbox{position:absolute;opacity:0;width:0;height:0}.custom-checkbox{width:24px;height:24px;border:2px solid var(--color-border);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff;cursor:pointer}.item-checkbox:checked+.custom-checkbox{background-color:var(--color-accent-blue);border-color:var(--color-accent-blue)}.custom-checkbox:hover{border-color:var(--color-accent-blue)}.custom-checkbox svg{width:14px;height:14px;stroke:#fff;stroke-width:3;opacity:0;transition:opacity .2s}.item-checkbox:checked+.custom-checkbox svg{opacity:1}.item-content{flex:1;min-width:0}.item-title{font-size:1rem;font-weight:500;color:var(--color-text-primary);margin-bottom:.25rem;transition:color .2s}.today-item.completed .item-title{color:var(--color-text-tertiary);text-decoration:line-through}.item-streak{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;background-color:#fff7ed;border-radius:6px;font-size:.75rem;font-weight:700;color:#c2410c}.item-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.25rem}.item-goal{font-size:.75rem;color:var(--color-text-tertiary);font-weight:500}.item-overdue{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;background-color:#fee2e2;border-radius:6px;font-size:.75rem;font-weight:700;color:#991b1b}.item-type-badge{flex-shrink:0;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.habit-badge{background:#dbeafe;color:#1e40af}.goal-badge{background:#fce7f3;color:#be185d}.goal-badge.goal-yearly{background:#fef3c7;color:#b45309}.goal-badge.goal-monthly{background:#d1fae5;color:#065f46}.goal-badge.goal-weekly{background:#dbeafe;color:#1e40af}.goal-badge.goal-daily{background:#fce7f3;color:#be185d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-state svg{color:var(--color-text-secondary);opacity:.5;margin-bottom:1.5rem}.empty-state h3{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:var(--color-text-primary)}.empty-state p{font-size:1rem;color:var(--color-text-secondary);margin:0;max-width:400px}.loading{display:flex;justify-content:center;align-items:center;padding:4rem;font-size:1.125rem;color:var(--color-text-secondary)}@media (max-width: 768px){.today-page{padding:1rem}.today-header{gap:1rem}.today-title-section h1{font-size:1.75rem}.today-stats-card{width:100%;padding:1rem 1.25rem}.stats-circle{width:70px;height:70px}.stats-circle svg{width:70px;height:70px}.stats-percentage{font-size:1.125rem}.stats-count{font-size:1.25rem}.today-filters{gap:0;padding:3px}.filter-btn{padding:.5rem .75rem;font-size:.8125rem}.today-section{padding:1rem}.section-title{font-size:1rem}.today-item{gap:.625rem;padding:.875rem}.item-type-badge{font-size:.625rem;padding:.25rem .5rem}.item-title{font-size:.9375rem}.empty-state{padding:3rem 1rem}.empty-state svg{width:48px;height:48px}.empty-state h3{font-size:1.25rem}.empty-state p{font-size:.875rem}}@media (max-width: 480px){.today-title-section h1{font-size:1.75rem}.today-date{font-size:.875rem}.stats-circle{width:60px;height:60px}.stats-circle svg{width:60px;height:60px}.stats-percentage{font-size:1rem}.stats-label{font-size:.8125rem}.stats-count{font-size:1.125rem}.filter-btn{font-size:.75rem;padding:.5rem}}.app{display:flex;min-height:100vh;background-color:var(--color-bg-primary)}.top-navbar{position:fixed;top:0;left:0;right:0;height:64px;z-index:1100;display:none;align-items:center;padding:0 1rem;pointer-events:none}.top-navbar>*{pointer-events:auto}.sidebar{width:240px;background-color:var(--color-bg-card);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border)}.user-profile{display:flex;align-items:center;gap:var(--spacing-md)}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:var(--font-size-sm);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-weight:600;color:var(--color-text-primary);font-size:var(--font-size-sm);line-height:1.2;margin-bottom:2px}.user-email{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav{flex:1;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);text-decoration:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);cursor:pointer}.nav-item:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background-color:#3b82f61a;color:var(--color-accent-blue)}.nav-item svg{flex-shrink:0}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing-xs)}.new-goal-btn{width:100%;justify-content:center;margin-bottom:var(--spacing-sm);padding:var(--spacing-md);font-weight:600}.main-content{flex:1;overflow-y:auto;background-color:var(--color-bg-primary)}.page-placeholder{display:flex;align-items:center;justify-content:center;min-height:60vh;font-size:var(--font-size-xl);color:var(--color-text-secondary)}@media (max-width: 768px){.top-navbar{display:flex}.sidebar{position:fixed;left:-240px;top:0;bottom:0;z-index:1000;transition:left var(--transition-normal)}.sidebar-header{padding-top:calc(var(--spacing-xl) + 48px)}.sidebar.open{left:0}.main-content{width:100%;padding-top:64px}.app.sidebar-open:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hamburger-menu{position:relative;background:var(--color-bg-card);border:none;border-radius:var(--radius-lg);padding:10px;width:44px;height:44px;box-shadow:var(--shadow-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal)}.hamburger{display:flex;flex-direction:column;gap:5px;width:24px;height:24px;justify-content:center}.hamburger span{display:block;height:3px;width:100%;background:var(--color-text-primary);border-radius:2px;transition:all .3s}.hamburger.active span:nth-child(1){transform:translateY(9px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}}:root{--color-bg-primary: #1a1a2e;--color-bg-secondary: #16213e;--color-bg-tertiary: #0f3460;--color-bg-card: #1e2a47;--color-bg-hover: #2a3a5f;--color-text-primary: #ffffff;--color-text-secondary: #a0a0b8;--color-text-muted: #6b7280;--color-accent-blue: #3b82f6;--color-accent-blue-hover: #2563eb;--color-accent-green: #10b981;--color-accent-purple: #8b5cf6;--color-accent-orange: #f59e0b;--color-accent-red: #ef4444;--color-border: #2d3748;--color-border-light: #374151;--color-priority-high: #ef4444;--color-priority-medium: #f59e0b;--color-priority-low: #6b7280;--color-financial: #10b981;--color-spiritual: #8b5cf6;--color-health: #ef4444;--color-fitness: #3b82f6;--color-education: #f59e0b;--color-text-tertiary: #6b7280;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4);--transition-fast: .15s ease-in-out;--transition-normal: .25s ease-in-out;--transition-slow: .35s ease-in-out;--font-family-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem}[data-theme=light]{--color-bg-primary: #f8fafc;--color-bg-secondary: #ffffff;--color-bg-tertiary: #e2e8f0;--color-bg-card: #ffffff;--color-bg-hover: #f1f5f9;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-text-tertiary: #94a3b8;--color-border: #e2e8f0;--color-border-light: #cbd5e1;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family-base);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal),color var(--transition-normal)}*{transition:background-color var(--transition-normal),border-color var(--transition-normal),color var(--transition-normal)}.container{max-width:1280px;margin:0 auto;padding:0 var(--spacing-lg)}.card{background-color:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);border:none;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-base);font-family:var(--font-family-base)}.btn-primary{background-color:var(--color-accent-blue);color:#fff}.btn-primary:hover{background-color:var(--color-accent-blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-md);color:#fff}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);font-family:var(--font-family-base);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 3px #3b82f61a}.input::placeholder{color:var(--color-text-muted)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-bg-hover)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.fade-in{animation:fadeIn var(--transition-normal)}.slide-in{animation:slideIn var(--transition-normal)}
