:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5;color:#0f172a;background:#f8fafc}*{box-sizing:border-box}body{margin:0}a{color:inherit;text-decoration:none}.container{max-width:1100px;margin:0 auto;padding:16px}.containerWide{max-width:1600px}.topbar{background:#0f172a;color:#fff}.nav{display:flex;gap:12px;align-items:center}.navSpacer{flex:1}.navUser{opacity:.85;font-size:14px}.nav a{padding:8px 10px;border-radius:8px;opacity:.9}.nav a.active{background:#ffffff1f;opacity:1}.appShell{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 56px)}.appShellWide{grid-template-columns:260px 1fr}.sidebar{background:#0b1220;padding:16px 12px;display:flex;flex-direction:column;gap:8px}.sidebar a{padding:10px 12px;border-radius:10px;color:#e2e8f0;opacity:.9}.sidebar a.active{background:#94a3b82e;opacity:1}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.btn{margin-top:12px;padding:10px 14px;border-radius:10px;border:none;background:#0f172a;color:#fff;cursor:pointer}.btn:disabled{opacity:.6;cursor:not-allowed}.btnGhost{padding:8px 12px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;cursor:pointer}.row{display:flex;gap:12px;flex-wrap:wrap}.checkboxLabel{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid #e2e8f0;border-radius:10px;background:#fff}.formGrid3{display:grid;grid-template-columns:repeat(3,minmax(240px,1fr));gap:12px 16px;align-items:end}.formGrid2{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:12px 16px;align-items:end}.field{display:flex;flex-direction:column;gap:6px;min-width:0}.field>input,.field>select,.field>textarea{width:100%;min-width:0}.gridSpanAll{grid-column:1 / -1}.gridInline{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.simpleTable{width:100%;border-collapse:collapse}.simpleTable th,.simpleTable td{text-align:left;padding:10px 8px;border-bottom:1px solid #e2e8f0;font-size:14px}.loginPage{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(120deg,#f8fafc,#e2e8f0);padding:20px}.loginCard{width:min(420px,92vw)}.muted{color:#64748b}@media(max-width:980px){.formGrid3{grid-template-columns:repeat(2,minmax(240px,1fr))}.appShell,.appShellWide{grid-template-columns:1fr}.sidebar{flex-direction:row;flex-wrap:wrap}}@media(max-width:640px){.formGrid3,.formGrid2{grid-template-columns:1fr}}input:not([type=checkbox]):not([type=radio]),select{padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;min-width:220px;background:#fff}input[type=checkbox],input[type=radio]{min-width:0;width:16px;height:16px;padding:0}textarea{padding:10px 12px;border-radius:10px;border:1px solid #cbd5e1;min-width:220px;background:#fff;font-family:inherit;line-height:1.5}.comboWrap{position:relative;min-width:0}.comboList{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:20;background:#fff;border:1px solid #e2e8f0;border-radius:10px;max-height:260px;overflow:auto}.comboItem{padding:8px 10px;cursor:pointer;-webkit-user-select:none;user-select:none}.comboItemActive{background:#f8fafc}.filterWrap{position:relative;display:inline-flex;align-items:center;gap:8px}.filterBtn{padding:4px 8px;border-radius:8px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;cursor:pointer}.filterPopover{position:absolute;top:calc(100% + 6px);right:0;z-index:30;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px;width:280px}.filterTitle{font-size:12px;color:#475569;margin-bottom:8px}.filterList{border:1px solid #e2e8f0;border-radius:10px;max-height:240px;overflow:auto;padding:6px;background:#fff}.filterItemRow{display:flex;align-items:center;gap:8px;padding:4px 6px}.filterActions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}button{padding:10px 12px;border-radius:10px;border:1px solid #0f172a;background:#0f172a;color:#fff;cursor:pointer}button.secondary{background:#fff;color:#0f172a}table{width:100%;border-collapse:collapse}.tableScrollX{overflow:auto;max-height:70vh;max-width:100%;position:relative;background:#fff;border:1px solid #e2e8f0;border-radius:10px}.stickyTable{border-collapse:separate;border-spacing:0;width:max-content;min-width:100%}.stickyTable thead th{background:#f8fafc;position:sticky;top:0;z-index:3}.stickyCell{position:sticky;background:#fff;z-index:2}.stickyHead{z-index:6}.stickyShadow{box-shadow:1px 0 #e2e8f0}.stickyTable{--sticky-col-0: 110px;--sticky-col-1: 90px;--sticky-col-2: 170px;--sticky-col-3: 220px;--sticky-col-4: 180px}.reportingStickyTable{--sticky-col-0: 110px;--sticky-col-1: 240px}.stickyCol0{left:0;width:var(--sticky-col-0);min-width:var(--sticky-col-0);max-width:var(--sticky-col-0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stickyCol1{left:var(--sticky-col-0);width:var(--sticky-col-1);min-width:var(--sticky-col-1);max-width:var(--sticky-col-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stickyCol2{left:calc(var(--sticky-col-0) + var(--sticky-col-1));width:var(--sticky-col-2);min-width:var(--sticky-col-2);max-width:var(--sticky-col-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stickyCol3{left:calc(var(--sticky-col-0) + var(--sticky-col-1) + var(--sticky-col-2));width:var(--sticky-col-3);min-width:var(--sticky-col-3);max-width:var(--sticky-col-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stickyCol4{left:calc(var(--sticky-col-0) + var(--sticky-col-1) + var(--sticky-col-2) + var(--sticky-col-3));width:var(--sticky-col-4);min-width:var(--sticky-col-4);max-width:var(--sticky-col-4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}th,td{text-align:left;padding:10px;border-bottom:1px solid #e2e8f0;font-size:14px}.muted{color:#475569}.error{color:#b91c1c}
