:root{color:#202a36;background:#f5f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}button{cursor:pointer;font-size:12px;font-weight:600}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid #7a70ff;outline-offset:2px}h1,h2,p{margin-top:0}.app-frame{display:grid;min-height:100vh;grid-template-columns:240px minmax(0,1fr)}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;height:100vh;border-right:1px solid #e2e8f0;background:#fff;padding:24px 18px}.brand-mark{display:flex;align-items:center;gap:10px;margin-bottom:36px}.brand-mark span{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:8px;background:#5b4dff;color:#fff;font-weight:800}.brand-mark strong{font-size:18px}.side-nav{display:grid;gap:8px}.side-nav-item{display:flex;width:100%;align-items:center;gap:12px;border:0;border-radius:8px;background:transparent;color:#6b7785;padding:12px 14px;text-align:left}.side-nav-item.active{background:#eef0ff;color:#5b4dff;font-weight:600}.workspace{min-width:0;padding:28px 32px 44px}.workspace-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:26px}.workspace-topbar h1{margin-bottom:6px;font-size:30px;letter-spacing:0}.workspace-topbar p{margin-bottom:0;color:#718093}.session-card{display:grid;min-width:180px;grid-template-columns:1fr auto;align-items:center;gap:2px 10px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;padding:8px 10px 8px 14px;box-shadow:0 2px 8px #0f172a0d}.sidebar-session-card{width:100%;min-width:0;margin-top:auto}.session-card span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700}.session-card small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#718093;font-size:11px}.session-card .icon-button{grid-row:1 / span 2;grid-column:2;width:34px;height:34px}.topbar-actions{display:flex;align-items:center;gap:10px}.date-range-group{display:flex;align-items:center;gap:8px}.date-range-control{display:flex;align-items:center;gap:5px;padding:8px;border:1px solid #d9ddff;border-radius:999px;background:#fff;color:#5b4dff;box-shadow:0 6px 18px #5b4dff17}.date-presets{display:flex;align-items:center;gap:8px}.date-range-control input{width:118px;border:0;color:#202a36}.date-range-control input::-webkit-calendar-picker-indicator{margin-left:2px}.date-presets button,.icon-button,.primary-outline-button,.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;font-size:12px;font-weight:600}.date-presets button{min-height:38px;border:1px solid #7a70ff;border-radius:8px;background:#fff;color:#5b4dff;padding:8px 14px}.date-presets button.active{background:#5b4dff;color:#fff}.icon-button{width:44px;height:44px;border:1px solid #d9ddff;background:#fff;color:#5b4dff}.primary-outline-button,.primary-button{min-height:38px;border:1px solid #7a70ff;padding:8px 14px}.primary-outline-button{background:#fff;color:#5b4dff}.primary-button{background:#5b4dff;color:#fff}.primary-button:disabled,.primary-outline-button:disabled{cursor:default;opacity:.72}.primary-button.save-success,.primary-outline-button.save-success{border-color:#35a86b;background:#e8f7ef;color:#20794d}.primary-button.save-error,.primary-outline-button.save-error{border-color:#d95b4f;background:#fff0ee;color:#a43a31}.notice,.panel,.authors-table{border:1px solid #e2e8f0;border-radius:8px;background:#fff;box-shadow:0 2px 8px #0f172a0d}.notice{padding:12px 14px}.notice.error{border-color:#f1b5aa;color:#9f2f24}.page-section{display:grid;gap:16px}.login-shell{display:grid;min-height:100vh;grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr);align-items:center;gap:32px;overflow:hidden;background:radial-gradient(circle at 18% 20%,rgb(91 77 255 / 24%),transparent 28%),radial-gradient(circle at 82% 12%,rgb(19 163 123 / 20%),transparent 24%),linear-gradient(135deg,#101827,#172238 48%,#f5f7fb 48%);padding:48px}.login-hero{max-width:680px;color:#fff}.login-hero h1{max-width:620px;margin-bottom:18px;font-size:clamp(42px,6vw,76px);line-height:.95;letter-spacing:-.05em}.login-hero p{max-width:520px;color:#ffffffc7;font-size:18px;line-height:1.6}.eyebrow{margin-bottom:16px;color:#85f0c6;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.login-logo{display:block;width:min(320px,72vw);height:auto;margin-bottom:34px;filter:drop-shadow(0 22px 44px rgb(0 0 0 / 28%))}.login-card{display:grid;gap:14px;border:1px solid rgb(255 255 255 / 70%);border-radius:28px;background:#ffffffeb;padding:34px;box-shadow:0 30px 80px #0f172a3d;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.login-card-icon{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;border-radius:16px;background:#eef0ff;color:#5b4dff}.login-card h2{margin-bottom:0;font-size:28px}.login-card p{color:#718093}.login-card label{display:grid;gap:7px;color:#4b5969;font-size:12px;font-weight:700}.login-card input,.site-user-create-card input,.site-user-create-card select,.site-user-row input,.site-user-row select{width:100%;border:1px solid #d9ddff;border-radius:8px;background:#fff;padding:9px 10px;color:#202a36}.toolbar{display:flex;align-items:center;gap:12px}.toolbar-spacer{flex:1}.toolbar-caption{margin:4px 0 0;color:#60717d;font-size:13px}.search-box{display:flex;width:min(360px,100%);align-items:center;gap:10px;border-radius:8px;background:#eef1f5;padding:0 12px;color:#718093}.search-box input{width:100%;height:42px;border:0;background:transparent;color:#202a36;outline:none}.status-pill{border-radius:999px;background:#f1f5f9;color:#718093;padding:8px 12px;font-size:13px;font-weight:800}.status-pill.online{background:#e8f8ef;color:#15803d}.metric-value.good{color:#16834a}.metric-value.warning{color:#d97706}.metric-value.bad{color:#dc2626}.authors-table{overflow-x:auto;padding:0 18px}.authors-table-head,.authors-row{display:grid;grid-template-columns:1.5fr .65fr .82fr .82fr .72fr .72fr .72fr .72fr .8fr .78fr .58fr .82fr;min-width:1280px;gap:10px;align-items:center}.authors-table-head{color:#718093;font-size:12px;font-weight:900;padding:18px 4px 12px;text-transform:uppercase}.authors-row{min-height:74px;border-top:1px solid #e5eaf0;padding:12px 4px}.author-cell{display:flex;min-width:0;align-items:center;gap:12px}.author-cell>div{min-width:0}.author-cell strong,.author-cell small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.author-cell small{color:#718093}.author-email{max-width:150px}.author-status-stack{display:grid;gap:4px;justify-items:start}.author-status-stack small{color:#718093;font-size:12px;font-weight:800}.status-badge{display:inline-flex;width:fit-content;align-items:center;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:900;line-height:1;white-space:nowrap}.status-badge.online{background:#e8f7ef;color:#20794d}.status-badge.stale{background:#fde8e8;color:#b42318}.avatar{display:inline-flex;width:42px;height:42px;flex:0 0 auto;align-items:center;justify-content:center;border-radius:50%;background:#13a37b;color:#fff;font-weight:900}.empty,.empty-table{color:#718093}.empty-table{padding:22px 4px}.author-card-strip{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.author-card{display:grid;min-width:230px;gap:6px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;padding:14px;text-align:left}.author-card.active{border-color:#5b4dff;box-shadow:0 0 0 2px #5b4dff1f}.author-card small,.mini-metrics{color:#718093}.mini-metrics{display:grid;gap:3px;font-size:12px}.activity-grid,.totals{display:grid;gap:12px}.activity-grid{grid-template-columns:repeat(7,minmax(0,1fr))}.totals{grid-template-columns:repeat(5,minmax(0,1fr))}.duration{border-radius:8px;background:#fff;border:1px solid #e2e8f0;padding:16px}.duration span{display:block;color:#718093;font-size:13px}.duration strong{display:block;margin-top:6px;font-size:22px}.panel{padding:18px}.panel h2{margin-bottom:16px;font-size:18px}.content-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.content-grid.compact{align-items:start}.list{display:grid;gap:8px}.row{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid #e5eaf0;padding:10px 0}.table-panel{margin-top:0}.table{display:grid;overflow-x:auto}.table-head,.table-row{display:grid;grid-template-columns:.7fr 1.2fr .8fr .65fr .65fr .65fr .8fr .6fr 1fr;min-width:1080px;gap:12px;align-items:center;border-bottom:1px solid #e5eaf0;padding:12px 0}.table-head,.profile-table-head{color:#718093;font-size:12px;font-weight:900;text-transform:uppercase}.source-cell{display:inline-flex;align-items:center;gap:7px}.report-type-badge{display:inline-flex;width:fit-content;align-items:center;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:900;line-height:1;white-space:nowrap}.donut-panel{display:grid;grid-template-columns:minmax(0,1fr) 150px;align-items:center;gap:22px}.donut-panel-copy{min-width:0}.donut-panel .row span{display:inline-flex;min-width:0;align-items:center;gap:8px}.row-color{display:inline-block;width:10px;height:10px;flex:0 0 auto;border-radius:3px}.donut-chart{display:grid;width:128px;aspect-ratio:1;place-items:center;border-radius:50%;background:conic-gradient(var(--donut-gradient))}.donut-chart:before{content:"";position:absolute;width:78px;aspect-ratio:1;border-radius:50%;background:#fff}.donut-chart{position:relative}.donut-chart span{position:relative;color:#1f2937;font-size:18px;font-weight:900}.report-type-badge.auto{background:#e8f7ef;color:#20794d}.report-type-badge.manual{background:#fff0d9;color:#9b5a00}.table-pagination{display:flex;align-items:center;justify-content:flex-end;gap:14px;padding-top:14px;color:#718093;font-size:13px}.table-pagination label{display:inline-flex;align-items:center;gap:8px;font-weight:800}.table-pagination select{min-height:34px;border:1px solid #d8e0e8;border-radius:8px;background:#fff;padding:6px 8px}.pagination-buttons{display:inline-flex;align-items:center;gap:8px}.alerts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.alert-author-card{display:grid;gap:16px;border:1px solid #e5eaf0;border-radius:18px;background:#fff;padding:18px;box-shadow:0 12px 30px #0f172a0d}.alert-author-header{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.alert-author-header strong,.alert-author-header small{display:block}.alert-author-header small{color:#718093;font-size:12px}.alert-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.alert-stat-row div{border-radius:12px;background:#f7f9fb;padding:10px}.alert-stat-row span,.alert-card small{color:#718093;font-size:12px;font-weight:800}.alert-stat-row strong{display:block;margin-top:4px;font-size:20px}.alert-stack{display:grid;gap:10px}.alert-card{display:grid;gap:8px;border-left:4px solid #d97706;border-radius:12px;background:#fff8ed;padding:12px}.alert-card.critical{border-left-color:#dc2626;background:#fff1f1}.alert-card>div{display:flex;justify-content:space-between;gap:12px}.alert-card>div span{color:#718093;font-size:12px;font-weight:900;text-transform:uppercase}.alert-card p{margin:0;color:#425466;font-size:13px;line-height:1.45}.analytics-page{gap:18px}.analytics-author-card{border:1px solid #e5eaf0;border-radius:18px;background:#fff;box-shadow:0 12px 30px #0f172a0d}.analytics-author-header small,.analytics-period-metrics span,.analytics-period-metrics small{color:#718093;font-size:12px;font-weight:800}.analytics-author-card{padding:18px}.analytics-author-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:16px}.analytics-author-card{display:grid;gap:14px}.analytics-author-card:has(.analytics-period-grid){grid-column:span 1}.analytics-author-grid:has(.analytics-author-card:only-child){grid-template-columns:1fr}.analytics-author-header{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.analytics-author-header strong,.analytics-author-header small{display:block}.analytics-author-header>div{min-width:0}.analytics-author-header small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-stack{display:flex;min-height:42px;align-items:center;padding-left:2px}.avatar-stack .mini-avatar{width:34px;height:34px;border:2px solid #ffffff;box-shadow:0 4px 10px #0f172a1f;font-size:12px}.avatar-stack .mini-avatar+.mini-avatar{margin-left:-12px}.analytics-period-grid{display:grid;grid-template-columns:repeat(4,minmax(210px,1fr));gap:12px}.analytics-period-card{display:grid;gap:12px;border:1px solid #e5eaf0;border-radius:14px;background:#f9fbfd;padding:14px}.analytics-period-header{display:grid;grid-template-columns:1fr auto;gap:4px 10px;align-items:baseline}.analytics-period-header span{color:#718093;font-size:12px;font-weight:900;text-transform:uppercase}.analytics-period-header strong{font-size:24px}.analytics-period-header small{grid-column:2;font-size:12px;font-weight:900}.analytics-period-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px}.analytics-period-metrics div{border-radius:10px;background:#fff;padding:9px}.analytics-period-metrics span,.analytics-period-metrics small{color:#718093;font-size:11px;font-weight:800}.analytics-period-metrics strong{display:block;margin:4px 0}.analytics-insights{display:flex;flex-wrap:wrap;gap:6px}.insight-chip{display:inline-flex;width:fit-content;border-radius:999px;background:#eef3f7;color:#637083;padding:5px 8px;font-size:11px;font-weight:900}.insight-chip.positive{background:#e8f7ef;color:#20794d}.insight-chip.negative{background:#fde8e8;color:#b42318}.positive{color:#20794d}.negative{color:#dc2626}.analytics-hierarchy,.analytics-tree,.analytics-week-list{display:grid;gap:18px}.analytics-selected-author{display:flex;align-items:center;gap:12px;border:1px solid #e5eaf0;border-radius:12px;background:#fff;padding:16px}.analytics-selected-author strong,.analytics-selected-author small{display:block}.analytics-selected-author small{color:#718093}.analytics-tree-card,.analytics-week-card,.analytics-metrics-table,.analytics-day-table{border-radius:12px;background:#fff}.analytics-tree-card{display:grid;gap:14px;border:2px solid #d9ddff;border-left:7px solid #5b4dff;box-shadow:0 10px 26px #5b4dff14;padding:16px}.analytics-week-card{display:grid;gap:10px;border:1px solid #d8e3ee;border-left:5px solid #94a3b8;background:#f8fafc;padding:12px}.analytics-tree-toggle{display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:14px;border:0;background:transparent;color:#202a36;padding:0;text-align:left}.analytics-tree-toggle>span{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:999px;background:#5b4dff;color:#fff;font-weight:900}.analytics-tree-toggle.month strong{font-size:20px}.analytics-month-title{display:flex;align-items:baseline;gap:14px}.analytics-tree-toggle.week>span{width:28px;height:28px;background:#e2e8f0;color:#334155}.analytics-tree-toggle.week strong{font-size:15px}.analytics-tree-toggle small{color:#718093;font-weight:800}.analytics-tree-toggle.week{grid-template-columns:28px 1fr auto;gap:12px}.analytics-period-summary{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.analytics-period-summary span{border-radius:999px;background:#eef3ff;color:#425466;padding:5px 9px;font-size:12px;font-weight:900}.analytics-period-summary.compact span{background:#fff}.analytics-metrics-table,.analytics-day-table{border:1px solid #e5eaf0;overflow-x:auto}.analytics-table-head,.analytics-day-row,.analytics-delta-row{display:grid;grid-template-columns:1.1fr repeat(6,minmax(110px,1fr));min-width:860px;gap:10px;align-items:center;padding:10px 12px}.analytics-table-head{background:#f1f5f9;color:#64748b;font-size:12px;font-weight:900;text-transform:uppercase}.analytics-day-row,.analytics-delta-row{border-top:1px solid #e5eaf0}.analytics-day-row.muted{color:#9aa7b4;opacity:.72}.analytics-delta-row{background:#f8fafc;font-size:13px;font-weight:900}.delta-badge{border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;text-transform:capitalize}.delta-badge.positive{background:#e8f7ef}.delta-badge.negative{background:#fde8e8}.settings-layout{gap:18px}.settings-tabs{display:inline-flex;width:fit-content;gap:8px;border:1px solid #d9ddff;border-radius:999px;background:#fff;padding:5px}.settings-tabs button{border:0;border-radius:999px;background:transparent;color:#718093;padding:9px 14px}.settings-tabs button.active{background:#5b4dff;color:#fff}.settings-row{display:flex;align-items:end;gap:12px}.settings-row label,.profile-create-card label,.site-user-create-card label,.profile-row label:not(.checkbox-cell),.score-settings-grid label{display:grid;gap:6px;color:#718093;font-size:13px;font-weight:800}.settings-row input,.profile-create-card input,.profile-create-card select,.profile-row input,.profile-row select,.score-settings-grid input{min-height:38px;border:1px solid #d8e0e8;border-radius:8px;padding:8px 10px}.settings-caption{color:#718093;font-size:13px}.score-settings-grid{display:grid;grid-template-columns:repeat(5,minmax(130px,1fr)) auto;gap:12px;align-items:end}.calendar-page{gap:18px}.calendar-year-header{display:flex;justify-content:space-between;gap:16px;border:1px solid #e5eaf0;border-radius:16px;background:#fff;padding:16px;box-shadow:0 12px 30px #0f172a0d}.calendar-year-header div{display:grid;gap:4px}.calendar-year-header span{color:#718093;font-size:12px;font-weight:900;text-transform:uppercase}.calendar-year-header strong{font-size:20px}.calendar-management{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);gap:16px;align-items:start;border:1px solid #e5eaf0;border-radius:16px;background:#fff;padding:14px;box-shadow:0 12px 30px #0f172a0d}.calendar-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.danger-button{border-color:#fecaca;color:#b42318}.danger-solid-button{background:#dc2626}.year-calendar-panel{display:grid;gap:16px;border:1px solid #e5eaf0;border-radius:16px;background:#fff;padding:16px;box-shadow:0 12px 30px #0f172a0d}.year-calendar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.month-card,.calendar-stat-card,.calendar-modal{border:1px solid #e5eaf0;border-radius:16px;background:#fff}.month-card,.calendar-stat-card{padding:12px}.month-card h2,.calendar-reasons h2{margin-top:0}.month-card h2{margin-bottom:14px;font-size:20px}.month-weekdays,.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.month-weekdays{margin-bottom:8px}.month-weekdays span{color:#718093;font-size:12px;font-weight:900;text-align:center}.calendar-day{position:relative;display:grid;place-items:center;min-width:0;aspect-ratio:1;border:1px solid #e5eaf0;border-radius:8px;background:#f9fbfd;cursor:pointer;font-size:12px;font-weight:600}.calendar-day.selected{border-color:#5b4dff;box-shadow:0 0 0 2px #5b4dff24}.calendar-day.today{border-color:#13a37b;background:#e8f7ef}.calendar-day.today strong{position:absolute;left:50%;bottom:3px;transform:translate(-50%);color:#20794d;font-size:8px;font-weight:900;text-transform:uppercase}.calendar-day.locked{cursor:not-allowed;opacity:.42}.empty-day{border:0;background:transparent}.day-mark-stack{position:absolute;right:4px;bottom:4px;display:flex}.day-mark-stack i,.color-dot{display:inline-block;width:9px;height:9px;border-radius:50%}.day-mark-stack i+i{margin-left:-3px}.range-dot{position:absolute;top:4px;right:4px;width:6px;height:6px;border-radius:50%;background:#5b4dff}.legend-list,.reason-list,.reason-editor,.stat-reasons,.latest-mark-stack{display:grid;gap:8px}.calendar-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;border-top:1px solid #e5eaf0;padding-top:14px}.legend-list,.calendar-legend .reason-list{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px}.legend-list span,.reason-list span{display:inline-flex;align-items:center;gap:7px;color:#425466;font-size:13px;font-weight:800}.reason-list span,.reason-chip-button{border-radius:999px;background:#eef3f7;border:0;color:#425466;cursor:pointer;font-size:12px;font-weight:600;padding:5px 8px}.reason-editor{grid-template-columns:1fr auto}.calendar-reasons{display:grid;gap:10px}.calendar-reasons h2{font-size:16px}.calendar-helper{margin:0;color:#718093;font-size:12px;font-weight:800}.reason-editor input,.calendar-modal select,.calendar-modal textarea{border:1px solid #d8e0e8;border-radius:8px;padding:8px 10px}.calendar-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}.calendar-stat-card{display:grid;gap:10px}.calendar-stat-card>div:first-child{display:flex;align-items:center;gap:8px}.stat-reasons,.latest-mark-stack{color:#718093;font-size:12px;font-weight:800}.modal-backdrop{position:fixed;inset:0;z-index:20;display:grid;place-items:center;background:#0f172a47;padding:20px}.calendar-modal{display:grid;width:min(560px,100%);gap:14px;padding:18px}.calendar-modal label{display:grid;gap:6px;color:#718093;font-size:13px;font-weight:800}.calendar-modal textarea{min-height:90px}.modal-author-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.modal-author-list label{display:flex;align-items:center;gap:7px;color:#202a36}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.profile-table{--profile-columns: minmax(220px, 1.3fr) minmax(180px, 1.1fr) minmax(150px, 1fr) minmax(150px, 1fr) minmax(150px, 1fr) minmax(76px, .55fr) minmax(110px, .7fr) 300px;display:grid;overflow-x:auto}.profile-create-card{display:grid;grid-template-columns:repeat(4,minmax(130px,1fr)) 86px 120px auto;gap:12px;align-items:start;border:1px solid #e5eaf0;border-radius:14px;background:#f8fafc;margin:14px 0;padding:12px}.profile-create-card button{align-self:end}.site-user-create-card{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr)) auto;gap:12px;align-items:end;margin:16px 0;border:1px solid #e8edf4;border-radius:12px;background:#fbfcff;padding:12px}.site-users-table{--site-user-columns: minmax(220px, 1.2fr) minmax(180px, 1fr) minmax(120px, .7fr) minmax(120px, .7fr) minmax(160px, .9fr) 240px;display:grid;overflow-x:auto}.site-users-head,.site-user-row{display:grid;grid-template-columns:var(--site-user-columns);gap:10px;align-items:center;min-width:1120px;border-bottom:1px solid #eef2f7;padding:10px 12px}.site-users-head{color:#718093;font-size:12px;font-weight:900}.site-user-row strong{overflow:hidden;text-overflow:ellipsis}.profile-table-head,.profile-row{display:grid;grid-template-columns:var(--profile-columns);min-width:1480px;gap:12px;align-items:center;border-bottom:1px solid #e5eaf0;padding:10px 12px}.profile-table-head span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-row input,.profile-row .checkbox-cell,.profile-row .profile-readonly-cell{box-sizing:border-box;width:100%}.profile-readonly-cell{min-height:38px;display:flex;align-items:center;overflow:hidden;border:1px solid #e5eaf0;border-radius:8px;background:#f8fafc;color:#5c6b7a;font-weight:800;padding:8px 10px;text-overflow:ellipsis;white-space:nowrap}.profile-actions{display:grid;grid-template-columns:72px 100px 112px;gap:8px}.profile-actions button{width:100%;min-width:0;padding-inline:10px;white-space:nowrap}.profile-author-cell{display:grid;gap:3px}.profile-author-cell strong{color:#202a36}.profile-author-cell small{color:#718093;font-size:12px}.checkbox-cell{display:inline-flex;align-items:center;gap:8px;min-height:38px;border:1px solid #d8e0e8;border-radius:8px;background:#fff;padding:8px 10px;box-sizing:border-box;color:#202a36;font-weight:800;white-space:nowrap}.checkbox-cell input{width:auto;min-height:auto;margin:0}.hourly-chart-list{display:grid;gap:14px}.hourly-chart-card{display:grid;gap:8px}.hourly-chart-header{display:flex;justify-content:space-between;gap:12px}.hourly-chart-header strong,.hourly-chart-header span{display:block}.hourly-chart-header span{color:#718093;font-size:13px}.hourly-chart-scroll{overflow-x:hidden;overflow-y:hidden}.hourly-chart{display:grid;grid-template-columns:34px 32px minmax(0,1fr);grid-template-rows:150px 58px;column-gap:12px;row-gap:0}.hourly-chart-y-title{display:flex;align-items:center;justify-content:center;width:34px;height:150px;color:#33434d;font-size:16px;font-weight:800;line-height:1;writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap}.hourly-chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;height:150px;color:#7d8a93;font-size:12px;line-height:1;text-align:right}.hourly-chart-y-axis span{display:block;width:100%}.hourly-chart-bars{display:grid;grid-template-columns:repeat(24,minmax(0,1fr));gap:6px;align-items:end;height:150px;border-bottom:1px solid #d7e0e5;background-image:linear-gradient(to top,#e5ebef 1px,transparent 1px);background-size:100% 25%}.hourly-chart-column{display:flex;height:150px;align-items:flex-end}.hourly-chart-bar{display:flex;width:100%;height:150px;flex-direction:column-reverse;justify-content:flex-start;overflow:hidden;border-radius:4px 4px 0 0;background:#f2f5f7}.hourly-chart-bar.has-activity{background:#dfe5eb}.hourly-chart-x-axis{display:grid;grid-template-columns:repeat(24,minmax(0,1fr));gap:6px;align-items:start}.hourly-chart-x-axis span{display:flex;align-items:center;justify-content:center;height:46px;min-width:0}.hourly-chart-x-axis span span{display:flex;width:46px;justify-content:center;color:#60717d;font-size:10px;line-height:1;text-align:center;transform:rotate(-90deg);transform-origin:center center;white-space:nowrap}.hourly-chart-segment.active{background:#66c98f}.hourly-chart-segment.overtime{background:#8b5cf6}.hourly-chart-segment.break{background:#4fa4ff}.hourly-chart-segment.idle{background:#ffcf75}.hourly-chart-legend{display:flex;justify-content:center;gap:18px;margin-top:-10px;color:#33434d}.hourly-chart-legend span{display:inline-flex;align-items:center;gap:7px}.hourly-chart-legend i{display:inline-block;width:14px;height:14px;border-radius:3px}.hourly-chart-legend i.active{background:#66c98f}.hourly-chart-legend i.overtime{background:#8b5cf6}.hourly-chart-legend i.break{background:#4fa4ff}.hourly-chart-legend i.idle{background:#ffcf75}@media(max-width:900px){.app-frame{grid-template-columns:1fr}.sidebar{position:static;display:block;height:auto;padding:14px}.sidebar-session-card{margin-top:14px}.side-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.workspace{padding:18px}.workspace-topbar,.topbar-actions,.toolbar{align-items:stretch;flex-direction:column}.date-range-group,.date-range-control,.date-presets{flex-wrap:wrap;border-radius:8px}.activity-grid,.content-grid{grid-template-columns:1fr}}
