.obras-container{padding:24px;background-color:#f8fafc;font-family:Arial,sans-serif;color:#1e293b}.estado-cards{display:flex;gap:20px;margin-bottom:20px;flex-wrap:wrap}.card{flex:1;color:#fff;padding:5px 20px;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 3px 8px #00000014}.card:hover{transform:translateY(-3px);box-shadow:0 6px 12px #0000001a}.card.ejecucion{background-color:#5a2ca0}.card.finalizadas{background-color:#0d9488}.card h3{font-size:21px;font-weight:600;margin-bottom:6px}.card p{font-size:14px;opacity:.9}.card.seleccionada{transform:scale(1.05);box-shadow:0 8px 16px #0000004d;border:3px solid white}.card-contador{background-color:#fff3;border-radius:12px;padding:2px 8px;font-size:18px;font-weight:700;margin-left:10px}.btn-nueva-obra{background-color:#2563eb;color:#fff;font-weight:600;padding:10px 22px;border:none;border-radius:8px;cursor:pointer;margin-bottom:22px;transition:all .25s ease;box-shadow:0 2px 5px #2563eb40}.btn-nueva-obra:hover{background-color:#1e40af;transform:translateY(-2px)}.acciones-principales-container{display:flex;align-items:center;gap:15px;margin-bottom:20px}.btn-exportar{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1d743f,#107c41);color:#fff;padding:0 25px;border:none;border-radius:6px;font-weight:700;font-size:.9rem;cursor:pointer;height:42px;transition:all .3s ease;box-shadow:0 4px 6px #107c4133;text-transform:uppercase}.btn-exportar:hover{transform:translateY(-2px);box-shadow:0 6px 12px #107c4166;filter:brightness(1.1)}.btn-exportar:active{transform:translateY(0)}.btn-nueva-obra{margin-bottom:0!important;height:42px}.filtros{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}.filtros input,.filtros select{padding:6px 8px;border-radius:6px;border:1px solid #d1d5db;background-color:#fff;transition:all .2s ease;font-size:17px}.filtros input:focus,.filtros select:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26;outline:none}.btn-limpiar{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;padding:5px 12px;cursor:pointer;font-size:16px;font-weight:500;transition:all .2s ease}.btn-limpiar:hover{background-color:#e2e8f0}.tabla-container{width:100%;overflow-x:auto;overflow-y:hidden;border-radius:12px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9}.tabla-container::-webkit-scrollbar{height:8px}.tabla-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.tabla-container::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:10px}.tabla-container table{min-width:1400px}.paginacion-container{display:flex;align-items:center;justify-content:flex-start;gap:25px;padding:10px 20px;background:linear-gradient(to bottom,#fff,#f1f3f5);border:1px solid #d1d5db;border-top:none;font-size:14px;color:#374151}.paginacion-info{display:flex;align-items:center;gap:8px}.input-pagina{width:45px;height:30px;text-align:center;border:1px solid #ced4da;border-radius:4px;font-weight:500}.paginacion-botones{display:flex;gap:2px}.btn-nav{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background-color:#fff;border:1px solid #ced4da;border-radius:50%;cursor:pointer;transition:all .2s;color:#4b5563;font-weight:700}.btn-nav:hover:not(:disabled){background-color:#f8f9fa;border-color:#adb5bd;box-shadow:0 2px 4px #0000001a}.btn-nav:disabled{opacity:.4;cursor:not-allowed}.paginacion-selector{display:flex;align-items:center;gap:10px}.select-filas{padding:4px 8px;border:1px solid #ced4da;border-radius:4px;background-color:#fff;cursor:pointer;outline:none}.select-filas:focus{border-color:#4dabf7}.texto-filas{color:#6b7280}.obras-table{width:100%;border-collapse:separate;border-spacing:0;background:#f9f9f9;border-radius:10px;box-shadow:0 2px 6px #0000000d;overflow:hidden;min-width:1400px}.obras-table thead{background-color:#f8f9fc;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:1}.obras-table th{font-size:15px;font-weight:600;color:#313030;text-transform:uppercase;letter-spacing:.3px;text-align:center;padding:12px 16px;white-space:nowrap;background-color:#f0ebeb;vertical-align:bottom}.obras-table td{font-size:14px;color:#334155;padding:5px 10px;border-bottom:1px solid #c3c3c3;vertical-align:middle;text-align:center;line-height:1.5}.obras-table tr:last-child td{border-bottom:none}.obras-table tbody td{vertical-align:top;padding-top:8px;padding-bottom:8px}.obras-table tbody tr:hover{background-color:#f9fafb;transition:background .2s ease}.obras-table th:nth-child(1),.obras-table td:nth-child(1){width:50px;text-align:center}.obras-table th:nth-child(2),.obras-table td:nth-child(2){width:220px;text-align:center}.obras-table th:nth-child(3),.obras-table td:nth-child(3){width:200px;font-weight:600}.obras-table th:nth-child(4),.obras-table th:nth-child(5),.obras-table th:nth-child(6),.obras-table td:nth-child(4),.obras-table td:nth-child(5),.obras-table td:nth-child(6){width:220px}.obras-table th:nth-child(10),.obras-table th:nth-child(11),.obras-table th:nth-child(12),.obras-table td:nth-child(10),.obras-table td:nth-child(11),.obras-table td:nth-child(12){width:220px}.obras-table td:nth-child(8),.obras-table td:nth-child(9){width:220px;white-space:nowrap}.acciones{gap:8px;height:100%}.icon{width:20px;height:20px;cursor:pointer;transition:all .2s ease}.icon:hover{transform:scale(1.2);opacity:.8}.icon.avance{color:#22c55e}.icon.editar{color:#2563eb}.icon.eliminar{color:#dc2626}.icon.estado{color:#f59e0b}.estado-ejecucion,.estado-finalizada{font-size:13px;font-weight:600;padding:5px 10px;border-radius:8px;display:inline-block;text-align:center}.estado-ejecucion{background-color:#dbeafe;color:#1e3a8a}.estado-finalizada{background-color:#dcfce7;color:#166534}.list-cell-content{display:flex;flex-wrap:wrap;justify-content:center;padding:4px 0}.tag{display:flex;align-items:center;justify-content:center;padding:3px 8px;margin:2px;font-size:.8rem;font-weight:500;border-radius:12px;background-color:#e0e7ff;color:#4338ca;border:1px solid #c7d2fe;height:fit-content;width:fit-content;max-width:90%}.tag-tarea{background-color:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.tag-equipo{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-nueva-obra{background:#fff;border-radius:12px;width:60%;max-height:90vh;overflow-y:auto;padding:24px;box-shadow:0 5px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #e2e8f0;margin-bottom:18px;padding-bottom:8px}.modal-header h2{font-weight:600;font-size:18px}.modal-header button{background:none;border:none;font-size:22px;cursor:pointer;color:#475569;transition:color .2s ease}.modal-header button:hover{color:#2563eb}.swal-high-zindex{z-index:99999!important}.menu{display:flex;gap:20px}.menu-btn{text-decoration:none;color:#0284c7;font-weight:600;padding:5px 10px;transition:color .2s,border-bottom .2s}.menu-btn:hover{color:#0369a1;border-bottom:2px solid #0284c7}.user-info{font-size:.9rem;color:#555;text-align:right}.header-content{font-family:Arial,sans-serif;background:#fff;padding:8px 20px;display:flex;justify-content:space-between;align-items:center;gap:20px}.header-left{display:flex;align-items:center;gap:15px}.header-content .logo{height:60px}.header-content p{font-size:14px;color:#0284c7;margin:0}.header-right{display:flex;align-items:center;gap:15px}.user-profile{display:flex;align-items:center;gap:10px;padding:5px 10px;border:1px solid #ddd;border-radius:6px;cursor:default}.user-details{display:flex;flex-direction:column;align-items:flex-start}.user-name-row{display:flex;align-items:center;gap:5px;font-size:16px;color:#333}.user-icon{color:#5d0263}.subsecretaria-text{font-size:11px;color:teal;margin:0;line-height:1.2}.btn-logout{background:none;border:none;color:#900;cursor:pointer;padding:5px;border-radius:4px;transition:background .2s}.btn-logout:hover{background:#f0f0f0}.main-footer{display:flex;background:#fff;padding:15px;color:#444;border-top:1px solid #d2d6de;font-size:13px;font-family:Arial,sans-serif}.modal-content{background:#fff;padding:24px 28px;border-radius:10px;box-shadow:0 6px 25px #0003;max-width:850px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;font-family:Arial,sans-serif}.modal-content h3{color:#374151;font-size:17px;margin-top:25px;margin-bottom:10px;padding-bottom:4px;border-bottom:2px solid #e5e7eb;font-weight:700}.modal-content form>div{display:flex;flex-direction:column;margin-bottom:12px}.modal-content label{font-size:14px;font-weight:600;margin-bottom:4px;color:#374151}.modal-content input,.modal-content select,.modal-content textarea{padding:8px 10px;border-radius:6px;border:1px solid #d1d5db;font-size:14px;transition:border-color .2s ease}.modal-content input:focus,.modal-content select:focus,.modal-content textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f626}.modal-content form{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}.modal-content form h3{grid-column:span 2}.modal-content textarea{resize:vertical;min-height:80px;grid-column:span 2}.form-buttons{grid-column:span 2;display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.form-buttons button{padding:8px 16px;font-weight:600;border-radius:6px;cursor:pointer;border:none;font-size:14px;transition:background .2s,transform .1s}.form-buttons button[type=button]{background:#9ca3af;color:#fff}.form-buttons button[type=button]:hover{background:#6b7280}.form-buttons button[type=submit]{background:#2563eb;color:#fff}.form-buttons button[type=submit]:hover{background:#1d4ed8;transform:translateY(-1px)}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-thumb{background-color:#9ca3af;border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background-color:#6b7280}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.modal-content form{grid-template-columns:1fr}.form-buttons{flex-direction:column;align-items:stretch}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:1000;display:flex;justify-content:center;align-items:center}.modal-content-avances{background-color:#fff;border-radius:10px;width:auto;max-height:90vh;padding:25px;font-family:Arial,sans-serif}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #eee;margin-bottom:15px}.modal-header h2{font-size:20px;font-weight:700}.modal-header button{border:none;background:none;font-size:20px;cursor:pointer}.modal-body-avances h3{font-size:18px;font-weight:600;margin-bottom:10px;color:#1e3a8a}.tabla-avances{width:100%;border-collapse:collapse;margin-bottom:20px}.tabla-avances th,.tabla-avances td{border:1px solid #ddd;padding:8px;font-size:14px}.tabla-avances th{background-color:#f3f4f6;text-align:left}.form-avance{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px}.full-width{grid-column:1 / -1}.form-avance label{font-size:14px;color:#374151;margin-bottom:5px;display:block}.form-avance input,.form-avance textarea{width:100%;padding:8px;border:1px solid #ccc;border-radius:6px}.botones-avance{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.btn-agregar{background-color:#22c55e;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer}.btn-guardar{background-color:#2563eb;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer}.btn-agregar:hover{background-color:#16a34a}.btn-guardar:hover{background-color:#1d4ed8}.form-avance{display:flex;flex-direction:column;gap:16px}.form-avance div{width:100%}.form-avance input,.form-avance select,.form-avance textarea{width:100%;box-sizing:border-box}.form-avance input,.form-avance select{padding:10px;font-size:.9rem;border:1px solid #ccc;border-radius:4px;height:40px;background-color:#fff;box-sizing:border-box}.form-avance select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23666%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right 10px center;background-size:10px 10px;padding-right:30px}.form-avance input::placeholder{color:#aaa;font-style:italic}.form-avance .select-multiple-container .equipment-list{height:150px;overflow-y:auto;border:1px solid #ccc;border-radius:4px;padding:8px;background-color:#fff}.form-avance .equipment-item{display:flex;align-items:center;padding:4px 8px;margin-bottom:4px;border:1px solid #eee;border-radius:3px;font-size:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.form-avance .equipment-item input[type=checkbox]{width:auto;height:auto;margin-right:8px}.form-avance .equipment-item span:last-child{margin-left:auto;font-weight:700;font-size:.8rem}.form-avance .equipment-item.selected{background-color:#e0f7fa;border-color:#00bcd4}.form-avance .equipment-item.disabled{background-color:#f0f0f0;opacity:.6;cursor:not-allowed;border-color:#ddd}.swal2-container{z-index:10000!important}.dashboard{padding:20px;background-color:#f4f6f9;min-height:100vh;font-family:Arial,sans-serif}.dashboard h2{font-size:2rem;font-weight:600;color:#333;border-bottom:2px solid #e0e4eb;padding-bottom:10px;margin-bottom:30px}.dashboard-content{display:flex;gap:30px;flex-wrap:wrap;justify-content:center}.stat-card{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;padding:25px;flex:1;min-width:350px;max-width:450px;text-align:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-card h3{font-size:1.5rem;color:#444;margin-top:0;margin-bottom:15px}.total-display{font-size:1.1rem;color:#666;margin-bottom:20px}.total-display strong{font-weight:700;color:#333;font-size:1.2rem}.chart-container{position:relative;width:100%;max-width:300px;height:350px;margin:0 auto;display:flex;justify-content:center;align-items:center}.chart-center{position:absolute;top:42%;left:50%;transform:translate(-50%,-50%);font-size:3rem;font-weight:700;color:#333;pointer-events:none}.no-data-message{padding:20px;border:1px solid #e0e0e0;border-radius:8px;color:#777;margin-top:20px}.dashboard-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:10px;background:#ffffff80;border-radius:12px}.btn-instructivo{display:inline-flex;align-items:center;background:linear-gradient(135deg,#0091ff,#1900ff);color:#fff;padding:14px 28px;border:none;border-radius:40px;font-weight:900px;font-size:1.1rem;letter-spacing:.5px;cursor:pointer;box-shadow:0 10px 15px -3px #ff910066;transition:transform .2s ease;position:relative;height:80px}.btn-instructivo span{font-weight:100}.btn-pulse{animation:pulse-animation 2s infinite}@keyframes pulse-animation{0%{box-shadow:0 0 #000000b3}70%{box-shadow:0 0 0 15px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}.btn-instructivo:hover{transform:scale(1.05);background:linear-gradient(135deg,#05009b,#000f94)}.btn-instructivo span{text-transform:uppercase}@media (max-width: 768px){.dashboard-header-row{flex-direction:column;align-items:flex-start;gap:15px}.btn-instructivo{width:100%}.dashboard-content{flex-direction:column;align-items:center}.stat-card{min-width:90%}.dashboard h2{text-align:center}}.user-management-container{max-width:1200px;margin:40px auto;padding:20px;background-color:#f4f7f9;border-radius:8px;box-shadow:0 4px 12px #0000001a;font-family:Arial,sans-serif}h2{color:#333;border-bottom:2px solid #ccc;padding-bottom:10px;margin-bottom:20px}.btn-nueva-obra{background-color:#007bff;color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;margin-bottom:20px;transition:background-color .3s}.btn-nueva-obra:hover{background-color:#0056b3}.table-wrapper{overflow-x:auto}.user-table{width:100%;border-collapse:collapse;background-color:#fff}.user-table th,.user-table td{padding:12px 15px;text-align:left;border-bottom:1px solid #ddd}.user-table th{background-color:#e9ecef;color:#333;font-weight:600}.user-table tbody tr:hover{background-color:#f1f1f1}.actions-cell{display:flex;gap:15px;align-items:center}.actions-cell .icon{cursor:pointer;transition:color .2s,transform .2s}.actions-cell .icon:hover{transform:scale(1.1)}.actions-cell .edit{color:#ffc107}.actions-cell .permissions{color:#17a2b8}.actions-cell .delete{color:#dc3545}.loading-message,.error-message{padding:20px;text-align:center;border-radius:4px;margin-top:20px;font-weight:700}.loading-message{background-color:#e0f7fa;color:#00bcd4}.error-message{background-color:#fdeaea;color:#dc3545}.user-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.user-modal-content{background:#fff;padding:30px;border-radius:8px;width:90%;max-width:500px;box-shadow:0 5px 15px #0000004d;position:relative}.close-button{position:absolute;top:10px;right:10px;background:none;border:none;font-size:20px;cursor:pointer;color:#aaa}.user-modal-content h3{margin-top:0;border-bottom:1px solid #eee;padding-bottom:10px}.user-modal-content label{display:block;margin-top:15px;margin-bottom:5px;font-weight:500;color:#555}.user-modal-content input[type=text],.user-modal-content input[type=email],.user-modal-content input[type=password]{width:100%;padding:10px;margin-bottom:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.form-buttons{text-align:right;margin-top:20px}.btn-primary{background-color:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:16px;transition:background-color .3s}.permissions-modal-content{max-width:800px;padding:20px}.permissions-transfer-box{display:flex;justify-content:space-between;gap:20px;margin-top:20px}.permissions-list{flex:1;border:1px solid #ddd;border-radius:6px;padding:10px;background-color:#fff;max-height:400px;display:flex;flex-direction:column}.permissions-list h4{margin-top:0;padding-bottom:10px;border-bottom:1px solid #eee;color:#007bff}.permissions-list.assigned h4{color:#28a745}.list-items{overflow-y:auto;flex-grow:1;padding-right:5px}.list-item{padding:10px;margin-bottom:5px;border-radius:4px;cursor:pointer;background-color:#f8f9fa;border:1px solid #eee;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s,transform .1s}.permissions-list.available .list-item:hover{background-color:#e9f5ff;border-color:#007bff;transform:translate(5px)}.permissions-list.assigned .list-item{background-color:#e5f7ea}.permissions-list.assigned .list-item:hover{background-color:#f7e0e5;border-color:#dc3545;transform:translate(-5px)}.separator-column{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-width:30px}.separator-icon{color:#6c757d}.save-button-container{text-align:center;padding-top:15px;border-top:1px solid #eee;margin-top:20px}html,body{margin:0;padding:0;overflow-x:hidden;box-sizing:border-box}.login-page{height:100vh;width:100vw;background:url(/loginDPV.jpg) no-repeat center center/cover;display:flex;flex-direction:column;justify-content:space-between;font-family:Arial,sans-serif}.login-panel{position:absolute;margin:20px 30px;border-radius:8px;right:0;height:73%;width:420px;background:#00000040;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:30px 24px;display:flex;flex-direction:column;justify-content:center}.login-header{background:#0284c7;color:#fff;border-radius:8px;text-align:center;padding:10px;margin-bottom:20px;margin-top:10px}.login-header h1{margin:0;font-size:26px;font-weight:800}.login-header span{color:#7dd3fc}.login-header .subtitle{font-size:16px;font-weight:600;margin:4px 0}.login-header .small-text{font-size:13px;opacity:.9}.input-group{display:flex;align-items:center;background:#fff;border-radius:6px;border:1px solid #ddd;margin-bottom:14px;padding:10px 12px}.input-group .icon{margin-right:8px;color:#666}.input-group input{border:none;outline:none;flex:1;font-size:15px}.btn-login{width:100%;background:#0284c7;border:none;border-radius:6px;padding:12px;color:#fff;font-weight:700;font-size:16px;cursor:pointer;margin-top:10px}.btn-login:hover{background:#0369a1}.forgot{text-align:center;margin-top:10px}.forgot a{font-size:14px;color:#fff;text-decoration:none}.forgot a:hover{text-decoration:underline}.login-footer{position:fixed;bottom:0;left:0;right:0}.barra-multicolor{display:flex;width:100%;height:8px}.franja{height:100%}.azul-oscuro{flex:.3;background:#001b7a}.celeste{flex:.75;background:#1d9bf0}.arena{flex:2;background:#d6a86c}.login-footer{max-height:90px}.footer-content{background:#fff;padding:8px 20px;display:flex;justify-content:space-between;align-items:center}.footer-left{display:flex;align-items:center;gap:15px}.footer-content .logo{height:60px}.footer-content p{font-size:14px;color:#0284c7;margin:0}.perfil-container{max-width:800px;margin:40px auto;padding:20px;background-color:#f9f9f9;border-radius:8px;box-shadow:0 4px 12px #00000014;font-family:Arial,sans-serif}.title-perfil{display:flex;align-items:center;color:#004d80;border-bottom:2px solid #ccc;padding-bottom:15px;margin-bottom:30px}.card-perfil{background-color:#fff;padding:25px;border-radius:6px;margin-bottom:25px;box-shadow:0 2px 4px #0000000d}.card-perfil h3{color:#333;margin-top:0;margin-bottom:20px;display:flex;align-items:center}.form-perfil{display:grid;grid-template-columns:1fr 1fr;gap:20px}.password-section .form-perfil{grid-template-columns:1fr}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:8px;color:#555;display:flex;align-items:center}.form-group input{padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:16px;transition:border-color .3s}.form-group input:focus{border-color:#007bff;outline:none}.form-group input:disabled{background-color:#eee;cursor:not-allowed}.btn-primary,.btn-secondary{grid-column:1 / -1;padding:12px 20px;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;transition:background-color .3s,opacity .3s;display:flex;align-items:center;justify-content:center}.btn-primary{background-color:#28a745;color:#fff}.btn-primary:hover{background-color:#218838}.btn-secondary{background-color:#007bff;color:#fff;margin-top:10px}.btn-secondary:hover{background-color:#0056b3}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.divider{border:0;height:1px;background-color:#ddd;margin:40px 0}.alert{padding:15px;border-radius:4px;margin-bottom:20px;font-weight:700;display:flex;align-items:center}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.spinner{animation:spin 1s linear infinite;margin-right:8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 600px){.form-perfil{grid-template-columns:1fr}}
