@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";:root{--primary-50: #f0fdf4;--primary-100: #dcfce7;--primary-200: #bbf7d0;--primary-300: #86efac;--primary-400: #4ade80;--primary-500: #22c55e;--primary-600: #16a34a;--primary-700: #15803d;--primary-800: #166534;--primary-900: #14532d;--secondary-100: #fef9c3;--secondary-200: #fef08a;--secondary-300: #fde047;--secondary-400: #facc15;--secondary-500: #eab308;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--success: #10b981;--success-light: #d1fae5;--warning: #f59e0b;--warning-light: #fef3c7;--error: #ef4444;--error-light: #fee2e2;--info: #3b82f6;--info-light: #dbeafe;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--shadow-glow: 0 0 40px rgba(74, 222, 128, .3);--shadow-glow-red: 0 0 40px rgba(239, 68, 68, .3);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--radius-sm: .375rem;--radius: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 9999px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,var(--primary-50) 0%,var(--gray-100) 50%,var(--primary-100) 100%);color:var(--gray-800);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--primary-400),var(--primary-600));border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--primary-500),var(--primary-700))}#root{min-height:100vh}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:var(--shadow-md),0 0 #22c55e66}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-500) 100%);transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 20px #22c55e4d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:#fff;color:var(--gray-700);border:2px solid var(--gray-200)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--primary-300);color:var(--primary-700)}.btn-danger{background:linear-gradient(135deg,var(--error) 0%,#dc2626 100%);color:#fff;box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#f87171 0%,var(--error) 100%);transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 20px #ef44444d}.btn-lg{padding:1rem 2rem;font-size:1.125rem;border-radius:var(--radius-xl)}.btn-icon{padding:.625rem;border-radius:var(--radius)}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.875rem;font-weight:600;color:var(--gray-700)}.input{padding:.875rem 1rem;font-size:1rem;font-family:inherit;border:2px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;color:var(--gray-800);transition:all var(--transition-base);outline:none}.input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #4ade8033}.input::placeholder{color:var(--gray-400)}.input-error{border-color:var(--error)}.input-error:focus{box-shadow:0 0 0 3px #ef444433}.card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:1.5rem;transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-xl)}.card-glass{background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5)}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.025em}.badge-success{background:var(--success-light);color:var(--primary-700)}.badge-warning{background:var(--warning-light);color:#92400e}.badge-error{background:var(--error-light);color:#991b1b}.badge-info{background:var(--info-light);color:#1e40af}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #4ade8066}50%{transform:scale(1.02);box-shadow:0 0 0 20px #4ade8000}}@keyframes pulseRed{0%,to{transform:scale(1);box-shadow:0 0 #ef444466}50%{transform:scale(1.02);box-shadow:0 0 0 20px #ef444400}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fadeIn{animation:fadeIn .5s ease-out}.animate-slideUp{animation:slideUp .6s ease-out}.animate-pulse{animation:pulse 2s infinite}.animate-pulse-red{animation:pulseRed 2s infinite}.animate-float{animation:float 3s ease-in-out infinite}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}.text-left{text-align:left}.text-right{text-align:right}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--primary-600)}.text-gray{color:var(--gray-500)}.text-error{color:var(--error)}.text-success{color:var(--success)}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}@media(max-width:768px){html{font-size:14px}.card{padding:1rem;border-radius:var(--radius-lg)}}.login-container{min-height:100vh;display:flex;position:relative;overflow:hidden;font-family:Inter,system-ui,-apple-system,sans-serif;background:#0a0f1a}.login-background{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#0a1628,#0d2137 40%,#0a3026);z-index:1}.bg-circle{position:absolute;border-radius:50%;filter:blur(100px);opacity:.5;pointer-events:none}.bg-circle-1{width:500px;height:500px;background:radial-gradient(circle,#10b981 0%,transparent 70%);top:-15%;right:-10%;animation:orbit1 15s ease-in-out infinite}.bg-circle-2{width:400px;height:400px;background:radial-gradient(circle,#3b82f6 0%,transparent 70%);bottom:-10%;left:-5%;animation:orbit2 18s ease-in-out infinite}.bg-circle-3{width:300px;height:300px;background:radial-gradient(circle,#8b5cf6 0%,transparent 70%);top:40%;left:30%;animation:orbit3 12s ease-in-out infinite}@keyframes orbit1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-40px,60px) scale(1.1)}66%{transform:translate(30px,-30px) scale(.95)}}@keyframes orbit2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,-40px) scale(1.05)}66%{transform:translate(-30px,50px) scale(.9)}}@keyframes orbit3{0%,to{transform:translate(0) scale(1);opacity:.4}50%{transform:translate(-20px,30px) scale(1.15);opacity:.6}}.login-background:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;z-index:1}.login-brand-content{position:relative;z-index:2;text-align:center;padding:3rem}.login-brand-content .brand-logo{height:160px;width:auto;object-fit:contain;filter:drop-shadow(0 20px 40px rgba(16,185,129,.3));margin-bottom:2rem;animation:logoFloat 6s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.login-brand-content h2{font-size:2.5rem;font-weight:900;color:#fff;letter-spacing:-.04em;margin-bottom:.75rem;line-height:1.1}.login-brand-content h2 span{background:linear-gradient(135deg,#34d399,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-brand-content p{font-size:1.1rem;color:#ffffff80;max-width:360px;margin:0 auto;line-height:1.6}.login-features{display:flex;gap:.75rem;margin-top:2.5rem;flex-wrap:wrap;justify-content:center}.feature-pill{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.1rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:100px;color:#ffffffb3;font-size:.8rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.feature-pill svg{color:#34d399;width:14px;height:14px}.login-card{position:relative;z-index:10;width:100%;max-width:480px;min-width:420px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3.5rem;background:#0f1729;border-left:1px solid rgba(255,255,255,.06);animation:slideInRight .6s cubic-bezier(.16,1,.3,1)}.login-background:after{content:"";position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,transparent,#0f1729);z-index:3;pointer-events:none;display:none}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.login-logo-container{display:none;justify-content:center;margin-bottom:1.5rem}.login-logo{height:100px;width:auto;object-fit:contain;filter:drop-shadow(0 8px 25px rgba(16,185,129,.3))}.login-header{text-align:center;margin-bottom:2.5rem;width:100%}.login-header h1{font-size:2rem;font-weight:800;color:#f1f5f9;margin-bottom:.5rem;letter-spacing:-.03em;background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;background-clip:unset}.login-header p{color:#64748b;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.5rem;width:100%}.login-form .input-group{position:relative}.login-form .input-group label{display:block;font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}.login-form .input-group .input{width:100%;height:52px;padding:0 1.25rem;border-radius:14px;border:1.5px solid rgba(255,255,255,.08);background:#ffffff0a;font-size:.95rem;color:#f1f5f9;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit}.login-form .input-group .input::placeholder{color:#475569}.login-form .input-group .input:focus{outline:none;border-color:#10b981;background:#10b9810d;box-shadow:0 0 0 4px #10b9811a}.password-input-wrapper{position:relative}.password-input-wrapper .input{width:100%;padding-right:3.5rem}.password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#475569;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:8px}.password-toggle:hover{color:#10b981;background:#10b9811a}.login-error{display:flex;align-items:center;gap:.6rem;padding:.875rem 1.25rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#fca5a5;border-radius:12px;font-size:.85rem;font-weight:500;animation:shakeX .5s ease}@keyframes shakeX{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.login-btn{margin-top:.5rem;height:52px;border-radius:14px;background:linear-gradient(135deg,#10b981,#059669)!important;border:none!important;color:#fff!important;font-size:.95rem!important;font-weight:700!important;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #10b9814d;position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.15));opacity:0;transition:opacity .3s ease}.login-btn:hover:before{opacity:1}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #10b98166}.login-btn:active{transform:translateY(0)}.login-footer{margin-top:2.5rem;text-align:center;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.06);width:100%}.login-footer p{margin-bottom:.25rem;color:#475569;font-size:.8rem}.login-footer p:first-child{font-weight:600;color:#64748b}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.4}50%{transform:translate(-50%,-50%) scale(1.1);opacity:.6}}.animate-slideUp{animation:slideInRight .6s cubic-bezier(.16,1,.3,1)}.animate-float{animation:logoFloat 6s ease-in-out infinite}.animate-fadeIn{animation:fadeIn .3s ease}@media(max-width:900px){.login-container{flex-direction:column}.login-background{min-height:45vh;padding:3rem 2rem 4rem;display:flex;align-items:center;justify-content:center}.login-background:after{display:block}.login-brand-content .brand-logo{height:120px;margin-bottom:1.5rem}.login-brand-content h2{font-size:2rem}.login-brand-content p{font-size:1rem}.login-features{display:none}.login-card{max-width:100%;min-width:0;border-left:none;border-top:none;padding:1.5rem 2rem 2.5rem;flex:1}}@media(max-width:480px){.login-background{min-height:40vh;padding:2.5rem 1.5rem 3.5rem}.login-brand-content .brand-logo{height:100px}.login-brand-content h2{font-size:1.6rem}.login-card{padding:1rem 1.25rem 2rem}.login-form{gap:1rem}.login-form .input-group .input{height:46px;font-size:.9rem}.login-btn{height:46px}.login-footer{margin-top:1.5rem}}.validacion-biometrica-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;animation:fadeIn .3s ease}.validacion-biometrica-modal{background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:24px;width:100%;max-width:400px;box-shadow:0 25px 80px #10b9814d;border:1px solid rgba(16,185,129,.2);overflow:hidden;animation:slideUp .4s ease}.validacion-biometrica-header{padding:1.5rem;text-align:center;background:linear-gradient(135deg,#10b98126,#0596691a);border-bottom:1px solid rgba(16,185,129,.2)}.validacion-biometrica-icon{width:50px;height:50px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:#fff;box-shadow:0 8px 25px #10b98166}.validacion-biometrica-title h2{font-size:1.3rem;font-weight:700;color:#fff;margin:0 0 .5rem}.validacion-biometrica-title p{font-size:.9rem;color:#ffffffb3;margin:0}.validacion-biometrica-title strong{color:#10b981}.validacion-biometrica-content{padding:2rem;min-height:200px;display:flex;align-items:center;justify-content:center}.validacion-biometrica-status{text-align:center;color:#fff}.validacion-biometrica-status h3{font-size:1.2rem;margin:1rem 0 .5rem;font-weight:600}.validacion-biometrica-status p{color:#ffffffb3;margin:0;font-size:.9rem}.biometric-icon-container{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#10b98133,#0596691a);border:2px solid rgba(16,185,129,.4);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:#10b981;transition:all .3s ease}.biometric-icon-container.pulse{animation:biometricPulse 1.5s ease-in-out infinite}@keyframes biometricPulse{0%,to{transform:scale(1);box-shadow:0 0 #10b98166}50%{transform:scale(1.05);box-shadow:0 0 0 20px #10b98100}}.validacion-biometrica-status.checking .spin{animation:spin 1s linear infinite;color:#10b981}.validacion-biometrica-status.success,.validacion-biometrica-status.success h3{color:#10b981}.validacion-biometrica-status.error,.validacion-biometrica-status.error p{color:#f87171}.validacion-biometrica-controls{padding:0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.btn-biometric{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;border:none;border-radius:12px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #10b98166}.btn-biometric:hover{transform:translateY(-2px);box-shadow:0 12px 35px #10b98180}.btn-biometric:active{transform:translateY(0)}.btn-biometric svg{width:24px;height:24px}.btn-cancel{padding:.75rem 1.5rem;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:transparent;color:#ffffffb3;font-size:.9rem;cursor:pointer;transition:all .3s ease}.btn-cancel:hover{background:#ffffff1a;color:#fff}.validacion-biometrica-footer{padding:1rem 1.5rem;text-align:center;border-top:1px solid rgba(255,255,255,.1)}.validacion-biometrica-footer p{margin:0;font-size:.8rem;color:#ffffff80}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.validacion-biometrica-overlay{padding:0}.validacion-biometrica-modal{border-radius:0;max-width:100%;height:100%;display:flex;flex-direction:column}.validacion-biometrica-content{flex:1}}.boton-marcacion-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.bloqueo-card,.tardanza-card{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:var(--radius-lg);width:100%;max-width:280px}.bloqueo-card{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}.tardanza-card{background:var(--warning-light);color:#92400e;border:1px solid #fcd34d}.bloqueo-card h4,.tardanza-card h4{font-size:.875rem;font-weight:600;margin-bottom:.125rem}.bloqueo-card p,.tardanza-card p{font-size:.75rem;opacity:.8}.boton-marcacion{position:relative;width:200px;height:200px;border-radius:50%;border:none;cursor:pointer;transition:all var(--transition-slow);display:flex;align-items:center;justify-content:center;overflow:hidden}.boton-marcacion.entrada{background:linear-gradient(145deg,var(--primary-400) 0%,var(--primary-600) 50%,var(--primary-700) 100%);box-shadow:0 10px 40px #22c55e66,inset 0 2px 20px #ffffff4d;animation:pulse 2.5s infinite}.boton-marcacion.salida{background:linear-gradient(145deg,#f87171 0%,var(--error) 50%,#dc2626 100%);box-shadow:0 10px 40px #ef444466,inset 0 2px 20px #ffffff4d;animation:pulseRed 2.5s infinite}.boton-marcacion.bloqueado{background:linear-gradient(145deg,var(--gray-300) 0%,var(--gray-400) 100%);box-shadow:0 4px 20px #0000001a;animation:none;cursor:not-allowed}.boton-marcacion:hover:not(:disabled):not(.bloqueado){transform:scale(1.05)}.boton-marcacion:disabled{animation:none}.boton-glow{position:absolute;inset:-4px;border-radius:50%;opacity:.5}.boton-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#fff;text-align:center}.boton-texto{font-size:.875rem;font-weight:700;letter-spacing:.05em}.boton-hint{display:flex;align-items:center;gap:.25rem;font-size:.7rem;opacity:.85}.marcacion-mensaje{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:var(--radius-lg);font-weight:500;width:100%;max-width:280px}.marcacion-mensaje.success{background:var(--success-light);color:var(--primary-800);border:1px solid var(--primary-200)}.marcacion-mensaje.error{background:var(--error-light);color:#991b1b;border:1px solid #fecaca}.mensaje-content{display:flex;flex-direction:column;gap:.25rem}.descuento-info{font-size:.75rem;font-weight:600;color:var(--error)}.boton-marcacion-compact-wrapper{display:flex;flex-direction:column;gap:.75rem;width:100%}.bloqueo-mensaje,.tardanza-mensaje{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius);font-size:.8125rem;font-weight:500}.bloqueo-mensaje{background:var(--gray-100);color:var(--gray-600)}.tardanza-mensaje{background:var(--warning-light);color:#92400e}.boton-marcacion-compact{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem 1.5rem;border:none;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all var(--transition-base)}.boton-marcacion-compact.entrada{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 15px #3b82f64d}.boton-marcacion-compact.entrada:hover:not(:disabled){background:linear-gradient(135deg,#60a5fa,#3b82f6);transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.boton-marcacion-compact.salida{background:linear-gradient(135deg,#f87171,#ef4444);box-shadow:0 4px 15px #ef44444d}.boton-marcacion-compact.salida:hover:not(:disabled){background:linear-gradient(135deg,#fca5a5,#f87171);transform:translateY(-2px);box-shadow:0 6px 20px #ef444466}.boton-marcacion-compact.bloqueado{background:var(--gray-300);box-shadow:none;cursor:not-allowed}.boton-marcacion-compact:disabled{opacity:.7}.marcacion-mensaje-compact{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500}.marcacion-mensaje-compact.success{background:var(--success-light);color:var(--primary-800)}.marcacion-mensaje-compact.error{background:var(--error-light);color:#991b1b}.descuento-badge{margin-left:auto;background:var(--error);color:#fff;padding:.125rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.boton-marcacion-loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--gray-400)}@media(max-width:480px){.boton-marcacion{width:160px;height:160px}.boton-content svg:first-child{width:36px;height:36px}}.historial-container{max-height:400px;overflow-y:auto}.historial-lista{list-style:none;display:flex;flex-direction:column;gap:.75rem}.historial-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-100);transition:all var(--transition-base)}.historial-item:hover{background:#fff;box-shadow:var(--shadow-md);transform:translate(4px)}.historial-item.entrada{border-left:3px solid var(--primary-500)}.historial-item.salida{border-left:3px solid var(--error)}.item-icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.item-icon.entrada{background:linear-gradient(135deg,var(--primary-100),var(--primary-200));color:var(--primary-700)}.item-icon.salida{background:linear-gradient(135deg,var(--error-light),#fecaca);color:#991b1b}.item-info{flex:1;min-width:0}.item-main{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.item-tipo{font-weight:700;font-size:.875rem;color:var(--gray-800);text-transform:uppercase;letter-spacing:.025em}.item-usuario{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--gray-500);background:var(--gray-100);padding:.125rem .5rem;border-radius:var(--radius-full)}.item-ubicacion{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--gray-500);font-family:monospace}.item-tiempo{text-align:right;flex-shrink:0}.item-hora{display:block;font-size:1.125rem;font-weight:700;color:var(--gray-800);font-variant-numeric:tabular-nums}.item-fecha{display:block;font-size:.75rem;color:var(--gray-500);text-transform:uppercase}.historial-empty,.historial-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--gray-400);gap:.75rem}.historial-empty h3{font-size:1.125rem;color:var(--gray-600);margin:0}.historial-empty p{font-size:.875rem;margin:0}.historial-loading span{font-size:.875rem;font-weight:500}@media(max-width:480px){.historial-item{padding:.875rem;gap:.75rem}.item-icon{width:36px;height:36px}.item-icon svg{width:16px;height:16px}.item-hora{font-size:1rem}.item-tipo{font-size:.75rem}}.mapa-container{position:relative;width:100%;height:400px;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-100)}.mapa-iframe{width:100%;height:100%;border:none}.mapa-overlay{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.6),transparent)}.btn-marcar-mapa{width:100%;padding:1rem;font-size:1rem}.mapa-loading,.mapa-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;height:300px;background:var(--gray-50);border-radius:var(--radius-lg);color:var(--gray-500)}.mapa-error button{margin-top:.5rem}.vista-historial{position:fixed;inset:0;background:#f8fafc;z-index:1000;display:flex;flex-direction:column;font-family:Inter,-apple-system,sans-serif}.historial-header-nav{display:flex;align-items:center;padding:1rem 1.25rem;background:#fff;border-bottom:1px solid #f1f5f9;box-shadow:0 2px 8px #00000008}.historial-header-nav h1{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0;margin-left:.75rem}.back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border:none;border-radius:12px;color:#10b981;cursor:pointer;transition:all .2s}.back-btn:hover{background:#ecfdf5;color:#059669}.historial-content{flex:1;overflow-y:auto;padding:1.25rem}.period-selector-container{margin-bottom:1.5rem}.period-selector-container label{display:block;font-size:.75rem;font-weight:700;color:#64748b;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.period-field{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:1rem;font-weight:600;color:#0f172a;box-shadow:0 2px 8px #0000000a;transition:all .2s}.period-field:hover{border-color:#10b981;box-shadow:0 4px 12px #10b9811a}.calendar-icon{color:#10b981}.historial-table-wrapper{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 20px #0000000a;border:1px solid #f1f5f9}.historial-table-custom{width:100%;border-collapse:collapse}.historial-table-custom th{text-align:left;padding:1rem .875rem;font-size:.6875rem;font-weight:700;color:#94a3b8;background:#f8fafc;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #f1f5f9}.historial-table-custom td{padding:.875rem;border-bottom:1px solid #f8fafc;font-size:.875rem;vertical-align:middle;color:#475569}.historial-table-custom tbody tr:last-child td{border-bottom:none}.historial-table-custom tbody tr:hover{background:#fafafa}.text-center{text-align:center}.day-num{font-weight:600;color:#0f172a;width:55px}.day-name{color:#64748b;width:90px}.time-val{color:#0f172a;font-weight:500;font-family:JetBrains Mono,SF Mono,monospace}.green-text{color:#10b981!important;font-weight:600}.highlight{background:#ecfdf5!important}.highlight .day-num,.highlight .day-name{color:#059669;font-weight:600}.highlight .time-val{color:#059669}.tardia{color:#ef4444!important;font-weight:600}.picker-overlay{position:fixed;inset:0;background:#0f172a80;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-end;z-index:1100}.picker-sheet{background:#fff;width:100%;border-radius:24px 24px 0 0;padding:1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0px));box-shadow:0 -20px 60px #00000026}.picker-controls{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #f1f5f9}.picker-control-group{display:flex;align-items:center;background:#f1f5f9;padding:.25rem;border-radius:12px}.picker-control-group button{width:36px;height:36px;background:transparent;border:none;color:#64748b;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:10px;transition:all .15s}.picker-control-group button:hover{background:#fff;color:#10b981}.picker-control-group button:active{transform:scale(.95)}.picker-val{font-size:.9375rem;font-weight:700;color:#0f172a;min-width:55px;text-align:center;padding:0 .25rem}.picker-today{height:36px;padding:0 1rem;background:#ecfdf5;border:none;color:#059669;font-weight:700;font-size:.8125rem;border-radius:10px;cursor:pointer;transition:all .15s}.picker-today:hover{background:#d1fae5}.picker-actions{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:.5rem}.btn-cancel-premium{height:56px;background:linear-gradient(145deg,#fff5f5,#ffe4e4);color:#e57373;border:none;border-radius:28px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:6px 6px 16px #e5737326,-4px -4px 12px #ffffffe6,inset 0 1px #fffc;position:relative;overflow:hidden}.btn-cancel-premium:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.4),transparent);border-radius:28px 28px 0 0}.btn-cancel-premium:hover{transform:translateY(-2px);box-shadow:8px 8px 20px #e5737333,-4px -4px 12px #fffffff2,inset 0 1px #ffffffe6}.btn-cancel-premium:active{transform:translateY(1px);box-shadow:2px 2px 8px #e573731a,-2px -2px 6px #fffc,inset 0 1px #fff9}.btn-confirm-premium{height:56px;background:linear-gradient(145deg,#2dd4bf,#14b8a6);color:#fff;border:none;border-radius:28px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 8px 24px #14b8a666,0 0 40px #2dd4bf33,inset 0 1px #ffffff4d,inset 0 -2px #0000001a;position:relative;overflow:hidden}.btn-confirm-premium:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25),transparent);border-radius:28px 28px 0 0}.btn-confirm-premium:hover{transform:translateY(-3px);box-shadow:0 12px 32px #14b8a680,0 0 60px #2dd4bf59,inset 0 1px #fff6,inset 0 -2px #0000001a}.btn-confirm-premium:active{transform:translateY(1px);box-shadow:0 4px 12px #14b8a64d,0 0 20px #2dd4bf26,inset 0 1px #fff3,inset 0 -1px #0000000d}.btn-confirm-premium svg{transition:transform .3s ease}.btn-confirm-premium:hover svg{transform:translate(4px)}.animate-slideUp{animation:slideUp .35s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(100%);opacity:.8}to{transform:translateY(0);opacity:1}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.mapa-premium-container{position:fixed;inset:0;background:#f8fafc;z-index:9999;display:flex;flex-direction:column;font-family:Inter,system-ui,-apple-system,sans-serif}.mapa-premium-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border-bottom:1px solid #f1f5f9;box-shadow:0 4px 12px #00000008;z-index:10}.mapa-close-btn{width:40px;height:40px;border-radius:12px;background:#fee2e2;border:none;color:#ef4444;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.mapa-close-btn:hover{background:#fecaca;transform:scale(1.05)}.mapa-header-info{flex:1}.mapa-header-info h1{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0}.mapa-header-info p{font-size:.8125rem;color:#10b981;margin:0;font-weight:600}.mapa-refresh-btn{width:40px;height:40px;border-radius:12px;background:#f1f5f9;border:none;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.mapa-refresh-btn:hover{background:#e2e8f0;color:#0f172a}.mapa-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.mapa-premium-content,.mapa-wrapper{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.mapa-premium-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;background:linear-gradient(180deg,#f0fdf4,#f8fafc)}.loading-pulse{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:1.5rem;animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #10b98166;transform:scale(1)}50%{box-shadow:0 0 0 20px #10b98100;transform:scale(1.05)}}.mapa-premium-loading h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.mapa-premium-loading p{font-size:.875rem;color:#64748b;margin:0}.mapa-premium-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;background:linear-gradient(180deg,#fef2f2,#f8fafc)}.mapa-premium-error svg{color:#ef4444;margin-bottom:1.5rem}.mapa-premium-error h3{font-size:1.25rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.mapa-premium-error p{font-size:.875rem;color:#64748b;margin:0 0 1.5rem;max-width:280px}.btn-retry{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:#ef4444;color:#fff;border:none;border-radius:12px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s}.btn-retry:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 8px 20px #ef44444d}.mapa-premium-map{flex:1;position:relative}.mapa-premium-map .leaflet-container{height:100%;width:100%;background:#e2e8f0}.custom-marker-icon{background:transparent!important;border:none!important}.mapa-premium-card{flex-shrink:0;background:#fff;border-radius:24px 24px 0 0;box-shadow:0 -10px 40px #0000001f;padding:1.25rem 1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0px));z-index:100}.mapa-card-status{margin-bottom:1rem}.status-indicator{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:12px;font-weight:600;font-size:.875rem}.status-indicator.in-range{background:#ecfdf5;color:#059669}.status-indicator.out-range{background:#fef2f2;color:#dc2626}.mapa-card-info{display:flex;gap:1rem;margin-bottom:1.25rem}.info-item{flex:1;display:flex;align-items:flex-start;gap:.75rem;padding:.875rem;background:#f8fafc;border-radius:14px}.info-item svg{color:#64748b;flex-shrink:0;margin-top:2px}.info-item label{display:block;font-size:.6875rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.info-item strong{display:block;font-size:.9375rem;font-weight:700;color:#0f172a}.btn-marcar-premium{width:100%;height:56px;display:flex;align-items:center;justify-content:center;gap:.75rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:16px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #10b9814d}.btn-marcar-premium:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #10b98166}.btn-marcar-premium:active:not(:disabled){transform:translateY(0)}.btn-marcar-premium.disabled{background:#94a3b8;cursor:not-allowed;box-shadow:none}.btn-marcar-premium.disabled:hover{transform:none}.success-overlay{position:fixed;inset:0;background:#059669f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.success-modal{text-align:center;padding:2rem;animation:scaleIn .5s cubic-bezier(.175,.885,.32,1.275)}.success-checkmark{width:120px;height:120px;margin:0 auto 1.5rem}.success-svg{width:100%;height:100%}.success-circle{stroke:#fff;stroke-width:3;stroke-dasharray:166;stroke-dashoffset:166;animation:stroke .8s cubic-bezier(.65,0,.45,1) forwards}.success-check{stroke:#fff;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:stroke .5s cubic-bezier(.65,0,.45,1) .8s forwards}.success-modal h2{color:#fff;font-size:1.875rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 20px rgba(0,0,0,.2)}.success-modal p{color:#fffffff2;font-size:1.125rem;margin:0 0 1.5rem;font-weight:500}.success-time{display:inline-block;background:#fff3;color:#fff;padding:.75rem 2rem;border-radius:50px;font-size:1.5rem;font-weight:700;font-family:JetBrains Mono,SF Mono,monospace;letter-spacing:.05em;box-shadow:0 4px 20px #0000001a}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes stroke{to{stroke-dashoffset:0}}.leaflet-control-attribution{display:none!important}.error-info-overlay{position:fixed;inset:0;background:#0f172acc;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1.5rem;animation:fadeIn .3s ease-out}.error-info-modal{background:#fff;border-radius:24px;padding:2rem;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275)}.error-info-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#ef4444}.error-info-modal h2{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 1rem}.error-info-modal p{font-size:1rem;color:#64748b;margin:0 0 1.5rem;line-height:1.6}.error-info-details{background:#f8fafc;border-radius:12px;padding:1rem;margin-bottom:1.5rem}.info-badge{display:flex;align-items:center;gap:.75rem;color:#475569;font-size:.9375rem;font-weight:600}.info-badge svg{color:#10b981;flex-shrink:0}.btn-error-ok{width:100%;height:52px;background:#10b981;color:#fff;border:none;border-radius:14px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #10b9814d}.btn-error-ok:hover{background:#059669;transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.btn-error-ok:active{transform:translateY(0)}.premium-error-modal{background:#fff;border-radius:32px;padding:2.5rem 2rem;max-width:380px;width:90%;text-align:center;box-shadow:0 25px 50px -12px #00000040;position:relative;overflow:hidden}.premium-error-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#f59e0b,#fbbf24)}.error-icon-wrapper{width:80px;height:80px;background:#fef3c7;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:#d97706!important}.pulse-animation{animation:soft-pulse 2s infinite}@keyframes soft-pulse{0%{transform:scale(1);box-shadow:0 0 #f59e0b66}70%{transform:scale(1.05);box-shadow:0 0 0 15px #f59e0b00}to{transform:scale(1);box-shadow:0 0 #f59e0b00}}.premium-error-title{font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:800;color:#1e293b;margin-bottom:.75rem;letter-spacing:-.02em}.premium-error-msg{font-size:1.0625rem;color:#64748b;line-height:1.6;margin-bottom:2rem}.premium-error-actions{display:flex;justify-content:center}.premium-btn{background:linear-gradient(135deg,#f59e0b,#d97706)!important;box-shadow:0 8px 20px #f59e0b4d!important;border-radius:18px!important;height:56px!important;font-size:1.0625rem!important;width:100%!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important}.premium-btn:hover{transform:translateY(-2px)!important;box-shadow:0 12px 25px #f59e0b66!important}.premium-btn:active{transform:scale(.98)!important}.animate-slideUp{animation:slideUpModal .4s cubic-bezier(.16,1,.3,1)}@keyframes slideUpModal{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.perfil-overlay{position:fixed;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .2s ease-out}.perfil-modal{background:#fff;border-radius:20px;width:100%;max-width:400px;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;animation:scaleUp .3s cubic-bezier(.16,1,.3,1)}.perfil-header{padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between}.perfil-header h2{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0}.perfil-close{width:32px;height:32px;border-radius:8px;border:none;background:#f1f5f9;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.perfil-close:hover{background:#e2e8f0;color:#0f172a}.perfil-avatar-section{padding:1.25rem;display:flex;align-items:center;gap:1rem;background:#f8fafc}.avatar-wrapper{position:relative;width:64px;height:64px;cursor:pointer}.avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid white;box-shadow:0 4px 12px #0000001a}.avatar-placeholder{width:100%;height:100%;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;color:#94a3b8}.avatar-edit-badge{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;background:#10b981;border:2px solid white;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 6px #10b98166}.user-basics h3{margin:0;font-size:1rem;color:#0f172a}.user-role{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;color:#059669;background:#ecfdf5;padding:2px 8px;border-radius:20px;margin-top:4px}.perfil-form{padding:1.25rem}.form-grid{display:grid;gap:1rem}.form-group label{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:#64748b;margin-bottom:6px}.form-group input{width:100%;padding:.625rem .875rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;color:#0f172a;transition:all .2s}.form-group input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.input-readonly{background-color:#f1f5f9;color:#64748b;cursor:not-allowed;border-color:#e2e8f0}.input-readonly:focus{box-shadow:none;border-color:#e2e8f0}.perfil-error{background:#fef2f2;color:#ef4444;padding:.75rem;border-radius:10px;font-size:.8125rem;margin-bottom:1rem;border:1px solid #fee2e2}.perfil-actions{margin-top:1.5rem}.btn-save{width:100%;height:48px;background:#10b981;color:#fff;border:none;border-radius:12px;font-weight:700;font-size:.9375rem;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #10b98140}.btn-save:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 6px 16px #10b98159}.btn-save:active:not(:disabled){transform:translateY(0)}.btn-save:disabled{opacity:.7;cursor:not-allowed}.btn-save.success{background:#059669}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:480px){.perfil-overlay{padding:1rem .25rem .25rem;align-items:flex-start}.perfil-modal{max-height:calc(100vh - 2rem);overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:16px}.perfil-header{padding:.5rem .75rem;position:sticky;top:0;background:#fff;z-index:10}.perfil-header h2{font-size:1rem}.perfil-avatar-section{padding:.5rem .75rem;gap:.5rem}.avatar-wrapper{width:40px;height:40px}.avatar-edit-badge{width:18px;height:18px;bottom:-2px;right:-2px}.avatar-edit-badge svg{width:10px;height:10px}.user-basics h3{font-size:.875rem}.user-role{font-size:.65rem;padding:1px 6px}.perfil-form{padding:.5rem .75rem}.form-grid{gap:.4rem}.form-group label{margin-bottom:1px;font-size:.65rem}.form-group input{padding:.4rem .6rem;font-size:.8rem;border-radius:8px}.perfil-actions{margin-top:.5rem;padding-bottom:.25rem}.btn-save{height:38px;font-size:.85rem;border-radius:10px}.perfil-error{padding:.5rem;font-size:.75rem;margin-bottom:.5rem}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes modalScaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modern-modal-overlay{position:fixed;inset:0;background:#0f172aa6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:overlayFadeIn .3s ease-out forwards}.modern-modal-container{background:#fff;width:90%;max-width:440px;border-radius:24px;padding:2rem;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;align-items:center;text-align:center;animation:modalScaleIn .3s cubic-bezier(.34,1.56,.64,1) forwards}.modern-modal-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.modern-modal-icon.warning{background:#fff7ed;color:#f97316}.modern-modal-icon.error{background:#fef2f2;color:#ef4444}.modern-modal-icon.success{background:#f0fdf4;color:#22c55e}.modern-modal-title{font-size:1.5rem;font-weight:800;color:#1e293b;margin:0 0 .75rem}.modern-modal-body{font-size:1rem;color:#64748b;line-height:1.6;margin-bottom:2rem}.modern-modal-actions{display:flex;gap:12px;width:100%}.modern-modal-btn{flex:1;padding:.85rem;border-radius:12px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s;border:none}.modern-modal-btn.cancel{background:#f1f5f9;color:#64748b}.modern-modal-btn.cancel:hover{background:#e2e8f0}.modern-modal-btn.confirm{background:#1e293b;color:#fff}.modern-modal-btn.confirm:hover{background:#0f172a;transform:translateY(-2px);box-shadow:0 4px 12px #0f172a33}.modern-modal-btn.confirm.danger{background:#ef4444}.modern-modal-btn.confirm.danger:hover{background:#dc2626;box-shadow:0 4px 12px #ef444433}.app-container{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;margin:0;background:#fff;position:fixed;inset:0;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#fff;border-bottom:1px solid var(--gray-100);flex-shrink:0;z-index:100}.header-user{display:flex;align-items:center;gap:.75rem}.user-avatar-header{width:40px;height:40px;min-width:40px;min-height:40px;max-width:40px;max-height:40px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;aspect-ratio:1 / 1}.avatar-img-header{width:100%;height:100%;object-fit:cover;border-radius:50%}.user-name-header{font-weight:600;font-size:1rem;color:var(--gray-800)}.header-actions{display:flex;gap:.5rem}.header-btn{width:40px;height:40px;border-radius:var(--radius);border:none;background:transparent;color:var(--gray-500);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.header-btn:hover{background:var(--gray-100);color:var(--gray-700)}.app-main{flex:1;padding:0 0 70px;overflow:hidden;position:relative;min-height:0;touch-action:pan-y pinch-zoom}.tabs-slider{display:flex;width:300%;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1)}.tab-content{width:33.333%;flex-shrink:0;padding:.75rem;height:100%;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;-webkit-overflow-scrolling:touch}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);padding:1rem}.jornada-card{padding:0;overflow:hidden}.jornada-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200);color:var(--gray-600);font-weight:500}.jornada-content{padding:1.25rem 1rem}.jornada-empty{text-align:center;color:var(--gray-500);font-size:.9375rem}.jornada-marcaciones{display:flex;flex-direction:column;gap:.75rem}.jornada-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:var(--radius);background:var(--gray-50)}.jornada-item.entrada{border-left:3px solid var(--primary-500)}.jornada-item.salida{border-left:3px solid var(--error)}.jornada-tipo{font-weight:600;font-size:.875rem;color:var(--gray-700);text-transform:uppercase;min-width:70px}.jornada-hora{font-weight:700;font-size:1rem;color:var(--gray-800)}.jornada-tardia{margin-left:auto;font-size:.75rem;font-weight:600;color:var(--error);background:var(--error-light);padding:.125rem .5rem;border-radius:var(--radius-full)}.historial-link{display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all var(--transition-base);border:none;width:100%;text-align:left}.historial-link:hover{background:var(--gray-50)}.historial-link-content{display:flex;align-items:center;gap:.75rem;color:var(--gray-700);font-weight:500}.historial-link svg:last-child{color:var(--gray-400)}.ubicacion-card{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #6ee7b7;color:#047857;font-weight:500}.ubicacion-card svg:last-child{margin-left:auto;color:#10b981}.historial-tabla-card{padding:0;overflow:hidden}.historial-tabla{width:100%;border-collapse:collapse}.historial-tabla th{padding:1rem;text-align:left;font-weight:500;font-size:.875rem;color:var(--gray-500);border-bottom:1px solid var(--gray-200)}.historial-tabla th:not(:first-child){text-align:center}.historial-tabla td{padding:1rem;font-size:.9375rem;border-bottom:1px solid var(--gray-100)}.historial-tabla td:not(:first-child){text-align:center;color:var(--gray-600)}.historial-tabla tr.hoy .fecha-col{color:#16a34a;font-weight:600}.historial-tabla td.tardia{color:var(--error);font-weight:600}.fecha-col{font-weight:500;color:var(--gray-700)}.btn-full{width:100%;padding:1rem;font-size:1rem}.boton-ir-mapa{width:100%;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:var(--radius-xl);padding:1rem;display:flex;align-items:center;justify-content:center;gap:.75rem;font-weight:700;font-size:1rem;cursor:pointer;box-shadow:0 4px 15px #2563eb4d;transition:transform .2s ease,box-shadow .2s ease}.boton-ir-mapa:active{transform:scale(.98)}.marcacion-wrapper{display:flex;justify-content:center;margin-top:1rem}.menu-list{display:flex;flex-direction:column;gap:.5rem}.menu-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);color:var(--gray-700);font-weight:500;width:100%;text-align:left}.menu-item:hover{background:var(--gray-50)}.menu-item svg:last-child{margin-left:auto;color:var(--gray-400)}.menu-item.danger{color:var(--error);border-color:var(--error-light)}.menu-item.danger:hover{background:var(--error-light)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;justify-content:space-around;background:#fff;border-top:1px solid var(--gray-200);padding:.5rem 0;z-index:100;box-shadow:0 -4px 20px #0000000d}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem 1.5rem;border:none;background:transparent;color:var(--gray-400);cursor:pointer;transition:all var(--transition-base);border-radius:var(--radius)}.nav-tab span{font-size:.75rem;font-weight:500}.nav-tab.active{color:#16a34a}.nav-tab:hover:not(.active){color:var(--gray-600)}@media(min-width:768px){.app-container{max-width:480px;margin:2rem auto;border-radius:var(--radius-2xl);min-height:calc(100vh - 4rem);max-height:calc(100vh - 4rem);overflow:hidden;box-shadow:0 0 40px #0000001a}.bottom-nav{position:absolute;bottom:0;border-radius:0 0 var(--radius-2xl) var(--radius-2xl)}}.notification-center{position:relative;z-index:1000}.notif-bell{position:relative;background:#f1f5f9;border:none;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#64748b;cursor:pointer;transition:all .2s}.notif-bell:hover{background:#e2e8f0;color:#0f172a}.notif-bell.has-unread{animation:bell-swing 2s infinite ease-in-out}.notif-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;padding:0 4px;border-radius:9px;border:2px solid white;display:flex;align-items:center;justify-content:center}.notif-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:320px;background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;border:1px solid #f1f5f9;overflow:hidden;animation:slideDown .3s cubic-bezier(.16,1,.3,1)}.notif-header{padding:1rem;background:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.notif-header h3{margin:0;font-size:14px;font-weight:700;color:#0f172a}.header-actions{display:flex;gap:.75rem}.header-actions button{background:none;border:none;font-size:12px;color:#3b82f6;cursor:pointer;font-weight:600}.notif-list{max-height:400px;overflow-y:auto}.notif-item{padding:.875rem 1rem;display:flex;gap:.75rem;border-bottom:1px solid #f8fafc;cursor:pointer;transition:all .2s;position:relative}.notif-item:hover{background:#f8fafc}.notif-item.unread{background:#f0f9ff}.notif-item.unread:hover{background:#e0f2fe}.notif-icon-wrapper{flex-shrink:0}.notif-icon{width:32px;height:32px;padding:7px;border-radius:10px}.notif-icon.marking{background:#dcfce7;color:#15803d}.notif-icon.security{background:#fef2f2;color:#dc2626}.notif-icon.personal{background:#eff6ff;color:#1d4ed8}.notif-icon.default{background:#f1f5f9;color:#64748b}.notif-content{flex:1;min-width:0}.notif-msg{margin:0;font-size:13px;color:#334155;line-height:1.4;word-break:break-word}.notif-time{font-size:11px;color:#94a3b8;margin-top:4px;display:block}.unread-dot{width:6px;height:6px;border-radius:50%;background:#3b82f6;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.notif-empty{padding:2rem;text-align:center;color:#94a3b8;font-size:13px}@keyframes bell-swing{0%,to{transform:rotate(0)}10%,30%{transform:rotate(15deg)}20%,40%{transform:rotate(-15deg)}50%{transform:rotate(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notif-icon.daily-report{background:linear-gradient(135deg,#dbeafe,#e0e7ff);color:#3b82f6}.daily-report-item{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem!important;border-left:3px solid #3b82f6}.daily-report-item.unread{background:linear-gradient(135deg,#f0f9ff,#eff6ff)}.daily-report-header{display:flex;justify-content:space-between;align-items:center}.report-summary{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.report-badge{padding:2px 8px;border-radius:8px;font-size:.72rem;font-weight:700}.report-badge.green{background:#d1fae5;color:#065f46}.report-badge.yellow{background:#fef3c7;color:#92400e}.report-badge.red{background:#fee2e2;color:#991b1b}.report-detail{margin-top:.5rem;border-top:1px solid #e2e8f0;padding-top:.5rem;animation:expandReport .3s ease}.report-section{margin-bottom:.5rem}.section-title{display:flex;align-items:center;gap:4px;font-size:.75rem;font-weight:700;margin-bottom:4px}.report-row{display:flex;align-items:center;gap:.5rem;font-size:.72rem;padding:2px 0;border-bottom:1px solid #f8fafc}.row-name{font-weight:600;color:#334155;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-detail{color:#64748b;font-size:.7rem;white-space:nowrap}.row-sucursal{color:#94a3b8;font-size:.68rem;white-space:nowrap}@keyframes expandReport{0%{opacity:0;max-height:0}to{opacity:1;max-height:600px}}@media(max-width:480px){.notif-dropdown{position:fixed;top:60px;left:10px;right:10px;width:auto}}:root{--p-emerald-50: #ecfdf5;--p-emerald-100: #d1fae5;--p-emerald-500: #10b981;--p-emerald-600: #059669;--p-emerald-700: #047857;--p-emerald-900: #064e3b;--sidebar-width: 280px;--modal-width: 550px;--admin-sidebar-bg: #0b1121;--admin-bg-main: #f1f5f9;--admin-card-bg: #ffffff;--admin-text-primary: #0f172a;--admin-text-secondary: #475569;--admin-text-muted: #94a3b8;--admin-border: #e2e8f0;--admin-shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .02);--admin-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -1px rgba(0, 0, 0, .04);--admin-shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--admin-radius: 20px;--admin-radius-lg: 28px;--admin-shadow-premium: 0 20px 40px -12px rgba(0, 0, 0, .12);--admin-glass: rgba(255, 255, 255, .85);--admin-glass-border: rgba(255, 255, 255, .5)}.admin-layout{display:flex;min-height:100vh;background:var(--admin-bg-main);font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--admin-text-primary);-webkit-font-smoothing:antialiased}.admin-sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,#0b1121,#0f1a2e,#0a1628);height:100vh;display:flex;flex-direction:column;position:sticky;top:0;z-index:100;box-shadow:4px 0 20px #00000026;transition:all .4s cubic-bezier(.4,0,.2,1);border-right:1px solid rgba(255,255,255,.04)}.sidebar-header{padding:2rem 1.75rem 1.5rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-logo{height:44px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(16,185,129,.3)) brightness(1.1);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.sidebar-logo:hover{transform:scale(1.1) rotate(5deg)}.sidebar-brand h1{font-size:1.15rem;font-weight:800;color:#f1f5f9;margin:0;letter-spacing:-.03em}.sidebar-brand span{font-size:.65rem;font-weight:700;color:#34d399;text-transform:uppercase;letter-spacing:.15em;display:block;margin-top:2px}.sidebar-nav{flex:1;padding:0 1.25rem;overflow-y:auto}.nav-section-title{padding:1.5rem 1rem .6rem;font-size:.6rem;font-weight:800;text-transform:uppercase;color:#94a3b880;letter-spacing:.15em}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.75rem 1.1rem;color:#cbd5e1b3;text-decoration:none;border-radius:12px;font-weight:500;font-size:.875rem;transition:all .25s ease;margin-bottom:2px}.nav-item:hover{background:#ffffff0f;color:#e2e8f0;transform:translate(4px)}.nav-item.active{background:#10b9811f;color:#34d399;font-weight:700;position:relative}.nav-item.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:#34d399;border-radius:0 4px 4px 0}.nav-item.active svg{color:#34d399}.sidebar-footer{padding:1.5rem 1.25rem;background:#00000026;border-top:1px solid rgba(255,255,255,.04)}.sidebar-user{display:flex;align-items:center;gap:.875rem;padding:.875rem;background:#ffffff0a;border-radius:14px;margin-bottom:1rem;border:1px solid rgba(255,255,255,.06)}.user-avatar-admin{width:40px;height:40px;border-radius:12px;aspect-ratio:1 / 1;flex-shrink:0;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem}.user-name-admin{font-size:.85rem;font-weight:700;color:#e2e8f0;line-height:1.2}.user-role-admin{font-size:.7rem;color:#94a3b899}.sidebar-actions{display:flex;gap:.6rem}.sidebar-btn{flex:1;height:40px;display:flex;align-items:center;justify-content:center;gap:.5rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:#cbd5e1b3;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .25s ease}.sidebar-btn:hover{border-color:#34d3994d;color:#34d399;background:#10b98114}.sidebar-btn.danger:hover{background:#ef44441a;border-color:#ef44444d;color:#f87171}.admin-main{flex:1;padding:2.5rem 3rem;min-width:0;animation:contentFadeIn .4s ease}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.content-header{margin-bottom:2.5rem;display:flex;justify-content:space-between;align-items:flex-end}.header-title h1{font-size:2rem;font-weight:800;color:#0f172a;margin:0;letter-spacing:-.04em}.header-title p{color:var(--admin-text-muted);font-size:1rem;margin-top:.35rem}.header-actions{display:flex;align-items:center;gap:1rem}.filters-bar{display:flex;gap:.75rem;background:#f1f5f9;padding:.5rem;border-radius:14px}.header-actions .input,.header-actions .date-input{border:none!important;background:#fff!important;height:40px!important;border-radius:10px!important;box-shadow:var(--admin-shadow-sm)!important;font-size:.9rem!important;color:var(--admin-text-secondary)!important;padding:0 1rem!important;cursor:pointer}.btn-secondary{height:40px;padding:0 1.25rem;border-radius:12px;background:var(--p-emerald-900);color:#fff;border:none;font-weight:600;font-size:.875rem;display:flex;align-items:center;gap:.75rem;transition:all .3s ease;cursor:pointer}.btn-secondary:hover{background:var(--p-emerald-700);transform:translateY(-2px);box-shadow:0 8px 20px #064e3b33}.btn-primary{height:40px;padding:0 1.25rem;border-radius:12px;background:var(--p-emerald-500);color:#fff;border:none;font-weight:700;font-size:.875rem;display:flex;align-items:center;gap:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;box-shadow:0 4px 6px -1px #10b9811a}.btn-primary:hover{background:var(--p-emerald-600);transform:translateY(-2px);box-shadow:0 10px 15px -3px #10b9814d}.btn-ghost{height:40px;padding:0 1.25rem;border-radius:12px;background:transparent;color:var(--admin-text-secondary);border:none;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease}.btn-ghost:hover{background:var(--p-emerald-50);color:var(--p-emerald-700)}.premium-input-group{position:relative;display:flex;align-items:center}.premium-input-group svg{position:absolute;left:1.25rem;color:var(--p-emerald-500);pointer-events:none;transition:all .3s ease}.premium-input-group input,.premium-input-group select{padding-left:3.25rem!important}.premium-input-group:focus-within svg{color:var(--p-emerald-700);transform:scale(1.1)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:4rem}.stat-card{background:#fff9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;padding:1.75rem;position:relative;border:1px solid rgba(255,255,255,.5);transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 10px 30px #0000000a;overflow:hidden}.stat-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 25px 50px -12px #10b98133;border-color:var(--p-emerald-300)}.stat-card.primary{background:linear-gradient(to bottom right,#fff,#f0fdf4)}.stat-card.success{background:linear-gradient(to bottom right,#fff,#ecfdf5)}.stat-card.info{background:linear-gradient(to bottom right,#fff,#eff6ff)}.stat-card.warning{background:linear-gradient(to bottom right,#fff,#fffbeb)}.stat-card:after{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle at top right,rgba(16,185,129,.05),transparent 70%)}.stat-icon{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;font-size:1.25rem;transition:all .3s ease}.stat-card:hover .stat-icon{transform:scale(1.1) rotate(-5deg)}.stat-card.primary .stat-icon{background:#f0fdf4;color:#10b981}.stat-card.success .stat-icon{background:#ecfdf5;color:#059669}.stat-card.warning .stat-icon{background:#fffcf0;color:#d97706}.stat-card.danger .stat-icon{background:#fff1f2;color:#e11d48}.stat-card.info .stat-icon{background:#eff6ff;color:#2563eb}.stat-card.neutral .stat-icon{background:#f8fafc;color:#475569}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:2.25rem;font-weight:800;color:var(--p-emerald-900);letter-spacing:-.04em;line-height:1}.stat-label{font-size:.9375rem;font-weight:600;color:var(--admin-text-muted);margin-top:.5rem}.stat-badge{position:absolute;top:1.75rem;right:1.75rem;padding:.4rem .75rem;border-radius:50%;aspect-ratio:1 / 1;flex-shrink:0;font-size:.7rem;font-weight:800;text-transform:uppercase;display:flex;align-items:center;gap:.4rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stat-badge.primary{background:#d1fae5;color:#065f46}.stat-badge.success{background:#dcfce7;color:#166534}.stat-badge.warning{background:#fef3c7;color:#92400e}.stat-badge.danger{background:#fee2e2;color:#991b1b}.stat-badge.info{background:#dbeafe;color:#1e40af}.stat-badge.neutral{background:#f1f5f9;color:#334155}.quick-actions{margin-top:2rem}.quick-actions h2{font-size:1.25rem;font-weight:800;margin-bottom:2rem;color:var(--p-emerald-900);letter-spacing:-.02em}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.action-card{background:#fff;border:1px solid var(--admin-border);border-radius:24px;padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:flex-start;gap:1.5rem;cursor:pointer;transition:all .4s ease;text-align:left;position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;bottom:-50px;right:-50px;width:150px;height:150px;background:var(--p-emerald-50);border-radius:50%;z-index:0;transition:all .4s ease}.action-card:hover:before{transform:scale(2);background:var(--p-emerald-100)}.action-card:hover{border-color:var(--p-emerald-500);transform:translateY(-10px);box-shadow:var(--admin-shadow-lg)}.action-card svg{color:var(--p-emerald-500);width:40px;height:40px;position:relative;z-index:1}.action-card span{font-size:1.125rem;font-weight:700;color:var(--p-emerald-900);position:relative;z-index:1}.action-card p{font-size:.9rem;color:var(--admin-text-muted);margin:0;position:relative;z-index:1}.tabs-container{display:inline-flex;background:#f1f5f9;padding:.4rem;border-radius:16px;margin-bottom:2.5rem;gap:.4rem}.tab{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;border:none;background:transparent;color:var(--admin-text-secondary);font-size:.875rem;font-weight:700;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab:hover{color:var(--p-emerald-700)}.tab.active{background:#fff;color:var(--p-emerald-600);box-shadow:var(--admin-shadow-sm)}.tab svg{width:18px;height:18px;opacity:.7}.tab.active svg{color:var(--p-emerald-500);opacity:1}.filters-bar{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-input{display:flex;align-items:center;gap:.75rem;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:14px;padding:0 1rem;transition:all .3s ease}.search-input:focus-within{background:#fff;border-color:var(--p-emerald-500);box-shadow:0 0 0 4px #10b9811a}.search-input svg{color:var(--admin-text-muted)}.search-input input{border:none;outline:none;padding:.875rem 0;width:100%;font-size:.9375rem;background:transparent;color:var(--admin-text-primary)}.table-container{background:#fff;border-radius:24px;border:1px solid var(--admin-border);box-shadow:var(--admin-shadow-md);overflow:hidden;margin-bottom:2rem}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table th{background:#f8fafc;padding:1rem 1.5rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--admin-text-secondary);border-bottom:1px solid var(--admin-border)}.data-table td{padding:1rem 1.5rem;font-size:.875rem;color:var(--admin-text-primary);border-bottom:1px solid var(--admin-border);vertical-align:middle}.data-table tbody tr{transition:all .2s ease}.data-table tbody tr:hover{background:var(--p-emerald-50)}.data-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-flex;align-items:center;padding:.5rem .875rem;border-radius:12px;font-size:.75rem;font-weight:700;letter-spacing:-.01em}.status-badge.presente{background:#ecfdf5;color:#059669}.status-badge.tardanza{background:#fffbeb;color:#d97706}.status-badge.ausente{background:#f1f5f9;color:#64748b}.user-cell{display:flex;align-items:center;gap:1rem}.user-avatar-small{width:36px;height:36px;border-radius:50%;aspect-ratio:1 / 1;flex-shrink:0;background:var(--p-emerald-100);color:var(--p-emerald-700);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem}.role-badge{display:inline-flex;padding:.4rem .8rem;border-radius:10px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.role-badge.admin{background:#fef2f2;color:#ef4444;border:1px solid #fee2e2}.role-badge.empleado{background:#f0fdf4;color:#16a34a;border:1px solid #dcfce7}.actions-cell{display:flex;gap:.5rem;align-items:center}.action-btn{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border:none;color:var(--admin-text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.action-btn:hover{background:var(--p-emerald-500);color:#fff;transform:translateY(-2px);box-shadow:0 8px 16px -4px #10b98166}.action-btn.danger:hover{background:#ef4444;color:#fff;box-shadow:0 8px 16px -4px #ef444466}.action-btn.success:hover{background:var(--p-emerald-500);color:#fff;box-shadow:0 8px 16px -4px #10b98166}.action-btn svg{width:16px;height:16px}.tardia-badge{background:#fef2f2;color:#991b1b;padding:.375rem .75rem;border-radius:8px;font-size:.75rem;font-weight:700}.descuento-value{color:#dc2626;font-weight:700;font-family:JetBrains Mono,monospace}.modal-overlay{position:fixed;inset:0;background:#064e3b66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .3s ease-out}.modal-content{background:#fff;width:100%;max-width:600px;border-radius:32px;box-shadow:0 40px 100px -20px #0003;overflow:hidden;position:relative;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.side-modal{max-width:500px!important;height:100vh;border-radius:40px 0 0 40px!important;margin:0!important;position:absolute;right:0;top:0;bottom:0;display:flex;flex-direction:column}.side-modal .modal-body{flex:1;overflow-y:auto;padding:2.5rem}.nano-scroll::-webkit-scrollbar{width:6px}.nano-scroll::-webkit-scrollbar-track{background:transparent}.nano-scroll::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:50%;aspect-ratio:1 / 1;flex-shrink:0}.nano-scroll::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.modal-header{padding:1.5rem 2.5rem;border-bottom:1px solid var(--admin-border);display:flex;justify-content:space-between;align-items:center;background:#fff}.modal-header-actions{display:flex;gap:.75rem;align-items:center}.modal-header h2{font-size:1.5rem;font-weight:800;color:var(--p-emerald-900);margin:0;letter-spacing:-.02em;display:flex;align-items:center;gap:.75rem}.btn-sm{padding:.5rem 1rem!important;font-size:.8125rem!important;border-radius:10px!important;height:auto!important}.modal-close{background:#f1f5f9;border:none;width:36px;height:36px;border-radius:50%;aspect-ratio:1 / 1;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--admin-text-secondary);cursor:pointer;transition:all .2s}.modal-close:hover{background:#fee2e2;color:#ef4444}.modal-form{padding:2rem;max-height:calc(85vh - 160px);overflow-y:auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.75rem;font-weight:700;color:#166534;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group select{width:100%;height:48px;padding:0 1rem;border-radius:12px;border:1.5px solid #e2e8f0;background:#fff;font-size:.9375rem;transition:all .3s;color:var(--admin-text-primary)}.form-group input:focus,.form-group select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 4px #10b9811a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:.5rem}.checkbox-group{display:flex;align-items:center}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:600!important;font-size:.875rem!important;color:var(--admin-text-secondary)!important;text-transform:none!important;letter-spacing:normal!important;margin-bottom:0!important}.checkbox-label input[type=checkbox]{width:20px;height:20px;border-radius:6px;cursor:pointer;accent-color:#10b981}.modal-actions{padding:1.5rem 2.5rem;background:#f8fafc;border-top:1px solid var(--admin-border);display:flex;gap:1rem;justify-content:flex-end}.form-error{background:#fef2f2;border:1px solid #fee2e2;color:#991b1b;padding:1rem;border-radius:12px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:600}.config-pane{padding:0}.config-tabs{display:flex;gap:2rem;border-bottom:2px solid #f0fdf4;margin-bottom:2rem}.config-tab-item{padding:1rem .5rem;font-size:.9375rem;font-weight:700;color:#6a8c7a;text-decoration:none;border-bottom:3px solid transparent;transition:all .3s}.config-tab-item.active{color:#166534;border-bottom-color:#22c55e}.search-box{background:#fdfdfd;border:1px solid #dcfce7;border-radius:12px;padding:.75rem 1.25rem;display:flex;align-items:center;gap:.75rem;color:#6a8c7a;width:100%;max-width:400px}.search-box input{background:transparent;border:none;outline:none;font-size:.9375rem;color:#166534;width:100%}.map-picker-container{border-radius:20px;border:2px solid #dcfce7;box-shadow:0 10px 30px #00320008;height:350px!important}.leaflet-popup-content-wrapper{border-radius:16px!important;padding:4px!important}.dev-tools{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.dev-card{background:#fff;border-radius:20px;padding:2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;border:1px solid var(--admin-border);transition:all .3s ease}.dev-card:hover{box-shadow:var(--shadow-lg);border-color:#cbd5e1}.dev-card-info{flex:1}.dev-card-info h3{font-size:1.25rem;font-weight:700;margin:0 0 .5rem;color:var(--p-emerald-900)}.dev-card-info p{font-size:.9375rem;color:#64748b;margin:0;line-height:1.6}.danger-card{border-left:6px solid #ef4444}.danger-card:hover{border-color:#ef4444}.info-card{border-left:6px solid #3b82f6;background:#f8faff}.btn-danger{background:#ef4444!important;color:#fff!important}.btn-danger:hover{background:#dc2626!important;transform:translateY(-2px);box-shadow:0 10px 15px -3px #ef444466}.badge.warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a;padding:6px 12px;border-radius:8px;font-weight:700;font-size:.75rem;letter-spacing:.05em}.toggle-switch{display:flex;align-items:center;gap:1rem;cursor:pointer;padding:.5rem 0}.toggle-switch input{display:none}.toggle-slider{width:44px;height:24px;background:#e2e8f0;border-radius:20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;background:#fff;border-radius:50%;top:3px;left:3px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000001a}.toggle-switch input:checked+.toggle-slider{background:var(--p-emerald-500)}.toggle-switch input:checked+.toggle-slider:before{left:23px}.toggle-label{display:flex;flex-direction:column}.toggle-main-text{font-size:.9375rem;font-weight:700;color:var(--p-emerald-900)}.toggle-sub-text{font-size:.75rem;color:var(--admin-text-muted)}.form-group-icon{position:relative;display:flex;align-items:center}.form-group-icon>svg:not(.password-toggle-btn svg){position:absolute;left:1rem;color:var(--admin-text-muted);pointer-events:none;z-index:2}.password-group input{padding-right:3rem!important}.form-group-icon input,.form-group-icon select{padding-left:2.75rem!important}.password-group{position:relative}.password-toggle-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:transparent;border:none;padding:0;margin:0;cursor:pointer;color:var(--admin-text-muted);display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;border-radius:50%;width:36px;height:36px;outline:none}.password-toggle-btn svg{position:static!important;left:auto!important;pointer-events:auto!important}.password-toggle-btn:hover{color:var(--p-emerald-600);background:var(--p-emerald-50)}.form-divider{height:1px;background:var(--admin-border);margin:1.5rem 0;width:100%}.form-section-title{font-size:.75rem;font-weight:800;text-transform:uppercase;color:var(--p-emerald-600);letter-spacing:.1em;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.form-section-title:after{content:"";flex:1;height:1px;background:var(--p-emerald-100)}.perfil-preview-admin{display:flex;justify-content:center;margin-bottom:2rem}.perfil-preview-admin img{border:4px solid white;box-shadow:0 10px 25px #0000001a}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.animate-slideInRight{animation:slideInRight .5s cubic-bezier(.16,1,.3,1)}.animate-slideUp{animation:slideUp .4s cubic-bezier(.16,1,.3,1)}@media(max-width:768px){.dev-card{flex-direction:column;text-align:center;padding:1.5rem}.btn-danger{width:100%}.side-modal{max-width:100%!important;border-radius:0!important}}.map-view-container{display:flex;gap:1.5rem;height:700px!important;background:#fff;border-radius:24px;padding:1.25rem;box-shadow:var(--admin-shadow-md);margin-top:1rem;animation:fadeIn .4s ease-out}.map-sidebar{width:340px;display:flex;flex-direction:column;gap:1.25rem;border-right:1px solid #f1f5f9;padding-right:1.5rem;overflow-y:auto}.map-sidebar h3{font-size:1.125rem;font-weight:800;color:var(--p-emerald-900);margin:0}.map-actual-container{flex:1;border-radius:20px;overflow:hidden;position:relative;border:1px solid #f1f5f9;background:#f8fafc}.map-locations-list{display:flex;flex-direction:column;gap:.75rem}.map-location-item{display:flex;gap:1rem;padding:1rem;background:#f8fafc;border-radius:16px;border:1px solid transparent;transition:all .3s ease;cursor:pointer}.map-location-item:hover{background:#fff;border-color:var(--p-emerald-200);box-shadow:var(--admin-shadow-sm);transform:translate(4px)}.location-info{display:flex;flex-direction:column;gap:.25rem}.location-info .user-name{font-size:.9375rem;font-weight:700;color:var(--p-emerald-900)}.location-info .time{font-size:.75rem;color:var(--admin-text-muted)}.btn-link{display:flex;align-items:center;gap:.4rem;color:var(--p-emerald-600);font-size:.75rem;font-weight:700;text-decoration:none;margin-top:.25rem}.custom-map-marker{background:none!important;border:none!important}.marker-info-wrapper{display:flex;flex-direction:column;align-items:center;position:relative}.marker-blue-box{background:#22c55e;background:#2563eb;color:#fff;padding:8px 16px;border-radius:14px;font-size:11px;font-weight:700;box-shadow:0 10px 25px -5px #2563eb66;display:flex;flex-direction:column;gap:3px;white-space:nowrap;border:2px solid white;position:relative;margin-bottom:12px}.marker-blue-box:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);border-left:10px solid transparent;border-right:10px solid transparent;border-top:10px solid white}.marker-blue-box span{display:flex;align-items:center;gap:6px}.marker-pin-custom{width:22px;height:22px;background:#2563eb;border-radius:50%;border:3px solid white;box-shadow:0 0 0 5px #2563eb26;z-index:2}.marker-sucursal-label{background:#fff;color:#1e3a8a;padding:6px 14px;border-radius:50%;aspect-ratio:1 / 1;flex-shrink:0;font-size:11px;font-weight:800;margin-top:10px;box-shadow:0 4px 15px #0000001a;white-space:nowrap;border:1px solid #e2e8f0;text-transform:uppercase;letter-spacing:.03rem}.marker-sucursal-sub{background:#f1f5f9;color:#64748b;padding:2px 10px;border-radius:6px;font-size:10px;font-weight:700;margin-top:4px;border:1px solid #e2e8f0}.leaflet-container{width:100%;height:100%;z-index:1}.modal-overlay-premium{position:fixed;inset:0;background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}.premium-modal{background:#fff;border-radius:32px;width:600px;max-width:95%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #10b98126;border:1px solid rgba(255,255,255,.4);position:relative;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.days-selector-v2{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.day-chip{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;border:2px solid #f1f5f9;background:#f8fafc;color:#64748b;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.day-chip.active{background:var(--p-emerald-500);border-color:var(--p-emerald-500);color:#fff;box-shadow:0 8px 20px #10b9814d;transform:scale(1.05)}.empty-state-premium{background:#fff;border-radius:32px;padding:6rem 2rem;text-align:center;border:2px dashed #e2e8f0;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.icon-float{animation:float 4s ease-in-out infinite;color:var(--p-emerald-300)}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:#fff;border:none;border-radius:8px;padding:.5rem;box-shadow:0 4px 6px -1px #0000001a;cursor:pointer;color:var(--p-emerald-600)}.mobile-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-sidebar{position:fixed;left:-100%;top:0;height:100vh;width:85%;max-width:300px;z-index:1000;transition:left .3s cubic-bezier(.4,0,.2,1);background:#0b1121;box-shadow:5px 0 25px #0003}.admin-sidebar.mobile-open{left:0}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center}.mobile-overlay{display:block}.admin-main{padding:4rem 1.5rem 2rem;width:100%}.content-header{flex-direction:column;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;margin-top:1rem}.header-title h1{font-size:1.75rem}.header-actions{width:100%;flex-direction:column;align-items:stretch}.filters-bar{display:flex;flex-direction:column;width:100%;gap:1rem}.search-input{width:100%}.header-actions .input,.header-actions .date-input,.header-actions select{width:100%!important}.btn-secondary{justify-content:center}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1.5rem}.stat-value{font-size:1.75rem}.table-container{border-radius:16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:800px}.data-table th,.data-table td{padding:.75rem 1rem;font-size:.8rem}.user-avatar-small{width:30px;height:30px}.quick-actions h2{font-size:1.1rem}.actions-grid{grid-template-columns:1fr}.action-card{padding:1.5rem}.tabs-container{width:100%;display:flex;overflow-x:auto;padding:.25rem;gap:.5rem}.tab{flex:1;justify-content:center;padding:.6rem;font-size:.8rem;white-space:nowrap}}.map-view-container{height:calc(100vh - 200px);width:100%;border-radius:20px;overflow:hidden;position:relative;box-shadow:0 4px 20px #0000000d}.cluster-pill{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.cluster-pill:hover{transform:scale(1.05);z-index:999!important}.avatar-stack{display:flex;align-items:center;justify-content:center;background:#fff;padding:2px;border-radius:50px;box-shadow:0 4px 12px #00000026}.cluster-pill.single .avatar-stack{padding:0;border-radius:50%}.avatar-circle{width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid white;margin-left:-15px;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#475569}.avatar-circle:first-child{margin-left:0}.avatar-circle img{width:100%;height:100%;object-fit:cover}.avatar-more{width:40px;height:40px;border-radius:50%;background:#2563eb;color:#fff;border:2px solid white;margin-left:-15px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.cluster-info{margin-top:8px;background:#fff;padding:6px 14px;border-radius:12px;font-size:.8rem;font-weight:700;color:#2563eb;box-shadow:0 4px 10px #2563eb33;position:relative}.cluster-pointer{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid white}.cluster-label{margin-top:8px;background:#eff6ff;color:#1e40af;padding:4px 10px;border-radius:8px;font-size:.75rem;font-weight:700;white-space:nowrap;box-shadow:0 2px 4px #0000000d}.premium-map-modal{position:absolute;top:20px;left:20px;width:400px;max-height:calc(100% - 40px);background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;z-index:10000;display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header-blue{background:#06f;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;color:#fff}.modal-header-blue h3{margin:0;font-size:.95rem;font-weight:700}.header-controls{display:flex;gap:.5rem}.icon-btn-light{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.icon-btn-light:hover{background:#ffffff4d}.modal-body-list{padding:1rem;background:#f8fafc;flex:1;overflow:hidden;display:flex;flex-direction:column}.modal-search{position:relative;margin-bottom:1rem}.modal-search input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:1px solid #e2e8f0;border-radius:50%;aspect-ratio:1 / 1;flex-shrink:0;font-size:.875rem;outline:none;transition:all .2s}.modal-search input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:#94a3b8}.list-header-row{display:grid;grid-template-columns:1.5fr .8fr .8fr .4fr;padding:.5rem .75rem;font-size:.7rem;font-weight:700;color:#94a3b8;text-transform:uppercase}.list-scroll-area{flex:1;overflow-y:auto;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.list-row-item{display:grid;grid-template-columns:1.5fr .8fr .8fr .4fr;padding:.75rem;border-bottom:1px solid #f1f5f9;align-items:center;transition:background .2s}.list-row-item:hover{background:#f8fafc}.list-row-item:last-child{border-bottom:none}.col-user{display:flex;align-items:center;gap:.75rem}.user-avatar-tiny{width:32px;height:32px;border-radius:50%;background:#f1f5f9;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#64748b}.user-avatar-tiny img{width:100%;height:100%;object-fit:cover}.user-name-list{font-size:.85rem;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.col-time{font-size:.85rem;color:#334155;font-weight:500}.col-time.orange{color:#f97316}.col-action{display:flex;justify-content:center}.eye-icon{color:#3b82f6;cursor:pointer;transition:transform .2s}.eye-icon:hover{transform:scale(1.1)}.modal-footer-count{margin-top:10px;text-align:center;font-size:.8rem;color:#94a3b8}@media(max-width:768px){.premium-map-modal{width:90%;left:5%;top:auto;bottom:20px;max-height:60vh}.map-view-container{height:70vh}}.dashboard-grid-premium{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:2rem}.premium-row{display:grid;gap:1.5rem}.premium-row.stats-row{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.premium-row.charts-row{grid-template-columns:2fr 1fr}.premium-row.bottom-row{grid-template-columns:1fr}.p-stat-card{background:#fff;border-radius:20px;padding:1.5rem;position:relative;overflow:hidden;box-shadow:var(--admin-shadow-sm);transition:all .35s cubic-bezier(.4,0,.2,1);border:1px solid var(--admin-border)}.p-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:20px 20px 0 0;opacity:0;transition:opacity .3s ease}.p-stat-card:hover{transform:translateY(-4px);box-shadow:var(--admin-shadow-lg);border-color:transparent}.p-stat-card:hover:before{opacity:1}.p-stat-card.blue{background:linear-gradient(160deg,#fff,#f0f7ff)}.p-stat-card.blue:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.p-stat-card.purple{background:linear-gradient(160deg,#fff,#f5f3ff)}.p-stat-card.purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.p-stat-card.pink{background:linear-gradient(160deg,#fff,#fdf2f8)}.p-stat-card.pink:before{background:linear-gradient(90deg,#ec4899,#f472b6)}.p-stat-card.green{background:linear-gradient(160deg,#fff,#ecfdf5)}.p-stat-card.green:before{background:linear-gradient(90deg,#10b981,#34d399)}.p-stat-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.p-icon-box{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.p-stat-card:hover .p-icon-box{transform:scale(1.1) rotate(-5deg)}.p-stat-card.blue .p-icon-box{color:#3b82f6;background:#3b82f61a}.p-stat-card.purple .p-icon-box{color:#8b5cf6;background:#8b5cf61a}.p-stat-card.pink .p-icon-box{color:#ec4899;background:#ec48991a}.p-stat-card.green .p-icon-box{color:#10b981;background:#10b9811a}.p-badge{padding:4px 10px;border-radius:20px;font-size:.7rem;font-weight:700;background:#eff6ff;color:#1e40af}.p-badge.warning{background:#fef2f2;color:#b91c1c}.p-badge.success{background:#ecfdf5;color:#065f46}.p-stat-value{font-size:1.875rem;font-weight:800;color:#0f172a;margin-bottom:.2rem;letter-spacing:-.03em}.p-stat-label{font-size:.825rem;color:#94a3b8;font-weight:500;margin-bottom:1rem}.p-stat-chart{height:40px;margin:0 -1rem -.5rem;opacity:.7}.p-chart-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:var(--admin-shadow-sm);border:1px solid var(--admin-border);display:flex;flex-direction:column;transition:box-shadow .3s ease}.p-chart-card:hover{box-shadow:var(--admin-shadow-md)}.card-header-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.card-header-flex h3{margin:0;font-size:1rem;font-weight:700;color:#0f172a}.chart-select{padding:6px 14px;border-radius:8px;border:1px solid #e2e8f0;font-size:.8rem;color:#475569;background:#f8fafc;cursor:pointer;transition:all .2s}.chart-select:hover{border-color:#10b981}.chart-container{flex:1;min-height:0;position:relative}.donut-wrapper{display:flex;align-items:center;justify-content:center}.donut-center-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.donut-center-text span{display:block;font-size:1.75rem;font-weight:800;color:#1e293b;line-height:1}.donut-center-text small{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.chart-legend{display:flex;justify-content:space-around;margin-top:1rem;border-top:1px solid #f8fafc;padding-top:1rem}.legend-item{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.8rem;color:#64748b}.legend-item .dot{width:8px;height:8px;border-radius:50%;margin-bottom:4px}.legend-item .val{font-weight:700;color:#1e293b}.btn-text{background:none;border:none;color:#3b82f6;font-weight:600;font-size:.85rem;cursor:pointer}.btn-text:hover{text-decoration:underline}@media(max-width:1024px){.premium-row.charts-row{grid-template-columns:1fr}}.p-filters-container{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;margin-bottom:2rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap;border:1px solid #f1f5f9}.p-filter-group{display:flex;align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:.5rem 1rem;min-width:240px;transition:all .2s}.p-filter-group:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fff}.p-filter-group svg{color:#94a3b8;margin-right:.75rem}.p-filter-group input,.p-filter-group select{border:none;background:transparent;outline:none;width:100%;font-size:.95rem;color:#334155}.p-tabs-container{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#f1f5f9;padding:.35rem;border-radius:14px;width:fit-content}.p-tab{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:12px;border:none;background:transparent;color:#64748b;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.p-tab.active{background:#fff;color:#0f172a;box-shadow:0 2px 4px #0000000d}.p-tab:hover:not(.active){background:#ffffff80;color:#475569}.premium-table-container{background:#fff;border-radius:20px;box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000006;border:1px solid #f1f5f9;overflow:hidden}.premium-table{width:100%;border-collapse:collapse}.premium-table th{background:#f8fafc;padding:1rem 1.5rem;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:700;border-bottom:1px solid #e2e8f0}.premium-table td{padding:1.25rem 1.5rem;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:#334155;font-size:.95rem}.premium-table tr:hover td{background:#fcfcfc}.premium-table tr:last-child td{border-bottom:none}.p-user-cell{display:flex;align-items:center;gap:1rem}.p-avatar{width:42px;height:42px;border-radius:12px;object-fit:cover;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-weight:700;color:#64748b;font-size:1.1rem;box-shadow:0 2px 5px #0000000d}.p-user-info{display:flex;flex-direction:column}.p-user-name{font-weight:600;color:#0f172a}.p-user-sub{font-size:.8rem;color:#94a3b8}.p-status-badge{padding:.35rem .75rem;border-radius:20px;font-size:.75rem;font-weight:700;display:inline-flex;align-items:center;gap:.35rem}.p-status-badge.presente{background:#dcfce7;color:#166534}.p-status-badge.tardanza{background:#fff7ed;color:#9a3412}.p-status-badge.ausente{background:#fef2f2;color:#991b1b}.p-time{font-family:Monaco,Consolas,monospace;font-size:.9rem;color:#475569}.p-time.late{color:#ef4444;font-weight:700}.p-action-btn{width:36px;height:36px;border-radius:50%;aspect-ratio:1 / 1;flex-shrink:0;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.p-action-btn:hover{background:#eff6ff;color:#3b82f6;border-color:#bfdbfe;transform:translateY(-1px)}.p-empty-state{padding:4rem;text-align:center;color:#94a3b8;display:flex;flex-direction:column;align-items:center;gap:1rem}.p-empty-icon{width:64px;height:64px;background:#f1f5f9;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#cbd5e1;margin-bottom:.5rem}.faceid-container{position:fixed;inset:0;background:#0f172a;color:#f8fafc;z-index:10000;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden}.faceid-bg-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:300px;height:300px;background:radial-gradient(circle,rgba(16,185,129,.15),transparent 70%);filter:blur(50px);pointer-events:none;z-index:1}.faceid-header-actions{padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:10}.faceid-cancel-btn{background:transparent;border:none;color:#10b981;font-size:1.1rem;font-weight:500;padding:.5rem;cursor:pointer}.faceid-cancel-btn:active{opacity:.6}.faceid-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:5;overflow-y:auto;-webkit-overflow-scrolling:touch;max-height:100vh}@media(max-width:480px){.faceid-main{padding:1rem;justify-content:flex-start}.faceid-camera-frame{width:240px;height:240px;margin-top:1rem;box-shadow:0 0 0 1000px #0f172a}.faceid-title{font-size:1.5rem;margin-bottom:.5rem}.faceid-subtitle{font-size:.9rem;margin-bottom:1.5rem}.faceid-actions-bar{padding:1rem;gap:1.5rem;margin-bottom:1rem}.faceid-instruction{font-size:1.4rem}.faceid-info-view{padding:0}.avatar-preview{width:60px;height:60px;margin-bottom:1rem}.faceid-form{padding:1rem;margin-bottom:1rem}.info-group{margin-bottom:.8rem}.info-group label{font-size:.75rem;margin-bottom:.3rem}.info-input{padding:.8rem;font-size:.9rem}}.faceid-content{text-align:center;max-width:360px;display:flex;flex-direction:column;align-items:center}.faceid-icon-wrapper{margin-bottom:3rem}.faceid-scan-circle{width:140px;height:140px;border:2px solid rgba(16,185,129,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;color:#10b981}.scan-line{position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(to right,transparent,#10b981,transparent);animation:scanMove 3s ease-in-out infinite;z-index:2}@keyframes scanMove{0%,to{top:0%}50%{top:100%}}.faceid-title{font-size:2.2rem;font-weight:700;margin-bottom:1rem;letter-spacing:-.5px;color:#f8fafc;text-shadow:0 0 20px rgba(0,0,0,.3)}.faceid-subtitle{font-size:1.1rem;color:#94a3b8;line-height:1.5;margin-bottom:3rem}.faceid-footer{width:100%;display:flex;flex-direction:column;gap:1rem}.faceid-primary-btn{width:100%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:14px;padding:1.2rem;font-size:1.15rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #10b9814d}.faceid-primary-btn:active{transform:scale(.96);filter:brightness(1.1)}.faceid-secondary-btn{background:transparent;border:none;color:#10b981;font-size:1rem;font-weight:500;padding:.5rem;cursor:pointer}.faceid-camera-view{display:flex;flex-direction:column;align-items:center;width:100%;height:100%;justify-content:space-around}.faceid-camera-frame{position:relative;width:300px;height:300px;border-radius:50%;overflow:hidden;background:#1e293b;box-shadow:0 0 0 2000px #0f172a;z-index:10}.faceid-camera-frame video,.faceid-camera-frame img{width:100%;height:100%;object-fit:cover}.faceid-camera-frame video.mirror{transform:scaleX(-1)}.faceid-camera-frame.captured{box-shadow:0 0 0 2000px #0f172af2}.faceid-ring{position:absolute;inset:-5px;pointer-events:none}.ring-segment{position:absolute;width:100%;height:100%;border:3px solid rgba(16,185,129,.3);border-radius:50%}.ring-segment:nth-child(1){border-top-color:#10b981;animation:ringRotation 8s linear infinite}.ring-segment:nth-child(2){border-right-color:#10b981;animation:ringRotation 12s linear reverse infinite}@keyframes ringRotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.faceid-camera-overlay{position:absolute;inset:0;background:#0f172ad9;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:#10b981}.faceid-camera-overlay.error{color:#ff453a}.faceid-mini-btn{margin-top:1rem;background:#10b981;border:none;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;cursor:pointer}.faceid-capturing-info{text-align:center;margin-top:2rem;position:relative;z-index:20}.faceid-instruction{font-size:1.8rem;font-weight:700;margin-bottom:.5rem;color:#f8fafc}.faceid-sub-instruction{color:#94a3b8;font-size:1.1rem}.faceid-actions-bar{display:flex;align-items:center;justify-content:center;gap:3rem;width:100%;padding:2rem;margin-bottom:2rem;position:relative;z-index:20}.faceid-preview-actions{display:flex;align-items:center;justify-content:center;gap:1.5rem;width:100%;padding:1rem 2rem}.faceid-preview-actions .faceid-action-btn.secondary{flex-direction:column;width:auto;height:auto;background:#ffffff1a;color:#f8fafc;border-radius:16px;padding:.8rem 1.2rem;gap:.4rem;font-size:.8rem;font-weight:600}.faceid-preview-actions .faceid-primary-btn.confirm-btn{display:flex;align-items:center;justify-content:center;gap:.8rem;flex:1;max-width:240px;height:64px;border-radius:16px;background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 20px #10b9814d}.faceid-trigger-btn{width:84px;height:84px;border-radius:50%;background:transparent;border:5px solid #10b981;padding:5px;cursor:pointer;transition:all .2s;box-shadow:0 0 20px #10b98133;position:relative;display:flex;align-items:center;justify-content:center}.faceid-trigger-btn:hover{transform:scale(1.05)}.faceid-trigger-btn:after{content:"CAPTURAR";position:absolute;bottom:-30px;font-size:.75rem;font-weight:700;color:#10b981;letter-spacing:1px}.trigger-inner{width:100%;height:100%;background:#10b981;border-radius:50%}.faceid-action-btn{background:#1e293bcc;border:1px solid rgba(255,255,255,.1);width:56px;height:56px;border-radius:50%;color:#f8fafc;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.faceid-action-btn:hover{background:#334155;border-color:#fff3}.faceid-success-view{text-align:center}.faceid-success-icon{width:100px;height:100px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 3rem;position:relative;box-shadow:0 0 30px #10b98166}.success-circle-bg{position:absolute;inset:-10px;border:2px solid #10b981;border-radius:50%;animation:successPulse 2s infinite}@keyframes successPulse{0%{transform:scale(1);opacity:.5}to{transform:scale(1.5);opacity:0}}.faceid-info-view{padding:0 1rem;width:100%}.avatar-preview{width:80px;height:80px;border-radius:50%;overflow:hidden;margin:0 auto 1.5rem;border:3px solid #10b981;box-shadow:0 0 15px #10b98133}.avatar-preview img{width:100%;height:100%;object-fit:cover}.faceid-form{background:#1e293bb3;border-radius:20px;padding:1.5rem;margin-bottom:2rem;border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 30px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.info-group{margin-bottom:1.2rem}.info-group:last-child{margin-bottom:0}.info-group label{display:block;font-size:.85rem;font-weight:700;color:#cbd5e1;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.info-input{width:100%;background:#0f172a80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;color:#f8fafc;font-size:1rem;transition:all .2s}.info-input:focus{outline:none;border-color:#10b981;background:#0f172acc;box-shadow:0 0 0 4px #10b98126}.animate-fadeIn{animation:fadeIn .4s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.faceid-ring.verified .ring-segment{border-color:#10b981;border-width:5px;box-shadow:0 0 20px #10b98166;transition:all .3s ease}.faceid-verified-badge{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#10b981e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:.6rem 1.2rem;border-radius:30px;display:flex;align-items:center;gap:.5rem;color:#fff;font-weight:700;font-size:.85rem;z-index:30;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 15px #0003}.faceid-trigger-btn.disabled{border-color:#475569;opacity:.5;cursor:not-allowed;filter:grayscale(1);transform:scale(.9)}.faceid-trigger-btn.disabled .trigger-inner{background:#475569}.faceid-trigger-btn.active{animation:trigger-pulse 1.5s infinite}@keyframes trigger-pulse{0%{transform:scale(1);box-shadow:0 0 #10b98166}70%{transform:scale(1.1);box-shadow:0 0 0 15px #10b98100}to{transform:scale(1);box-shadow:0 0 #10b98100}}.animate-bounceIn{animation:bounceIn .6s cubic-bezier(.175,.885,.32,1.275)}@keyframes bounceIn{0%{opacity:0;transform:translate(-50%) scale(.5)}to{opacity:1;transform:translate(-50%) scale(1)}}
