:root{--bg: #05070d;--fg: #e8edf5;--muted: rgba(232, 237, 245, .55);--muted-2: rgba(232, 237, 245, .4);--atp: #3a7bd5;--wta: #e94584;--gs: #f5c14b;--itf-w: #a78bfa;--itf-m: #4ade80;--live: #ff5e7c;--line: rgba(255, 255, 255, .08);--line-2: rgba(255, 255, 255, .16);--panel: rgba(8, 11, 20, .92)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;height:100dvh;overflow:hidden;background:var(--bg);color:var(--fg);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none;touch-action:pan-x pan-y}#globe{position:absolute;inset:0;cursor:grab}#globe:active{cursor:grabbing}#globe.busy{cursor:pointer}.brand{position:absolute;top:clamp(20px,3vw,32px);left:clamp(20px,3vw,28px);display:flex;align-items:center;gap:10px;font-weight:600;font-size:17px;letter-spacing:-.01em;z-index:12}.brand-dot{width:8px;height:8px;border-radius:999px;background:linear-gradient(135deg,var(--atp),var(--wta));box-shadow:0 0 12px #3a7bd599}.toolbar{position:absolute;top:clamp(20px,3vw,32px);left:50%;transform:translate(-50%);z-index:12;display:flex;align-items:center;gap:6px;background:#05070db3;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:999px;padding:5px;box-shadow:0 8px 30px #0006}.toolbar .divider{width:1px;height:22px;background:var(--line);margin:0 4px}.seg{display:flex;gap:1px}.seg button{background:transparent;color:var(--muted);border:none;font:inherit;font-size:12.5px;font-weight:500;padding:7px 14px;border-radius:999px;cursor:pointer;transition:color .15s ease,background .15s ease;white-space:nowrap}.seg button:hover{color:var(--fg)}.seg button.on{background:#ffffff17;color:var(--fg)}.chips{display:flex;gap:4px}.chip{background:transparent;color:var(--muted);border:1px solid transparent;font:inherit;font-size:12px;font-weight:500;padding:6px 11px;border-radius:999px;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;gap:6px}.chip:hover{color:var(--fg)}.chip.on{color:var(--fg);background:#ffffff0f}.chip .sw{width:6.5px;height:6.5px;border-radius:999px;flex-shrink:0;opacity:.7}.chip.on .sw{opacity:1}.chip[data-cat=ATP] .sw{background:var(--atp)}.chip[data-cat=WTA] .sw{background:var(--wta)}.chip[data-cat=GS] .sw{background:var(--gs)}.chip[data-cat=ITF_W] .sw{background:var(--itf-w)}.chip[data-cat=ITF_M] .sw{background:var(--itf-m)}.chip .sub{font-size:9.5px;font-weight:600;letter-spacing:.05em;opacity:.65;margin-left:1px}.tally{font-size:11.5px;font-variant-numeric:tabular-nums;color:var(--muted);padding:6px 14px 6px 10px;white-space:nowrap}.tally strong{color:var(--fg);font-weight:600}.hover-card{position:absolute;z-index:14;background:#05070df0;border:1px solid var(--line-2);border-radius:10px;padding:9px 12px;backdrop-filter:blur(10px);pointer-events:none;transform:translate(-50%,calc(-100% - 14px));opacity:0;transition:opacity .12s ease;white-space:nowrap;box-shadow:0 10px 30px #00000080}.hover-card.show{opacity:1}.hover-card .name{font-size:13.5px;font-weight:600;margin-bottom:2px}.hover-card .meta{font-size:11px;color:var(--muted);letter-spacing:.02em}.hover-card.live .name:after{content:" · LIVE";color:var(--live);font-weight:600;font-size:10.5px;letter-spacing:.04em}.panel{position:absolute;top:0;right:0;bottom:0;width:min(460px,92vw);background:#080b14f0;backdrop-filter:blur(20px);border-left:1px solid var(--line);z-index:13;transform:translate(101%);transition:transform .32s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;overflow:hidden}.panel.open{transform:translate(0)}.panel .hero{position:relative;padding:32px 28px 18px;background:radial-gradient(130% 90% at 100% 0%,var(--surface-tint, rgba(58, 123, 213, .3)) 0%,transparent 62%)}.panel[data-surface=clay]{--surface-tint: rgba(214, 109, 60, .32)}.panel[data-surface=grass]{--surface-tint: rgba(74, 222, 128, .22)}.panel[data-surface=hard]{--surface-tint: rgba(58, 123, 213, .28)}.panel .close{position:absolute;top:22px;right:22px;width:30px;height:30px;font-size:15px}.panel .eyebrow{display:flex;gap:10px;align-items:center;font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:14px;font-weight:500}.panel .eyebrow .pulse{width:7px;height:7px;border-radius:999px;background:var(--live);box-shadow:0 0 #ff5e7c80;animation:pulse 1.5s infinite}.panel .eyebrow.live{color:var(--live)}@keyframes pulse{0%{box-shadow:0 0 #ff5e7c8c}70%{box-shadow:0 0 0 10px #ff5e7c00}to{box-shadow:0 0 #ff5e7c00}}.panel .display{font-size:30px;font-weight:600;letter-spacing:-.022em;line-height:1.05;margin-bottom:6px}.panel .place{font-size:13px;color:var(--muted)}.panel .tabs{padding:14px 28px 0;margin-top:16px;border-bottom:1px solid var(--line)}.tabs button{background:transparent;color:var(--muted);border:none;font:inherit;font-size:12px;font-weight:500;padding:9px 12px;cursor:pointer;position:relative;transition:color .15s ease;display:inline-flex;align-items:center;gap:7px}.tabs button:hover,.tabs button.on{color:var(--fg)}.tabs button.on:after{content:"";position:absolute;left:12px;right:12px;bottom:-1px;height:2px;background:var(--fg);border-radius:2px}.tabs .sw{width:6.5px;height:6.5px;border-radius:999px}.panel .body{padding:22px 28px 18px;flex:1;overflow-y:auto}.panel .meta-row{display:flex;gap:18px;align-items:baseline;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line)}.panel .meta-row .col .k{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-2);margin-bottom:4px}.panel .meta-row .col.dates .v{font-size:17px;font-weight:500;letter-spacing:-.01em}.panel .meta-row .col.prize{margin-left:auto;text-align:right}.panel .meta-row .col.prize .v{font-size:17px;font-weight:500;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.badges{display:flex;flex-wrap:wrap;gap:5px}.badge{font-size:10.5px;font-weight:600;letter-spacing:.04em;padding:3px 8px;border-radius:999px;background:#ffffff0f;border:1px solid var(--line);color:var(--fg)}.badge.live{background:var(--live);border-color:transparent;color:#1c0007}.badge[data-cat=ATP]{color:var(--atp);border-color:#3a7bd573}.badge[data-cat=WTA]{color:var(--wta);border-color:#e9458473}.badge[data-cat=GS]{color:var(--gs);border-color:#f5c14b73}.badge[data-cat=ITF_W]{color:var(--itf-w);border-color:#a78bfa73}.badge[data-cat=ITF_M]{color:var(--itf-m);border-color:#4ade8073}.panel .badges-row{margin-bottom:22px}.panel .keyfact-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}.panel .keyfact{border:1px solid var(--line);border-radius:10px;padding:12px 14px 13px;background:#ffffff05}.panel .keyfact .k{font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-2);margin-bottom:4px;font-weight:500}.panel .keyfact .v{font-size:14px;font-weight:500}.panel .actions{padding:16px 28px;border-top:1px solid var(--line);display:flex;gap:10px;background:#0003}.btn{flex:1;background:#ffffff0f;color:var(--fg);border:1px solid var(--line);font:inherit;font-size:12.5px;font-weight:500;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .15s ease}.btn:hover{background:#ffffff1a;border-color:var(--line-2)}.btn.primary{background:var(--fg);color:#050913;border-color:var(--fg)}.btn.primary:hover{background:#fff}.bubble{position:absolute;z-index:13;width:320px;background:#05070df2;border:1px solid var(--line-2);border-radius:14px;backdrop-filter:blur(12px);box-shadow:0 18px 50px #0000008c;opacity:0;transform:translate(-50%,calc(-100% - 18px)) scale(.96);transition:opacity .16s ease,transform .16s ease;pointer-events:none;overflow:hidden}.bubble.open{opacity:1;transform:translate(-50%,calc(-100% - 18px)) scale(1);pointer-events:auto}.bubble:after{content:"";position:absolute;bottom:-7px;left:50%;transform:translate(-50%) rotate(45deg);width:12px;height:12px;background:#05070df2;border-right:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}.bubble .head{padding:14px 16px 8px}.bubble .row1{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.bubble .title{font-size:16px;font-weight:600;letter-spacing:-.01em;line-height:1.2}.bubble .sub{font-size:11.5px;color:var(--muted);margin-top:3px}.bubble .tabs{padding:0;margin-top:8px;border-bottom:1px solid var(--line)}.bubble .body{padding:12px 16px 14px}.bubble .badges{margin-bottom:12px}.bubble .grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;margin-bottom:12px}.bubble .grid .k{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);margin-bottom:3px}.bubble .grid .v{font-size:12.5px;font-weight:500}.bubble .actions{padding-top:10px;border-top:1px solid var(--line);display:flex;gap:8px}.bubble .close{width:26px;height:26px;font-size:14px}.close{background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:999px;width:30px;height:30px;cursor:pointer;font-size:16px;line-height:1;flex-shrink:0}.close:hover{color:var(--fg);border-color:var(--line-2);background:#ffffff0d}.cluster-picker{position:absolute;z-index:13;background:#05070df2;border:1px solid var(--line-2);border-radius:12px;backdrop-filter:blur(12px);box-shadow:0 14px 40px #0000008c;padding:6px;min-width:220px;opacity:0;transform:translate(-50%,calc(-100% - 16px)) scale(.96);transition:opacity .14s ease,transform .14s ease;pointer-events:none}.cluster-picker.open{opacity:1;transform:translate(-50%,calc(-100% - 16px)) scale(1);pointer-events:auto}.cluster-picker .ph{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);padding:5px 9px 6px}.cluster-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:13px;background:transparent;border:none;color:var(--fg);text-align:left;width:100%}.cluster-item:hover{background:#ffffff0f}.cluster-item .sw{width:8px;height:8px;border-radius:999px;flex-shrink:0}.cluster-item .nm{flex:1;font-weight:500}.cluster-item .mt{font-size:10.5px;color:var(--muted);letter-spacing:.02em}.cluster-item.live .nm:after{content:" ●";color:var(--live)}@media(min-width:761px){.bubble{display:none!important}}@media(max-width:760px){.panel{display:none!important}.toolbar{flex-direction:column;gap:4px;padding:6px 8px;border-radius:18px;width:calc(100% - 32px);max-width:460px;top:clamp(16px,3vw,24px)}.toolbar .divider{display:none}.tally{padding:4px 0}.bubble{width:calc(100% - 24px);max-width:380px}.brand{font-size:15px;top:clamp(14px,3vw,22px)}}
