body{padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:#000;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#1a1a1a;border:3px solid #ffd600;border-radius:25px;box-shadow:0 0 60px #ffd6004d;max-width:450px;padding:40px;width:100%}.login-header{margin-bottom:35px;text-align:center}.logo-container{display:flex;justify-content:center;margin-bottom:20px}.logo{animation:fadeInScale .5s ease-out;border:4px solid #ffd600;border-radius:50%;box-shadow:0 0 30px #ffd60099;height:100px;object-fit:cover;width:100px}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.app-title{color:#ffd600;font-size:36px;font-weight:700;margin:15px 0 5px;text-shadow:0 0 20px #ffd60080}.app-subtitle{color:#fff;font-size:16px;font-weight:500;margin:0;opacity:.8}.login-form{display:flex;flex-direction:column;gap:20px}.error-message{align-items:center;animation:shake .4s ease-out;background:#ffd6001a;border:2px solid #ffd600;border-radius:12px;color:#ffd600;display:flex;font-size:14px;gap:10px;padding:15px}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}.error-icon{flex-shrink:0;font-size:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#fff;font-size:14px;font-weight:600}.form-group input{background:#0a0a0a;border:2px solid #333;border-radius:12px;color:#fff;font-size:16px;padding:14px;transition:all .3s}.form-group input::placeholder{color:#666}.form-group input:focus{background:#000;border-color:#ffd600;box-shadow:0 0 0 3px #ffd60033;outline:none}.form-group input:disabled{background:#0a0a0a;cursor:not-allowed;opacity:.5}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{flex:1 1;padding-right:50px}.toggle-password{background:none;border:none;cursor:pointer;filter:grayscale(1) brightness(1.5);font-size:24px;padding:5px 10px;position:absolute;right:10px;transition:transform .2s}.toggle-password:hover{transform:scale(1.1)}.toggle-password:active{transform:scale(.95)}.toggle-password:disabled{cursor:not-allowed;opacity:.3}.login-button{align-items:center;background:#ffd600;border:none;border-radius:12px;box-shadow:0 0 20px #ffd60080;color:#000;cursor:pointer;display:flex;font-size:16px;font-weight:700;gap:10px;justify-content:center;margin-top:10px;padding:16px;transition:all .3s}.login-button:hover:not(:disabled){box-shadow:0 0 30px #ffd600cc;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.spinner{animation:spin .8s linear infinite;border:3px solid #0000004d;border-radius:50%;border-top-color:#000;height:16px;width:16px}.login-footer{margin-top:25px;text-align:center}.login-footer p{color:#999;font-size:13px;margin:0}@media (max-width:480px){.login-card{padding:30px 20px}.logo{height:80px;width:80px}.app-title{font-size:28px}.app-subtitle{font-size:14px}}.empleado-container{background:#000;min-height:100vh;padding-bottom:20px}.header{align-items:flex-start;background:#1a1a1a;border-bottom:4px solid #ffd600;border-radius:0 0 30px 30px;box-shadow:0 4px 20px #ffd6004d;color:#fff;display:flex;justify-content:space-between;margin-bottom:20px;padding:50px 20px 20px}.header h2{color:#ffd600;font-size:22px;margin:0;text-shadow:0 0 10px #ffd60080;word-break:break-word}.header p{color:#fff;font-size:15px;margin:8px 0 0;opacity:.9}.logout-btn{flex-shrink:0;min-width:80px;padding:10px 16px;white-space:nowrap}.tabs-empleado{display:flex;gap:10px;margin:0 15px 20px;padding:0}.tab-empleado{align-items:center;background:#1a1a1a;border:2px solid #333;border-radius:12px;color:#999;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:700;justify-content:center;min-height:50px;padding:15px 12px;text-align:center;transition:all .3s}.tab-empleado.active{background:#ffd600;border-color:#ffd600;box-shadow:0 0 20px #ffd60080;color:#000}.tab-empleado:active{transform:scale(.98)}.reloj-card{background:linear-gradient(135deg,#1a1a1a,#0a0a0a);border:2px solid #333;border-radius:20px;box-shadow:0 4px 20px #ffd60033;margin:0 15px 20px;padding:25px 20px;text-align:center}.fecha{color:#999;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-transform:capitalize}.hora{color:#ffd600;font-family:Courier New,monospace;font-size:48px;font-weight:700;letter-spacing:2px;margin:0;text-shadow:0 0 20px #ffd60099}.registro-card{background:#1a1a1a;border:2px solid #333;border-radius:20px;box-shadow:0 4px 20px #00000080;margin:0 15px;padding:30px 20px;text-align:center}.status-text{color:#999;font-size:16px;font-weight:600;margin:0 0 20px}.status-text-error{color:#ff9800;font-size:18px;font-weight:700;margin:0 0 15px}.registro-info{margin-bottom:20px}.hora-registro{color:#ffd600;font-family:Courier New,monospace;font-size:36px;font-weight:700;margin:10px 0 0;text-shadow:0 0 15px #ffd60099}.btn{align-items:center;border:none;border-radius:15px;box-shadow:0 4px 15px #0000004d;cursor:pointer;display:flex;font-size:18px;font-weight:700;justify-content:center;letter-spacing:1px;min-height:60px;padding:18px 20px;text-transform:uppercase;transition:all .3s;width:100%}.btn:active{transform:scale(.98)}.btn-entrada{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 4px 20px #4caf5066;color:#fff}.btn-entrada:active{background:linear-gradient(135deg,#45a049,#3d8b40);box-shadow:0 2px 10px #4caf5099}.btn-salida{background:linear-gradient(135deg,#f44336,#da190b);box-shadow:0 4px 20px #f4433666;color:#fff}.btn-salida:active{background:linear-gradient(135deg,#da190b,#c41606);box-shadow:0 2px 10px #f4433699}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.registro-antiguo{background:#ff98000d;border:2px solid #ff9800;border-radius:15px;padding:20px}.error-info{background:#0a0a0a;border-radius:12px;margin-top:15px;padding:15px;text-align:left}.error-info p{color:#fff;font-size:14px;line-height:1.6;margin:8px 0}.error-info strong{color:#ffd600}.error-message{background:#ff98001a;border-left:4px solid #ff9800;border-radius:8px;color:#ff9800!important;font-size:13px!important;line-height:1.5!important;margin-top:15px!important;padding:12px}@media (max-width:374px){.header{padding:45px 15px 15px}.header h2{font-size:18px}.header p{font-size:13px}.logout-btn{font-size:12px;min-width:70px;padding:8px 12px}.hora{font-size:40px}.hora-registro{font-size:30px}.btn{font-size:16px;min-height:55px;padding:16px 18px}.tab-empleado{font-size:12px;padding:12px 8px}}@media (min-width:375px) and (max-width:480px){.header h2{font-size:20px}.hora{font-size:44px}.hora-registro{font-size:32px}}@media (min-width:481px) and (max-width:768px){.empleado-container{margin:0 auto;max-width:600px}.header{border-radius:20px;margin:0 20px 20px}.header h2{font-size:24px}.registro-card,.reloj-card{margin:0 20px 20px}.hora{font-size:56px}.tabs-empleado{margin:0 20px 20px}}@media (min-width:769px){.empleado-container{margin:0 auto;max-width:700px;padding:20px}.header{border-radius:25px;margin-bottom:30px}.header h2{font-size:26px}.logout-btn{font-size:15px;padding:12px 24px}.registro-card,.reloj-card{margin:0 0 30px;padding:40px 30px}.hora{font-size:64px}.hora-registro{font-size:42px}.tabs-empleado{margin:0 0 30px}.tab-empleado{font-size:16px;padding:16px 20px}.btn{border-radius:18px;font-size:20px;padding:20px}.btn:hover{box-shadow:0 6px 25px #ffd60080;transform:translateY(-2px)}.btn:active{transform:translateY(0)}}@media (max-height:500px) and (orientation:landscape){.header{padding:20px 20px 15px}.reloj-card{margin-bottom:15px;padding:15px}.hora{font-size:36px}.registro-card{padding:20px}.btn{font-size:16px;min-height:50px;padding:14px 18px}}.btn:focus,.logout-btn:focus,.tab-empleado:focus{outline:3px solid #ffd600;outline-offset:2px}@media (prefers-contrast:high){.fecha,.status-text{color:#fff}.header p{opacity:1}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}@supports (padding:max(0px)){.header{padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));padding-top:max(50px,env(safe-area-inset-top))}.empleado-container{padding-bottom:max(20px,env(safe-area-inset-bottom))}}button,input,select,textarea{font-size:16px!important}html{-webkit-overflow-scrolling:touch}.btn,.logout-btn,.tab-empleado{-webkit-tap-highlight-color:rgba(255,214,0,.2);user-select:none;-webkit-user-select:none;-moz-user-select:none}.btn,.registro-card,.reloj-card,.tab-empleado{backface-visibility:hidden;-webkit-backface-visibility:hidden;will-change:transform}.modal-overlay{animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000e6;padding:20px;z-index:9999}.modal-container{animation:slideUp .3s ease-out;background:#1a1a1a;border:3px solid #ffd600;border-radius:20px;box-shadow:0 0 60px #ffd60080;max-width:450px;padding:35px 30px;text-align:center;width:100%}.modal-icon{animation:iconBounce .5s ease-out;filter:drop-shadow(0 0 10px rgba(255,214,0,.5));font-size:64px;margin-bottom:20px}@keyframes iconBounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.modal-title{color:#ffd600;font-size:24px;font-weight:700;margin:0 0 15px;text-shadow:0 0 10px #ffd6004d}.modal-message{color:#fff;font-size:16px;line-height:1.6;margin:0 0 25px;opacity:.9;white-space:pre-line}.modal-input{background:#0a0a0a;border:2px solid #333;border-radius:10px;box-sizing:border-box;color:#fff;font-size:16px;margin-bottom:20px;padding:14px;transition:border .3s;width:100%}.modal-input::placeholder{color:#666}.modal-input:focus{border-color:#ffd600;box-shadow:0 0 0 3px #ffd60033;outline:none}.modal-buttons{display:flex;gap:12px;justify-content:center}.modal-btn{border:2px solid;border-radius:12px;cursor:pointer;flex:1 1;font-size:16px;font-weight:700;min-width:120px;padding:14px 24px;transition:all .3s}.modal-btn:active{transform:scale(.97)}.modal-btn-primary{background:#ffd600;border-color:#ffd600;box-shadow:0 0 20px #ffd60066;color:#000}.modal-btn-primary:hover{box-shadow:0 0 30px #ffd600b3;transform:translateY(-2px)}.modal-btn-primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.modal-btn-danger{background:#000;border-color:#ffd600;box-shadow:0 0 20px #ffd60033;color:#ffd600}.modal-btn-danger:hover{background:#ffd600;box-shadow:0 0 30px #ffd600b3;color:#000;transform:translateY(-2px)}.modal-btn-secondary{background:#0a0a0a;border-color:#333;color:#999}.modal-btn-secondary:hover{background:#222;border-color:#ffd600;color:#ffd600}.toast{align-items:center;animation:slideInRight .3s ease-out;background:#1a1a1a;border:2px solid;border-radius:12px;box-shadow:0 0 30px #000c;cursor:pointer;display:flex;gap:12px;min-width:300px;padding:16px 24px;position:fixed;right:20px;top:20px;transition:transform .2s;z-index:99999}.toast:hover{transform:translateX(-5px)}.toast:active{transform:scale(.98)}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-success{background:#1a1a1a;border-color:#ffd600;box-shadow:0 0 30px #ffd60080}.toast-success .toast-icon{color:#ffd600;filter:drop-shadow(0 0 5px rgba(255,214,0,.5))}.toast-success .toast-message{color:#fff}.toast-error{background:#0a0a0a;border-color:#ffd600;box-shadow:0 0 30px #ffd6004d}.toast-error .toast-icon{color:#ffd600}.toast-error .toast-message{color:#fff}.toast-warning{background:#ffd6001a;border-color:#ffd600;box-shadow:0 0 30px #ffd60066}.toast-warning .toast-icon,.toast-warning .toast-message{color:#ffd600}.toast-icon{flex-shrink:0;font-size:24px}.toast-message{flex:1 1;font-size:15px;font-weight:500}.toast-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:28px;font-weight:700;height:30px;justify-content:center;line-height:1;margin-left:auto;padding:0;transition:all .2s;width:30px}.toast-close:hover{background:#ffd60033;color:#ffd600}.toast-close:active{transform:scale(.9)}.toast-exit{animation:slideOutRight .3s ease-out forwards}@keyframes slideOutRight{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(120%)}}@media (max-width:480px){.modal-container{margin:20px;padding:30px 20px}.modal-icon{font-size:56px}.modal-title{font-size:20px}.modal-message{font-size:14px}.modal-buttons{flex-direction:column}.modal-btn{width:100%}.toast{left:20px;min-width:auto;right:20px}}.mis-registros-container,.mis-registros-container *{box-sizing:border-box}.mis-registros-container{background:#000;min-height:100vh;padding:15px 15px 80px}.mes-selector-empleado{align-items:center;background:#1a1a1a;border:2px solid #333;border-radius:15px;display:flex;gap:10px;justify-content:space-between;margin-bottom:15px;padding:12px 15px}.btn-mes-nav{background:#ffd600;border:none;border-radius:10px;box-shadow:0 0 15px #ffd60066;color:#000;cursor:pointer;flex-shrink:0;font-size:18px;font-weight:700;height:45px;transition:all .3s;width:45px}.btn-mes-nav:active{box-shadow:0 0 25px #ffd600cc;transform:scale(.95)}.mes-titulo{color:#ffd600;flex:1 1;font-size:18px;margin:0;min-width:0;overflow:hidden;text-align:center;text-overflow:ellipsis;text-shadow:0 0 10px #ffd60080;white-space:nowrap}.stats-empleado{grid-gap:10px;box-sizing:border-box;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);margin-bottom:15px;width:100%}.stat-card{border:2px solid #333;box-sizing:border-box;gap:12px;min-height:80px;padding:15px;transition:all .3s}.stat-card:active{border-color:#ffd600;box-shadow:0 0 15px #ffd60033;transform:scale(.98)}.stat-card.stat-warning{border-color:#ff9800}.stat-icon{flex-shrink:0;font-size:28px}.stat-info{min-width:0}.stat-num{color:#ffd600;font-size:24px;font-weight:700;line-height:1;margin-bottom:2px;text-shadow:0 0 10px #ffd60066}.stat-text{color:#999;font-size:11px;font-weight:600;letter-spacing:.5px;line-height:1.2;text-transform:uppercase}.vista-toggle{background:#1a1a1a;border-radius:15px;gap:8px;margin-bottom:15px;padding:8px}.toggle-btn,.vista-toggle{border:2px solid #333;display:flex}.toggle-btn{align-items:center;background:#0000;border-radius:10px;color:#999;cursor:pointer;flex:1 1;font-size:13px;font-weight:700;justify-content:center;min-height:45px;padding:12px 10px;text-align:center;transition:all .3s}.toggle-btn.active{background:#ffd600;border-color:#ffd600;box-shadow:0 0 15px #ffd60080;color:#000}.toggle-btn:active{transform:scale(.98)}.registros-contenido{background:#1a1a1a;border:2px solid #333;border-radius:15px;min-height:300px;padding:15px}.loading-registros{color:#ffd600;font-size:16px;font-weight:600}.loading-registros,.sin-registros{padding:60px 20px;text-align:center}.sin-registros{color:#666}.sin-registros .empty-icon{font-size:60px;margin-bottom:10px;opacity:.5}.sin-registros p:last-child{font-size:15px;margin:0}.calendario-mini{max-width:100%;overflow-x:hidden;width:100%}.calendario-header{flex-direction:row;gap:2px;margin-bottom:5px;width:100%}.dia-header{background:#0a0a0a;border-radius:6px;box-sizing:border-box;color:#ffd600;flex-basis:calc(14.28571% - 1.71429px);flex-grow:0;flex-shrink:0;font-size:11px;font-weight:700;line-height:1.2;padding:6px 0;text-align:center;white-space:nowrap}.calendario-grid{display:flex;flex-wrap:wrap;gap:2px;width:100%}.dia-celda,.dia-vacio{aspect-ratio:1;box-sizing:border-box;flex-basis:calc(14.28571% - 1.71429px);flex-grow:0;flex-shrink:0}.dia-vacio{pointer-events:none;visibility:hidden}.dia-celda{border-radius:8px;overflow:hidden;padding:3px 2px;transition:all .2s}.dia-celda:active{transform:scale(1.08);z-index:10}.dia-numero{font-size:12px;line-height:1;margin-bottom:2px}.dia-horas{font-size:8px;line-height:1;white-space:nowrap}.dia-icono{font-size:9px;line-height:1;position:absolute;right:2px;top:2px}.dia-celda.completo{box-shadow:inset 0 0 10px #ffd6001a}.dia-celda.completo:active{border-color:#ffd600;box-shadow:0 0 15px #ffd60066}.dia-celda.incompleto{box-shadow:inset 0 0 10px #ff98001a}.dia-celda.ausente{background:#0a0a0a;border-color:#444;opacity:.5}.dia-celda.ausente .dia-numero{color:#666}.dia-celda.futuro{background:#0a0a0a;border-color:#222;cursor:default;opacity:.3}.dia-celda.futuro:active{transform:none}.semanas-lista{display:flex;flex-direction:column;gap:12px}.semana-card{background:#0a0a0a;border:2px solid #333;border-radius:15px;overflow:hidden;transition:all .3s}.semana-card:active{border-color:#ffd600;box-shadow:0 0 15px #ffd60033}.semana-header{align-items:center;background:#0a0a0a;cursor:pointer;display:flex;gap:10px;justify-content:space-between;padding:15px;transition:all .3s}.semana-header:active{background:#111}.semana-info{flex:1 1;min-width:0}.semana-info h4{color:#ffd600;font-size:15px;margin:0 0 5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.semana-info p{color:#999;font-size:12px;margin:0}.semana-toggle{color:#ffd600;flex-shrink:0;font-size:18px;font-weight:700;transition:transform .3s}.semana-contenido{animation:slideDown .3s ease-out;padding:0 15px 15px}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:2000px;opacity:1}}.timeline{padding-left:25px;position:relative}.timeline-item{margin-bottom:15px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-line{background:#333;height:15px;left:8px;position:absolute;top:-15px;width:2px}.timeline-dot{background:#0a0a0a;border:3px solid;border-radius:50%;height:18px;left:0;position:absolute;top:12px;width:18px;z-index:2}.timeline-dot.completo{border-color:#ffd600;box-shadow:0 0 10px #ffd60080}.timeline-dot.activo{animation:pulse 2s infinite;border-color:#4caf50;box-shadow:0 0 10px #4caf5080}.timeline-card{background:#111;border:1px solid #333;border-radius:12px;margin-left:12px;padding:12px}.timeline-fecha{align-items:center;border-bottom:1px solid #333;display:flex;gap:10px;justify-content:space-between;margin-bottom:10px;padding-bottom:8px}.fecha-dia{color:#fff;flex:1 1;font-size:13px;font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize}.estado-badge{flex-shrink:0;font-size:16px}.timeline-horarios{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.horario-entry,.horario-exit{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.horario-entry .icon,.horario-exit .icon{flex-shrink:0;font-size:10px}.horario-entry .label,.horario-exit .label{color:#999;flex-shrink:0;font-size:11px;min-width:55px}.horario-entry .time,.horario-exit .time{color:#ffd600;flex:1 1;font-size:15px;font-weight:700}.pendiente{color:#ff9800;font-size:12px;font-weight:600}.timeline-total{background:#ffd6000d;border-radius:8px;color:#ffd600;font-size:13px;padding:10px}.timeline-alerta,.timeline-total{font-weight:600;margin-top:8px;text-align:center}.timeline-alerta{background:#ff98001a;border:1px solid #ff9800;border-radius:6px;color:#ff9800;font-size:11px;padding:8px}@media (max-width:374px){.mis-registros-container{padding:10px}.registros-contenido{padding:8px}.mes-selector-empleado{padding:10px 12px}.btn-mes-nav,.mes-titulo{font-size:15px}.btn-mes-nav{height:38px;width:38px}.stats-empleado{gap:8px}.stat-card{gap:10px;min-height:75px;padding:12px}.stat-icon{font-size:24px}.stat-num{font-size:20px}.stat-text{font-size:10px}.toggle-btn{font-size:11px;padding:10px 6px}.calendario-header{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:1px}.dia-header{flex-basis:calc(14.28571% - 0.85714px);flex-grow:0;flex-shrink:0;font-size:10px;min-width:0;padding:5px 0}.calendario-grid{gap:1px}.dia-celda,.dia-vacio{flex-basis:calc(14.28571% - 0.85714px);flex-grow:0;flex-shrink:0}.dia-numero{font-size:11px}.dia-horas{font-size:7px}.dia-icono{font-size:8px}.semana-info h4{font-size:13px}.timeline-card{padding:10px}.horario-entry .time,.horario-exit .time{font-size:14px}}@media (min-width:375px) and (max-width:480px){.stats-empleado{gap:10px}.stat-card{padding:15px}.stat-num{font-size:24px}.calendario-header{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:2px}.dia-header{flex-basis:calc(14.28571% - 1.71429px);flex-grow:0;flex-shrink:0;font-size:11px;min-width:0;padding:6px 0}.calendario-grid{gap:2px}.dia-celda,.dia-vacio{flex-basis:calc(14.28571% - 1.71429px);flex-grow:0;flex-shrink:0}.dia-numero{font-size:12px}.dia-horas{font-size:8px}}@media (min-width:481px) and (max-width:768px){.mis-registros-container{margin:0 auto;max-width:600px;padding:20px}.mes-selector-empleado{padding:15px 20px}.stats-empleado{gap:15px;margin-bottom:20px;margin-left:auto;margin-right:auto;max-width:500px}.stat-card{min-height:90px;padding:18px 15px}.stat-icon{font-size:32px}.stat-num{font-size:28px}.stat-text{font-size:12px}.calendario-header{gap:4px}.dia-header{flex-basis:calc(14.28571% - 3.42857px);flex-grow:0;flex-shrink:0;font-size:12px;padding:8px 0}.calendario-grid{gap:4px}.dia-celda,.dia-vacio{flex-basis:calc(14.28571% - 3.42857px);flex-grow:0;flex-shrink:0}.dia-numero{font-size:14px}.dia-horas{font-size:9px}.dia-icono{font-size:11px}.timeline-horarios{flex-direction:row;justify-content:space-around}.horario-entry,.horario-exit{align-items:flex-start;flex-direction:column}}@media (min-width:769px){.mis-registros-container{margin:0 auto;max-width:900px;padding:30px}.mes-selector-empleado{margin-bottom:20px;padding:15px 20px}.mes-titulo{font-size:22px}.btn-mes-nav{height:50px;width:50px}.btn-mes-nav:hover{box-shadow:0 0 30px #ffd600cc;transform:translateY(-2px)}.stats-empleado{gap:20px;margin-bottom:25px;margin-left:auto;margin-right:auto;max-width:600px}.stat-card{min-height:110px;padding:25px 20px}.stat-card:hover{border-color:#ffd600;box-shadow:0 0 25px #ffd60066;transform:translateY(-5px)}.stat-icon{font-size:40px}.stat-num{font-size:32px}.stat-text{font-size:13px}.vista-toggle{margin-bottom:20px}.toggle-btn{font-size:15px}.toggle-btn:hover:not(.active){border-color:#ffd600;color:#ffd600}.registros-contenido{padding:20px}.calendario-header{gap:6px;margin-bottom:10px}.dia-header{flex-basis:calc(14.28571% - 5.14286px);flex-grow:0;flex-shrink:0;font-size:13px;padding:10px 0}.calendario-grid{gap:6px}.dia-celda,.dia-vacio{flex-basis:calc(14.28571% - 5.14286px);flex-grow:0;flex-shrink:0}.dia-numero{font-size:16px}.dia-horas{font-size:10px}.dia-icono{font-size:12px}.dia-celda:hover{box-shadow:0 0 15px #ffd6004d;transform:scale(1.05)}.semana-card:hover{border-color:#ffd600;box-shadow:0 0 20px #ffd60033}.semana-header:hover{background:#111}.timeline{padding-left:30px}.timeline-card{padding:15px}.timeline-horarios{flex-direction:row;justify-content:space-around}}@media (max-height:500px) and (orientation:landscape){.stats-empleado{gap:8px}.stat-card{min-height:60px;padding:10px}.stat-num{font-size:20px}.dia-celda{padding:2px}}.btn-mes-nav:focus,.dia-celda:focus,.semana-header:focus,.toggle-btn:focus{outline:3px solid #ffd600;outline-offset:2px}@supports (padding:max(0px)){.mis-registros-container{padding-bottom:max(80px,env(safe-area-inset-bottom));padding-left:max(15px,env(safe-area-inset-left));padding-right:max(15px,env(safe-area-inset-right))}}.btn-mes-nav,.dia-celda,.semana-header,.toggle-btn{-webkit-tap-highlight-color:rgba(255,214,0,.2);user-select:none;-webkit-user-select:none}.semanas-lista{-webkit-overflow-scrolling:touch}.dia-celda,.semana-card,.stat-card,.timeline-card{-webkit-backface-visibility:hidden;backface-visibility:hidden;will-change:transform}.admin-container{background:#000;min-height:100vh;padding-bottom:20px}.admin-header{align-items:flex-start;background:#1a1a1a;border-bottom:4px solid #ffd600;border-radius:0 0 30px 30px;box-shadow:0 4px 20px #ffd6004d;color:#fff;display:flex;justify-content:space-between;padding:50px 20px 20px;position:relative}.admin-header h1{color:#ffd600;font-size:28px;margin:0;text-shadow:0 0 10px #ffd60080}.admin-header p{color:#fff;font-size:16px;margin:5px 0 0;opacity:.9}.logout-btn{background:#0000;border:2px solid #ffd600;border-radius:20px;color:#ffd600;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:all .3s}.logout-btn:active{background:#ffd600;color:#000;transform:scale(.95)}.tabs-container{display:flex;gap:10px;margin:20px 20px 0;overflow-x:auto}.tab{background:#1a1a1a;border:2px solid #333;border-radius:10px;color:#999;cursor:pointer;flex:1 1;font-size:15px;font-weight:700;padding:15px 20px;transition:all .3s}.tab.active{background:#ffd600;border-color:#ffd600;box-shadow:0 0 20px #ffd60080;color:#000}.tab:hover:not(.active){background:#222;border-color:#ffd600;color:#ffd600}.filter-section{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 20px #ffd6001a;margin:20px;padding:20px}.filter-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.filter-type-btn{background:#0a0a0a;border:2px solid #333;border-radius:10px;color:#999;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;min-width:80px;padding:12px;transition:all .3s}.filter-type-btn.active{background:#ffd600;border-color:#ffd600;box-shadow:0 0 15px #ffd60080;color:#000}.filter-type-btn:hover:not(.active){border-color:#ffd600;color:#ffd600}.filter-type-btn:active{transform:scale(.95)}.date-selector{align-items:center;display:flex;gap:10px;justify-content:space-between}.date-btn{background:#ffd600;border:none;border-radius:10px;box-shadow:0 0 15px #ffd60066;color:#000;cursor:pointer;font-size:16px;font-weight:700;min-width:50px;padding:12px 20px;transition:all .3s}.date-btn:disabled{background:#333;box-shadow:none;color:#666;cursor:not-allowed;opacity:.5}.date-btn:hover:not(:disabled){box-shadow:0 0 25px #ffd600cc;transform:translateY(-2px)}.date-btn:active:not(:disabled){transform:translateY(0)}.date-display{background:#0a0a0a;border:1px solid #333;border-radius:8px;color:#fff;flex:1 1;font-size:15px;font-weight:600;padding:10px;text-align:center}.custom-date-range{align-items:center;display:flex;flex:1 1;gap:10px;justify-content:center}.date-input{background:#0a0a0a;border:2px solid #333;border-radius:8px;color:#fff;font-size:14px;font-weight:600;padding:10px}.date-input:focus{border-color:#ffd600;outline:none}.custom-date-range span{color:#ffd600;font-weight:700}.additional-filters{grid-gap:15px;background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 20px #ffd6001a;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:0 20px 20px;padding:20px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#ffd600;font-size:14px;font-weight:700}.filter-select,.search-input{background:#0a0a0a;border:2px solid #333;border-radius:10px;color:#fff;font-size:14px;padding:12px;transition:border .3s}.filter-select:focus,.search-input:focus{border-color:#ffd600;box-shadow:0 0 0 3px #ffd6001a;outline:none}.search-group{grid-column:1/-1}.stats-container{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:0 20px 20px}.stat-box{background:#1a1a1a;border:2px solid;border-radius:15px;box-shadow:0 0 20px #00000080;padding:25px;text-align:center;transition:transform .3s}.stat-box:hover{transform:translateY(-5px)}.stat-purple{background:linear-gradient(135deg,#1a1a1a,#0a0a0a);border-color:#ffd600}.stat-blue,.stat-green{background:#0a0a0a;border-color:#ffd600}.stat-orange{background:#ffd600;border-color:#ffd600}.stat-number{font-size:36px;font-weight:700;margin-bottom:8px}.stat-purple .stat-number{color:#ffd600;text-shadow:0 0 10px #ffd60080}.stat-purple .stat-label{color:#ffd600;opacity:.9}.stat-green .stat-number{color:#ffd600}.stat-green .stat-label{color:#999}.stat-blue .stat-number{color:#ffd600}.stat-blue .stat-label{color:#999}.stat-orange .stat-number{color:#000}.stat-orange .stat-label{color:#000;opacity:.8}.export-buttons{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:0 20px 20px}.export-btn{background:#0a0a0a;border:2px solid #ffd600;border-radius:12px;box-shadow:0 0 15px #00000080;color:#ffd600;cursor:pointer;font-size:14px;font-weight:700;padding:15px 20px;transition:all .3s}.export-btn:hover{background:#ffd600;box-shadow:0 0 25px #ffd600cc;color:#000;transform:translateY(-2px)}.export-btn:active{transform:translateY(0)}.table-container{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 30px #ffd6001a;margin:0 20px;overflow:hidden;padding:20px}.table-container h3{color:#ffd600;font-size:20px;margin:0 0 20px}.results-count{background:#ffd6001a;border-left:4px solid #ffd600;border-radius:4px;color:#ffd600;font-size:14px;font-weight:600;margin-bottom:15px;padding:10px 15px}.loading{color:#ffd600;font-size:18px;padding:60px 20px;text-align:center}.empty-state{color:#666;padding:80px 20px;text-align:center}.empty-icon{font-size:80px;margin-bottom:15px;opacity:.5}.registros-table{border-collapse:collapse;font-size:14px;width:100%}.registros-table thead{background:#0a0a0a;border-bottom:2px solid #ffd600}.registros-table th{color:#ffd600;font-size:13px;font-weight:700;letter-spacing:.5px;padding:15px 12px;text-align:left;text-transform:uppercase}.registros-table td{border-bottom:1px solid #333;color:#fff;padding:14px 12px}.registros-table tbody tr{transition:background .2s}.registros-table tbody tr:hover{background:#222}.registros-table tbody tr:nth-child(2n){background:#0f0f0f}.registros-table tbody tr:nth-child(2n):hover{background:#222}.badge{border:2px solid;border-radius:20px;display:inline-block;font-size:12px;font-weight:700;padding:6px 14px}.badge.activo{background:#0000;border-color:#ffd600;color:#ffd600}.badge.completado{background:#ffd600;border-color:#ffd600;color:#000}.badge-warning{background:#0000;border-color:#ffd600;color:#ffd600;display:inline-block;margin-top:5px}.acciones-td{white-space:nowrap}.btn-accion{background:#0000;border:2px solid #ffd600;border-radius:6px;color:#ffd600;cursor:pointer;font-size:12px;font-weight:700;margin:2px;padding:6px 12px;transition:all .3s}.btn-accion:hover{background:#ffd600;box-shadow:0 0 15px #ffd60080;color:#000;transform:scale(1.05)}.btn-accion:active{transform:scale(.95)}.row-warning{background:#ffd6000d!important;border-left:4px solid #ffd600}.row-warning:hover{background:#ffd6001a!important}.row-sospechoso{animation:pulse 2s infinite;background:#ffd60014!important;border-left:4px solid #ffd600}.row-sospechoso:hover{background:#ffd60026!important}.warning-icon{color:#ffd600;cursor:help;display:inline-block;font-size:16px;margin-left:8px}.distance-info{color:#999;margin-top:4px}.admin-badge,.distance-info{font-size:11px;font-weight:400}.admin-badge{color:#ffd600;margin-top:3px}.tiempo-transcurrido{color:#ffd600;font-size:13px;font-weight:700}.resumen-container{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 30px #ffd6001a;margin:0 20px;padding:30px}.resumen-container h3{color:#ffd600;font-size:22px;margin:0 0 25px}.resumen-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.resumen-card{background:#0a0a0a;border:2px solid #333;border-left:5px solid #ffd600;border-radius:12px;box-shadow:0 0 20px #00000080;padding:25px}.resumen-card h4{color:#999;font-size:14px;letter-spacing:1px;margin:0 0 10px;text-transform:uppercase}.resumen-card p{color:#ffd600;font-size:28px;font-weight:700;margin:0}@media (min-width:1024px){.admin-container{margin:0 auto;max-width:1600px}.stats-container{grid-template-columns:repeat(4,1fr)}.export-buttons{grid-template-columns:auto auto auto 1fr;justify-content:start}.export-btn{min-width:180px;width:auto}.registros-table{font-size:15px}.registros-table td,.registros-table th{padding:16px 15px}.additional-filters{grid-template-columns:repeat(3,1fr)}.search-group{grid-column:span 1}}@media (min-width:768px) and (max-width:1023px){.additional-filters,.stats-container{grid-template-columns:repeat(2,1fr)}}@media (max-width:767px){.admin-header h1{font-size:22px}.tabs-container{margin:15px 15px 0}.tab{font-size:13px;padding:12px 15px;white-space:nowrap}.additional-filters,.export-buttons,.filter-section,.resumen-container,.stats-container,.table-container{margin:0 15px 15px}.filter-type-btn{font-size:13px;padding:10px}.date-btn{font-size:14px;padding:10px 15px}.date-display{font-size:12px}.custom-date-range{flex-direction:column;gap:8px}.date-input{width:100%}.stats-container{gap:10px;grid-template-columns:repeat(2,1fr)}.stat-number{font-size:28px}.stat-label{font-size:11px}.export-buttons{gap:8px;grid-template-columns:1fr}.registros-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto;white-space:nowrap}.registros-table td,.registros-table th{font-size:13px;padding:12px 10px}.results-count{font-size:13px}.resumen-cards{grid-template-columns:1fr}.resumen-card p{font-size:24px}.filter-group label{font-size:13px}.filter-select,.search-input{font-size:13px;padding:10px}.acciones-td{display:flex;flex-direction:column;gap:4px}.btn-accion{width:100%}}.resumen-container,.table-container{animation:fadeIn .3s ease-out}.btn-accion:focus,.date-btn:focus,.export-btn:focus,.filter-select:focus,.filter-type-btn:focus,.search-input:focus,.tab:focus{outline:3px solid #ffd600;outline-offset:2px}.dashboard-container{background:#000;min-height:100vh;padding-bottom:40px}.dashboard-header{align-items:center;background:#1a1a1a;border-bottom:4px solid #ffd600;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;padding:50px 20px 20px}.dashboard-header h1{color:#ffd600;font-size:28px;margin:0;text-shadow:0 0 10px #ffd60080}.back-btn{background:#0000;border:2px solid #ffd600;border-radius:10px;color:#ffd600;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:all .3s}.back-btn:hover{background:#ffd600;color:#000;transform:translateY(-2px)}.back-btn:active{transform:translateY(0)}.periodo-selector{display:flex;gap:10px}.periodo-selector button{background:#0a0a0a;border:2px solid #333;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:all .3s}.periodo-selector button.active{background:#ffd600;border-color:#ffd600;box-shadow:0 0 15px #ffd60080;color:#000}.periodo-selector button:hover:not(.active){background:#1a1a1a;border-color:#ffd600;color:#ffd600}.dashboard-loading{align-items:center;background:#000;color:#ffd600;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.spinner-large{animation:spin 1s linear infinite;border:6px solid #333;border-radius:50%;border-top-color:#ffd600;height:60px;margin-bottom:20px;width:60px}@keyframes spin{to{transform:rotate(1turn)}}.dashboard-loading p{color:#fff;font-size:18px}.stats-destacadas{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:30px 20px}.stat-card{align-items:center;background:#1a1a1a;border:3px solid #ffd600;border-radius:15px;box-shadow:0 0 20px #ffd60033;display:flex;gap:20px;padding:25px;transition:transform .3s,box-shadow .3s}.stat-card:hover{box-shadow:0 0 30px #ffd60099;transform:translateY(-5px)}.stat-icon{filter:drop-shadow(0 0 10px rgba(255,214,0,.5));font-size:48px}.stat-info{flex:1 1}.stat-label{color:#fff;letter-spacing:1px;opacity:.9}.graficos-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));padding:0 20px}.grafico-card{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 20px #00000080;padding:25px;transition:border-color .3s,box-shadow .3s}.grafico-card:hover{border-color:#ffd600;box-shadow:0 0 30px #ffd6004d}.grafico-card h3{color:#ffd600;font-size:18px;font-weight:700;margin:0 0 20px;text-align:center}.custom-tooltip{background:#1a1a1a;border:2px solid #ffd600;border-radius:10px;box-shadow:0 0 20px #ffd60099;padding:12px 15px}.custom-tooltip .label{color:#ffd600;font-size:14px;font-weight:700;margin:0 0 8px}.custom-tooltip p{color:#fff;font-size:13px;font-weight:600;margin:4px 0}.recharts-cartesian-axis-tick-value,.recharts-label,.recharts-text{fill:#fff!important}.recharts-legend-item-text{color:#fff!important}.recharts-pie-label-text{fill:#000!important;font-size:14px!important;font-weight:700!important;text-shadow:0 0 3px #fff}@media (max-width:1200px){.graficos-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}}@media (max-width:1024px){.graficos-grid{grid-template-columns:1fr}}@media (max-width:768px){.dashboard-header{align-items:stretch;flex-direction:column}.dashboard-header h1{font-size:24px;text-align:center}.back-btn{order:-1}.periodo-selector{justify-content:center}.stats-destacadas{gap:15px;grid-template-columns:repeat(2,1fr);padding:20px 15px}.stat-card{flex-direction:column;padding:20px;text-align:center}.stat-icon{font-size:40px}.stat-value{font-size:28px}.stat-label{font-size:12px}.graficos-grid{gap:20px;grid-template-columns:1fr;padding:0 15px}.grafico-card{padding:20px 15px}.grafico-card h3{font-size:16px}}@media (max-width:480px){.stats-destacadas{grid-template-columns:1fr}.periodo-selector button{font-size:12px;padding:8px 15px}}.grafico-card{animation:fadeIn .5s ease-out}.stat-card{animation:fadeIn .3s ease-out}.back-btn:focus,.periodo-selector button:focus{outline:3px solid #ffd600;outline-offset:2px}.calendario-container{margin:0 auto;max-width:1400px;padding:20px}.calendario-header{align-items:center;background:#1a1a1a;border:2px solid #333;border-radius:15px;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.calendario-header h2{color:#ffd600;font-size:24px;margin:0;text-shadow:0 0 10px #ffd60080}.btn-refresh{background:#ffd600;border:none;border-radius:10px;box-shadow:0 0 15px #ffd60066;color:#000;cursor:pointer;font-size:16px;font-weight:700;padding:10px 20px;transition:all .3s}.btn-refresh:hover{box-shadow:0 0 25px #ffd600cc;transform:translateY(-2px)}.btn-refresh:active{transform:translateY(0)}.calendario-filtros{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 20px #ffd6001a;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:20px}.filtro-group{display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:200px}.filtro-group label{color:#ffd600;font-size:14px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.filtro-group select{background:#0a0a0a;border:2px solid #333;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px;transition:all .3s}.filtro-group select:focus{border-color:#ffd600;box-shadow:0 0 0 3px #ffd6001a;outline:none}.filtro-group select:hover{border-color:#ffd600}.mes-selector{align-items:center;flex-direction:row;gap:15px;justify-content:center}.btn-mes{background:#ffd600;border:none;border-radius:10px;box-shadow:0 0 15px #ffd60066;color:#000;cursor:pointer;font-size:18px;font-weight:700;height:45px;transition:all .3s;width:45px}.btn-mes:hover{box-shadow:0 0 25px #ffd600cc;transform:translateY(-2px)}.btn-mes:active{transform:translateY(0)}.mes-nombre{color:#ffd600;font-size:18px;font-weight:700;min-width:200px;text-align:center;text-shadow:0 0 10px #ffd6004d}.calendario-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:20px}.stat-item{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 20px #00000080;padding:20px;text-align:center;transition:all .3s}.stat-item:hover{border-color:#ffd600;box-shadow:0 0 25px #ffd6004d;transform:translateY(-5px)}.stat-value{color:#ffd600;display:block;font-size:32px;font-weight:700;margin-bottom:5px;text-shadow:0 0 10px #ffd60066}.stat-label{color:#999;display:block;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.calendario-grid-container{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 20px #ffd6001a;padding:20px}.calendario-dias-semana{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.dia-semana-header{background:#0a0a0a;border:1px solid #333;border-radius:8px;color:#ffd600;font-size:14px;font-weight:700;letter-spacing:1px;padding:12px;text-align:center;text-transform:uppercase}.calendario-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr)}.dia-celda,.dia-vacio{aspect-ratio:1}.dia-celda{align-items:center;background:#0a0a0a;border:2px solid #333;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:5px;justify-content:center;padding:10px;position:relative;transition:all .3s}.dia-celda:hover{border-color:#ffd600;box-shadow:0 0 20px #ffd60066;transform:scale(1.05);z-index:10}.dia-numero{color:#fff;font-size:16px;font-weight:700}.dia-icono{font-size:24px}.dia-horas{color:#ffd600;font-size:12px;font-weight:700;text-shadow:0 0 5px #ffd60080}.dia-celda.completo{background:linear-gradient(135deg,#0a0a0a,#1a1a0a);border-color:#ffd600;box-shadow:inset 0 0 20px #ffd6001a}.dia-celda.completo:hover{background:linear-gradient(135deg,#1a1a0a,#2a2a0a);box-shadow:0 0 25px #ffd60099}.dia-celda.completo .dia-numero{color:#ffd600}.dia-celda.completo .dia-horas{color:#ffd600;text-shadow:0 0 10px #ffd600b3}.dia-celda.incompleto{background:linear-gradient(135deg,#0a0a0a,#1a0f0a);border-color:#ff9800;box-shadow:inset 0 0 20px #ff98001a}.dia-celda.incompleto:hover{background:linear-gradient(135deg,#1a0f0a,#2a1a0a);box-shadow:0 0 25px #ff980080}.dia-celda.incompleto .dia-numero{color:#ff9800}.dia-celda.incompleto .dia-icono{filter:drop-shadow(0 0 5px rgba(255,152,0,.6))}.dia-celda.ausente{background:linear-gradient(135deg,#0a0a0a,#1a0a0a);border-color:#f44336;box-shadow:inset 0 0 20px #f443361a}.dia-celda.ausente:hover{background:linear-gradient(135deg,#1a0a0a,#2a0a0a);box-shadow:0 0 25px #f4433666}.dia-celda.ausente .dia-numero{color:#f44336}.dia-celda.ausente .dia-icono{filter:drop-shadow(0 0 5px rgba(244,67,54,.6))}.dia-celda.libre{background:#0a0a0a;border-color:#444;cursor:default;opacity:.6}.dia-celda.libre:hover{border-color:#444;box-shadow:none;transform:none}.dia-celda.libre .dia-numero{color:#666}.dia-celda.libre .dia-icono{opacity:.5}.calendario-leyenda{background:#1a1a1a;border:2px solid #333;border-radius:15px;box-shadow:0 0 20px #ffd6001a;display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-bottom:20px;padding:15px}.leyenda-item{color:#fff;font-size:14px;font-weight:600;gap:8px}.leyenda-color,.leyenda-item{align-items:center;display:flex}.leyenda-color{background:#0a0a0a;border:2px solid;border-radius:8px;font-size:16px;height:35px;justify-content:center;width:35px}.leyenda-item:first-child .leyenda-color{background:linear-gradient(135deg,#0a0a0a,#1a1a0a);border-color:#ffd600}.leyenda-item:nth-child(2) .leyenda-color{background:linear-gradient(135deg,#0a0a0a,#1a0f0a);border-color:#ff9800}.leyenda-item:nth-child(3) .leyenda-color{background:linear-gradient(135deg,#0a0a0a,#1a0a0a);border-color:#f44336}.leyenda-item:nth-child(4) .leyenda-color{background:linear-gradient(135deg,#0a0a0a,#1a0f0a);border-color:#ff9800}.leyenda-item:nth-child(5) .leyenda-color{background:#0a0a0a;border-color:#444}.modal-overlay{align-items:center;animation:fadeIn .2s;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-detalles{animation:slideUp .3s;background:#1a1a1a;border:2px solid #ffd600;border-radius:20px;box-shadow:0 0 50px #ffd60066;max-height:80vh;max-width:500px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;background:#0a0a0a;border-bottom:2px solid #333;border-radius:18px 18px 0 0;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#ffd600;font-size:20px;margin:0;text-shadow:0 0 10px #ffd60080}.modal-close{background:#0000;border:2px solid #ffd600;border-radius:10px;color:#ffd600;cursor:pointer;font-size:20px;font-weight:700;height:35px;transition:all .2s;width:35px}.modal-close:hover{background:#ffd600;color:#000;transform:scale(1.1)}.modal-close:active{transform:scale(.95)}.modal-body{padding:20px}.detalle-estado{align-items:center;background:#0a0a0a;border:2px solid #333;border-radius:12px;display:flex;gap:15px;margin-bottom:20px;padding:15px}.detalle-icono{font-size:40px}.detalle-mensaje{color:#ffd600;font-size:18px;font-weight:700}.detalle-registro{display:flex;flex-direction:column;gap:12px}.detalle-row{align-items:center;background:#0a0a0a;border:1px solid #333;border-radius:8px;display:flex;justify-content:space-between;padding:12px}.detalle-label{color:#999;font-size:14px;font-weight:700}.detalle-value{color:#fff;font-size:14px;font-weight:600}.detalle-value.destacado{color:#ffd600;font-size:20px;font-weight:700;text-shadow:0 0 10px #ffd60080}.detalle-ausente,.detalle-libre{background:#0a0a0a;border:2px dashed #333;border-radius:12px;color:#999;font-size:16px;padding:30px;text-align:center}.calendario-loading{color:#ffd600;font-size:18px;font-weight:600;padding:60px 20px;text-align:center}.modal-detalles::-webkit-scrollbar{width:8px}.modal-detalles::-webkit-scrollbar-track{background:#0a0a0a}.modal-detalles::-webkit-scrollbar-thumb{background:#ffd600;border-radius:4px}.modal-detalles::-webkit-scrollbar-thumb:hover{background:#ffed4e}@media (min-width:1024px){.calendario-stats{grid-template-columns:repeat(5,1fr)}.dia-celda{padding:15px}.dia-numero{font-size:18px}.dia-icono{font-size:28px}.dia-horas{font-size:14px}}@media (min-width:768px) and (max-width:1023px){.calendario-stats{grid-template-columns:repeat(3,1fr)}.calendario-filtros{grid-template-columns:repeat(2,1fr)}}@media (max-width:767px){.calendario-container{padding:15px}.calendario-header{flex-direction:column;gap:15px;text-align:center}.calendario-header h2{font-size:20px}.btn-refresh{width:100%}.calendario-filtros{flex-direction:column;padding:15px}.filtro-group{min-width:100%}.mes-selector{flex-direction:row}.mes-nombre{font-size:16px;min-width:auto}.btn-mes{font-size:16px;height:40px;width:40px}.calendario-stats{gap:10px;grid-template-columns:repeat(2,1fr)}.stat-value{font-size:24px}.stat-label{font-size:11px}.calendario-leyenda{gap:10px;padding:12px}.leyenda-item{font-size:12px}.leyenda-color{font-size:14px;height:25px;width:25px}.calendario-grid-container{padding:10px}.dia-semana-header{font-size:11px;padding:8px 4px}.calendario-grid{gap:4px}.dia-celda{padding:5px}.dia-numero{font-size:12px}.dia-icono{font-size:18px}.dia-horas{font-size:10px}.modal-detalles{max-height:90vh;width:95%}.modal-header h3{font-size:18px}.detalle-estado{flex-direction:column;text-align:center}.detalle-icono{font-size:50px}.detalle-row{flex-direction:column;gap:5px;text-align:center}}.btn-mes:focus,.btn-refresh:focus,.filtro-group select:focus,.modal-close:focus{outline:3px solid #ffd600;outline-offset:2px}.dia-celda:focus{outline:3px solid #ffd600;outline-offset:3px;z-index:10}.calendario-grid-container{animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stat-item{animation:scaleIn .3s ease-out backwards}.stat-item:first-child{animation-delay:.05s}.stat-item:nth-child(2){animation-delay:.1s}.stat-item:nth-child(3){animation-delay:.15s}.stat-item:nth-child(4){animation-delay:.2s}.stat-item:nth-child(5){animation-delay:.25s}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#000;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.loading-screen{align-items:center;background:#000;color:#ffd600;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-screen h2{font-size:32px;margin:0 0 10px;text-shadow:0 0 20px #ffd60099}.loading-screen p{animation:pulse 1.5s infinite;color:#fff;font-size:18px;margin:0}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}::-webkit-scrollbar{height:10px;width:10px}::-webkit-scrollbar-track{background:#0a0a0a}::-webkit-scrollbar-thumb{background:#333;border-radius:5px;-webkit-transition:background .3s;transition:background .3s}::-webkit-scrollbar-thumb:hover{background:#ffd600}*{scrollbar-color:#333 #0a0a0a;scrollbar-width:thin}::selection{background:#ffd600;color:#000}::-moz-selection{background:#ffd600;color:#000}html{scroll-behavior:smooth}button{user-select:none;-webkit-user-select:none;-moz-user-select:none}:focus-visible{outline:3px solid #ffd600;outline-offset:2px}*{transition-duration:.2s;transition-property:background-color,border-color,color;transition-timing-function:ease-in-out}:not(button):not(a):not(input):not(select):not(textarea){transition-property:none}
/*# sourceMappingURL=main.54c8b7a8.css.map*/