@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary:#10b981;--color-primary-hover:#059669;--color-secondary:#3b82f6;--color-bg-base:#0f172a;--color-bg-surface:#1e293b;--color-bg-surface-hover:#334155;--color-text-main:#f8fafc;--color-text-muted:#94a3b8;--color-success:#10b981;--color-danger:#ef4444;--color-warning:#f59e0b;--color-border:#334155;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-glow:0 0 20px #10b98133;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-bg-base);color:var(--color-text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}a{color:var(--color-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary-hover)}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.app-container{flex-direction:column;min-height:100vh;display:flex}.input-field{background-color:var(--color-bg-base);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-main);padding:.75rem 1rem;font-size:.95rem;transition:all .2s}.input-field:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #10b98133}.input-label{color:var(--color-text-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.btn-primary{background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.card{background-color:var(--color-bg-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);padding:2rem}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex;position:relative;overflow:hidden}.glow-circle{filter:blur(100px);z-index:0;opacity:.5;border-radius:50%;position:absolute}.circle-1{background-color:#10b98133;width:400px;height:400px;animation:10s ease-in-out infinite alternate float;top:-100px;right:-100px}.circle-2{background-color:#3b82f626;width:500px;height:500px;animation:12s ease-in-out infinite alternate-reverse float;bottom:-150px;left:-150px}@keyframes float{0%{transform:translateY(0)scale(1)}to{transform:translateY(30px)scale(1.05)}}.login-content{z-index:1;flex-direction:column;gap:2rem;width:100%;max-width:420px;display:flex;position:relative}.login-header{text-align:center}.logo-container{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));width:80px;height:80px;box-shadow:var(--shadow-glow);color:#fff;border-radius:24px;justify-content:center;align-items:center;margin:0 auto 1.5rem;display:flex}.login-header h1{background:linear-gradient(90deg,#f8fafc,#cbd5e1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2rem;font-weight:700}.subtitle{color:var(--color-text-muted);font-size:1.1rem}.login-card{-webkit-backdrop-filter:blur(16px);background-color:#1e293bb3;border:1px solid #ffffff0d;padding:2.5rem}.form-group{margin-bottom:1.5rem}.password-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.password-header .input-label{margin-bottom:0}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--color-text-muted);position:absolute;left:1rem}.input-field.with-icon{padding-left:3rem}.input-field:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:var(--color-primary)}.login-btn{width:100%;height:3rem;margin-top:1rem}.footer-text{text-align:center;color:var(--color-text-muted);font-size:.875rem}.password-toggle{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;right:1rem}.password-toggle:hover{color:var(--color-primary)}.input-field.with-right-icon{padding-right:3rem}.sidebar{background-color:var(--color-bg-surface);border-right:1px solid var(--color-border);flex-direction:column;width:260px;height:100%;padding:1.5rem;display:flex}.sidebar-header{align-items:center;gap:1rem;margin-bottom:2.5rem;display:flex}.logo-small{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));width:32px;height:32px;box-shadow:var(--shadow-glow);border-radius:8px}.sidebar-header h2{color:var(--color-text-main);margin:0;font-size:1.25rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:.5rem;display:flex}.nav-item{border-radius:var(--radius-md);color:var(--color-text-muted);align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:var(--color-text-main);background-color:#ffffff0d}.nav-item.active{color:var(--color-primary);background-color:#10b9811a}.sidebar-footer{border-top:1px solid var(--color-border);margin-top:auto;padding-top:1.5rem}.logout-btn{border-radius:var(--radius-md);width:100%;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;transition:all .2s;display:flex}.logout-btn:hover{color:var(--color-danger);background-color:#ef44441a}.main-layout{background-color:var(--color-bg-base);min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;height:100vh;display:flex;overflow-y:auto}.top-header{border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;background-color:#1e293b80;justify-content:space-between;align-items:center;padding:2rem 2.5rem;display:flex;position:sticky;top:0}.page-title{margin-top:0;margin-bottom:.25rem;font-size:1.5rem}.page-subtitle{color:var(--color-text-muted);margin:0;font-size:.875rem}.user-profile{cursor:pointer;align-items:center;gap:.75rem;display:flex}.avatar{background-color:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:600;display:flex}.layout-content{flex-direction:column;flex:1;gap:2rem;padding:2.5rem;display:flex}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.stat-card{align-items:flex-start;gap:1.25rem;padding:1.5rem;display:flex}.stat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon.users{color:var(--color-secondary);background-color:#3b82f61a}.stat-icon.activity{color:var(--color-primary);background-color:#10b9811a}.stat-details h3{color:var(--color-text-muted);margin-top:0;margin-bottom:.25rem;font-size:.875rem}.stat-value{margin-top:0;margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.stat-trend{font-size:.75rem;font-weight:500}.stat-trend.positive{color:var(--color-success)}.recent-activity{flex:1}.recent-activity h2{margin-top:0;margin-bottom:1.5rem;font-size:1.1rem}.activity-list{margin:0;padding:0;list-style:none}.activity-item{border-bottom:1px solid var(--color-border);padding:1rem 0}.activity-item:last-child{border-bottom:none}.empty-state{border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);justify-content:center;align-items:center;padding:3rem;display:flex}.sedes-container{padding:0;overflow:hidden}.sedes-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.sedes-header h2{margin:0;font-size:1.25rem}.table-responsive{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:1.25rem 2rem}.data-table tr:hover td{background-color:#ffffff05}.btn-icon{cursor:pointer;border-radius:var(--radius-md);color:var(--color-text-muted);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:inline-flex}.btn-icon.text-primary:hover{color:var(--color-primary);background-color:#10b9811a}.btn-icon.text-danger:hover{color:var(--color-danger);background-color:#ef44441a}.empty-icon{color:var(--color-border);margin-bottom:1rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0f172acc;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:600px;box-shadow:var(--shadow-lg);flex-direction:column;max-height:90vh;animation:.3s ease-out slideUp;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.modal-header h2{margin:0;font-size:1.25rem}.modal-form{flex-direction:column;gap:1.5rem;padding:2rem;display:flex;overflow-y:auto}.form-row{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=640px){.form-row{grid-template-columns:1fr;gap:1rem}}.modal-footer{border-top:1px solid var(--color-border);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);background-color:#1e293b4d;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;display:flex}.btn-secondary{color:var(--color-text-main);border:1px solid var(--color-border);background-color:#0000}.btn-secondary:hover{background-color:var(--color-border)}.checkbox-group{align-items:flex-end;padding-bottom:.75rem;display:flex}.checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;display:flex}.checkbox-label input[type=checkbox]{width:1.2rem;height:1.2rem;accent-color:var(--color-primary);cursor:pointer}.usuarios-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;padding:1.5rem}.filters-bar{flex-direction:column;gap:1.5rem;margin-bottom:1.5rem;display:flex}@media (width>=1024px){.filters-bar{flex-direction:row;justify-content:space-between;align-items:center}}.search-group{flex:1;max-width:400px;position:relative}.search-icon{color:#6b7280;pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{width:100%;padding-left:2.5rem!important}.dropdowns-group{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.filter-select-wrapper{min-width:160px;position:relative}.select-icon{color:#6b7280;pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.filter-select{color:#fff!important;background-color:#ffffff0d!important;border:1px solid #ffffff1a!important;padding-left:2rem!important}.filter-select option{color:#fff;background-color:#1a1f2c}.role-badge{text-transform:uppercase;border-radius:9999px;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.role-badge.admin{color:var(--color-danger);background-color:#ef44441a;border:1px solid #ef444433}.role-badge.operador{color:var(--color-success);background-color:#22c55e1a;border:1px solid #22c55e33}.role-badge.supervisor{color:var(--color-secondary);background-color:#3b82f61a;border:1px solid #3b82f633}.modal-large{max-width:700px!important}.textarea-field{resize:vertical;min-height:100px}.checkbox-group{align-items:center;margin-top:.5rem;display:flex}.checkbox-label{cursor:pointer;color:#d1d5db;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.checkbox-label input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;width:16px;height:16px}.status-badge{border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge.invalid{color:var(--color-danger);background-color:#ef44441a}.action-buttons{gap:.5rem;display:flex}.btn-icon{cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.25rem;transition:background-color .2s;display:flex}.btn-icon:hover{background-color:#ffffff1a}.text-primary{color:var(--color-secondary)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.font-semibold{font-weight:600}.text-sm{font-size:.875rem}.text-muted{color:#9ca3af}.mb-4{margin-bottom:1rem}.mt-4{margin-top:1rem}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th,.data-table td{border-bottom:1px solid #ffffff0d;padding:.75rem 1rem}.data-table th{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;background-color:#ffffff05;font-size:.75rem;font-weight:600}.data-table tr:hover{background-color:#ffffff03}.actividad-container{flex-direction:column;gap:1.5rem;display:flex}.actividad-header-actions{justify-content:space-between;align-items:center;display:flex}.last-updated{color:#9ca3af;font-size:.875rem}.kpi-grid{grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem;display:grid}@media (width>=640px){.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=1024px){.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.kpi-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;align-items:center;gap:1rem;padding:1.5rem;display:flex}.kpi-icon-wrapper{color:#fff;border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.kpi-icon-wrapper.bg-blue{color:var(--color-secondary);background-color:#3b82f633}.kpi-icon-wrapper.bg-green{color:var(--color-success);background-color:#22c55e33}.kpi-icon-wrapper.bg-yellow{color:var(--color-warning);background-color:#f55e0b33}.kpi-icon-wrapper.bg-red{color:var(--color-danger);background-color:#ef444433}.kpi-info h3{color:#9ca3af;margin:0;font-size:.875rem}.kpi-value{color:#fff;margin:.25rem 0;font-size:1.5rem;font-weight:700}.kpi-subtext{color:#6b7280;font-size:.75rem}.user-cell{align-items:center;gap:.75rem;display:flex}.user-avatar{color:#fff;background-color:#3b82f6;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:600;display:flex}.gps-count{color:#d1d5db;background-color:#ffffff0d;border-radius:4px;padding:.25rem .5rem;font-size:.75rem}.alerts-cell{gap:.5rem;display:flex}.alert-badge{border-radius:4px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.alert-badge.warning{color:var(--color-warning);background-color:#f59e0b1a}.alert-badge.danger{color:var(--color-danger);background-color:#ef44441a}.alert-badge.success{color:var(--color-success);background-color:#22c55e1a}.status-badge.sin-marcar{color:var(--color-text-muted);background-color:#9ca3af1a}.status-badge.presente{color:var(--color-success);background-color:#22c55e1a}.status-badge.en-break{color:var(--color-warning);background-color:#f59e0b1a}.status-badge.salida{color:var(--color-secondary);background-color:#3b82f61a}.status-badge.observado{color:var(--color-danger);background-color:#ef44441a}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.detalle-container{padding:1rem 0}.detalle-content-grid{grid-template-columns:1fr 2fr;gap:1.5rem;margin-top:1.5rem;display:grid}@media (width<=1024px){.detalle-content-grid{grid-template-columns:1fr}}.jornada-times{grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.5rem;display:grid}.time-item{background-color:var(--bg-color);border-radius:var(--border-radius-md);border:1px solid var(--border-color);flex-direction:column;gap:.25rem;padding:.75rem;display:flex}.time-label{color:var(--text-muted);font-size:.75rem;font-weight:500}.time-value{color:var(--text-color);font-size:1.1rem;font-weight:600}.incidencias-list{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.incidencia-item{border-radius:var(--border-radius-md);border-left:4px solid;padding:1rem}.incidencia-item.pendiente{border-color:var(--warning-color);background-color:#fef3c7}.incidencia-item.resuelto{border-color:var(--success-color);background-color:#d1fae5}.incidencia-item.atendiendo{border-color:var(--secondary-color);background-color:#dbeafe}.incidencia-header{justify-content:space-between;margin-bottom:.5rem;display:flex}.incidencia-tipo{color:var(--text-color);font-weight:600}.incidencia-hora{color:var(--text-muted);font-size:.8rem}.incidencia-desc{color:var(--text-color);font-size:.9rem}.max-h-600{max-height:600px;overflow-y:auto}.row-alert{background-color:#fef2f2!important}.row-alert:hover{background-color:#fee2e2!important}.badge-count{background-color:var(--bg-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:9999px;padding:.25rem .5rem;font-size:.8rem;font-weight:600}.status-badge.valid{color:#065f46;background-color:#d1fae5}.alert-banner{border-radius:var(--border-radius-md);padding:.5rem 1rem;font-size:.9rem;font-weight:500}.alert-banner.warning{color:#92400e;background-color:#fef3c7;border:1px solid #fcd34d}
