html{font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1e293b;background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}#root{min-height:100vh}*,:before,:after{box-sizing:border-box}button{font:inherit;cursor:pointer;background:0 0;border:none;margin:0;padding:0}input,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{margin:0}img{max-width:100%;height:auto}:focus-visible{outline-offset:2px;outline:2px solid #3b82f6}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#3b82f6;--primary-hover:#2563eb;--secondary-color:#64748b;--success-color:#10b981;--warning-color:#f59e0b;--danger-color:#ef4444;--background-color:#f8fafc;--surface-color:#fff;--text-primary:#1e293b;--text-secondary:#64748b;--border-color:#e2e8f0;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--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}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.app{flex-direction:column;min-height:100vh;display:flex}.header{background:var(--surface-color);border-bottom:1px solid var(--border-color);padding:var(--spacing-md);box-shadow:var(--shadow);z-index:100;position:sticky;top:0}.header-content{gap:var(--spacing-md);flex-direction:column;max-width:1200px;margin:0 auto;display:flex}.header-top{justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.logo{font-size:var(--font-size-2xl);color:var(--primary-color);font-weight:700;text-decoration:none}.add-task-btn{background:var(--primary-color);color:#fff;padding:var(--spacing-sm)var(--spacing-lg);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;align-items:center;gap:var(--spacing-sm);border:none;font-weight:500;transition:all .2s;display:flex}.add-task-btn:hover{background:var(--primary-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.header-controls{gap:var(--spacing-md);flex-direction:column;width:100%;display:flex}.search-bar{flex:1;position:relative}.search-input{width:100%;padding:var(--spacing-sm)var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--surface-color);padding-left:2.5rem;transition:border-color .2s}.search-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #3b82f61a}.search-icon{left:var(--spacing-sm);color:var(--text-secondary);width:1rem;height:1rem;position:absolute;top:50%;transform:translateY(-50%)}.category-filter{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.category-btn{padding:var(--spacing-xs)var(--spacing-md);border:1px solid var(--border-color);background:var(--surface-color);color:var(--text-secondary);border-radius:var(--radius-md);font-size:var(--font-size-xs);cursor:pointer;transition:all .2s}.category-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.category-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.category-btn.no-tasks{opacity:.5;cursor:not-allowed}.category-btn.no-tasks:hover{border-color:var(--border-color);color:var(--text-secondary)}.main-content{max-width:1200px;padding:var(--spacing-lg);flex:1;width:100%;margin:0 auto}.view-mode-toggle{justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex}.toggle-btn{padding:var(--spacing-sm)var(--spacing-lg);border:2px solid var(--border-color);background:var(--surface-color);color:var(--text-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;align-items:center;gap:var(--spacing-xs);font-weight:500;transition:all .2s;display:flex}.toggle-btn:hover{border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.toggle-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:var(--shadow)}.stats-panel{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.filter-status{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow)}.filter-status h3{margin:0 0 var(--spacing-sm)0;color:var(--text-primary);font-size:var(--font-size-lg);font-weight:600}.filter-status p{color:var(--text-secondary);font-size:var(--font-size-sm);margin:0;font-style:italic}.stat-card{background:var(--surface-color);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow);text-align:center;border:1px solid var(--border-color)}.stat-number{font-size:var(--font-size-3xl);color:var(--primary-color);margin-bottom:var(--spacing-xs);font-weight:700}.stat-label{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500}.task-list{gap:var(--spacing-md);flex-direction:column;display:flex}.task-card{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow);transition:all .2s}.task-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.task-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);display:flex}.task-title{font-size:var(--font-size-lg);color:var(--text-primary);margin-bottom:var(--spacing-xs);font-weight:600}.task-category{padding:var(--spacing-xs)var(--spacing-sm);background:var(--primary-color);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;display:inline-block}.task-description{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md);line-height:1.5}.task-details{gap:var(--spacing-md);margin-bottom:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));display:grid}.task-detail{gap:var(--spacing-xs);flex-direction:column;display:flex}.task-detail-label{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.task-detail-value{font-size:var(--font-size-sm);color:var(--text-primary)}.task-actions{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.btn{padding:var(--spacing-xs)var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer;align-items:center;gap:var(--spacing-xs);font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-primary:hover{background:var(--primary-hover)}.btn-success{background:var(--success-color);color:#fff;border-color:var(--success-color)}.btn-warning{background:var(--warning-color);color:#fff;border-color:var(--warning-color)}.btn-danger{background:var(--danger-color);color:#fff;border-color:var(--danger-color)}.btn-secondary{background:var(--surface-color);color:var(--text-secondary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--background-color);color:var(--text-primary)}.status-badge{padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.status-pending{color:#92400e;background:#fef3c7}.status-in-progress{color:#1e40af;background:#dbeafe}.status-completed{color:#065f46;background:#d1fae5}.modal-overlay{z-index:1000;padding:var(--spacing-md);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-xl);color:var(--text-primary);font-weight:600}.modal-close{font-size:var(--font-size-xl);cursor:pointer;color:var(--text-secondary);padding:var(--spacing-xs);border-radius:var(--radius-sm);background:0 0;border:none}.modal-close:hover{background:var(--background-color);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{font-size:var(--font-size-sm);color:var(--text-primary);margin-bottom:var(--spacing-xs);font-weight:500;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm)var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--surface-color);transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;min-height:80px}.form-actions{gap:var(--spacing-md);margin-top:var(--spacing-xl);justify-content:flex-end;display:flex}@media (min-width:768px){.header-controls{flex-direction:row;align-items:center}.search-bar{max-width:300px}.task-details{grid-template-columns:repeat(3,1fr)}.stats-panel{grid-template-columns:repeat(4,1fr)}}@media (min-width:1024px){.main-content{padding:var(--spacing-2xl)}.task-details{grid-template-columns:repeat(4,1fr)}}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.empty-state-icon{margin-bottom:var(--spacing-md);opacity:.5;font-size:3rem}.loading{padding:var(--spacing-2xl);justify-content:center;align-items:center;display:flex}.spinner{border:2px solid var(--border-color);border-top:2px solid var(--primary-color);border-radius:50%;width:2rem;height:2rem;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.task-hierarchy{max-width:1200px;padding:var(--spacing-lg);margin:0 auto}.hierarchy-title{font-size:var(--font-size-2xl);color:var(--text-primary);margin-bottom:var(--spacing-xl);text-align:center;border-bottom:2px solid var(--primary-color);padding-bottom:var(--spacing-md);font-weight:700}.category-section{margin-bottom:var(--spacing-xl);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.category-header{background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;padding:var(--spacing-lg);cursor:pointer;align-items:center;gap:var(--spacing-md);transition:all .2s;display:flex}.category-header:hover{background:linear-gradient(135deg,var(--primary-hover),var(--primary-color))}.category-icon{font-size:var(--font-size-xl)}.category-title{font-size:var(--font-size-xl);flex:1;margin:0;font-weight:600}.category-progress{align-items:flex-end;gap:var(--spacing-xs);flex-direction:column;display:flex}.progress-percentage{color:var(--primary-color);padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-lg);text-align:center;background:#ffffffe6;min-width:50px;font-weight:700}.task-count{padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:#fff3;font-weight:500}.tasks-container{background:var(--surface-color);padding:var(--spacing-md)}.task-section{margin-bottom:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.task-header{background:var(--background-color);padding:var(--spacing-md);cursor:pointer;align-items:center;gap:var(--spacing-sm);transition:background-color .2s;display:flex}.task-icon{font-size:var(--font-size-lg);min-width:1.5rem}.task-title{font-size:var(--font-size-base);color:var(--text-primary);flex:1;margin:0;font-weight:500}.subtask-count{background:var(--secondary-color);color:#fff;padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500}.subtasks-container{background:var(--surface-color);padding:var(--spacing-md);border-top:1px solid var(--border-color)}.subtask-item{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)0;border-bottom:1px solid #f1f5f9;display:flex}.subtask-icon{color:var(--primary-color);min-width:1rem;font-weight:700}.subtask-title{font-size:var(--font-size-sm);color:var(--text-secondary);flex:1}.status-badge{padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;text-align:center;color:#fff;min-width:60px;font-weight:600}.task-actions,.subtask-actions{gap:var(--spacing-xs);margin-left:var(--spacing-sm);display:flex}.status-btn{cursor:pointer;opacity:.7;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;transition:all .2s;display:flex}.status-btn:hover{opacity:1;transform:scale(1.1);box-shadow:0 2px 4px #0003}.status-btn.pending{color:#fff;background:#ef4444}.status-btn.in-progress{color:#fff;background:#f59e0b}.status-btn.completed{color:#fff;background:#10b981}.subtask-item{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)0;border-bottom:1px solid #f1f5f9;display:flex;position:relative}.subtask-item:last-child{border-bottom:none}.subtask-actions{margin-left:auto}.task-header{background:var(--background-color);padding:var(--spacing-md);cursor:pointer;align-items:center;gap:var(--spacing-sm);transition:background-color .2s;display:flex;position:relative}.task-header:hover{background:#f1f5f9}.task-header .task-actions{opacity:0;margin-left:auto;transition:opacity .2s}.task-header:hover .task-actions{opacity:1}@media (max-width:768px){.category-header{padding:var(--spacing-md);flex-wrap:wrap}.category-title{font-size:var(--font-size-lg)}.task-header{padding:var(--spacing-sm);flex-wrap:wrap}.task-title{font-size:var(--font-size-sm)}.subtasks-container{padding:var(--spacing-sm)}.task-actions,.subtask-actions{margin-left:0;margin-top:var(--spacing-xs);flex-wrap:wrap}.status-btn{width:24px;height:24px;font-size:10px}.task-header .task-actions{opacity:1}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}
