@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";html{font-size:13.5px}: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}.modal-overlay .modal-content,.modal-overlay .hm-shell{zoom:1.25}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:.75rem;display:flex;position:fixed;top:1.5rem;right:1.5rem}.toast-item{pointer-events:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;background:#1e293be6;border:1px solid #ffffff1a;border-radius:12px;align-items:center;gap:.75rem;min-width:300px;max-width:450px;padding:1rem;animation:.3s ease-out toast-in;display:flex;box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0003}.toast-item.success{border-left:4px solid var(--color-success)}.toast-item.success .toast-icon{color:var(--color-success)}.toast-item.error{border-left:4px solid var(--color-danger)}.toast-item.error .toast-icon{color:var(--color-danger)}.toast-item.warning{border-left:4px solid var(--color-warning)}.toast-item.warning .toast-icon{color:var(--color-warning)}.toast-item.info{border-left:4px solid var(--color-secondary)}.toast-item.info .toast-icon{color:var(--color-secondary)}.toast-message{flex:1;font-size:.925rem;font-weight:500}.toast-close{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.toast-close:hover{color:#fff;background:#ffffff0d}@keyframes toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.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;width:100%;display:flex;position:relative}.input-icon{color:var(--color-text-muted);pointer-events:none;z-index:10;transition:color .2s;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.input-field.with-icon{padding-left:3.5rem!important}.input-field.with-right-icon{padding-right:3.5rem!important}.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);z-index:10;background:0 0;border:none;align-items:center;padding:.25rem;transition:all .2s;display:flex;position:absolute;right:1.25rem}.password-toggle:hover{color:var(--color-primary);transform:scale(1.1)}.input-field:focus{box-shadow:0 0 0 3px #10b9811a, var(--shadow-glow);background-color:#0f172ae6}.sidebar{background-color:var(--color-bg-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;width:16.25rem;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:2rem;height:2rem;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}.sidebar-close-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;transition:all .2s;display:none}.sidebar-close-btn:hover{color:var(--color-text-main);background-color:#ffffff0d}.sidebar-overlay{display:none}@media (width<=1024px){.sidebar{z-index:1000;height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:10px 0 30px #00000080}.sidebar.open{transform:translate(0)}.sidebar-close-btn{justify-content:center;align-items:center;display:flex}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;background-color:#0f172abf;width:100vw;height:100vh;animation:.2s ease-out fadeInOverlay;display:block;position:fixed;top:0;left:0}.sidebar-header{justify-content:space-between;width:100%}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.main-layout{background-color:var(--color-bg-base);height:100vh;display:flex;overflow:hidden}.main-content{zoom:.8;flex-direction:column;flex:1;width:125%;height:125vh;display:flex;overflow:hidden}.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}.header-left{align-items:center;gap:1.25rem;display:flex}.menu-toggle-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.5rem;transition:all .2s;display:none}.menu-toggle-btn:hover{color:var(--color-text-main);background-color:#ffffff0d}.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:2.5rem;height:2.5rem;font-weight:600;display:flex}.layout-content{flex-direction:column;flex:1;gap:2rem;padding:2.5rem;display:flex;overflow-y:auto}@media (width<=1024px){.main-content{zoom:1;width:100%;height:100%}.menu-toggle-btn{justify-content:center;align-items:center;display:flex}.top-header{padding:1.25rem 1.5rem}.layout-content{gap:1.5rem;padding:1.5rem}}@media (width<=640px){.top-header{padding:1rem}.layout-content{gap:1.25rem;padding:1rem}.user-profile span{display:none}}.dashboard-content{flex-direction:column;gap:2rem;padding-bottom:2rem;display:flex}.dashboard-filter-bar{border:1px solid var(--color-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e293b66;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.filter-group{align-items:center;gap:.75rem;display:flex}.filter-label{color:var(--color-text-muted);font-size:.875rem;font-weight:500}.select-input{border:1px solid var(--color-border);color:var(--color-text-main);border-radius:var(--radius-md);cursor:pointer;background:#0f172a;outline:none;padding:.5rem 1rem;font-size:.875rem;transition:border-color .2s}.select-input:focus{border-color:var(--color-primary)}.date-badge-group{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#0f172a;padding:.25rem;display:flex}.date-btn{color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;padding:.375rem 1rem;font-size:.875rem;transition:all .2s}.date-btn.active{background:var(--color-primary);color:#fff;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;display:grid}.stat-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#0f172a66;align-items:center;gap:1.25rem;padding:1.5rem;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;position:relative;overflow:hidden}.stat-card:hover{border-color:#10b98166;transform:translateY(-4px);box-shadow:0 10px 25px -5px #0000004d,0 0 15px -3px #10b98126}.stat-icon-wrapper{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:3.25rem;height:3.25rem;font-size:1.25rem;display:flex}.stat-icon-wrapper.blue{color:#60a5fa;background:#3b82f626}.stat-icon-wrapper.green{color:#34d399;background:#10b98126}.stat-icon-wrapper.yellow{color:#fbbf24;background:#f59e0b26}.stat-icon-wrapper.red{color:#f87171;background:#ef444426}.stat-icon-wrapper.purple{color:#a78bfa;background:#8b5cf626}.stat-info{flex-direction:column;display:flex}.stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8125rem;font-weight:500}.stat-value{color:var(--color-text-main);margin:.15rem 0;font-size:1.625rem;font-weight:700}.stat-subtext{color:var(--color-text-muted);font-size:.75rem}.dashboard-charts-row{grid-template-columns:2fr 1fr;gap:1.5rem;display:grid}.dashboard-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#0f172a66;flex-direction:column;padding:1.5rem;display:flex}.section-header{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;display:flex}.section-header h2{color:var(--color-text-main);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;display:flex}.empty-chart{min-height:220px;color:var(--color-text-muted);text-align:center;border:1px dashed var(--color-border);border-radius:var(--radius-md);background:#ffffff03;flex:1;justify-content:center;align-items:center;padding:2rem;font-size:.875rem;display:flex}.donut-chart-container{flex-direction:column;align-items:center;gap:1.5rem;padding:.5rem 0;display:flex}.donut-chart-svg-wrapper{width:150px;height:150px;position:relative}.donut-total-num{fill:var(--color-text-main);font-size:24px;font-weight:700}.donut-total-lbl{fill:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.donut-legend{flex-direction:column;gap:.5rem;width:100%;display:flex}.legend-item{align-items:center;font-size:.8125rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-right:.75rem;display:inline-block}.legend-label{color:var(--color-text-main);flex-grow:1}.legend-value{color:var(--color-text-muted);font-weight:500}.bar-chart-container{flex-direction:column;gap:1.5rem;height:100%;display:flex}.bar-chart-bars{justify-content:space-between;align-items:flex-end;gap:.5rem;height:250px;padding-top:1rem;display:flex;overflow-x:auto}.bar-column-wrapper{flex-direction:column;flex:1;align-items:center;gap:.75rem;min-width:32px;display:flex}.bar-stacked-track{background:#ffffff08;border-radius:4px;flex-direction:column;justify-content:flex-end;width:16px;height:200px;display:flex;position:relative;overflow:hidden}.bar-segment{cursor:pointer;width:100%;transition:height .6s cubic-bezier(.4,0,.2,1);position:relative}.bar-segment.completa{background-color:var(--color-success)}.bar-segment.incompleta{background-color:var(--color-warning)}.bar-segment.ausente{background-color:var(--color-danger)}.bar-segment:hover{filter:brightness(1.25)}.bar-segment .tooltip-text{visibility:hidden;color:#fff;text-align:center;white-space:nowrap;z-index:10;border:1px solid var(--color-border);background-color:#0f172a;border-radius:4px;padding:4px 8px;font-size:.75rem;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000080}.bar-segment:hover .tooltip-text{visibility:visible}.bar-label{color:var(--color-text-muted);text-align:center;font-size:.75rem}.bar-legend{justify-content:center;gap:1.5rem;display:flex}.bar-legend .legend-dot.completa{background-color:var(--color-success)}.bar-legend .legend-dot.incompleta{background-color:var(--color-warning)}.bar-legend .legend-dot.ausente{background-color:var(--color-danger)}.horizontal-bar-chart{flex-direction:column;gap:1rem;display:flex}.horizontal-bar-row{flex-direction:column;gap:.375rem;display:flex}.bar-label-container{justify-content:space-between;font-size:.8125rem;display:flex}.row-label{color:var(--color-text-main);font-weight:500}.row-value{color:var(--color-text-muted)}.bar-track{background:#ffffff0d;border-radius:4px;height:8px;overflow:hidden}.bar-fill{border-radius:4px;height:100%;transition:width .8s ease-in-out}.dashboard-grid-secondary{grid-template-columns:1.5fr 1fr;gap:1.5rem;display:grid}.activity-feed-wrapper{max-height:480px;padding-right:.5rem;overflow-y:auto}.activity-timeline{flex-direction:column;gap:1.25rem;display:flex}.timeline-item{gap:1rem;display:flex;position:relative}.timeline-item:not(:last-child):after{content:"";background-color:var(--color-border);width:2px;position:absolute;top:24px;bottom:-16px;left:11px}.timeline-icon{border:2px solid var(--color-primary);width:24px;height:24px;color:var(--color-primary);z-index:1;background-color:#0f172a;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;display:flex}.timeline-icon.danger{border-color:var(--color-danger);color:var(--color-danger)}.timeline-icon.warning{border-color:var(--color-warning);color:var(--color-warning)}.timeline-icon.success{border-color:var(--color-success);color:var(--color-success)}.timeline-icon.info{border-color:var(--color-info);color:var(--color-info)}.timeline-content{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffff05;flex-direction:column;flex:1;gap:.25rem;padding:.75rem 1rem;display:flex}.timeline-header{justify-content:space-between;align-items:center;display:flex}.timeline-user-info{flex-direction:column;display:flex}.timeline-user{color:var(--color-text-main);font-size:.875rem;font-weight:600}.timeline-role{color:var(--color-text-muted);font-size:.75rem}.timeline-time-badge{color:var(--color-text-muted);align-items:center;gap:.25rem;font-size:.75rem;display:flex}.timeline-desc{color:var(--color-text-muted);margin:.25rem 0 0;font-size:.8125rem}.timeline-sede-badge{color:var(--color-text-muted);border:1px solid var(--color-border);background:#ffffff0d;border-radius:4px;width:fit-content;margin-top:.25rem;padding:1px 6px;font-size:.7rem}.operational-status{flex-direction:column;gap:1.25rem;display:flex}.status-metric-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffff05;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.status-metric-header{color:var(--color-text-muted);justify-content:space-between;align-items:center;font-size:.8125rem;font-weight:500;display:flex}.status-metric-value{color:var(--color-text-main);font-size:1.375rem;font-weight:700}.progress-bar{background-color:#ffffff0d;border-radius:3px;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .6s}.progress-fill.success{background-color:var(--color-success)}.progress-fill.warning{background-color:var(--color-warning)}.progress-fill.danger{background-color:var(--color-danger)}.progress-fill.info{background-color:var(--color-info)}.quick-actions-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem;display:grid}.action-btn-redesign{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-main);cursor:pointer;background:#ffffff05;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:1.25rem 1rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.action-btn-redesign:hover{border-color:var(--color-primary);background:#10b98114;transform:translateY(-2px);box-shadow:0 4px 12px #10b9811a}.action-btn-redesign .icon-container{color:var(--color-primary);font-size:1.25rem}.action-btn-redesign span{text-align:center;font-size:.8125rem;font-weight:500}.animate-in{opacity:0;animation:.4s ease-out forwards slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=1024px){.dashboard-charts-row,.dashboard-charts-row.three-cols,.dashboard-grid-secondary{grid-template-columns:1fr}}@media (width<=768px){.dashboard-filter-bar{flex-direction:column;align-items:flex-start}}.dashboard-charts-row.three-cols{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.pulse-badge{color:var(--color-success);background:#10b9811a;border:1px solid #10b98133;border-radius:12px;align-items:center;gap:.5rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:flex}.pulse-dot{background-color:var(--color-success);border-radius:50%;width:8px;height:8px;animation:1.5s infinite pulse;box-shadow:0 0 #10b981b3}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.gps-tracking-summary{flex-direction:column;gap:1rem;display:flex}.gps-stats-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.gps-stat-mini{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffff05;flex-direction:column;gap:.25rem;padding:.75rem;display:flex}.gps-stat-label{color:var(--color-text-muted);font-size:.75rem}.gps-stat-val{color:var(--color-text-main);font-size:1.125rem;font-weight:700}.gps-stat-val.alert{color:var(--color-danger)}.latest-locations-list{flex-direction:column;gap:.75rem;display:flex}.location-item-mini{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffff03;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.loc-user-info{flex-direction:column;gap:.15rem;display:flex}.loc-username{color:var(--color-text-main);font-size:.8125rem;font-weight:600}.loc-time{color:var(--color-text-muted);font-size:.7rem}.loc-details{flex-direction:column;align-items:flex-end;gap:.25rem;display:flex}.loc-status-badge{border-radius:4px;padding:.125rem .5rem;font-size:.7rem;font-weight:600}.loc-status-badge.inside{color:var(--color-success);background:#10b9811a}.loc-status-badge.outside{color:var(--color-danger);background:#ef44441a}.loc-battery{color:var(--color-text-muted);font-size:.7rem}.empty-state-mini{text-align:center;color:var(--color-text-muted);border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:1rem;font-size:.75rem}.dashboard-empty-state{text-align:center;border-radius:var(--radius-lg);background:#1e293b26;border:1.5px dashed #ffffff12;flex-direction:column;justify-content:center;align-items:center;height:100%;min-height:250px;padding:2.5rem 1.5rem;display:flex}.empty-state-icon-wrapper{color:var(--color-text-muted);background:#ffffff05;border:1px solid #ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:3.25rem;height:3.25rem;margin-bottom:.875rem;display:flex}.empty-state-icon{color:var(--color-primary);opacity:.8}.empty-state-title{color:var(--color-text-main);margin-bottom:.375rem;font-size:.9rem;font-weight:600}.empty-state-desc{color:var(--color-text-muted);max-width:280px;margin-bottom:1rem;font-size:.75rem;line-height:1.45}.empty-state-example{border-radius:var(--radius-md);text-align:left;background:#3b82f60a;border:1px solid #3b82f61a;flex-direction:column;gap:.15rem;max-width:300px;padding:.5rem .75rem;display:flex}.example-tag{color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem;font-weight:700}.example-text{color:var(--color-text-muted);font-size:.7rem;line-height:1.3}.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 th,.data-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:1.25rem 2rem}.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;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.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);zoom:1.25;flex-direction:column;max-height:90vh;animation:.3s ease-out slideUp;display:flex;overflow:hidden}.modal-header h2{margin:0;font-size:1.15rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=640px){.form-row{grid-template-columns:1fr;gap:.75rem}}.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;flex-shrink:0;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;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}.modal-content.modal-large{flex-direction:column!important;width:95%!important;max-width:1400px!important;height:90vh!important;max-height:90vh!important;padding:0!important;display:flex!important}.modal-content.modal-large .modal-form{flex-direction:column!important;flex:1!important;height:calc(90vh - 72px)!important;max-height:calc(90vh - 72px)!important;padding:0!important;display:flex!important;overflow:hidden!important}.modal-layout-grid{box-sizing:border-box!important;flex:1!important;grid-template-columns:35fr 65fr!important;gap:2rem!important;height:calc(100% - 76px)!important;padding:1rem 2rem .5rem!important;display:grid!important;overflow:hidden!important}.form-column{box-sizing:border-box!important;height:100%!important;padding-right:.75rem!important;display:block!important;overflow-y:auto!important}.form-column>.form-row,.form-column>.form-group{margin-bottom:1.25rem}.form-column>:last-child{margin-bottom:0}.form-column::-webkit-scrollbar{width:6px}.form-column::-webkit-scrollbar-track{background:0 0}.form-column::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.map-column{box-sizing:border-box!important;flex-direction:column!important;gap:.5rem!important;height:100%!important;display:flex!important;overflow:hidden!important}.map-search-container{z-index:10;position:relative}.map-search-input{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 .75rem 2.5rem;font-size:.95rem;transition:all .2s}.map-search-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #10b98133}.map-search-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.map-canvas-container{border-radius:var(--radius-lg);border:1px solid var(--color-border);background-color:var(--color-bg-base);position:relative;overflow:hidden;flex:1!important;height:100%!important;min-height:500px!important}.map-canvas{width:100%;height:100%}.map-loading-overlay{color:var(--color-text-main);z-index:5;border-radius:var(--radius-lg);background-color:#0f172ad9;justify-content:center;align-items:center;font-size:.95rem;display:flex;position:absolute;inset:0}.modal-content.modal-large .modal-footer{border-top:1px solid var(--color-border);background-color:#1e293b4d;flex-shrink:0;padding:1.25rem 2rem}.pac-container{border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;z-index:10000!important;background-color:#1e293b!important;border:1px solid #334155!important;margin-top:4px!important;font-family:Inter,sans-serif!important}.pac-item{cursor:pointer;align-items:center;display:flex;color:#f8fafc!important;border-top:1px solid #334155!important;padding:.6rem 1rem!important;font-size:.9rem!important}.pac-item:hover{background-color:#334155!important}.pac-item-query{color:#f8fafc!important;padding-right:.25rem!important;font-size:.9rem!important}.pac-matched{color:var(--color-primary)!important;font-weight:600!important}.pac-icon{filter:invert()hue-rotate(180deg);margin-right:8px!important}@media (width<=768px){.modal-content.modal-large{height:auto;max-height:90vh}.modal-content.modal-large .modal-form{height:auto;overflow-y:auto}.modal-layout-grid{grid-template-columns:1fr;gap:1rem;height:auto;padding:1.5rem;overflow:visible}.form-column{height:auto;padding-right:0;overflow-y:visible}.map-canvas-container{height:250px;min-height:250px}}.map-card-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(145deg, var(--color-bg-surface), #1e293b66)!important;box-sizing:border-box!important;flex-direction:column!important;gap:1rem!important;height:100%!important;padding:1.5rem!important;display:flex!important}.map-help-text{color:var(--color-text-muted);margin:-.25rem 0 .25rem;font-size:.85rem;line-height:1.4}.map-card-wrapper .input-label{color:var(--color-text-main);margin:0;font-size:1.1rem;font-weight:600}.usuarios-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;padding:1.5rem}.filters-container{flex-direction:column!important;gap:1.5rem!important;width:100%!important;margin-bottom:2.5rem!important;display:flex!important}.filters-top-row{justify-content:space-between!important;align-items:center!important;gap:2rem!important;width:100%!important;display:flex!important}.search-group{flex:1!important;max-width:600px!important;position:relative!important}.filters-bottom-row{flex-wrap:wrap!important;justify-content:flex-start!important;align-items:center!important;gap:1rem!important;width:100%!important;display:flex!important}.search-group .search-icon{color:#94a3b8!important;z-index:10!important;position:absolute!important;top:50%!important;left:1.25rem!important;transform:translateY(-50%)!important}.search-group .search-input{background-color:#0f172a99!important;border:1px solid #ffffff1a!important;border-radius:12px!important;width:100%!important;height:3rem!important;padding-left:3.5rem!important;font-size:.9rem!important}.filter-select-wrapper{flex:1!important;min-width:180px!important;position:relative!important}.filter-select-wrapper .select-icon{color:#94a3b8!important;z-index:10!important;pointer-events:none!important;position:absolute!important;top:50%!important;left:1rem!important;transform:translateY(-50%)!important}.filter-select-wrapper .filter-select{color:#fff!important;cursor:pointer!important;background-color:#1e293b99!important;border:1px solid #ffffff1a!important;border-radius:12px!important;width:100%!important;height:3rem!important;padding-left:3.5rem!important;font-size:.9rem!important}.btn-add-user{white-space:nowrap!important;background:linear-gradient(135deg,#10b981,#059669)!important;border-radius:12px!important;height:3rem!important;padding:0 1.5rem!important;transition:all .3s!important;box-shadow:0 4px 12px #10b98133!important}.btn-add-user:hover{transform:translateY(-2px)!important;box-shadow:0 6px 15px #10b9814d!important}.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,.role-badge.superadmin{color:var(--color-danger);background-color:#ef44441a;border:1px solid #ef444433}.role-badge.supervisor,.role-badge.gerente{color:var(--color-secondary);background-color:#3b82f61a;border:1px solid #3b82f633}.modal-large{max-width:800px!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.valid{color:var(--color-success);background-color:#22c55e1a}.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}.success-icon-large{background:#10b9811a;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto;display:flex}.credentials-box{background:var(--color-bg-base);border:1px dashed var(--color-primary);border-radius:12px;flex-direction:column;gap:1rem;margin:1.5rem 0;padding:1.5rem;display:flex}.credential-item{flex-direction:column;align-items:center;gap:.25rem;display:flex}.credential-item span{color:var(--color-text-muted);font-size:.9rem}.credential-item strong{color:var(--color-primary);letter-spacing:.05em;font-size:1.1rem}.justify-center{justify-content:center!important}.text-center{text-align:center!important}.w-full{width:100%!important}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#000c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--color-bg-surface);zoom:1.25;border:1px solid #ffffff1a;border-radius:20px;flex-direction:column;width:100%;max-width:480px;max-height:90vh;animation:.3s cubic-bezier(.4,0,.2,1) modalAppear;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}@keyframes modalAppear{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h2{color:#fff;margin:0;font-size:1.25rem}.modal-footer{border-top:1px solid #ffffff14;flex-shrink:0;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.sede-selection-container{background:#0f172a66;border:1px solid #ffffff0d;border-left:3px solid #3b82f6;border-radius:16px;margin-top:.5rem;padding:1.25rem}.selection-header-info{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.selection-header-info h4{color:#f8fafc;margin:0;font-size:.9rem;font-weight:600}.sede-chips-grid{background:#0003;border-radius:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;max-height:250px;padding:.5rem;display:grid;overflow-y:auto}.sede-chips-grid::-webkit-scrollbar{width:5px}.sede-chips-grid::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:10px}.sede-chip-item{cursor:pointer;text-align:center;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.sede-chip-item:hover{background:#3b82f61a;border-color:#3b82f666;transform:translateY(-2px)}.sede-chip-item.selected{background:linear-gradient(135deg,#3b82f626,#2563eb33);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633}.sede-chip-item.selected .chip-icon-wrapper{color:#fff;background:#3b82f6}.sede-chip-item.is-central{cursor:default;background:#f59e0b14!important;border-color:#f59e0b!important}.central-badge{color:#000;text-transform:uppercase;background:#f59e0b;border-bottom-left-radius:8px;padding:2px 6px;font-size:.55rem;font-weight:800;position:absolute;top:0;right:0}.chip-icon-wrapper{color:#94a3b8;background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .3s;display:flex}.sede-chip-name{color:#e2e8f0;font-size:.75rem;font-weight:500;line-height:1.2}.badge-count{color:#fff;background:#3b82f6;border-radius:10px;padding:1px 6px;font-size:.7rem}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:#ffffff03}.modal-body::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.modal-body::-webkit-scrollbar-thumb:hover{background:#fff3}.form-section{background:#ffffff03;border:1px solid #ffffff0a;border-radius:12px;margin-bottom:.5rem;padding:1.5rem}.section-title{letter-spacing:.03em;border-bottom:1px solid #ffffff14;align-items:center;gap:.5rem;padding-bottom:.5rem;font-size:.95rem;font-weight:600;display:flex;color:#60a5fa!important;margin:0 0 1.25rem!important}.section-title-icon{font-size:1.1rem}.form-grid-2{grid-template-columns:repeat(2,1fr);gap:1.25rem 1.5rem;display:grid}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group.full-width{grid-column:span 2}.form-group label{color:#94a3b8;align-items:center;font-size:.8rem;font-weight:500;display:inline-flex}.textarea-field{resize:vertical;height:100px!important;min-height:100px!important;max-height:150px!important;padding:.75rem 1rem!important;line-height:1.5!important}.password-input-wrapper{align-items:center;width:100%;display:flex;position:relative}.password-input-wrapper .input-field{padding-right:3.5rem!important}.password-input-wrapper .password-toggle-btn{color:#94a3b8;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;padding:.25rem .6rem;font-size:.75rem;font-weight:600;transition:all .2s;position:absolute;right:.5rem}.password-input-wrapper .password-toggle-btn:hover{color:#fff;background:#ffffff1a;border-color:#fff3}.checkbox-row{gap:2rem;margin-top:.5rem;display:flex}.modal-body{flex-direction:column;flex:1;gap:1.75rem;padding:2rem;display:flex;overflow-y:auto}.modal-form{flex-direction:column;flex:1;display:flex;overflow:hidden}@media (width<=768px){.form-grid-2{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.checkbox-row{flex-direction:column;gap:.75rem}.modal-body{padding:1.25rem}}.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,.status-badge.puntual{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}.status-badge.no-marcó-entrada,.status-badge.no_marco_entrada{color:var(--color-danger);background-color:#ef44441a}.status-badge.temprano{color:var(--color-secondary);background-color:#3b82f61a}.status-badge.pendiente{color:var(--color-text-muted);background-color:#9ca3af1a}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}@keyframes spin{to{transform:rotate(360deg)}}.time-stack{flex-direction:column;gap:.25rem;display:flex}.time-stack span{font-family:monospace;font-size:.8rem}.actividad-cell{flex-direction:column;gap:.5rem;max-width:200px;display:flex}.actividad-current{background:#a855f71a;border-left:3px solid #a855f7;border-radius:4px;flex-direction:column;padding:.4rem .6rem;display:flex}.actividad-label{text-transform:uppercase;color:#a855f7;font-size:.65rem;font-weight:700}.actividad-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.actividad-time{color:#d1d5db;font-size:.75rem}.actividad-total{color:#94a3b8;padding-left:.5rem;font-size:.75rem;font-weight:600}.role-badge.mini{padding:.1rem .4rem;font-size:.65rem}.role-badge.asesor{color:#a855f7;background-color:#a855f71a;border:1px solid #a855f733}.role-badge.operador{color:var(--color-success);background-color:#22c55e1a;border:1px solid #22c55e33}.status-badge.actividad-en-proceso{color:#a855f7;background-color:#a855f71a}.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{background-color:#f59e0b26;border-color:#f59e0b}.incidencia-item.resuelto{background-color:#10b98126;border-color:#10b981}.incidencia-item.atendiendo{background-color:#3b82f626;border-color:#3b82f6}.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);margin-bottom:.75rem;font-size:.9rem}.incidencia-thumbnail{object-fit:cover;border-radius:var(--border-radius-sm);cursor:pointer;border:1px solid var(--border-color);width:100%;max-width:120px;height:80px;transition:transform .2s}.incidencia-thumbnail:hover{filter:brightness(1.1);transform:scale(1.05)}.image-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.image-modal-content{max-width:90%;max-height:90%;position:relative}.image-modal-close{color:#fff;cursor:pointer;background:0 0;border:none;position:absolute;top:-40px;right:0}.image-modal-img{border-radius:var(--border-radius-md);max-width:100%;max-height:80vh;box-shadow:0 0 30px #00000080}.max-h-600{max-height:600px;overflow-y:auto}.row-alert{background-color:#451a1a!important}.row-alert:hover{background-color:#5c2424!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,.status-badge.puntual{color:#10b981;background-color:#10b9811a}.status-badge.tardanza{color:#f59e0b;background-color:#f59e0b1a}.status-badge.observado,.status-badge.invalid,.status-badge.no-marcó-entrada,.status-badge.no_marco_entrada{color:#ef4444;background-color:#ef44441a}.status-badge.justificado{color:#10b981;background-color:#10b9811a}.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}.actividades-timeline{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex;position:relative}.actividades-timeline:before{content:"";background:#ffffff0d;width:2px;position:absolute;top:1.5rem;bottom:1.5rem;left:2rem}.actividad-card{padding-left:2.5rem;transition:transform .2s;position:relative}.actividad-card:after{content:"";z-index:2;background:#1e293b;border:2px solid #a855f7;border-radius:50%;width:12px;height:12px;position:absolute;top:.5rem;left:1.7rem}.actividad-header{background:#ffffff05;border:1px solid #ffffff0d;border-radius:8px 8px 0 0;padding:1rem}.actividad-title-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.actividad-tipo-tag{color:#a855f7;text-transform:uppercase;background-color:#a855f726;border-radius:4px;padding:.2rem .6rem;font-size:.7rem;font-weight:700}.actividad-hora{color:var(--text-muted);font-family:monospace;font-size:.8rem}.actividad-card h3{color:#fff;margin:0;font-size:1rem}.actividad-body{background:#ffffff03;border:1px solid #ffffff0d;border-top:none;border-radius:0 0 8px 8px;padding:1rem}.actividad-desc{color:#d1d5db;margin-bottom:1rem;font-size:.9rem;line-height:1.5}.actividad-details-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.detail-row{color:#9ca3af;align-items:center;gap:.5rem;font-size:.85rem;display:flex}.detail-row strong{color:#d1d5db}.actividad-evidencias{border-top:1px solid #ffffff0d;flex-wrap:wrap;gap:1rem;padding-top:1rem;display:flex}.evidencia-item{flex-direction:column;gap:.5rem;display:flex}.evidencia-label{color:#6b7280;font-size:.75rem;font-weight:600}.evidencia-item img{object-fit:cover;cursor:pointer;border:1px solid #ffffff1a;border-radius:6px;width:120px;height:80px;transition:filter .2s}.evidencia-item img:hover{filter:brightness(1.2)}.actividad-card.finalizada:after{border-color:#10b981}.actividad-card.finalizada .actividad-tipo-tag{color:#10b981;background-color:#10b98126}.actividad-card.pendiente:after{border-color:#f59e0b}.actividad-card.pendiente .actividad-tipo-tag{color:#f59e0b;background-color:#f59e0b26}.sedes-overview{padding:.75rem 0}.section-title-wrapper{margin-bottom:1.5rem}.section-title-wrapper h2{color:#f8fafc;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.35rem;font-size:1.65rem;font-weight:700}.section-title-wrapper p{color:#94a3b8;font-size:.95rem}.sedes-grid{grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1.5rem;display:grid}.sede-card-premium{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#1e293bb3;border:1px solid #ffffff14;border-radius:16px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 8px 24px #00000040}.sede-card-premium:hover{border-color:#6366f173;transform:translateY(-5px);box-shadow:0 12px 30px #6366f12e}.sede-card-glow{pointer-events:none;background:radial-gradient(circle,#6366f124 0%,#6366f100 70%);border-radius:50%;width:220px;height:220px;position:absolute;top:-100px;right:-100px}.sede-card-content{padding:1.5rem}.sede-header-premium{border-bottom:1px solid #ffffff0d;align-items:center;gap:.85rem;margin-bottom:1.25rem;padding-bottom:.85rem;display:flex}.sede-icon-bg{color:#818cf8;background:linear-gradient(135deg,#6366f133,#6366f10d);border:1px solid #6366f14d;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.sede-icon-bg svg{width:22px;height:22px}.sede-title-premium{color:#f8fafc;font-size:1.25rem;font-weight:700}.sede-metrics-grid{grid-template-columns:repeat(2,1fr);gap:.8rem;display:grid}.metric-box{background:#0f172a66;border:1px solid #ffffff08;border-radius:10px;align-items:center;gap:.65rem;padding:.65rem .85rem;transition:all .2s;display:flex}.metric-box:hover{background:#0f172ab3;border-color:#ffffff14}.metric-box svg{width:18px;height:18px}.metric-info{flex-direction:column;display:flex}.metric-value{color:#f8fafc;font-size:1.2rem;font-weight:700;line-height:1.1}.metric-label{color:#94a3b8;font-size:.75rem;font-weight:500}.tabs-container{border-bottom:1px solid #ffffff14;gap:.35rem;margin-bottom:1.5rem;padding-bottom:.35rem;display:flex;overflow-x:auto}.tab-btn{color:#94a3b8;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.65rem 1.1rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.tab-btn svg{width:18px;height:18px}.tab-btn:hover{color:#f8fafc;background:#ffffff08}.tab-btn.active{color:#3b82f6;background:#3b82f614;box-shadow:inset 0 -2px #3b82f6}.sede-detailed-panel{animation:.3s ease-out fadeIn}.detailed-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.btn-back-link{color:#94a3b8;cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;transition:color .3s;display:flex}.btn-back-link svg{width:18px;height:18px}.btn-back-link:hover{color:#f8fafc}.detailed-actions-group{gap:.65rem;display:flex}.horarios-list-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem;display:grid}.horario-detail-card{background:#1e293b80;border:1px solid #ffffff0d;border-radius:14px;flex-direction:column;justify-content:space-between;padding:1.25rem;transition:all .2s;display:flex;box-shadow:0 4px 15px #0000001a}.horario-detail-card:hover{border-color:#3b82f64d;box-shadow:0 6px 20px #3b82f614}.horario-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.85rem;display:flex}.horario-card-header h4{color:#f8fafc;margin:0;font-size:1.15rem;font-weight:700}.horario-desc{color:#94a3b8;margin-top:.2rem;font-size:.85rem}.horario-actions{gap:.45rem;display:flex}.btn-icon-detail{cursor:pointer;background:#ffffff08;border:1px solid #ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .2s;display:flex}.btn-icon-detail svg{width:16px;height:16px}.btn-icon-detail:hover{background:#ffffff14}.horario-days-summary{margin:.85rem 0}.horario-days-summary h5{color:#64748b;text-transform:uppercase;margin-bottom:.6rem;font-size:.75rem;font-weight:600}.days-ranges-list{flex-direction:column;gap:.45rem;display:flex}.day-range-row{background:#0f172a4d;border:1px solid #ffffff05;border-radius:8px;justify-content:space-between;align-items:center;padding:.45rem .65rem;display:flex}.day-label-pill{color:#3b82f6;background:#3b82f61a;border-radius:6px;padding:2px 8px;font-size:.75rem;font-weight:700}.time-range-box{gap:.45rem;display:flex}.time-badge{color:#f8fafc;border-radius:4px;padding:2px 6px;font-size:.75rem;font-weight:500}.input-badge{color:#10b981;background:#10b9811a}.output-badge{color:#f59e0b;background:#f59e0b1a}.horario-card-footer{color:#94a3b8;border-top:1px solid #ffffff0d;align-items:center;gap:.5rem;margin-top:.5rem;padding-top:.75rem;font-size:.8rem;display:flex}.horario-card-footer svg{width:16px;height:16px}.table-responsive-p{background:#1e293b4d;border:1px solid #ffffff0f;border-radius:14px;overflow:hidden;box-shadow:0 4px 15px #00000026}.data-table-p{border-collapse:collapse;text-align:left;width:100%}.data-table-p th{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;background:#0f172a80;border-bottom:1px solid #ffffff14;padding:.8rem 1rem;font-size:.9rem;font-weight:600}.data-table-p td{color:#e2e8f0;border-bottom:1px solid #ffffff0a;padding:.75rem 1rem;font-size:.95rem}.data-table-p tr:hover td{background:#ffffff05}.rol-badge{color:#818cf8;background:#818cf81a;border-radius:6px;padding:2px 8px;font-size:.75rem;font-weight:700}.text-muted-p{color:#64748b;font-size:.85rem}.btn-icon-p{cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .2s;display:flex}.btn-icon-p svg{width:16px;height:16px}.btn-icon-p:hover{background:#ef44441a}.modal-overlay{-webkit-backdrop-filter:blur(6px)!important;backdrop-filter:blur(6px)!important;z-index:9999!important;background-color:#000000bf!important;justify-content:center!important;align-items:center!important;width:125vw!important;height:125vh!important;display:flex!important;position:fixed!important;top:0!important;left:0!important}.modal-content{zoom:1.25!important;border-radius:16px!important;flex-direction:column!important;width:95%!important;max-width:600px!important;max-height:90vh!important;padding:0!important;display:flex!important;overflow:hidden!important}.modal-content .modal-header{border-bottom:1px solid #ffffff12!important;flex-shrink:0!important;padding:1rem 1.25rem!important}.modal-content.modal-large{max-width:800px!important}.modal-header h2{font-size:1.2rem!important}.modal-form{flex-direction:column!important;flex:1!important;gap:.85rem!important;padding:1rem 1.25rem!important;display:flex!important;overflow:hidden auto!important}.modal-form::-webkit-scrollbar{width:5px}.modal-form::-webkit-scrollbar-track{background:0 0}.modal-form::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:10px}.modal-form .form-group{margin-bottom:0!important}.modal-form label{margin-bottom:.25rem!important;font-size:.75rem!important}.modal-form .modal-footer{background:0 0!important;border-top:1px solid #ffffff12!important;flex-shrink:0!important;justify-content:flex-end!important;gap:.75rem!important;margin-top:auto!important;padding:.85rem 0 0!important;display:flex!important}.input-field{width:100%;color:#fff!important;background-color:#1e293b!important;border:1px solid #475569!important;border-radius:.375rem!important;padding:.5rem .75rem!important;font-size:.8rem!important}.days-configs-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin-top:.5rem;display:grid}.day-config-card{background:#0f172a4d;border:1px solid #ffffff0d;border-radius:10px;padding:.75rem;transition:all .2s}.day-config-card.active{background:#3b82f60d;border-color:#3b82f64d}.day-card-header{border-bottom:1px solid #ffffff0a;padding-bottom:.35rem;font-size:.8rem}.day-card-times{flex-direction:column;gap:.5rem;display:flex}.time-group label{color:#94a3b8;margin-bottom:.15rem;font-size:.65rem;font-weight:600;display:block}.input-field-sm{color:#fff!important;background-color:#1e293b!important;border:1px solid #475569!important;border-radius:.25rem!important;width:75px!important;padding:.25rem .4rem!important;font-size:.75rem!important}.users-select-checklist-scroll{background:#0f172a66;border-radius:10px;flex-direction:column;max-height:140px;padding:.35rem;display:flex;overflow-y:auto;border:1px solid #ffffff0d!important}.users-select-checklist-scroll::-webkit-scrollbar{width:5px}.users-select-checklist-scroll::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:10px}.user-select-row-p{cursor:pointer;border-radius:6px;align-items:center;padding:.35rem .5rem;transition:all .2s;display:flex}.user-select-row-p:hover{background:#ffffff08}.user-select-row-p.selected{background:#3b82f614}.user-select-row-p span.font-semibold{font-size:.8rem}.user-select-row-p span.text-xs{font-size:.7rem}.empty-state-tab{text-align:center;background:#1e293b33;border:1px dashed #ffffff1a;border-radius:12px;padding:2.5rem 1.5rem}.empty-icon-tab{color:#64748b;width:36px;height:36px;margin:0 auto 1rem}.empty-state-tab h3{color:#f8fafc;margin-bottom:.35rem;font-size:1rem;font-weight:700}.empty-state-tab p{color:#94a3b8;max-width:320px;margin:0 auto;font-size:.8rem}.alert-tab-info{color:#f87171;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.75rem;display:flex}.btn{border-radius:10px!important;padding:.55rem 1.1rem!important;font-size:.95rem!important}.btn-premium-action{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:10px;padding:.75rem;font-size:.95rem;font-weight:600;transition:all .2s}.btn-premium-action:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f140}.schedule-mode-selector{background:#0f172a66;border:1px solid #ffffff0d;border-radius:12px;padding:.75rem}.btn-mode-select{color:#94a3b8;cursor:pointer;text-align:left;background:#ffffff05;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;flex:1;padding:.6rem .8rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.btn-mode-select:hover{background:#3b82f60d;border-color:#3b82f633;transform:translateY(-1px)}.btn-mode-select.active{color:#3b82f6;background:linear-gradient(135deg,#3b82f626,#6366f126);border-color:#3b82f6;box-shadow:0 4px 8px #3b82f614}.btn-mode-select.active small{color:#f8fafc}.btn-mode-select small{font-size:.65rem}.timeline-helper-card{background:#6366f10a;border:1px solid #6366f11f;border-left:3px solid #818cf8;border-radius:10px;padding:.65rem .85rem}.helper-title{color:#a5b4fc!important;font-size:.7rem!important}.helper-item span{font-size:.7rem;line-height:1.35}.day-selector-btn-pill{color:#94a3b8;cursor:pointer;background:#ffffff05;border:1px solid #ffffff14;border-radius:15px;padding:.45rem .85rem;font-size:.75rem;font-weight:600;transition:all .2s}.day-selector-btn-pill:hover{background:#3b82f60d;border-color:#3b82f633}.day-selector-btn-pill.active{color:#fff;background:#3b82f6;border-color:#3b82f6;box-shadow:0 3px 8px #3b82f640}.global-times-panel{background:#0f172a99!important;border:1px solid #ffffff14!important;border-radius:12px!important;flex-direction:row!important;gap:1.5rem!important;margin-bottom:1.25rem!important;padding:1.25rem!important;display:flex!important;box-shadow:inset 0 2px 4px #0003!important}.global-times-panel .form-group{flex-direction:column!important;flex:1!important;gap:.6rem!important;margin-bottom:0!important;display:flex!important}.global-times-panel label{align-items:center!important;gap:.35rem!important;margin-bottom:0!important;font-size:.85rem!important;font-weight:700!important;display:flex!important}.global-times-panel .input-field{color:#fff!important;text-align:center!important;background-color:#0f172a!important;border:1px solid #ffffff26!important;border-radius:8px!important;width:100%!important;max-width:120px!important;padding:.5rem .75rem!important;font-size:.9rem!important;font-weight:600!important;transition:all .2s!important}.global-times-panel .input-field:focus{border-color:#3b82f6!important;outline:none!important;box-shadow:0 0 0 2px #3b82f633!important}.global-times-panel .form-hint{color:#64748b!important;margin-top:.25rem!important;font-size:.75rem!important}input[type=time]::-webkit-calendar-picker-indicator{filter:invert()brightness()!important;cursor:pointer!important}.animate-spin{animation:1s linear infinite spin}.hm-shell{zoom:1.25;background:#1e293b;border:1px solid #ffffff14;border-radius:16px;flex-direction:column;width:95%;max-width:680px;max-height:90vh;animation:.25s cubic-bezier(.4,0,.2,1) slideUp;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 60px #00000080}.hm-header{background:#0f172a66;border-bottom:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;display:flex}.hm-header h2{color:#f8fafc;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:1rem;font-weight:700}.hm-body{flex-direction:column;flex:1;gap:.85rem;min-height:0;padding:1rem 1.25rem;display:flex;overflow:hidden auto}.hm-body::-webkit-scrollbar{width:5px}.hm-body::-webkit-scrollbar-track{background:0 0}.hm-body::-webkit-scrollbar-thumb{background:#6366f159;border-radius:10px}.hm-body::-webkit-scrollbar-thumb:hover{background:#6366f199}.hm-footer{background:#0f172a80;border-top:1px solid #ffffff12;flex-shrink:0;justify-content:flex-end;align-items:center;gap:.65rem;padding:.85rem 1.25rem;display:flex}.assignment-section-modal{border-top:1px solid #ffffff0f;flex-direction:column;gap:.5rem;margin-top:.25rem;padding-top:.85rem;display:flex}.historial-container{flex-direction:column;gap:2rem;padding-bottom:3rem;display:flex}.selection-header{margin-bottom:2rem;padding:1.5rem 2rem!important}.search-wrapper{background:var(--color-bg-base);border-radius:var(--radius-md);border:1px solid var(--color-border);align-items:center;gap:1rem;padding:.75rem 1.25rem;display:flex}.search-icon{color:var(--color-text-muted)}.search-input{color:var(--color-text-main);background:0 0;border:none;outline:none;width:100%;font-size:1rem}.users-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.user-selection-card{cursor:pointer;border:1px solid var(--color-border);align-items:center;gap:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;padding:1.5rem!important}.user-selection-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-glow);background:#10b98108;transform:translateY(-4px)}.user-card-avatar{background:linear-gradient(135deg, var(--color-primary), #34d399);color:#fff;border-radius:12px;justify-content:center;align-items:center;width:3.125rem;height:3.125rem;font-size:1.5rem;font-weight:700;display:flex}.user-card-info{flex:1}.user-card-info h3{color:var(--color-text-main);margin:0 0 .25rem;font-size:1.1rem}.user-card-info p{color:var(--color-text-muted);align-items:center;gap:.4rem;margin:0 0 .5rem;font-size:.85rem;display:flex}.user-card-sede{color:var(--color-text-muted);background:#ffffff0d;border-radius:4px;align-items:center;gap:.4rem;padding:.2rem .6rem;font-size:.75rem;display:inline-flex}.arrow-icon{color:var(--color-border);transition:transform .3s}.user-selection-card:hover .arrow-icon{color:var(--color-primary);transform:translate(5px)}.view-actions{margin-bottom:1.5rem}.btn-back{color:var(--color-primary);cursor:pointer;border-radius:var(--radius-md);background:0 0;border:none;align-items:center;gap:.5rem;padding:.5rem;font-weight:600;transition:all .2s;display:flex}.btn-back:hover{background:#10b9811a}.filters-card{margin-bottom:2rem;background:linear-gradient(145deg, var(--color-bg-surface), #1e293bb3)!important;padding:2.5rem!important}.filters-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:flex-end;gap:2rem;display:grid}.filter-group{flex-direction:column;gap:.75rem;display:flex}.filter-group label{color:var(--color-text-muted);align-items:center;gap:.625rem;font-size:.9rem;font-weight:600;display:flex}.filter-actions{gap:1.25rem;display:flex}.results-card{overflow:hidden;padding:0!important}.results-header{border-bottom:1px solid var(--color-border);background:#0f172a33;justify-content:space-between;align-items:center;padding:2rem 2.5rem;display:flex}.results-header h2{margin:0;font-size:1.25rem;font-weight:600}.table-responsive{-webkit-overflow-scrolling:touch;width:100%;padding:0;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--color-border);background-color:#1e293b80;padding:1.5rem 2.5rem;font-size:.8rem;font-weight:600}.data-table td{border-bottom:1px solid var(--color-border);padding:1.5rem 2.5rem;font-size:.95rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background-color:#ffffff08}.time-cell{color:var(--color-text-main);align-items:center;gap:.625rem;font-weight:600;display:flex}.duration-tag{color:var(--color-primary);background:#10b98114;border:1px solid #10b98133;border-radius:8px;padding:.375rem 1rem;font-size:.875rem;font-weight:700;display:inline-block}.status-badge{text-transform:uppercase;letter-spacing:.025em;border-radius:6px;padding:.375rem .875rem;font-size:.75rem;font-weight:700}.count-badge{text-align:center;border-radius:4px;min-width:24px;padding:.25rem .5rem;font-size:.75rem;font-weight:700;display:inline-block}.count-badge.danger{color:#f87171;background:#ef444433;border:1px solid #ef44444d}.count-badge.info{color:#60a5fa;background:#3b82f633;border:1px solid #3b82f64d}.status-badge.valid,.status-badge.completada,.status-badge.completa,.status-badge.puntual{color:var(--color-success);background:#10b9811a}.status-badge.observada,.status-badge.en_proceso{color:var(--color-warning);background:#f59e0b1a}.status-badge.tardanza,.status-badge.incompleta,.status-badge.no_marco_entrada{color:var(--color-danger);background:#ef44441a}.status-badge.programada,.status-badge.temprano{color:var(--color-secondary);background:#3b82f61a}.status-badge.ausente,.status-badge.pendiente{color:#94a3b8;background:#94a3b81a}.alert-message{border-radius:var(--radius-md);align-items:center;gap:1rem;margin-bottom:2rem;padding:1.25rem 1.5rem;font-size:.95rem;font-weight:600;animation:.4s ease-out slideIn;display:flex}.alert-message svg{flex-shrink:0}.alert-message.warning{color:var(--color-warning);background:#f59e0b14;border:1px solid #f59e0b33}.alert-message.danger{color:var(--color-danger);background:#ef444414;border:1px solid #ef444433}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sede-cell{color:var(--color-text-muted);align-items:center;gap:.625rem;font-size:.9375rem;display:flex}.loading-state{color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;padding:6rem;display:flex}.spinner{border:3px solid #10b9811a;border-top-color:var(--color-primary);border-radius:50%;width:3rem;height:3rem;margin-bottom:1.5rem;animation:.8s cubic-bezier(.4,0,.2,1) infinite spin}.empty-state{color:var(--color-text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;padding:6rem;display:flex}.detail-layout{grid-template-columns:1.5fr 1fr;gap:2rem;display:grid}.summary-header-card{margin-bottom:2rem;padding:2.5rem!important}.summary-info{justify-content:space-between;align-items:flex-start;margin-bottom:2.5rem;display:flex}.summary-date{align-items:center;gap:1.5rem;display:flex}.summary-date h3{text-transform:capitalize;margin:0;font-size:1.5rem}.summary-date p{color:var(--color-text-muted);margin:.25rem 0 0;font-size:1.1rem}.status-badge.large{border-radius:12px;padding:.75rem 1.5rem;font-size:.9rem}.metrics-grid{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:#0f172a33;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:1.5rem;display:grid}.metric-item{align-items:center;gap:1rem;display:flex}.metric-val span{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem;font-size:.75rem;display:block}.metric-val strong{font-size:1.1rem;font-weight:700}.events-timeline-card{padding:2rem 2.5rem!important}.events-timeline-card h2{margin-bottom:2rem;font-size:1.25rem}.timeline-v2{flex-direction:column;gap:2rem;display:flex;position:relative}.timeline-v2:before{content:"";background:var(--color-border);width:2px;position:absolute;top:0;bottom:0;left:90px}.timeline-v2-item{align-items:center;gap:2rem;display:flex}.time-col{width:70px;color:var(--color-text-muted);text-align:right;font-size:.9rem;font-weight:700}.marker-col{z-index:1;position:relative}.marker-dot{background:var(--color-border);border:3px solid var(--color-bg-surface);border-radius:50%;width:14px;height:14px;box-shadow:0 0 0 4px #ffffff0d}.marker-dot.entrada{background:var(--color-success)}.marker-dot.salida{background:var(--color-danger)}.marker-dot.inicio_break{background:var(--color-warning)}.marker-dot.fin_break{background:var(--color-primary)}.content-col h4{text-transform:capitalize;margin:0;font-size:1rem}.warning-pill{color:#f87171;text-transform:uppercase;background:#ef44441a;border-radius:4px;margin-top:.5rem;padding:.2rem .6rem;font-size:.7rem;font-weight:700;display:inline-block}.incidents-list-card,.map-placeholder-card,.gps-points-card{margin-bottom:2rem;padding:2rem!important}.card-header-flex{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.badge-count{background:var(--color-primary);color:#fff;border-radius:6px;padding:.2rem .6rem;font-size:.75rem;font-weight:700}.incidents-list-card h2,.map-placeholder-card h2,.gps-points-card h2{margin:0;font-size:1.15rem}.incidents-stack{flex-direction:column;gap:1.5rem;display:flex}.activities-stack{flex-direction:column;gap:1.5rem;width:100%;display:flex}.incident-card-v2{border-radius:var(--radius-md);border:1px solid var(--color-border);background:#0f172a4d;padding:1.25rem}.inc-header{justify-content:space-between;margin-bottom:.75rem;display:flex}.inc-time{color:var(--color-text-muted);font-size:.8rem}.inc-media{margin-top:1rem}.inc-media img{cursor:pointer;border-radius:8px;width:100%;transition:transform .2s}.inc-media img:hover{transform:scale(1.02)}.map-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.mini-map-mock{border-radius:var(--radius-md);border:1px dashed var(--color-border);background:#0f172a66;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;height:250px;display:flex;position:relative;overflow:hidden}.mock-map-bg{background:#10b9811a;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative}.pulse-pin{color:var(--color-primary);animation:2s infinite pulsePin}@keyframes pulsePin{0%{filter:drop-shadow(0 0 #10b98100);transform:scale(1)}50%{filter:drop-shadow(0 0 10px #10b98180);transform:scale(1.2)}to{filter:drop-shadow(0 0 #10b98100);transform:scale(1)}}.max-h-400{max-height:400px;overflow-y:auto}.data-table.small th,.data-table.small td{padding:1rem 1.5rem;font-size:.85rem}.row-alert td{background:#ef44440d}.status-badge.small{padding:.2rem .5rem;font-size:.7rem}.activities-history-card{margin-bottom:2rem;padding:2.5rem!important}.activity-history-item{padding-bottom:2rem}.act-type-tag{color:#a855f7;text-transform:uppercase;background:#a855f71a;border-radius:4px;margin-bottom:.4rem;padding:.15rem .5rem;font-size:.65rem;font-weight:700;display:inline-block}.act-meta{color:var(--color-text-muted);flex-wrap:wrap;gap:1.5rem;font-size:.85rem;display:flex}.act-meta strong{color:var(--color-text-main)}.act-evidence{gap:1rem;display:flex}.evidence-thumb{object-fit:cover;cursor:pointer;border:1px solid var(--color-border);border-radius:6px;width:6.25rem;height:4.0625rem;transition:transform .2s}.evidence-thumb:hover{transform:scale(1.05)}.marker-dot.success{background:var(--color-success)}.marker-dot.warning{background:var(--color-warning)}.marker-dot.danger{background:var(--color-danger)}.status-badge.finalizada{color:var(--color-success);background:#10b9811a}.status-badge.pendiente{color:var(--color-warning);background:#f59e0b1a}.status-badge.en_proceso{color:var(--color-secondary);background:#3b82f61a}.role-badge.mini{text-transform:uppercase;border-radius:4px;margin-top:.5rem;padding:.1rem .5rem;font-size:.65rem;font-weight:700;display:inline-block}.role-badge.asesor{color:#a855f7;background:#a855f71a;border:1px solid #a855f733}.role-badge.operador{color:var(--color-success);background:#10b9811a;border:1px solid #10b98133}.clickable-row{cursor:pointer;transition:background .2s}.clickable-row:hover{background:#ffffff0d!important}@media (width<=1200px){.detail-layout{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.selection-header,.user-selection-card,.filters-card,.summary-header-card,.events-timeline-card,.incidents-list-card,.recorrido-gps-card,.activities-history-card{padding:1.25rem!important}.results-header{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1.25rem!important}.data-table th,.data-table td{padding:1rem 1.25rem!important}.users-grid{grid-template-columns:1fr;gap:1rem}.filters-grid{gap:1.25rem}.metrics-grid{grid-template-columns:1fr;gap:1rem;padding:1rem}.summary-info{flex-direction:column;align-items:flex-start;gap:1.5rem}.summary-date{gap:1rem}.summary-date h3{font-size:1.25rem}.timeline-v2:before{left:20px}.timeline-v2-item{flex-direction:column;align-items:flex-start;gap:1rem}.time-col{text-align:left;width:auto;padding-left:45px}.marker-col{position:absolute;top:5px;left:14px}.content-col{padding-left:45px}}.recorrido-gps-card{border:1px solid var(--color-border);margin-top:2rem;background:linear-gradient(145deg, var(--color-bg-surface), #1e293b66)!important;padding:2.5rem!important}.gps-section-layout{grid-template-columns:2.5fr 1fr;gap:2rem;margin-top:1.5rem;display:grid}.google-map-wrapper{border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);background:#0f172a66;width:100%;height:500px;min-height:500px;position:relative;overflow:hidden}.google-map-canvas{width:100%;height:100%}.gps-metrics-sidebar{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:#0f172a4d;flex-direction:column;gap:1.25rem;padding:1.75rem;display:flex}.gps-metrics-sidebar h3{color:var(--color-text-main);border-bottom:1px solid var(--color-border);margin:0 0 .5rem;padding-bottom:.75rem;font-size:1.1rem;font-weight:600}.gps-metric-tile{border-radius:var(--radius-md);background:#1e293b66;border:1px solid #ffffff08;flex-direction:column;gap:.35rem;padding:1rem 1.25rem;transition:all .2s;display:flex}.gps-metric-tile:hover{background:#1e293b99;border-color:#10b9811a}.tile-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.tile-value{color:var(--color-text-main);font-size:1.25rem;font-weight:700}.tile-value.subtext{flex-direction:column;gap:.25rem;font-size:.95rem;font-weight:500;display:flex}.coordinates{color:var(--color-text-muted);font-family:monospace;font-size:.8rem}.gps-two-column{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=1024px){.gps-section-layout{grid-template-columns:1fr;gap:1.5rem}.google-map-wrapper{height:400px;min-height:400px}.gps-metrics-sidebar{grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem;display:grid}.gps-metrics-sidebar h3{grid-column:span 2;margin:0}.gps-tile-full{grid-column:span 2}}@media (width<=640px){.recorrido-gps-card{padding:1.25rem!important}.google-map-wrapper{height:320px;min-height:320px}.gps-metrics-sidebar{grid-template-columns:1fr;gap:.75rem;padding:1.25rem}.gps-metrics-sidebar h3,.gps-tile-full{grid-column:span 1}.gps-two-column{grid-template-columns:1fr;gap:.75rem}}.incidents-activities-stack{flex-direction:column;gap:2.5rem;width:100%;display:flex}.incidents-block{border-bottom:1px solid var(--color-border);flex-direction:column;gap:1rem;padding-bottom:2rem;display:flex}.activities-block{flex-direction:column;gap:1rem;display:flex}.section-subtitle{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:.5rem;font-size:.85rem;font-weight:700}.incident-card-premium{border:1px solid var(--color-border);box-shadow:var(--shadow-md);background:#1e293b73;border-radius:12px;flex-direction:column;gap:1.25rem;padding:1.5rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.incident-card-premium:hover{border-color:#ef444466;transform:translateY(-2px);box-shadow:0 10px 15px -3px #ef44441a}.incident-card-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}.incident-title{color:var(--color-text-main);font-size:.95rem;font-weight:600}.incident-time{color:var(--color-text-muted);font-size:.75rem}.incident-card-body{flex-direction:column;gap:1rem;display:flex}.incident-detail-item{flex-direction:column;gap:.25rem;display:flex}.incident-detail-item.inline-flex{flex-direction:row;align-items:center;gap:.5rem}.incident-detail-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:.7rem;font-weight:700}.incident-detail-value{color:var(--color-text-main);word-break:normal;overflow-wrap:anywhere;white-space:normal;font-size:.9rem;line-height:1.5}.incident-status-badge{color:#cbd5e1;text-transform:uppercase;background:#94a3b81a;border:1px solid #94a3b833;border-radius:4px;padding:.2rem .6rem;font-size:.75rem;font-weight:700}.incident-media-box{flex-direction:column;gap:.5rem;display:flex}.incident-media-label{text-transform:uppercase;color:var(--color-text-muted);font-size:.7rem;font-weight:700}.incident-media-thumb{object-fit:cover;border:1px solid var(--color-border);cursor:pointer;border-radius:8px;width:80px;height:80px;transition:transform .2s}.incident-media-thumb:hover{transform:scale(1.05)}.activity-card-premium{border:1px solid var(--color-border);box-shadow:var(--shadow-md);box-sizing:border-box;background:#1e293b73;border-radius:12px;flex-direction:column;gap:1.25rem;width:100%;padding:1.5rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.activity-card-premium:hover{border-color:#a855f766;transform:translateY(-2px);box-shadow:0 10px 15px -3px #a855f71a}.activity-card-header{border-bottom:1px solid #ffffff0f;flex-wrap:wrap;align-items:center;gap:.5rem;padding-bottom:.75rem;display:flex}.activity-card-body{flex-direction:column;gap:1.25rem;width:100%;display:flex}.activity-detail-item{flex-direction:column;gap:.35rem;width:100%;display:flex}.activity-detail-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:.7rem;font-weight:700}.activity-detail-value{color:var(--color-text-main);word-break:normal;overflow-wrap:anywhere;white-space:normal;font-size:.95rem;line-height:1.5}.activity-detail-value.main-highlight{color:var(--color-text-main);font-size:1.1rem;font-weight:700}.activity-detail-value.description-text{font-size:.95rem;line-height:1.6}.activity-detail-value.time-value{color:var(--color-text-main);border:1px solid var(--color-border);background:#0f172a4d;border-radius:6px;align-self:flex-start;padding:.5rem .75rem;font-size:.95rem;font-weight:600;display:inline-block}.activity-detail-value.observation-box{color:var(--color-warning);background:#f59e0b0a;border:1px solid #f59e0b1a;border-radius:8px;padding:.75rem 1rem;font-style:italic}.activity-evidence-wrapper{border-top:1px solid #ffffff0f;flex-wrap:wrap;gap:1rem;padding-top:1rem;display:flex}.evidence-item{flex-direction:column;gap:.4rem;display:flex}.evidence-label{text-transform:uppercase;color:var(--color-text-muted);font-size:.7rem;font-weight:700}.evidence-thumb{object-fit:cover;border:1px solid var(--color-border);cursor:pointer;border-radius:8px;width:70px;height:70px;transition:all .2s}.evidence-thumb:hover{border-color:#fff3;transform:scale(1.05)}.empty-state-message{color:var(--color-text-muted);border:1px solid var(--color-border);background:#1e293b33;border-radius:10px;margin:0;padding:1.25rem;font-size:.9rem;font-style:italic}.empty-msg-large{text-align:center;border:1px solid var(--color-border);color:var(--color-text-muted);background:#1e293b26;border-radius:12px;margin:0;padding:2.5rem;font-style:italic}.pulse-badge-live{color:var(--color-success);text-transform:uppercase;letter-spacing:.05em;background:#10b9811a;border:1px solid #10b98133;border-radius:9999px;align-items:center;gap:.5rem;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-flex}.pulse-dot{background-color:var(--color-success);border-radius:50%;width:8px;height:8px;display:inline-block;position:relative}.pulse-dot:after{content:"";background-color:var(--color-success);border-radius:50%;width:100%;height:100%;animation:1.5s ease-out infinite pulseLive;position:absolute;top:0;left:0}@keyframes pulseLive{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}
