body{margin:0}#root{width:100%;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}:root{--cream:#f5f0e8;--cream-border:#d9cfc0;--ivory:#fdfaf5;--ink:#2c2416;--ink-light:#7a6e5f;--ink-xlight:#beb5a5;--gold:#b8860b;--gold-soft:#e8d5a0}body{background:var(--cream);min-height:100vh;font-family:DM Sans,sans-serif}.login-wrap{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--ivory);border:1px solid var(--cream-border);border-radius:20px;width:100%;max-width:400px;padding:52px 44px;box-shadow:0 2px 32px #2c241617}.brand{align-items:center;gap:12px;margin-bottom:36px;display:flex}.brand-icon{background:var(--ink);border-radius:11px;justify-content:center;align-items:center;width:44px;height:44px;font-size:32px;display:flex}.brand-name{color:var(--ink);font-family:Georgia,serif;font-size:26px;font-weight:500}.brand-tag{letter-spacing:2px;color:var(--ink-xlight);text-transform:uppercase;font-size:10px}.field{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.field label{color:var(--ink-light);letter-spacing:1px;text-transform:uppercase;font-size:11px;font-weight:500}.field input{background:var(--cream);border:1.5px solid var(--cream-border);color:var(--ink);border-radius:10px;outline:none;padding:13px 15px;font-family:inherit;font-size:15px;transition:border-color .2s}.field input:focus{border-color:var(--gold)}.field input::placeholder{color:var(--ink-xlight)}.error{color:#8b3a3a;background:#f3e8e8;border:1px solid #d9bfbf;border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:12px}.btn-enter{background:var(--ink);width:100%;color:var(--ivory);cursor:pointer;border:none;border-radius:10px;margin-bottom:10px;padding:14px;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s}.btn-enter:hover{background:#3d3224;transform:translateY(-1px)}.btn-exit{background:var(--cream);width:100%;color:var(--ink);border:1.5px solid var(--cream-border);cursor:pointer;border-radius:10px;padding:13px;font-family:inherit;font-size:14px;transition:all .2s}.btn-exit:hover{border-color:var(--gold);color:var(--gold)}button:disabled{opacity:.6;cursor:not-allowed;transform:none}.dash-wrap{width:100%;max-width:860px;margin:0 auto;padding:40px 24px}.dash-header{justify-content:space-between;align-items:flex-end;margin-bottom:32px;display:flex}.dash-eyebrow{letter-spacing:2px;text-transform:uppercase;color:#b8860b;margin-bottom:6px;font-size:10px}.dash-title{color:#2c2416;font-family:Georgia,serif;font-size:32px}.dash-fecha{color:#7a6e5f;text-transform:capitalize;font-size:13px}.stats-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px;display:grid}.stat{background:#fdfaf5;border:1px solid #d9cfc0;border-radius:12px;padding:18px 20px}.stat-val{color:#2c2416;font-family:Georgia,serif;font-size:28px}.stat-lbl{color:#beb5a5;text-transform:uppercase;letter-spacing:1px;margin-top:4px;font-size:11px}.table-card{background:#fdfaf5;border:1px solid #d9cfc0;border-radius:14px;overflow:hidden}.table-header{color:#7a6e5f;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid #d9cfc0;padding:14px 20px;font-size:12px;font-weight:500}.tabla{border-collapse:collapse;width:100%}.tabla th{text-align:left;color:#7a6e5f;text-transform:uppercase;letter-spacing:1px;background:#ede6d6;padding:10px 20px;font-size:10px;font-weight:500}.tabla td{color:#2c2416;border-top:1px solid #d9cfc0;padding:13px 20px;font-size:13px}.tabla tr:hover td{background:#f5f0e8}.badge-in{color:#4a7c59;background:#e8f3ec;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.badge-out{color:#8b3a3a;background:#f3e8e8;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.btn-new{color:#fdfaf5;cursor:pointer;background:#2c2416;border:none;border-radius:10px;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.btn-new:hover{background:#3d3224;transform:translateY(-1px)}.badge-hours{color:#b8860b;background:#f5edd5;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.action-btn{color:#7a6e5f;cursor:pointer;background:0 0;border:1px solid #d9cfc0;border-radius:7px;padding:5px 10px;font-family:inherit;font-size:11px;transition:all .2s}.action-btn.del:hover{color:#8b3a3a;border-color:#8b3a3a}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#2c241659;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fdfaf5;border:1px solid #d9cfc0;border-radius:20px;width:100%;max-width:420px;padding:36px;box-shadow:0 8px 48px #2c24162e}.modal-title{color:#2c2416;margin-bottom:6px;font-family:Georgia,serif;font-size:22px}.modal-sub{color:#7a6e5f;margin-bottom:24px;font-size:13px}.cred-preview{background:#f5f0e8;border-radius:10px;margin-bottom:16px;padding:14px 16px}.cred-preview-label{letter-spacing:1.5px;text-transform:uppercase;color:#beb5a5;margin-bottom:10px;font-size:10px}.cred-preview-row{color:#7a6e5f;justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.btn-confirm{color:#fdfaf5;cursor:pointer;background:#2c2416;border:none;border-radius:10px;flex:1;padding:13px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.btn-confirm:hover{background:#3d3224}.btn-cancel{color:#7a6e5f;cursor:pointer;background:0 0;border:1.5px solid #d9cfc0;border-radius:10px;padding:13px 18px;font-family:inherit;font-size:13px;transition:all .2s}.btn-cancel:hover{border-color:#7a6e5f}.tabs{background:#ede6d6;border-radius:10px;gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.tab{color:#7a6e5f;cursor:pointer;background:0 0;border:none;border-radius:7px;padding:8px 18px;font-family:inherit;font-size:13px;transition:all .2s}.tab.active{color:#2c2416;background:#fdfaf5;font-weight:500;box-shadow:0 1px 4px #2c241614}.historial-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.month-nav{background:#fdfaf5;border:1px solid #d9cfc0;border-radius:10px;align-items:center;display:flex;overflow:hidden}.month-btn{color:#7a6e5f;cursor:pointer;background:0 0;border:none;padding:8px 16px;font-family:inherit;font-size:18px;transition:all .2s}.month-btn:hover{color:#2c2416;background:#f5f0e8}.month-label{color:#2c2416;text-align:center;border-left:1px solid #d9cfc0;border-right:1px solid #d9cfc0;min-width:160px;padding:8px 20px;font-size:14px;font-weight:500}.emp-select{color:#2c2416;cursor:pointer;appearance:none;background:#fdfaf5;border:1px solid #d9cfc0;border-radius:10px;outline:none;min-width:200px;padding:9px 14px;font-family:inherit;font-size:13px}.emp-select:focus{border-color:#b8860b}.ficha-hero{background:#fdfaf5;border:1px solid #d9cfc0;border-radius:14px;align-items:center;gap:20px;margin-bottom:24px;padding:24px 28px;display:flex}.ficha-avatar{color:#7a6e5f;background:#ede6d6;border:1px solid #d9cfc0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:18px;font-weight:500;display:flex}.ficha-nombre{color:#2c2416;margin-bottom:6px;font-family:Georgia,serif;font-size:22px}.ficha-meta{color:#beb5a5;gap:8px;font-size:12px;display:flex}.cal-leyenda{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.cal-leyenda-item{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.cal-grid-meses{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.cal-mes{background:#fdfaf5;border:1px solid #d9cfc0;border-radius:12px;padding:16px}.cal-mes-titulo{color:#2c2416;text-align:center;margin-bottom:10px;font-family:Georgia,serif;font-size:14px;font-weight:500}.cal-dias-header{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;display:grid}.cal-dia-header{text-align:center;color:#beb5a5;padding:2px 0;font-size:10px;font-weight:500}.cal-dias{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-dia-empty{aspect-ratio:1}.cal-dia{aspect-ratio:1;border-radius:6px;justify-content:center;align-items:center;font-size:11px;font-weight:500;transition:transform .1s;display:flex;position:relative}.cal-dia:hover{z-index:2;transform:scale(1.15)}.cal-dia-hoy{outline-offset:1px;outline:2px solid #b8860b}.cal-semana-wrap{background:#fdfaf5;border:1px solid #d9cfc0;border-radius:14px;overflow:hidden}.cal-header-row{background:#ede6d6;border-bottom:1px solid #d9cfc0;grid-template-columns:repeat(7,1fr);display:grid}.cal-header-cell{text-align:center;color:#7a6e5f;letter-spacing:.5px;text-transform:uppercase;padding:10px 0;font-size:11px;font-weight:500}.cal-semana-row{border-bottom:1px solid #d9cfc0;grid-template-columns:repeat(7,1fr);display:grid}.cal-semana-row:last-child{border-bottom:none}.cal-semana-dia{border-right:1px solid #d9cfc0;flex-direction:column;justify-content:center;align-items:center;gap:3px;min-height:60px;padding:10px 6px;transition:transform .1s;display:flex}.cal-semana-dia:last-child{border-right:none}.cal-semana-dia:hover{z-index:2;transform:scale(1.04)}.cal-semana-num{font-size:15px;font-weight:500;line-height:1}.cal-semana-hora{opacity:.8;font-family:monospace;font-size:10px}.cal-dia-hoy .cal-semana-num{color:#fdfaf5;background:#2c2416;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.cal-mes-label{color:#7a6e5f;text-transform:uppercase;letter-spacing:1.5px;background:#ede6d6;border-bottom:1px solid #d9cfc0;padding:8px 16px;font-size:11px;font-weight:500}.login-divider{background:#d9cfc0;height:1px;margin:20px 0}.admin-link{text-align:center;color:#7a6e5f;font-size:12px}.admin-link span{color:#b8860b;cursor:pointer;font-weight:500}.admin-link span:hover{text-decoration:underline}@media (width<=768px){.login-wrap{align-items:flex-start;padding:40px 16px 16px}.login-card{border-radius:16px;padding:36px 24px}.layout{flex-direction:column}.sidebar{flex-direction:row;justify-content:space-between;align-items:center;width:100%;height:auto;padding:16px 0 8px;position:relative}.sidebar-brand{margin-bottom:0;padding:0 16px}.sidebar-section,.sidebar-item,.sidebar-bottom{display:none}.main{padding:20px 16px}.dash-header{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:20px}.dash-title{font-size:24px}.stats-row,.stats-bar{grid-template-columns:repeat(2,1fr);gap:10px}.stat-val{font-size:22px}.tabs{width:100%;overflow-x:auto}.table-card{-webkit-overflow-scrolling:touch;border-radius:10px;overflow-x:auto}.tabla{min-width:580px}.tabla th,.tabla td{white-space:nowrap;padding:10px 12px;font-size:12px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:20px 20px 0 0;width:100%;max-width:100%;max-height:90vh;padding:28px 20px 40px;overflow-y:auto}.dash-wrap{padding:20px 16px}.ficha-hero{gap:12px;padding:16px}.ficha-nombre{font-size:18px}.ficha-meta{flex-wrap:wrap;gap:4px}.historial-header{flex-direction:column;align-items:flex-start;gap:12px}.emp-select{width:100%}.cal-semana-dia{min-height:44px;padding:4px 2px}.cal-semana-num{font-size:12px}.cal-semana-hora{font-size:8px}.cal-header-cell{font-size:9px}.cal-leyenda{gap:5px}.cal-leyenda-item{padding:2px 7px;font-size:10px}.btn-new{justify-content:center;width:100%}.field-row{grid-template-columns:1fr}}@media (width<=480px){.stats-row,.stats-bar{grid-template-columns:repeat(2,1fr)}.cal-grid-meses{grid-template-columns:1fr}.dash-stats{grid-template-columns:repeat(2,1fr)}}.btn-export{color:#fdfaf5;cursor:pointer;background:#2c2416;border:none;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:opacity .2s}.btn-export:hover{opacity:.8}.btn-export-csv{background:#4a7c59}.ip-info-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.ip-box{background:#f5f0e8;border:1px solid #d9cfc0;border-radius:10px;padding:12px 16px}.ip-label{color:#beb5a5;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:10px}.ip-val{color:#2c2416;font-family:monospace;font-size:14px;font-weight:500}
