*{box-sizing:border-box}:root{color:#162033;background:#f2f5f8;font-family:Segoe UI,Arial,sans-serif}body{margin:0;min-width:360px;background:linear-gradient(135deg,rgba(47,111,237,.08),transparent 32%),linear-gradient(315deg,rgba(20,184,166,.09),transparent 26%),#f2f5f8}button,input{font:inherit}button{border:0;cursor:pointer}.loginShell{min-height:100vh;display:grid;place-items:center;padding:24px}.loginPanel{width:min(100%,430px);padding:28px;display:grid;gap:16px;border:1px solid #dce4ed;border-radius:8px;background:#fff;box-shadow:0 18px 38px #1620331f}.brandMark{width:44px;height:44px;display:inline-grid;place-items:center;border-radius:8px;background:#2f6fed;color:#fff;font-weight:800}h1,h2,p{margin:0}.loginPanel h1{font-size:28px}.loginPanel p,.pageHeader p,.panelHeader span,.sessionItem span,.consentBox span,.screenshotRow span,.empty{color:#667085}label{display:grid;gap:6px;color:#4b5563;font-size:14px}input{height:42px;padding:0 12px;border:1px solid #d5dfeb;border-radius:8px}.loginPanel button{min-height:44px;border-radius:8px;color:#fff;background:#2f6fed;font-weight:700}.shell{min-height:100vh;display:grid;grid-template-columns:260px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;padding:24px;display:flex;flex-direction:column;gap:18px;color:#f8fafc;background:#162033}.sidebar p{margin-top:6px;color:#b7c3d4}.sideButton{min-height:42px;display:flex;align-items:center;justify-content:center;gap:10px;border-radius:8px;color:#dbe5f2;background:#ffffff12}.sideButton:hover{color:#fff;background:#2f6fed}.nav{display:grid;gap:8px}.nav button{min-height:42px;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:#dbe5f2;background:#ffffff12}.nav button:hover,.nav button.active{color:#fff;background:#2f6fed}.sideButton.logout{margin-top:auto}.content{padding:28px}.pageHeader{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:20px}.pageHeader span{display:block;color:#2f6fed;font-weight:800;font-size:13px;text-transform:uppercase}.pageHeader h1{margin-top:4px;font-size:30px}.error{padding:12px 14px;margin-bottom:16px;border:1px solid #fecaca;border-radius:8px;background:#fff1f2;color:#9f1239}.statsGrid{display:grid;grid-template-columns:repeat(6,minmax(140px,1fr));gap:14px;margin-bottom:16px}.statCard,.panel{border:1px solid #dce4ed;border-radius:8px;background:#fffffff5;box-shadow:0 12px 28px #16203312}.statCard{min-height:118px;padding:16px;display:grid;align-content:space-between;gap:10px;border-top:4px solid #64748b}.statCard small{color:#667085}.statCard strong{min-width:0;font-size:22px;overflow-wrap:anywhere}.statIcon{width:34px;height:34px;display:grid;place-items:center;border-radius:8px;color:#fff;background:#64748b}.blue{border-top-color:#2f6fed}.green{border-top-color:#16a34a}.amber{border-top-color:#d97706}.rose{border-top-color:#e11d48}.violet{border-top-color:#7c3aed}.blue .statIcon{background:#2f6fed}.green .statIcon{background:#16a34a}.amber .statIcon{background:#d97706}.rose .statIcon{background:#e11d48}.violet .statIcon{background:#7c3aed}.pageGrid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:16px;margin-bottom:16px}.panel{overflow:hidden}.tableWrap{width:100%;overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px 14px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:middle;font-size:14px;white-space:nowrap}th{background:#f8fafc;color:#5f6b7a;font-weight:700}tbody tr:hover{background:#f6f9fc}.timesheetFormPanel{margin-bottom:16px}.timesheetForm{padding:16px;display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:14px}.switchLabel{min-height:42px;align-self:end;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 12px;border:1px solid #d5dfeb;border-radius:8px;background:#fff}.switchLabel input{width:18px;height:18px}input:disabled{color:#94a3b8;background:#f1f5f9}.dayPicker{grid-column:1 / -1;display:grid;gap:8px;color:#4b5563;font-size:14px}.dayPicker>div,.dayTags,.rowActions,.formActions{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.day{min-height:34px;padding:0 12px;border:1px solid #d5dfeb;border-radius:8px;color:#475569;background:#fff}.day.active{border-color:#2f6fed;color:#fff;background:#2f6fed}.formActions{grid-column:1 / -1;justify-content:flex-end}.formActions button,.rowActions button{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;color:#fff;background:#2f6fed;font-weight:700}.formActions button{padding:0 14px}.formActions .secondaryButton{color:#475569;background:#e9eef5}.rowActions button{width:34px}.rowActions .dangerButton{background:#e11d48}.dayTags span{min-height:26px;display:inline-flex;align-items:center;padding:0 8px;border-radius:8px;color:#334155;background:#e9eef5;font-size:12px;font-weight:700}.statusPill{min-height:26px;display:inline-flex;align-items:center;padding:0 9px;border-radius:999px;font-size:12px;font-weight:800}.statusPill.editing{color:#92400e;background:#fef3c7}.statusPill.pending{color:#1d4ed8;background:#dbeafe}.statusPill.pending_edit,.statusPill.pending_delete{color:#7c2d12;background:#ffedd5}.statusPill.approved{color:#166534;background:#dcfce7}.panelHeader{min-height:70px;padding:16px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid #e7edf4}.barChart{height:280px;padding:18px;display:grid;grid-template-columns:repeat(12,minmax(34px,1fr));align-items:end;gap:12px;overflow-x:auto}.barGroup{min-width:38px;display:grid;justify-items:center;gap:8px}.bars{height:210px;width:100%;display:flex;align-items:end;justify-content:center;gap:4px;padding:8px 4px;border-radius:8px;background:#f3f7fb}.bar{width:8px;min-height:4px;border-radius:8px 8px 2px 2px}.bar.left{background:#d97706}.bar.right{background:#e11d48}.bar.moves{background:#0284c7}.bar.keys{background:#7c3aed}.barGroup small{color:#64748b;font-size:11px}.sessionList,.screenshotList{padding:14px;display:grid;gap:12px}.sessionItem,.screenshotRow,.consentBox{min-height:58px;padding:12px;display:grid;align-items:center;gap:12px;border:1px solid #edf2f7;border-radius:8px;background:#fff}.sessionItem{grid-template-columns:minmax(180px,1fr) auto auto}.sessionItem span,.sessionItem strong{display:block}.sessionItem span{margin-top:4px;font-size:12px}.pill{display:inline-flex;align-items:center;min-height:24px;padding:4px 8px;border-radius:999px;color:#475569;background:#e9eef5;font-size:12px;font-style:normal;font-weight:700;text-transform:capitalize}.pill.online{color:#166534;background:#dcfce7}.consentBox{grid-template-columns:auto 1fr;color:#2f6fed;background:#f5f9ff}.consentBox strong,.consentBox span{display:block}.screenshotRow{grid-template-columns:1fr auto}.empty,.emptyState{padding:18px}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1200px){.statsGrid{grid-template-columns:repeat(3,minmax(160px,1fr))}.pageGrid{grid-template-columns:1fr}.timesheetForm{grid-template-columns:repeat(2,minmax(180px,1fr))}}@media(max-width:820px){.shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.content{padding:18px}.pageHeader{align-items:stretch;flex-direction:column}.statsGrid{grid-template-columns:1fr 1fr}.sessionItem,.screenshotRow{grid-template-columns:1fr}}@media(max-width:560px){.statsGrid,.timesheetForm{grid-template-columns:1fr}}
