.sidebar{background:linear-gradient(135deg,#103053 0% 50%,#213547);color:#fff;display:flex;flex-direction:column;padding:0;box-shadow:4px 0 25px #3b82f633;position:fixed;left:0;top:0;height:100vh;overflow:hidden;transition:all .3s ease;z-index:1000}.sidebar.collapsed{width:64px}.sidebar.open,.sidebar.pinned{width:256px}.sidebar-toggle{position:absolute;top:20px;right:15px;width:32px;height:32px;background:linear-gradient(135deg,#2b4358,#103053,#213547);border:2px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:3px;transition:all .3s ease;box-shadow:0 3px 10px #fffbfb4d;z-index:1002}@keyframes pulse{0%{box-shadow:0 4px 15px #0000004d}50%{box-shadow:0 4px 20px #3b82f666}to{box-shadow:0 4px 15px #0000004d}}.sidebar.pinned .sidebar-toggle span:nth-child(1){transform:rotate(45deg) translate(5px,5px);background:linear-gradient(90deg,#fff,#f0f0f0)}.sidebar.pinned .sidebar-toggle span:nth-child(2){opacity:0;transform:scale(0)}.sidebar.pinned .sidebar-toggle span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);background:linear-gradient(90deg,#fff,#f0f0f0)}.sidebar.pinned .sidebar-toggle{animation:none;background:linear-gradient(135deg,#103053 0% 50%,#103053);border-color:#3b82f64d}.sidebar.pinned .sidebar-toggle:hover{background:linear-gradient(135deg,#103053 0% 50%,#1d4ed8);transform:scale(1.1)}.sidebar:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,#2b435826,#2135471a);pointer-events:none}.sidebar-header{padding:20px;background:linear-gradient(135deg,#103053 0% 50%,#213547);text-align:center;position:relative;z-index:1;display:flex;justify-content:center;align-items:center;min-height:80px;transition:all .3s ease}.sidebar-title{font-size:1.2rem;font-weight:700;letter-spacing:1px;text-shadow:0 2px 4px rgba(0,0,0,.3);color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-title{opacity:0;transform:translate(-20px)}.sidebar.open .sidebar-title,.sidebar.pinned .sidebar-title{opacity:1;transform:translate(0)}.sidebar nav{flex:1;display:flex;flex-direction:column;padding:20px 0;position:relative;z-index:1}.sidebar nav a{padding:15px 25px;color:#d1d5db;text-decoration:none;transition:all .3s ease;position:relative;font-weight:500;font-size:.95rem;display:flex;align-items:center;gap:12px;border-left:3px solid transparent;white-space:nowrap;overflow:hidden}.sidebar.collapsed nav a{padding:15px;justify-content:center}.sidebar.collapsed nav a span{opacity:0;transform:translate(-20px)}.sidebar.open nav a span,.sidebar.pinned nav a span{opacity:1;transform:translate(0)}.sidebar nav a span:first-child,.sidebar-dropdown-btn span:first-child{font-size:1.2rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:20px}.sidebar nav a span:last-child,.sidebar-dropdown-btn span:last-child{transition:all .3s ease}.sidebar nav a:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#103053 0% 100%);transform:scaleY(0);transition:transform .3s ease}.sidebar nav a:hover{background:linear-gradient(90deg,#2b435833,#10305326,#2135471a);color:#fff;transform:translate(5px);box-shadow:0 4px 15px #3b82f64d}.sidebar nav a:hover:before{transform:scaleY(1)}.sidebar nav a.active{background:linear-gradient(90deg,#2b43584d,#10305340,#21354733);color:#fff;border-left-color:#103053;font-weight:600;box-shadow:0 4px 15px #1030534d}.sidebar nav a.active:before{transform:scaleY(1)}.sidebar-dropdown-btn{background:none;border:none;color:#d1d5db;padding:15px 25px;cursor:pointer;transition:all .3s ease;font-size:.95rem;font-weight:500;text-align:left;width:100%;display:flex;align-items:center;gap:12px;position:relative;border-left:3px solid transparent;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-dropdown-btn{padding:15px;justify-content:center}.sidebar.collapsed .sidebar-dropdown-btn span:first-child{opacity:1;transform:translate(0)}.sidebar.collapsed .sidebar-dropdown-btn span:last-child{opacity:0;transform:translate(-20px)}.sidebar.open .sidebar-dropdown-btn span,.sidebar.pinned .sidebar-dropdown-btn span{opacity:1;transform:translate(0)}.sidebar-dropdown-btn:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#103053,#384e70,#103053);transform:scaleY(0);transition:transform .3s ease}.sidebar-dropdown-btn:after{content:"▼";font-size:.8rem;transition:transform .3s ease}.sidebar-dropdown-btn:hover{background:linear-gradient(90deg,#2b435833,#10305326,#2135471a);color:#fff;transform:translate(5px);box-shadow:0 4px 15px #3b82f64d}.sidebar-dropdown-btn:hover:before{transform:scaleY(1)}.sidebar-dropdown-btn:hover:after{transform:rotate(180deg)}.sidebar-dropdown-content{background:linear-gradient(180deg,#1f2937e6,#111827f2);border-left:3px solid #eaebec;margin-left:20px;border-radius:0 8px 8px 0;overflow:hidden;animation:slideDown .3s ease;box-shadow:0 4px 20px #3741514d}.sidebar-dropdown-content a{padding:12px 20px;color:#9ca3af;text-decoration:none;display:block;transition:all .3s ease;font-size:.9rem;border-left:2px solid transparent;position:relative}.sidebar-dropdown-content a:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#a8aaab,#384e70,#1f2937);transform:scaleY(0);transition:transform .3s ease}.sidebar-dropdown-content a:hover{background:linear-gradient(90deg,#2b435833,#10305326,#2135471a);color:#fff;transform:translate(3px);border-left-color:#103053;box-shadow:0 2px 10px #10305333}.sidebar-dropdown-content a:hover:before{transform:scaleY(1)}.sidebar-dropdown-content a.active{background:linear-gradient(90deg,#2b43584d,#10305340,#21354733);color:#fff;border-left-color:#103053;font-weight:600;box-shadow:0 2px 10px #1030534d}.sidebar-dropdown-content a.active:before{transform:scaleY(1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.sidebar{width:100%;height:auto;position:fixed;left:-100%;top:0;transform:translate(0);transition:left .3s ease;z-index:1000}.sidebar.open,.sidebar.pinned{left:0}.sidebar.hovered{left:-100%}.sidebar nav a span,.sidebar-dropdown-btn span{opacity:1!important;transform:translate(0)!important}.sidebar-toggle{position:fixed;top:25px;left:20px;right:auto;transform:none;z-index:1003}.sidebar-header{padding:15px;min-height:70px;display:flex;justify-content:center;align-items:center}.sidebar-title{font-size:1rem}.truck-icon{font-size:1.2rem}.sidebar nav{padding:10px 0}.sidebar nav a,.sidebar-dropdown-btn{padding:12px 20px;font-size:.9rem}.sidebar-dropdown-content{margin-left:15px}.mobile-menu-toggle{display:block;background:none;border:none;font-size:1.5rem;color:#103053;cursor:pointer;padding:5px}}@media (max-width: 480px){.sidebar{width:100%}.sidebar-header{padding:15px;min-height:60px}.sidebar-title{font-size:.9rem}.truck-icon{font-size:1rem}.sidebar nav a,.sidebar-dropdown-btn{padding:10px 15px;font-size:.85rem}.sidebar-dropdown-content{margin-left:10px}}.navbar{background:linear-gradient(135deg,#103053 0% 50%,#213547);padding:20px 30px;display:flex;justify-content:flex-end;align-items:center;box-shadow:0 4px 20px #0000001a;position:relative;overflow:hidden}.navbar:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,#ffffff1a,#ffffff0d);pointer-events:none}.navbar .user{display:flex;align-items:center;gap:20px;position:relative;z-index:1}.navbar .user span{color:#fff;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.2);background:#ffffff1a;padding:8px 16px;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.navbar .user .admin-icon{font-size:1.3rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));animation:pulse 2s infinite;display:flex;align-items:center;justify-content:center;background:#ffffff1a;padding:8px;border-radius:50%;border:2px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.navbar .user .admin-icon:hover{background:#fff3;transform:scale(1.1);box-shadow:0 4px 15px #ffffff4d}.navbar .user button{background:linear-gradient(135deg,#ee5a24,#d63031);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ee5a244d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);text-shadow:0 1px 2px rgba(0,0,0,.2)}.navbar .user button:hover{background:linear-gradient(135deg,#d63031,#b71c1c);transform:translateY(-2px);box-shadow:0 8px 25px #ee5a2466}.navbar .user button:active{transform:translateY(0);box-shadow:0 4px 15px #ee5a244d}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}}*{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.layout{display:flex;min-height:100vh;background-color:#f4f6f8;transition:all .3s ease}.layout-main{flex:1;display:flex;flex-direction:column;transition:all .3s ease;margin-left:64px}.sidebar.open~.layout-main,.sidebar.pinned~.layout-main{margin-left:256px}.layout-content{padding:30px;overflow-y:auto}.piloto-sidebar{background:linear-gradient(135deg,#103053 0% 50%,#213547);color:#fff;display:flex;flex-direction:column;padding:0;box-shadow:4px 0 25px #3b82f633;position:fixed;left:0;top:0;width:280px;height:100vh;overflow:hidden;transition:all .3s ease;z-index:1000}.piloto-sidebar.collapsed{width:64px}.piloto-sidebar.open,.piloto-sidebar.pinned{width:256px}.sidebar-toggle{position:absolute;top:20px;right:15px;width:32px;height:32px;background:linear-gradient(135deg,#2b4358,#103053,#213547);border:2px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:3px;transition:all .3s ease;box-shadow:0 3px 10px #0000004d;z-index:1002}.sidebar-toggle:hover{background:linear-gradient(135deg,#103053,#2b4358,#213547);transform:scale(1.15);box-shadow:0 8px 25px #00000080;border-color:#fff6}.sidebar-toggle span{width:18px;height:2px;background:linear-gradient(90deg,#fff,#f0f0f0);border-radius:2px;transition:all .3s ease;box-shadow:0 1px 3px #0000004d;transform-origin:center}.sidebar-toggle:hover span{transform:scale(1.1);background:linear-gradient(90deg,#60a5fa,#3b82f6);box-shadow:0 4px 8px #3b82f666}.sidebar-toggle:hover span:nth-child(1){transform:translateY(-2px) scale(1.1)}.sidebar-toggle:hover span:nth-child(3){transform:translateY(2px) scale(1.1)}.sidebar-toggle:active span{transform:scale(.95)}.sidebar-toggle{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 3px 10px #0000004d}50%{box-shadow:0 3px 15px #3b82f666}to{box-shadow:0 3px 10px #0000004d}}.piloto-sidebar.pinned .sidebar-toggle span:nth-child(1){transform:rotate(45deg) translate(5px,5px);background:linear-gradient(90deg,#fff,#f0f0f0)}.piloto-sidebar.pinned .sidebar-toggle span:nth-child(2){opacity:0;transform:scale(0)}.piloto-sidebar.pinned .sidebar-toggle span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);background:linear-gradient(90deg,#fff,#f0f0f0)}.piloto-sidebar.pinned .sidebar-toggle{animation:none;background:linear-gradient(135deg,#103053 0% 50%,#103053);border-color:#3b82f64d}.piloto-sidebar.pinned .sidebar-toggle:hover{background:linear-gradient(135deg,#103053 0% 50%,#1d4ed8);transform:scale(1.1)}.sidebar-header{background:#103053;text-align:center;position:relative;z-index:1;display:flex;justify-content:center;align-items:center;min-height:80px;transition:all .3s ease;padding:20px 10px}.sidebar-title{font-size:1.4rem;font-weight:700;letter-spacing:1px;text-shadow:0 2px 4px rgba(0,0,0,.3);color:#fff;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .3s ease;white-space:nowrap;overflow:hidden;width:100%;text-align:center;margin-left:-15px}.piloto-sidebar.collapsed .sidebar-title{opacity:0;transform:translate(-20px)}.piloto-sidebar.open .sidebar-title,.piloto-sidebar.pinned .sidebar-title{opacity:1;transform:translate(0)}.truck-icon{font-size:1.5rem}.company-name{font-size:1.2rem;font-weight:600;letter-spacing:1px}.pilot-info{display:flex;align-items:center;justify-content:center;gap:8px;font-size:1rem;font-weight:500}.pilot-icon{font-size:1.2rem}.pilot-name{font-size:.9rem}.piloto-sidebar nav{padding:20px 0}.piloto-sidebar nav a{padding:15px 25px;color:#d1d5db;text-decoration:none;transition:all .3s ease;position:relative;font-weight:500;font-size:.95rem;display:flex;align-items:center;gap:12px;border-left:3px solid transparent;white-space:nowrap;overflow:hidden}.piloto-sidebar.collapsed nav a{padding:15px;justify-content:center}.piloto-sidebar.collapsed nav a span{opacity:0;transform:translate(-20px)}.piloto-sidebar.open nav a span,.piloto-sidebar.pinned nav a span{opacity:1;transform:translate(0)}.piloto-sidebar nav a span:first-child{font-size:1.2rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:20px}.piloto-sidebar nav a span:last-child{transition:all .3s ease}.piloto-sidebar nav a:hover{background:#ffffff1a;border-left-color:#fff;transform:translate(5px)}.piloto-sidebar nav a.active{background:#ffffff26;border-left-color:#fff;font-weight:600}.piloto-layout{display:flex;min-height:100vh;background:#f8f9fa}.piloto-main{flex:1;margin-left:280px;display:flex;flex-direction:column}.piloto-content{flex:1;padding:30px;background:#f8f9fa;min-height:calc(100vh - 70px);display:flex;justify-content:flex-start;align-items:flex-start}.dashboard{padding:20px;background-color:#f9fafb;min-height:100vh}.dashboard h2{color:#1f2937;margin-bottom:30px;font-size:2rem;font-weight:700}.dashboard h3{color:#374151;margin-bottom:20px;font-size:1.5rem;font-weight:600}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.card{background:#fff;padding:25px;border-radius:12px;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease,box-shadow .3s ease;position:relative;overflow:hidden}.card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #00000026}.card-icon{font-size:2.5rem;margin-bottom:15px;display:flex;align-items:center;justify-content:center}.card h3{color:#374151;font-size:1.1rem;font-weight:600;margin-bottom:10px;text-align:center}.card p{color:#1f2937;font-size:2rem;font-weight:700;text-align:center;margin:0}.dashboard-section{background:#fff;border-radius:12px;padding:25px;box-shadow:0 4px 6px #0000001a;margin-bottom:20px}.rutas-por-fecha{display:flex;flex-direction:column;gap:25px}.fecha-grupo{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.fecha-header{background:linear-gradient(135deg,#103053,#213547);color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center}.fecha-header h4{margin:0;font-size:1.2rem;font-weight:600}.cantidad-badge{background:#fff3;padding:5px 12px;border-radius:20px;font-size:.9rem;font-weight:500}.rutas-tabla{overflow-x:auto}.rutas-tabla table{width:100%;border-collapse:collapse;font-size:.9rem}.rutas-tabla th{background-color:#f8fafc;color:#374151;padding:12px 8px;text-align:left;font-weight:600;border-bottom:2px solid #e5e7eb}.rutas-tabla td{padding:10px 8px;border-bottom:1px solid #f3f4f6;color:#1f2937}.rutas-tabla tr:hover{background-color:#f9fafb}.estado-badge{color:#fff;padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:500;display:inline-block}.loading{text-align:center;padding:40px;font-size:1.1rem;color:#6b7280}.sin-datos{text-align:center;padding:40px;color:#6b7280;font-style:italic}@media (max-width: 768px){.dashboard{padding:15px}.dashboard h2{font-size:1.5rem}.dashboard-cards{grid-template-columns:1fr;gap:15px}.card{padding:20px}.card-icon{font-size:2rem}.card p{font-size:1.5rem}.dashboard-section{padding:15px}.fecha-header{padding:12px 15px;flex-direction:column;gap:8px;text-align:center}.fecha-header h4{font-size:1rem}.rutas-tabla{font-size:.8rem}.rutas-tabla th,.rutas-tabla td{padding:8px 4px}}.dashboard-filtro{display:flex;align-items:center;gap:8px;background:#f8fafc;padding:8px 12px;border-radius:8px;border:1px solid #e5e7eb}.dashboard-filtro label{font-size:.9rem;font-weight:600;color:#374151;white-space:nowrap}.dashboard-filtro select{padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease}.dashboard-filtro select:hover{border-color:#103053;box-shadow:0 0 0 1px #103053}.dashboard-filtro select:focus{outline:none;border-color:#103053;box-shadow:0 0 0 2px #1030531a}@media (max-width: 768px){.dashboard{padding:10px}.dashboard-cards{grid-template-columns:1fr;gap:15px;margin-bottom:20px}.card{padding:20px;text-align:center}.card h3{font-size:1rem;margin-bottom:8px}.card p{font-size:1.5rem;font-weight:700}.dashboard-section{margin:20px 0}.dashboard-section h3{font-size:1.2rem;margin-bottom:15px}.rutas-tabla{font-size:.75rem;overflow-x:auto}.rutas-tabla th,.rutas-tabla td{padding:6px 4px;white-space:nowrap}.dashboard-filtro{flex-direction:column;align-items:stretch;gap:6px;margin-bottom:15px}.dashboard-filtro label{text-align:center;font-size:.85rem}.dashboard-filtro select{width:100%;font-size:.85rem}}@media (max-width: 480px){.dashboard{padding:5px}.dashboard-cards{gap:10px}.card{padding:15px}.card h3{font-size:.9rem}.card p{font-size:1.2rem}.rutas-tabla{font-size:.7rem}.rutas-tabla th,.rutas-tabla td{padding:4px 2px}.dashboard-section h3{font-size:1rem}}.reportes-container{max-width:1200px;margin:0 auto;padding:20px;font-family:Arial,sans-serif}.logo{max-width:150px;height:auto}.reportes-title{text-align:center;color:#2c3e50;margin-bottom:30px;font-size:2rem;font-weight:700}.filtros-container{background:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a}.filtro-group{display:inline-block;margin-right:20px;margin-bottom:15px;vertical-align:top}.filtro-group label{display:block;margin-bottom:5px;font-weight:700;color:#2c3e50}.filtro-select,.filtro-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;min-width:150px}.filtro-select:focus,.filtro-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 5px #3498db4d}.filtro-actions{display:inline-block;margin-top:20px}.btn-generar,.btn-exportar{padding:10px 20px;margin-right:10px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:background-color .3s}.btn-generar{background-color:#3498db;color:#fff}.btn-generar:hover{background-color:#2980b9}.btn-exportar{background-color:#27ae60;color:#fff}.btn-exportar:hover{background-color:#229954}.reportes-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;margin-bottom:30px}.reportes-table{width:100%;border-collapse:collapse;font-size:14px}.reportes-table th{background-color:#103053;color:#fff;padding:15px 10px;text-align:left;font-weight:700}.reportes-table td{padding:12px 10px;border-bottom:1px solid #ecf0f1}.reportes-table tr:hover{background-color:#f8f9fa}.reportes-table tr:last-child td{border-bottom:none}.no-data{text-align:center;padding:40px;color:#7f8c8d;font-style:italic}.resumen-container{background:#ecf0f1;padding:20px;border-radius:8px;margin-top:20px}.resumen-container h3{color:#2c3e50;margin-bottom:15px;text-align:center}.resumen-stats{display:flex;justify-content:space-around;flex-wrap:wrap}.stat-item{text-align:center;margin:10px;padding:15px;background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a;min-width:150px}.stat-label{display:block;font-size:12px;color:#7f8c8d;margin-bottom:5px;text-transform:uppercase;font-weight:700}.stat-value{display:block;font-size:18px;color:#2c3e50;font-weight:700}.loading-container{text-align:center;padding:40px}.loading-spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 20px}.error-message{background-color:#fee2e2;color:#dc2626;padding:12px;border-radius:4px;margin-bottom:20px;border:1px solid #fecaca}.reporte-visual-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:1000;display:flex;justify-content:center;align-items:center;padding:20px}.reporte-visual-container{background:#fff;border-radius:15px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d;position:relative}.reporte-visual-header{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:30px;text-align:center;border-radius:15px 15px 0 0;position:relative}.reporte-visual-titulo{font-size:32px;font-weight:700;margin-bottom:10px}.reporte-visual-subtitulo{font-size:18px;opacity:.9;margin-bottom:10px}.reporte-visual-fecha{font-size:14px;opacity:.8;margin-bottom:20px}.cerrar-reporte-btn{position:absolute;top:20px;right:20px;background:#fff3;border:none;color:#fff;padding:10px 15px;border-radius:50%;cursor:pointer;font-size:16px;transition:background .3s}.cerrar-reporte-btn:hover{background:#ffffff4d}.reporte-visual-estadisticas{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;padding:30px;background:#f8f9fa}.reporte-stat-card{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:25px;border-radius:15px;text-align:center;box-shadow:0 8px 16px #0000001a;transition:transform .3s}.reporte-stat-card:hover{transform:translateY(-5px)}.reporte-stat-card.verde{background:linear-gradient(135deg,#27ae60,#229954)}.reporte-stat-card.naranja{background:linear-gradient(135deg,#f39c12,#e67e22)}.reporte-stat-card.rojo{background:linear-gradient(135deg,#e74c3c,#c0392b)}.reporte-stat-card.azul{background:linear-gradient(135deg,#3498db,#2980b9)}.reporte-stat-numero{font-size:42px;font-weight:700;margin-bottom:8px}.reporte-stat-label{font-size:16px;opacity:.9;font-weight:500}.reporte-visual-graficos{padding:30px;background:#fff}.reporte-grafico-titulo{text-align:center;color:#2c3e50;font-size:24px;font-weight:700;margin-bottom:30px}.reporte-barra-container{margin:25px 0}.reporte-barra-label{display:flex;justify-content:space-between;margin-bottom:8px;font-weight:700;color:#2c3e50;font-size:16px}.reporte-barra{height:35px;border-radius:18px;background:#ecf0f1;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.reporte-barra-fill{height:100%;border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;transition:width .8s ease}.reporte-barra-fill.completadas{background:linear-gradient(90deg,#27ae60,#2ecc71)}.reporte-barra-fill.pendientes{background:linear-gradient(90deg,#f39c12,#e67e22)}.reporte-barra-fill.canceladas{background:linear-gradient(90deg,#e74c3c,#c0392b)}.reporte-barra-fill.en-curso{background:linear-gradient(90deg,#3498db,#2980b9)}.reporte-barra-fill.entregadas{background:linear-gradient(90deg,#27ae60,#2ecc71)}.reporte-barra-fill.incidentes{background:linear-gradient(90deg,#e67e22,#d35400)}.reporte-visual-tabla{margin:30px;overflow-x:auto;border-radius:10px;box-shadow:0 4px 8px #0000001a}.reporte-visual-tabla table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden}.reporte-visual-tabla th{background:#34495e;color:#fff;padding:18px;text-align:left;font-weight:700;font-size:16px}.reporte-visual-tabla td{padding:15px 18px;border-bottom:1px solid #ecf0f1;font-size:15px}.reporte-visual-tabla tr:hover{background:#f8f9fa}.reporte-visual-footer{text-align:center;padding:30px;background:#f8f9fa;border-radius:0 0 15px 15px;color:#7f8c8d;font-size:14px}.reporte-visual-footer p{margin:5px 0}.reporte-footer-actions{display:flex;justify-content:center;gap:15px;margin-bottom:15px}.btn-imprimir-pdf{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2c3e504d}.btn-imprimir-pdf:hover{background:linear-gradient(135deg,#34495e,#2c3e50);transform:translateY(-2px);box-shadow:0 6px 20px #2c3e5066}.btn-cerrar-reporte{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #e74c3c4d}.btn-cerrar-reporte:hover{background:linear-gradient(135deg,#c0392b,#e74c3c);transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c66}@media (max-width: 768px){.reportes-container{padding:10px}.filtro-group{display:block;margin-right:0;margin-bottom:15px}.filtro-select,.filtro-input{width:100%;min-width:auto}.filtro-actions{display:block;margin-top:20px}.btn-generar,.btn-exportar{display:block;width:100%;margin-bottom:10px;margin-right:0}.resumen-stats{flex-direction:column}.stat-item{margin:5px 0}.reportes-table{font-size:12px}.reportes-table th,.reportes-table td{padding:8px 5px}.reporte-visual-overlay{padding:10px}.reporte-visual-container{max-height:95vh}.reporte-visual-header{padding:20px}.reporte-visual-titulo{font-size:24px}.reporte-visual-subtitulo{font-size:16px}.reporte-visual-estadisticas{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;padding:20px}.reporte-stat-card{padding:20px}.reporte-stat-numero{font-size:32px}.reporte-visual-graficos{padding:20px}.reporte-grafico-titulo{font-size:20px}.reporte-barra{height:30px}.reporte-barra-fill{font-size:14px}.reporte-visual-tabla{margin:20px}.reporte-visual-tabla th,.reporte-visual-tabla td{padding:12px 15px;font-size:14px}}.filtro-dias{display:flex;align-items:center;gap:8px;background:#f8fafc;padding:8px 12px;border-radius:8px;border:1px solid #e5e7eb;min-width:150px}.filtro-dias label{font-size:.9rem;font-weight:600;color:#374151;white-space:nowrap}.filtro-dias select{padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease;flex:1}.filtro-dias select:hover{border-color:#103053;box-shadow:0 0 0 1px #103053}.filtro-dias select:focus{outline:none;border-color:#103053;box-shadow:0 0 0 2px #1030531a}.paginacion-container{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding:15px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.paginacion-info{font-size:.9rem;color:#6b7280;font-weight:500}.paginacion-controls{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.paginacion-elementos{display:flex;align-items:center;gap:8px;background:#f8fafc;padding:8px 12px;border-radius:6px;border:1px solid #e5e7eb}.paginacion-elementos label{font-size:.9rem;font-weight:600;color:#374151;white-space:nowrap}.paginacion-select{padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease;min-width:120px}.paginacion-select:hover{border-color:#103053;box-shadow:0 0 0 1px #103053}.paginacion-select:focus{outline:none;border-color:#103053;box-shadow:0 0 0 2px #1030531a}.paginacion-btn{padding:8px 16px;background:#103053;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:5px}.paginacion-btn:hover:not(:disabled){background:#0d2540;transform:translateY(-1px);box-shadow:0 2px 4px #10305333}.paginacion-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.paginacion-numeros{display:flex;gap:5px}.paginacion-numero{width:40px;height:40px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.paginacion-numero:hover{border-color:#103053;background:#f8fafc;transform:translateY(-1px)}.paginacion-numero.activa{background:#103053;color:#fff;border-color:#103053;box-shadow:0 2px 4px #10305333}.paginacion-numero.activa:hover{background:#0d2540;transform:translateY(-1px)}@media (max-width: 768px){.filtro-dias{flex-direction:column;align-items:stretch;gap:6px;min-width:120px}.filtro-dias label{text-align:center}.paginacion-elementos{flex-direction:column;gap:6px;min-width:120px}.paginacion-elementos label{text-align:center}.paginacion-numeros{flex-wrap:wrap;justify-content:center}.paginacion-numero{width:35px;height:35px;font-size:.8rem}.paginacion-select{min-width:100px;font-size:.8rem}.paginacion-btn{padding:6px 12px;font-size:.8rem}}.success-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:3000;animation:fadeIn .3s ease-in-out}.success-modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;max-width:400px;width:90%;animation:slideIn .3s ease-in-out}.success-modal-content{padding:30px;text-align:center}.success-icon{font-size:3rem;margin-bottom:15px;animation:bounce .6s ease-in-out}.success-title{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 10px}.success-message{font-size:1rem;color:#6b7280;margin:0 0 25px;line-height:1.5}.success-close-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.success-close-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.success-close-btn:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media (max-width: 480px){.success-modal{margin:20px;width:calc(100% - 40px)}.success-modal-content{padding:20px}.success-icon{font-size:2.5rem}.success-title{font-size:1.3rem}.success-message{font-size:.9rem}}.reutilizar-table{width:100%;min-width:1000px;table-layout:fixed;border-collapse:collapse;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.reutilizar-table{width:100%;min-width:1200px;table-layout:auto;border-collapse:collapse;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.reutilizar-table th,.reutilizar-table td{padding:14px 20px;text-align:center;border-bottom:1px solid #e5e7eb;word-wrap:break-word}.reutilizar-container h2{text-align:center;font-size:2rem;font-weight:700;margin-bottom:25px;color:#1f2937}.reutilizar-table th{background-color:#103053;color:#fff;font-weight:600;font-size:1rem;text-align:center}.reutilizar-table td{padding:12px 15px;border-bottom:1px solid #e5e7eb;text-align:center;word-wrap:break-word}.reutilizar-table th:nth-child(6),.reutilizar-table td:nth-child(6){width:100px}.view-btn{display:inline-block;padding:6px 12px;background-color:#2563eb;color:#fff;border-radius:6px;text-decoration:none;font-size:.9rem;transition:background .2s}.view-btn:hover{background-color:#1d4ed8}.reutilizar-form{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;margin-bottom:25px}.reutilizar-input,.reutilizar-select{padding:8px 12px;border:1px solid #cbd5e0;border-radius:6px}.reutilizar-button{background-color:#3b82f6;color:#fff;padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.ingresar-reutilizar-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.ingresar-reutilizar-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.ingresar-reutilizar-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.ingresar-reutilizar-form .form-group{margin-bottom:18px;text-align:left}.ingresar-reutilizar-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.ingresar-reutilizar-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;transition:.2s}.ingresar-reutilizar-form input:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}@media (max-width: 480px){.ingresar-reutilizar-container{width:90%;padding:25px 20px}}@media (max-width: 768px){.reutilizar-table th,.reutilizar-table td{font-size:.85rem;padding:8px}}.reutilizar-controls{display:flex;flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}.reutilizar-search{width:250px;padding:10px 15px;border:1px solid #d1d5db;border-radius:10px;font-size:1rem;outline:none;transition:.2s}.reutilizar-search:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}.reutilizar-page-filter{display:flex;align-items:center;gap:10px;font-size:1rem;color:#1f2937}.reutilizar-select-pages{padding:6px 12px;border-radius:8px;border:1px solid #d1d5db;font-size:1rem;cursor:pointer;outline:none;transition:.2s}.reutilizar-select-pages:focus{border-color:#6366f1;box-shadow:0 0 6px #6366f14d}.reutilizar-controls-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap}.reutilizar-pages-left,.reutilizar-search-center{display:flex;align-items:center;gap:5px;font-size:.9rem}.reutilizar-search{width:300px;padding:8px 12px;border-radius:8px;border:1px solid #cbd5e0;outline:none;font-size:1rem}.reutilizar-pagination{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:15px}.reutilizar-button{background-color:#103053;color:#fff;padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:.3s}.reutilizar-button:hover{background-color:#4b5563}.reutilizar-button:disabled{background-color:#9ca3af;cursor:not-allowed}.modal{background:#fff;padding:25px 30px;border-radius:12px;box-shadow:0 10px 25px #00000040;max-width:400px;width:90%;text-align:center;animation:fadeInScale .3s ease-in-out;position:relative;left:30px}.modal p{margin-bottom:20px;font-size:1.1rem;color:#1f2937;font-weight:500}.modal-buttons{display:flex;justify-content:space-between;gap:12px}.modal-buttons .form-button{flex:1;padding:10px 15px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;background-color:#2563eb;color:#fff;transition:background .3s}.modal-buttons .form-button:hover{background-color:#1d4ed8}.modal-buttons .close-button{flex:1;padding:10px 15px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;background-color:#ef4444;color:#fff;transition:background .3s}.modal-buttons .close-button:hover{background-color:#dc2626}.reutilizar-table{border:1px solid #cbd5e0;border-collapse:collapse}.reutilizar-table th,.reutilizar-table td{border:1px solid #cbd5e0;padding:12px 15px;text-align:center;word-wrap:break-word}.reutilizar-table th{background-color:#103053;color:#fff;font-weight:600;font-size:1rem}.reutilizar-table tr:hover{background-color:#2563eb33}html,body{height:100%;margin:0;padding:0;background-color:#f9fafb;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.rutas-container{width:100%;padding:10px;margin:0 auto;overflow-x:auto}.rutas-container h2{font-size:1.6rem;font-weight:700;margin-bottom:15px;color:#1f2937;text-align:center}.rutas-controls-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:15px}.rutas-pages-left,.rutas-search-center{display:flex;align-items:center;gap:8px;font-size:.8rem}.rutas-next-number{display:flex;align-items:center;gap:8px;font-size:.9rem;background-color:#e8f5e8;padding:8px 12px;border-radius:6px;border:1px solid #4ade80}.next-number-label{font-weight:600;color:#166534}.next-number-value{font-weight:700;color:#15803d;background-color:#dcfce7;padding:4px 8px;border-radius:4px;border:1px solid #22c55e}.rutas-search{width:200px;padding:6px 8px;border-radius:6px;border:1px solid #cbd5e0;font-size:.8rem}.rutas-select{padding:5px 8px;border-radius:6px;border:1px solid #cbd5e0;font-size:.8rem;cursor:pointer}.rutas-button{background-color:#103053;color:#fff;padding:5px 10px;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.85rem;transition:.3s}.rutas-button:hover{background-color:#4b5563}.rutas-button:disabled{background-color:#9ca3af;cursor:not-allowed}.ingresar-btn{background-color:#2563eb}.ingresar-btn:hover{background-color:#1d4ed8}.rutas-table{width:100%;min-width:1200px;border-collapse:collapse;table-layout:fixed;font-size:.75rem}.rutas-table th,.rutas-table td{padding:6px 8px;text-align:center;border:1px solid #e5e7eb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;word-break:break-word}.rutas-table th{background-color:#103053;color:#fff;font-weight:600}.rutas-table tr:hover{background-color:#2563eb33}.rutas-table select,.rutas-table input{width:100%;font-size:.75rem;padding:4px 6px;border-radius:4px;border:1px solid #cbd5e0;box-sizing:border-box}.estado-select{font-weight:600;border-radius:4px;padding:2px 4px;width:100%;font-size:.7rem;box-sizing:border-box}.rutas-table th:nth-child(1),.rutas-table td:nth-child(1){width:60px}.rutas-table th:nth-child(5),.rutas-table td:nth-child(5){width:100px}.rutas-table th:nth-child(8),.rutas-table td:nth-child(8){width:100px}.rutas-table th:nth-child(9),.rutas-table td:nth-child(9){width:100px}.rutas-table th:nth-child(12),.rutas-table td:nth-child(12){width:80px}.rutas-table th:nth-child(14),.rutas-table td:nth-child(14){width:90px}.rutas-pagination{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:15px;font-size:.8rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;padding:20px 25px;border-radius:12px;box-shadow:0 10px 25px #00000040;max-width:400px;width:90%;text-align:center;animation:fadeInScale .3s ease-in-out;position:relative}.modal p{margin-bottom:15px;font-size:1rem;color:#1f2937;font-weight:500}.modal-buttons .form-button,.modal-buttons .close-button{font-size:.85rem;padding:8px 12px}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 1024px){.rutas-table th,.rutas-table td,.rutas-search,.rutas-select,.rutas-button{font-size:.7rem;padding:3px 5px}}@media (max-width: 768px){.rutas-table th,.rutas-table td{font-size:.65rem;padding:2px 4px}.rutas-search,.rutas-select,.rutas-button{font-size:.65rem;padding:2px 3px}}.rutas-table th:nth-child(12),.rutas-table td:nth-child(12){width:auto;white-space:normal;word-break:break-word;text-align:center}.ver-chofer-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.ver-chofer-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.ver-chofer-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.ver-chofer-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.ver-chofer-form .form-group{margin-bottom:18px;text-align:left}.ver-chofer-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.ver-chofer-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;background-color:#f9fafb;color:#374151}.button-group{display:flex;justify-content:flex-end;margin-top:25px}@media (max-width: 480px){.ver-chofer-container{width:90%;padding:25px 20px}}.ingresar-chofer-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.ingresar-chofer-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.ingresar-chofer-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.ingresar-chofer-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.ingresar-chofer-form .form-group{margin-bottom:18px;text-align:left}.ingresar-chofer-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.ingresar-chofer-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;transition:.2s}.ingresar-chofer-form input:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}@media (max-width: 480px){.ingresar-chofer-container{width:90%;padding:25px 20px}}.mostrar-ayudante-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.mostrar-ayudante-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.mostrar-ayudante-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.mostrar-ayudante-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.mostrar-ayudante-form .form-group{margin-bottom:18px;text-align:left}.mostrar-ayudante-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.mostrar-ayudante-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;background-color:#f9fafb;color:#374151}@media (max-width: 480px){.mostrar-ayudante-container{width:90%;padding:25px 20px}}.ingresar-clientes-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.ingresar-clientes-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.ingresar-clientes-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.ingresar-clientes-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.ingresar-clientes-form .form-group{margin-bottom:18px;text-align:left}.ingresar-clientes-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.ingresar-clientes-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;transition:.2s}.ingresar-clientes-form input:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}@media (max-width: 480px){.ingresar-clientes-container{width:90%;padding:25px 20px}}.mostrar-clientes-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.mostrar-clientes-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.mostrar-clientes-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.mostrar-clientes-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.mostrar-clientes-form .form-group{margin-bottom:18px;text-align:left}.mostrar-clientes-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.mostrar-clientes-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;background-color:#f9fafb;color:#374151}@media (max-width: 480px){.mostrar-clientes-container{width:90%;padding:25px 20px}}.form-group input,.form-group select{padding:8px 10px;border:1px solid #ccc;border-radius:5px;font-size:14px}.ruta-number-container{display:flex;flex-direction:column;gap:8px}.ruta-number-input{width:100%;padding:8px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:16px;transition:border-color .2s ease}.ruta-number-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.next-number-indicator{display:flex;align-items:center;gap:8px;background-color:#f0f9ff;padding:8px 12px;border-radius:6px;border:1px solid #0ea5e9;font-size:14px}.indicator-label{font-weight:600;color:#0369a1}.indicator-value{font-weight:700;color:#0c4a6e;background-color:#e0f2fe;padding:4px 8px;border-radius:4px;border:1px solid #0ea5e9}.add-cliente-btn{background-color:#10b981;color:#fff;border:none;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.add-cliente-btn:hover{background-color:#059669}.mostrar-camiones-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.mostrar-camiones-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.mostrar-camiones-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.mostrar-camiones-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.mostrar-camiones-form .form-group{margin-bottom:18px;text-align:left}.mostrar-camiones-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.mostrar-camiones-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;background-color:#f9fafb;color:#374151}.button-group{display:flex;justify-content:center;margin-top:25px}.close-button{flex:1;padding:12px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:.3s;color:#fff;background-color:#103053}.close-button:hover{background-color:#4b5563}@media (max-width: 480px){.mostrar-camiones-container{width:90%;padding:25px 20px}}.editar-ayudante-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.editar-ayudante-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.editar-ayudante-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.editar-ayudante-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.editar-ayudante-form .form-group{margin-bottom:18px;text-align:left}.editar-ayudante-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.editar-ayudante-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;transition:.2s}.editar-ayudante-form input:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}@media (max-width: 480px){.editar-ayudante-container{width:90%;padding:25px 20px}}.editar-clientes-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.editar-clientes-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.editar-clientes-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.editar-clientes-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.editar-clientes-form .form-group{margin-bottom:18px;text-align:left}.editar-clientes-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.editar-clientes-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;transition:.2s}.editar-clientes-form input:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}@media (max-width: 480px){.editar-clientes-container{width:90%;padding:25px 20px}}.editar-chofer-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.editar-chofer-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.editar-chofer-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.editar-chofer-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.editar-chofer-form .form-group{margin-bottom:18px;text-align:left}.editar-chofer-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.editar-chofer-form input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;transition:.2s}.editar-chofer-form input:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}.form-button,.close-button{flex:1;padding:12px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:.3s;color:#fff;margin:0 5px;background-color:#103053}.form-button:hover,.close-button:hover{background-color:#4b5563}.form-button.ingresar-btn{background-color:#2563eb}.form-button.ingresar-btn:hover{background-color:#1d4ed8}@media (max-width: 480px){.editar-chofer-container{width:90%;padding:25px 20px}}.logo-container{margin-bottom:25px}.logo{width:120px;height:auto}.editar-rutas-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.editar-rutas-container{background-color:#fff;padding:30px 40px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:480px;max-width:95%;text-align:center}.editar-rutas-container:hover{transform:translateY(-5px);box-shadow:0 20px 40px #0003}.logo-container{margin-bottom:20px}.logo{width:80px;height:auto}.editar-rutas-title{font-size:1.9rem;margin-bottom:25px;color:#1f2937;font-weight:700}.editar-rutas-form .form-group{margin-bottom:18px;text-align:left}.editar-rutas-form label{display:block;margin-bottom:6px;color:#4b5563;font-weight:500}.editar-rutas-form input,.editar-rutas-form select{width:100%;padding:12px 14px;border-radius:10px;border:1px solid #d1d5db;outline:none;font-size:1rem;transition:.2s}.editar-rutas-form input:focus,.editar-rutas-form select:focus{border-color:#6366f1;box-shadow:0 0 8px #6366f14d}.button-group{display:flex;justify-content:space-between;margin-top:25px}.form-button,.close-button{flex:1;padding:12px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:.3s;color:#fff;margin:0 5px}.form-button{background-color:#2563eb}.form-button:hover{background-color:#1d4ed8}.close-button{background-color:#ef4444}.close-button:hover{background-color:#dc2626}.cliente-combobox-container{position:relative;width:100%}.cliente-input-wrapper{position:relative;display:flex;align-items:center}.cliente-combobox-input{width:100%;padding:8px 40px 8px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:16px;transition:border-color .2s ease;background-color:#fff}.cliente-combobox-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.cliente-dropdown-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:12px;color:#6b7280;cursor:pointer;padding:4px;transition:color .2s ease}.cliente-dropdown-btn:hover{color:#374151}.cliente-dropdown{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:2px solid #e5e7eb;border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:250px;overflow-y:auto}.cliente-dropdown-header{padding:8px 12px;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;font-weight:600;color:#374151;font-size:14px;text-align:center}.cliente-options{max-height:200px;overflow-y:auto}.cliente-option{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f1f5f9}.cliente-option:hover{background-color:#f8fafc}.cliente-option.selected{background-color:#eff6ff;color:#1d4ed8;font-weight:500}.cliente-option-name{flex:1;font-size:14px}.cliente-new-badge{background-color:#fef3c7;color:#92400e;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;margin-left:8px}.loading-container{display:flex;flex-direction:column;align-items:center;padding:40px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-container{text-align:center;padding:40px}.error-message{color:#dc2626;font-size:16px;margin-bottom:20px}@media (max-width: 480px){.editar-rutas-container{width:90%;padding:25px 20px}}.ingresar-ruta-wrapper{display:flex;justify-content:center;padding:30px 10px;min-height:100vh;background:linear-gradient(135deg,#e0e7ff,#213547);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.ingresar-ruta-container{background-color:#fff;padding:25px 30px;border-radius:15px;box-shadow:0 10px 25px #00000026;width:500px;max-width:95%}.logo-container{text-align:center;margin-bottom:20px}.logo{width:120px}.ingresar-ruta-title{text-align:center;font-size:24px;font-weight:600;margin-bottom:20px}.ingresar-ruta-form{display:flex;flex-wrap:wrap;gap:15px 20px}.form-row{display:flex;gap:20px;width:100%}.form-group{flex:1;display:flex;flex-direction:column}.form-group.full-width{flex:1 1 100%}.form-group label{margin-bottom:5px;font-weight:500;text-align:left}.form-group input,.form-group select{padding:8px 10px;border:1px solid #ccc;border-radius:5px;font-size:14px;background-color:#f3f4f6}.small-input{max-width:150px}.full-input{width:100%}.button-group{width:100%;display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.form-button{padding:10px 18px;border:none;border-radius:6px;cursor:pointer;font-weight:500;background-color:#2563eb;color:#fff}.close-button{padding:10px 18px;border:none;border-radius:6px;cursor:pointer;font-weight:500;background-color:#e5e7eb;color:#111827}@media (max-width: 700px){.form-row{flex-direction:column}.small-input,.full-input{max-width:100%}}.login-container{height:100vh;width:100%;background:linear-gradient(135deg,#1a3755,#2b4a6b,#1a3755);display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:url(/assets/5-DoSBYVCE.jpeg) no-repeat center center/cover;opacity:.4;z-index:1;filter:blur(1px)}.login-card{background:#fffffff2;padding:40px 30px;border-radius:16px;box-shadow:0 8px 32px #1a37554d;text-align:center;width:100%;max-width:400px;animation:fadeIn .6s ease-in-out;position:relative;z-index:2;border:1px solid rgba(26,55,85,.1)}.login-logo{width:100px;margin-bottom:15px}.login-header{text-align:center;margin-bottom:25px}.company-logo{width:140px;height:90px;margin:0 auto 15px;display:block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));border-radius:15px;background:#ffffff1a;padding:8px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.login-title{font-size:1.8rem;font-weight:700;margin:0 0 8px;color:#1a3755;text-shadow:0 2px 4px rgba(26,55,85,.1)}.login-subtitle{font-size:.9rem;color:#6b7280;font-weight:500;margin:0 0 20px;text-align:center;opacity:.8}.login-card input{width:100%;padding:14px 18px;margin:12px 0;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;outline:none;transition:all .3s ease;background:#fffffff2;box-shadow:0 2px 4px #0000000d;font-weight:500}.login-card input:focus{border-color:#1a3755;box-shadow:0 0 0 4px #1a375526,0 4px 8px #0000001a;background:#fff;transform:translateY(-1px)}.login-card input:hover{border-color:#9ca3af;box-shadow:0 2px 8px #00000014}.login-card input::placeholder{color:#9ca3af;font-weight:400}.login-card button{width:100%;padding:16px 20px;background:linear-gradient(135deg,#1a3755,#2b4a6b);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;margin-top:25px;transition:all .3s ease;box-shadow:0 4px 15px #1a37554d;position:relative;overflow:hidden}.login-card button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-card button:hover{background:linear-gradient(135deg,#2b4a6b,#1a3755);transform:translateY(-3px);box-shadow:0 8px 25px #1a375566}.login-card button:hover:before{left:100%}.login-card button:active{transform:translateY(-1px);box-shadow:0 4px 15px #1a37554d}.login-card label{display:block;text-align:left;margin-bottom:8px;color:#1a3755;font-weight:600;font-size:.95rem;letter-spacing:.3px}.error-text{color:#dc2626;font-size:.875rem;margin-top:10px;text-align:center;background:#fef2f2;padding:8px 12px;border-radius:6px;border:1px solid #fecaca}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.company-logo{width:130px;height:80px}}@media (max-width: 480px){.login-card{margin:20px;padding:30px 20px}.login-title{font-size:1.5rem}.login-subtitle{font-size:.8rem}.company-logo{width:120px;height:70px}}.piloto-rutas-container{padding:20px 20px 20px 0;max-width:1200px;width:100%;box-sizing:border-box;display:flex;flex-direction:column;align-items:flex-start;margin:0 0 0 -50px}.piloto-header{text-align:center;margin-bottom:30px;padding:20px;background:#103053;color:#fff;border-radius:10px;width:100%;max-width:1200px}.piloto-header h1{margin:0 0 10px;font-size:2rem}.piloto-header p{margin:0 0 15px;opacity:.9}.btn-recargar{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);padding:10px 20px;border-radius:25px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;margin-top:10px}.btn-recargar:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.btn-recargar:disabled{opacity:.6;cursor:not-allowed}.loading{text-align:center;padding:50px;font-size:1.2rem;color:#666}.error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:5px;margin-bottom:20px;border:1px solid #f5c6cb;width:100%;max-width:1200px;text-align:left;margin-left:-30px}.no-rutas{display:flex;justify-content:flex-start;align-items:center;min-height:400px;text-align:left;width:100%;max-width:1200px;margin-left:-30px}.no-rutas-content{background:#fff;padding:40px;border-radius:15px;box-shadow:0 4px 6px #0000001a;border:2px dashed #dee2e6;max-width:400px}.no-rutas-content h3{color:#6c757d;margin:0 0 15px;font-size:1.5rem}.no-rutas-content p{color:#868e96;margin:0 0 15px;font-size:1rem}.piloto-info{background:#0000000d;padding:15px;border-radius:8px;margin-top:15px;border-left:4px solid #007bff}.piloto-info p{margin:5px 0;color:#555;font-size:14px}.rutas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:30px;width:100%;max-width:1200px;justify-content:flex-start;margin-left:-30px}.ruta-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 4px 6px #0000001a;border:1px solid #e9ecef;transition:transform .2s,box-shadow .2s}.ruta-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.ruta-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #f8f9fa}.ruta-header h3{margin:0;color:#333;font-size:1.3rem}.estado-badge{padding:5px 12px;border-radius:20px;color:#fff;font-weight:700;font-size:.9rem;text-transform:uppercase}.ruta-info{margin-bottom:15px}.ruta-info p{margin:8px 0;color:#555;font-size:.95rem}.ruta-info strong{color:#333;font-weight:600}.btn-cambiar-estado{width:100%;background:#007bff;color:#fff;border:none;padding:12px;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-cambiar-estado:hover{background:#0056b3}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:10px;width:90%;max-width:500px;box-shadow:0 10px 25px #0003}.modal-content h3{margin:0 0 20px;color:#333;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.estado-select{width:100%;padding:10px;border:2px solid #e9ecef;border-radius:6px;font-size:1rem;background:#fff;cursor:pointer}.estado-select:focus{outline:none;border-color:#007bff}.comentario-textarea{width:100%;padding:10px;border:2px solid #e9ecef;border-radius:6px;font-size:1rem;font-family:inherit;resize:vertical;min-height:80px}.comentario-textarea:focus{outline:none;border-color:#007bff}.modal-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:25px}.btn-cancelar{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.btn-cancelar:hover{background:#545b62}.btn-guardar{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.btn-guardar:hover{background:#1e7e34}.usuarios-container{padding:20px;background-color:#f8f9fa;min-height:100vh}.usuarios-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a}.usuarios-header h1{color:#2c3e50;margin:0;font-size:2rem;font-weight:600}.main-form-container{background:#fff;padding:30px;border-radius:15px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px}.form-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.form-container{background:#fff;padding:30px;border-radius:15px;box-shadow:0 10px 30px #0000004d;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.form-container h2{color:#2c3e50;margin-bottom:25px;text-align:center;font-size:1.5rem}.usuario-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;color:#2c3e50;margin-bottom:8px;font-size:.9rem}.form-group input,.form-group select{padding:12px;border:2px solid #e1e8ed;border-radius:8px;font-size:1rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.password-input-group{display:flex;gap:10px;align-items:center}.password-input-group input{flex:1}.btn-hash{background:#f39c12;color:#fff;border:none;padding:12px;border-radius:8px;cursor:pointer;font-size:1.2rem;transition:all .3s ease;min-width:50px}.btn-hash:hover{background:#e67e22;transform:scale(1.05)}.permissions-field{display:flex;flex-direction:column;gap:10px}.permissions-button{background:#f8f9fa;border:2px dashed #bdc3c7;color:#7f8c8d;padding:15px;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease;text-align:left;min-height:50px;display:flex;align-items:center;justify-content:space-between}.permissions-button:hover{background:#e3f2fd;border-color:#3498db;color:#3498db}.permissions-button:after{content:"⚙️";font-size:1.2rem}.selected-permissions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.permission-tag{background:#e8f5e8;color:#27ae60;padding:4px 8px;border-radius:12px;font-size:.8rem;font-weight:500;border:1px solid #27ae60}.pilot-info{display:flex;align-items:center;gap:10px;background:#e3f2fd;border:1px solid #3498db;border-radius:8px;padding:12px 15px;margin-top:10px}.info-icon{font-size:1.2rem;color:#3498db}.info-text{color:#2c3e50;font-size:.9rem;line-height:1.4}.form-actions{display:flex;gap:15px;justify-content:center;margin-top:25px;padding-top:20px;border-top:1px solid #e1e8ed}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 25px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #3498db4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.btn-secondary{background:#95a5a6;color:#fff;border:none;padding:12px 25px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#7f8c8d;transform:translateY(-1px)}.usuarios-table-container{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.usuarios-table{width:100%;border-collapse:collapse}.usuarios-table th{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:15px 12px;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.usuarios-table td{padding:15px 12px;border-bottom:1px solid #e1e8ed;font-size:.9rem}.usuarios-table tbody tr:hover{background-color:#f8f9fa}.usuarios-table tbody tr:last-child td{border-bottom:none}.role-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-piloto{background:#e8f5e8;color:#27ae60;border:1px solid #27ae60}.role-administrador{background:#fef9e7;color:#f39c12;border:1px solid #f39c12}.role-gestor{background:#e3f2fd;color:#3498db;border:1px solid #3498db}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-activo{background:#e8f5e8;color:#27ae60;border:1px solid #27ae60}.status-inactivo{background:#fdf2f2;color:#e74c3c;border:1px solid #e74c3c}.piloto-assigned{background:#e8f5e8;color:#27ae60;padding:4px 8px;border-radius:12px;font-size:.8rem;font-weight:500;border:1px solid #27ae60}.no-piloto{color:#bdc3c7;font-style:italic}.loading-pilotos{display:flex;align-items:center;gap:10px;padding:12px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;color:#7f8c8d;font-size:.9rem}.loading-spinner-small{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.action-buttons{display:flex;gap:8px;justify-content:center}.action-buttons button{background:none;border:none;padding:8px;border-radius:6px;cursor:pointer;font-size:1.2rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:35px;height:35px}.btn-edit{background:#fef9e7;color:#f39c12}.btn-edit:hover{background:#f39c12;color:#fff;transform:scale(1.1)}.btn-delete{background:#fdf2f2;color:#e74c3c}.btn-delete:hover{background:#e74c3c;color:#fff;transform:scale(1.1)}.btn-status{background:#f39c12;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .3s ease;margin:0 2px}.btn-status:hover{transform:scale(1.1)}.btn-activate{background:#27ae60}.btn-activate:hover{background:#229954}.btn-deactivate{background:#e74c3c}.btn-deactivate:hover{background:#c0392b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-container{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000004d;max-width:600px;width:90%;max-height:80vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.modal-header h3{margin:0;color:#2c3e50;font-size:1.5rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#7f8c8d;padding:5px;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.modal-close:hover{background:#e74c3c;color:#fff}.modal-body{padding:30px;max-height:400px;overflow-y:auto}.permissions-list{display:flex;flex-direction:column;gap:15px}.permission-item{border:1px solid #e0e0e0;border-radius:10px;padding:15px;transition:all .3s ease}.permission-item:hover{border-color:#3498db;box-shadow:0 2px 8px #3498db1a}.permission-checkbox{display:flex;align-items:flex-start;cursor:pointer;gap:15px}.permission-checkbox input[type=checkbox]{display:none}.checkmark{width:20px;height:20px;border:2px solid #bdc3c7;border-radius:4px;position:relative;transition:all .3s ease;flex-shrink:0;margin-top:2px}.permission-checkbox input[type=checkbox]:checked+.checkmark{background:#3498db;border-color:#3498db}.permission-checkbox input[type=checkbox]:checked+.checkmark:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:14px}.permission-info{flex:1}.permission-name{font-weight:600;color:#2c3e50;font-size:1.1rem;margin-bottom:5px;text-transform:capitalize}.permission-description{color:#7f8c8d;font-size:.9rem;line-height:1.4}.modal-footer{display:flex;justify-content:flex-end;gap:15px;padding:20px 30px;border-top:1px solid #e0e0e0;background:#f8f9fa}.loading-permissions{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-permissions{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:#7f8c8d}.no-permissions p{margin-bottom:20px;font-size:1.1rem}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:1.2rem;color:#7f8c8d}.permisos-button-container{display:flex;flex-direction:column;gap:15px}.btn-permissions{background:#103053;color:#fff;border:none;border-radius:8px;padding:12px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;box-shadow:0 2px 4px #0000001a}.btn-permissions:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003;background:#0d2540}.selected-permissions{background:#f8f9fa;border:1px solid #e5e7eb;border-radius:8px;padding:15px}.selected-permissions strong{color:#374151;font-size:14px;display:block;margin-bottom:10px}.permissions-list{display:flex;flex-wrap:wrap;gap:8px}.permission-tag{background:#3b82f6;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.user-role-info{display:flex;align-items:flex-start;gap:10px;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:12px;margin-top:10px}.user-role-info .info-icon{font-size:16px;flex-shrink:0}.user-role-info .info-text{color:#92400e;font-size:14px;line-height:1.4}.user-role-info .info-text strong{color:#78350f;font-weight:600}.permisos-group{width:100%}.permisos-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:15px;margin-top:10px;max-height:400px;overflow-y:auto;padding:10px;border:1px solid #e5e7eb;border-radius:8px;background-color:#f9fafb}.permiso-item{background:#fff;border-radius:8px;padding:0;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.permiso-item:hover{box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.permiso-checkbox{display:flex;align-items:flex-start;padding:15px;cursor:pointer;border-radius:8px;transition:background-color .2s ease;position:relative}.permiso-checkbox:hover{background-color:#f3f4f6}.permiso-checkbox input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{height:20px;width:20px;background-color:#e5e7eb;border-radius:4px;margin-right:12px;flex-shrink:0;position:relative;transition:all .2s ease;border:2px solid #d1d5db}.permiso-checkbox:hover .checkmark{background-color:#d1d5db;border-color:#9ca3af}.permiso-checkbox input:checked~.checkmark{background-color:#3b82f6;border-color:#3b82f6}.checkmark:after{content:"";position:absolute;display:none;left:6px;top:2px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.permiso-checkbox input:checked~.checkmark:after{display:block}.permiso-info{display:flex;flex-direction:column;gap:4px;flex:1}.permiso-nombre{font-weight:600;color:#1f2937;font-size:14px;text-transform:capitalize}.permiso-descripcion{font-size:12px;color:#6b7280;line-height:1.4}@media (max-width: 768px){.permisos-container{grid-template-columns:1fr;gap:10px}.permiso-checkbox{padding:12px}.permiso-nombre{font-size:13px}.permiso-descripcion{font-size:11px}}@media (max-width: 768px){.usuarios-container{padding:10px}.usuarios-header{flex-direction:column;gap:15px;text-align:center}.form-row{grid-template-columns:1fr}.form-container{width:95%;padding:20px}.usuarios-table-container{overflow-x:auto}.usuarios-table{min-width:600px}.action-buttons{flex-direction:column;gap:5px}}@media (max-width: 480px){.usuarios-header h1{font-size:1.5rem}.form-actions{flex-direction:column;gap:10px}.btn-primary,.btn-secondary{width:100%;padding:12px;font-size:.9rem}.form-container{width:100%;padding:15px;margin:10px}.form-group{margin-bottom:15px}.form-group label{font-size:.9rem;margin-bottom:5px}.form-group input,.form-group select{padding:10px;font-size:.9rem}.permisos-button-container{gap:10px}.btn-permissions{padding:10px 15px;font-size:.85rem}.usuarios-table{font-size:.7rem}.usuarios-table th,.usuarios-table td{padding:6px 4px}.action-buttons{flex-direction:column;gap:3px}.action-buttons button{padding:6px;font-size:1rem}}
