:root{color:#17201c;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7f8f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}button{cursor:pointer}.app-shell{grid-template-columns:72px minmax(0,1fr);min-height:100vh;display:grid}.side-rail{color:#f7f8f5;background:#17201c;flex-direction:column;align-items:center;gap:14px;padding:18px 12px;display:flex}.brand-mark,.rail-button{border-radius:8px;place-items:center;width:42px;height:42px;display:grid}.brand-mark{color:#17201c;background:#edb230;margin-bottom:10px}.rail-button{color:#b8c5bd;background:0 0;border:1px solid #0000}.rail-button.active,.rail-button:hover{color:#fff;background:#26342f;border-color:#385047}.workspace{flex-direction:column;gap:22px;padding:28px;display:flex;overflow:hidden}.topbar,.panel-heading{justify-content:space-between;align-items:center;gap:20px;display:flex}.topbar h1,.panel-heading h2{color:#17201c;letter-spacing:0;margin:0}.topbar h1{font-size:38px;line-height:1.05}.topbar p,.panel-heading p{color:#66746d;margin:8px 0 0}.refresh-button,.state-panel button{color:#fff;background:#1c8f73;border:0;border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 14px;font-size:14px;font-weight:700;display:inline-flex}.summary-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.metric,.status-panel,.path-panel,.state-panel{background:#fff;border:1px solid #dce3de;border-radius:8px;box-shadow:0 16px 34px #17201c0f}.metric{flex-direction:column;justify-content:space-between;min-height:126px;padding:18px;display:flex}.metric span,.metric small,.info-line span{color:#66746d;font-size:13px}.metric strong{color:#17201c;letter-spacing:0;font-size:27px;line-height:1}.status-panel{padding:20px}.toolbar{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.search-box{color:#66746d;background:#f7f8f5;border:1px solid #dce3de;border-radius:8px;align-items:center;gap:8px;min-width:min(320px,100%);height:40px;padding:0 12px;display:inline-flex}.search-box input{color:#17201c;background:0 0;border:0;outline:0;width:100%;font-size:14px}.segmented{background:#f7f8f5;border:1px solid #dce3de;border-radius:8px;height:40px;display:inline-flex;overflow:hidden}.segmented button{color:#66746d;background:0 0;border:0;border-right:1px solid #dce3de;min-width:72px;font-size:13px;font-weight:700}.segmented button:last-child{border-right:0}.segmented .selected{color:#fff;background:#17201c}.table-frame{border:1px solid #e8ede9;border-radius:8px;margin-top:18px;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:860px}th,td{text-align:left;white-space:nowrap;border-bottom:1px solid #e8ede9;padding:14px 16px;font-size:14px}th{color:#66746d;text-transform:uppercase;letter-spacing:0;background:#f7f8f5;font-size:12px}td{color:#2e3934}tbody tr:last-child td{border-bottom:0}.game-cell,.status-pill,.state-panel{align-items:center;gap:8px;display:inline-flex}.game-cell{font-weight:800}.status-pill{white-space:normal;border-radius:8px;max-width:320px;min-height:28px;padding:0 9px;font-size:12px;font-weight:800}.status-pill.cached{color:#11735a;background:#e8f6f0}.status-pill.missing{color:#8d5c00;background:#fff4dc}.empty-state{color:#66746d;text-align:center;padding:34px}.path-panel{gap:12px;padding:18px;display:grid}.info-line{grid-template-columns:140px minmax(0,1fr);align-items:center;gap:14px;display:grid}.info-line code{overflow-wrap:anywhere;color:#2e3934;min-width:0;font-size:13px}.state-panel{color:#66746d;justify-content:center;min-height:180px;font-weight:700}.state-panel.error{color:#9f3434}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=860px){.app-shell{grid-template-columns:1fr}.side-rail{flex-direction:row;justify-content:flex-start;padding:10px 14px}.brand-mark{margin:0 8px 0 0}.workspace{padding:18px}.topbar h1{font-size:30px}.topbar,.panel-heading{flex-direction:column;align-items:flex-start}.summary-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.toolbar,.search-box,.segmented{width:100%}.segmented button{flex:1}}@media (width<=540px){.summary-strip,.info-line{grid-template-columns:1fr}}
