.sidebar{position:fixed;top:0;left:0;width:240px;height:100vh;background:#0f172a;color:#fff;display:flex;flex-direction:column;z-index:100}.sidebar-header{height:60px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;background:#020617}.sidebar-title{font-size:18px;font-weight:700}.toggle-btn{background:none;border:none;color:#fff;font-size:22px;cursor:pointer}.sidebar-menu{padding:16px;overflow-y:auto}.menu-title{font-size:12px;opacity:.6;margin-bottom:6px}.menu-item{display:block;padding:10px 12px;border-radius:8px;color:#e5e7eb;text-decoration:none;margin-bottom:6px;background:none;border:none;width:100%;text-align:left;cursor:pointer;font-size:14px}.menu-item:hover{background:#1e293b}.floating-toggle{position:fixed;top:20px;left:20px;background:#020617;color:#fff;border:none;font-size:22px;padding:10px 14px;border-radius:10px;cursor:pointer;z-index:200}.menu-toggle{background:none;border:none;width:100%;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center}.arrow{transition:transform .2s ease;font-size:12px}.arrow.open{transform:rotate(90deg)}.submenu{margin-left:12px;margin-top:6px;display:flex;flex-direction:column;gap:4px}.submenu-item{padding:8px 12px;border-radius:8px;color:#e5e7eb;text-decoration:none;font-size:13px}.submenu-item:hover{background:#1e293b}.logout-btn{color:#f87171!important;border:1px solid #f87171;margin-top:20px}.logout-btn:hover{background:#f87171!important;color:#fff!important}.app-layout{min-height:100vh;background:#f1f5f9}.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#0f172a;color:#fff;z-index:100;transition:transform .3s ease}.sidebar.collapsed{transform:translate(-100%)}.main-content{flex:1;padding:24px;overflow-y:auto;transition:all .3s ease}.main-content.with-sidebar{margin-left:260px}.main-content.full{margin-left:0}.open-sidebar{position:fixed;top:20px;left:20px;z-index:200;background:#111827;color:#fff;border:none;padding:10px 14px;border-radius:8px;cursor:pointer}:root{--primary: #004a99;--primary-hover: #003670;--secondary: #64748b;--text-dark: #1e293b;--text-muted: #94a3b8;--bg-light: #f8fafc;--bg-muted: #e2e8f0;--white: #ffffff;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--radius: 8px;--radius-lg: 12px;--transition: all .2s ease}*{box-sizing:border-box;margin:0;padding:0}.login-wrapper{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-light);padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.login-left{display:none}@media(min-width:992px){.login-left{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;max-width:450px;padding-right:4rem;border-right:1px solid var(--bg-muted);margin-right:3rem}.login-left h1{font-size:2.25rem;font-weight:700;color:var(--text-dark);line-height:1.3;margin-bottom:1rem}.login-left p{font-size:1.1rem;color:var(--secondary);line-height:1.6}}.login-right{width:100%;max-width:420px}.login-card{background:var(--white);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-lg);border:1px solid var(--bg-muted)}#header{margin-bottom:2rem;text-align:center}.header-text h1{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin-bottom:.25rem}.header-text p{font-size:.9rem;color:var(--secondary)}#header .logos{display:flex;justify-content:center;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--bg-muted)}#header .logos img{height:44px;object-fit:contain}#form{display:flex;flex-direction:column;gap:1.25rem}#form .form-group{display:flex;flex-direction:column;gap:.5rem}#form label{font-size:.85rem;font-weight:500;color:var(--text-dark)}#form input{width:100%;padding:.875rem 1rem;border:1px solid var(--bg-muted);border-radius:var(--radius);font-size:.95rem;color:var(--text-dark);background:var(--bg-light);transition:var(--transition)}#form input::placeholder{color:var(--text-muted)}#form input:hover{border-color:#cbd5e1}#form input:focus{outline:none;border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px #004a991a}#form button{margin-top:.5rem;background:var(--primary);color:var(--white);border:none;border-radius:var(--radius);padding:.9rem 1.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition);width:100%}#form button:hover{background:var(--primary-hover)}#form button:active{transform:scale(.98)}#footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--bg-muted);text-align:center}#footer .motto{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:.35rem}#footer .warning{font-size:.75rem;color:var(--text-muted);font-style:italic}@media(max-width:480px){.login-wrapper{padding:2rem 1rem 1rem;align-items:flex-start}.login-card{padding:1.75rem}#header .logos img{height:38px}}.gs-container{padding:24px;max-width:100%}.gs-card{background:#fff;border-radius:14px;padding:24px;box-shadow:0 10px 25px #00000014;max-width:1300px;width:100%;margin:0 auto}.content{padding:32px;min-height:100vh;background:#f1f5f9}.page-wrapper{max-width:1200px;margin:0 auto}.card{background:#fff;border-radius:16px;padding:24px 28px;box-shadow:0 10px 30px #00000014}.gs-header{margin-bottom:16px}.gs-title{font-size:24px;font-weight:700;color:#1d4ed8}.gs-subtitle{font-size:14px;color:#6b7280}.page-title{font-size:1.8rem;font-weight:700;color:#0f172a;margin-bottom:6px}.page-description{color:#64748b;margin-bottom:1.5rem}.gs-table-wrapper{width:100%;overflow-x:auto;border-radius:12px;background:#fff}.gs-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;column-width:auto}.gs-table thead th{background:#f8fafc;padding:14px 16px;font-weight:600;color:#475569;text-align:left;white-space:nowrap;border-bottom:2px solid #cbd5e1;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.gs-table thead th.gs-actions-header{text-align:center;width:100px}.gs-table tbody td{padding:14px 16px;vertical-align:middle;word-wrap:break-word;overflow-wrap:break-word;color:#334155;width:auto}.gs-table tbody td.gs-actions-cell{text-align:center;width:120px;padding:10px;vertical-align:middle}.gs-actions{align-items:center;gap:12px;width:100%}.gs-table tbody tr{transition:background-color .2s ease}.gs-table tbody tr td{border-bottom:1px solid #e5e7eb}.gs-table tbody tr:last-child td{border-bottom:none}.gs-table tbody tr:hover{background:#f8fafc}.gs-badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.gs-badge.pendiente{background:#fef3c7;color:#92400e}.gs-badge.aprobada{background:#dcfce7;color:#166534}.gs-badge.rechazada{background:#fee2e2;color:#991b1b}.gs-justificacion{max-height:3.6em;overflow:hidden;line-height:1.2}.gs-justificacion.expandida{max-height:none}.gs-ver-mas{display:inline-block;margin-top:4px;font-size:12px;color:#2563eb;cursor:pointer;font-weight:600}.gs-ver-mas:hover{text-decoration:underline}.gs-observacion{font-size:12px;color:#b91c1c;line-height:1.4}.gs-btn{padding:0;width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;font-size:18px;font-weight:700;transition:all .2s ease;margin:0 10px}.gs-btn:disabled{background-color:#f1f5f9!important;color:#cbd5e1!important;cursor:not-allowed;opacity:.6;transform:none}.gs-btn-approve{background:#dcfce7;color:#15803d}.gs-btn-approve:hover:not(:disabled){background:#bbf7d0;transform:scale(1.1)}.gs-btn-reject{background:#fee2e2;color:#b91c1c}.gs-btn-reject:hover:not(:disabled){background:#fecaca;transform:scale(1.1)}@media(max-width:1024px){.gs-table{font-size:13px}}@media(max-width:768px){.gs-card{padding:16px}.gs-title{font-size:20px}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-container{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:500px;box-shadow:0 10px 25px #0003;animation:slideDown .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.close-x{background:none;border:none;font-size:24px;color:#94a3b8;cursor:pointer}.modal-body{padding:24px}.user-info{background:#f8fafc;padding:10px;border-radius:8px;margin:10px 0 20px;border-left:4px solid #cbd5e1}.form-group-modal{margin-bottom:1rem;display:flex;flex-direction:column;gap:5px}.form-group-modal textarea{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:8px;resize:none;font-size:14px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.text-approve{color:#16a34a}.text-reject{color:#dc2626}.btn-modal-approve{background:#16a34a;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600}.btn-modal-reject{background:#dc2626;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600}.btn-modal-cancel{background:#fff;color:#64748b;border:1px solid #e2e8f0;padding:10px 20px;border-radius:8px;cursor:pointer}.modal-assignment-fields{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:20px;background:#f1f5f9;padding:15px;border-radius:10px}.form-group-modal select{width:100%;padding:10px;border-radius:8px;border:1px solid #cbd5e1;background:#fff;font-size:14px;margin-top:5px}.form-group-modal label{font-size:12px;font-weight:700;color:#475569;text-transform:uppercase}.btn-modal-approve:disabled{background:#94a3b8;cursor:not-allowed;opacity:.7}.modal-select,.modal-body textarea{padding:10px;border:1px solid #ddd;border-radius:6px;width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.table-card{background:#fff;border-radius:14px;padding:16px;box-shadow:0 10px 25px #0000000d;width:100%}.tabla-solicitudes{width:100%;border-collapse:collapse;table-layout:auto;font-size:14px}.tabla-solicitudes thead{background:#f3f4f6}.tabla-solicitudes thead tr{border-bottom:1px solid #e5e7eb}.tabla-solicitudes th{padding:12px;text-align:left;font-weight:600;color:#374151;white-space:nowrap}.tabla-solicitudes td{padding:12px;vertical-align:middle;word-wrap:break-word;overflow-wrap:break-word}.tabla-solicitudes tbody tr{border-bottom:1px solid #e5e7eb}.tabla-solicitudes tbody tr:last-child{border-bottom:none}.tabla-solicitudes tbody tr:hover{background:#f9fafb}.tabla-vacia{text-align:center;padding:20px;color:#9ca3af}.estado{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.estado.aprobada{background:#dcfce7;color:#166534}.estado.rechazada{background:#fee2e2;color:#991b1b}.acciones{text-align:center;white-space:nowrap}.accion-link{font-size:13px;font-weight:600;text-decoration:none;color:#16a34a}.accion-link:hover{color:#15803d;text-decoration:underline}.texto-corto{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden;line-height:1.5}.texto-corto.expandido{-webkit-line-clamp:unset}.ver-mas{margin-top:6px;font-size:12px;font-weight:600;color:#2563eb;cursor:pointer;display:inline-block}.ver-mas:hover{text-decoration:underline}.form-container{max-width:700px;max-height:650px;margin:0 auto;background:#fff;border-radius:16px;padding:32px;box-shadow:0 12px 30px #00000014;border-top:6px solid #2563eb}.form-title{font-size:22px;font-weight:700;color:#1e3a8a;text-align:center;margin-bottom:8px}.form-subtitle{text-align:center;font-size:14px;color:#6b7280;margin-bottom:28px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full{grid-column:1 / -1}.form-label{font-size:13px;font-weight:600;color:#374151}.form-input,.form-textarea{border:1px solid #d1d5db;border-radius:10px;padding:10px 12px;font-size:14px;transition:all .2s ease;background:#f9fafb}.form-input:disabled{background:#f3f4f6;color:#6b7280}.form-input:focus,.form-textarea:focus{outline:none;border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px #2563eb26}.form-textarea{resize:none}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.btn-cancel{background:#fff;border:1px solid #d1d5db;color:#374151;padding:10px 18px;border-radius:10px;font-size:14px;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background:#f3f4f6}.btn-submit{background:#2563eb;color:#fff;border:none;padding:10px 22px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-submit:hover{background:#1e40af}@media(max-width:640px){.form-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;z-index:999}.modal-card{background:#fff;width:500px;max-width:95%;border-radius:16px;padding:24px;box-shadow:0 10px 35px #00000026;animation:fadeIn .2s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h2{margin:0;font-size:20px;color:#0f172a}.modal-close{background:none;border:none;font-size:18px;cursor:pointer}.modal-body{display:flex;flex-direction:column;gap:14px}.modal-row span{font-size:13px;color:#64748b}.modal-row strong{display:block;font-size:14px;color:#0f172a}.modal-row p{margin:4px 0 0;font-size:14px;color:#334155}@keyframes fadeIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.gs-btn-ver{background:#0f172a;color:#fff;border:none;padding:6px 12px;border-radius:8px;cursor:pointer;transition:.2s}.gs-btn-ver:hover{background:#1e293b}.modal-close{width:34px;height:34px;border-radius:50%;border:none;background:#f1f5f9;color:#334155;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s ease}.modal-close:hover{background:#ef4444;color:#fff;transform:rotate(90deg) scale(1.1);box-shadow:0 4px 12px #ef444466}.modal-close:active{transform:scale(.95)}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e2e8f0;padding-bottom:12px;margin-bottom:16px}.table-card{background:#fff;border-radius:18px;padding:28px;box-shadow:0 20px 45px #0000000f;max-width:1300px;width:100%;margin:0 auto}.tabla-actividades{width:100%;border-collapse:collapse;font-size:14px}.tabla-actividades thead{background:#f8fafc}.tabla-actividades th{padding:18px;font-weight:600;color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:1px}.tabla-actividades td.acciones{padding:18px;color:#1e293b;border:none;display:flex;align-items:center;vertical-align:middle}.tabla-actividades tbody tr{transition:all .2s ease}.tabla-actividades tbody tr:hover{background:#f9fafb}.estado{padding:6px 14px;border-radius:999px;font-size:12px;font-weight:600;display:inline-block}.estado.pendiente{background:#fef3c7;color:#92400e}.estado.en-curso{background:#dbeafe;color:#1e40af}.estado.completado{background:#dcfce7;color:#166534}.avance-wrapper{display:flex;align-items:center;gap:12px;min-width:200px}.progress{flex:1;height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden;position:relative}.progress-bar{height:100%;border-radius:999px;transition:width .6s ease}.progress-bar.rojo{background:linear-gradient(90deg,#ef4444,#dc2626)}.progress-bar.amarillo{background:linear-gradient(90deg,#facc15,#f59e0b)}.progress-bar.verde{background:linear-gradient(90deg,#22c55e,#16a34a)}.avance-text{font-size:13px;font-weight:600;color:#475569;min-width:40px;text-align:center}.table-card .acciones{display:flex;gap:8px;align-items:center;text-align:center;vertical-align:middle}.table-card .acciones button{all:unset;min-height:36px;padding:0 14px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .25s ease}.table-card .acciones button.iniciar{background:#16a34a;color:#fff}.table-card .acciones button.iniciar:hover{background:#15803d;transform:translateY(-2px)}.table-card .acciones button.editar{background:#f1f5f9;color:#0f172a}.table-card .acciones button.editar:hover{background:#e2e8f0}.table-card .acciones button.eliminar{background:#fee2e2;color:#b91c1c}.table-card .acciones button.eliminar:hover{background:#fecaca}.fila-padre{background:#f8fafc;cursor:pointer;font-weight:500}.fila-padre:hover{background:#eef2ff}.fila-hija{background:#fff}.hija-nombre{padding-left:35px;color:#64748b;font-style:italic}.table-card .acciones .crear-hija{all:unset;min-height:36px;padding:0 14px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;transition:all .25s ease;background:#ede9fe;color:#5b21b6}.table-card .acciones .crear-hija:hover{background:#ddd6fe;transform:translateY(-2px)}.table-card .acciones .aprobar{background:#dcfce7;color:#166534}.table-card .acciones .aprobar:hover{background:#bbf7d0}@media(max-width:768px){.acciones{flex-wrap:wrap}}.barra-filtros{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:20px}.barra-filtros input,.barra-filtros select{padding:8px 12px;border:1px solid #dcdcdc;border-radius:6px;font-size:14px;background:#fff;min-width:160px}.barra-filtros input:focus,.barra-filtros select:focus{outline:none;border-color:#4f46e5}.btn-buscar{padding:8px 16px;background:#4f46e5;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.btn-limpiar:hover{background:#d1d5db}.btn-buscar{padding:8px 16px;background:#4f46e5;color:#fff;border:none;border-radius:6px;cursor:pointer;float:right}.btn-buscar:hover{background:#4338ca}.btn-limpiar{padding:8px 16px;background:#e5e7eb;border:none;border-radius:6px;cursor:pointer}.header-actividades{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.header-actividades h1{display:block;margin:0;font-size:28px;font-weight:700}.input-busqueda{padding:10px 16px;border:1px solid #dcdcdc;border-radius:10px;min-width:320px;font-size:14px;background:#f9fafb;transition:all .2s ease}.input-busqueda:focus{outline:none;border-color:#4f46e5;background:#fff}.actividad-form{background:#fff;padding:32px;border-radius:16px;max-width:650px;max-height:650px;margin:0 auto;box-shadow:0 20px 40px #0f172a14;border:1px solid #e5e7eb;animation:fadeIn .4s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-title{margin-bottom:28px;font-size:24px;font-weight:700;color:#0f172a;text-align:center}.form-group{display:flex;flex-direction:column;margin-bottom:18px}.form-group label{font-weight:600;margin-bottom:6px;font-size:14px;color:#374151}.form-group input,.form-group select{padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;font-size:14px;background:#f9fafb;transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px #2563eb26}.form-row .form-group{flex:1}.btn-submit{margin-top:12px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:14px;width:100%;border-radius:12px;font-weight:600;font-size:15px;cursor:pointer;transition:all .25s ease;box-shadow:0 10px 20px #2563eb40}.btn-submit:hover{transform:translateY(-1px);box-shadow:0 14px 28px #2563eb59}.btn-submit:active{transform:scale(.98)}@media(max-width:640px){.actividad-form{padding:24px}.form-row{flex-direction:column}.form-title{font-size:20px}}.tabla-historial-container{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:18px;box-shadow:0 10px 25px #0f172a14,inset 0 1px #fff9;border:1px solid #e5e7eb;overflow:hidden}.tabla-historial{width:100%;border-collapse:separate;border-spacing:0;font-family:Inter,system-ui,sans-serif}.tabla-historial thead{background:linear-gradient(180deg,#f1f5f9,#e2e8f0)}.tabla-historial th{padding:16px;font-size:13px;font-weight:700;color:#334155;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e7eb}.fila{transition:background .25s ease,transform .15s ease}.fila:hover{background:#f9fafb}.tabla-historial td{padding:16px;font-size:14px;color:#1f2937;border-bottom:1px solid #eef2f7;vertical-align:middle}.fila:last-child td{border-bottom:none}.estado-completado{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:700;display:inline-block}.link-evidencia{color:#2563eb;font-weight:600;text-decoration:none;position:relative}.link-evidencia:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:#2563eb;transition:width .25s ease}.link-evidencia:hover:after{width:100%}.sin-evidencia{color:#9ca3af;font-size:13px;font-style:italic}.acciones{display:flex;justify-content:center;gap:10px}.acciones-header{text-align:center}.btn{width:36px;height:36px;border-radius:10px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .15s ease,box-shadow .15s ease}.btn.ver{background:#eff6ff;color:#2563eb}.btn.ver:hover{background:#dbeafe;box-shadow:0 6px 12px #2563eb40}.btn.editar{background:#fff7ed;color:#d97706}.btn.editar:hover{background:#ffedd5;box-shadow:0 6px 12px #d9770640}.btn.eliminar{background:#fef2f2;color:#dc2626}.btn.eliminar:hover{background:#fee2e2;box-shadow:0 6px 12px #dc262640}.btn:active{transform:scale(.92)}.tabla-vacia{padding:28px;text-align:center;font-size:14px;color:#64748b}@media(max-width:768px){.tabla-historial{font-size:13px}.tabla-historial th,.tabla-historial td{padding:12px}}.historial-page{max-width:1300px;margin:0 auto;padding:12px 8px 40px;display:flex;flex-direction:column;gap:18px}.historial-title{font-size:26px;font-weight:800;color:#0f172a;display:flex;align-items:center;gap:10px}.historial-busqueda .historial-wrapper{width:100%}.historial-top{display:flex;justify-content:flex-end;margin-bottom:20px}.input-busqueda{width:320px;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s ease}.input-busqueda:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.tarjeta-equipo{display:flex;align-items:center;gap:26px;background:linear-gradient(145deg,#05314d,#04263c);border-radius:20px;padding:26px 30px;color:#fff;height:100%;box-shadow:0 18px 40px #021c3240,inset 0 1px #ffffff0f;transition:all .35s ease}.tarjeta-equipo:hover{transform:translateY(-6px);box-shadow:0 30px 65px #021c3259,inset 0 1px #ffffff1a}.tarjeta-imagen{width:120px;height:120px;min-width:120px;border-radius:50%;overflow:hidden;background:#fff;border:4px solid rgba(255,255,255,.25);box-shadow:0 12px 28px #00000059}.tarjeta-info{display:flex;flex-direction:column;gap:6px}.tarjeta-info h2{font-size:20px;font-weight:900;margin:0;line-height:1.2}.tarjeta-info h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin:0;color:#7dd3fc}.tarjeta-info p{font-size:14px;line-height:1.55;color:#e5e7eb;opacity:.92;margin-top:8px;max-width:420px}@media(max-width:768px){.tarjeta-equipo{flex-direction:column;text-align:center;padding:28px 22px}.tarjeta-imagen{width:110px;height:110px;min-width:110px}.tarjeta-info p{max-width:100%}}.equipo-page{max-width:1400px;margin:0 auto;padding:60px 28px 100px}.equipo-title{font-size:34px;font-weight:900;margin-bottom:48px;color:#0f172a;letter-spacing:-.02em}.equipo-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;gap:20px;flex-wrap:wrap}.equipo-search{display:flex;align-items:center;background:#fff;padding:6px;border-radius:16px;box-shadow:0 12px 30px #0f172a14;border:1px solid #e2e8f0;transition:.3s ease}.equipo-search:focus-within{box-shadow:0 18px 40px #2563eb2e;border-color:#2563eb}.equipo-search input{border:none;outline:none;padding:12px 16px;font-size:14px;min-width:240px;border-radius:12px;background:transparent}.equipo-search button{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:10px 18px;border-radius:12px;cursor:pointer;font-weight:600;transition:all .3s ease}.equipo-search button:hover{transform:translateY(-2px);box-shadow:0 10px 25px #2563eb59}.btn-agregar{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;padding:12px 24px;border-radius:16px;font-weight:700;letter-spacing:.4px;cursor:pointer;transition:all .3s ease;box-shadow:0 12px 30px #22c55e40}.btn-agregar:hover{transform:translateY(-3px);box-shadow:0 20px 45px #22c55e59}.equipo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:42px;align-items:stretch}.tarjeta-wrapper{position:relative}.tarjeta-equipo{background:linear-gradient(160deg,#05314d,#041f33);border-radius:24px;padding:28px;display:flex;align-items:center;gap:22px;color:#fff;min-height:160px;box-shadow:0 20px 40px #021c3247,inset 0 1px #ffffff0f;transition:transform .35s ease,box-shadow .35s ease}.tarjeta-equipo:hover{transform:translateY(-8px);box-shadow:0 35px 70px #021c3261,inset 0 1px #ffffff1f}.tarjeta-imagen{width:90px;height:120px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#fff;border:3px solid rgba(255,255,255,.3);box-shadow:0 12px 25px #00000059}.tarjeta-imagen img{width:100%;height:100%;object-fit:cover}.tarjeta-info h2{font-size:20px;font-weight:900;margin-bottom:6px}.tarjeta-info .rol{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#7dd3fc;margin-bottom:8px}.tarjeta-info p{font-size:13.5px;line-height:1.6;color:#e5e7eb;opacity:.9}.modal-registro-personas{text-align:center}.btn-eliminar{position:absolute;top:16px;right:16px;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.25);padding:8px 14px;border-radius:12px;cursor:pointer;transition:all .3s ease;font-size:13px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-eliminar:hover{background:#ef4444;color:#fff;box-shadow:0 10px 25px #ef444459;transform:translateY(-2px)}@media(max-width:768px){.equipo-title{font-size:26px}.equipo-actions{flex-direction:column;align-items:stretch}.equipo-search,.equipo-search input,.btn-agregar{width:100%}.tarjeta-equipo{flex-direction:column;text-align:center;padding:22px}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center}.modal{background:#fff;padding:2rem;border-radius:10px;width:400px}.modal select{width:100%;padding:8px;margin:1rem 0}.modal-actions{display:flex;justify-content:space-between}.btn-editar{position:absolute;bottom:16px;right:16px;background:#3b82f626;color:#3b82f6;border:1px solid rgba(59,130,246,.35);padding:8px 16px;border-radius:12px;cursor:pointer;transition:all .3s ease;font-size:13px;font-weight:700;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-editar:hover{background:#3b82f6;color:#fff;box-shadow:0 10px 25px #3b82f666;transform:translateY(-2px)}.modal-overlay{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-container{width:480px;background:#fff;padding:40px;border-radius:24px;box-shadow:0 30px 80px #00000040,0 10px 25px #0000001a;animation:aparecer .25s ease}.modal-container h2{font-size:24px;font-weight:900;margin-bottom:28px;color:#0f172a}.modal-container input,.modal-container textarea,.modal-container select{width:100%;padding:14px 16px;margin-bottom:18px;border-radius:14px;border:1px solid #e2e8f0;background:#f8fafc;font-size:14px;transition:all .25s ease;outline:none}.modal-container input:focus,.modal-container textarea:focus,.modal-container select:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb26}.modal-buttons{display:flex;gap:14px;margin-top:10px}.btn-guardar{flex:1;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;padding:14px;border-radius:14px;color:#fff;font-weight:800;font-size:14px;cursor:pointer;transition:all .25s ease}.btn-guardar:hover{transform:translateY(-3px);box-shadow:0 15px 35px #16a34a66}.btn-cancelar{flex:1;background:#f1f5f9;border:none;padding:14px;border-radius:14px;font-weight:800;font-size:14px;cursor:pointer;transition:all .25s ease;color:#334155}.btn-cancelar:hover{background:#e2e8f0;transform:translateY(-2px)}@keyframes aparecer{0%{opacity:0;transform:translateY(15px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.ver-actividad-container{display:flex;justify-content:center;padding:40px}.ver-actividad-card{background:#fff;width:100%;max-width:900px;border-radius:14px;padding:30px;box-shadow:0 10px 25px #00000014}.ver-title{font-size:26px;margin-bottom:25px;color:#1f2937}.ver-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.ver-grid div span,.ver-descripcion span{font-size:13px;color:#6b7280;font-weight:600;text-transform:uppercase}.ver-grid div p{font-size:16px;margin-top:5px;color:#111827}.ver-descripcion{margin-top:25px}.ver-descripcion p{margin-top:8px;line-height:1.6;color:#374151}.estado{display:inline-block;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:600}.estado.en-progreso{background:#e0f2fe;color:#0369a1}.ver-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px}.btn-volver,.btn-editar{border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-weight:600}.btn-volver{background:#e5e7eb}.btn-editar{background:#2563eb;color:#fff}.btn-equis{background-color:#fceaea;border:none;color:#c0392b;font-weight:700;width:22px;height:22px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s ease-in-out;margin-right:10px}.btn-equis:hover{background-color:#e74c3c;color:#fff;transform:scale(1.1)}.btn-equis:active{transform:scale(.95)}.listado-apoyo{display:flex;justify-content:space-between}.editar-container{display:flex;justify-content:center;padding:40px}.editar-card{width:100%;max-width:700px;background:#fff;padding:30px;border-radius:16px;box-shadow:0 15px 40px #0000001a}.editar-card h1{margin-bottom:20px;color:#1d4ed8}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:600;margin-bottom:6px}.form-group input,.form-group select{width:100%;padding:10px;border-radius:10px;border:1px solid #d1d5db}.form-row{display:flex;gap:16px}.progress-bar{width:100%;height:10px;background:#e5e7eb;border-radius:999px;overflow:hidden;margin-top:6px}.progress-fill{height:100%;background:linear-gradient(90deg,#2563eb,#1e40af);transition:width .3s ease}.form-actions{display:flex;justify-content:space-between;margin-top:25px}.btn-save{background:#2563eb;color:#fff;padding:10px 20px;border-radius:10px;border:none;font-weight:700;cursor:pointer}.btn-save:hover{background:#1e40af}.btn-cancel{background:#6b7280;color:#fff;padding:10px 20px;border-radius:10px;border:none;cursor:pointer}.error-msg{color:#dc2626;margin-top:10px;font-size:14px}.sp-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;margin-top:24px;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 8px 28px #0f172a14;transition:.3s ease}.sp-table thead{background:linear-gradient(135deg,#0f172a,#1e293b)}.sp-table th{padding:16px 18px;font-weight:600;font-size:12px;letter-spacing:.6px;text-transform:uppercase;color:#f8fafc;border-bottom:none;position:relative}.sp-table th:not(:last-child):after{content:"";position:absolute;right:0;top:30%;height:40%;width:1px;background:#ffffff14}.sp-table td{padding:16px 18px;border-bottom:1px solid #f1f5f9;color:#334155;font-weight:500}.sp-table tbody tr{transition:all .25s ease}.sp-table tbody tr:hover{background:#f8fafc;transform:translateY(-2px);box-shadow:inset 4px 0 #3b82f6}.sp-table tbody tr:last-child td{border-bottom:none}.estado-badge{padding:6px 12px;border-radius:50px;font-size:12px;font-weight:600;display:inline-block}.estado-badge.pendiente{background:#fef3c7;color:#92400e}.estado-badge.aprobado{background:#dcfce7;color:#166534}.estado-badge.rechazado{background:#fee2e2;color:#991b1b}.acciones-botones{display:flex;gap:8px}.btn-aprobar,.btn-rechazar{border:none;padding:6px 10px;border-radius:8px;font-size:13px;cursor:pointer;font-weight:600;transition:.25s ease}.btn-aprobar{background:#16a34a;color:#fff}.btn-aprobar:hover{background:#15803d;transform:scale(1.05)}.btn-rechazar{background:#dc2626;color:#fff}.btn-rechazar:hover{background:#b91c1c;transform:scale(1.05)}.tabla-vacia{margin-top:28px;padding:24px;text-align:center;background:#f8fafc;border-radius:12px;color:#64748b;font-size:14px;border:1px dashed #cbd5e1;box-shadow:inset 0 0 0 2px #fff}.ver-solicitud-container{padding:30px 20px;display:flex;justify-content:center;background:#f4f6f9;min-height:auto}.ver-solicitud-card{background:#fff;width:100%;max-width:950px;border-radius:12px;padding:35px;border:1px solid #e5e7eb;box-shadow:0 4px 18px #0000000a}.ver-title{font-size:22px;font-weight:700;margin-bottom:30px;color:#111827;border-bottom:1px solid #e5e7eb;padding-bottom:12px}.ver-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px}.ver-grid div{padding-bottom:8px;border-bottom:1px solid #f1f5f9}.ver-grid div span{display:block;font-size:11px;font-weight:600;color:#9ca3af;margin-bottom:4px;text-transform:uppercase;letter-spacing:.8px}.ver-grid div p{font-size:15px;font-weight:600;color:#111827;margin:0}.ver-section{margin-bottom:25px}.ver-section span{display:block;font-size:11px;font-weight:600;color:#9ca3af;margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}.ver-section p{background:#f9fafb;padding:16px;border-radius:8px;line-height:1.6;font-size:14px;color:#374151;border:1px solid #e5e7eb;margin:0}.estado{display:inline-block;padding:5px 14px;border-radius:999px;font-size:12px;font-weight:600}.estado.aprobada,.estado.aprobado{background:#ecfdf5;color:#047857}.estado.pendiente{background:#fffbeb;color:#b45309}.estado.rechazada,.estado.rechazado{background:#fef2f2;color:#b91c1c}.ver-actions{margin-top:30px;display:flex;justify-content:flex-end}.btn-volver{padding:9px 18px;border-radius:6px;border:none;background:#111827;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:.2s ease}.btn-volver:hover{background:#374151}*{margin:0;padding:0;box-sizing:border-box;font-family:Segoe UI,sans-serif}.app-container{display:flex;min-height:100vh;background-color:#f4f6f9}.sidebar{width:260px;background-color:#111827;color:#fff;padding:20px}.sidebar h2{text-align:center;margin-bottom:30px}.sidebar h4{margin-top:20px;margin-bottom:10px;font-size:14px;color:#9ca3af;text-transform:uppercase}.sidebar ul{list-style:none}.sidebar li{margin-bottom:10px}.sidebar a{text-decoration:none;color:#e5e7eb;padding:10px;display:block;border-radius:6px;transition:background .3s}.sidebar a:hover{background-color:#1f2937}.content{flex:1;padding:30px}.card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 4px 10px #00000014;max-width:1300px;width:100%;margin:0 auto}.page-title{font-size:24px;margin-bottom:15px}.page-wrapper{width:100%;max-width:1300px;margin:0 auto}button{background-color:#2563eb;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-weight:700}button:hover{background-color:#1e40af}input,textarea{width:100%;padding:10px;margin-bottom:15px;border-radius:6px;border:1px solid #d1d5db}textarea{resize:none;height:100px}
