*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;font-family:Segoe UI,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@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: #228B22;--color-primary-dark: #1e7b1e;--color-primary-light: #2ea02e;--color-secondary: #4a4a4a;--color-background: #f5f5f5;--color-surface: #ffffff;--color-error: #dc3545;--color-success: #28a745;--color-warning: #ffc107;--color-info: #17a2b8;--color-text-primary: #333333;--color-text-secondary: #666666;--color-border: #dddddd;--color-entrada: #28a745;--color-salida: #dc3545;--border-radius: 8px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}:root{--color-primary: #2c3e50;--color-accent: #228B22;--color-secondary: #FF6200;--color-background: #ffffff;--color-border: #ddd;--color-shadow: rgba(0,0,0,.1);--color-error: #dc3545;--color-success: #228B22;--color-warning: #ffc107;--color-text-light: #666;--color-entrada: #228B22;--color-salida: #dc3545}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--color-background);padding:0;margin:0;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);font-size:24px;font-weight:700;margin:0}.trademark{font-size:14px}.auth-content{width:100%;max-width:500px;background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 12px var(--color-shadow)}.input-group{margin-bottom:20px}.input-group label{display:block;color:var(--color-primary);font-size:14px;font-weight:500;margin-bottom:6px}.input-group input,.input-group textarea{width:100%;padding:12px;border:2px solid var(--color-border);border-radius:6px;font-size:14px;transition:border-color .2s;font-family:inherit;box-sizing:border-box}.input-group input:focus,.input-group textarea:focus{outline:none;border-color:var(--color-accent)}.input-group input::placeholder,.input-group textarea::placeholder{color:#aaa}.password-container{display:flex;flex-direction:row;align-items:center;width:100%;gap:10px}.password-input{flex:1;padding:12px;border:2px solid var(--color-border);border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box;min-width:0;font-family:inherit}.password-input:focus{outline:none;border-color:var(--color-accent)}.password-input:disabled{background-color:#f0f0f0;cursor:not-allowed}.password-input::-ms-reveal,.password-input::-ms-clear{display:none}.password-show-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:40px;border-radius:5px;transition:background-color .2s}.password-show-button:hover{background-color:#f0f0f0}.password-show-button:disabled{cursor:not-allowed;opacity:.5}.password-icon{width:20px;height:20px;fill:var(--color-accent)}.checkbox-group{display:flex;align-items:center;gap:8px;margin-bottom:20px}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent)}.checkbox-group label{color:var(--color-accent);font-size:14px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.btn{padding:12px 30px;border:none;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .2s,transform .1s;font-family:inherit}.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}.auth-buttons{display:flex;gap:10px;margin-top:20px;justify-content:center}.btn-config{position:fixed;bottom:30px;right:30px;width:50px;height:50px;background-color:#ff8c00;color:#fff;border:none;border-radius:50%;font-size:24px;cursor:pointer;box-shadow:0 2px 8px #0003;transition:background-color .2s,transform .2s;display:flex;align-items:center;justify-content:center;z-index:1000}.btn-config:hover{background-color:#e57c00;transform:scale(1.05)}.auth-footer{text-align:center;margin-top:20px}.version-info{color:var(--color-primary);font-size:11px;margin-bottom:5px;opacity:.6}.auth-footer a{color:var(--color-primary);text-decoration:none;font-size:12px;opacity:.7}.auth-footer a:hover{opacity:1}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:450px;box-shadow:0 4px 20px #0000004d;overflow:hidden}.modal-header-verde{background:var(--color-accent);color:#fff;padding:15px 20px;text-align:center}.modal-header-verde h3{margin:0;font-size:18px;font-weight:600}.modal-body{padding:20px}.modal-footer{display:flex;gap:10px;padding:15px 20px;background:#f9f9f9;border-top:1px solid #eee}.btn-guardar{flex:1;padding:12px;border:none;border-radius:6px;background:var(--color-accent);color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}.btn-guardar:hover:not(:disabled){background:#1e7b1e}.btn-guardar:disabled{background:#ccc;cursor:not-allowed}.btn-cancelar{flex:1;padding:12px;border:none;border-radius:6px;background:var(--color-secondary);color:#fff;font-size:14px;cursor:pointer;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{margin:0;font-size:16px;color:#333}.modal-config .modal-footer{justify-content:center}@media(max-width:600px){.auth-content{padding:20px;margin:10px}.btn{width:100%}.btn-config{bottom:20px;right:20px;width:45px;height:45px;font-size:20px}}.fichar-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec)}.fichar-content{max-width:800px;margin:0 auto;padding:20px 20px 100px}.header{background:var(--color-primary);color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px var(--color-shadow)}.header-logo{display:flex;align-items:center;gap:10px}.header-logo img{height:35px}.header-logo span{font-weight:700;font-size:18px}.header-user{display:flex;align-items:center;gap:15px}.header-user span{font-size:14px}.btn-logout{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.btn-logout:hover{background:#ffffff1a;border-color:#fff}.empleado-info{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px var(--color-shadow);text-align:center;margin-bottom:20px}.empleado-info h2{color:var(--color-primary);font-size:20px;margin-bottom:5px}.empleado-info p{color:var(--color-text-light);font-size:14px;margin:5px 0}.reloj-container{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 8px var(--color-shadow);text-align:center;margin-bottom:20px}.reloj-digital{font-size:64px;font-weight:700;color:var(--color-primary);font-family:Segoe UI,monospace;letter-spacing:2px}.fecha-actual{font-size:18px;color:var(--color-text-light);margin-top:10px}.botones-fichar{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.btn-fichar{padding:40px 20px;border:none;border-radius:12px;font-size:20px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:0 4px 12px var(--color-shadow)}.btn-fichar:active{transform:scale(.98)}.btn-fichar:disabled{opacity:.5;cursor:not-allowed}.btn-entrada{background:linear-gradient(135deg,#28a745,#218838);color:#fff}.btn-entrada:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1e7e34)}.btn-salida{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.btn-salida:hover:not(:disabled){background:linear-gradient(135deg,#c82333,#bd2130)}.btn-fichar .icon{font-size:40px}.nav-bottom{position:fixed;bottom:0;left:0;right:0;background:#fff;display:flex;justify-content:space-around;padding:10px 0;box-shadow:0 -2px 8px var(--color-shadow);z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;background:none;border:none;cursor:pointer;color:var(--color-text-light);font-size:12px;transition:color .2s;text-decoration:none}.nav-item:hover,.nav-item.active{color:var(--color-accent)}.nav-item .icon{font-size:20px}.movimientos-dia{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px var(--color-shadow)}.movimientos-dia h3{color:var(--color-primary);font-size:16px;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid var(--color-border)}.movimiento-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f0f0f0}.movimiento-item:last-child{border-bottom:none}.movimiento-tipo{display:flex;align-items:center;gap:10px}.movimiento-tipo .badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700}.movimiento-tipo .badge.entrada{background-color:#d4edda;color:#155724}.movimiento-tipo .badge.salida{background-color:#f8d7da;color:#721c24}.movimiento-hora{font-weight:700;color:var(--color-primary);font-size:16px}.sin-movimientos{text-align:center;color:var(--color-text-light);padding:20px}.gps-toggle-group{margin-top:10px}.toggle-container{display:flex;align-items:center;gap:12px;cursor:pointer;padding:8px 0}.toggle-switch{width:50px;height:26px;background-color:#ccc;border-radius:13px;position:relative;transition:background-color .3s}.toggle-switch.active{background-color:var(--color-accent)}.toggle-slider{width:22px;height:22px;background-color:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .3s;box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-slider{transform:translate(24px)}.toggle-label{font-size:14px;color:var(--color-primary);font-weight:500}.gps-hint{display:block;font-size:12px;color:var(--color-text-light);margin-top:4px}
