*{scroll-behavior:smooth}.rdrDateDisplayWrapper{background-color:#fff!important}:root{--brand:#2d6bff;--brand-600:#2256da;--brand-50:#eef3ff;--bg:#f7f8fa;--surface:#fff;--surface-2:#fbfbfc;--surface-3:#7746465e;--border:#eceef2;--border-strong:#e1e4ea;--hover:#f4f5f8;--text:#0e1525;--text-2:#3c4659;--muted:#697384;--muted-2:#94a0b2;--green:#10b981;--green-bg:#e6f8f0;--green-text:#0a5c40;--amber:#f59e0b;--amber-bg:#fef4e2;--amber-text:#7a5a04;--red:#ef4444;--red-bg:#fdecec;--red-text:#9a2a2a;--blue-bg:#eef3ff;--blue-text:#1a4ed0;--gray-bg:#f4f5f8;--gray-text:#3c4659;--shadow-sm:0 1px 1px #0f172a0a,0 1px 2px #0f172a0a;--shadow:0 1px 2px #0f172a0a,0 4px 20px #0f172a0f;--radius:14px;--radius-sm:10px;--sidebar-w:252px}html[data-theme=dark]{--bg:#0b0d12;--surface:#11141b;--surface-2:#0e1117;--surface-3:#7746465e;--border:#1b202b;--border-strong:#252b38;--hover:#161a22;--text:#eceff5;--text-2:#bfc6d3;--muted:#8a93a3;--muted-2:#5c6577;--brand-50:#172346;--green-bg:#0e2a20;--green-text:#34d399;--amber-bg:#2e2412;--amber-text:#fcd34d;--red-bg:#2c1717;--red-text:#f87171;--blue-bg:#172346;--blue-text:#93bbfd;--gray-bg:#1b202b;--gray-text:#bfc6d3;--shadow:0 1px 2px #00000080,0 8px 28px #0006}body{background:#f7f8fa;color:#0e1525}.app{grid-template-columns:252px 1fr}.sidebar{background:#fff;border-right:1px solid #eceef2}.brand-mark{background:#2d6bff;box-shadow:0 4px 14px -4px #2d6bff8c}.brand-name span{color:#2d6bff}.brand-sub,.nav-sect{color:#94a0b2}.nav-item{color:#3c4659;position:relative}.nav-item:hover{background:#f4f5f8;color:#0e1525}.nav-item.active{background:#eef3ff;color:#2d6bff}.nav-item.active .ni{color:#2d6bff}.ni{color:#697384}.nav-badge{background:#ef4444;background:var(--red);border-radius:999px;color:#fff;font-size:10.5px;font-weight:700;margin-left:auto;padding:1px 6px}.sidebar-foot{border-top:1px solid #eceef2}.admin-row:hover{background:#f4f5f8}.admin-info span{color:#697384}.topbar{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#f7f8fae0;border-bottom:1px solid #eceef2}html[data-theme=dark] .topbar{background:#f7f8fa;background:var(--bg)}.topbar-sub{color:#697384}.icon-btn{color:#3c4659;position:relative;transition:background .12s,color .12s}.icon-btn:hover{background:#f4f5f8;border-color:#eceef2;color:#0e1525}.icon-btn .notif-dot{border:2px solid #f7f8fa;border:2px solid var(--bg);border-radius:50%;height:7px;right:7px;top:7px;width:7px}.icon-btn .notif-count,.icon-btn .notif-dot{background:#ef4444;background:var(--red);position:absolute}.icon-btn .notif-count{border:2px solid #f7f8fa;border:2px solid var(--bg);border-radius:9px;color:#fff;display:grid;font-size:10px;font-weight:700;height:17px;min-width:17px;padding:0 4px;place-items:center;right:0;top:3px}.theme-toggle{align-items:center;background:#fff;background:var(--surface);border:1px solid #eceef2;border:1px solid var(--border);border-radius:10px;color:#3c4659;color:var(--text-2);display:inline-flex;font-size:13px;font-weight:500;gap:7px;height:34px;padding:0 12px;transition:background .12s}.theme-toggle:hover{background:#f4f5f8;background:var(--hover)}.theme-toggle svg{height:15px;width:15px}.page-head{display:none!important}.page-head .sub{color:#697384}.btn{transition:background .12s,box-shadow .12s}.btn-ghost{background:#fff;border:1px solid #eceef2;color:#3c4659}.btn-ghost:hover{background:#f4f5f8;color:#0e1525}.btn-brand{background:#2d6bff;box-shadow:0 2px 8px -2px #2d6bff66}.btn-brand:hover{background:#2256da;box-shadow:0 4px 14px -4px #2d6bff80}.kpis{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr)}.kpi{background:#fff;background:var(--surface);border:1px solid #eceef2;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 1px #0f172a0a,0 1px 2px #0f172a0a;box-shadow:var(--shadow-sm);cursor:default;overflow:hidden;padding:18px 20px 16px;position:relative;transition:border-color .15s,box-shadow .15s}.kpi:hover{border-color:#e1e4ea;border-color:var(--border-strong);box-shadow:0 1px 2px #0f172a0a,0 4px 20px #0f172a0f;box-shadow:var(--shadow)}.kpi-stripe{border-radius:14px 14px 0 0;border-radius:var(--radius) var(--radius) 0 0;height:3px;left:0;position:absolute;right:0;top:0}.kpi-head{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.kpi-label{color:#697384;color:var(--muted);font-size:11.5px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.kpi-icon{height:32px;width:32px}.kpi-value{font-feature-settings:"tnum";font-size:30px;font-weight:700;letter-spacing:-.025em;line-height:1}.kpi-footer{align-items:center;color:#697384;color:var(--muted);display:flex;font-size:12px;gap:7px;margin-top:8px}.kpi-chip{border-radius:6px;display:inline-flex;font-size:11px;font-weight:700;gap:3px;padding:2px 8px}.kpi-chip.up{background:#e6f8f0;background:var(--green-bg);color:#0a5c40;color:var(--green-text)}.kpi-chip.warn{background:#fef4e2;background:var(--amber-bg);color:#7a5a04;color:var(--amber-text)}.kpi-chip.miss{background:#fdecec;background:var(--red-bg);color:#9a2a2a;color:var(--red-text)}.kpi-chip svg{height:10px;width:10px}.alert-strip{align-items:center;background:#fef4e2;background:var(--amber-bg);border:1px solid #f59e0b38;border-radius:10px;border-radius:var(--radius-sm);display:flex;gap:8px;padding:11px 18px}.alert-strip .icon{color:#f59e0b;color:var(--amber);display:inline-flex;flex-shrink:0}.alert-strip .icon svg{height:16px;width:16px}.alert-strip .text{color:#7a5a04;color:var(--amber-text);flex:1 1;font-size:13px;font-weight:500}.alert-strip .text strong{font-weight:700}.alert-strip .av-pile{display:flex;margin-left:auto}.alert-strip .av-pile .av-sm{border:2.5px solid #fef4e2;border:2.5px solid var(--amber-bg);border-radius:50%;color:#fff;display:grid;font-size:10px;font-weight:600;height:27px;margin-left:-9px;place-items:center;width:27px}.alert-strip .av-pile .av-sm:first-child{margin-left:0}.av-more{background:#0000001a;border:2.5px solid #fef4e2;border:2.5px solid var(--amber-bg);border-radius:50%;display:grid;font-size:10px;font-weight:700;height:27px;margin-left:-9px;place-items:center;width:27px}.alert-strip .see-link,.av-more{color:#7a5a04;color:var(--amber-text)}.alert-strip .see-link{border-bottom:1px solid #7850044d;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:600;margin-left:14px;white-space:nowrap}.two-col{grid-gap:18px;align-items:start;display:grid;gap:18px;grid-template-columns:1fr 308px}.card{background:#fff;border:1px solid #eceef2;border-radius:14px;box-shadow:0 1px 1px #0f172a0a,0 1px 2px #0f172a0a}.card-head{border-bottom:1px solid #eceef2}.card-head h2{letter-spacing:-.005em}.card-head .log-count{color:#697384;color:var(--muted);font-size:12px}.tbl thead th{background:#fbfbfc;color:#697384}.tbl tbody td,.tbl thead th{border-bottom:1px solid #eceef2}.tbl tbody tr:hover td{background:#f4f5f8}.tbl tbody tr.row-ok td{background:#10b98105}.tbl tbody tr.row-ok:hover td{background:#10b9810d}.tbl tbody tr.row-warn:hover td{background:#f59e0b0f}.tbl tbody tr.row-warn td:first-child{box-shadow:inset 3px 0 0 #f59e0b}.tbl tbody tr.row-absent:hover td{background:rgba(239,68,68,.055)}.tbl tbody tr.row-absent td:first-child{box-shadow:inset 3px 0 0 #ef4444}.mem-cell,.mem-info{min-width:0}.mem-info b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mem-info span{color:#697384}.tc.in svg{color:#10b981}.tc.out svg{color:#ef4444}.tc.dash{color:#94a0b2}.hours-badge.ok{background:#e6f8f0;color:#0a5c40}.hours-badge.none{background:#f4f5f8;color:#94a0b2}.type-badge.remote{background:#eef3ff;color:#1a4ed0}.type-badge.office{background:#f4f5f8;color:#3c4659}.absent-tag{background:#fdecec;color:#9a2a2a}.act{color:#697384;transition:background .1s,color .1s,border-color .1s}.act:hover{background:#f4f5f8;border-color:#eceef2;color:#3c4659}.act.del:hover{background:#fdecec;color:#ef4444}.tbl-foot{border-top:1px solid #eceef2;color:#697384}.pager button{background:#fff;border:1px solid #eceef2;color:#3c4659}.pager button:hover:not(:disabled){background:#f4f5f8}.pager button.on{background:#2d6bff;border-color:#2d6bff}.side-stack{display:flex;flex-direction:column;gap:14px}.sc{background:#fff;background:var(--surface);border:1px solid #eceef2;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 1px #0f172a0a,0 1px 2px #0f172a0a;box-shadow:var(--shadow-sm);overflow:hidden}.sc-head{align-items:center;border-bottom:1px solid #eceef2;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:13px 16px 11px}.sc-head h3{font-size:13px;font-weight:600;margin:0}.sc-count{border-radius:6px;font-size:11px;font-weight:700;padding:2px 8px}.sc-count.amber{background:#fef4e2;background:var(--amber-bg);color:#7a5a04;color:var(--amber-text)}.sc-count.red{background:#fdecec;background:var(--red-bg);color:#9a2a2a;color:var(--red-text)}.late-grid{display:flex;flex-wrap:wrap;gap:8px;padding:14px 16px}.late-av{border-radius:50%;color:#fff;cursor:pointer;display:grid;font-size:11.5px;font-weight:600;height:36px;place-items:center;position:relative;transition:transform .12s;width:36px}.late-av:hover{transform:scale(1.1)}.late-av:after{border:2px solid #f59e0b;border:2px solid var(--amber);border-radius:50%;content:"";inset:-2.5px;opacity:.8;position:absolute}.absent-row{align-items:center;border-bottom:1px solid #eceef2;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:10px;padding:11px 16px;transition:background .1s}.absent-row:last-child{border-bottom:none}.absent-row:hover{background:#f4f5f8;background:var(--hover)}.absent-row .info{flex:1 1;min-width:0}.absent-row .info b{display:block;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.absent-row .info span{color:#697384;color:var(--muted);font-size:11.5px}.absent-row .chev{color:#94a0b2;color:var(--muted-2);flex-shrink:0}.absent-row .chev svg{height:14px;width:14px}@media(max-width:1280px){.kpis{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr 280px}}@media(max-width:960px){:root{--sidebar-w:0px}.sidebar{display:none}.two-col{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.kpis{grid-template-columns:1fr 1fr}.content{padding:16px 14px 40px}}.side-col{display:flex;flex-direction:column;gap:20px}.card-pad{padding:18px}.card-pad h2{font-size:14px;font-weight:700}.bar-row{align-items:center;display:flex;gap:10px;margin-bottom:12px}.bar-row:last-child{margin-bottom:0}.bar-label{align-items:center;color:#3c4659;color:var(--text-2);display:flex;font-size:12.5px;gap:6px;width:92px}.bar-label .ni{height:14px;width:14px}.bar-track{background:#f4f5f8;background:var(--gray-bg);border-radius:999px;flex:1 1;height:8px;overflow:hidden}.bar-fill{border-radius:999px;height:100%;transition:width .4s ease}.bar-val{color:#0e1525;color:var(--text);font-size:13px;font-weight:600;text-align:right;width:28px}.nav-item-btn{background:none;border:none;cursor:pointer;font:inherit;text-align:left;width:100%}.frm-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.frm-field label{color:#3c4659;color:var(--text-2);font-size:12.5px;font-weight:600}.frm-field input{background:#fff;background:var(--surface);border:1px solid #e1e4ea;border:1px solid var(--border-strong);border-radius:10px;border-radius:var(--radius-sm);color:#0e1525;color:var(--text);font:400 14px var(--font);height:42px;padding:0 12px}.frm-field input:focus{border-color:#2d6bff;border-color:var(--brand);outline:2px solid #2d6bff;outline:2px solid var(--brand);outline-offset:1px}.frm-err{color:#ef4444;color:var(--red);font-size:12px}.settings-wrap{margin:8px auto;width:440px}.settings-head{padding:8px 0 4px;text-align:center}.settings-head .av{margin:0 auto 10px}.inline-time{background:#fff;background:var(--surface);border:1px solid #e1e4ea;border:1px solid var(--border-strong);border-radius:8px;color:#0e1525;color:var(--text);font:500 12.5px var(--font);height:32px;padding:0 8px}.inline-time:focus{outline:2px solid #2d6bff;outline:2px solid var(--brand);outline-offset:1px}.btn-sm{font-size:12px;padding:0 10px}.acts .btn-sm{gap:4px}.btn-primary{background:#2d6bff;background:var(--brand);border-color:#2d6bff;border-color:var(--brand);color:#fff}.btn-primary:hover{background:#2256da;background:var(--brand-600)}.btn-danger{background:#ef4444;background:var(--red);border-color:#ef4444;border-color:var(--red);color:#fff}.pager{align-items:center;gap:6px}.pager-btn{background:#fff;background:var(--surface);border:1px solid #eceef2;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#0e1525;color:var(--text);cursor:pointer;font:600 13px var(--font);height:34px;min-width:34px;padding:0 10px}.pager-btn:hover:not(:disabled){background:#f4f5f8;background:var(--hover)}.pager-btn.on{background:#2d6bff;background:var(--brand);border-color:#2d6bff;border-color:var(--brand);color:#fff}.pager-btn:disabled{cursor:not-allowed;opacity:.45}.modal-overlay{align-items:center;background:#0206178c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:200}.modal-card{background:#fff;background:var(--surface);border:1px solid #eceef2;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 2px #0f172a0a,0 4px 20px #0f172a0f;box-shadow:var(--shadow);max-width:420px;padding:22px;width:100%}.modal-card h3{font-size:16px;font-weight:700;margin-bottom:16px;text-align:center}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:6px}.confirm-icon{background:#fdecec;background:var(--red-bg);border-radius:50%;display:grid;height:46px;margin:0 auto 12px;place-items:center;width:46px}.confirm-icon svg{color:#ef4444;color:var(--red);height:20px;width:20px}.confirm-msg{color:#697384;color:var(--muted);font-size:13.5px;margin:-6px 0 18px}.App,.confirm-msg{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}body{font-size:14px}button,input{cursor:pointer;font-family:inherit}.shell{grid-gap:16px;display:grid;gap:16px;grid-template-columns:440px 1fr;min-height:100vh}.left{background:#0e1525;display:flex;flex-direction:column;overflow:hidden;padding:36px 40px 40px;position:relative}.left:before{background:radial-gradient(circle,#2d6bff38 0,#0000 70%);bottom:-120px;height:480px;right:-160px;width:480px}.left:after,.left:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.left:after{background:radial-gradient(circle,#2d6bff24 0,#0000 70%);height:260px;left:-80px;top:100px;width:260px}.left-texture{background-image:radial-gradient(circle,#ffffff0f 1px,#0000 0);background-size:28px 28px;inset:0;pointer-events:none;position:absolute}.logo{align-items:center;display:flex;gap:10px;position:relative;z-index:1}.logo-mark{background:var(--brand);border-radius:10px;box-shadow:0 4px 16px -4px #2d6bff99;display:grid;height:36px;place-items:center;width:36px}.logo-mark svg{color:#fff;height:18px;width:18px}.logo-name{color:#fff;font-size:16px;font-weight:700;letter-spacing:-.01em}.logo-name span{color:#fff6;font-weight:400}.hero{margin-top:auto;position:relative;z-index:1}.hero-tag{align-items:center;background:#2d6bff2e;border:1px solid #2d6bff4d;border-radius:999px;color:#93bbfd;display:inline-flex;font-size:11.5px;font-weight:600;gap:6px;letter-spacing:.02em;margin-bottom:20px;padding:4px 12px;text-transform:uppercase}.hero-tag i{animation:pulse 2s ease-in-out infinite;background:#2d6bff;border-radius:50%;box-shadow:0 0 6px 2px #2d6bffb3;flex-shrink:0;height:6px;width:6px}.hero h1{color:#fff;font-size:34px;font-weight:700;letter-spacing:-.025em;line-height:1.18;margin:0 0 16px}.hero h1 em{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#93bbfd,#7c5cff);-webkit-background-clip:text;background-clip:text;font-style:normal}.hero p{color:#ffffff80;font-size:14px;line-height:1.75;margin:0 0 32px;max-width:340px}.av-row{align-items:center;display:flex;gap:0;margin-bottom:28px}.av-row .av{border:2.5px solid #0e1525;border-radius:50%;color:#fff;display:grid;flex-shrink:0;font-size:11px;font-weight:600;height:34px;margin-left:-10px;place-items:center;width:34px}.av-row .av:first-child{margin-left:0}.av-row .av-label{color:#ffffff73;font-size:12.5px;line-height:1.4;margin-left:14px}.av-row .av-label b{color:#fffc;display:block;font-weight:600}.stats{background:#ffffff0a;border:1px solid #ffffff14;border-radius:var(--radius-sm);display:flex;gap:0;overflow:hidden}.stat{border-right:1px solid #ffffff14;flex:1 1;padding:14px 16px;position:relative}.stat:last-child{border-right:none}.stat-n{font-feature-settings:"tnum";color:#fff;font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1;margin-bottom:4px}.stat-n .unit{color:#fff6;font-size:14px;font-weight:500;margin-left:2px}.stat-l{color:#ffffff59;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.stat-dot{border-radius:50%;height:7px;position:absolute;right:14px;top:14px;width:7px}.stat-dot.green{background:var(--green);box-shadow:0 0 6px 1px #10b98180}.stat-dot.amber{background:var(--amber)}.stat-dot.red{background:var(--red)}.left-foot{align-items:center;color:#fff3;display:flex;font-size:11.5px;gap:6px;margin-top:28px;position:relative;z-index:1}.left-foot svg{color:#fff3;height:12px;width:12px}.right{align-items:center;background:#0000;border-radius:0;display:flex;justify-content:center;padding:0}.form-card{max-width:480px;width:100%}.form-head{margin-bottom:32px}.form-head h2{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:0 0 6px}.form-head p{color:var(--muted);font-size:14px;margin:0}.form-body{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 26px 24px}.frow{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.frow:last-of-type{margin-bottom:0}.frow label{color:var(--text-2);font-size:12.5px;font-weight:600}.frow input{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;height:44px;outline:none;padding:0 14px;transition:border-color .15s,box-shadow .15s,background .15s}.frow input:focus{background:var(--surface);border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-50)}.frow input::placeholder{color:var(--muted-2)}.pw-wrap{position:relative}.pw-wrap input{padding-right:44px;width:100%}.pw-toggle{background:none;border:none;border-radius:6px;color:var(--muted-2);display:grid;padding:4px;place-items:center;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .12s}.pw-toggle:hover{color:var(--text-2)}.pw-toggle svg{height:16px;width:16px}.frow-top{align-items:baseline;display:flex;justify-content:space-between}.forgot{background:none;border:none;color:var(--brand);cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;padding:0;transition:opacity .12s}.forgot:hover{opacity:.75}.divider{margin:20px 0}.btn-login{align-items:center;background:var(--brand);border:none;border-radius:var(--radius-sm);box-shadow:0 2px 8px -2px #2d6bff73;color:#fff;display:flex;font-size:14px;font-weight:600;gap:8px;height:44px;justify-content:center;letter-spacing:.01em;transition:background .15s,box-shadow .15s;width:100%}.btn-login:hover{background:var(--brand-600);box-shadow:0 4px 16px -4px #2d6bff8c}.btn-login svg{height:16px;width:16px}.error-msg{align-items:center;background:var(--red-bg);border:1px solid #ef444433;border-radius:8px;color:var(--red-text);display:none;font-size:13px;gap:8px;margin-top:12px;padding:10px 12px}.error-msg svg{flex-shrink:0;height:14px;width:14px}.form-hint{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);display:flex;font-size:12.5px;gap:8px;margin-top:20px;padding:12px 14px}.form-hint svg{color:var(--muted-2);flex-shrink:0;height:14px;width:14px}.form-hint b{color:var(--text-2);font-weight:600}.form-foot{color:var(--muted-2);font-size:12px;margin-top:16px;text-align:center}@media(max-width:860px){.shell{grid-template-columns:1fr;padding:20px 0}.left{display:none}}.login-page{--bg:#f7f8fa;--surface:#fff;--surface-2:#fbfbfc;--border:#eceef2;--border-strong:#e1e4ea;--hover:#f4f5f8;--text:#0e1525;--text-2:#3c4659;--muted:#697384;--muted-2:#94a0b2;--green-bg:#e6f8f0;--green-text:#0a5c40;--amber-bg:#fef4e2;--amber-text:#7a5a04;--red-bg:#fdecec;--red-text:#9a2a2a}.admin-info b,.brand-name{color:var(--text)}.av-28{font-size:10.5px;height:28px;width:28px}.av-48{font-size:16px;height:48px;width:48px}.icon-btn{transition:background .12s,border-color .12s}.btn-icon{background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-2);display:grid;height:36px;padding:0;place-items:center;transition:background .12s,color .12s;width:36px}.btn-icon:hover{background:var(--hover);color:var(--text)}.btn-icon svg{height:15px;width:15px}.stat-strip{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.stat-chip{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);display:flex;gap:12px;padding:14px 16px}.stat-chip-icon{border-radius:9px;display:grid;flex-shrink:0;height:36px;place-items:center;width:36px}.stat-chip-icon svg{height:16px;width:16px}.stat-chip-body{min-width:0}.stat-chip-n{font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1}.stat-chip-l{color:var(--muted);font-size:11.5px;margin-top:2px}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.seg button{padding:5px 12px}.search-wrap{align-items:center;display:flex;flex:1 1;max-width:280px;min-width:180px;position:relative}.search-wrap svg{color:var(--muted-2);height:15px;left:11px;position:absolute;width:15px}.search-wrap input{background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font:inherit;font-size:13px;height:36px;outline:none;padding:0 12px 0 35px;transition:border-color .15s,box-shadow .15s;width:100%}.search-wrap input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-50)}.search-wrap input::placeholder{color:var(--muted-2)}.view-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;display:flex;gap:3px;margin-left:auto;padding:3px}.view-toggle button{background:#0000;border:none;border-radius:7px;color:var(--muted);display:grid;height:30px;place-items:center;transition:background .12s,color .12s;width:30px}.view-toggle button.on{background:var(--surface-3);box-shadow:0 1px 3px #0000004d;color:var(--text)}.view-toggle button svg{height:15px;width:15px}.members-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.mc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:0;position:relative;transition:border-color .15s,box-shadow .15s,transform .15s}.mc:hover{border-color:var(--border-strong);box-shadow:inset 0 0 0 1px #ffffff0f,0 8px 32px #0000008c;transform:translateY(-2px)}.mc-strip{height:3px;width:100%}.mc-badges{display:flex;flex-wrap:wrap;gap:4px;min-height:26px;padding:12px 14px 0}.role-tag{border-radius:5px;font-size:10px;padding:2px 7px;white-space:nowrap}.role-tag svg{height:10px;width:10px}.mc-body{align-items:center;display:flex;flex-direction:column;gap:10px;padding:14px 16px 0;text-align:center}.mc-av-wrap{display:inline-block;position:relative}.status-ring{border:2px solid #0000;border-radius:50%;inset:-3px;pointer-events:none;position:absolute}.status-ring.present{border-color:var(--green)}.status-ring.absent{border-color:var(--red)}.status-ring.partial,.status-ring.remote{border-color:var(--amber)}.av-status-dot{border:2px solid var(--surface);border-radius:50%;bottom:1px;height:11px;position:absolute;right:1px;width:11px}.av-status-dot.present{background:var(--green)}.av-status-dot.absent{background:var(--red)}.av-status-dot.remote{background:var(--amber)}.mc-name{color:var(--text);font-size:14px;font-weight:600;letter-spacing:-.005em;margin:0}.mc-title{color:var(--muted);font-size:12px;margin:0}.mc-time{align-items:center;border-radius:7px;display:inline-flex;font-size:12px;font-weight:500;gap:5px;padding:3px 10px}.mc-time svg{height:12px;width:12px}.mc-time.ok{background:var(--green-bg);color:var(--green-text)}.mc-time.late{background:var(--amber-bg);color:var(--amber-text)}.mc-time.absent{background:var(--red-bg);color:var(--red-text)}.mc-time.remote{background:var(--amber-bg);color:var(--amber-text)}.mc-divider{background:var(--border);height:1px;margin:12px 0 0}.mc-foot{align-items:center;display:flex;justify-content:space-between;padding:10px 14px}.mc-action{align-items:center;color:var(--brand);display:inline-flex;font-size:12px;font-weight:600;gap:4px;transition:gap .12s}.mc:hover .mc-action{gap:6px}.mc-action svg{height:12px;width:12px}.mc-dots{background:#0000;border:none;border-radius:7px;color:var(--muted);display:grid;height:26px;place-items:center;transition:background .12s,color .12s;width:26px}.mc-dots:hover{background:var(--hover);color:var(--text)}.mc-dots svg{height:14px;width:14px}.members-table-wrap{display:none}.members-table-wrap.show{display:block}.members-grid.hide{display:none}.card-head{padding:14px 20px}.tbl tbody tr{cursor:pointer}.mem-info span,.status-pill{font-size:12px}.status-pill{align-items:center;border-radius:7px;display:inline-flex;font-weight:500;gap:5px;padding:3px 10px}.status-pill i{border-radius:50%;flex-shrink:0;height:6px;width:6px}.status-pill.present{background:var(--green-bg);color:var(--green-text)}.status-pill.present i{background:var(--green)}.status-pill.absent{background:var(--red-bg);color:var(--red-text)}.status-pill.absent i{background:var(--red)}.status-pill.remote{background:var(--amber-bg);color:var(--amber-text)}.status-pill.remote i{background:var(--amber)}.member-status-tag{align-items:center;border-radius:6px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:2px 8px}.member-status-tag.active{background:var(--green-bg);color:var(--green-text)}.member-status-tag.inactive{background:var(--gray-bg);color:var(--muted)}@media(max-width:1400px){.members-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1100px){.members-grid,.stat-strip{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.members-grid{grid-template-columns:1fr}.content{padding:16px 14px 40px}}.mc-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);display:flex;flex-direction:column;min-width:150px;padding:6px;position:absolute;right:0;top:28px;z-index:20}.mc-menu-item{background:none;border:none;border-radius:8px;color:var(--text);cursor:pointer;font:500 13px var(--font);padding:8px 10px;text-align:left}.mc-menu-item:hover{background:var(--hover)}.mc-menu-item.danger{color:var(--red)}.admin-info{line-height:1.25;min-width:0}.av-80{font-size:26px;height:80px;width:80px}.topbar{background:#0b0d12e0}.btn svg{height:14px;width:14px}.btn-danger{background:var(--red-bg);border:1px solid #ef444433;color:var(--red-text)}.btn-danger:hover{background:#ef44442e}.breadcrumb{align-items:center;color:var(--muted);display:flex;font-size:13px;gap:8px}.breadcrumb svg{color:var(--muted-2);height:14px;width:14px}.breadcrumb a{color:var(--brand);font-weight:500}.breadcrumb span{color:var(--muted-2)}.page-head-left{align-items:center;display:flex;gap:16px}.detail-grid{grid-gap:18px;align-items:start;display:grid;gap:18px;grid-template-columns:300px 1fr}.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.profile-cover{background:linear-gradient(135deg,#2d6bff59,#7c5cff40);height:80px;overflow:hidden;position:relative}.profile-cover:before{background-image:radial-gradient(circle,#ffffff0d 1px,#0000 0);background-size:22px 22px;content:"";inset:0;position:absolute}.profile-av-area{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:14px;margin-top:-40px;padding:0 20px}.profile-av-ring{border:3px solid var(--surface);border-radius:50%;box-shadow:0 4px 16px #00000080;flex-shrink:0;height:80px;overflow:hidden;width:80px;z-index:99}.profile-av-ring .av{border-radius:50%;height:100%;width:100%}.profile-online{align-items:center;background:var(--green-bg);border-radius:7px;color:var(--green-text);display:inline-flex;font-size:11.5px;font-weight:600;gap:5px;margin-bottom:6px;padding:3px 10px}.profile-online i{animation:pulse 2s ease-in-out infinite;background:var(--green);border-radius:50%;height:6px;width:6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.profile-body{padding:0 20px 20px}.profile-name{font-size:18px;font-weight:700;letter-spacing:-.015em;margin-bottom:2px}.profile-title{color:var(--muted);font-size:13px;margin-bottom:16px}.profile-roles{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.role-tag{align-items:center;border-radius:6px;display:inline-flex;font-size:10.5px;font-weight:600;gap:4px;padding:3px 9px}.role-tag svg{height:11px;width:11px}.role-tag.slack{background:var(--blue-bg);color:var(--blue-text)}.role-tag.admin{background:var(--violet-bg);color:var(--violet-text)}.divider{background:var(--border);height:1px;margin:14px 0}.pf{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}.pf label{color:var(--muted-2);font-size:10.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase}.pf span{color:var(--text-2);font-size:13px}.pf span a{color:var(--brand)}.punch-row{grid-gap:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);display:grid;gap:0;grid-template-columns:1fr 1px 1fr;margin:14px 0;overflow:hidden}.punch-col{padding:12px;text-align:center}.punch-divider{background:var(--border)}.punch-label{color:var(--muted-2);font-size:10px;font-weight:600;letter-spacing:.07em;margin-bottom:5px;text-transform:uppercase}.punch-time{align-items:center;display:flex;font-size:17px;font-weight:700;gap:6px;justify-content:center;letter-spacing:-.01em}.punch-time svg{height:15px;width:15px}.punch-time.in{color:var(--green-text)}.punch-time.out{color:var(--red-text)}.punch-time.none{color:var(--muted-2);font-size:20px}.profile-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-top:14px}.ps{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}.ps-n{font-size:21px;font-weight:700;letter-spacing:-.02em}.ps-n.green{color:var(--green-text)}.ps-n.amber{color:var(--amber-text)}.ps-l{color:var(--muted);font-size:11px;margin-top:2px}.heatmap-section{border-top:1px solid var(--border);padding:16px 20px 18px}.heatmap-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.heatmap-title{color:var(--muted);font-size:11.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase}.heatmap-nav{align-items:center;display:flex;gap:6px}.heatmap-nav button{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--muted);display:grid;height:24px;place-items:center;transition:background .12s;width:24px}.heatmap-nav button:hover{background:var(--hover);color:var(--text)}.heatmap-nav button svg{height:12px;width:12px}.heatmap-month{color:var(--text-2);font-size:12px;font-weight:600}.hm-day-labels{grid-gap:3px;display:grid;gap:3px;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.hm-day-labels span{color:var(--muted-2);font-size:9px;font-weight:500;text-align:center}.hm-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.hm-cell{aspect-ratio:1;border-radius:3px;cursor:pointer;transition:transform .1s,opacity .1s}.hm-cell:hover{opacity:.9;transform:scale(1.2)}.hm-present{background:var(--green)}.hm-partial{background:var(--amber)}.hm-absent{background:#ef444440}.hm-empty{background:var(--border)}.hm-weekend{background:var(--border-strong)}.hm-today{outline:1px solid var(--brand);outline-offset:1px}.hm-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.hm-leg{align-items:center;color:var(--muted);display:inline-flex;font-size:10.5px;gap:4px}.hm-leg i{border-radius:2px;height:10px;width:10px}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.detail-card-head{align-items:center;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:15px 20px}.detail-card-head h2{font-size:14px;font-weight:600;margin:0}.detail-card-head .right{align-items:center;display:flex;gap:8px}.seg{border-radius:9px}.seg button{border-radius:6px;font-size:12px;padding:4px 10px}.tbl tbody td{padding:12px 18px}.tbl tbody tr.row-today td{background:#2d6bff0f}.tbl tbody tr.row-today td:first-child{box-shadow:inset 3px 0 0 var(--brand)}.date-cell .d{font-size:13.5px}.tbl-foot{padding:12px 20px}.summary-bar{grid-gap:1px;background:var(--border);border-bottom:1px solid var(--border);display:grid;gap:1px;grid-template-columns:repeat(4,1fr)}.sb-item{background:var(--surface-2);padding:12px 18px;text-align:center}.sb-n{font-size:18px;font-weight:700;letter-spacing:-.02em}.sb-l{color:var(--muted);font-size:11px;margin-top:2px}@media(max-width:1100px){.detail-grid{grid-template-columns:1fr}}.rdrCalendarWrapper{background:#fff;box-sizing:border-box;display:inline-flex;flex-direction:column;-webkit-user-select:none;-moz-user-select:none;user-select:none}.rdrDateDisplay{display:flex;justify-content:space-between}.rdrDateDisplayItem{color:inherit;flex:1 1;text-align:center;width:0}.rdrDateDisplayItem+.rdrDateDisplayItem{margin-left:.833em}.rdrDateDisplayItem input{text-align:inherit}.rdrDateDisplayItem input:disabled{cursor:default}.rdrMonthAndYearWrapper{box-sizing:inherit;display:flex;justify-content:space-between}.rdrMonthAndYearPickers{align-items:center;display:flex;flex:1 1 auto;justify-content:center}.rdrNextPrevButton{box-sizing:inherit;cursor:pointer;outline:none}.rdrMonths{display:flex}.rdrMonthsVertical{flex-direction:column}.rdrMonthsHorizontal>div>div>div{display:flex;flex-direction:row}.rdrMonth{width:27.667em}.rdrWeekDays{display:flex}.rdrWeekDay{box-sizing:inherit;flex-basis:14.28571%;text-align:center}.rdrDays{display:flex;flex-wrap:wrap}.rdrInfiniteMonths{overflow:auto}.rdrDateRangeWrapper{-webkit-user-select:none;-moz-user-select:none;user-select:none}.rdrDateInput{position:relative}.rdrDateInput input{outline:none}.rdrDateInput .rdrWarning{color:red;font-size:1.6em;line-height:1.6em;position:absolute;right:.25em;top:0}.rdrDay{box-sizing:inherit;cursor:pointer;font:inherit;position:relative;width:14.28571%}.rdrDayNumber{display:block;position:relative}.rdrDayNumber span{color:#1d2429}.rdrDayDisabled{cursor:not-allowed}@supports (-ms-ime-align:auto){.rdrDay{flex-basis:14.285%!important}}.rdrEndEdge,.rdrInRange,.rdrSelected,.rdrStartEdge{pointer-events:none}.rdrDateRangePickerWrapper{display:inline-flex;-webkit-user-select:none;-moz-user-select:none;user-select:none}.rdrStaticRanges{display:flex;flex-direction:column}.rdrStaticRange{font-size:inherit}.rdrInputRange{display:flex}.rdrCalendarWrapper{color:#000;font-size:12px}.rdrDateDisplayWrapper{background-color:#eff2f7}.rdrDateDisplay{margin:.833em}.rdrDateDisplayItem{background-color:#fff;border:1px solid #0000;border-radius:4px;box-shadow:0 1px 2px 0 #23394236}.rdrDateDisplayItem input{background:#0000;border:0;color:#849095;cursor:pointer;height:2.5em;line-height:2.5em;width:100%}.rdrDateDisplayItemActive{border-color:currentColor}.rdrDateDisplayItemActive input{color:#7d888d}.rdrMonthAndYearWrapper{align-items:center;height:60px;padding-top:10px}.rdrMonthAndYearPickers{font-weight:600}.rdrMonthAndYearPickers select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:#0000;background:url("data:image/svg+xml;utf8,<svg width=%279px%27 height=%276px%27 viewBox=%270 0 9 6%27 version=%271.1%27 xmlns=%27http://www.w3.org/2000/svg%27 xmlns:xlink=%27http://www.w3.org/1999/xlink%27><g id=%27Artboard%27 stroke=%27none%27 stroke-width=%271%27 fill=%27none%27 fill-rule=%27evenodd%27 transform=%27translate%28-636.000000, -171.000000%29%27 fill-opacity=%270.368716033%27><g id=%27input%27 transform=%27translate%28172.000000, 37.000000%29%27 fill=%27%230E242F%27 fill-rule=%27nonzero%27><g id=%27Group-9%27 transform=%27translate%28323.000000, 127.000000%29%27><path d=%27M142.280245,7.23952813 C141.987305,6.92353472 141.512432,6.92361662 141.219585,7.23971106 C140.926739,7.5558055 140.926815,8.06821394 141.219755,8.38420735 L145.498801,13 L149.780245,8.38162071 C150.073185,8.0656273 150.073261,7.55321886 149.780415,7.23712442 C149.487568,6.92102998 149.012695,6.92094808 148.719755,7.23694149 L145.498801,10.7113732 L142.280245,7.23952813 Z%27 id=%27arrow%27></path></g></g></g></svg>") no-repeat;background-position:right 8px center;border:0;border-radius:4px;color:#3e484f;cursor:pointer;outline:0;padding:10px 30px 10px 10px;text-align:center}.rdrMonthAndYearPickers select:hover{background-color:#00000012}.rdrMonthPicker,.rdrYearPicker{margin:0 5px}.rdrNextPrevButton{background:#eff2f7;border:0;border-radius:5px;display:block;height:24px;margin:0 .833em;padding:0;width:24px}.rdrNextPrevButton:hover{background:#e1e7f0}.rdrNextPrevButton i{border-style:solid;display:block;height:0;margin:auto;padding:0;text-align:center;transform:translate(-3px);width:0}.rdrPprevButton i{border-color:#0000 #34495e #0000 #0000;border-width:4px 6px 4px 4px;transform:translate(-3px)}.rdrNextButton i{border-color:#0000 #0000 #0000 #34495e;border-width:4px 4px 4px 6px;margin:0 0 0 7px;transform:translate(3px)}.rdrWeekDays{padding:0 .833em}.rdrMonth{padding:0 .833em 1.666em}.rdrMonth .rdrWeekDays{padding:0}.rdrMonths.rdrMonthsVertical .rdrMonth:first-child .rdrMonthName{display:none}.rdrWeekDay{color:#849095;font-weight:400;line-height:2.667em}.rdrDay{background:#0000;border:0;color:#1d2429;height:3em;line-height:3em;padding:0;text-align:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.rdrDay:focus{outline:0}.rdrDayNumber{align-items:center;bottom:0;bottom:5px;display:flex;font-weight:300;justify-content:center;left:0;outline:0;position:absolute;right:0;top:0;top:5px}.rdrDayToday .rdrDayNumber span{font-weight:500}.rdrDayToday .rdrDayNumber span:after{background:#3d91ff;border-radius:2px;bottom:4px;content:"";height:2px;left:50%;position:absolute;transform:translate(-50%);width:18px}.rdrDayToday:not(.rdrDayPassive) .rdrEndEdge~.rdrDayNumber span:after,.rdrDayToday:not(.rdrDayPassive) .rdrInRange~.rdrDayNumber span:after,.rdrDayToday:not(.rdrDayPassive) .rdrSelected~.rdrDayNumber span:after,.rdrDayToday:not(.rdrDayPassive) .rdrStartEdge~.rdrDayNumber span:after{background:#fff}.rdrDay:not(.rdrDayPassive) .rdrEndEdge~.rdrDayNumber span,.rdrDay:not(.rdrDayPassive) .rdrInRange~.rdrDayNumber span,.rdrDay:not(.rdrDayPassive) .rdrSelected~.rdrDayNumber span,.rdrDay:not(.rdrDayPassive) .rdrStartEdge~.rdrDayNumber span{color:#ffffffd9}.rdrEndEdge,.rdrInRange,.rdrSelected,.rdrStartEdge{background:currentColor;bottom:5px;left:0;position:absolute;right:0;top:5px}.rdrSelected{left:2px;right:2px}.rdrStartEdge{border-bottom-left-radius:1.042em;border-top-left-radius:1.042em;left:2px}.rdrEndEdge{border-bottom-right-radius:1.042em;border-top-right-radius:1.042em;right:2px}.rdrSelected{border-radius:1.042em}.rdrDayStartOfMonth .rdrEndEdge,.rdrDayStartOfMonth .rdrInRange,.rdrDayStartOfWeek .rdrEndEdge,.rdrDayStartOfWeek .rdrInRange{border-bottom-left-radius:1.042em;border-top-left-radius:1.042em;left:2px}.rdrDayEndOfMonth .rdrInRange,.rdrDayEndOfMonth .rdrStartEdge,.rdrDayEndOfWeek .rdrInRange,.rdrDayEndOfWeek .rdrStartEdge{border-bottom-right-radius:1.042em;border-top-right-radius:1.042em;right:2px}.rdrDayStartOfMonth .rdrDayEndPreview,.rdrDayStartOfMonth .rdrDayInPreview,.rdrDayStartOfWeek .rdrDayEndPreview,.rdrDayStartOfWeek .rdrDayInPreview{border-bottom-left-radius:1.333em;border-left-width:1px;border-top-left-radius:1.333em;left:0}.rdrDayEndOfMonth .rdrDayInPreview,.rdrDayEndOfMonth .rdrDayStartPreview,.rdrDayEndOfWeek .rdrDayInPreview,.rdrDayEndOfWeek .rdrDayStartPreview{border-bottom-right-radius:1.333em;border-right-width:1px;border-top-right-radius:1.333em;right:0}.rdrDayEndPreview,.rdrDayInPreview,.rdrDayStartPreview{background:#ffffff17;border:0 solid;bottom:3px;left:0;pointer-events:none;position:absolute;right:0;top:3px;z-index:1}.rdrDayStartPreview{border-bottom-left-radius:1.333em;border-bottom-width:1px;border-left-width:1px;border-top-left-radius:1.333em;border-top-width:1px;left:0}.rdrDayInPreview{border-bottom-width:1px;border-top-width:1px}.rdrDayEndPreview{border-bottom-right-radius:1.333em;border-bottom-width:1px;border-right-width:1px;border-top-right-radius:1.333em;border-top-width:1px;right:2px;right:0}.rdrDefinedRangesWrapper{background:#fff;border-right:1px solid #eff2f7;font-size:12px;width:226px}.rdrDefinedRangesWrapper .rdrStaticRangeSelected{color:currentColor;font-weight:600}.rdrStaticRange{background:#fff;border:0;border-bottom:1px solid #eff2f7;cursor:pointer;display:block;outline:0;padding:0}.rdrStaticRange:focus .rdrStaticRangeLabel,.rdrStaticRange:hover .rdrStaticRangeLabel{background:#eff2f7}.rdrStaticRangeLabel{display:block;line-height:18px;outline:0;padding:10px 20px;text-align:left}.rdrInputRanges{padding:10px 0}.rdrInputRange{align-items:center;padding:5px 20px}.rdrInputRangeInput{border:1px solid #dee7eb;border-radius:4px;color:#6c767a;height:30px;line-height:30px;margin-right:10px;text-align:center;width:30px}.rdrInputRangeInput:focus,.rdrInputRangeInput:hover{border-color:#b4bfc4;color:#333;outline:0}.rdrCalendarWrapper:not(.rdrDateRangeWrapper) .rdrDayHovered .rdrDayNumber:after{background:#0000;border:1px solid;border-radius:1.333em;bottom:-2px;content:"";left:0;position:absolute;right:0;top:-2px}.rdrDayPassive{pointer-events:none}.rdrDayPassive .rdrDayNumber span{color:#d5dce0}.rdrDayPassive .rdrDayEndPreview,.rdrDayPassive .rdrDayInPreview,.rdrDayPassive .rdrDayStartPreview,.rdrDayPassive .rdrEndEdge,.rdrDayPassive .rdrInRange,.rdrDayPassive .rdrSelected,.rdrDayPassive .rdrStartEdge{display:none}.rdrDayDisabled{background-color:#f8f8f8}.rdrDayDisabled .rdrDayNumber span{color:#aeb9bf}.rdrDayDisabled .rdrDayEndPreview,.rdrDayDisabled .rdrDayInPreview,.rdrDayDisabled .rdrDayStartPreview,.rdrDayDisabled .rdrEndEdge,.rdrDayDisabled .rdrInRange,.rdrDayDisabled .rdrSelected,.rdrDayDisabled .rdrStartEdge{filter:grayscale(100%) opacity(60%)}.rdrMonthName{color:#849095;font-weight:600;padding:.833em;text-align:left}*{box-sizing:border-box;margin:0;padding:0}body,html{font-size:14px;height:100%}body{-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,sans-serif;line-height:1.5}button,input,select{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:2px;height:100vh;overflow-y:auto;padding:20px 14px;position:-webkit-sticky;position:sticky;top:0}.brand{align-items:center;display:flex;gap:10px;padding:6px 10px 20px}.brand-mark{background:var(--brand);border-radius:9px;box-shadow:0 4px 16px -4px #2d6bff99;display:grid;flex-shrink:0;height:33px;place-items:center;width:33px}.brand-mark svg{color:#fff;height:17px;width:17px}.brand-name{font-size:15px;font-weight:700;letter-spacing:-.01em;line-height:1.1}.brand-name span{color:var(--brand)}.brand-sub{color:var(--muted-2);font-size:10.5px;margin-top:1px}.nav-sect{color:var(--muted-2);font-size:10px;font-weight:600;letter-spacing:.09em;padding:14px 12px 5px;text-transform:uppercase}.nav-item{align-items:center;border-radius:10px;color:var(--text-2);cursor:pointer;display:flex;font-size:13.5px;font-weight:500;gap:10px;padding:9px 12px;transition:background .12s,color .12s}.nav-item:hover{background:var(--hover);color:var(--text)}.nav-item.active{background:var(--brand-50)}.nav-item.active,.nav-item.active .ni{color:var(--brand)}.ni{color:var(--muted);flex-shrink:0;height:17px;width:17px}.sidebar-foot{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2px;margin-top:auto;padding-top:12px}.admin-row{align-items:center;border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:10px 12px}.admin-row:hover{background:var(--hover)}.admin-info b{display:block;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-info span{color:var(--muted);font-size:11px}.av{border-radius:50%;color:#fff;display:grid;flex-shrink:0;font-weight:600;place-items:center}.av-32{font-size:12px;height:32px;width:32px}.av-36{font-size:13px;height:36px;width:36px}.av-MH{background:linear-gradient(135deg,#a78bfa,#7c5cff)}.av-IK{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.av-IB{background:linear-gradient(135deg,#f472b6,#ec4899)}.av-JA{background:linear-gradient(135deg,#22d3ee,#0891b2)}.av-LS{background:linear-gradient(135deg,#ffb48a,#ff6f61)}.av-MC{background:linear-gradient(135deg,#6ee7b7,#059669)}.av-NU{background:linear-gradient(135deg,#c4b5fd,#8b5cf6)}.av-NJ{background:linear-gradient(135deg,#fca5a5,#ef4444)}.av-AH{background:linear-gradient(135deg,#34d399,#10b981)}.av-TH{background:linear-gradient(135deg,#fdba74,#ea580c)}.av-PD{background:linear-gradient(135deg,#a5f3fc,#06b6d4)}.av-RA{background:linear-gradient(135deg,#fde68a,#d97706)}.av-SA{background:linear-gradient(135deg,#bae6fd,#0284c7)}.av-SK{background:linear-gradient(135deg,#d9f99d,#65a30d)}.av-TA{background:linear-gradient(135deg,#60a5fa,#2d6bff)}.av-TN{background:linear-gradient(135deg,#ddd6fe,#7c3aed)}.main{display:flex;flex-direction:column;min-width:0}.topbar{align-items:center;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:var(--bg);border-bottom:1px solid var(--border);display:flex;gap:12px;height:auto;padding:12px 28px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar-left{display:flex;flex-direction:column;line-height:1.2}.topbar-title{font-size:18px;font-weight:600;letter-spacing:-.01em}.topbar-sub{color:var(--muted);font-size:12px;margin-top:4px}.topbar-right{align-items:center;display:flex;gap:6px;margin-left:auto}.icon-btn{background:#0000;border:1px solid #0000;border-radius:10px;color:var(--text-2);display:grid;height:36px;place-items:center;transition:background .12s;width:36px}.icon-btn:hover{background:var(--hover);border-color:var(--border);color:var(--text)}.icon-btn svg{height:17px;width:17px}.notif-wrap{position:relative}.notif-count{background:var(--red);border:2px solid var(--bg);border-radius:9px;color:#fff;display:grid;font-size:10px;font-weight:700;height:17px;min-width:17px;padding:0 4px;place-items:center;position:absolute;right:0;top:3px}.btn{align-items:center;border-radius:10px;display:inline-flex;font:inherit;font-size:13.5px;font-weight:500;gap:7px;height:36px;padding:0 16px;transition:background .12s;white-space:nowrap}.btn svg{flex-shrink:0;height:15px;width:15px}.btn-ghost{background:var(--surface);border:1px solid var(--border);color:var(--text-2)}.btn-ghost:hover{background:var(--hover);color:var(--text)}.btn-brand{background:var(--brand);border:none;box-shadow:0 2px 10px -2px #2d6bff80;color:#fff}.btn-brand:hover{background:var(--brand-600)}.btn-sm{font-size:12.5px;height:30px;padding:0 11px}.content{display:flex;flex-direction:column;gap:20px;padding:24px 28px 48px}.page-head{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.page-head h1{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:3px}.page-head .sub{color:var(--muted);font-size:13px}.page-tools{display:flex;gap:8px}.kpi-strip{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.kpi-chip{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);display:flex;gap:12px;overflow:hidden;padding:14px 18px;position:relative}.kpi-chip:before{background:var(--brand);background:var(--kc,var(--brand));border-radius:var(--radius-sm) var(--radius-sm) 0 0;content:"";height:2px;left:0;position:absolute;right:0;top:0}.kpi-icon{border-radius:9px;display:grid;flex-shrink:0;height:34px;place-items:center;width:34px}.kpi-icon svg{height:15px;width:15px}.kpi-n{font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1}.kpi-l{color:var(--muted);font-size:11.5px;margin-top:2px}.filter-panel{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:12px;padding:16px 20px}.filter-panel .divider-v{background:var(--border);flex-shrink:0;height:24px;width:1px}.seg{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;display:flex;gap:2px;padding:3px}.seg button{background:#0000;border:none;border-radius:7px;color:var(--muted);font:inherit;font-size:12.5px;font-weight:500;padding:5px 11px;transition:background .12s,color .12s;white-space:nowrap}.seg button.on{background:var(--surface-3);box-shadow:0 1px 3px #0000004d;color:var(--text);font-weight:600}.date-range{align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text-2);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;height:36px;padding:0 14px;transition:border-color .12s;white-space:nowrap}.date-range:hover{border-color:var(--border-strong);color:var(--text)}.date-range svg{color:var(--muted-2);height:14px;width:14px}.member-select{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text-2);cursor:pointer;font:inherit;font-size:13px;height:36px;min-width:160px;outline:none;padding:0 12px;transition:border-color .12s}.member-select:focus{border-color:var(--brand)}.type-seg{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;display:flex;gap:2px;padding:3px}.type-seg button{align-items:center;background:#0000;border:none;border-radius:7px;color:var(--muted);display:flex;font:inherit;font-size:12px;font-weight:500;gap:4px;padding:4px 10px;transition:background .12s,color .12s}.type-seg button svg{height:11px;width:11px}.type-seg button.on{background:var(--surface-3);box-shadow:0 1px 3px #0000004d;color:var(--text);font-weight:600}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.card-head{align-items:center;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:15px 20px}.card-head h2{font-size:14px;font-weight:600;margin:0}.card-head .right{align-items:center;display:flex;gap:8px}.tbl{border-collapse:initial;border-spacing:0;font-size:13.5px;width:100%}.tbl thead th{background:var(--surface-2);color:var(--muted);font-size:10.5px;font-weight:600;letter-spacing:.07em;padding:9px 18px;text-align:left;text-transform:uppercase;white-space:nowrap}.tbl tbody td,.tbl thead th{border-bottom:1px solid var(--border)}.tbl tbody td{padding:11px 18px;vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr{transition:background .1s}.tbl tbody tr:hover td{background:var(--hover)}.tbl tbody tr.row-ok td{background:#10b98108}.tbl tbody tr.row-ok:hover td{background:#10b9810f}.tbl tbody tr.row-warn td{background:rgba(245,158,11,.025)}.tbl tbody tr.row-warn:hover td{background:rgba(245,158,11,.055)}.tbl tbody tr.row-warn td:first-child{box-shadow:inset 3px 0 0 var(--amber)}.tbl tbody tr.row-absent td{background:rgba(239,68,68,.025)}.tbl tbody tr.row-absent:hover td{background:#ef44440d}.tbl tbody tr.row-absent td:first-child{box-shadow:inset 3px 0 0 var(--red)}.date-cell .d{color:var(--text);font-size:13px;font-weight:500}.date-cell .d2{color:var(--muted);font-size:11.5px;margin-top:1px}.mem-cell{align-items:center;display:flex;gap:10px}.mem-info b{display:block;font-size:13.5px;font-weight:600;line-height:1.2}.mem-info span{color:var(--muted);font-size:11.5px}.tc{align-items:center;display:flex;font-size:13.5px;gap:6px;white-space:nowrap}.tc svg{flex-shrink:0;height:14px;width:14px}.tc.in svg{color:var(--green)}.tc.out svg{color:var(--red)}.tc.dash{color:var(--muted-2)}.hours-badge{align-items:center;border-radius:7px;display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:3px 10px}.hours-badge.ok{background:var(--green-bg);color:var(--green-text)}.hours-badge.none{background:var(--gray-bg);color:var(--muted-2)}.hours-badge svg{height:12px;width:12px}.type-badge{align-items:center;border-radius:7px;display:inline-flex;font-size:11.5px;font-weight:500;gap:4px;padding:2px 9px;white-space:nowrap}.type-badge svg{height:11px;width:11px}.type-badge.remote{background:var(--blue-bg);color:var(--blue-text)}.type-badge.office{background:var(--gray-bg);color:var(--gray-text)}.absent-tag{align-items:center;background:var(--red-bg);border-radius:7px;color:var(--red-text);display:inline-flex;font-size:11.5px;font-weight:600;gap:4px;padding:2px 9px}.acts{display:flex;gap:3px;justify-content:flex-end}.act{background:#0000;border:1px solid #0000;border-radius:8px;color:var(--muted);display:grid;height:28px;place-items:center;transition:all .1s;width:28px}.act:hover{background:var(--hover);border-color:var(--border);color:var(--text-2)}.act.del:hover{background:var(--red-bg);border-color:#0000;color:var(--red)}.act svg{height:13px;width:13px}.tbl-foot{align-items:center;border-top:1px solid var(--border);color:var(--muted);display:flex;font-size:12.5px;justify-content:space-between;padding:13px 20px}.pager{display:flex;gap:3px}.pager button{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-2);font:inherit;font-size:12.5px;height:30px;min-width:30px;padding:0 7px;transition:background .1s}.pager button:hover:not(:disabled){background:var(--hover)}.pager button.on{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}.pager button:disabled{cursor:not-allowed;opacity:.38}.rows-per-page{align-items:center;color:var(--muted);display:flex;font-size:12.5px;gap:6px}.rows-per-page select{background:var(--surface-2);border:1px solid var(--border);border-radius:7px;color:var(--text-2);font:inherit;font-size:12px;height:28px;outline:none;padding:0 8px}@media(max-width:1280px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}@media(max-width:960px){.sidebar{display:none}}@media(max-width:600px){.content{padding:16px 14px 40px}}
/*# sourceMappingURL=main.6203a517.css.map*/