*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;color:#333;background:#f5f7fa;line-height:1.5;min-width:390px}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{height:60px;background-color:#474747;flex-shrink:0}.app-header__content{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;padding:0 24px}.app-main{flex:1;display:flex;flex-direction:column}.app-main>*{flex:1}.app-footer{height:270px;background-color:#474747;flex-shrink:0}.app-footer__content{max-width:1200px;margin:0 auto;height:100%;padding:24px}.visually-hidden{display:none}.login-page{min-height:100%;display:flex;align-items:center;justify-content:center;background:#545454;padding:20px}.login-container{width:100%;max-width:448px}.login-card{display:flex;flex-direction:column;width:448px;min-height:300px;background:#c3c3c3;border-radius:5px;padding-bottom:30px;gap:16px}@media (max-width: 480px){.login-card{width:100%;padding:24px}}.login-card-header{display:flex;justify-content:center;align-items:center;height:50px;background:#a5a5a5}.login-title{font-size:17px;font-weight:400;line-height:1.5;color:#5f5f5f}.form-description{font-size:15px;line-height:1.5;margin-bottom:14px}.login-form{display:flex;flex-direction:column;padding-inline:24px}.form-groups{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#555}.form-input{padding:14px 16px;font-size:16px;border:none;border-radius:4px;outline:none;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.form-input.error{border-color:#e74c3c}.form-input::placeholder{color:#353535;background:#fff}.error-message{font-size:12px;color:#e74c3c}.login-error{margin-top:16px;background:#ffeaea;color:#e74c3c;padding:12px 16px;border-radius:8px;font-size:14px;text-align:center}.login-button{min-height:40px;padding:10px 30px;font-size:16px;font-weight:600;color:#fff;background:#519945;border:none;border-radius:4px;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:26px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.todos-page{min-height:100%;background:#f5f7fa}.header{background:#545454;color:#fff;padding:24px}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;gap:20px}@media (max-width: 768px){.header-content{flex-direction:column}}.user-info{display:flex;gap:16px;align-items:flex-start}@media (max-width: 768px){.user-info{flex-direction:column;align-items:center;text-align:center;width:100%}}.user-avatar{width:60px;height:60px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0}.user-details .user-name{font-size:22px;font-weight:700;margin:0 0 8px}.user-details .user-meta{font-size:14px;opacity:.9;margin:4px 0}.user-details .user-meta .separator{margin:0 8px;opacity:.5}.logout-button{padding:10px 20px;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;flex-shrink:0}.logout-button:hover{background:#ffffff4d}@media (max-width: 768px){.logout-button{align-self:flex-end}}.main-content{max-width:1200px;margin:0 auto;padding:24px}.section-title{font-size:18px;font-weight:700;color:#333;margin:0 0 16px}.section-title .todos-count{font-weight:400;color:#888}.create-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px}.create-form{display:flex;gap:12px;flex-wrap:wrap}@media (max-width: 768px){.create-form{flex-direction:column}}.create-input{padding:12px 16px;font-size:14px;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .2s}.create-input:focus{border-color:#667eea}.create-input::placeholder{color:#353535}.create-input.user-id-input{width:100px}@media (max-width: 768px){.create-input.user-id-input{width:100%}}.create-input.title-input{flex:1;min-width:200px}.add-button{padding:12px 24px;font-size:14px;font-weight:600;color:#fff;background:#545454;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.add-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #667eea66}.add-button:disabled{opacity:.6;cursor:not-allowed}.filters-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px}.filters-row{display:flex;gap:20px;flex-wrap:wrap;align-items:flex-end}@media (max-width: 768px){.filters-row{flex-direction:column}}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px}.filter-group.search-group{flex:1;min-width:200px}@media (max-width: 768px){.filter-group.search-group{width:100%}}@media (max-width: 768px){.filter-group{width:100%}}.filter-select{padding:12px 16px;font-size:14px;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .2s}.filter-select:focus{border-color:#667eea}.filter-select::placeholder{color:#353535}.filter-select{background:#fff;cursor:pointer;min-width:140px}@media (max-width: 768px){.filter-select{width:100%}}.search-input{padding:12px 16px;font-size:14px;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .2s}.search-input:focus{border-color:#667eea}.search-input::placeholder{color:#353535}.search-input{width:100%}.todos-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f}.loading,.error,.empty{text-align:center;padding:40px;color:#888;font-size:16px}.error{color:#e74c3c}.todos-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}.todo-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f9fafb;border-radius:10px;transition:transform .2s,box-shadow .2s}.todo-item:hover{transform:translate(4px);box-shadow:0 2px 8px #00000014}.todo-item.completed .todo-title{text-decoration:line-through;color:#888}.todo-status{flex-shrink:0}.status-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#e0e0e0;color:#888;font-size:14px}.status-icon.done{background:#4caf50;color:#fff}.todo-content{flex:1;min-width:0}.todo-title{font-size:15px;color:#333;margin:0 0 6px;line-height:1.4}.todo-meta{display:flex;gap:12px;font-size:12px;color:#888}.todo-id{font-family:monospace}.favorite-button{flex-shrink:0;width:36px;height:36px;border:none;background:transparent;font-size:20px;color:#ccc;cursor:pointer;transition:color .2s,transform .2s;border-radius:50%}.favorite-button:hover{color:#ffc107;transform:scale(1.1)}.favorite-button.active{color:#ffc107}
