*{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;height:100%;font-family:Segoe UI,Arial,sans-serif}@media (display-mode:standalone){html,body{overscroll-behavior-y:contain}}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}:root{--color-primary:#2c3e50;--color-accent:#228b22;--color-secondary:#ff6200;--color-background:#fff;--color-border:#ddd;--color-shadow:#0000001a;--color-error:#dc3545;--color-success:#228b22;--color-warning:#ffc107;--color-text-light:#666;--color-entrada:#228b22;--color-salida:#dc3545}.auth-container{background:var(--color-background);box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;margin:0;padding:0 20px;display:flex;position:relative}.auth-header{text-align:center;margin-top:10px;margin-bottom:30px}.auth-logo{max-width:300px;height:auto;margin-bottom:20px}.auth-title{color:var(--color-primary);margin:0;font-size:24px;font-weight:700}.trademark{font-size:14px}.auth-content{background:#fff;border:1px solid #0000001f;border-radius:20px;width:100%;max-width:420px;padding:40px;box-shadow:0 2px 8px #0000001a,0 25px 50px -12px #00000026}.auth-header-inside{text-align:center;margin-bottom:30px}.auth-logo-inside{max-width:300px;height:auto;margin-bottom:20px}.auth-title-inside{color:var(--color-primary);margin:0;font-size:24px;font-weight:700}.logo-container{text-align:center;margin-bottom:20px}.logo-container img{max-width:200px;height:auto}.logo-container h1{color:var(--color-primary);margin-top:10px;font-size:24px;font-weight:600}.input-group{margin-bottom:20px}.input-group label{color:var(--color-text-light);align-items:center;gap:8px;margin-bottom:8px;font-size:.9rem;font-weight:500;display:flex}.input-icon{width:18px;height:18px;color:var(--color-accent)}.input-group input,.input-group textarea{color:#4a5568;border:1px solid #0003;border-radius:10px;width:100%;padding:14px 16px;font-family:inherit;font-size:1rem;transition:all .3s}.input-group input:focus,.input-group textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #228b2226}.input-group input::placeholder,.input-group textarea::placeholder{color:#aaa}.input-with-icon{position:relative}.input-with-icon input{padding-right:45px}.input-with-icon .icon-btn{cursor:pointer;color:#666;background:0 0;border:none;padding:5px;font-size:18px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.input-with-icon .icon-btn:hover{color:var(--color-primary)}.password-field{align-items:center;display:flex;position:relative}.password-field input{width:100%;padding-right:50px}.password-field input::-ms-reveal{display:none}.password-field input::-ms-clear{display:none}.toggle-password{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:5px;display:flex;position:absolute;right:12px}.toggle-password svg{width:22px;height:22px;color:var(--color-accent);transition:color .3s}.toggle-password:hover svg{color:var(--color-accent)}.checkbox-group{align-items:center;gap:8px;margin-bottom:20px;display:flex}.checkbox-group input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--color-accent)}.checkbox-group label{color:var(--color-accent);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;font-weight:500}.btn{cursor:pointer;border:none;border-radius:6px;padding:12px 30px;font-family:inherit;font-size:16px;font-weight:700;transition:background-color .2s,transform .1s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-accept{background-color:var(--color-accent);color:#fff}.btn-accept:hover:not(:disabled){background-color:#1e7b1e}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:#e55a00}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-group{justify-content:center;gap:15px;margin-top:25px;display:flex}.auth-buttons{justify-content:center;gap:10px;margin-top:20px;display:flex}.auth-buttons .btn-accept{color:#fff;cursor:pointer;background:linear-gradient(135deg,#228b22 0%,#1e7b1e 100%);border:none;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 24px;font-size:1rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 15px #228b224d}.auth-buttons .btn-accept:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #228b2266}.auth-buttons .btn-accept:disabled{opacity:.7;cursor:not-allowed}.auth-buttons .btn-accept svg{width:20px;height:20px}.auth-buttons .btn-accept .spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.btn-salir{color:#fff;background-color:#ff6200}.btn-salir:hover:not(:disabled){background-color:#e55800}.btn-config{border:1px solid var(--color-secondary);color:var(--color-secondary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:20px;padding:12px 20px;font-size:.9rem;transition:all .3s;display:flex}.btn-config:hover{border-color:var(--color-secondary);color:var(--color-secondary);background:#ff620014}.btn-config svg{width:18px;height:18px}.footer{text-align:center;color:var(--color-text-light);margin-top:30px;font-size:12px}.footer a{color:var(--color-primary);text-decoration:none}.footer a:hover{text-decoration:underline}.auth-footer{text-align:center;margin-top:20px}.version-info{color:var(--color-primary);opacity:.6;margin-bottom:5px;font-size:11px}.auth-footer a{color:var(--color-primary);opacity:.7;font-size:12px;text-decoration:none}.auth-footer a:hover{opacity:1}.error-message{color:#721c24;text-align:center;background-color:#f8d7da;border-radius:6px;margin-bottom:20px;padding:12px;font-size:14px}.success-message{color:#155724;text-align:center;background-color:#d4edda;border-radius:6px;margin-bottom:20px;padding:12px;font-size:14px}.loading-spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:1s ease-in-out infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=600px){.auth-content{border-radius:15px;margin:0 15px;padding:25px 20px}.auth-header-inside{margin-bottom:25px}.auth-logo-inside{max-width:250px}.auth-title-inside{font-size:20px}.btn-group{flex-direction:column}.btn{width:100%}.btn-config{border-radius:8px;margin-top:15px;padding:10px 16px;font-size:.85rem}.btn-config svg{width:16px;height:16px}.header{gap:6px;padding:10px 8px}.header-logo{gap:6px}.header-logo img{height:28px}.header-logo span{font-size:15px}.header-user{gap:6px}.header-user span{font-size:12px}.btn-logout{padding:6px 10px;font-size:12px}}.fichar-container{background:linear-gradient(135deg,#f5f7fa 0%,#e4e8ec 100%);min-height:100vh}.fichar-content{max-width:600px;margin:0 auto;padding:20px}.empleado-info{box-shadow:0 2px 8px var(--color-shadow);text-align:center;background:#fff;border-radius:12px;margin-bottom:20px;padding:20px}.empleado-info h2{color:var(--color-primary);margin-bottom:5px;font-size:20px}.empleado-info p{color:var(--color-text-light);font-size:14px}.reloj-container{box-shadow:0 2px 8px var(--color-shadow);text-align:center;background:#fff;border-radius:12px;margin-bottom:20px;padding:30px}.reloj-digital{color:var(--color-primary);letter-spacing:2px;font-family:Segoe UI,monospace;font-size:64px;font-weight:700}.fecha-actual{color:var(--color-text-light);margin-top:10px;font-size:18px}.botones-fichar{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.btn-fichar{cursor:pointer;box-shadow:0 4px 12px var(--color-shadow);border:none;border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:40px 20px;font-size:20px;font-weight:700;transition:all .2s;display:flex}.btn-fichar:active{transform:scale(.98)}.btn-fichar:disabled{opacity:.5;cursor:not-allowed}.btn-entrada{color:#fff;background:linear-gradient(135deg,#28a745 0%,#218838 100%)}.btn-entrada:hover:not(:disabled){background:linear-gradient(135deg,#218838 0%,#1e7e34 100%)}.btn-salida{color:#fff;background:linear-gradient(135deg,#dc3545 0%,#c82333 100%)}.btn-salida:hover:not(:disabled){background:linear-gradient(135deg,#c82333 0%,#bd2130 100%)}.btn-fichar .icon{font-size:40px}.ultimo-movimiento{box-shadow:0 2px 8px var(--color-shadow);background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:15px 20px;display:flex}.ultimo-movimiento .label{color:var(--color-text-light);font-size:14px}.ultimo-movimiento .valor{font-size:16px;font-weight:700}.ultimo-movimiento .valor.entrada{color:var(--color-entrada)}.ultimo-movimiento .valor.salida{color:var(--color-salida)}.movimientos-dia{box-shadow:0 2px 8px var(--color-shadow);background:#fff;border-radius:12px;padding:20px}.movimientos-dia h3{color:var(--color-primary);border-bottom:1px solid var(--color-border);margin-bottom:15px;padding-bottom:10px;font-size:16px}.movimiento-item{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.movimiento-item:last-child{border-bottom:none}.movimiento-tipo{align-items:center;gap:10px;display:flex}.movimiento-tipo .badge{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.movimiento-tipo .badge.entrada{color:#155724;background-color:#d4edda}.movimiento-tipo .badge.salida{color:#721c24;background-color:#f8d7da}.movimiento-hora{color:var(--color-primary);font-size:16px;font-weight:700}.sin-movimientos{text-align:center;color:var(--color-text-light);padding:20px}.header{background:var(--color-primary);color:#fff;box-shadow:0 2px 4px var(--color-shadow);justify-content:space-between;align-items:center;gap:8px;padding:15px 12px;display:flex}.header-logo{flex-shrink:0;align-items:center;gap:8px;display:flex}.header-logo img{height:35px}.header-logo span{font-size:18px;font-weight:700}.header-user{flex:1;justify-content:flex-end;align-items:center;gap:10px;min-width:0;display:flex}.header-user span{white-space:nowrap;text-overflow:ellipsis;font-size:14px;overflow:hidden}.btn-logout{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff80;border-radius:6px;padding:8px 16px;font-size:14px;transition:all .2s}.btn-logout:hover{background:#ffffff1a;border-color:#fff}.nav-bottom{box-shadow:0 -2px 8px var(--color-shadow);z-index:100;background:#fff;justify-content:space-around;padding:10px 0;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{cursor:pointer;color:var(--color-text-light);background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;font-size:12px;transition:color .2s;display:flex}.nav-item:hover,.nav-item.active{color:var(--color-accent)}.nav-item .icon{font-size:20px}.movimientos-container{background:linear-gradient(135deg,#f5f7fa 0%,#e4e8ec 100%);min-height:100vh;padding-bottom:80px}.movimientos-content{max-width:600px;margin:0 auto;padding:20px}.fecha-selector{box-shadow:0 2px 8px var(--color-shadow);background:#fff;border-radius:12px;align-items:center;gap:15px;margin-bottom:20px;padding:15px 20px;display:flex}.fecha-selector label{color:var(--color-primary);font-weight:500}.fecha-selector input[type=date]{border:2px solid var(--color-border);border-radius:6px;flex:1;padding:10px;font-family:inherit;font-size:14px}.fecha-selector input[type=date]:focus{border-color:var(--color-accent);outline:none}.calendario-container{background:linear-gradient(135deg,#f5f7fa 0%,#e4e8ec 100%);min-height:100vh;padding-bottom:80px}.calendario-content{max-width:600px;margin:0 auto;padding:20px}.calendario-nav{box-shadow:0 2px 8px var(--color-shadow);background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:15px 20px;display:flex}.calendario-nav button{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:10px 20px;font-size:16px}.calendario-nav button:hover{background:#1e7b1e}.calendario-nav h3{color:var(--color-primary);text-transform:capitalize}.calendario-grid{box-shadow:0 2px 8px var(--color-shadow);background:#fff;border-radius:12px;padding:20px}.calendario-header{grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:10px;display:grid}.calendario-header span{text-align:center;color:var(--color-primary);padding:10px 0;font-size:12px;font-weight:700}.calendario-dias{grid-template-columns:repeat(7,1fr);gap:5px;display:grid}.calendario-dia{aspect-ratio:1;cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex;position:relative}.calendario-dia:hover{background:#f0f0f0}.calendario-dia.hoy{background:var(--color-accent);color:#fff}.calendario-dia.con-fichajes:after{content:"";background:var(--color-accent);border-radius:50%;width:6px;height:6px;position:absolute;bottom:5px}.calendario-dia.hoy.con-fichajes:after{background:#fff}.calendario-dia.otro-mes{opacity:.4}.calendario-dia.vacaciones{color:#228b22;background-color:#228b2233}.calendario-dia.vacaciones:hover{background-color:#228b224d}.calendario-dia.festivo{color:#ff69b4;background-color:#ff69b433}.calendario-dia.festivo:hover{background-color:#ff69b44d}.calendario-dia.hoy.vacaciones,.calendario-dia.hoy.festivo{background:var(--color-accent);color:#fff}.resumen-mes{box-shadow:0 2px 8px var(--color-shadow);background:#fff;border-radius:12px;margin-top:20px;padding:20px}.resumen-mes h4{color:var(--color-primary);margin-bottom:15px}.resumen-item{border-bottom:1px solid #f0f0f0;justify-content:space-between;padding:10px 0;display:flex}.resumen-item:last-child{border-bottom:none}.resumen-item .label{color:var(--color-text-light)}.resumen-item .valor{color:var(--color-primary);font-weight:700}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:450px;overflow:hidden;box-shadow:0 4px 20px #0000004d}.modal-header-verde{background:var(--color-accent);color:#fff;text-align:center;padding:15px 20px}.modal-header-verde h3{margin:0;font-size:18px;font-weight:600}.modal-body{padding:20px}.modal-footer{background:#f9f9f9;border-top:1px solid #eee;gap:10px;padding:15px 20px;display:flex}.btn-guardar{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:6px;flex:1;padding:12px;font-size:14px;font-weight:700;transition:all .2s}.btn-guardar:hover:not(:disabled){background:#1e7b1e}.btn-guardar:disabled{cursor:not-allowed;background:#ccc}.btn-cancelar{background:var(--color-secondary);color:#fff;cursor:pointer;border:none;border-radius:6px;flex:1;padding:12px;font-size:14px;transition:all .2s}.btn-cancelar:hover{background:#e55800}.modal-config{max-width:350px}.modal-config-body{text-align:center;padding:30px 20px}.modal-config-body p{color:#333;margin:0;font-size:16px}.modal-config .modal-footer{justify-content:center}.codigo-container{justify-content:center;gap:10px;display:flex}.codigo-input{text-align:center;border:2px solid var(--color-border);width:50px;height:60px;color:var(--color-primary);border-radius:8px;font-size:28px;font-weight:700;transition:border-color .2s,box-shadow .2s}.codigo-input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #228b2233}.codigo-input:disabled{cursor:not-allowed;background-color:#f5f5f5}.link-button{color:var(--color-text-light);cursor:pointer;background:0 0;border:none;padding:8px;font-size:13px;text-decoration:underline;transition:color .2s}.link-button:hover{color:var(--color-accent)}.link-button:disabled{cursor:not-allowed;opacity:.5}@media (width<=400px){.codigo-input{width:42px;height:52px;font-size:24px}.codigo-container{gap:6px}}
