:root{color:#111827;background:#eef2f5;--ink: #101820;--line: #d8e0e7;--muted: #65758a;--brand: #0f766e;--brand-dark: #134e4a;--danger: #a33131;--sidebar: #111a24;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}button:disabled,input:disabled{cursor:not-allowed;opacity:.55}.login-shell{align-items:center;background:#eef2f6;display:flex;min-height:100vh;justify-content:center;padding:24px}.login-panel,.panel{background:#fff;border:1px solid #dce2e8;border-radius:8px;box-shadow:0 10px 30px #1f2a3714}.login-panel{display:grid;gap:16px;max-width:380px;padding:24px;width:100%}.brand-row{align-items:center;display:flex;gap:10px}.brand-row h1{font-size:24px;margin:0}label{display:grid;gap:6px;font-size:14px;font-weight:700}input,select{border:1px solid #cdd6df;border-radius:6px;color:#17202a;min-height:38px;padding:8px 10px;width:100%}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{align-content:start;background:#131d29;color:#fff;display:grid;gap:14px;padding:18px}.sidebar-nav{display:grid;gap:8px;margin-top:8px}.nav-button{align-items:center;background:transparent;border:1px solid transparent;border-radius:7px;color:#cbd5e1;display:flex;gap:10px;min-height:42px;padding:9px 11px;text-align:left}.nav-button:hover,.nav-button.active{background:#edf2f7;border-color:#edf2f7;color:#111827}.workspace{display:grid;gap:16px;padding:20px 22px}.topline{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}.metric{align-items:center;background:#fff;border:1px solid #dce2e8;border-radius:8px;display:grid;gap:6px;grid-template-columns:auto 1fr auto;min-height:58px;padding:12px 14px}.metric svg{color:#176b5b}.grid-layout,.agents-layout{display:grid;gap:16px;grid-template-columns:minmax(240px,320px) minmax(260px,360px) 1fr}.games-layout{display:grid;gap:16px;grid-template-columns:minmax(300px,380px) minmax(0,1fr)}.users-layout{display:grid;max-width:980px}.control-panel{gap:18px}.play-panel{min-height:calc(100vh - 132px)}.panel{align-content:start;display:grid;gap:14px;padding:16px}.panel-heading.compact-heading{margin-top:4px}.wide-panel{grid-row:span 2}.panel-heading{align-items:center;display:flex;gap:10px;justify-content:space-between}.panel-heading h2{font-size:18px;margin:0}.inline-form{display:grid;gap:8px;grid-template-columns:1fr 40px}.stack-form{display:grid;gap:8px}.user-form{display:grid;gap:8px;grid-template-columns:minmax(160px,1fr) minmax(180px,1fr) 140px auto}.primary-button,.secondary-button,.icon-button,.text-button{align-items:center;border-radius:6px;display:inline-flex;gap:8px;justify-content:center;min-height:38px;padding:8px 12px}.danger-text{color:#a33131}.primary-button{background:#176b5b;border:1px solid #176b5b;color:#fff}.primary-button:hover{background:#125648}.secondary-button{background:transparent;border:1px solid rgba(255,255,255,.35);color:#fff}.secondary-button:hover{background:#ffffff14}.icon-button{background:#eef2f6;border:1px solid #ccd5df;color:#17202a;min-width:38px;padding:8px}.icon-button:hover{background:#e2e8f0}.danger-button{background:#fff0ed;border-color:#efb2a8;color:#a33131}.text-button{background:transparent;border:0;color:#176b5b;min-height:30px;padding:4px 0}.row-button{color:#17202a;justify-content:flex-start;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.row-actions{display:flex!important;flex-shrink:0;gap:6px}.list{display:grid;gap:8px;max-height:320px;overflow:auto}.list-row{align-items:center;border:1px solid #e1e7ee;border-radius:6px;display:flex;gap:8px;justify-content:space-between;min-height:46px;padding:8px 10px}.list-row:hover,.history-row:hover{background:#f8fafc}.selected-row{background:#f2fbf8;border-color:#176b5b;box-shadow:inset 0 0 0 1px #176b5b}.list-row div{display:grid;min-width:0}.list-row span{color:#65758a;font-size:12px}.subtle-text{color:#65758a;display:block;font-size:13px;margin-top:4px}.live-actions{align-items:center;display:flex;gap:8px}.match-meta{align-items:center;background:#f8fafc;border:1px solid #e1e7ee;border-radius:6px;display:grid;gap:8px 12px;grid-template-columns:auto minmax(0,1fr);padding:10px}.match-meta span{color:#65758a;font-size:12px;font-weight:700;text-transform:uppercase}.match-meta code{overflow-wrap:anywhere}.board{aspect-ratio:7 / 6;background:#2363a8;border:6px solid #1a4f87;border-radius:8px;display:grid;gap:8px;max-width:720px;padding:10px;width:100%}.board-cell{align-items:center;background:#f7fbff;border-radius:50%;display:flex;justify-content:center;min-width:0}.disc{border-radius:50%;display:inline-block;height:80%;width:80%}.player-1{background:#e74c3c}.player-2{background:#f1c40f}.player-strip{display:flex;flex-wrap:wrap;gap:8px}.player{align-items:center;border:1px solid #dce2e8;border-radius:6px;display:flex;gap:8px;padding:8px 10px}.player.active{border-color:#176b5b;box-shadow:inset 0 0 0 1px #176b5b}.player .disc{height:18px;width:18px}.status-pill{border-radius:999px;font-size:12px;font-weight:700;padding:4px 8px;text-transform:uppercase}.status-created{background:#eef2f6}.status-active{background:#dff5ef;color:#176b5b}.status-finished{background:#f7e7df;color:#8a3d20}.count-pill{background:#eef2f6;border-radius:999px;color:#475569;font-size:12px;font-weight:800;padding:4px 8px}.history-block{border-top:1px solid #e1e7ee;display:grid;gap:12px;padding-top:14px}.history-list{max-height:360px}.history-row{align-items:center;background:#fff;border:1px solid #e1e7ee;border-radius:6px;color:#17202a;display:flex;gap:8px;justify-content:space-between;min-height:48px;padding:8px 10px;text-align:left}.history-row div{display:grid;min-width:0}.history-row span{color:#65758a;font-size:12px}.user-list{max-height:560px}.user-row{align-items:center;border:1px solid #e1e7ee;border-radius:6px;display:grid;gap:8px;grid-template-columns:minmax(180px,1fr) auto auto;min-height:52px;padding:8px 10px}.user-row:has(input){grid-template-columns:minmax(160px,1fr) minmax(180px,1fr) 140px auto auto}.user-row span{color:#65758a;font-size:12px}.dot{background:#9aa7b5;border-radius:50%;height:10px;width:10px}.dot.online{background:#17845f}.error-text,.notice{color:#a33131;margin:0}.token-banner{align-items:center;background:#fff8dc;border:1px solid #ead36f;border-radius:8px;display:flex;flex-wrap:wrap;gap:8px;padding:12px}.token-banner code{flex:1;overflow-wrap:anywhere}.dismiss-button{margin-left:auto}.token-row{align-items:center;border:1px solid #e1e7ee;border-radius:6px;display:grid;gap:8px;grid-template-columns:minmax(0,1fr) auto;padding:8px 10px}.token-row code{overflow-wrap:anywhere}.small-empty{color:#65758a;font-size:13px;padding:8px 0}.empty-state{align-items:center;border:1px dashed #cdd6df;border-radius:8px;color:#65758a;display:flex;min-height:220px;justify-content:center}@media(max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{align-items:center;grid-template-columns:1fr auto auto}.grid-layout,.agents-layout,.games-layout,.user-form,.user-row,.user-row:has(input){grid-template-columns:1fr}.play-panel{min-height:auto}}@media(max-width:700px){.workspace{padding:12px}.topline{grid-template-columns:1fr 1fr}.sidebar{grid-template-columns:1fr}}input:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0f766e24;outline:none}.sidebar{background:var(--sidebar)}.workspace{align-content:start;padding-bottom:28px}.panel{border-color:var(--line);box-shadow:0 12px 30px #15233012;overflow:hidden}.metric{border-color:var(--line);gap:8px;height:62px;min-height:0}.metric svg,.text-button{color:var(--brand)}.metric span{color:#334155}.metric strong{font-size:20px}.primary-button{background:var(--brand);border-color:var(--brand)}.primary-button:hover{background:var(--brand-dark)}.danger-text,.error-text,.notice{color:var(--danger)}.selected-row{background:#eefaf7;border-color:var(--brand);box-shadow:inset 0 0 0 1px var(--brand)}.user-row{gap:10px;grid-template-columns:minmax(0,1fr) auto auto}.user-row:has(input){grid-template-columns:minmax(150px,1fr) minmax(170px,1fr) 132px auto auto}.user-row div{display:grid;gap:2px;min-width:0}.user-row strong,.user-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-stack{display:grid;gap:8px;max-width:min(420px,calc(100vw - 32px));position:fixed;right:18px;top:18px;z-index:20}.toast{align-items:center;animation:toast-enter .22s ease-out both;background:#fff;border:1px solid var(--line);border-left:4px solid #64748b;border-radius:8px;box-shadow:0 16px 36px #0f172a2e;display:flex;gap:12px;justify-content:space-between;min-height:46px;padding:10px 12px;transform-origin:top right}.toast-closing{animation:toast-exit .2s ease-in both}.toast-success{border-left-color:var(--brand)}.toast-error{border-left-color:var(--danger)}.toast-close{align-items:center;background:transparent;border:0;color:#475569;display:inline-flex;justify-content:center;padding:2px}@keyframes toast-enter{0%{opacity:0;transform:translate3d(16px,-8px,0) scale(.98)}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes toast-exit{0%{opacity:1;transform:translateZ(0) scale(1)}to{opacity:0;transform:translate3d(16px,-6px,0) scale(.98)}}@media(prefers-reduced-motion:reduce){.toast,.toast-closing{animation:none}}@media(max-width:1100px){.sidebar{align-items:stretch;grid-template-columns:1fr;position:sticky;top:0;z-index:10}.sidebar-nav{display:flex;flex-wrap:wrap;margin-top:0}.nav-button{flex:1 1 150px}}@media(max-width:700px){.topline{grid-template-columns:1fr 1fr}.metric{height:56px;padding:10px}.metric strong{font-size:18px}.inline-form,.user-form,.user-row,.user-row:has(input),.match-meta{grid-template-columns:1fr}.list-row,.history-row{align-items:stretch;flex-direction:column}.row-actions{justify-content:flex-end}.board{border-width:4px;gap:5px;padding:7px}.toast-stack{left:12px;max-width:none;right:12px;top:12px}}
