@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--color-primary: #3730A3;--color-primary-hover: #312E81;--color-primary-light: #E0E7FF;--color-primary-subtle: #EEF2FF;--color-success: #059669;--color-success-bg: #ECFDF5;--color-success-text:#065F46;--color-warning: #D97706;--color-warning-bg: #FFFBEB;--color-warning-text:#92400E;--color-danger: #DC2626;--color-danger-bg: #FEF2F2;--color-danger-text: #991B1B;--color-info: #2563EB;--color-info-bg: #EFF6FF;--color-info-text: #1E40AF;--color-bg: #F1F5F9;--color-surface: #FFFFFF;--color-surface-alt: #F8FAFC;--color-border: #E2E8F0;--color-border-strong:#CBD5E1;--color-text: #0F172A;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-sidebar-bg: #0F172A;--color-sidebar-surface: #1E293B;--color-sidebar-text: #94A3B8;--color-sidebar-text-hover: #E2E8F0;--color-sidebar-active-bg: #3730A3;--color-sidebar-active-text: #FFFFFF;--color-sidebar-border: rgba(255,255,255,.06);--sidebar-width: 240px;--header-height: 56px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--radius-sm: 4px;--radius: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(15,23,42,.06);--shadow: 0 1px 3px rgba(15,23,42,.1), 0 1px 2px rgba(15,23,42,.06);--shadow-md: 0 4px 6px -1px rgba(15,23,42,.1), 0 2px 4px -1px rgba(15,23,42,.06);--shadow-lg: 0 10px 15px -3px rgba(15,23,42,.12), 0 4px 6px -2px rgba(15,23,42,.06);--shadow-xl: 0 20px 25px -5px rgba(15,23,42,.14), 0 10px 10px -5px rgba(15,23,42,.05);--transition: .15s cubic-bezier(.4, 0, .2, 1);--transition-slow: .25s cubic-bezier(.4, 0, .2, 1);--font-ui: "Outfit", system-ui, sans-serif;--font-data: "IBM Plex Mono", "Courier New", monospace}[data-theme=dark]{--color-bg: #0D1117;--color-surface: #161B22;--color-surface-alt: #1C2128;--color-border: rgba(240, 246, 252, .08);--color-border-strong:rgba(240, 246, 252, .16);--color-text: #E6EDF3;--color-text-secondary: #8B949E;--color-text-muted: #484F58;--color-primary-light: rgba(79, 70, 229, .22);--color-primary-subtle: rgba(79, 70, 229, .12);--color-success: #3FB950;--color-success-bg: rgba(46, 160, 67, .15);--color-success-text:#3FB950;--color-warning: #D29922;--color-warning-bg: rgba(187, 128, 9, .15);--color-warning-text:#D29922;--color-danger: #F85149;--color-danger-bg: rgba(248, 81, 73, .15);--color-danger-text: #F85149;--color-info: #58A6FF;--color-info-bg: rgba(56, 139, 253, .15);--color-info-text: #58A6FF;--color-sidebar-bg: #080D16;--color-sidebar-surface: #0D1321;--color-sidebar-text: #6E7681;--color-sidebar-text-hover: #CDD9E5;--color-sidebar-active-bg: #1F2A3C;--color-sidebar-active-text: #E6EDF3;--color-sidebar-border: rgba(240, 246, 252, .04);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 1px 3px rgba(0, 0, 0, .55), 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .55), 0 2px 4px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .65), 0 4px 6px -2px rgba(0, 0, 0, .45);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .75), 0 10px 10px -5px rgba(0, 0, 0, .55)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;color-scheme:light dark}body{font-family:var(--font-ui);background-color:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}h1,h2,h3,h4,h5,h6{font-family:var(--font-ui);font-weight:600;line-height:1.25;color:var(--color-text);margin:0}h1{font-size:1.75rem;font-weight:700}h2{font-size:1.25rem;font-weight:600}h3{font-size:1.0625rem}h4{font-size:.9375rem}h5{font-size:.875rem;font-weight:500}h6{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary)}p{font-family:var(--font-ui);line-height:1.65;color:var(--color-text-secondary);margin:0 0 var(--sp-3)}p:last-child{margin-bottom:0}small{font-size:.8125rem;color:var(--color-text-muted)}strong,b{font-weight:600;color:var(--color-text)}code{font-family:var(--font-data);font-size:.85em;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:1px 5px}hr{border:none;border-top:1px solid var(--color-border);margin:var(--sp-5) 0}header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-6);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm);font-family:var(--font-ui);gap:var(--sp-4)}header>span:first-child{font-size:.875rem;color:var(--color-text-secondary);font-weight:400;letter-spacing:.01em;flex:1}header>span:first-child>span:last-child{color:var(--color-text);font-weight:600}header>span:nth-child(2){font-size:.875rem;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}header>button,header button[type=button]{font-family:var(--font-ui);font-size:.8125rem;font-weight:500;padding:5px var(--sp-3);border-radius:var(--radius);border:1.5px solid rgba(220,38,38,.25);background:transparent;color:var(--color-danger);cursor:pointer;white-space:nowrap;transition:background var(--transition),border-color var(--transition);display:inline-flex;align-items:center;gap:var(--sp-1)}header>button:hover,header button[type=button]:hover{background:var(--color-danger-bg);border-color:#dc262673}.logout-btn{border-color:#dc262640!important;color:var(--color-danger)!important}.dark-mode-btn{width:34px;height:34px;padding:0!important;border-radius:var(--radius-md)!important;border:1.5px solid var(--color-border-strong)!important;background:var(--color-surface-alt)!important;color:var(--color-text-secondary)!important;cursor:pointer;display:inline-flex!important;align-items:center;justify-content:center;font-size:.875rem;flex-shrink:0;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition)!important}.dark-mode-btn:hover{background:var(--color-primary-light)!important;border-color:var(--color-primary)!important;color:var(--color-primary)!important;transform:rotate(12deg)}[data-theme=dark] .dark-mode-btn{background:#ffffff0f!important;border-color:#ffffff1f!important;color:#94a3b8!important}[data-theme=dark] .dark-mode-btn:hover{background:#fcd34d1f!important;border-color:#fcd34d66!important;color:#fcd34d!important;transform:rotate(20deg)}nav{width:var(--sidebar-width);min-height:calc(100vh - var(--header-height));background:linear-gradient(180deg,#0d1526,#0f172a 40%,#0c1220);display:flex;flex-direction:column;flex-shrink:0;padding:var(--sp-3) 0 var(--sp-6);font-family:var(--font-ui);border-right:1px solid rgba(255,255,255,.05);overflow-y:auto;overflow-x:hidden;transition:width .22s cubic-bezier(.4,0,.2,1)}nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px;padding:0 var(--sp-3)}nav li{margin:0}nav a{display:flex;align-items:center;gap:var(--sp-2);padding:9px var(--sp-3);border-radius:var(--radius);color:var(--color-sidebar-text);font-size:.875rem;font-weight:500;text-decoration:none;letter-spacing:.01em;transition:background var(--transition),color var(--transition);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}nav a:hover{background:#ffffff12;color:var(--color-sidebar-text-hover)}nav a[aria-current=page]{background:linear-gradient(90deg,#3730a3,#4338ca);color:#fff;font-weight:600;box-shadow:0 2px 12px #3730a38c,inset 0 1px #ffffff1a}nav a[aria-current=page]:hover{background:var(--color-primary-hover)}[data-theme=dark] nav{background:linear-gradient(180deg,#080d16,#0a1120,#070c15);border-right:1px solid rgba(240,246,252,.04)}main{flex:1;background:var(--color-bg);min-height:calc(100vh - var(--header-height));font-family:var(--font-ui);padding:var(--sp-6)!important}section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-5) var(--sp-6);margin-bottom:var(--sp-5);box-shadow:var(--shadow-sm);animation:fadeInUp .18s ease forwards}section:last-child{margin-bottom:0}section>h2:first-child,section>.section-header-row h2{font-size:1.0625rem;font-weight:700;color:var(--color-text);margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:2px solid var(--color-border);display:flex;align-items:center;gap:var(--sp-2);letter-spacing:-.01em}section>h2:first-child i,section>.section-header-row h2 i{color:var(--color-primary);font-size:.9375rem;opacity:1}section>h3{font-size:.9375rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--sp-3)}section>p:first-child{margin-top:0}table{width:100%;border-collapse:collapse;border-spacing:0;border:none!important;font-family:var(--font-ui);font-size:.875rem}section>table,section>div>table{margin:0}div:has(>table){overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border)}thead{background:linear-gradient(90deg,#3730a3,#4338ca)}thead tr{border-bottom:none}thead th{padding:var(--sp-3) var(--sp-4);text-align:left;font-family:var(--font-ui);font-weight:600;font-size:.6875rem;letter-spacing:.07em;text-transform:uppercase;color:#ffffffeb;white-space:nowrap;padding:10px var(--sp-4)!important}thead th:first-child{border-radius:var(--radius-md) 0 0 0}thead th:last-child{border-radius:0 var(--radius-md) 0 0}tbody{background:var(--color-surface)}tbody tr{border-bottom:1px solid var(--color-border);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--color-primary-subtle)}tbody tr:nth-child(2n){background:var(--color-surface-alt)}tbody tr:nth-child(2n):hover{background:var(--color-primary-subtle)}td,tbody th{padding:10px var(--sp-4)!important;color:var(--color-text);vertical-align:middle;border:none!important;font-size:.875rem}tbody th{font-weight:600;color:var(--color-text-secondary);white-space:nowrap;background:var(--color-surface-alt);width:1%}td:last-child,td[data-type=number],td:has(time){font-family:var(--font-data);font-size:.8125rem}table:not(:has(thead)) td:first-child,table:not(:has(thead)) th{font-weight:500;color:var(--color-text-secondary);font-size:.8125rem;width:40%;background:var(--color-surface-alt)}table:not(:has(thead)) td:last-child{font-family:var(--font-data);font-size:.8125rem}tfoot{background:var(--color-surface-alt);border-top:2px solid var(--color-border)}tfoot td,tfoot th{font-weight:600;font-size:.8125rem;color:var(--color-text-secondary)}label{display:block;font-family:var(--font-ui);font-size:.875rem;font-weight:500;color:var(--color-text);margin-bottom:var(--sp-1)}input,select,textarea{display:block;width:100%;padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-family:var(--font-ui);font-size:.875rem;line-height:1.5;transition:border-color var(--transition),box-shadow var(--transition);-moz-appearance:none;appearance:none;-webkit-appearance:none}input:hover,select:hover,textarea:hover{border-color:var(--color-border-strong)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}input::-moz-placeholder,textarea::-moz-placeholder{color:var(--color-text-muted);font-weight:400}input::placeholder,textarea::placeholder{color:var(--color-text-muted);font-weight:400}input:disabled,select:disabled,textarea:disabled{background:var(--color-bg);color:var(--color-text-muted);cursor:not-allowed;border-color:var(--color-border)}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--sp-3) center;padding-right:var(--sp-8);cursor:pointer}input[type=checkbox],input[type=radio]{width:auto;display:inline-block;padding:0;accent-color:var(--color-primary);cursor:pointer;border:none;box-shadow:none;margin-right:var(--sp-2);vertical-align:middle}input[type=checkbox]:focus,input[type=radio]:focus{box-shadow:none;outline:2px solid var(--color-primary-light);outline-offset:2px}input[type=date],input[type=time],input[type=datetime-local],input[type=number]{font-family:var(--font-data);letter-spacing:.02em}textarea{resize:vertical;min-height:80px}fieldset{border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-5);margin:0}legend{font-family:var(--font-ui);font-weight:600;font-size:.875rem;color:var(--color-text);padding:0 var(--sp-2)}form>*+*,fieldset>*+*{margin-top:var(--sp-4)}form>div,fieldset>div{display:flex;flex-direction:column;gap:var(--sp-1)}button{font-family:var(--font-ui);font-weight:500;font-size:.875rem;line-height:1.5;padding:var(--sp-2) var(--sp-4);border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);white-space:nowrap;text-decoration:none;transition:background var(--transition),color var(--transition),border-color var(--transition),box-shadow var(--transition),opacity var(--transition);position:relative;vertical-align:middle}button:disabled{opacity:.48;cursor:not-allowed;pointer-events:none}button:active:not(:disabled){transform:translateY(1px)}button[type=button]:not(header button){background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}button[type=button]:not(header button):hover{background:var(--color-surface-alt);border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}button[type=submit]{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:600}button[type=submit]:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:var(--shadow-md)}button[type=submit]:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-family:var(--font-ui);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.status-a-tiempo,.status-puntual{background:var(--color-success-bg);color:var(--color-success-text)}.status-tardanza,.status-tarde{background:var(--color-warning-bg);color:var(--color-warning-text)}.status-falta,.status-ausente{background:var(--color-danger-bg);color:var(--color-danger-text)}.status-justificado,.status-permiso{background:var(--color-info-bg);color:var(--color-info-text)}.status-activo{background:var(--color-success-bg);color:var(--color-success-text)}.status-inactivo,.status-desvinculado,.status-baja{background:var(--color-danger-bg);color:var(--color-danger-text)}.status-vacaciones,.status-suspendido{background:var(--color-warning-bg);color:var(--color-warning-text)}.badge{display:inline-flex;align-items:center;padding:2px var(--sp-2);border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:.75rem;font-weight:600}.badge-primary{background:var(--color-primary-light);color:var(--color-primary)}.badge-success{background:var(--color-success-bg);color:var(--color-success-text)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning-text)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger-text)}.badge-neutral{background:var(--color-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--sp-4);margin-bottom:var(--sp-5)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-5);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--sp-2);transition:box-shadow var(--transition),border-color var(--transition),transform var(--transition);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-border-strong);border-radius:var(--radius-md) var(--radius-md) 0 0}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong);transform:translateY(-1px)}.stat-card-primary:before{background:var(--color-primary)}.stat-card-success:before{background:var(--color-success)}.stat-card-warning:before{background:var(--color-warning)}.stat-card-danger:before{background:var(--color-danger)}.stat-value{font-family:var(--font-data);font-size:2.5rem;font-weight:700;color:var(--color-text);line-height:1;letter-spacing:-.04em}.stat-label{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);letter-spacing:.01em}.stat-card-primary .stat-value{color:var(--color-primary)}.stat-card-success .stat-value{color:var(--color-success)}.stat-card-warning .stat-value{color:var(--color-warning)}.stat-card-danger .stat-value{color:var(--color-danger)}[role=dialog][aria-modal=true]{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73!important;animation:fadeIn .15s ease}[role=dialog][aria-modal=true]>div{background:var(--color-surface)!important;border:none!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-xl)!important;padding:0!important;animation:slideUp .2s cubic-bezier(.34,1.56,.64,1);overflow:hidden}[role=dialog][aria-modal=true]>div>div:first-child{display:flex!important;align-items:center!important;justify-content:space-between!important;padding:var(--sp-4) var(--sp-5)!important;border-bottom:1px solid var(--color-border)!important;background:var(--color-surface-alt)}[role=dialog][aria-modal=true]>div>div:first-child strong{font-family:var(--font-ui);font-size:1rem;font-weight:600;color:var(--color-text)}[role=dialog][aria-modal=true]>div>div:first-child button{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);padding:4px 8px;font-size:.75rem;line-height:1}[role=dialog][aria-modal=true]>div>div:first-child button:hover{background:var(--color-bg);color:var(--color-text)}[role=dialog][aria-modal=true]>div>div:not(:first-child):not(:last-child){padding:var(--sp-5)!important}[role=dialog][aria-modal=true]>div>div:last-child:not(:first-child){padding:var(--sp-4) var(--sp-5)!important;border-top:1px solid var(--color-border)!important;display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:var(--sp-3)!important;background:var(--color-surface-alt)}[style*="position: fixed"][style*="bottom: 16"]{font-family:var(--font-ui)!important;font-size:.875rem!important;border-radius:var(--radius-md)!important;border:none!important;box-shadow:var(--shadow-lg)!important;background:var(--color-text)!important;color:#fff!important;padding:var(--sp-3) var(--sp-4)!important;animation:slideInRight .25s cubic-bezier(.34,1.56,.64,1)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.table-wrapper table{margin:0}.filters-bar{display:flex;align-items:flex-end;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-4);padding-bottom:var(--sp-4);border-bottom:1px solid var(--color-border)}.filters-bar label{margin-bottom:var(--sp-1);font-size:.8125rem}.filters-bar input,.filters-bar select{width:auto;min-width:160px}.filters-bar button{align-self:flex-end}.empty-state{text-align:center;padding:var(--sp-12) var(--sp-6);color:var(--color-text-muted)}.empty-state p{font-size:.9375rem;color:var(--color-text-muted)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--sp-8);color:var(--color-text-muted);font-size:.875rem;gap:var(--sp-2)}.loading:before{content:"";display:inline-block;width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}section>p:only-child,main>p:first-child:only-child{color:var(--color-text-muted);font-size:.875rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:100px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}nav::-webkit-scrollbar-thumb{background:#ffffff1f}@media(max-width:1024px){nav{width:200px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}@media(max-width:768px){main{padding:var(--sp-4)!important}section{padding:var(--sp-4);border-radius:var(--radius)}nav{width:64px;overflow:hidden}nav a{padding:10px;justify-content:center;overflow:hidden}nav a span{display:none}header{padding:0 var(--sp-4)}.filters-bar{flex-direction:column;align-items:stretch}.filters-bar input,.filters-bar select{width:100%}.stat-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){nav{display:none}main{padding:var(--sp-3)!important}header{padding:0 var(--sp-3)}header>span:first-child{display:none}section{padding:var(--sp-3);border-radius:var(--radius)}.stat-grid{grid-template-columns:1fr 1fr;gap:var(--sp-3)}.stat-value{font-size:1.5rem}table,thead,tbody,th,td,tr{display:block}thead tr{position:absolute;top:-9999px;left:-9999px}tbody tr{border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:var(--sp-3);background:var(--color-surface)!important;overflow:hidden}td{display:flex!important;justify-content:space-between;align-items:center;padding:var(--sp-2) var(--sp-3)!important;border-bottom:1px solid var(--color-border)!important;font-size:.8125rem}td:last-child{border-bottom:none!important}td:before{content:attr(data-label);font-weight:600;color:var(--color-text-secondary);font-family:var(--font-ui);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;margin-right:var(--sp-3)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes dbHeroReveal{0%{opacity:0;transform:translateY(36px) scale(.97);filter:blur(8px)}60%{opacity:1;filter:blur(0)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@keyframes dbPanelReveal{0%{opacity:0;transform:translateY(28px);filter:blur(4px)}55%{filter:blur(0)}to{opacity:1;transform:translateY(0);filter:blur(0)}}@keyframes dbCardReveal{0%{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes dbKpiPop{0%{opacity:0;transform:translateY(12px) scale(.9)}70%{transform:translateY(-2px) scale(1.03)}to{opacity:1;transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){.db-hero,.db-main-grid,.db-entities-grid,.db-analytics-section,.db-hero-kpi,.db-entity-card,.db-panel{animation:none!important}}.panel-dashboard{position:relative;min-height:420px}.panel-dashboard--idle .db-hero,.panel-dashboard--idle .db-panel,.panel-dashboard--idle .db-entity-card,.panel-dashboard--idle .db-analytics-section,.panel-dashboard--idle .db-hero-kpis .db-hero-kpi{opacity:0;animation-play-state:paused}.panel-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:80;background:linear-gradient(135deg,#f8fafcd1,#eef2ffb8);-webkit-backdrop-filter:blur(14px) saturate(1.25);backdrop-filter:blur(14px) saturate(1.25);border-radius:var(--radius-md, 12px);opacity:1;transition:opacity .45s ease,backdrop-filter .45s ease}.panel-loading-overlay--leaving{opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(0) saturate(1);backdrop-filter:blur(0) saturate(1)}.panel-loading-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:var(--sp-4, 1rem);padding:var(--sp-6, 1.5rem)}.panel-loading-overlay-label{font-family:var(--font-ui, "Outfit", sans-serif);font-size:.9375rem;font-weight:500;letter-spacing:.02em;color:var(--color-text-secondary, #475569);margin:0;text-align:center;animation:panelLabelPulse 1.8s ease-in-out infinite}.dark .panel-loading-overlay,[data-theme=dark] .panel-loading-overlay{background:linear-gradient(135deg,#0d1117c7,#161b22b8)}.dark .panel-loading-overlay-label,[data-theme=dark] .panel-loading-overlay-label{color:var(--color-text-secondary, #8B949E)}@keyframes panelLabelPulse{0%,to{opacity:.55}50%{opacity:1}}@media(prefers-reduced-motion:reduce){.panel-loading-overlay{transition:opacity .2s linear}.panel-loading-overlay-label{animation:none}.panel-dashboard--idle .db-hero,.panel-dashboard--idle .db-panel,.panel-dashboard--idle .db-entity-card,.panel-dashboard--idle .db-analytics-section,.panel-dashboard--idle .db-hero-kpis .db-hero-kpi{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.skeleton{background:linear-gradient(90deg,var(--color-surface-alt) 25%,var(--color-border) 50%,var(--color-surface-alt) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}.panel-root{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg);font-family:var(--font-ui);color:var(--color-text)}.panel-body{display:flex;flex:1;min-height:calc(100vh - var(--header-height))}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.sidebar-brand{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-5) var(--sp-4) var(--sp-4);border-bottom:1px solid var(--color-sidebar-border);margin-bottom:var(--sp-2);flex-shrink:0;min-height:72px}.sidebar-logo{width:36px;height:36px;min-width:36px;background:var(--color-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #3730a373}.sidebar-logo-icon{color:#fff;font-size:1rem}.sidebar-logo-text{display:flex;flex-direction:column;gap:1px;overflow:hidden}.sidebar-app-name{font-family:var(--font-ui);font-size:.9375rem;font-weight:700;color:#fff;letter-spacing:-.01em;white-space:nowrap;line-height:1.2}.sidebar-app-sub{font-family:var(--font-ui);font-size:.625rem;font-weight:500;color:var(--color-sidebar-text);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.sidebar-nav-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--sp-1) 0}.sidebar-nav-scroll::-webkit-scrollbar{width:3px}.sidebar-nav-scroll::-webkit-scrollbar-track{background:transparent}.sidebar-nav-scroll::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:100px}.nav-group{margin-bottom:2px}.nav-group-label{display:block;padding:var(--sp-3) var(--sp-4) var(--sp-1);font-family:var(--font-ui);font-size:.625rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#94a3b873;-webkit-user-select:none;-moz-user-select:none;user-select:none}.nav-group ul{padding:0 var(--sp-3);gap:1px}nav a>i:first-child{width:16px;text-align:center;flex-shrink:0;font-size:.8125rem;opacity:.75;transition:opacity var(--transition)}nav a:hover>i:first-child,nav a[aria-current=page]>i:first-child{opacity:1}.nav-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.sidebar-footer{padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--color-sidebar-border);flex-shrink:0}.sidebar-role-badge{display:flex;align-items:center;gap:var(--sp-2);padding:7px var(--sp-3);border-radius:var(--radius);font-family:var(--font-ui);font-size:.6875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.sidebar-role-badge.role-director{background:#3730a333;color:#a5b4fc;border:1px solid rgba(55,48,163,.3)}.sidebar-role-badge.role-administrador{background:#7c3aed33;color:#c4b5fd;border:1px solid rgba(124,58,237,.3)}.sidebar-role-badge.role-supervisor{background:#0d948833;color:#5eead4;border:1px solid rgba(13,148,136,.3)}.sidebar-role-badge.role-dev{background:#eab30826;color:#fde68a;border:1px solid rgba(234,179,8,.25)}.sidebar-role-dot{font-size:.4375rem;opacity:.8}.header-left{display:flex;align-items:center;gap:var(--sp-3);flex:1;min-width:0;overflow:hidden}.header-right{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}.header-breadcrumbs{display:flex;align-items:center;flex-wrap:nowrap;overflow:hidden;width:auto!important;min-height:auto!important;background:transparent!important;flex-direction:row!important;padding:0!important;border:none!important;font-family:var(--font-ui);font-size:.875rem}.breadcrumb-piece{display:inline-flex;align-items:center;gap:var(--sp-2);white-space:nowrap}.breadcrumb-item{color:var(--color-text-muted);font-weight:400}.breadcrumb-sep{color:var(--color-text-muted);font-size:1rem;line-height:1;opacity:.5}.breadcrumb-current{color:var(--color-text);font-weight:600;overflow:hidden;text-overflow:ellipsis;max-width:240px}.header-role-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-family:var(--font-ui);font-size:.6875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.header-role-badge.role-director{background:var(--color-primary-light);color:var(--color-primary)}.header-role-badge.role-administrador{background:#ede9fe;color:#7c3aed}.header-role-badge.role-supervisor{background:#ccfbf1;color:#0d9488}.header-role-badge.role-dev{background:#fef9c3;color:#92400e}.user-avatar{width:32px;height:32px;min-width:32px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:.75rem;font-weight:700;color:#fff;letter-spacing:.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:default;flex-shrink:0}.logout-btn{font-family:var(--font-ui)!important;font-size:.8125rem!important;font-weight:500!important;padding:5px var(--sp-3)!important;border-radius:var(--radius)!important;border:1.5px solid rgba(220,38,38,.25)!important;background:transparent!important;color:var(--color-danger)!important;cursor:pointer;white-space:nowrap;transition:background var(--transition),border-color var(--transition)!important;display:inline-flex!important;align-items:center;gap:var(--sp-2)!important}.logout-btn:hover{background:var(--color-danger-bg)!important;border-color:#dc262673!important}.hamburger-btn{background:transparent;border:none;color:var(--color-text-secondary);padding:6px 8px;border-radius:var(--radius);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:.9375rem;transition:background var(--transition),color var(--transition);flex-shrink:0;line-height:1}.hamburger-btn:hover{background:var(--color-bg);color:var(--color-text)}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:40;animation:fadeIn .2s ease}.panel-nav--collapsed:not(.panel-nav--open){width:64px!important;overflow:hidden}.panel-nav--collapsed:not(.panel-nav--open) .sidebar-logo-text,.panel-nav--collapsed:not(.panel-nav--open) .nav-item-label,.panel-nav--collapsed:not(.panel-nav--open) .nav-group-label,.panel-nav--collapsed:not(.panel-nav--open) .sidebar-app-sub{display:none}.panel-nav--collapsed:not(.panel-nav--open) .sidebar-role-badge span{display:none}.panel-nav--collapsed:not(.panel-nav--open) .sidebar-brand{justify-content:center;padding:var(--sp-4) var(--sp-3);gap:0}.panel-nav--collapsed:not(.panel-nav--open) a{justify-content:center;padding:10px;gap:0}.panel-nav--collapsed:not(.panel-nav--open) a>i:first-child{width:auto}.panel-nav--collapsed:not(.panel-nav--open) .sidebar-footer{display:flex;justify-content:center;padding:var(--sp-3)}.panel-nav--collapsed:not(.panel-nav--open) .sidebar-role-badge{padding:7px;justify-content:center;gap:0}.panel-nav--collapsed:not(.panel-nav--open) a{position:relative}.panel-nav--collapsed:not(.panel-nav--open) a:hover:after{content:attr(data-tooltip);position:absolute;left:calc(100% + var(--sp-2));top:50%;transform:translateY(-50%);background:var(--color-text);color:#fff;padding:5px 10px;border-radius:var(--radius);font-size:.8125rem;font-weight:500;white-space:nowrap;z-index:200;font-family:var(--font-ui);pointer-events:none;box-shadow:var(--shadow-md)}.sidebar-footer-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);width:100%}.panel-nav--collapsed:not(.panel-nav--open) .sidebar-footer-inner{justify-content:center}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;flex-shrink:0;border:1px solid var(--color-sidebar-border);background:#ffffff0a;border-radius:var(--radius);color:var(--color-sidebar-text);cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition);font-size:.625rem}.sidebar-toggle-btn:hover{background:#ffffff1a;color:var(--color-sidebar-text-hover);border-color:#ffffff26}@media(max-width:768px){.hamburger-btn{display:flex}nav:not(.header-breadcrumbs){position:fixed!important;top:0;left:0;height:100vh!important;width:var(--sidebar-width)!important;z-index:50;transform:translate(-100%);transition:transform var(--transition-slow);overflow-y:auto}nav.panel-nav--open{transform:translate(0)}.sidebar-logo-text,.nav-item-label,.nav-group-label{display:initial}.sidebar-app-sub{display:block}.sidebar-role-badge span{display:inline}.sidebar-brand{justify-content:flex-start;padding:var(--sp-5) var(--sp-4) var(--sp-4);gap:var(--sp-3)}nav a{justify-content:flex-start;padding:9px var(--sp-3);gap:var(--sp-2)}nav a>i:first-child{width:16px}nav a:hover:after{display:none}.sidebar-footer{display:block;justify-content:initial;padding:var(--sp-3) var(--sp-4)}.sidebar-role-badge{padding:7px var(--sp-3);justify-content:flex-start;gap:var(--sp-2)}header{padding:0 var(--sp-3)}.header-role-badge,.logout-text{display:none}main{padding:var(--sp-4)!important}}@media(max-width:600px){nav:not(.header-breadcrumbs):not(.panel-nav--open){display:flex!important}header{padding:0 var(--sp-3)}.breadcrumb-current{max-width:140px}main{padding:var(--sp-3)!important}}.stat-card-icon-row{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.0625rem;margin-bottom:var(--sp-2);background:var(--color-bg);color:var(--color-text-secondary);flex-shrink:0}.stat-card-success .stat-card-icon-row{background:var(--color-success-bg);color:var(--color-success)}.stat-card-warning .stat-card-icon-row{background:var(--color-warning-bg);color:var(--color-warning)}.stat-card-danger .stat-card-icon-row{background:var(--color-danger-bg);color:var(--color-danger)}.stat-card-primary .stat-card-icon-row{background:var(--color-primary-subtle);color:var(--color-primary)}.stat-sublabel{font-size:.75rem;color:var(--color-text-muted);font-family:var(--font-data);margin-top:2px}.stat-grid--compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.stat-grid--compact .stat-value{font-size:1.5rem}.dashboard-welcome-section{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-6) var(--sp-6);background:linear-gradient(135deg,#3730a3,#4338ca 60%,#6366f1);border:none;border-radius:var(--radius-lg);margin-bottom:var(--sp-5);box-shadow:0 4px 20px #3730a359;animation:fadeInUp .25s ease forwards;position:relative;overflow:hidden}.dashboard-welcome-section:before{content:"";position:absolute;top:-40%;right:-5%;width:280px;height:280px;background:#ffffff0a;border-radius:50%;pointer-events:none}.dashboard-welcome-section:after{content:"";position:absolute;bottom:-60%;left:30%;width:200px;height:200px;background:#ffffff08;border-radius:50%;pointer-events:none}.dashboard-welcome-text{display:flex;flex-direction:column;gap:var(--sp-1)}.dashboard-greeting{font-family:var(--font-ui);font-size:1.5rem;font-weight:700;color:#fff;margin:0;line-height:1.3}.dashboard-greeting span{color:#c7d2fe}.dashboard-date{display:flex;align-items:center;gap:var(--sp-2);font-size:.8125rem;color:#ffffffa6;margin:0;font-family:var(--font-ui);text-transform:capitalize}.dashboard-summary-pills{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;justify-content:flex-end}.summary-pill{display:inline-flex;align-items:center;gap:var(--sp-2);padding:5px 12px;border-radius:100px;background:#ffffff24;border:1px solid rgba(255,255,255,.2);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;color:#ffffffe6;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.summary-pill i{font-size:.75rem;color:#ffffffb3}.summary-pill--primary{background:#ffffff38;border-color:#ffffff59;color:#fff;font-weight:600}.summary-pill--primary i{color:#c7d2fe}.alert-card{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);border-radius:var(--radius-md);margin-bottom:var(--sp-5);animation:fadeInUp .2s ease forwards;flex-wrap:wrap}.alert-card--warning{background:var(--color-warning-bg);border:1px solid rgba(217,119,6,.25)}.alert-card--danger{background:var(--color-danger-bg);border:1px solid rgba(220,38,38,.25)}.alert-card--info{background:var(--color-info-bg);border:1px solid rgba(2,132,199,.2)}.alert-card-content{display:flex;align-items:flex-start;gap:var(--sp-3);flex:1}.alert-card-icon{font-size:1.125rem;color:var(--color-warning);flex-shrink:0;margin-top:1px}.alert-card--danger .alert-card-icon{color:var(--color-danger)}.alert-card--info .alert-card-icon{color:var(--color-info)}.alert-card-title{font-family:var(--font-ui);font-size:.9375rem;font-weight:600;color:var(--color-text);margin:0 0 2px}.alert-card-desc{font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-secondary);margin:0}.alert-card-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);background:var(--color-warning);color:#fff;border:none;border-radius:var(--radius);font-family:var(--font-ui);font-size:.8125rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background var(--transition),box-shadow var(--transition)}.alert-card-btn:hover{background:#b45309;box-shadow:var(--shadow-sm)}.alert-card--danger .alert-card-btn{background:var(--color-danger)}.alert-card--danger .alert-card-btn:hover{background:#b91c1c}.period-selector{display:flex;align-items:center;gap:var(--sp-1);flex-shrink:0}.period-selector-label{font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-muted);margin-right:var(--sp-1);white-space:nowrap}.period-btn{padding:4px 12px;border-radius:100px;background:transparent;border:1.5px solid var(--color-border);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition)}.period-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.period-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.period-btn--active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.section-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-4)}.section-header-row h2{margin-bottom:0!important}.section-action-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:5px var(--sp-3);background:var(--color-primary-light);border:1px solid rgba(55,48,163,.2);border-radius:var(--radius);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;color:var(--color-primary);cursor:pointer;transition:background var(--transition),border-color var(--transition);white-space:nowrap}.section-action-btn:hover{background:#3730a31f;border-color:#3730a359}.charts-grid{display:grid;grid-template-columns:1fr minmax(220px,320px);gap:var(--sp-4);margin-bottom:var(--sp-5)}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-5);box-shadow:var(--shadow-sm);position:relative}.chart-title{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.9375rem;font-weight:600;color:var(--color-text);margin:0 0 var(--sp-4)}.chart-title i{color:var(--color-primary);opacity:.75;font-size:.875rem}.chart-container{position:relative;height:240px}.chart-container--sm{height:200px}.chart-center-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;padding-bottom:48px}.chart-center-value{font-family:var(--font-data);font-size:1.625rem;font-weight:700;color:var(--color-text);line-height:1}.chart-center-desc{font-family:var(--font-ui);font-size:.6875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.analytics-table-section{margin-top:var(--sp-5)}.analytics-table-section h3{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.9375rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--sp-3)}.analytics-table-section h3 i{color:var(--color-primary);opacity:.6;font-size:.8125rem}.zone-name{display:inline-flex;align-items:center;gap:var(--sp-2);font-weight:500}.zone-name i{color:var(--color-primary);opacity:.6;font-size:.75rem}.employee-cell{display:inline-flex;align-items:center;gap:var(--sp-2);font-weight:500}.employee-avatar{width:28px;height:28px;min-width:28px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:.6875rem;font-weight:700;letter-spacing:.02em;flex-shrink:0}.metric-number{font-family:var(--font-data);font-weight:700;font-size:.9375rem;color:var(--color-text)}.metric-number.danger{color:var(--color-danger)}.metric-number.warning{color:var(--color-warning)}.metric-number.success{color:var(--color-success)}.supervisor-hero-card{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-6);padding:var(--sp-6);border-radius:var(--radius-md);margin-bottom:var(--sp-5);border:1px solid transparent;animation:fadeInUp .25s ease forwards;overflow:hidden;position:relative}.supervisor-hero--success{background:linear-gradient(135deg,rgba(5,150,105,.06) 0%,var(--color-surface) 60%);border-color:#05966933}.supervisor-hero--warning{background:linear-gradient(135deg,rgba(217,119,6,.06) 0%,var(--color-surface) 60%);border-color:#d9770633}.supervisor-hero--danger{background:linear-gradient(135deg,rgba(220,38,38,.06) 0%,var(--color-surface) 60%);border-color:#dc262633}.supervisor-hero-left{display:flex;flex-direction:column;gap:var(--sp-2);flex:1}.supervisor-hero-meta{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-muted);margin:0;text-transform:capitalize}.supervisor-hero-title{font-family:var(--font-ui);font-size:1.375rem;font-weight:700;color:var(--color-text);margin:0;line-height:1.3}.supervisor-hero-subtitle{font-family:var(--font-ui);font-size:.875rem;color:var(--color-text-secondary);margin:0}.supervisor-hero-subtitle strong{color:var(--color-text);font-weight:700}.supervisor-hero-right{flex-shrink:0}.supervisor-hero-ring{position:relative;width:96px;height:96px}.supervisor-hero-svg{width:96px;height:96px;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:var(--color-border);stroke-width:7}.ring-fill{fill:none;stroke-width:7;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.34,1.56,.64,1)}.supervisor-hero--success .ring-fill{stroke:var(--color-success)}.supervisor-hero--warning .ring-fill{stroke:var(--color-warning)}.supervisor-hero--danger .ring-fill{stroke:var(--color-danger)}.supervisor-hero-pct-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.supervisor-hero-pct{font-family:var(--font-data);font-size:1.25rem;font-weight:700;color:var(--color-text);line-height:1}.supervisor-hero-pct-label{font-family:var(--font-ui);font-size:.5625rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.action-items-list{display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-1)}.action-item{display:flex;align-items:center;gap:var(--sp-3);padding:10px var(--sp-4);border-radius:var(--radius);border:1px solid transparent;transition:background var(--transition)}.action-item--warning{background:var(--color-warning-bg);border-color:#d977062e;color:var(--color-warning-text)}.action-item--danger{background:var(--color-danger-bg);border-color:#dc26262e;color:var(--color-danger-text)}.action-item--info{background:var(--color-info-bg);border-color:#0284c72e;color:var(--color-info-text)}.action-item i{font-size:.875rem;flex-shrink:0;opacity:.8}.action-item-label{flex:1;font-family:var(--font-ui);font-size:.875rem;font-weight:500}.action-item-count{font-family:var(--font-data);font-size:1rem;font-weight:700;min-width:28px;text-align:right}@media(max-width:900px){.charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-welcome-section{flex-direction:column;align-items:flex-start;padding:var(--sp-4)}.dashboard-summary-pills{justify-content:flex-start}.supervisor-hero-card{flex-direction:column;align-items:flex-start;gap:var(--sp-4);padding:var(--sp-4)}.supervisor-hero-right{align-self:center}.section-header-row{flex-direction:column;align-items:flex-start;gap:var(--sp-2)}.period-selector{flex-wrap:wrap}.alert-card{flex-direction:column;align-items:flex-start}}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--sp-4);background:#0f172a85;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .15s ease}.modal-box{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .22s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.modal-box--sm{max-width:480px}.modal-box--md{max-width:640px}.modal-box--lg{max-width:800px}.modal-box--xl{max-width:960px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--color-border);background:var(--color-surface-alt);flex-shrink:0}.modal-title{font-family:var(--font-ui);font-size:1rem;font-weight:600;color:var(--color-text);line-height:1.4}.modal-close-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-size:.75rem;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition);flex-shrink:0;padding:0}.modal-close-btn:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-border-strong)}.modal-body{padding:var(--sp-5);overflow-y:auto;flex:1;font-family:var(--font-ui)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--color-border);background:var(--color-surface-alt);flex-shrink:0}@media(max-width:600px){.modal-overlay{padding:var(--sp-3);align-items:flex-end}.modal-box{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:85vh;animation:slideUpMobile .25s cubic-bezier(.34,1.56,.64,1)}}@keyframes slideUpMobile{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.toast-stack{position:fixed;bottom:var(--sp-5);right:var(--sp-5);z-index:9999;display:flex;flex-direction:column;gap:var(--sp-2);max-width:400px;min-width:280px;pointer-events:none}.toast{position:relative;display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);padding-bottom:calc(var(--sp-3) + 3px);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-family:var(--font-ui);font-size:.875rem;overflow:hidden;pointer-events:all;animation:slideInRight .25s cubic-bezier(.34,1.56,.64,1);border:1px solid transparent}.toast--exit{animation:slideOutRight .2s ease forwards}.toast--success{background:#ecfdf5;border-color:#05966933;color:#065f46}.toast--error{background:#fef2f2;border-color:#dc262633;color:#991b1b}.toast--warning{background:#fffbeb;border-color:#d9770633;color:#92400e}.toast--info{background:#eff6ff;border-color:#3b82f633;color:#1e40af}.toast-icon{font-size:1rem;flex-shrink:0;margin-top:1px}.toast--success .toast-icon{color:var(--color-success)}.toast--error .toast-icon{color:var(--color-danger)}.toast--warning .toast-icon{color:var(--color-warning)}.toast--info .toast-icon{color:#3b82f6}.toast-content{flex:1;min-width:0}.toast-title{font-weight:600;font-size:.875rem;margin:0 0 2px;line-height:1.3}.toast-msg{font-size:.8125rem;margin:0;line-height:1.4;opacity:.85}.toast-close{background:transparent;border:none;padding:2px;cursor:pointer;color:currentColor;opacity:.5;flex-shrink:0;font-size:.75rem;transition:opacity var(--transition);display:flex;align-items:center;justify-content:center}.toast-close:hover{opacity:1}.toast-progress{position:absolute;bottom:0;left:0;height:3px;width:100%;border-radius:0 0 var(--radius-md) var(--radius-md);animation:toastProgress linear forwards;transform-origin:left}.toast--success .toast-progress{background:var(--color-success)}.toast--error .toast-progress{background:var(--color-danger)}.toast--warning .toast-progress{background:var(--color-warning)}.toast--info .toast-progress{background:#3b82f6}@keyframes toastProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(110%)}}@media(max-width:600px){.toast-stack{left:var(--sp-3);right:var(--sp-3);bottom:var(--sp-4);min-width:unset;max-width:unset}}.spinner{display:inline-block;border-radius:50%;border-style:solid;border-color:var(--color-border);border-top-color:var(--color-primary);animation:spin .65s linear infinite;flex-shrink:0}.spinner--sm{width:16px;height:16px;border-width:2px}.spinner--md{width:24px;height:24px;border-width:2.5px}.spinner--lg{width:36px;height:36px;border-width:3px}.spinner-container{display:flex;align-items:center;justify-content:center;gap:var(--sp-3);padding:var(--sp-8);color:var(--color-text-muted);font-family:var(--font-ui);font-size:.875rem}@keyframes glow-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.page-loading-overlay{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px;background:transparent;z-index:9999;pointer-events:none}.glow-spinner{position:relative;border-radius:50%;background-image:linear-gradient(135deg,#9b59b6,#84cdfa,#5ad1cd);animation:glow-spin 1.1s linear infinite;flex-shrink:0}.glow-spinner span{position:absolute;inset:0;border-radius:50%;background-image:linear-gradient(135deg,#9b59b6,#84cdfa,#5ad1cd)}.glow-spinner span:nth-child(1){filter:blur(4px)}.glow-spinner span:nth-child(2){filter:blur(9px)}.glow-spinner span:nth-child(3){filter:blur(22px)}.glow-spinner span:nth-child(4){filter:blur(44px)}.glow-spinner--sm{width:52px;height:52px}.glow-spinner--sm span:nth-child(4){filter:blur(24px)}.glow-spinner--sm:after{content:"";position:absolute;inset:5px;background:var(--color-bg, #F8FAFC);border:3px solid var(--color-bg, #F8FAFC);border-radius:50%;z-index:2}.glow-spinner--md{width:72px;height:72px}.glow-spinner--md:after{content:"";position:absolute;inset:7px;background:var(--color-bg, #F8FAFC);border:3px solid var(--color-bg, #F8FAFC);border-radius:50%;z-index:2}.glow-spinner--lg{width:128px;height:128px}.glow-spinner--lg:after{content:"";position:absolute;inset:14px;background:var(--color-bg, #F8FAFC);border:6px solid var(--color-bg, #F8FAFC);border-radius:50%;z-index:2}.section-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);padding:var(--sp-6);min-height:140px;width:100%}.section-loading-label{font-family:var(--font-ui);font-size:1rem;font-weight:600;color:var(--color-text);margin:0;text-align:center;letter-spacing:.02em}.panel-initial-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;min-height:min(72vh,600px);width:100%;padding:var(--sp-8) var(--sp-4);box-sizing:border-box}.panel-initial-label{font-family:var(--font-ui);font-size:1.25rem;font-weight:600;color:var(--color-text);letter-spacing:.03em;margin:0;text-align:center;animation:fade-pulse 1.6s ease-in-out infinite}.inline-glow-loading{display:flex;align-items:center;gap:var(--sp-2);color:var(--color-text-muted);font-family:var(--font-ui);font-size:.875rem}.page-loading-label{font-family:var(--font-ui);font-size:1.125rem;font-weight:600;color:var(--color-text);letter-spacing:.04em;margin:0;animation:fade-pulse 1.6s ease-in-out infinite}@keyframes fade-pulse{0%,to{opacity:.5}50%{opacity:1}}[data-theme=dark] .glow-spinner--sm:after,[data-theme=dark] .glow-spinner--md:after,[data-theme=dark] .glow-spinner--lg:after{background:#0d1117;border-color:#0d1117}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-4);min-height:240px;padding:var(--sp-12)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);text-align:center;padding:var(--sp-12) var(--sp-6);color:var(--color-text-muted)}.empty-state-icon{width:56px;height:56px;border-radius:50%;background:var(--color-bg);border:1.5px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--color-text-muted)}.empty-state-title{font-family:var(--font-ui);font-size:.9375rem;font-weight:600;color:var(--color-text-secondary);margin:0}.empty-state-desc{font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-muted);margin:0;max-width:320px;line-height:1.5}.empty-state-action{margin-top:var(--sp-2)}.avatar{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-weight:700;letter-spacing:.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;cursor:default}.avatar--sm{width:28px;height:28px;font-size:.6875rem}.avatar--md{width:36px;height:36px;font-size:.875rem}.avatar--lg{width:48px;height:48px;font-size:1.125rem}.avatar--xl{width:64px;height:64px;font-size:1.375rem}.avatar--primary{background:var(--color-primary-light);color:var(--color-primary)}.avatar--teal{background:#ccfbf1;color:#0d9488}.avatar--violet{background:#ede9fe;color:#7c3aed}.avatar--amber{background:#fef3c7;color:#d97706}.avatar--neutral{background:var(--color-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border)}.confirm-modal-body{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-4);padding:var(--sp-2) 0 var(--sp-4)}.confirm-modal-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.confirm-modal-icon--danger{background:var(--color-danger-bg);color:var(--color-danger)}.confirm-modal-icon--warning{background:var(--color-warning-bg);color:var(--color-warning)}.confirm-modal-icon--primary{background:var(--color-primary-light);color:var(--color-primary)}.confirm-modal-msg{font-family:var(--font-ui);font-size:.9375rem;color:var(--color-text-secondary);line-height:1.55;margin:0;max-width:340px}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger);font-weight:600}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c;box-shadow:var(--shadow-md)}.btn-warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning);font-weight:600}.btn-warning:hover{background:#b45309;border-color:#b45309;box-shadow:var(--shadow-md)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);margin-bottom:var(--sp-5);flex-wrap:wrap}.page-header-text h1{font-family:var(--font-ui);font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0 0 2px;line-height:1.2}.page-header-text p{font-family:var(--font-ui);font-size:.875rem;color:var(--color-text-muted);margin:0;line-height:1.5}.page-header-actions{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}.export-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:7px var(--sp-3);border-radius:var(--radius);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition);white-space:nowrap}.export-btn:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-border-strong)}.export-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.export-btn--excel:hover:not(:disabled){color:#166534;border-color:#16653459;background:#f0fdf4}.export-btn--pdf:hover:not(:disabled){color:var(--color-danger);border-color:#dc26264d;background:var(--color-danger-bg)}.export-btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.export-btn--primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.asist-stats-bar{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--sp-4);box-shadow:var(--shadow-sm);flex-wrap:wrap;animation:fadeInUp .2s ease forwards}.asist-stat-chip{display:inline-flex;align-items:center;gap:var(--sp-2);padding:5px 12px;border-radius:100px;font-family:var(--font-ui);font-size:.8125rem;font-weight:500;border:1px solid transparent}.asist-stat-val{font-family:var(--font-data);font-size:1rem;font-weight:700;line-height:1}.asist-stat-lbl{font-size:.75rem;font-weight:500;opacity:.85}.asist-stat--primary{background:var(--color-primary-subtle);border-color:#3730a326;color:var(--color-primary)}.asist-stat--success{background:var(--color-success-bg);border-color:#05966933;color:var(--color-success-text)}.asist-stat--warning{background:var(--color-warning-bg);border-color:#d9770633;color:var(--color-warning-text)}.asist-stat--danger{background:var(--color-danger-bg);border-color:#dc262633;color:var(--color-danger-text)}.asist-stat-pct{display:inline-flex;align-items:center;gap:var(--sp-2);margin-left:auto;font-family:var(--font-ui);font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.asist-stat-pct i{color:var(--color-primary);opacity:.7;font-size:.75rem}.filtros-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-5);margin-bottom:var(--sp-4);box-shadow:var(--shadow-sm)}.filtros-row-primary{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.filtros-row-right{display:flex;align-items:center;gap:var(--sp-2);margin-left:auto;flex-wrap:wrap}.period-presets{display:flex;align-items:center;gap:var(--sp-1)}.filtros-active-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;background:var(--color-primary-light);color:var(--color-primary);font-family:var(--font-ui);font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.filtros-clear-btn{display:inline-flex;align-items:center;gap:var(--sp-1);padding:4px 10px;border-radius:var(--radius);background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-ui);font-size:.75rem;font-weight:500;cursor:pointer;transition:background var(--transition),border-color var(--transition)}.filtros-clear-btn:hover{background:var(--color-bg);border-color:var(--color-border-strong)}.filtros-toggle-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:5px 12px;border-radius:var(--radius);background:var(--color-surface);border:1.5px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition)}.filtros-toggle-btn:hover{background:var(--color-bg);border-color:var(--color-border-strong);color:var(--color-text)}.filtros-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--sp-3);margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid var(--color-border)}.filtros-search-wrap{position:relative}.filtros-search-wrap i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);font-size:.75rem;pointer-events:none}.filtros-search-wrap input{padding-left:30px}.table-action-group{display:flex;align-items:center;gap:var(--sp-1)}.icon-btn{width:30px;height:30px;border-radius:var(--radius);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;transition:background var(--transition),border-color var(--transition),color var(--transition);padding:0;flex-shrink:0}.icon-btn:hover{background:var(--color-bg);border-color:var(--color-border-strong)}.icon-btn--edit:hover{background:var(--color-primary-light);border-color:#3730a34d;color:var(--color-primary)}.icon-btn--history:hover{background:#eff6ff;border-color:#3b82f64d;color:#2563eb}.icon-btn--view:hover{background:var(--color-success-bg);border-color:#0596694d;color:var(--color-success)}.icon-btn--danger:hover{background:var(--color-danger-bg);border-color:#dc26264d;color:var(--color-danger)}.employee-info{display:flex;flex-direction:column;gap:1px;min-width:0}.employee-name{font-family:var(--font-ui);font-size:.875rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.employee-dept{font-family:var(--font-ui);font-size:.75rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.time-mono{font-family:var(--font-data);font-size:.8125rem;color:var(--color-text);letter-spacing:.02em}.time-mono.delay-text{color:var(--color-warning-text);font-weight:500}.manual-tag{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:var(--radius-sm);background:var(--color-primary-light);color:var(--color-primary);font-family:var(--font-data);font-size:.625rem;font-weight:700;margin-left:var(--sp-1);vertical-align:middle;cursor:default}.modal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--sp-4);margin-bottom:var(--sp-4)}.modal-info-item{display:flex;flex-direction:column;gap:3px}.modal-info-label{font-family:var(--font-ui);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted)}.modal-info-value{font-family:var(--font-ui);font-size:.9375rem;font-weight:500;color:var(--color-text)}.historial-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:var(--sp-5)}.historial-timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--color-border);border-radius:2px}.historial-entry{position:relative;padding:var(--sp-3) 0 var(--sp-4) var(--sp-3)}.historial-dot{position:absolute;left:calc(-1 * var(--sp-5) + 1px);top:calc(var(--sp-3) + 4px);width:14px;height:14px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-surface);box-shadow:0 0 0 2px var(--color-primary-light);flex-shrink:0}.historial-content{display:flex;flex-direction:column;gap:var(--sp-2)}.historial-meta{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.historial-date{font-family:var(--font-data);font-size:.8125rem;font-weight:500;color:var(--color-text)}.historial-user{display:inline-flex;align-items:center;gap:var(--sp-1);font-family:var(--font-ui);font-size:.75rem;color:var(--color-text-muted)}.historial-user i{font-size:.625rem}.historial-change{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}.historial-arrow{color:var(--color-text-muted);font-size:.75rem}.historial-motivo{font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-secondary);font-style:italic;margin:0;padding:var(--sp-2) var(--sp-3);background:var(--color-bg);border-left:2px solid var(--color-border);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.director-asist-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-5);animation:fadeInUp .2s ease forwards}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-1);cursor:pointer;transition:box-shadow var(--transition),border-color var(--transition),transform var(--transition);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-border-strong);border-radius:var(--radius-md) var(--radius-md) 0 0}.kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong);transform:translateY(-1px)}.kpi-card--active{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light),var(--shadow-sm)}.kpi-card--active:before{background:var(--color-primary)}.kpi-card--success:before{background:var(--color-success)}.kpi-card--warning:before{background:var(--color-warning)}.kpi-card--danger:before{background:var(--color-danger)}.kpi-card--info:before{background:var(--color-info)}.kpi-card-value{font-family:var(--font-data);font-size:1.875rem;font-weight:700;color:var(--color-text);line-height:1;letter-spacing:-.02em}.kpi-card-label{font-family:var(--font-ui);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary)}.kpi-card-pct{font-family:var(--font-data);font-size:.75rem;font-weight:500;color:var(--color-text-muted);margin-top:2px}.kpi-card--success .kpi-card-value{color:var(--color-success)}.kpi-card--warning .kpi-card-value{color:var(--color-warning)}.kpi-card--danger .kpi-card-value{color:var(--color-danger)}.kpi-card--info .kpi-card-value{color:var(--color-info)}.kpi-asist-rate{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--color-bg);border-radius:var(--radius);margin-top:var(--sp-2);font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-secondary)}.kpi-asist-rate strong{font-family:var(--font-data);font-weight:700;color:var(--color-text)}.detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-4)}.detail-info-item{display:flex;flex-direction:column;gap:3px}.detail-info-item label{font-family:var(--font-ui);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);margin-bottom:0;display:block}.detail-info-item span{font-family:var(--font-ui);font-size:.9375rem;font-weight:500;color:var(--color-text)}.detail-photo{width:100%;max-height:200px;-o-object-fit:contain;object-fit:contain;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-bg);margin-bottom:var(--sp-4)}.detail-edit-section{padding:var(--sp-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:var(--sp-4)}.detail-obs{font-family:var(--font-ui);font-size:.875rem;color:var(--color-text-secondary);font-style:italic;padding:var(--sp-3) var(--sp-4);background:var(--color-bg);border-left:3px solid var(--color-border);border-radius:0 var(--radius) var(--radius) 0;margin-bottom:var(--sp-4)}.tipo-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--color-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border)}.tipo-badge--movil{background:var(--color-primary-light);color:var(--color-primary);border-color:#3730a326}.tipo-badge--manual{background:var(--color-warning-bg);color:var(--color-warning-text);border-color:#d9770633}.historial-cambios-list{display:flex;flex-direction:column;gap:var(--sp-3)}.historial-cambios-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2);transition:box-shadow var(--transition)}.historial-cambios-card:hover{box-shadow:var(--shadow-sm)}.historial-cambios-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap}.historial-cambios-empleado{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.875rem;font-weight:600;color:var(--color-text)}.historial-cambios-empleado i{color:var(--color-text-muted);font-size:.75rem}.historial-cambios-fecha{font-family:var(--font-data);font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.historial-cambios-arrow{display:flex;align-items:center;gap:var(--sp-2)}.historial-cambios-footer{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap}.historial-meta-item{display:inline-flex;align-items:center;gap:var(--sp-1);font-family:var(--font-ui);font-size:.75rem;color:var(--color-text-muted)}.historial-meta-item i{font-size:.625rem}.historial-cambios-paginacion{display:flex;align-items:center;justify-content:center;gap:var(--sp-3);padding-top:var(--sp-4);border-top:1px solid var(--color-border);margin-top:var(--sp-3);font-family:var(--font-ui);font-size:.875rem;color:var(--color-text-secondary)}.manual-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:var(--color-warning-bg);color:var(--color-warning-text);border:1px solid rgba(217,119,6,.2)}.registrar-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.registrar-form-grid .form-full{grid-column:1 / -1}.results-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-3) 0;flex-wrap:wrap}.results-count{font-family:var(--font-ui);font-size:.875rem;color:var(--color-text-secondary)}.results-count strong{font-family:var(--font-data);font-weight:700;color:var(--color-text)}.results-actions{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:var(--sp-3)}.filtros-row-primary{flex-direction:column;align-items:flex-start}.filtros-row-right{margin-left:0}.filtros-grid{grid-template-columns:1fr 1fr}.modal-info-grid{grid-template-columns:1fr}.director-asist-kpi-grid{grid-template-columns:1fr 1fr}.detail-info-grid{grid-template-columns:1fr}.asist-stats-bar{gap:var(--sp-1)}.asist-stat-chip{padding:4px 8px}.registrar-form-grid{grid-template-columns:1fr}}@media(max-width:600px){.filtros-grid{grid-template-columns:1fr}.director-asist-kpi-grid{grid-template-columns:1fr 1fr}.asist-stat-pct{display:none}}.role-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:100px;font-family:var(--font-ui);font-size:.6875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid transparent}.role-badge--trabajador{background:#ccfbf1;color:#0d9488;border-color:#0d948833}.role-badge--supervisor{background:#fef3c7;color:#d97706;border-color:#d9770633}.role-badge--administrador{background:#ede9fe;color:#7c3aed;border-color:#7c3aed33}.role-badge--director{background:var(--color-primary-light);color:var(--color-primary);border-color:#3730a333}.emp-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin-bottom:var(--sp-5);animation:fadeInUp .2s ease forwards}.emp-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);display:flex;align-items:center;gap:var(--sp-3);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.emp-stat-card:hover{box-shadow:var(--shadow)}.emp-stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.emp-stat-icon--total{background:var(--color-primary-light);color:var(--color-primary)}.emp-stat-icon--admin{background:#ede9fe;color:#7c3aed}.emp-stat-icon--supervisor{background:#fef3c7;color:#d97706}.emp-stat-icon--trabajador{background:#ccfbf1;color:#0d9488}.emp-stat-data{display:flex;flex-direction:column;gap:1px;min-width:0}.emp-stat-value{font-family:var(--font-data);font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.emp-stat-label{font-family:var(--font-ui);font-size:.75rem;font-weight:500;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-bar{display:flex;align-items:center;gap:var(--sp-3);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);padding:8px var(--sp-3);transition:border-color var(--transition),box-shadow var(--transition);margin-bottom:var(--sp-4)}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.search-bar i{color:var(--color-text-muted);font-size:.875rem;flex-shrink:0}.search-bar input{flex:1;border:none;background:transparent;outline:none;font-family:var(--font-ui);font-size:.875rem;color:var(--color-text);padding:0;width:100%;box-shadow:none}.search-bar input::-moz-placeholder{color:var(--color-text-muted)}.search-bar input::placeholder{color:var(--color-text-muted)}.search-bar input:focus{outline:none;border:none;box-shadow:none}.emp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-4)}.emp-form-grid .form-full{grid-column:1 / -1}.emp-form-section{grid-column:1 / -1;padding-top:var(--sp-3);margin-top:var(--sp-1);border-top:1px solid var(--color-border)}.emp-form-section-label{font-family:var(--font-ui);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);margin-bottom:var(--sp-3);display:flex;align-items:center;gap:var(--sp-2)}.emp-form-section-label i{font-size:.625rem}.info-note{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--color-info-bg);border:1px solid rgba(37,99,235,.15);border-radius:var(--radius);margin-bottom:var(--sp-4);font-family:var(--font-ui);font-size:.8125rem;color:var(--color-info-text);line-height:1.5}.info-note i{font-size:.875rem;margin-top:1px;flex-shrink:0;color:var(--color-info)}.info-note--warning{background:var(--color-warning-bg);border-color:#d9770633;color:var(--color-warning-text)}.info-note--warning i{color:var(--color-warning)}.info-note--danger{background:var(--color-danger-bg);border-color:#dc262633;color:var(--color-danger-text)}.info-note--danger i{color:var(--color-danger)}.softdelete-list{display:flex;flex-direction:column;gap:var(--sp-2);margin:var(--sp-3) 0}.softdelete-item{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.875rem;color:var(--color-text-secondary)}.softdelete-item i{color:var(--color-text-muted);font-size:.75rem;flex-shrink:0;width:14px;text-align:center}.codigo-invitacion-wrap{display:flex;flex-direction:column;align-items:center;gap:var(--sp-4);padding:var(--sp-5) 0;text-align:center}.codigo-invitacion-label{font-family:var(--font-ui);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);line-height:1.5}.codigo-invitacion-display{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);background:var(--color-primary-subtle);border:2px dashed var(--color-primary-light);border-radius:var(--radius-lg)}.codigo-invitacion-text{font-family:var(--font-data);font-size:2rem;font-weight:700;color:var(--color-primary);letter-spacing:.15em;line-height:1}.codigo-copy-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:8px var(--sp-4);border-radius:var(--radius);background:var(--color-primary);color:#fff;border:none;font-family:var(--font-ui);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition),box-shadow var(--transition)}.codigo-copy-btn:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.codigo-copy-btn--copied{background:var(--color-success)}.codigo-expiracion{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-muted)}.codigo-expiracion i{font-size:.75rem;color:var(--color-warning)}.emp-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-4)}.emp-detail-item{display:flex;flex-direction:column;gap:3px}.emp-detail-item label{font-family:var(--font-ui);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);margin-bottom:0;display:block}.emp-detail-item span{font-family:var(--font-ui);font-size:.9375rem;font-weight:500;color:var(--color-text)}.emp-detail-avatar-row{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4);background:var(--color-bg);border-radius:var(--radius);margin-bottom:var(--sp-4);border:1px solid var(--color-border)}.emp-detail-avatar{width:56px;height:56px;min-width:56px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:1.25rem;font-weight:700;letter-spacing:.02em;flex-shrink:0}.emp-detail-avatar-info{display:flex;flex-direction:column;gap:var(--sp-1);min-width:0}.emp-detail-name{font-family:var(--font-ui);font-size:1.125rem;font-weight:700;color:var(--color-text);line-height:1.2}.emp-detail-id{font-family:var(--font-data);font-size:.75rem;color:var(--color-text-muted)}.tz-chip{display:inline-flex;align-items:center;gap:var(--sp-1);font-family:var(--font-data);font-size:.75rem;color:var(--color-text-secondary)}.tz-chip-offset{font-family:var(--font-data);font-size:.6875rem;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:1px 5px;margin-left:2px}.aprobacion-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--color-success-bg);color:var(--color-success-text);border:1px solid rgba(5,150,105,.2)}.aprobacion-badge--pendiente{background:var(--color-warning-bg);color:var(--color-warning-text);border-color:#d9770633}.aprobacion-badge--rechazado{background:var(--color-danger-bg);color:var(--color-danger-text);border-color:#dc262633}@media(max-width:768px){.emp-stats-bar{grid-template-columns:1fr 1fr}.emp-form-grid,.emp-detail-grid{grid-template-columns:1fr}.codigo-invitacion-text{font-size:1.5rem}}@media(max-width:600px){.emp-stats-bar{grid-template-columns:1fr 1fr}.codigo-invitacion-display{flex-direction:column;padding:var(--sp-4)}}.reporte-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-4);margin-bottom:var(--sp-5)}.reporte-kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-border-strong);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-5);display:flex;align-items:center;gap:var(--sp-4);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.reporte-kpi-card:hover{box-shadow:var(--shadow)}.reporte-kpi-card--total{border-left-color:var(--color-primary)}.reporte-kpi-card--atempo{border-left-color:var(--color-success)}.reporte-kpi-card--tardanza{border-left-color:var(--color-warning)}.reporte-kpi-card--falta{border-left-color:var(--color-danger)}.reporte-kpi-card--permiso{border-left-color:#6366f1}.reporte-kpi-card--rate{border-left-color:var(--color-primary);background:var(--color-primary-subtle)}.reporte-kpi-icon{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.reporte-kpi-card--total .reporte-kpi-icon{background:var(--color-primary-subtle);color:var(--color-primary)}.reporte-kpi-card--atempo .reporte-kpi-icon{background:var(--color-success-bg);color:var(--color-success)}.reporte-kpi-card--tardanza .reporte-kpi-icon{background:var(--color-warning-bg);color:var(--color-warning)}.reporte-kpi-card--falta .reporte-kpi-icon{background:var(--color-danger-bg);color:var(--color-danger)}.reporte-kpi-card--permiso .reporte-kpi-icon{background:#6366f11a;color:#6366f1}.reporte-kpi-card--rate .reporte-kpi-icon{background:#3730a326;color:var(--color-primary)}.reporte-kpi-data{flex:1}.reporte-kpi-val{font-family:var(--font-data);font-size:1.75rem;font-weight:700;color:var(--color-text);line-height:1}.reporte-kpi-lbl{font-size:.8125rem;color:var(--color-text-secondary);margin-top:var(--sp-1)}.dist-chart{display:flex;flex-direction:column;gap:var(--sp-4)}.dist-row{display:flex;flex-direction:column;gap:var(--sp-1)}.dist-label-row{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem}.dist-label{font-weight:500;color:var(--color-text)}.dist-pct{font-family:var(--font-data);font-weight:600;color:var(--color-text-secondary)}.dist-track{height:8px;background:var(--color-surface-alt);border-radius:999px;overflow:hidden}.dist-fill{height:100%;border-radius:999px;transition:width .5s ease}.dist-fill--atempo{background:var(--color-success)}.dist-fill--tardanza{background:var(--color-warning)}.dist-fill--falta{background:var(--color-danger)}.dist-fill--permiso{background:#6366f1}.reporte-layout{display:grid;grid-template-columns:1fr 300px;gap:var(--sp-5);align-items:start}.export-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-5);box-shadow:var(--shadow-sm)}.export-section h3{font-size:.9375rem;font-weight:600;margin-bottom:var(--sp-1)}.export-section>p{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:var(--sp-4);line-height:1.5}.export-section-btns{display:flex;flex-direction:column;gap:var(--sp-2)}.export-btn-xl{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius);border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;font-family:var(--font-ui);font-size:.875rem;font-weight:500;transition:all var(--transition);color:var(--color-text);width:100%;text-align:left}.export-btn-xl:hover{box-shadow:var(--shadow)}.export-btn-xl:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.export-btn-xl--excel{border-color:#05966959}.export-btn-xl--excel:hover{background:var(--color-success-bg);border-color:var(--color-success)}.export-btn-xl--excel .export-xl-icon{color:var(--color-success)}.export-btn-xl--pdf{border-color:#dc26264d}.export-btn-xl--pdf:hover{background:var(--color-danger-bg);border-color:var(--color-danger)}.export-btn-xl--pdf .export-xl-icon{color:var(--color-danger)}.export-xl-icon{font-size:1.125rem;flex-shrink:0}.export-xl-label{flex:1;line-height:1.2}.export-xl-sub{font-size:.75rem;color:var(--color-text-muted);display:block;margin-top:2px}.voz-resumen-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4);margin-bottom:var(--sp-5)}.voz-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);text-align:center;box-shadow:var(--shadow-sm)}.voz-stat-val{font-family:var(--font-data);font-size:2rem;font-weight:700;color:var(--color-text);line-height:1}.voz-stat-lbl{font-size:.8125rem;color:var(--color-text-secondary);margin-top:var(--sp-2)}.voz-stat-card--completados .voz-stat-val{color:var(--color-success)}.voz-stat-card--pendientes .voz-stat-val{color:var(--color-warning)}.voz-stat-card--rate .voz-stat-val{color:var(--color-primary)}.week-nav{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-4);flex-wrap:wrap}.week-nav-label{flex:1;font-weight:600;font-size:.9375rem;color:var(--color-text);text-align:center}.week-nav-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:all var(--transition)}.week-nav-btn:hover{background:var(--color-bg);border-color:var(--color-border-strong)}.week-nav-btn--today{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.week-nav-btn--today:hover{background:var(--color-primary-hover)}.week-estado-chip{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:700;font-family:var(--font-ui);letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.week-estado-chip--a_tiempo{background:var(--color-success-bg);color:var(--color-success)}.week-estado-chip--tardanza{background:var(--color-warning-bg);color:var(--color-warning)}.week-estado-chip--falta{background:var(--color-danger-bg);color:var(--color-danger)}.week-estado-chip--esperando{background:#3b82f61f;color:#3b82f6}.week-estado-chip--no_laboral{color:var(--color-text-muted);font-size:.75rem}.voz-emp-name{font-weight:500;color:var(--color-text);font-size:.875rem}.voz-emp-sub{font-size:.75rem;color:var(--color-text-muted);margin-top:2px}.voz-resumen-cell{font-family:var(--font-data);font-size:.875rem;font-weight:600;white-space:nowrap}.auto-report-list{display:flex;flex-direction:column;gap:var(--sp-3)}.auto-report-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-5);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.auto-report-card:hover{box-shadow:var(--shadow)}.auto-report-card--inactive{opacity:.6}.auto-report-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-3)}.auto-report-email{font-weight:600;font-size:.9375rem;color:var(--color-text);display:flex;align-items:center;gap:var(--sp-2)}.auto-report-email i{color:var(--color-primary)}.auto-report-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-3);margin-bottom:var(--sp-3);padding-bottom:var(--sp-3);border-bottom:1px solid var(--color-border)}.auto-report-meta-item{display:flex;flex-direction:column;gap:2px}.auto-report-meta-label{font-size:.6875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.auto-report-meta-val{font-size:.875rem;font-weight:500;color:var(--color-text)}.auto-report-actions{display:flex;align-items:center;gap:var(--sp-2)}.auto-report-btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-3);border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition);color:var(--color-text)}.auto-report-btn:hover{background:var(--color-bg);border-color:var(--color-border-strong)}.auto-report-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.auto-report-btn--test{color:var(--color-primary);border-color:var(--color-primary-light)}.auto-report-btn--test:hover{background:var(--color-primary-subtle)}.auto-report-btn--delete{color:var(--color-danger);border-color:#dc262640}.auto-report-btn--delete:hover{background:var(--color-danger-bg);border-color:var(--color-danger)}.toggle-wrap{display:flex;align-items:center;gap:var(--sp-2);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.toggle-wrap input{position:absolute;opacity:0;width:0;height:0}.toggle-track{position:relative;width:36px;height:20px;background:var(--color-border-strong);border-radius:999px;transition:background var(--transition);flex-shrink:0}.toggle-wrap input:checked+.toggle-track{background:var(--color-success)}.toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #00000040;transition:transform var(--transition)}.toggle-wrap input:checked+.toggle-track .toggle-thumb{transform:translate(16px)}.toggle-label{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary)}.day-chips{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-1)}.day-chip{padding:4px 10px;border:1.5px solid var(--color-border);border-radius:var(--radius);font-size:.8125rem;font-weight:500;cursor:pointer;background:var(--color-surface);color:var(--color-text-secondary);transition:all var(--transition);font-family:var(--font-ui)}.day-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.day-chip--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.auto-info-note{display:flex;gap:var(--sp-3);padding:var(--sp-4);background:var(--color-primary-subtle);border:1px solid var(--color-primary-light);border-radius:var(--radius-md);margin-bottom:var(--sp-5)}.auto-info-note i{color:var(--color-primary);font-size:1rem;flex-shrink:0;margin-top:2px}.auto-info-note-body{display:flex;flex-direction:column;gap:4px}.auto-info-note-body p{font-size:.875rem;color:var(--color-text-secondary);margin:0;line-height:1.5}.form-group{margin-bottom:var(--sp-4)}.form-group:last-child{margin-bottom:0}.form-group>label{display:block;font-size:.875rem;font-weight:500;margin-bottom:var(--sp-1)}.perfil-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--sp-5);align-items:start}.perfil-hero{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--sp-6);text-align:center;box-shadow:var(--shadow-sm);position:sticky;top:calc(var(--header-height) + var(--sp-5))}.perfil-avatar{width:88px;height:88px;border-radius:50%;background:var(--color-primary);color:#fff;font-family:var(--font-ui);font-size:2rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto var(--sp-4);box-shadow:0 4px 16px #3730a34d;letter-spacing:-1px}.perfil-hero-name{font-size:1.125rem;font-weight:700;color:var(--color-text);margin-bottom:var(--sp-2);font-family:var(--font-ui)}.perfil-hero-email{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:var(--sp-4);word-break:break-all}.perfil-hero-divider{height:1px;background:var(--color-border);margin:var(--sp-4) 0}.perfil-hero-meta{display:flex;flex-direction:column;gap:var(--sp-2);text-align:left}.perfil-hero-meta-item{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem}.perfil-hero-meta-label{color:var(--color-text-muted)}.perfil-hero-meta-val{font-weight:500;color:var(--color-text)}.plan-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;padding:2px 10px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}.plan-badge--trial{background:#fef3c7;color:#b45309}.plan-badge--basico{background:#e0e7ff;color:#3730a3}.plan-badge--profesional{background:#d1fae5;color:#065f46}.plan-badge--empresarial{background:#ede9fe;color:#5b21b6}.plan-badge--personalizado{background:#f0fdf4;color:#166534}.perfil-sections{display:flex;flex-direction:column;gap:var(--sp-5)}.perfil-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3) var(--sp-6)}.perfil-info-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:4px}.perfil-info-value{font-size:.9375rem;color:var(--color-text);font-weight:500}.perfil-info-value--mono{font-family:var(--font-data)}.trial-countdown{display:inline-flex;align-items:center;gap:var(--sp-2);background:#fef3c7;color:#92400e;border:1px solid #FDE68A;border-radius:var(--radius);padding:var(--sp-2) var(--sp-3);font-size:.875rem;font-weight:500;margin-top:var(--sp-3)}.trial-countdown i{font-size:.875rem}.field-error{font-size:.8125rem;color:var(--color-danger);margin-top:var(--sp-1);display:flex;align-items:center;gap:4px}.section-title-row{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--color-border)}.section-title-row h2,.section-title-row h3{margin:0;font-size:1rem;font-weight:600}.section-title-row i{color:var(--color-primary);width:16px;text-align:center}.entity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--sp-4);margin-top:var(--sp-4)}.entity-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4) var(--sp-5);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),border-color var(--transition),transform var(--transition);cursor:pointer;display:flex;flex-direction:column;gap:var(--sp-3)}.entity-card:hover{box-shadow:var(--shadow);border-color:var(--color-primary-light);transform:translateY(-1px)}.entity-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-2)}.entity-card-name{font-weight:700;font-size:1rem;color:var(--color-text);line-height:1.3}.entity-card-desc{font-size:.8125rem;color:var(--color-text-muted);line-height:1.5;flex:1}.entity-card-meta{display:flex;flex-wrap:wrap;gap:var(--sp-2);font-size:.8125rem;color:var(--color-text-secondary)}.entity-card-meta-item{display:flex;align-items:center;gap:4px}.entity-card-meta-item i{font-size:.75rem;color:var(--color-text-muted)}.entity-card-actions{display:flex;gap:var(--sp-2);padding-top:var(--sp-3);border-top:1px solid var(--color-border);margin-top:auto}.entity-card-btn{flex:1;font-size:.8125rem;padding:var(--sp-1) var(--sp-2);border-radius:var(--radius);border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all var(--transition);font-family:var(--font-ui)}.entity-card-btn:hover{background:var(--color-bg);border-color:var(--color-border-strong);color:var(--color-text)}.entity-card-btn--danger:hover{background:var(--color-danger-bg);border-color:var(--color-danger);color:var(--color-danger)}.estado-badge{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:99px;white-space:nowrap;flex-shrink:0}.estado-badge--activo{background:var(--color-success-bg);color:var(--color-success)}.estado-badge--inactivo{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.estado-badge--planificacion{background:#ede9fe;color:#5b21b6}.estado-badge--pausado{background:var(--color-warning-bg);color:var(--color-warning)}.estado-badge--completado{background:var(--color-success-bg);color:var(--color-success)}.estado-badge--cancelado{background:var(--color-danger-bg);color:var(--color-danger)}.encargado-list{display:flex;flex-wrap:wrap;gap:var(--sp-1)}.encargado-chip{font-size:.75rem;background:var(--color-primary-subtle);color:var(--color-primary);padding:2px 8px;border-radius:99px;font-weight:500}.accion-tabs{display:flex;gap:var(--sp-1);flex-wrap:wrap;padding:var(--sp-1);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--sp-5)}.accion-tab{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius);border:none;background:transparent;color:var(--color-text-secondary);font-family:var(--font-ui);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap}.accion-tab:hover{background:var(--color-surface);color:var(--color-text)}.accion-tab--active{background:var(--color-surface);color:var(--color-primary);font-weight:600;box-shadow:var(--shadow-sm)}.accion-tab-badge{font-size:.6875rem;font-weight:700;background:var(--color-danger);color:#fff;padding:1px 6px;border-radius:99px;min-width:18px;text-align:center}.accion-tab-badge--warning{background:var(--color-warning)}.accion-tab-badge--info{background:var(--color-primary)}.accion-tab-badge--success{background:var(--color-success)}.urgency-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-3)}.urgency-card{background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2);cursor:pointer;transition:box-shadow var(--transition),transform var(--transition)}.urgency-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.urgency-card--alta{border-left-color:var(--color-danger)}.urgency-card--media{border-left-color:var(--color-warning)}.urgency-card--baja{border-left-color:var(--color-success)}.urgency-card--info{border-left-color:var(--color-primary)}.urgency-card-count{font-family:var(--font-data);font-size:2rem;font-weight:700;color:var(--color-text);line-height:1}.urgency-card--alta .urgency-card-count{color:var(--color-danger)}.urgency-card--media .urgency-card-count{color:var(--color-warning)}.urgency-card--info .urgency-card-count{color:var(--color-primary)}.urgency-card-label{font-size:.875rem;font-weight:600;color:var(--color-text)}.urgency-card-sub{font-size:.75rem;color:var(--color-text-muted)}.accion-content{animation:fadeInUp .15s ease forwards}.accion-list{display:flex;flex-direction:column;gap:var(--sp-3)}.accion-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);display:flex;align-items:center;gap:var(--sp-4)}.accion-item-info{flex:1;min-width:0}.accion-item-name{font-weight:600;font-size:.9375rem;color:var(--color-text);truncate:true}.accion-item-meta{font-size:.8125rem;color:var(--color-text-muted);margin-top:2px}.accion-item-actions{display:flex;gap:var(--sp-2);flex-shrink:0}.accion-btn{font-size:.8125rem;font-weight:500;padding:var(--sp-1) var(--sp-3);border-radius:var(--radius);border:1.5px solid var(--color-border);background:transparent;cursor:pointer;font-family:var(--font-ui);transition:all var(--transition);display:inline-flex;align-items:center;gap:4px;color:var(--color-text-secondary)}.accion-btn:hover{background:var(--color-bg);border-color:var(--color-border-strong);color:var(--color-text)}.accion-btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.accion-btn--primary:hover{background:var(--color-primary-hover)}.accion-btn--danger{color:var(--color-danger);border-color:#dc26264d}.accion-btn--danger:hover{background:var(--color-danger-bg);border-color:var(--color-danger)}.accion-btn--success{color:var(--color-success);border-color:#0596694d}.accion-btn--success:hover{background:var(--color-success-bg);border-color:var(--color-success)}@media(max-width:1024px){.perfil-layout{grid-template-columns:1fr}.perfil-hero{position:static}.perfil-info-grid{grid-template-columns:1fr}.entity-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.urgency-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.accion-tabs{gap:2px}.accion-tab{font-size:.75rem;padding:var(--sp-1) var(--sp-2)}.accion-item{flex-direction:column;align-items:flex-start}.accion-item-actions{width:100%}.urgency-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.entity-grid{grid-template-columns:1fr}.urgency-grid{grid-template-columns:1fr 1fr}}@media(max-width:1024px){.reporte-kpi-grid{grid-template-columns:repeat(2,1fr)}.reporte-layout{grid-template-columns:1fr}.auto-report-meta-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.voz-resumen-bar,.auto-report-meta-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.reporte-kpi-grid{grid-template-columns:1fr 1fr}.voz-resumen-bar{grid-template-columns:repeat(2,1fr)}.week-nav{flex-direction:row;flex-wrap:wrap;justify-content:center}.week-nav-label{order:-1;flex-basis:100%;text-align:center;font-size:.875rem}.auto-report-meta-grid{grid-template-columns:1fr 1fr}.auto-report-card{padding:var(--sp-3) var(--sp-4)}}.db-hero{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-6);padding:var(--sp-6) var(--sp-8);background:linear-gradient(135deg,#1e1b4b,#3730a3 45%,#4f46e5);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);position:relative;overflow:hidden;animation:dbHeroReveal .75s cubic-bezier(.16,1,.3,1) both}.db-hero:before{content:"";position:absolute;top:-50%;right:-8%;width:340px;height:340px;background:#ffffff0a;border-radius:50%;pointer-events:none}.db-hero:after{content:"";position:absolute;bottom:-70%;left:25%;width:260px;height:260px;background:#ffffff08;border-radius:50%;pointer-events:none}.db-hero-left{display:flex;flex-direction:column;gap:var(--sp-1);z-index:1}.db-hero-greeting{font-family:var(--font-ui);font-size:1.75rem;font-weight:700;color:#fff;line-height:1.2;letter-spacing:-.02em}.db-hero-greeting span{color:#a5b4fc}.db-hero-date{font-family:var(--font-ui);font-size:.875rem;color:#ffffff8c;display:flex;align-items:center;gap:var(--sp-2);text-transform:capitalize}.db-hero-kpis{display:flex;align-items:center;gap:var(--sp-3);z-index:1;flex-wrap:wrap;justify-content:flex-end}.db-hero-kpi{display:flex;flex-direction:column;align-items:center;gap:2px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);min-width:72px;cursor:pointer;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.db-hero-kpis .db-hero-kpi:nth-child(1){animation:dbKpiPop .55s cubic-bezier(.16,1,.3,1) .18s both}.db-hero-kpis .db-hero-kpi:nth-child(2){animation:dbKpiPop .55s cubic-bezier(.16,1,.3,1) .28s both}.db-hero-kpis .db-hero-kpi:nth-child(3){animation:dbKpiPop .55s cubic-bezier(.16,1,.3,1) .38s both}.db-hero-kpis .db-hero-kpi:nth-child(4){animation:dbKpiPop .55s cubic-bezier(.16,1,.3,1) .48s both}.db-hero-kpi:hover{background:#ffffff2e;transform:translateY(-2px);box-shadow:0 8px 20px #00000040}.db-hero-kpi i{font-size:.875rem;color:#fff9;margin-bottom:2px}.db-hero-kpi-val{font-family:var(--font-data);font-size:1.625rem;font-weight:700;color:#fff;line-height:1;letter-spacing:-.03em}.db-hero-kpi-label{font-family:var(--font-ui);font-size:.6875rem;font-weight:500;color:#fff9;text-transform:uppercase;letter-spacing:.06em}.db-hero-kpi--accent{background:#ffffff2e;border-color:#ffffff4d}.db-hero-kpi--accent .db-hero-kpi-val,.db-hero-kpi--accent .db-hero-kpi-label{color:#fff}.db-hero-kpi--success{background:#05966940;border-color:#05966966}.db-hero-kpi--success .db-hero-kpi-val{color:#6ee7b7}.db-hero-kpi--success .db-hero-kpi-label{color:#6ee7b7b3}.db-main-grid{display:grid;grid-template-columns:320px 1fr;gap:var(--sp-5);margin-bottom:var(--sp-5)}.db-main-grid .db-panel:nth-child(1){animation:dbPanelReveal .7s cubic-bezier(.16,1,.3,1) .12s both}.db-main-grid .db-panel:nth-child(2){animation:dbPanelReveal .7s cubic-bezier(.16,1,.3,1) .22s both}.db-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--sp-5) var(--sp-6);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--sp-4)}.db-panel-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}.db-panel-title{font-family:var(--font-ui);font-size:.9375rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:var(--sp-2)}.db-panel-title i{color:var(--color-primary);font-size:.875rem}.db-asist-badge{font-family:var(--font-data);font-size:1rem;font-weight:700;padding:4px 12px;border-radius:100px;letter-spacing:-.01em}.db-asist-badge--success{background:var(--color-success-bg);color:var(--color-success)}.db-asist-badge--warning{background:var(--color-warning-bg);color:var(--color-warning)}.db-asist-badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.db-donut-wrapper{display:flex;flex-direction:column;gap:var(--sp-4);flex:1}.db-donut-chart{position:relative;width:180px;height:180px;align-self:center;flex-shrink:0}.db-donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.db-donut-pct{font-family:var(--font-data);font-size:1.75rem;font-weight:700;color:var(--color-text);line-height:1;letter-spacing:-.03em}.db-donut-pct--empty{color:var(--color-text-muted);font-size:1.5rem}.db-donut-sub{font-family:var(--font-ui);font-size:.6875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.db-att-metrics{display:flex;flex-direction:column;gap:var(--sp-2)}.db-att-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius);background:var(--color-surface-alt)}.db-att-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.db-att-row--success .db-att-dot{background:var(--color-success)}.db-att-row--warning .db-att-dot{background:var(--color-warning)}.db-att-row--danger .db-att-dot{background:var(--color-danger)}.db-att-row--muted .db-att-dot{background:var(--color-border-strong)}.db-att-name{flex:1;font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-secondary)}.db-att-num{font-family:var(--font-data);font-size:1rem;font-weight:700;color:var(--color-text)}.db-att-row--success .db-att-num{color:var(--color-success)}.db-att-row--warning .db-att-num{color:var(--color-warning)}.db-att-row--danger .db-att-num{color:var(--color-danger)}.db-panel--trend{min-height:320px}.db-chart-area{flex:1;min-height:240px;position:relative}.db-chart-loading{display:flex;align-items:center;justify-content:center;height:100%;min-height:200px}.db-chart-loading .section-loading{min-height:180px;padding:var(--sp-4)}.db-chart-empty{font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-muted);text-align:center;margin:0;display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) 0}.db-entities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5);margin-bottom:var(--sp-5)}.db-entities-grid .db-entity-card:nth-child(1){animation:dbCardReveal .65s cubic-bezier(.16,1,.3,1) .36s both}.db-entities-grid .db-entity-card:nth-child(2){animation:dbCardReveal .65s cubic-bezier(.16,1,.3,1) .46s both}.db-entities-grid .db-entity-card:nth-child(3){animation:dbCardReveal .65s cubic-bezier(.16,1,.3,1) .56s both}.db-entity-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--sp-5) var(--sp-6);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--sp-3);transition:box-shadow var(--transition),transform var(--transition);position:relative;overflow:hidden}.db-entity-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.db-entity-card--zonas:before{background:linear-gradient(90deg,var(--color-primary),#818CF8)}.db-entity-card--proyectos:before{background:linear-gradient(90deg,var(--color-info),#38BDF8)}.db-entity-card--equipo:before{background:linear-gradient(90deg,var(--color-success),#34D399)}.db-entity-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.db-entity-header{display:flex;align-items:center;justify-content:space-between}.db-entity-icon-box{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.125rem}.db-entity-card--zonas .db-entity-icon-box{background:var(--color-primary-subtle);color:var(--color-primary)}.db-entity-card--proyectos .db-entity-icon-box{background:var(--color-info-bg);color:var(--color-info)}.db-entity-card--equipo .db-entity-icon-box{background:var(--color-success-bg);color:var(--color-success)}.db-entity-tag{font-family:var(--font-ui);font-size:.6875rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;padding:3px 8px;border-radius:100px;background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.db-entity-count{font-family:var(--font-data);font-size:3rem;font-weight:700;line-height:1;letter-spacing:-.04em;color:var(--color-text)}.db-entity-card--zonas .db-entity-count{color:var(--color-primary)}.db-entity-card--proyectos .db-entity-count{color:var(--color-info)}.db-entity-card--equipo .db-entity-count{color:var(--color-success)}.db-entity-label{font-family:var(--font-ui);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-top:calc(-1 * var(--sp-2))}.db-team-breakdown{display:flex;flex-direction:column;gap:var(--sp-1);padding:var(--sp-2) 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.db-team-item{display:flex;align-items:center;gap:var(--sp-2)}.db-team-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.db-team-dot--primary{background:var(--color-primary)}.db-team-dot--warning{background:var(--color-warning)}.db-team-dot--success{background:var(--color-success)}.db-team-role{flex:1;font-family:var(--font-ui);font-size:.8125rem;color:var(--color-text-secondary)}.db-team-num{font-family:var(--font-data);font-size:.875rem;font-weight:700;color:var(--color-text)}.db-entity-btn{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.8125rem;font-weight:600;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition);width:100%;justify-content:center;margin-top:auto}.db-entity-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-subtle)}.db-entity-btn i{font-size:.75rem;transition:transform var(--transition)}.db-entity-btn:hover i{transform:translate(3px)}@keyframes db-dot-pulse{0%,to{box-shadow:0 0 #10b9818c;transform:scale(1)}50%{box-shadow:0 0 0 5px #10b98100;transform:scale(1.25)}}.db-entity-preview{display:flex;flex-direction:column;gap:2px;padding:var(--sp-2) 0;border-top:1px solid var(--color-border);flex:1;min-width:0}.db-entity-preview-item{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:var(--sp-2);padding:5px 8px;border-radius:var(--radius);cursor:pointer;transition:background var(--transition);min-width:0}.db-entity-preview-item:hover{background:var(--color-bg)}.db-entity-preview-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border-strong);justify-self:center}.db-entity-preview-dot--inactive{background:var(--color-text-muted);opacity:.5}.db-entity-preview-dot--active{background:#10b981;box-shadow:0 0 #10b9818c;animation:db-dot-pulse 2.2s ease-in-out infinite}.db-entity-preview-name{min-width:0;font-family:var(--font-ui);font-size:.8rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.db-entity-preview-badge{font-family:var(--font-ui);font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 7px;border-radius:100px;background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border);white-space:nowrap}.db-entity-preview-badge--active{background:#10b9811a;color:#059669;border-color:#10b98140}.db-entity-preview-zone{display:flex;align-items:center;gap:3px;font-family:var(--font-ui);font-size:.65rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:72px}.db-entity-preview-zone i{font-size:.5rem;flex-shrink:0}.db-entity-preview-more{font-family:var(--font-ui);font-size:.7rem;color:var(--color-primary);padding:1px 8px;font-weight:500;letter-spacing:.01em}.db-team-asist-bar{padding:var(--sp-2) 0;border-top:1px solid var(--color-border)}.db-team-asist-label{display:flex;justify-content:space-between;font-family:var(--font-ui);font-size:.75rem;color:var(--color-text-muted);margin-bottom:6px}.db-team-asist-pct{font-weight:700;color:var(--color-text-secondary);font-family:var(--font-data)}.db-team-asist-track{height:5px;background:var(--color-border);border-radius:100px;overflow:hidden}.db-team-asist-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--color-success),#34D399);transition:width .6s ease}.db-analytics-section{animation:dbPanelReveal .7s cubic-bezier(.16,1,.3,1) .66s both}.db-analytics-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}.db-analytics-header h2{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:1rem;font-weight:700;color:var(--color-text);margin:0}.db-analytics-header h2 i{color:var(--color-primary);font-size:.875rem}.db-analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5)}.db-analytics-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.db-analytics-panel-title{display:flex;align-items:center;gap:var(--sp-2);font-family:var(--font-ui);font-size:.8125rem;font-weight:700;color:var(--color-text-secondary);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--color-border);background:var(--color-bg);text-transform:uppercase;letter-spacing:.04em}.db-analytics-panel-title i{color:var(--color-primary)}.db-analytics-panel .table-wrapper{border-radius:0;border:none;box-shadow:none}@media(max-width:1200px){.db-main-grid{grid-template-columns:300px 1fr}}@media(max-width:960px){.db-main-grid{grid-template-columns:1fr}.db-entities-grid{grid-template-columns:1fr 1fr}.db-hero{flex-direction:column;align-items:flex-start;gap:var(--sp-4)}.db-hero-kpis{justify-content:flex-start}.db-analytics-grid{grid-template-columns:1fr}}@media(max-width:600px){.db-entities-grid{grid-template-columns:1fr}.db-hero-kpis{flex-wrap:wrap}.db-hero-kpi{min-width:calc(50% - var(--sp-2))}.db-hero{padding:var(--sp-5) var(--sp-4)}.db-analytics-header{flex-direction:column;align-items:flex-start;gap:var(--sp-3)}}body,header,nav,main,section,.panel-root,.panel-body,aside,.stat-card,.chart-card,.modal-box,.modal-header,.modal-footer,.alert-card,.action-item,.db-hero,.db-panel,.db-entity-card,.db-entity-btn,.db-entity-tag,.db-entity-icon-box,.db-att-row,.db-asist-badge{transition:background-color .22s ease,background .22s ease,border-color .22s ease,color .22s ease,box-shadow .22s ease}[data-theme=dark] header{background:#161b22;border-bottom-color:#f0f6fc14;box-shadow:0 1px #0006}[data-theme=dark] .header-role-badge.role-director{background:#4f46e533;color:#a5b4fc}[data-theme=dark] .header-role-badge.role-administrador{background:#7c3aed33;color:#c4b5fd}[data-theme=dark] .header-role-badge.role-supervisor{background:#0d948833;color:#5eead4}[data-theme=dark] .header-role-badge.role-dev{background:#eab30826;color:#fde68a}[data-theme=dark] .hamburger-btn:hover{background:#f0f6fc14;color:var(--color-text)}[data-theme=dark] .logout-btn{border-color:#f851494d!important;color:#f85149!important}[data-theme=dark] .logout-btn:hover{background:#f851491f!important;border-color:#f8514980!important}[data-theme=dark] nav a:hover:after{background:#1c2128!important;color:#cdd9e5!important;border:1px solid rgba(240,246,252,.12)!important;box-shadow:0 4px 12px #00000080!important}[data-theme=dark] nav a[aria-current=page]{background:linear-gradient(90deg,#3730a3,#4338ca);box-shadow:0 0 12px #6366f166,0 2px 8px #3730a380,inset 0 1px #ffffff14}[data-theme=dark] nav a:hover{background:#f0f6fc0f;color:#cdd9e5}[data-theme=dark] .sidebar-role-badge.role-director{background:#4f46e533;color:#a5b4fc;border-color:#4f46e54d}[data-theme=dark] .sidebar-role-badge.role-administrador{background:#7c3aed33;color:#c4b5fd;border-color:#7c3aed4d}[data-theme=dark] .sidebar-role-badge.role-supervisor{background:#0d948833;color:#5eead4;border-color:#0d94884d}[data-theme=dark] .sidebar-role-badge.role-dev{background:#eab30826;color:#fde68a;border-color:#eab30840}[data-theme=dark] .stat-card{background:linear-gradient(160deg,#1a2133,#161b22);border-color:#f0f6fc14}[data-theme=dark] .stat-card:hover{border-color:#f0f6fc29;box-shadow:0 0 0 1px #4f46e533,0 8px 24px #00000073}[data-theme=dark] .stat-card-icon-row{background:#f0f6fc0d;color:var(--color-text-secondary)}[data-theme=dark] .stat-card-success .stat-card-icon-row{background:#2ea04326;color:#3fb950}[data-theme=dark] .stat-card-warning .stat-card-icon-row{background:#bb800926;color:#d29922}[data-theme=dark] .stat-card-danger .stat-card-icon-row{background:#f8514926;color:#f85149}[data-theme=dark] .stat-card-primary .stat-card-icon-row{background:#4f46e52e;color:#818cf8}[data-theme=dark] thead{background:linear-gradient(90deg,#211f74,#2e2b97)}[data-theme=dark] tbody tr:nth-child(2n){background:#f0f6fc06}[data-theme=dark] tbody tr:hover,[data-theme=dark] tbody tr:nth-child(2n):hover{background:#4f46e51a}[data-theme=dark] tbody th,[data-theme=dark] table:not(:has(thead)) td:first-child,[data-theme=dark] table:not(:has(thead)) th{background:#f0f6fc08;color:var(--color-text-secondary)}[data-theme=dark] tfoot{background:#f0f6fc0a;border-top-color:#f0f6fc1a}[data-theme=dark] div:has(>table),[data-theme=dark] .table-wrapper{border-color:#f0f6fc14}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:#0d1117;border-color:#f0f6fc1a;color:var(--color-text)}[data-theme=dark] input:hover,[data-theme=dark] select:hover,[data-theme=dark] textarea:hover{border-color:#f0f6fc33}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e533;background:#0d1117}[data-theme=dark] input:disabled,[data-theme=dark] select:disabled,[data-theme=dark] textarea:disabled{background:#f0f6fc08;color:var(--color-text-muted);border-color:#f0f6fc0f}[data-theme=dark] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236E7681' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}[data-theme=dark] fieldset{border-color:#f0f6fc1a}[data-theme=dark] button[type=button]:not(header button):not(.dark-mode-btn):not(.logout-btn):not(.period-btn):not(.section-action-btn):not(.alert-card-btn):not(.modal-close-btn){background:#1c2128;border-color:#f0f6fc1f;color:var(--color-text)}[data-theme=dark] button[type=button]:not(header button):not(.dark-mode-btn):not(.logout-btn):not(.period-btn):not(.section-action-btn):not(.alert-card-btn):not(.modal-close-btn):hover{background:#262d36;border-color:#f0f6fc33}[data-theme=dark] .modal-overlay,[data-theme=dark] [role=dialog][aria-modal=true]{background:#010409bf!important;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}[data-theme=dark] .modal-box{background:#161b22;border:1px solid rgba(240,246,252,.1);box-shadow:0 0 0 1px #f0f6fc0f,0 24px 48px #000000b3}[data-theme=dark] .modal-header{background:#1c2128;border-bottom-color:#f0f6fc14}[data-theme=dark] .modal-footer{background:#1c2128;border-top-color:#f0f6fc14}[data-theme=dark] .modal-close-btn{border-color:#f0f6fc1f;color:#8b949e}[data-theme=dark] .modal-close-btn:hover{background:#f0f6fc0f;color:#e6edf3;border-color:#f0f6fc33}[data-theme=dark] [role=dialog][aria-modal=true]>div{background:#161b22!important;box-shadow:0 0 0 1px #f0f6fc0f,0 24px 48px #000000b3!important}[data-theme=dark] [role=dialog][aria-modal=true]>div>div:first-child{background:#1c2128;border-bottom-color:#f0f6fc14!important}[data-theme=dark] [role=dialog][aria-modal=true]>div>div:last-child:not(:first-child){background:#1c2128;border-top-color:#f0f6fc14!important}[data-theme=dark] [style*="position: fixed"][style*="bottom: 16"]{background:#1c2128!important;color:#e6edf3!important;border:1px solid rgba(240,246,252,.1)!important;box-shadow:0 8px 24px #0009!important}[data-theme=dark] .toast--success{background:#2ea04326;border-color:#3fb9504d;color:#3fb950}[data-theme=dark] .toast--error{background:#f8514926;border-color:#f851494d;color:#f85149}[data-theme=dark] .toast--warning{background:#bb800926;border-color:#d299224d;color:#d29922}[data-theme=dark] .toast--info{background:#388bfd26;border-color:#58a6ff4d;color:#58a6ff}[data-theme=dark] .toast--success .toast-icon{color:#3fb950}[data-theme=dark] .toast--error .toast-icon{color:#f85149}[data-theme=dark] .toast--warning .toast-icon{color:#d29922}[data-theme=dark] .toast--info .toast-icon{color:#58a6ff}[data-theme=dark] .dashboard-welcome-section{background:linear-gradient(135deg,#1e1b6a,#2e2b97 55%,#3730a3);box-shadow:0 0 0 1px #6366f133,0 8px 32px #3730a373}[data-theme=dark] section{background:#161b22;border-color:#f0f6fc14;box-shadow:0 1px #0000004d}[data-theme=dark] section>h2:first-child,[data-theme=dark] section>.section-header-row h2{border-bottom-color:#f0f6fc14}[data-theme=dark] .chart-card{background:#161b22;border-color:#f0f6fc14}[data-theme=dark] .alert-card--warning{background:#bb80091f;border-color:#d2992240}[data-theme=dark] .alert-card--danger{background:#f851491f;border-color:#f8514940}[data-theme=dark] .alert-card--info{background:#388bfd1f;border-color:#58a6ff33}[data-theme=dark] .alert-card-btn:hover{background:#8a6700}[data-theme=dark] .alert-card--danger .alert-card-btn:hover{background:#b91c1c}[data-theme=dark] .action-item--warning{background:#bb80091f;border-color:#d2992233;color:#d29922}[data-theme=dark] .action-item--danger{background:#f851491f;border-color:#f8514933;color:#f85149}[data-theme=dark] .action-item--info{background:#388bfd1f;border-color:#58a6ff33;color:#58a6ff}[data-theme=dark] .period-btn{background:transparent;border-color:#f0f6fc1f;color:#8b949e}[data-theme=dark] .period-btn:hover{border-color:#4f46e5;color:#818cf8;background:#4f46e526}[data-theme=dark] .period-btn--active{background:#4f46e5;border-color:#4f46e5;color:#fff}[data-theme=dark] .period-btn--active:hover{background:#4338ca;border-color:#4338ca}[data-theme=dark] .section-action-btn{background:#4f46e52e;border-color:#4f46e559;color:#818cf8}[data-theme=dark] .section-action-btn:hover{background:#4f46e547;border-color:#4f46e580}[data-theme=dark] .status-a-tiempo,[data-theme=dark] .status-puntual,[data-theme=dark] .status-activo{background:#2ea04326;color:#3fb950}[data-theme=dark] .status-tardanza,[data-theme=dark] .status-tarde,[data-theme=dark] .status-vacaciones,[data-theme=dark] .status-suspendido{background:#bb800926;color:#d29922}[data-theme=dark] .status-falta,[data-theme=dark] .status-ausente,[data-theme=dark] .status-inactivo,[data-theme=dark] .status-desvinculado,[data-theme=dark] .status-baja{background:#f8514926;color:#f85149}[data-theme=dark] .status-justificado,[data-theme=dark] .status-permiso{background:#388bfd26;color:#58a6ff}[data-theme=dark] .badge-primary{background:#4f46e533;color:#818cf8}[data-theme=dark] .badge-success{background:#2ea04326;color:#3fb950}[data-theme=dark] .badge-warning{background:#bb800926;color:#d29922}[data-theme=dark] .badge-danger{background:#f8514926;color:#f85149}[data-theme=dark] .badge-neutral{background:#f0f6fc0f;color:#8b949e;border-color:#f0f6fc1a}[data-theme=dark] .filters-bar{border-bottom-color:#f0f6fc14}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#161b22 25%,#1c2128,#161b22 75%);background-size:200% 100%}[data-theme=dark] ::-webkit-scrollbar-track{background:transparent}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#f0f6fc1a}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#f0f6fc2e}[data-theme=dark] nav::-webkit-scrollbar-thumb{background:#f0f6fc14}[data-theme=dark] .employee-avatar{background:#4f46e533;color:#818cf8}[data-theme=dark] .supervisor-hero--success{background:linear-gradient(135deg,#2ea0431f,#161b22 60%);border-color:#3fb95040}[data-theme=dark] .supervisor-hero--warning{background:linear-gradient(135deg,#bb80091f,#161b22 60%);border-color:#d2992240}[data-theme=dark] .supervisor-hero--danger{background:linear-gradient(135deg,#f851491f,#161b22 60%);border-color:#f8514940}[data-theme=dark] input[type=checkbox].toggle+label{background:#f0f6fc14}[data-theme=dark] code{background:#f0f6fc0f;border-color:#f0f6fc1a;color:#f97316}[data-theme=dark] hr{border-top-color:#f0f6fc14}[data-theme=dark] .kpi-card{background:linear-gradient(160deg,#1a2133,#161b22);border-color:#f0f6fc14}[data-theme=dark] .kpi-card:hover{border-color:#f0f6fc29;box-shadow:0 0 0 1px #4f46e533,0 8px 24px #00000073}[data-theme=dark] .kpi-card--active{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e540,var(--shadow-sm)}[data-theme=dark] .icon-btn{background:#1c2128;border-color:#f0f6fc1a;color:#8b949e}[data-theme=dark] .icon-btn:hover{background:#262d36;border-color:#f0f6fc2e}[data-theme=dark] .icon-btn--history:hover{background:#388bfd26;border-color:#58a6ff4d;color:#58a6ff}[data-theme=dark] .icon-btn--edit:hover{background:#4f46e52e;border-color:#4f46e559;color:#818cf8}[data-theme=dark] .export-btn{background:#1c2128;border-color:#f0f6fc1a;color:#8b949e}[data-theme=dark] .export-btn:hover:not(:disabled){background:#262d36;border-color:#f0f6fc2e}[data-theme=dark] .export-btn--excel:hover:not(:disabled){background:#2ea04326;border-color:#3fb9504d;color:#3fb950}[data-theme=dark] .historial-dot{border-color:#161b22;box-shadow:0 0 0 2px #4f46e54d}[data-theme=dark] .historial-motivo{background:#f0f6fc0a;border-left-color:#f0f6fc1f}[data-theme=dark] .detail-edit-section,[data-theme=dark] .detail-obs,[data-theme=dark] .modal-info-grid{background:#f0f6fc08;border-color:#f0f6fc14}[data-theme=dark] .filtros-section{background:#161b22;border-color:#f0f6fc14}[data-theme=dark] .filtros-grid{border-top-color:#f0f6fc14}[data-theme=dark] .filtros-clear-btn:hover,[data-theme=dark] .filtros-toggle-btn:hover{background:#f0f6fc0f;border-color:#f0f6fc2e;color:var(--color-text)}[data-theme=dark] .asist-stats-bar{background:#161b22;border-color:#f0f6fc14}[data-theme=dark] .asist-stat--primary{background:#4f46e526;border-color:#4f46e540;color:#818cf8}[data-theme=dark] .asist-stat--success{background:#2ea04326;border-color:#3fb95040;color:#3fb950}[data-theme=dark] .asist-stat--warning{background:#bb800926;border-color:#d2992240;color:#d29922}[data-theme=dark] .asist-stat--danger{background:#f8514926;border-color:#f8514940;color:#f85149}[data-theme=dark] .page-header{border-bottom-color:#f0f6fc14}[data-theme=dark] .db-hero{background:linear-gradient(135deg,#0d1117,#0f0e2a 30%,#1a1756,#2d2a8a);border:1px solid rgba(79,70,229,.2);box-shadow:0 0 0 1px #4f46e51a,0 8px 32px #00000080,inset 0 1px #ffffff0a}[data-theme=dark] .db-hero:before{background:radial-gradient(circle,rgba(79,70,229,.12) 0%,transparent 70%);width:480px;height:480px}[data-theme=dark] .db-hero-kpi{background:#ffffff0d;border-color:#ffffff14;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .db-hero-kpi:hover{background:#4f46e533;border-color:#818cf859}[data-theme=dark] .db-hero-kpi--accent{background:#4f46e540;border-color:#818cf866}[data-theme=dark] .db-hero-kpi--success{background:#0596692e;border-color:#34d3994d}[data-theme=dark] .db-panel{background:#161b22;border-color:#f0f6fc1a;box-shadow:0 1px 3px #0006,inset 0 1px #ffffff08}[data-theme=dark] .db-att-row{background:#f0f6fc0a}[data-theme=dark] .db-att-row--success{background:#05966914}[data-theme=dark] .db-att-row--warning{background:#d9770614}[data-theme=dark] .db-att-row--danger{background:#dc262614}[data-theme=dark] .db-asist-badge--success{background:#0596692e;color:#34d399}[data-theme=dark] .db-asist-badge--warning{background:#d977062e;color:#fcd34d}[data-theme=dark] .db-asist-badge--danger{background:#dc26262e;color:#f87171}[data-theme=dark] .db-entity-card{background:#161b22;border-color:#f0f6fc14;box-shadow:0 1px 3px #0006,inset 0 1px #ffffff08}[data-theme=dark] .db-entity-card:hover{border-color:#f0f6fc26;box-shadow:0 8px 24px #0006,0 0 0 1px #4f46e533,inset 0 1px #ffffff0d;transform:translateY(-3px)}[data-theme=dark] .db-entity-card--zonas:before{background:linear-gradient(90deg,#6366f1,#a5b4fc);opacity:.9}[data-theme=dark] .db-entity-card--proyectos:before{background:linear-gradient(90deg,#0ea5e9,#7dd3fc);opacity:.9}[data-theme=dark] .db-entity-card--equipo:before{background:linear-gradient(90deg,#10b981,#6ee7b7);opacity:.9}[data-theme=dark] .db-entity-card--zonas .db-entity-icon-box{background:#6366f126;color:#818cf8}[data-theme=dark] .db-entity-card--proyectos .db-entity-icon-box{background:#0ea5e926;color:#38bdf8}[data-theme=dark] .db-entity-card--equipo .db-entity-icon-box{background:#10b98126;color:#34d399}[data-theme=dark] .db-entity-tag{background:#f0f6fc0d;border-color:#f0f6fc1a;color:#8b949e}[data-theme=dark] .db-team-breakdown{border-top-color:#f0f6fc12;border-bottom-color:#f0f6fc12}[data-theme=dark] .db-entity-btn{background:#f0f6fc0a;border-color:#f0f6fc1a;color:#8b949e}[data-theme=dark] .db-entity-btn:hover{background:#6366f11f;border-color:#6366f166;color:#818cf8}[data-theme=dark] .db-donut-pct{color:#e6edf3}[data-theme=dark] .db-donut-pct--empty{color:#484f58}[data-theme=dark] .db-donut-sub{color:#8b949e}@keyframes db-dot-pulse-dark{0%,to{box-shadow:0 0 #34d39980;transform:scale(1)}50%{box-shadow:0 0 0 5px #34d39900;transform:scale(1.25)}}[data-theme=dark] .db-entity-preview{border-top-color:#f0f6fc14}[data-theme=dark] .db-entity-preview-item:hover{background:#f0f6fc0a}[data-theme=dark] .db-entity-preview-name{color:#e6edf3}[data-theme=dark] .db-entity-preview-badge{background:#f0f6fc0f;color:#6e7681;border-color:#f0f6fc1a}[data-theme=dark] .db-entity-preview-badge--active{background:#34d3991f;color:#34d399;border-color:#34d39933}[data-theme=dark] .db-entity-preview-dot--active{background:#34d399;animation:db-dot-pulse-dark 2.2s ease-in-out infinite}[data-theme=dark] .db-entity-preview-zone{color:#6e7681}[data-theme=dark] .db-entity-preview-more{color:#818cf8}[data-theme=dark] .db-team-asist-bar{border-top-color:#f0f6fc14}[data-theme=dark] .db-team-asist-label{color:#6e7681}[data-theme=dark] .db-team-asist-pct{color:#c9d1d9}[data-theme=dark] .db-team-asist-track{background:#f0f6fc14}[data-theme=dark] .db-analytics-header h2{color:#c9d1d9}[data-theme=dark] .db-analytics-panel{background:#161b22;border-color:#f0f6fc1a}[data-theme=dark] .db-analytics-panel-title{background:#0d111799;color:#8b949e;border-bottom-color:#f0f6fc14}[data-theme=dark] .db-analytics-panel-title i{color:#818cf8}
