.landing-container{text-align:center;padding:2rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.landing-title{font-size:2.5rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.landing-subtitle{font-size:1.25rem;color:#4b5563;margin-bottom:2.5rem}.landing-actions{display:flex;justify-content:center;gap:1.5rem}.button{display:inline-block;padding:.75rem 2rem;border-radius:.5rem;font-weight:600;text-decoration:none;box-shadow:0 4px 6px #0000001a;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.button-primary{background-color:#007bff;color:#fff}.button-primary:hover{background-color:#0056b3}.button-secondary{background-color:#6c757d;color:#fff}.button-secondary:hover{background-color:#5a6268}.auth-container{max-width:400px;margin:0 auto;padding:3rem;background-color:#fff;border-radius:.75rem;box-shadow:0 8px 16px #0000001a;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.auth-title{margin-bottom:1.5rem;font-size:1.75rem;text-align:center;color:#333;font-weight:700}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#555}.form-group input{width:100%;padding:.625rem;border:1px solid #ccc;border-radius:.5rem;transition:border-color .2s}.form-group input:focus{border-color:#4a90e2;outline:none}.submit-button{width:100%;padding:.75rem;background-color:#22c55e;color:#fff;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.login-button{background-color:#007bff}.login-button:hover{background-color:#0056b3}.register-button{background-color:#28a745}.register-button:hover{background-color:#218838}.error-message{color:#dc2626;font-size:.875rem;text-align:center}.success-message{color:#16a34a;font-size:.875rem;text-align:center}.form-footer{margin-top:1.25rem;text-align:center;color:#666}.form-footer a{color:#4a90e2;text-decoration:none}.form-footer a:hover{text-decoration:underline}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:2rem;border-radius:12px;box-shadow:0 5px 15px #0000004d;width:100%;max-width:500px;animation:slideIn .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;padding-bottom:1rem;margin-bottom:1.5rem}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.close-button{background:none;border:none;font-size:2rem;cursor:pointer;color:#888;line-height:1}.creation-form{display:flex;flex-direction:column;gap:1.25rem}.form-group input,.form-group select{width:100%;padding:.75rem 1rem;border:1px solid #ccc;border-radius:8px;transition:border-color .2s;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group select:focus{border-color:#007bff;outline:none;box-shadow:0 0 0 2px #007bff40}.form-group input[type=color]{padding:.25rem;height:40px;width:60px;border-radius:6px;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.button-cancel,.button-submit{padding:.6rem 1.5rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .2s}.button-cancel{background-color:#f0f0f0;color:#555;border:1px solid #ccc}.button-cancel:hover{background-color:#e0e0e0}.button-submit{background-color:#007bff;color:#fff}.button-submit:hover{background-color:#0056b3}.button-submit:disabled{background-color:#a0c7ff;cursor:not-allowed}@keyframes slideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.dashboard-layout{width:100%;height:100vh;display:flex;flex-direction:column;background-color:#f7f9fc;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding-left:1%;padding-right:1%;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;flex-shrink:0}.dashboard-main-content{display:flex;flex-grow:1;overflow:hidden}.account-button{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;background-color:#007bff;transition:background-color .2s;color:#fff;text-decoration:none;display:inline-block}.account-button:hover{background-color:#155d9c}.logout-button{padding:.5rem 1rem;background-color:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.logout-button:hover{background-color:#c82333}.sidebar{width:300px;background-color:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column}.sidebar-header{display:flex;justify-content:space-between;align-items:center;flex-shrink:0;border-bottom:1px solid #e9ecef;padding-left:1.5rem;padding-right:1.5rem}.sidebar-title{font-size:1.1rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:1px}.sidebar-content{flex-grow:1;overflow-y:auto;padding:1rem;list-style:none;margin:0}.sidebar-footer{margin-top:auto;padding:1rem;border-top:1px solid #e9ecef;flex-shrink:0}.archive-toggle{display:flex;align-items:center;cursor:pointer;font-size:.9rem;color:#000;font-weight:500;margin-left:5px}.archive-toggle input{opacity:0;width:0;height:0}.slider{position:relative;display:inline-block;width:40px;height:22px;background-color:#ccc;border-radius:22px;transition:background-color .2s}.slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:transform .2s}.archive-toggle input:checked+.slider{background-color:#28a745}.archive-toggle input:checked+.slider:before{transform:translate(18px)}.toggle-label{margin-left:.75rem}.add-button{background-color:#007bff;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:1.5rem;cursor:pointer;transition:background-color .2s,transform .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding-bottom:5px}.course-list-item{display:flex;justify-content:space-between;align-items:center;padding:10px;margin-bottom:.5rem;border-radius:8px;cursor:pointer;transition:background-color .2s}.course-info{display:flex;align-items:center;gap:12px;font-weight:500;color:#444;flex-grow:1;min-width:0}.course-name-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-color-tag{width:12px;height:12px;border-radius:50%;margin-right:12px;flex-shrink:0}.all-tasks-icon{background-color:#000}.course-actions{display:flex;align-items:center;gap:.5rem;opacity:0;transition:opacity .2s ease-in-out}.course-list-item:hover{background-color:#f0f4f8}.course-list-item.active{background-color:#007bff;color:#fff;font-weight:600}.course-list-item.active .course-info{color:#fff}.course-list-item:hover .course-actions{opacity:1}.action-button{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;border-radius:4px}.action-button:hover{background-color:#0000001a}.course-list-item.active .action-button:hover{background-color:#fff3}.task-area{flex-grow:1;display:flex;flex-direction:column;overflow:auto}.reminders-container{padding:1rem 2rem 0;display:flex;flex-direction:column;flex-shrink:0;gap:1rem}.reminder-section{padding:1rem 1.5rem;border-radius:8px;border-left-width:5px;box-shadow:0 2px 8px #0000000f;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.reminder-content{display:flex;align-items:flex-start;gap:1rem}.reminder-content:before{font-family:Segoe UI Symbol,sans-serif;font-size:1.5rem;line-height:1.2;font-weight:700}.reminder-section.overdue{background-color:#fff5f5;border-color:#e53e3e}.reminder-section.overdue .reminder-content:before{content:"❗";color:#c53030}.reminder-section.due-soon{background-color:ivory;border-color:#dd6b20}.reminder-section.due-soon .reminder-content:before{content:"🕒";color:#b7791f}.reminder-title{margin:0 0 .25rem;font-weight:700;font-size:1rem}.reminder-section.overdue .reminder-title{color:#c53030}.reminder-section.due-soon .reminder-title{color:#b7791f}.reminder-section ul{list-style:none;padding-left:0;margin:0;font-size:.9rem;color:#4a5568}.reminder-section li{padding:.1rem 0}.reminder-dismiss-button{background:none;border:none;font-size:1.5rem;color:#aaa;cursor:pointer;padding:0;line-height:1;transition:color .2s}.reminder-dismiss-button:hover{color:#333}.task-list-container{flex-grow:1;padding:0 2rem 2rem;display:flex;flex-direction:column}.task-list-main-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.task-list-main-header h2{font-size:1.75rem;font-weight:700;color:#333}.task-list-main-header .add-button{border-radius:8px;width:auto;height:auto;padding:.5rem 1rem;font-size:.9rem;font-weight:600}.task-list-column-headers{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr 80px;gap:1rem;padding:0 1rem .5rem;border-bottom:2px solid #e0e0e0;margin-bottom:1rem;flex-shrink:0}.task-list-column-headers h3{font-size:.875rem;font-weight:600;color:#666;text-transform:uppercase}.sortable-header{background:none;border:none;padding:0;font-family:inherit;font-size:.875rem;font-weight:600;color:#666;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;gap:.5rem;text-align:left}.sortable-header:hover{color:#007bff}.sort-icon{font-size:.7rem;line-height:1}.task-list{position:relative}.task-item{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr 80px;gap:1rem;align-items:center;background-color:#fff;padding:.75rem 1rem;border-radius:8px;margin-bottom:.75rem;box-shadow:0 1px 3px #00000014}.task-item.completed{text-decoration:line-through;color:#888;opacity:0;max-height:0;padding-top:0;padding-bottom:0;margin-bottom:0;overflow:hidden;border:none;box-shadow:none}.completed-text{text-decoration:line-through;color:#888}.task-main-info{display:flex;align-items:center;gap:1rem}.task-checkbox{width:18px;height:18px;cursor:pointer}.task-title{font-weight:600;color:#333;transition:color .2s}.task-item.completed .task-title{text-decoration:line-through;color:#888}.task-item.completed{background-color:#f9fafb}.task-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;opacity:0;transition:opacity .2s ease-in-out}.task-item:hover .task-actions{opacity:1}.task-item-animation-exit{opacity:1;max-height:100px;transform:scale(1)}.task-item-animation-exit-active{opacity:0;max-height:0;padding-top:0;padding-bottom:0;margin-bottom:0;transform:scale(.95);transition:all .5s ease-in-out}.task-priority{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-align:center;width:fit-content}.priority-high{background-color:#fde2e2;color:#c53030}.priority-medium{background-color:#fefcbf;color:#b7791f}.priority-low{background-color:#e6fffa;color:#2c7a7b}.account-settings-container{width:100%;max-width:700px;margin:2rem auto;padding:2rem;background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.account-settings-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;padding-bottom:1rem;margin-bottom:2rem}.account-settings-header h1{font-size:1.75rem;font-weight:700;color:#333;margin:0}.back-link{font-size:.9rem;color:#007bff;text-decoration:none;font-weight:500}.back-link:hover{text-decoration:underline}.settings-section{margin-bottom:2.5rem}.settings-section h2{font-size:1.25rem;font-weight:600;color:#444;margin-bottom:.5rem}.settings-section p{font-size:.9rem;color:#666;margin-bottom:1.5rem}.settings-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:600;color:#555;font-size:.875rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid #ccc;border-radius:8px;transition:border-color .2s;font-size:1rem}.form-group input:focus{border-color:#4a90e2;outline:none;box-shadow:0 0 0 2px #4a90e233}.submit-button{align-self:flex-start;padding:.6rem 1.5rem;background-color:#007bff;color:#fff;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.submit-button:hover{background-color:#0056b3}.message{padding:.75rem;border-radius:6px;font-size:.9rem;text-align:center}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;width:100%}#root{height:100%;width:100%}input,button,textarea,select{font-family:inherit}
