*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface2: #22263a;--color-border: #2e3350;--color-text: #e8eaf6;--color-text-muted: #8891b4;--color-in: #22c55e;--color-in-bg: #052e16;--color-out: #ef4444;--color-out-bg: #2d0707;--color-accent: #6366f1;--color-accent-hover: #4f46e5;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .4)}html,body,#root{height:100%;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background-color:var(--color-bg);color:var(--color-text);font-size:15px;line-height:1.5}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,#1a1d3a 0%,#0f1117 70%);padding:1rem}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.5rem 2rem;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{font-size:2.5rem;display:block;margin-bottom:.75rem}.login-header h1{font-size:1.6rem;font-weight:700;color:var(--color-text);margin-bottom:.25rem}.login-header p{color:var(--color-text-muted);font-size:.875rem}.login-error{background:var(--color-out-bg);border:1px solid var(--color-out);color:#fca5a5;border-radius:var(--radius-sm);padding:.75rem 1rem;margin-bottom:1rem;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.form-group input{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.75rem 1rem;font-size:.95rem;transition:border-color .15s;outline:none}.form-group input:focus{border-color:var(--color-accent)}.btn-login{background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:.85rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;margin-top:.5rem}.btn-login:hover:not(:disabled){background:var(--color-accent-hover)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.presence-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.presence-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}.header-left{display:flex;align-items:center;gap:.5rem}.header-logo{font-size:1.4rem}.header-title{font-size:1.1rem;font-weight:700;color:var(--color-text)}.header-right{display:flex;align-items:center;gap:1rem}.header-user{display:flex;align-items:center;gap:.5rem}.header-username{font-weight:600;color:var(--color-text)}.header-badge{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:99px;padding:.15rem .6rem;font-size:.75rem;color:var(--color-text-muted);text-transform:capitalize}.btn-logout{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.4rem .9rem;font-size:.825rem;cursor:pointer;transition:color .15s,border-color .15s}.btn-logout:hover{color:var(--color-out);border-color:var(--color-out)}.presence-layout{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;max-width:1100px;margin:0 auto;padding:2rem 1.25rem;align-items:start}.presence-main{display:flex;flex-direction:column;gap:1.5rem}.clock-section{text-align:center;padding:2rem 1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.clock-date{font-size:1rem;color:var(--color-text-muted);text-transform:capitalize;letter-spacing:.03em;margin-bottom:.5rem}.clock-time{font-size:3.5rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--color-text);line-height:1;margin-bottom:.5rem}.clock-week{font-size:.8rem;color:var(--color-text-muted)}.alert-error{background:var(--color-out-bg);border:1px solid var(--color-out);color:#fca5a5;border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.875rem}.loading-state{text-align:center;color:var(--color-text-muted);padding:3rem}.status-section{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.status-badge{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:99px;font-weight:700;font-size:.9rem;letter-spacing:.08em}.status-badge.status-in{background:var(--color-in-bg);border:2px solid var(--color-in);color:var(--color-in)}.status-badge.status-out{background:var(--color-out-bg);border:2px solid var(--color-out);color:var(--color-out)}.status-dot{width:10px;height:10px;border-radius:50%;background:currentColor;animation:pulse 1.8s infinite}.status-in .status-dot{animation:pulse 1.8s infinite}.status-out .status-dot{animation:none;opacity:.5}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.daily-status-label{padding:.35rem .85rem;border-radius:99px;font-size:.8rem;font-weight:600;border:1px solid}.status-present{color:var(--color-in);border-color:var(--color-in);background:var(--color-in-bg)}.status-absent{color:var(--color-out);border-color:var(--color-out);background:var(--color-out-bg)}.status-partial{color:#f59e0b;border-color:#f59e0b;background:#2d1b00}.status-conge{color:#818cf8;border-color:#818cf8;background:#1e1b4b}.log-note-section{display:flex;flex-direction:column;gap:.375rem}.log-note-label{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.log-note-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.75rem 1rem;font-size:.9rem;resize:vertical;outline:none;transition:border-color .15s;font-family:inherit}.log-note-input:focus{border-color:var(--color-accent)}.action-section{display:flex;justify-content:center}.btn-checkin,.btn-checkout{width:100%;max-width:380px;padding:1.1rem 2rem;border:none;border-radius:var(--radius);font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .1s,opacity .15s;letter-spacing:.04em}.btn-checkin:active,.btn-checkout:active{transform:scale(.97)}.btn-checkin{background:var(--color-in);color:#fff}.btn-checkin:hover:not(:disabled){background:#16a34a}.btn-checkout{background:var(--color-out);color:#fff}.btn-checkout:hover:not(:disabled){background:#dc2626}.btn-checkin:disabled,.btn-checkout:disabled{opacity:.55;cursor:not-allowed}.manager-note-section{background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.3);border-radius:var(--radius);padding:1rem 1.25rem}.manager-note-label{font-size:.75rem;font-weight:700;color:#818cf8;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}.manager-note-text{color:var(--color-text);font-size:.9rem;line-height:1.6}.daily-note-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem}.daily-note-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.daily-note-header h3{font-size:.95rem;font-weight:600;color:var(--color-text)}.btn-edit-note{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.25rem .75rem;font-size:.8rem;cursor:pointer;transition:color .15s,border-color .15s}.btn-edit-note:hover{color:var(--color-accent);border-color:var(--color-accent)}.daily-note-text{color:var(--color-text);font-size:.9rem;line-height:1.6}.note-empty{color:var(--color-text-muted);font-style:italic}.daily-note-input{width:100%;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.75rem 1rem;font-size:.9rem;resize:vertical;outline:none;font-family:inherit;transition:border-color .15s}.daily-note-input:focus{border-color:var(--color-accent)}.daily-note-actions{display:flex;gap:.75rem;margin-top:.75rem}.btn-save-note{background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.btn-save-note:hover:not(:disabled){background:var(--color-accent-hover)}.btn-save-note:disabled{opacity:.5;cursor:not-allowed}.btn-cancel-note{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.5rem 1.25rem;font-size:.875rem;cursor:pointer;transition:color .15s}.btn-cancel-note:hover{color:var(--color-text)}.note-hint{font-size:.8rem;color:var(--color-text-muted);margin-top:.5rem}.logs-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem}.logs-section h3{font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:1rem}.logs-empty{color:var(--color-text-muted);font-size:.875rem;text-align:center;padding:1rem 0}.logs-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.log-item{display:flex;align-items:flex-start;justify-content:space-between;padding:.75rem 1rem;border-radius:var(--radius-sm);background:var(--color-surface2);border:1px solid var(--color-border);gap:1rem;flex-wrap:wrap}.log-item-left{display:flex;align-items:center;gap:.75rem}.log-type-badge{font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.2rem .6rem;border-radius:99px}.log-type-in{background:var(--color-in-bg);color:var(--color-in);border:1px solid var(--color-in)}.log-type-out{background:var(--color-out-bg);color:var(--color-out);border:1px solid var(--color-out)}.log-time{font-size:.9rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--color-text)}.log-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}.log-note{font-size:.825rem;color:var(--color-text-muted);font-style:italic;max-width:240px;text-align:right}.log-ip{font-size:.75rem;color:var(--color-border);font-variant-numeric:tabular-nums}@media (max-width: 768px){.presence-layout{grid-template-columns:1fr;padding:1rem .75rem}.week-panel{order:-1}}@media (max-width: 480px){.clock-time{font-size:2.5rem}.presence-header{padding:.75rem 1rem}.header-username{display:none}}.manager-layout{max-width:1800px;margin:0 auto;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1.5rem}.manager-top{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:1rem}.manager-title{font-size:1.4rem;font-weight:700;color:var(--color-text)}.manager-date{font-size:.875rem;color:var(--color-text-muted);margin-top:.2rem;text-transform:capitalize}.btn-refresh{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:color .15s}.btn-refresh:hover:not(:disabled){color:var(--color-text)}.btn-show-present{background:transparent;border:1px solid #334155;border-radius:var(--radius-sm);color:#94a3b8;padding:.25rem .75rem;font-size:.75rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-show-present:hover{background:#1e293b;color:#e2e8f0;border-color:#475569}.btn-manager-link{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.4rem .9rem;font-size:.825rem;text-decoration:none;transition:color .15s,border-color .15s}.btn-manager-link:hover{color:var(--color-accent);border-color:var(--color-accent)}.btn-manager-link--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;cursor:default;pointer-events:none}.general-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.general-section-title{font-size:1.05rem;font-weight:600;color:var(--color-text);margin-right:.6rem}.general-section-date{font-size:.82rem;color:var(--color-text-muted)}.bureau-chart-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem;max-width:1600px;margin-left:auto;margin-right:auto;width:100%}.bureau-chart-title{font-size:.82rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.bureau-chart-grid{display:flex;flex-direction:column;gap:.5rem}.bureau-chart-row{display:grid;grid-template-columns:48px 1fr 40px 52px;align-items:center;gap:.75rem}.bureau-chart-label{font-size:.8rem;font-weight:600;color:var(--color-text);text-align:right}.bureau-chart-bar-track{height:14px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden;display:flex}.bureau-chart-bar-seg{height:100%;transition:width .4s ease;min-width:0}.bureau-chart-pct{font-size:.8rem;font-weight:700;color:var(--color-text);text-align:right}.bureau-chart-detail{font-size:.75rem}.bureau-chart-legend{display:flex;gap:1rem;flex-wrap:wrap}.bureau-chart-legend-item{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--color-text-muted)}.bureau-chart-legend-item i{display:inline-block;width:10px;height:10px;border-radius:3px;font-style:normal}.bureaux-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;max-width:1600px;margin-left:auto;margin-right:auto}.bureau-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s,box-shadow .15s}.bureau-card--issues{border-color:#fb923c73}.bureau-card--expanded{box-shadow:0 0 0 2px #6366f159}.bureau-card-header{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s}.bureau-card-header:hover{background:var(--color-surface2)}.bureau-card-title{display:flex;align-items:baseline;gap:.4rem;flex:1;min-width:0}.bureau-card-name{font-size:1rem;font-weight:600;color:var(--color-text)}.bureau-card-id{font-size:.72rem;color:var(--color-text-muted)}.bureau-card-stats{display:flex;gap:.35rem;flex-wrap:wrap}.bstat{display:flex;align-items:center;gap:.2rem;padding:.2rem .45rem;border-radius:999px;font-size:.78rem;font-weight:600;border:1px solid transparent;cursor:pointer;background:none;font-family:inherit;transition:opacity .12s,box-shadow .12s}.bstat:hover{opacity:.8}.bstat--np{background:rgba(139,92,246,.15);color:#a78bfa;border-color:#8b5cf64d}.bstat--abs{background:rgba(239,68,68,.15);color:#f87171;border-color:#ef44444d}.bstat--ret{background:rgba(251,146,60,.15);color:#fb923c;border-color:#fb923c4d}.bstat--pres{background:rgba(34,197,94,.12);color:#4ade80;border-color:#22c55e4d;pointer-events:none}.bstat--conge{background:rgba(129,140,248,.12);color:#818cf8;border-color:#818cf84d;pointer-events:none}.bstat--zero{opacity:.3;pointer-events:none}.bstat--active{box-shadow:0 0 0 2px currentColor;opacity:1}.bstat-num{font-size:.85rem}.bstat-lbl{font-size:.7rem;font-weight:400}.bureau-card-total{font-size:.72rem;color:var(--color-text-muted)}.bureau-card-chevron{font-size:.7rem;color:var(--color-text-muted);flex-shrink:0}.bureau-card-body{border-top:1px solid var(--color-border);background:var(--color-surface2)}.bureau-full-table{display:grid;gap:0}.bureau-full-head,.bureau-full-row{display:grid;grid-template-columns:1.4fr 1.3fr 60px 1.5fr;gap:.5rem;align-items:start;padding:.45rem 1rem;font-size:.8rem}.bureau-full-head{background:rgba(255,255,255,.03);color:var(--color-text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border)}.bureau-full-head span,.bureau-full-row>div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.bureau-full-row>div:last-child{white-space:normal;word-break:break-word;overflow:visible;text-overflow:unset}.bureau-full-row{border-bottom:1px solid rgba(255,255,255,.04);color:var(--color-text)}.bureau-full-row:last-child{border-bottom:none}.bureau-full-row:hover{background:rgba(255,255,255,.03)}.manager-counters{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.counter-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.1rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}.counter-num{font-size:2rem;font-weight:800;font-variant-numeric:tabular-nums;line-height:1}.counter-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.counter-present .counter-num{color:var(--color-in)}.counter-num-total{font-size:.65em;opacity:.55}.counter-late .counter-num{color:#f59e0b}.counter-absent .counter-num{color:var(--color-out)}.counter-num-secondary{font-size:.65em;opacity:.7;color:#818cf8}.counter-waiting .counter-num{color:#f59e0b}.counter-total .counter-num{color:var(--color-accent)}.agents-table{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.agents-table-header{display:grid;grid-template-columns:1.5fr 1fr 1fr 2fr auto;gap:1rem;padding:.75rem 1.25rem;background:var(--color-surface2);border-bottom:1px solid var(--color-border);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.agents-empty{text-align:center;color:var(--color-text-muted);padding:3rem;font-size:.875rem}.agent-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 2fr auto;gap:1rem;align-items:center;padding:.9rem 1.25rem;border-bottom:1px solid var(--color-border);transition:background .1s}.agent-row:last-child{border-bottom:none}.agent-row:hover{background:var(--color-surface2)}.agent-info{display:flex;flex-direction:row;align-items:center;gap:.5rem}.agent-name{font-weight:600;color:var(--color-text);font-size:.9rem}.agent-profil{font-size:.72rem;color:var(--color-text-muted);background:rgba(255,255,255,.07);border-radius:4px;padding:1px 6px;font-weight:600;text-transform:uppercase}.agent-status-badge{display:inline-block;padding:.25rem .65rem;border-radius:99px;font-size:.75rem;font-weight:600;border:1px solid}.as-present{color:#22c55e;border-color:#22c55e;background:#052e16}.as-absent{color:#ef4444;border-color:#ef4444;background:#2d0707}.as-partial{color:#f59e0b;border-color:#f59e0b;background:#2d1b00}.as-conge{color:#818cf8;border-color:#818cf8;background:#1e1b4b}.as-none{color:var(--color-text-muted);border-color:var(--color-border);background:transparent}.action-badge{font-size:.75rem;font-weight:700;letter-spacing:.04em}.action-in{color:#22c55e}.action-out{color:#ef4444}.action-none{color:var(--color-text-muted);font-weight:400}.note-preview-text{font-size:.8rem;color:var(--color-text-muted);font-style:italic;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;cursor:default}.note-preview-empty{color:var(--color-border);font-size:.8rem}.agent-actions-col{display:flex;flex-direction:column;gap:.4rem}.btn-agent-edit,.btn-agent-rename{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.35rem .75rem;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.btn-agent-edit:hover{color:var(--color-accent);border-color:var(--color-accent)}.btn-agent-rename:hover{color:#f59e0b;border-color:#f59e0b}.rename-input{width:100%;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.6rem .75rem;font-size:.9rem;outline:none;transition:border-color .15s}.rename-input:focus{border-color:var(--color-accent)}.modal-box--sm{max-width:380px}.agent-map-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.agent-map-search{flex:1;min-width:180px;max-width:320px}.agent-map-filters{display:flex;gap:.4rem}.filter-btn{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.35rem .85rem;font-size:.82rem;cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap}.filter-btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.filter-btn:not(.filter-btn--active):hover{color:var(--color-accent);border-color:var(--color-accent)}.agent-map-count{font-size:.82rem;color:var(--color-text-muted);margin-bottom:.5rem}.agents-table-header--map,.agent-row--map{grid-template-columns:2fr 2fr 80px 1fr 1fr 1fr}.agent-id-sub{font-size:.75rem;color:var(--color-text-muted);display:block}.nom-presence-value{color:var(--color-accent);font-size:.88rem;font-weight:500}.agent-active-badge{font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:99px;border:1px solid;white-space:nowrap}.agent-active-badge--on{background:#22c55e22;color:#22c55e;border-color:#22c55e55}.agent-active-badge--off{background:#6b728022;color:#6b7280;border-color:#6b728055}.btn-agent-toggle{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.3rem .65rem;font-size:.78rem;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.btn-agent-toggle--off{color:#ef4444;border-color:#ef444455}.btn-agent-toggle--off:hover{background:#ef444415}.btn-agent-toggle--on{color:#22c55e;border-color:#22c55e55}.btn-agent-toggle--on:hover{background:#22c55e15}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:480px;display:flex;flex-direction:column;gap:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h3{font-size:1rem;font-weight:700;color:var(--color-text)}.modal-agent-name{color:var(--color-accent)}.modal-close{background:transparent;border:none;color:var(--color-text-muted);font-size:1rem;cursor:pointer;padding:.25rem;transition:color .15s}.modal-close:hover{color:var(--color-text)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.status-pills{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.25rem}.status-pill{background:transparent;border:1px solid var(--color-border);border-radius:99px;color:var(--color-text-muted);padding:.35rem .9rem;font-size:.825rem;cursor:pointer;transition:all .15s}.status-pill:hover{border-color:var(--pill-color, var(--color-accent));color:var(--pill-color, var(--color-accent))}.status-pill--active{background:color-mix(in srgb,var(--pill-color, var(--color-accent)) 15%,transparent);border-color:var(--pill-color, var(--color-accent));color:var(--pill-color, var(--color-accent));font-weight:600}.modal-footer{display:flex;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid var(--color-border)}@media (max-width: 768px){.manager-counters{grid-template-columns:repeat(2,1fr)}.agents-table-header{display:none}.agent-row{grid-template-columns:1fr;gap:.5rem}}.date-nav{display:flex;align-items:center;gap:.75rem}.date-nav-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);width:36px;height:36px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s}.date-nav-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.date-nav-btn:disabled{opacity:.3;cursor:not-allowed}.date-nav-center{display:flex;align-items:center;gap:.75rem}.date-nav-label{font-size:1rem;font-weight:700;color:var(--color-text);text-transform:capitalize;min-width:200px}.date-nav-today{background:transparent;border:1px solid var(--color-accent);border-radius:99px;color:var(--color-accent);padding:.2rem .7rem;font-size:.75rem;cursor:pointer;transition:background .15s}.date-nav-today:hover{background:rgba(99,102,241,.1)}.manager-top-right{display:flex;align-items:center;gap:.5rem}.date-picker{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.45rem .75rem;font-size:.875rem;outline:none;cursor:pointer}.date-picker:focus{border-color:var(--color-accent)}.agent-action-col{display:flex;flex-direction:column;gap:.3rem;align-items:flex-start}.btn-show-logs{background:transparent;border:none;color:var(--color-text-muted);font-size:.75rem;cursor:pointer;padding:0;transition:color .15s}.btn-show-logs:hover{color:var(--color-accent)}.agent-logs-expanded{grid-column:1 / -1;background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:.75rem 1.5rem .75rem 2.5rem;display:flex;flex-direction:column;gap:.4rem}.log-mini{display:flex;align-items:center;gap:.75rem;font-size:.825rem;flex-wrap:wrap}.log-mini-note{color:var(--color-text-muted);font-style:italic}.modal-date-sub{font-size:.75rem;color:var(--color-text-muted);font-weight:400;margin-left:.5rem;text-transform:capitalize}.week-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem;position:sticky;top:80px}.week-panel-header{margin-bottom:1.25rem}.week-panel-header h2{font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:.2rem}.week-range{font-size:.78rem;color:var(--color-text-muted)}.week-loading{text-align:center;color:var(--color-text-muted);font-size:.875rem;padding:1.5rem 0}.week-list{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}.week-day{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-sm);background:var(--color-surface2);border:1px solid transparent;transition:border-color .15s;overflow:hidden}.week-day--today{border-color:var(--color-accent);background:rgba(99,102,241,.08)}.week-day-left{display:flex;align-items:center;gap:.4rem}.week-day-name{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;width:26px}.week-day--today .week-day-name{color:var(--color-accent)}.week-day-num{font-size:.875rem;font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums}.week-day-center{display:flex;align-items:center;gap:.4rem}.week-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ws-present{background:var(--color-in)}.ws-absent{background:var(--color-out)}.ws-partial{background:#f59e0b}.ws-conge{background:#818cf8}.week-status-text{font-size:.8rem;font-weight:500}.ws-text-present{color:var(--color-in)}.ws-text-absent{color:var(--color-out)}.ws-text-partial{color:#f59e0b}.ws-text-conge{color:#818cf8}.week-status-future,.week-status-missing{font-size:.78rem;color:var(--color-border)}.week-day-right{text-align:right;font-size:.8rem}.week-day-note{cursor:default;opacity:.7}.week-summary{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;border-top:1px solid var(--color-border);padding-top:1rem}.week-summary-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--color-text-muted)}.ws-count{font-size:1.1rem;font-weight:700;font-variant-numeric:tabular-nums;min-width:20px;text-align:center}.ws-count-present{color:var(--color-in)}.ws-count-absent{color:var(--color-out)}.ws-count-conge{color:#818cf8}.ws-count-partial{color:#f59e0b}.overview-toolbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem}.threshold-control,.bureau-select-control{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--color-text-muted)}.bureau-select{background:#1a1d2e;border:1px solid var(--color-accent);border-radius:var(--radius-sm);color:var(--color-text);padding:.3rem 1.6rem .3rem .6rem;font-size:.82rem;outline:none;cursor:pointer;min-width:110px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236366f1'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .55rem center;color-scheme:dark}.bureau-select option{background:#1a1d2e;color:#e2e8f0}.bureau-select option:checked,.bureau-select option:hover{background:#312e81;color:#fff}.bureau-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px #6366f140}.bureau-name-badge{display:inline-block;background:rgba(99,102,241,.12);color:#818cf8;border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-sm);padding:.15rem .5rem;font-size:.75rem;font-weight:600;letter-spacing:.04em}.overview-search{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.3rem .6rem;font-size:.82rem;outline:none;min-width:180px}.overview-search:focus{border-color:var(--color-accent)}.filter-group{display:flex;gap:.25rem}.profil-cell{display:flex;align-items:center;gap:.3rem}.profil-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#1a1d2e;color:var(--color-text);padding:.2rem .5rem;font-size:.78rem;font-weight:600;cursor:pointer;outline:none;color-scheme:dark;min-width:58px;text-align:center;transition:border-color .15s,background .15s}.profil-select:hover{border-color:var(--color-accent)}.profil-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px #6366f133}.profil-select:disabled{opacity:.5;cursor:wait}.profil-select option{background:#1a1d2e;color:#e2e8f0}.profil-select--ret{border-color:#f59e0b;color:#fbbf24}.profil-select--sup{border-color:#6366f1;color:#a5b4fc}.profil-select--man{border-color:#22c55e;color:#4ade80}.profil-select--cm{border-color:#06b6d4;color:#67e8f9}.profil-select--none{border-color:var(--color-border);color:var(--color-text-muted)}.profil-saving{font-size:1rem;color:var(--color-text-muted);animation:pulse .8s ease-in-out infinite}.alerts-section{background:var(--color-surface2);border:1px solid rgba(239,68,68,.18);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1rem}.alerts-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.85rem}.alerts-section-title{font-size:.92rem;font-weight:700;color:var(--color-text);flex:1}.alerts-section-date{font-size:.78rem;color:var(--color-text-muted)}.alerts-counters{display:flex;gap:.65rem;margin-bottom:1rem}.alert-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:.55rem .4rem;border-radius:var(--radius-sm);background:var(--color-bg);border:1px solid var(--color-border);gap:.15rem}.alert-stat-num{font-size:1.4rem;font-weight:700;line-height:1}.alert-stat-label{font-size:.68rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.alert-stat--non-pointe{border-color:#9ca3af4d}.alert-stat--non-pointe .alert-stat-num{color:#9ca3af}.alert-stat--absent{border-color:#ef444459}.alert-stat--absent .alert-stat-num{color:#ef4444}.alert-stat--retard{border-color:#f59e0b59}.alert-stat--retard .alert-stat-num{color:#f59e0b}.alerts-table-head,.alerts-table-row{display:grid;grid-template-columns:2fr 120px 1fr 72px;align-items:center;gap:.6rem;padding:.45rem .5rem;font-size:.82rem}.alerts-table--admin .alerts-table-head,.alerts-table--admin .alerts-table-row{grid-template-columns:72px 2fr 120px 1fr 72px}.alerts-table-head{color:var(--color-text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);padding-bottom:.35rem;margin-bottom:.1rem}.alerts-table-row{border-bottom:1px solid rgba(255,255,255,.04);border-radius:var(--radius-sm);transition:background .1s}.alerts-table-row:last-child{border-bottom:none}.alerts-table-row:hover{background:rgba(255,255,255,.03)}.agent-info-full{display:flex;flex-direction:column;gap:.1rem;min-width:0}.agent-info-line{display:flex;align-items:center;gap:.4rem}.profil-tag{display:inline-block;border:none;background:transparent;padding:0;font-size:.68rem;font-weight:700;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.profil-tag--ret,.profil-tag--agent{color:#94a3b8}.profil-tag--sup,.profil-tag--support{color:#a5b4fc}.profil-tag--man,.profil-tag--manager{color:#4ade80}.profil-tag--cm,.profil-tag--crm_manager{color:#67e8f9}.alerts-status-badge{display:inline-block;border:1px solid;border-radius:var(--radius-sm);padding:.12rem .45rem;font-size:.73rem;font-weight:600;white-space:nowrap}.alerts-note-text{font-size:.78rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alerts-time{font-size:.78rem;color:var(--color-text-muted);white-space:nowrap}.alerts-empty{text-align:center;color:#22c55e;font-size:.85rem;padding:.75rem 0 .25rem}.alerts-bureaux{display:flex;flex-direction:column;gap:.75rem;margin-top:.25rem}.alerts-bureau-block{border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.alerts-bureau-header{display:flex;align-items:center;gap:.65rem;padding:.45rem .75rem;background:rgba(255,255,255,.04);border-bottom:1px solid var(--color-border)}.alerts-bureau-name{font-size:.82rem;font-weight:700;color:var(--color-text);letter-spacing:.03em;flex-shrink:0}.alerts-bureau-mini-stats{display:flex;gap:.4rem;flex-wrap:wrap}.alerts-mini-stat{display:inline-block;border:1px solid;border-radius:var(--radius-sm);padding:.08rem .4rem;font-size:.7rem;font-weight:600;white-space:nowrap}.alerts-mini-stat--absent{color:#ef4444;border-color:#ef444444;background:#ef444415}.alerts-mini-stat--retard{color:#f59e0b;border-color:#f59e0b44;background:#f59e0b15}.alerts-mini-stat--np{color:#9ca3af;border-color:#9ca3af44;background:transparent}.alerts-bureau-block .alerts-table-head,.alerts-bureau-block .alerts-table-row{grid-template-columns:2fr 110px 1fr 68px;padding:.38rem .75rem}.threshold-input{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.3rem .5rem;font-size:.82rem;outline:none;width:90px}.threshold-input:focus{border-color:var(--color-accent)}.overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.overview-card{display:flex;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:box-shadow .15s}.overview-card--issue{border-color:color-mix(in srgb,var(--card-color) 40%,var(--color-border))}.overview-card-bar{width:4px;flex-shrink:0;background:var(--card-color, var(--color-border))}.overview-card-body{flex:1;padding:.75rem .9rem;display:flex;flex-direction:column;gap:.4rem}.overview-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.overview-agent-name{font-weight:600;font-size:.9rem;color:var(--color-text)}.overview-status-badge{font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:99px;border:1px solid;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.03em}.overview-card-mid{font-size:.82rem}.overview-checkin-time{color:var(--color-text-muted);display:flex;align-items:center;gap:.4rem}.overview-checkin-late{color:#fb923c;font-weight:600}.late-flag{font-size:.68rem;background:#fb923c22;color:#fb923c;border:1px solid #fb923c55;border-radius:99px;padding:.1rem .4rem;font-weight:700;letter-spacing:.05em}.overview-no-checkin{color:var(--color-text-muted);font-style:italic;font-size:.8rem}.overview-note{display:flex;align-items:flex-start;gap:.35rem;background:var(--color-surface-2);border-radius:var(--radius-sm);padding:.4rem .6rem;margin-top:.2rem}.overview-note-icon{font-size:.82rem;flex-shrink:0}.overview-note-text{font-size:.8rem;color:var(--color-text-muted);line-height:1.4}.overview-note-empty{font-size:.78rem;color:var(--color-text-muted);font-style:italic;opacity:.6}.panel-tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:.75rem}.panel-tab{flex:1;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);padding:.5rem 0;font-size:.82rem;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.panel-tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.month-nav-label{font-size:.9rem;font-weight:600;color:var(--color-text);text-transform:capitalize}.month-summary{display:flex;gap:.5rem;margin-bottom:.75rem}.month-stat{flex:1;background:var(--color-surface-2);border-radius:var(--radius-sm);padding:.5rem .4rem;text-align:center}.month-stat-num{display:block;font-size:1.3rem;font-weight:700;line-height:1}.month-stat-label{font-size:.68rem;color:var(--color-text-muted);margin-top:.2rem;display:block}.month-day-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem}.month-day-item{background:var(--color-surface-2);border-radius:var(--radius-sm);overflow:hidden}.month-day-header{width:100%;display:flex;align-items:center;justify-content:space-between;background:transparent;border:none;padding:.45rem .65rem;cursor:pointer;color:var(--color-text);text-align:left}.month-day-left{display:flex;align-items:center;gap:.4rem}.month-day-date{font-size:.8rem;font-weight:600;min-width:46px}.month-day-right{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--color-text-muted)}.month-day-logs-count{font-size:.72rem;color:var(--color-text-muted)}.month-day-chevron{font-size:.65rem;color:var(--color-text-muted)}.month-day-note{font-size:.78rem;color:var(--color-text-muted);padding:.3rem .65rem .4rem;border-top:1px solid var(--color-border);font-style:italic}.month-logs-list{list-style:none;padding:.3rem .65rem .5rem;margin:0;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.2rem}.month-log{display:flex;align-items:center;gap:.4rem;font-size:.78rem}.week-live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#22c55e;margin-left:4px;vertical-align:middle;animation:pulse-live 1.5s ease-in-out infinite}@keyframes pulse-live{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.week-day-center{display:flex;align-items:center;gap:.35rem;overflow:hidden;white-space:nowrap;min-width:0}.week-time{font-size:.72rem;font-weight:500;white-space:nowrap;flex-shrink:0}.week-time-in{color:#22c55e}.week-time-out{color:#94a3b8}.month-day-inline-times{display:flex;gap:.4rem;align-items:center;flex-wrap:nowrap;overflow:hidden;white-space:nowrap;flex-shrink:1;min-width:0}
