*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:#eef2f4;color:#1f252b;font-family:Inter,Vazirmatn,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,select{font:inherit}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{min-height:70px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:11px 16px;background:#fff;border-bottom:1px solid #d9e0e5}.brand{min-width:235px;display:grid;gap:1px;direction:ltr}.brand span{color:#66717c;font-size:12px}.brand strong{color:#111820;font-size:21px;letter-spacing:0}.controls{display:flex;align-items:end;justify-content:flex-end;gap:9px;flex-wrap:wrap}.controls label{min-width:104px;display:grid;gap:4px}.controls label span{color:#5d6874;font-size:11px}select{height:36px;min-width:0;border:1px solid #c7d0d8;border-radius:6px;background:#fff;color:#20262d;padding:0 10px}button{height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid #146c59;border-radius:6px;background:#146c59;color:#fff;padding:0 13px;cursor:pointer;white-space:nowrap}button.secondary{border-color:#2d4663;background:#2d4663}button.live-toggle{border-color:#9aa8b4;background:#f7f9fa;color:#2c3640}button.live-toggle.active{border-color:#0f8b65;background:#0f8b65;color:#fff}button:disabled{cursor:wait;opacity:.65}.workspace{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 335px}.chart-wrap{min-width:0;min-height:calc(100vh - 70px);display:flex;flex-direction:column;background:#fff}.chart-head{min-height:50px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid #e2e7eb}.chart-head div{display:flex;align-items:baseline;gap:12px;min-width:0}.chart-head b{color:#111820;font-size:16px;direction:ltr}.chart-head span,.chart-head p{color:#64707c;font-size:12px;margin:0}.legend-row{min-height:38px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:7px 14px;border-bottom:1px solid #edf0f2;background:#fbfcfc}.legend-item,.legend-note{display:inline-flex;align-items:center;gap:6px;color:#58636e;font-size:12px}.legend-item:before{content:"";width:22px;height:10px;border-radius:2px;display:inline-block}.legend-item.current:before{background:linear-gradient(90deg,#08966f 0 50%,#d33f49 50% 100%)}.legend-item.past:before{background:#2563eb2e;border:1px solid rgba(37,99,235,.28)}.legend-item.future:before{background:#2563eb61;border:1px solid rgba(37,99,235,.48)}.legend-note{margin-right:auto}.chart-stage{position:relative;flex:1;min-height:650px;overflow:hidden}.chart-surface{position:absolute;inset:0;width:100%;height:100%}.now-marker{position:absolute;top:0;bottom:0;width:0;border-left:2px solid rgba(17,24,39,.72);pointer-events:none;z-index:3}.now-marker span{position:absolute;top:10px;transform:translate(-50%);background:#111827;color:#fff;border-radius:4px;padding:3px 7px;font-size:11px;white-space:nowrap}.error-line{padding:10px 16px;color:#9f1d1d;background:#fff2f2;border-top:1px solid #f0c4c4;font-size:13px}.side-panel{min-height:calc(100vh - 70px);border-right:1px solid #d9e0e5;background:#f8fafb;overflow:auto}.panel-title{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 14px;border-bottom:1px solid #e1e7eb;background:#fff}.panel-title strong{color:#18212b;font-size:14px}.panel-title span{color:#687480;font-size:12px}.match-list{display:grid;gap:10px;padding:10px}.match-card{border:1px solid #dfe6eb;border-radius:8px;padding:10px;background:#fff}.match-top{display:flex;align-items:center;gap:8px;margin-bottom:10px}.match-top b{direction:ltr;color:#17202a;font-size:13px}.rank{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:#fff;border-radius:50%;font-size:12px;flex:0 0 auto}dl{display:grid;grid-template-columns:1fr 1fr;gap:8px 10px;margin:0}dt{color:#6d7884;font-size:11px;margin-bottom:2px}dd{margin:0;color:#242b33;direction:ltr;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1080px){.topbar{align-items:stretch;flex-direction:column}.brand{min-width:0}.controls{justify-content:stretch}.controls label,.controls button{flex:1 1 112px}.workspace{grid-template-columns:1fr}.chart-stage{min-height:590px}.side-panel{min-height:0;border-right:0;border-top:1px solid #d9e0e5}}@media(max-width:620px){.topbar{padding:10px}.controls{gap:8px}.controls label,.controls button{flex-basis:calc(50% - 4px)}.chart-head{align-items:flex-start;flex-direction:column}.chart-head div{flex-direction:column;gap:2px}.legend-note{margin-right:0}.chart-stage{min-height:520px}}
