body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.sidebar{background:#213448;box-shadow:2px 0 8px #00000014;color:#fff;display:flex;flex-direction:column;height:100vh;justify-content:space-between;left:0;position:fixed;top:0;width:220px;z-index:100}.sidebar-title{color:#ecefca;font-size:1.6rem;font-weight:700;letter-spacing:2px;padding:2rem 1.5rem 1rem;text-align:left}.sidebar-toggle{background:#0000;border:none;cursor:pointer;text-align:left;width:100%}.sidebar-toggle:focus{outline:2px solid #ffffff59;outline-offset:2px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:.5rem;padding:0 1.5rem}.sidebar-link{border-radius:6px;color:#fff;font-size:1.05rem;padding:.75rem 1rem;text-decoration:none;transition:background .2s,color .2s}.sidebar-link.active,.sidebar-link:hover{background:#ecefca;color:#030303}.sidebar-link.active{font-weight:700}.sidebar-logout{background:#7d0a0a;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin:1.5rem;padding:.7rem 1rem;transition:background .2s}.sidebar-logout:hover{background:#bf3131}@media (max-width:700px){.sidebar{align-items:stretch;flex-direction:column;height:auto;padding:0;position:static;width:100%}.sidebar-title{font-size:1.2rem;padding:1rem}.sidebar-nav{display:none;flex-direction:column;gap:.2rem;padding:0 .5rem .5rem}.sidebar.open .sidebar-nav{display:flex}.sidebar.open .sidebar-logout{display:block}.sidebar-logout{display:none}.sidebar-link,.sidebar-logout{font-size:.95rem;padding:.5rem .7rem}.sidebar-logout{margin:.5rem}}.reusable-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #00000012;margin:1rem 0;overflow:hidden;width:100%}.reusable-table td,.reusable-table th{padding:.75rem 1rem;text-align:left}.reusable-table th{background:#f5f6fa;color:#333;font-weight:600}.reusable-table tr{border-bottom:1px solid #ececec}.reusable-table tr:last-child{border-bottom:none}.reusable-table tbody tr:hover{background:#f0f4ff}@media (max-width:700px){.reusable-table td,.reusable-table th{font-size:.85rem;padding:.4rem .5rem}.reusable-table th{white-space:nowrap}.modal-content .table-container{overflow-x:auto}.modal-content .reusable-table{min-width:560px}}.close-btn,.create-btn,.delete-btn,.edit-btn,.view-btn{border:none;border-radius:4px;cursor:pointer;font-weight:500;margin:0 .25rem;padding:.5rem 1rem;transition:background .2s}.create-btn{background:#537d5d;color:#fff}.create-btn:hover{background:#27ae38}.edit-btn{background:#03346e;color:#fff}.edit-btn:hover{background:#005fa3}.view-btn{background:#210f37;color:#fff}.view-btn:hover{background:#4f1c51}.delete-btn{background:#7d0a0a;color:#fff}.delete-btn:hover{background:#bf3131}.close-btn{background:#888;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-block;font-weight:500;margin-top:0;padding:.5rem 1.2rem;transition:background .2s}.close-btn:focus,.close-btn:hover{background:#555}.save-btn{background:#0074d9;border:none;border-radius:4px;box-shadow:0 1px 3px #0000000f;color:#fff;cursor:pointer;display:inline-block;font-weight:500;margin-left:.5rem;padding:.5rem 1.2rem;transition:background .2s}.save-btn:focus,.save-btn:hover{background:#005fa3}.modal-actions{gap:.5rem;justify-content:flex-end;margin-top:auto}.modal-actions,.modal-overlay{align-items:center;display:flex}.modal-overlay{background:#00000059;bottom:0;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 24px #00000026;display:flex;flex-direction:column;max-width:70vw;min-width:320px;padding:2rem;position:relative}.modal-content h2{color:#222;font-size:1.5rem;margin-bottom:1rem;margin-top:0}.modal-content input{background:#f8fafc;border:1.5px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:1.08rem;height:2.7rem;margin:0 0 .5rem;outline:none;padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}.modal-content input:focus{background:#eaf4ff;border-color:#0074d9;box-shadow:0 0 0 2px #b3dbff}@media (max-width:600px){.modal-content{max-height:85vh;min-width:auto;overflow:hidden;padding:1rem;width:92vw}.reusable-table td,.reusable-table th{font-size:.95rem;padding:.5rem}}.create-btn.create-btn-float{align-items:center;border-radius:50%;box-shadow:0 2px 8px #2ccc4014;display:flex;float:right;font-size:1.7rem;font-weight:700;height:2.7rem;justify-content:center;margin-bottom:1rem;padding:0;width:2.7rem}.create-btn.create-btn-float:focus,.create-btn.create-btn-float:hover{background:#27ae38}.pagination-controls{align-items:center;display:flex;justify-content:space-between;padding:1rem 0}.pagination-controls select{border:1px solid #ccc;border-radius:4px;padding:.5rem}.page-navigation{align-items:center;display:flex;gap:1rem}.page-navigation button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:background-color .2s}.page-navigation button:disabled{background-color:#ccc;cursor:not-allowed}.page-navigation button:hover:not(:disabled){background-color:#0056b3}.priority-btn{background:#ffd600;border:none;border-radius:4px;color:#333;cursor:pointer;font-weight:500;margin:0 .25rem;padding:.5rem 1rem;transition:background .2s}.priority-btn:hover{background:#ffc400}.area-btn{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;margin:0 .25rem;padding:.5rem 1rem;transition:background .2s}.area-btn:hover{background:#5a6268}.category-btn{background:#8e24aa;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;margin:0 .25rem;padding:.5rem 1rem;transition:background .2s}.category-btn:hover{background:#7b1fa2}.cambiar-responsable-btn{background:#090040;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;margin:0 .25rem;padding:.5rem 1rem;transition:background .2s}.cambiar-responsable-btn:hover{background:#7b1fa2}.cambiar-estado-btn{background:#ff9800;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;margin:0 .25rem;padding:.5rem 1rem;transition:background .2s}.cambiar-estado-btn:hover{background:#f57c00}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}.reusable-table td{-webkit-hyphens:auto;hyphens:auto;word-break:break-word}@media (max-width:700px){.pagination-controls{align-items:stretch;flex-direction:column;gap:.5rem}.page-navigation{justify-content:space-between}.page-navigation span{font-size:.95rem}.area-btn,.cambiar-estado-btn,.cambiar-responsable-btn,.category-btn,.close-btn,.create-btn,.delete-btn,.edit-btn,.priority-btn,.save-btn,.view-btn{font-size:.95rem;padding:.5rem .75rem}}.area-btn:focus,.cambiar-estado-btn:focus,.cambiar-responsable-btn:focus,.category-btn:focus,.close-btn:focus,.create-btn:focus,.delete-btn:focus,.edit-btn:focus,.priority-btn:focus,.save-btn:focus,.view-btn:focus{outline:2px solid #0074d959;outline-offset:2px}.modal-close{align-items:center;background-color:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:22px;font-weight:700;height:36px;justify-content:center;line-height:1;position:absolute;right:8px;top:8px;width:36px}.modal-body{max-height:70vh;overflow-y:auto}.detail-table{background:#fff;border-collapse:collapse;border-radius:6px;box-shadow:0 1px 6px #0000000f;overflow:hidden;width:100%}.detail-table td,.detail-table th{padding:.6rem .9rem;text-align:left;vertical-align:top}.detail-table th{background:#f5f6fa;color:#333;font-weight:600;white-space:nowrap;width:38%}.detail-table tr{border-bottom:1px solid #ececec}.detail-table tr:last-child{border-bottom:none}.detail-table tbody tr:hover{background:#f0f4ff}@media (max-width:700px){.detail-table td,.detail-table th{font-size:.95rem;padding:.5rem .65rem}.detail-table th{width:45%}}.modal-permisos-backdrop{align-items:center;background:#00000059;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.modal-permisos-container{background:#fff;border:1px solid #e0e0e0;border-radius:14px;box-shadow:0 8px 32px #0000002e;max-width:480px;min-width:380px;padding:32px 32px 24px}.modal-permisos-title{color:#1976d2;font-size:22px;font-weight:600;margin-bottom:18px;margin-top:0}.modal-permisos-loading{color:#888;padding:24px;text-align:center}.modal-permisos-list{margin-bottom:18px;max-height:300px;overflow-y:auto}.modal-permisos-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;padding:7px 0}.modal-permisos-item:last-child{border-bottom:none}.modal-permisos-checkbox{accent-color:#1976d2;margin-right:10px;transform:scale(1.2)}.modal-permisos-nombre{font-weight:500}.modal-permisos-desc{color:#888;font-size:13px;margin-left:8px}.modal-permisos-actions{margin-top:10px;text-align:right}.modal-permisos-btn{border-radius:5px;cursor:pointer;font-size:15px;font-weight:500;margin-left:4px;padding:7px 18px;transition:background .2s,color .2s}.modal-permisos-btn.cancelar{background:#dc3545;border:1px solid #dc3545;color:#fff}.modal-permisos-btn.cancelar:hover{background:#c82333;border-color:#c82333}.modal-permisos-btn.guardar{background:#1976d2;border:none;box-shadow:0 2px 8px #1976d214;color:#fff}.modal-permisos-btn.guardar:disabled{background:#b3d1f7;box-shadow:none;cursor:not-allowed}.modal-permisos-btn.close-x{align-items:center;background:#d32f2f;border:none;border-radius:50%;box-shadow:0 2px 8px #00000014;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;font-weight:700;height:36px;justify-content:center;margin-left:16px;position:relative;transition:background .2s,color .2s;width:36px}.modal-permisos-btn.close-x:hover{background:#b71c1c;color:#fff}.home-container{display:flex}.home-content{align-items:flex-start;box-sizing:border-box;display:flex;flex-direction:column;flex-grow:1;gap:16px;margin-left:220px;min-height:100vh;padding:20px}.home-content h1{align-items:center;margin-bottom:1rem;text-align:left;width:100%}.boxes-container{display:flex;gap:30px;justify-content:flex-start;margin-bottom:1rem;width:100%}.box-wrapper{flex-direction:column}.box-wrapper,.info-box{align-items:center;display:flex}.info-box{border-radius:20px;box-shadow:0 4px 8px #0000001a;color:#fff;font-size:56px;font-weight:700;height:180px;justify-content:center;width:200px}.box-hechas{background-color:#c53030}.box-todas{background-color:#2b6cb0}.box-label{color:#333;margin-top:12px}.box-label,.iphone-button{font-size:1.1rem;font-weight:700}.iphone-button{border:none;border-radius:15px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;max-width:320px;padding:15px;transition:transform .2s ease,box-shadow .2s ease;width:80%}.iphone-button:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.iphone-button:active{box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.btn-calificables{background-color:#3c096c}.btn-comentarios{background-color:#dc2626}.btn-crear{background-color:#16a34a}.buttons-container{align-items:flex-start;display:flex;flex-direction:column;gap:16px;margin-top:auto;width:100%}@media (max-width:700px){.home-container{flex-direction:column}.home-content{margin-left:0;max-width:100%;padding:16px;width:100%}.boxes-container{flex-direction:column;flex-wrap:nowrap;gap:16px;width:100%}.info-box{font-size:64px;height:220px;width:100%}.box-label{font-size:1.1rem;text-align:center}.iphone-button{max-width:none;width:100%}.buttons-container{align-items:stretch;width:100%}}.search-bar-container{display:flex;gap:.5rem;justify-content:flex-end;margin-bottom:1rem}.search-bar-container input{border:1px solid #ccc;border-radius:4px;padding:.5rem}.search-bar-container button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:background-color .2s}.search-bar-container button:hover{background-color:#0056b3}@media (max-width:700px){.search-bar-container{align-items:stretch;flex-direction:column}.search-bar-container button,.search-bar-container input{width:100%}}.admin-layout{display:flex;min-height:100vh}.admin-content{background:#f7f7fa;flex:1 1;margin-left:220px;padding:2rem}@media (max-width:700px){.admin-layout{flex-direction:column}.admin-content{margin-left:0;padding:1rem}}.register-page-container{align-items:center;background-color:#f0f2f5;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.form-title{color:#00638f;font-size:32px;font-weight:900;margin-bottom:20px;text-align:center}.register-form-card{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-width:400px;padding:26px 36px;text-align:center;width:90%}.form-logo{display:block;height:auto;margin-bottom:20px;margin-left:auto;margin-right:auto;max-width:100px}.app-title{color:#000;font-size:28px;font-weight:700;margin-bottom:10px;text-transform:uppercase}.form-subtitle{color:#000;font-size:20px;font-weight:400;margin-bottom:25px}.register-form .form-group{margin-bottom:20px;text-align:left}.register-form .form-group label{color:#555;display:block;font-weight:600;margin-bottom:8px}.register-form .form-group input[type=email],.register-form .form-group input[type=password],.register-form .form-group input[type=text],.register-form .form-group select{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:16px;padding:12px 15px;transition:border-color .2s;width:100%}.register-form .form-group input:focus,.register-form .form-group select:focus{border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40;outline:none}.submit-btn{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 15px;transition:background-color .2s;width:100%}.submit-btn:hover{background-color:#0056b3}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#dc3545}.error-message,.success-message{font-size:14px;margin-bottom:20px;padding:10px}.success-message{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;color:#155724}::placeholder{color:#aaa;opacity:1}:-ms-input-placeholder{color:#aaa}::-ms-input-placeholder{color:#aaa}.login-link-container{font-size:14px;margin-top:20px;text-align:center}.login-link-container p{color:#555;margin-bottom:0}.login-link{color:#007bff;font-weight:600;text-decoration:none}.login-link:hover{text-decoration:underline}.login-page-links-container{margin-top:20px;text-align:center}.form-link-item{font-size:14px;margin-bottom:10px}.form-link-item p{color:#555;margin:0}.form-link{color:#007bff;font-weight:600;text-decoration:none}.form-link:hover{text-decoration:underline}.form-container{align-items:center;background-color:#f0f2f5;box-sizing:border-box;display:flex;flex-direction:column;min-height:calc(100vh - 60px);padding:20px}.form-container h2{color:#00638f;font-size:28px;font-weight:700;margin-bottom:25px;text-align:center}.form-group{margin-bottom:20px;text-align:left}.form-group label{color:#555;display:block;font-weight:600;margin-bottom:8px}.form-group input[type=email],.form-group input[type=number],.form-group input[type=password],.form-group input[type=text],.form-group select,.form-group textarea{background-color:#fff;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:16px;padding:12px 15px;transition:border-color .2s;width:100%}.form-group input[type=file]{background-color:#fff;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group input[type=file]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40;outline:none}.form-group textarea{min-height:100px;resize:vertical}.crear-tarea-container{display:flex}.crear-tarea-content{display:flex;flex-grow:1;justify-content:center;margin-left:220px;padding:20px}.form-wrapper{max-width:900px;width:100%}.grid-form{display:flex;flex-direction:column;gap:20px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-group.full-width,.submit-button{grid-column:1/-1}.submit-button{justify-self:flex-start}@media (max-width:700px){.crear-tarea-container{flex-direction:column}.crear-tarea-content{margin-left:0;max-width:100%;padding:16px;width:100%}}
/*# sourceMappingURL=main.bcfbef72.css.map*/