:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#10213f;background:radial-gradient(circle at 20% 20%,#fff1d6,#d9efff 42%,#efe6ff)}*{box-sizing:border-box}body{margin:0;min-height:100vh}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px}.shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr}.sidebar{background:linear-gradient(180deg,#052b58,#0f4675);color:#f4fbff;padding:24px 18px;display:flex;flex-direction:column;gap:18px}.sidebar h1{margin:0;font-size:20px;letter-spacing:.4px}.brand-title{display:flex;align-items:center;gap:10px}.brand-icon{width:34px;height:34px;border-radius:8px;object-fit:cover;background:#f4fbff}.nav-link{display:block;padding:10px 12px;color:#d4e8f8;text-decoration:none;border-radius:10px;margin-bottom:8px}.nav-link.active,.nav-link:hover{background:#1b5f9c;color:#fff}.content{padding:24px;min-width:0;overflow-x:hidden}.card{background:#fff;border-radius:16px;border:1px solid #d7e2f0;box-shadow:0 10px 24px #11274b14;padding:18px}.login-card{width:min(420px,100%)}.login-card h2{margin:0 0 8px}.login-card p{margin:0 0 18px;color:#4f6584}label{display:grid;gap:8px;margin-bottom:14px;font-weight:600}input{border:1px solid #bed0e6;border-radius:10px;padding:10px 12px;font-size:14px}textarea{border:1px solid #bed0e6;border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit}select{border:1px solid #bed0e6;border-radius:10px;padding:10px 12px;font-size:14px;background:#fff}.primary-btn,.ghost-btn{border-radius:10px;border:none;padding:10px 14px;font-weight:700;cursor:pointer}.as-link{text-decoration:none;display:inline-block}.primary-btn{background:linear-gradient(135deg,#1b73dd,#0eb39b);color:#fff}.ghost-btn{background:#e5eefb;color:#10396b}.primary-btn:disabled,.ghost-btn:disabled{opacity:.6;cursor:not-allowed}.error-box{background:#ffe2e2;color:#7b1f1f;border:1px solid #f2b8b8;border-radius:10px;padding:10px;margin-bottom:10px}.info-box{background:#e5f7ec;color:#1d5f3a;border:1px solid #bfe7ce;border-radius:10px;padding:10px;margin:10px 0;display:flex;align-items:center;justify-content:space-between;gap:10px}.notice-close-btn{border:0;background:transparent;color:#1d5f3a;font-size:18px;line-height:1;cursor:pointer}.section-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;flex-wrap:wrap}.inline-field{display:grid;gap:6px;margin:0}.stack-gap{display:grid;gap:10px}.action-row{display:flex;gap:8px;flex-wrap:wrap}.chip-btn{border:1px solid #b7cdeb;background:#f4f9ff;color:#143f70;border-radius:999px;padding:6px 12px;font-weight:600;cursor:pointer}.chip-btn.danger{border-color:#f2b3b3;background:#fff1f1;color:#852626}.link-btn{background:none;border:none;color:#1359a5;text-decoration:underline;cursor:pointer;padding:0;font:inherit}.menu-wrap{position:relative}.menu-popover{position:absolute;right:0;top:30px;background:#fff;border:1px solid #d7e2f0;border-radius:10px;box-shadow:0 10px 24px #11274b1f;padding:8px;min-width:150px;z-index:5;display:grid;gap:4px}.menu-popover button{border:1px solid #d9e6f8;border-radius:8px;background:#f8fbff;padding:6px 8px;cursor:pointer;text-align:left}.toggle-wrap{display:inline-flex;align-items:center;gap:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d192d73;display:grid;place-items:center;z-index:30;padding:16px}.modal-card{width:min(560px,100%);background:#fff;border-radius:14px;border:1px solid #d7e2f0;box-shadow:0 20px 50px #11274b33;padding:16px}.grid-cards{margin-top:16px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.timers-grid{align-items:start}.timers-manual-card{display:flex;flex-direction:column}.timers-manual-list{margin-top:8px;max-height:280px;overflow-y:auto;overflow-x:auto}.stat-card{min-height:112px;display:grid}.stat-card span{color:#3f5472}.stat-card strong{font-size:32px;margin-top:auto}.stat-card.mint{background:#daf8ef}.stat-card.sun{background:#ffefca}.stat-card.sky{background:#dff2ff}.stat-card.rose{background:#ffe2e7}.kpi-clickable{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.kpi-clickable:hover{transform:translateY(-1px);box-shadow:0 12px 22px #162f5a24}.table-card{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid #e4ecf8;text-align:left;padding:12px 10px;font-size:14px}th{background:#f6f9ff}.attendance-weekend{background:#ffe6ee}.attendance-holiday{background:#ece4ff}.attendance-status{display:inline-block;border-radius:999px;padding:3px 9px;font-weight:700;font-size:12px}.status-not-marked{background:#ffe3e8;color:#8f1d2c}.status-wfo{background:#d7f3df;color:#14532d}.status-wfh{background:#e9f9ee;color:#1f6f42}.status-leave{background:#ffeed6;color:#8d4b00}.status-half-day{background:#fff7d6;color:#705a00}.attendance-month-table{table-layout:fixed;width:max-content;min-width:100%}.attendance-month-table th,.attendance-month-table td{width:48px;min-width:48px;max-width:48px;text-align:center;padding:10px 6px}.attendance-month-table th:first-child,.attendance-month-table td:first-child{width:170px;min-width:170px;max-width:170px;position:sticky;left:0;z-index:3;background:#f6f9ff}.attendance-month-table.with-leaves th:nth-child(2),.attendance-month-table.with-leaves td:nth-child(2){width:72px;min-width:72px;max-width:72px;font-weight:700;color:#1c3e68;background:#f6f9ff;position:sticky;left:170px;z-index:2}.attendance-month-table .link-btn{width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.attendance-month-table .attendance-status{padding:2px 4px;font-size:10px;line-height:1.15;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attendance-month-wrap{width:100%;max-width:100%;overflow:auto;max-height:72vh}.attendance-month-table thead th{position:sticky;top:0;z-index:5;background:#f6f9ff}.user-project-col{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-pill-wrap{display:inline-flex;align-items:center;gap:4px;max-width:100%}.project-pill{display:inline-block;background:#e7f1ff;color:#1c4574;border-radius:999px;padding:2px 6px;font-size:10px;line-height:1.15;max-width:42px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-pill.extra{background:#f0ecff;color:#4a3f8a;max-width:none}.pill{border-radius:999px;display:inline-block;padding:4px 10px;font-size:12px;font-weight:700}.pill.on{background:#d4f8e5;color:#14593a}.pill.off{background:#ffe3e3;color:#8d1d1d}.muted{color:#526884}.users-filter-card{position:sticky;top:10px;z-index:6}.users-chip-row{display:flex;gap:8px;align-items:flex-end}.users-bulk-bar{position:sticky;top:92px;z-index:6;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}.users-bulk-summary{display:flex;gap:10px;align-items:center}.analytics-trend-list{display:grid;gap:10px}.analytics-legend{display:flex;gap:12px;flex-wrap:wrap;margin:8px 0 12px}.analytics-legend span{display:inline-flex;align-items:center;gap:6px;color:#39597f;font-size:12px}.analytics-legend i{width:10px;height:10px;border-radius:50%;display:inline-block}.analytics-trend-row{display:grid;grid-template-columns:110px 1fr 360px;gap:10px;align-items:center}.analytics-trend-date{font-weight:600;color:#294972}.analytics-trend-bar{display:flex;width:100%;height:14px;border-radius:999px;overflow:hidden;background:#e8eff8}.analytics-trend-bar .seg-wfo{background:#4db88a}.analytics-trend-bar .seg-wfh{background:#5fa7ea}.analytics-trend-bar .seg-leave{background:#f2be66}.analytics-trend-bar .seg-halfday{background:#a785db}.analytics-legend .seg-wfo{background:#4db88a}.analytics-legend .seg-wfh{background:#5fa7ea}.analytics-legend .seg-leave{background:#f2be66}.analytics-legend .seg-halfday{background:#a785db}.analytics-trend-meta{color:#39597f;font-size:13px}.analytics-project-bars{display:grid;gap:10px}.analytics-section-title{margin:0 0 8px}.donut-wrap{display:grid;grid-template-columns:132px 1fr;gap:12px;align-items:center}.analytics-donut{width:132px;height:132px;border-radius:50%;display:grid;place-items:center}.analytics-donut-center{width:76px;height:76px;border-radius:50%;background:#fff;display:grid;place-items:center;box-shadow:inset 0 0 0 1px #d9e4f4}.analytics-donut-center strong{font-size:18px;line-height:1;color:#153965}.analytics-donut-center span{font-size:10px;color:#5a7395}.donut-legend{display:grid;gap:6px}.donut-legend-item{border:1px solid #d9e6f8;border-radius:10px;padding:6px 8px;background:#f8fbff;display:grid;grid-template-columns:12px 1fr auto;gap:8px;align-items:center;cursor:pointer;text-align:left}.donut-legend-item i{width:10px;height:10px;border-radius:50%;display:inline-block}.donut-legend-item span{color:#2e4f78;font-size:13px}.donut-legend-item strong{color:#0f3564}.analytics-project-row{display:grid;grid-template-columns:minmax(130px,200px) 1fr minmax(110px,200px);gap:10px;align-items:center}.analytics-project-label{font-weight:600;color:#294972}.analytics-project-track{height:12px;border-radius:999px;background:#e7eff9;overflow:hidden}.analytics-project-fill{height:100%;border-radius:999px;background:linear-gradient(135deg,#1b73dd,#0eb39b)}.analytics-project-value{text-align:right;color:#355376;font-size:13px}@media (max-width: 900px){.shell{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:2}.section-head{align-items:stretch}.analytics-trend-row,.analytics-project-row{grid-template-columns:1fr}.analytics-project-value{text-align:left}.donut-wrap{grid-template-columns:1fr;justify-items:center}.donut-legend{width:100%}}
