*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--s1:#141414;--s2:#1c1c1c;--s3:#262626;--s4:#2f2f2f;--b1:#ffffff0f;--b2:#ffffff1f;--b3:#fff3;--tx:#f4f4f4;--tm:#8a8a8a;--td:#4a4a4a;--gr:#35d387;--ye:#fac04a;--re:#ef5a5a;--bl:#6fb1ff;--pu:#b39aff;--gold:#f5a623;--accent:#f47b20;--accent-2:#ff9a4d;--accent-3:#e06a0f;--glow:#f47b2073;--fs-2xs:9px;--fs-xs:10px;--fs-sm:11px;--fs-md:13px;--fs-lg:15px;--fs-xl:18px;--fs-2xl:22px;--fs-3xl:30px;--fs-4xl:38px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:18px;--r-2xl:22px;--r-pill:999px;--t-fast:.12s cubic-bezier(.4,0,.2,1);--t-med:.22s cubic-bezier(.4,0,.2,1)}html,body,#root{background:var(--bg);height:100%;color:var(--tx);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-family:Outfit,system-ui,-apple-system,sans-serif;overflow:hidden}body{background:radial-gradient(1200px 600px at 100% -10%, #f47b2012, transparent 60%), radial-gradient(800px 400px at -10% 110%, #6fb1ff0a, transparent 60%), var(--bg)}button,input,select,textarea{font-family:inherit}button{cursor:pointer}.app{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.scroll-area,.main{-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.scroll-area::-webkit-scrollbar{width:4px}.main::-webkit-scrollbar{width:4px}.scroll-area::-webkit-scrollbar-track{background:0 0}.main::-webkit-scrollbar-track{background:0 0}.scroll-area::-webkit-scrollbar-thumb{background:var(--s3);border-radius:4px}.main::-webkit-scrollbar-thumb{background:var(--s3);border-radius:4px}.main{width:100%;max-width:960px;padding:var(--sp-4) var(--sp-4) 96px;margin:0 auto}header{-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--b1);padding:0 var(--sp-4);justify-content:space-between;align-items:center;gap:var(--sp-3);z-index:60;background:#0a0a0ad9;flex-shrink:0;height:58px;display:flex;position:relative}header:after{content:"";background:linear-gradient(90deg, transparent, var(--accent) 50%, transparent);opacity:.35;height:1px;position:absolute;bottom:-1px;left:0;right:0}.logo{font-size:var(--fs-xl);letter-spacing:2px;color:var(--tx);text-transform:uppercase;white-space:nowrap;font-weight:900;line-height:1}.logo span{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.loc-pill{align-items:center;gap:var(--sp-2);background:var(--s2);border:1px solid var(--b2);border-radius:var(--r-pill);font-size:var(--fs-sm);color:var(--tm);white-space:nowrap;text-overflow:ellipsis;max-width:160px;padding:6px 12px;font-weight:600;display:flex;overflow:hidden}.ldot{background:var(--gr);width:6px;height:6px;box-shadow:0 0 6px var(--gr);border-radius:50%;flex-shrink:0;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.prof-avatar{width:34px;height:34px;font-size:var(--fs-sm);cursor:pointer;transition:border-color var(--t-fast), transform var(--t-fast);border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex}.prof-avatar:hover{border-color:var(--accent);transform:scale(1.05)}.btn-post{font-weight:800;font-size:var(--fs-sm);border-radius:var(--r-md);color:#fff;background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);white-space:nowrap;transition:transform var(--t-fast), box-shadow var(--t-fast), filter var(--t-fast);text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 14px -4px var(--glow);border:none;padding:10px 16px}.btn-post:hover{box-shadow:0 6px 18px -4px var(--glow);filter:brightness(1.05);transform:translateY(-1px)}.btn-post:active{transform:translateY(0)}.sport-bar{gap:var(--sp-2);padding:var(--sp-3) var(--sp-4) var(--sp-3);scrollbar-width:none;background:var(--bg);-webkit-overflow-scrolling:touch;flex-shrink:0;display:flex;overflow-x:auto}.sport-bar::-webkit-scrollbar{display:none}.sbar-btn,.sport-btn{border-radius:var(--r-md);border:1.5px solid var(--b1);background:var(--s1);cursor:pointer;transition:transform var(--t-fast), border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;min-width:62px;min-height:60px;padding:10px 12px;display:flex;position:relative}.sbar-btn:hover,.sport-btn:hover{border-color:var(--b3);transform:translateY(-1px)}.sbar-ico,.sport-ico{filter:grayscale(.25);transition:filter var(--t-fast);font-size:20px;line-height:1}.sbar-lbl,.sport-lbl{font-size:var(--fs-2xs);text-transform:uppercase;letter-spacing:.5px;color:var(--tm);font-weight:800;line-height:1}.sport-btn[style*=rgba] .sport-ico,.sbar-btn[style*=rgba] .sbar-ico{filter:grayscale(0)}.nav-tabs{gap:var(--sp-1);padding:0 var(--sp-4) var(--sp-3);background:var(--bg);border-bottom:1px solid var(--b1);flex-shrink:0;display:flex}.ntab{font-size:var(--fs-sm);color:var(--tm);transition:color var(--t-fast), border-color var(--t-fast);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;cursor:pointer;border-bottom:3px solid #0000;margin-bottom:-1px;padding:10px 14px;font-weight:800;position:relative}.ntab:hover{color:var(--tx)}.ntab.active{color:var(--accent);border-bottom-color:var(--accent)}.ntab.active:before{content:"";background:var(--accent);width:24px;height:3px;box-shadow:0 0 8px var(--glow);border-radius:2px 2px 0 0;position:absolute;bottom:-1px;left:50%;transform:translate(-50%)}.filter-section{margin-bottom:var(--sp-4)}.filter-group,.filters{gap:var(--sp-2);margin-bottom:var(--sp-3);flex-wrap:wrap;align-items:center;display:flex}.fgl{font-size:var(--fs-2xs);text-transform:uppercase;letter-spacing:.7px;color:var(--td);margin-bottom:var(--sp-2);width:100%;padding-left:2px;font-weight:800}.fp{border-radius:var(--r-pill);font-size:var(--fs-sm);border:1px solid var(--b2);background:var(--s1);color:var(--tm);cursor:pointer;transition:all var(--t-fast);white-space:nowrap;letter-spacing:.2px;padding:7px 13px;font-weight:700}.fp:hover{border-color:var(--b3);color:var(--tx);background:var(--s2)}.fp.active{border-color:var(--accent);color:#fff;background:var(--accent);box-shadow:0 0 12px -2px var(--glow)}.fsep,.filter-sep{background:var(--b2);width:1px;height:18px;margin:0 2px}.sbadge,.vbadge,.fbadge,.fee-badge,.tbadge,.age-badge,.stag,.sport-tag{font-size:var(--fs-2xs);text-transform:uppercase;letter-spacing:.5px;border-radius:var(--r-sm);align-items:center;gap:3px;padding:3px 8px;font-weight:800;line-height:1.4;display:inline-flex}.s-beg,.s-beginner{color:var(--gr);background:#35d38724}.s-int,.s-intermediate{color:var(--ye);background:#fac04a24}.s-adv,.s-advanced{color:var(--re);background:#ef5a5a24}.s-all{color:var(--tm);background:#ffffff0f}.v-in,.v-indoor{color:var(--bl);background:#6fb1ff24}.v-out,.v-outdoor,.f-free,.fee-free{color:var(--gr);background:#35d38724}.f-paid,.fee-paid{color:var(--ye);background:#fac04a24}.tbadge{color:var(--tm);background:#ffffff0f}.age-badge{color:var(--pu);background:#b39aff24}.age-badge.mismatch{color:var(--ye);background:#fac04a24}.stag,.sport-tag{letter-spacing:.7px;padding:4px 9px;font-weight:900}.games{gap:var(--sp-3);flex-direction:column;display:flex}.gcard{background:linear-gradient(180deg, var(--s1) 0%, #111 100%);border:1px solid var(--b1);border-radius:var(--r-lg);padding:var(--sp-4);gap:var(--sp-3);transition:transform var(--t-fast), border-color var(--t-fast), box-shadow var(--t-med);margin-bottom:var(--sp-3);grid-template-columns:1fr auto;display:grid;position:relative;overflow:hidden}.gcard:before{content:"";background:var(--accent);opacity:.85;width:3px;position:absolute;top:0;bottom:0;left:0}.gcard:hover{border-color:var(--b2);box-shadow:0 12px 28px -12px #000c, 0 0 0 1px var(--b2);transform:translateY(-2px)}.ctop{margin-bottom:var(--sp-2);flex-wrap:wrap;align-items:center;gap:5px;display:flex}.ctitle{font-size:var(--fs-lg);margin-bottom:var(--sp-1);letter-spacing:-.2px;font-weight:800;line-height:1.25}.cmeta{gap:var(--sp-3);margin-bottom:var(--sp-2);flex-wrap:wrap;display:flex}.mi{font-size:var(--fs-sm);color:var(--tm);font-weight:500}.cnote{font-size:var(--fs-sm);color:var(--tm);margin-bottom:var(--sp-2);padding-left:var(--sp-3);border-left:2px solid var(--b2);font-style:italic;line-height:1.5}.cfoot{align-items:center;gap:var(--sp-2);margin-top:var(--sp-1);flex-wrap:wrap;display:flex}.avi{width:22px;height:22px;font-size:var(--fs-2xs);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:900;display:flex}.avlbl,.avlabel{font-size:var(--fs-sm);color:var(--tm);font-weight:500}.pdots,.dots{flex-wrap:wrap;gap:3px;display:flex}.pdot,.dot{width:6px;height:6px;transition:background var(--t-fast);border-radius:50%}.cright{justify-content:space-between;align-items:flex-end;gap:var(--sp-2);flex-direction:column;min-width:64px;display:flex}.spots{text-align:right}.spotnum,.snum{font-size:var(--fs-3xl);letter-spacing:-1.5px;font-variant-numeric:tabular-nums;font-weight:900;line-height:1}.spotlbl,.slabel{font-size:var(--fs-2xs);color:var(--td);letter-spacing:.8px;text-transform:uppercase;margin-top:2px;font-weight:800}.cbtns,.card-btns{gap:var(--sp-1);flex-direction:column;align-items:stretch;width:100%;display:flex}.bjoin{border-radius:var(--r-md);font-size:var(--fs-sm);color:#fff;transition:transform var(--t-fast), filter var(--t-fast), box-shadow var(--t-fast);text-transform:uppercase;letter-spacing:.6px;border:none;min-width:76px;min-height:38px;padding:10px 16px;font-weight:800}.bjoin:hover{filter:brightness(1.12);transform:translateY(-1px)}.bjoin:active{transform:translateY(0)}.bjoin.joined,.bjoin:disabled{cursor:default;background:var(--s3)!important;color:var(--tm)!important;filter:none!important;box-shadow:none!important;transform:none!important}.bjoin.full{cursor:not-allowed;background:var(--s3)!important;color:var(--td)!important}.bchat{border:1px solid var(--b2);color:var(--tm);border-radius:var(--r-md);font-size:var(--fs-2xs);transition:all var(--t-fast);text-transform:uppercase;letter-spacing:.6px;background:0 0;min-height:30px;padding:7px 12px;font-weight:800}.bchat:hover{color:var(--tx);border-color:var(--b3);background:var(--s2)}.age-hint{align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--ye);border-radius:var(--r-sm);margin-top:var(--sp-1);background:#fac04a12;border:1px solid #fac04a33;padding:6px 10px;display:flex}.venue-card{background:var(--s1);border:1px solid var(--b1);border-radius:var(--r-lg);transition:border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-med);margin-bottom:var(--sp-3);overflow:hidden}.venue-card:hover{border-color:var(--b2);transform:translateY(-1px);box-shadow:0 10px 24px -10px #000000b3}.venue-card.expanded{border-color:var(--b2)}.vtop,.venue-top{padding:var(--sp-4);gap:var(--sp-3);cursor:pointer;align-items:flex-start;display:flex}.vico,.venue-icon{border-radius:var(--r-md);background:var(--s3);border:1px solid var(--b1);flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:22px;display:flex}.vinfo,.venue-info{flex:1;min-width:0}.vname,.venue-name{font-size:var(--fs-lg);letter-spacing:-.2px;text-overflow:ellipsis;align-items:baseline;gap:6px;margin-bottom:4px;font-weight:800;line-height:1.25;display:flex;overflow:hidden}.vaddr,.venue-addr{font-size:var(--fs-sm);color:var(--tm);margin-bottom:var(--sp-2);font-weight:500}.vchips,.venue-sports{flex-wrap:wrap;gap:4px;display:flex}.vchip,.vsport-chip{border-radius:var(--r-pill);font-size:var(--fs-2xs);text-transform:uppercase;letter-spacing:.4px;border:1px solid #0000;align-items:center;gap:3px;padding:3px 8px;font-weight:800;line-height:1.4;display:inline-flex}.vright,.venue-right{align-items:flex-end;gap:var(--sp-1);flex-direction:column;flex-shrink:0;display:flex}.vgcount,.venue-game-count{font-size:var(--fs-sm);color:var(--tm);font-weight:500}.vgcount strong,.venue-game-count strong{color:var(--tx);font-weight:900}.vchev,.venue-chevron{font-size:var(--fs-lg);color:var(--td);transition:transform var(--t-med), color var(--t-fast);font-weight:700}.venue-card.open .vchev,.venue-card.expanded .venue-chevron{color:var(--accent);transform:rotate(90deg)}.vstrip,.venue-game-strip{border-top:1px solid var(--b1);padding:var(--sp-3) var(--sp-4);gap:var(--sp-2);background:#0003;flex-direction:column;display:flex}.vgrow,.vg-row{align-items:center;gap:var(--sp-2);background:var(--s2);border:1px solid var(--b1);border-radius:var(--r-md);cursor:pointer;transition:background var(--t-fast), border-color var(--t-fast);padding:10px 12px;display:flex}.vgrow:hover,.vg-row:hover{background:var(--s3);border-color:var(--b2)}.vgsico,.vg-sport-ico{flex-shrink:0;font-size:18px}.vginfo,.vg-info{flex:1;min-width:0}.vgtitle,.vg-title{font-size:var(--fs-md);margin-bottom:2px;font-weight:800}.vgmeta,.vg-meta{font-size:var(--fs-sm);color:var(--tm);font-weight:500}.vgright,.vg-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.vgspots,.vg-spots{font-size:var(--fs-sm);font-weight:800}.vgjoin,.vg-join{border-radius:var(--r-sm);font-size:var(--fs-2xs);cursor:pointer;color:#fff;text-transform:uppercase;letter-spacing:.5px;transition:filter var(--t-fast), transform var(--t-fast);border:none;padding:6px 12px;font-weight:800}.vgjoin:hover,.vg-join:hover{filter:brightness(1.1);transform:translateY(-1px)}.vpost,.venue-post-btn{justify-content:center;align-items:center;gap:var(--sp-2);margin:var(--sp-2) var(--sp-4) var(--sp-4);border:1.5px dashed var(--b2);border-radius:var(--r-md);font-size:var(--fs-md);color:var(--tm);cursor:pointer;transition:all var(--t-fast);padding:11px;font-weight:700;display:flex}.vpost:hover,.venue-post-btn:hover{border-color:var(--accent);color:var(--accent);background:#f47b200a}.amenity-row{gap:var(--sp-1);padding:0 var(--sp-4) var(--sp-3);flex-wrap:wrap;display:flex}.amen{border-radius:var(--r-pill);border:1px solid var(--b1);font-size:var(--fs-sm);color:var(--tm);align-items:center;gap:4px;padding:4px 10px;display:flex}.chat-overlay{z-index:90;-webkit-backdrop-filter:blur(4px);background:#0009;position:fixed;inset:0}.chat-panel{z-index:91;background:var(--s1);border-left:1px solid var(--b2);flex-direction:column;width:380px;max-width:100vw;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-12px 0 40px -12px #0009}.chat-panel.open{transform:translate(0)}.chdr,.chat-hdr{padding:var(--sp-4);border-bottom:1px solid var(--b1);flex-shrink:0}.chdr-top,.chat-hdr-top{justify-content:space-between;align-items:flex-start;margin-bottom:2px;display:flex}.cname,.chat-court{font-size:var(--fs-lg);letter-spacing:-.2px;font-weight:800;line-height:1.25}.cmeta-line,.chat-meta{font-size:var(--fs-sm);color:var(--tm);margin-top:2px;font-weight:500}.cclose,.chat-close{background:var(--s3);width:30px;height:30px;color:var(--tm);font-size:var(--fs-md);transition:background var(--t-fast), color var(--t-fast);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.cclose:hover,.chat-close:hover{background:var(--s4);color:var(--tx)}.cmsgs,.chat-msgs{padding:var(--sp-4);gap:var(--sp-3);flex-direction:column;flex:1;display:flex;overflow-y:auto}.cmsgs::-webkit-scrollbar{width:3px}.chat-msgs::-webkit-scrollbar{width:3px}.cmsgs::-webkit-scrollbar-thumb{background:var(--s3)}.chat-msgs::-webkit-scrollbar-thumb{background:var(--s3)}.msg{gap:var(--sp-2);align-items:flex-end;display:flex}.msg.me{flex-direction:row-reverse}.mavi,.msg-avi{width:28px;height:28px;font-size:var(--fs-2xs);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:900;display:flex}.mbody,.msg-body{max-width:240px}.mwho,.msg-name{font-size:var(--fs-2xs);color:var(--tm);margin-bottom:3px;font-weight:600}.msg.me .mwho,.msg.me .msg-name{text-align:right}.mbub,.msg-bubble{border-radius:var(--r-lg);font-size:var(--fs-md);word-break:break-word;padding:9px 13px;font-weight:500;line-height:1.45}.mbub.them{background:var(--s3);color:var(--tx);border-bottom-left-radius:4px}.mbub.me{color:#fff;border-bottom-right-radius:4px}.mtime,.msg-time{font-size:var(--fs-2xs);color:var(--td);margin-top:3px}.msg.me .mtime,.msg.me .msg-time{text-align:left}.cinput-row,.chat-input-row{padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--b1);gap:var(--sp-2);background:var(--s1);flex-shrink:0;align-items:flex-end;display:flex}.cinput,.chat-input{background:var(--s2);border:1px solid var(--b2);color:var(--tx);font-size:var(--fs-md);border-radius:var(--r-xl);resize:none;max-height:100px;transition:border-color var(--t-fast);outline:none;flex:1;padding:10px 14px;line-height:1.5}.cinput:focus,.chat-input:focus{border-color:var(--accent)}.csend,.chat-send{color:#fff;width:38px;height:38px;transition:filter var(--t-fast), transform var(--t-fast);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.csend:hover,.chat-send:hover{filter:brightness(1.12);transform:scale(1.05)}.csend:disabled,.chat-send:disabled{opacity:.5;cursor:not-allowed}.modal-bg,.overlay{z-index:200;-webkit-backdrop-filter:blur(6px);padding:var(--sp-4);animation:modalBgIn var(--t-med);background:#000000c7;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes modalBgIn{0%{opacity:0}to{opacity:1}}.modal{background:linear-gradient(180deg, var(--s2) 0%, var(--s1) 100%);border:1px solid var(--b2);border-radius:var(--r-xl);width:100%;max-width:520px;max-height:90vh;padding:var(--sp-6);animation:.28s cubic-bezier(.4,0,.2,1) modalIn;overflow-y:auto;box-shadow:0 24px 60px -12px #000c}@keyframes modalIn{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal::-webkit-scrollbar{width:4px}.modal::-webkit-scrollbar-thumb{background:var(--s3);border-radius:4px}.mhdr{margin-bottom:var(--sp-5);justify-content:space-between;align-items:center;display:flex}.mttl{font-size:var(--fs-xl);text-transform:uppercase;letter-spacing:.5px;font-weight:900;line-height:1}.mxbtn,.mclose{background:var(--s3);width:32px;height:32px;color:var(--tm);font-size:var(--fs-md);transition:background var(--t-fast), color var(--t-fast);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.mxbtn:hover,.mclose:hover{background:var(--s4);color:var(--tx)}.flbl,.flabel{font-size:var(--fs-2xs);letter-spacing:.7px;text-transform:uppercase;color:var(--tm);margin-bottom:var(--sp-2);font-weight:800;display:block}.fgrp,.fgroup{margin-bottom:var(--sp-4)}.finp,.finput,.fsel,.fselect,.ftxt{background:var(--s2);border:1px solid var(--b2);width:100%;color:var(--tx);font-size:var(--fs-md);border-radius:var(--r-md);transition:border-color var(--t-fast);outline:none;padding:11px 13px}.finp:focus,.finput:focus,.fsel:focus,.fselect:focus,.ftxt:focus{border-color:var(--accent)}.fsel option,.fselect option{background:var(--s2)}.ftxt{resize:vertical;min-height:72px;line-height:1.5}.frow{gap:var(--sp-3);grid-template-columns:1fr 1fr;display:grid}.sgrid,.sport-grid{gap:var(--sp-2);grid-template-columns:repeat(auto-fit,minmax(64px,1fr));display:grid}.sopt{border:1.5px solid var(--b1);border-radius:var(--r-md);background:var(--s1);text-align:center;cursor:pointer;transition:all var(--t-fast);padding:10px 4px}.sopt:hover{border-color:var(--b3);transform:translateY(-1px)}.sopt.sel{box-shadow:0 0 12px -2px var(--glow)}.sopt-i,.sopt-ico{margin-bottom:4px;font-size:20px;line-height:1}.sopt-l,.sopt-lbl{font-size:var(--fs-2xs);color:var(--tm);text-transform:uppercase;letter-spacing:.5px;font-weight:800}.vpick,.venue-picker{border:1px solid var(--b1);border-radius:var(--r-md);max-height:200px;overflow:hidden auto}.vpick::-webkit-scrollbar{width:3px}.venue-picker::-webkit-scrollbar{width:3px}.vpick::-webkit-scrollbar-thumb{background:var(--s3)}.venue-picker::-webkit-scrollbar-thumb{background:var(--s3)}.vpitem,.vp-item{align-items:center;gap:var(--sp-2);cursor:pointer;transition:background var(--t-fast);border-bottom:1px solid var(--b1);padding:11px 13px;display:flex}.vpitem:last-child,.vp-item:last-child{border-bottom:none}.vpitem:hover,.vp-item:hover{background:var(--s2)}.vpitem.vsel,.vp-item.sel{border-left:3px solid var(--accent);background:#f47b2014;padding-left:10px}.vpico,.vp-ico{text-align:center;flex-shrink:0;width:26px;font-size:20px}.vpname,.vp-name{font-size:var(--fs-md);font-weight:700}.vpaddr,.vp-addr{font-size:var(--fs-sm);color:var(--tm)}.vpcheck,.vp-check{color:var(--accent);opacity:0;font-size:var(--fs-lg);transition:opacity var(--t-fast);margin-left:auto;font-weight:900}.vpitem.vsel .vpcheck,.vp-item.sel .vp-check{opacity:1}.vpcustom,.custom-loc-row{font-size:var(--fs-md);color:var(--tm);cursor:pointer;align-items:center;gap:var(--sp-1);transition:background var(--t-fast), color var(--t-fast);border-top:1px solid var(--b1);padding:11px 13px;font-weight:500;display:flex}.vpcustom:hover,.custom-loc-row:hover{background:var(--s2);color:var(--tx)}.bsub,.bsubmit{color:#fff;width:100%;font-size:var(--fs-md);border-radius:var(--r-md);margin-top:var(--sp-2);letter-spacing:.8px;text-transform:uppercase;transition:filter var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);box-shadow:0 6px 18px -6px var(--glow);border:none;padding:14px;font-weight:900}.bsub:hover,.bsubmit:hover{filter:brightness(1.08);box-shadow:0 10px 24px -8px var(--glow);transform:translateY(-1px)}.bsub:active,.bsubmit:active{transform:translateY(0)}.age-modal-wrap{z-index:150;-webkit-backdrop-filter:blur(6px);padding:var(--sp-5);background:#000000b8;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.age-modal{background:linear-gradient(180deg, var(--s2) 0%, var(--s1) 100%);border:1px solid var(--b2);border-radius:var(--r-xl);width:100%;max-width:360px;padding:var(--sp-6);box-shadow:0 24px 60px -12px #000c}.age-modal-ico{text-align:center;margin-bottom:var(--sp-3);font-size:36px}.age-modal-title{font-size:var(--fs-xl);text-align:center;margin-bottom:var(--sp-2);letter-spacing:-.2px;font-weight:900}.age-modal-body{font-size:var(--fs-md);color:var(--tm);text-align:center;margin-bottom:var(--sp-4);line-height:1.6}.age-modal-body strong{color:var(--tx);font-weight:800}.age-modal-tags{justify-content:center;gap:var(--sp-2);margin-bottom:var(--sp-5);display:flex}.age-modal-btn-row{gap:var(--sp-2);display:flex}.am-btn{border-radius:var(--r-md);font-size:var(--fs-md);transition:filter var(--t-fast), transform var(--t-fast);text-transform:uppercase;letter-spacing:.4px;border:none;flex:1;padding:12px;font-weight:800}.am-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.am-cancel{background:var(--s3);color:var(--tm)}.am-confirm{color:#fff;background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);box-shadow:0 6px 16px -6px var(--glow)}.toast{bottom:var(--sp-5);background:var(--s2);border:1px solid var(--b2);color:var(--tx);border-radius:var(--r-md);font-size:var(--fs-md);z-index:300;align-items:center;gap:var(--sp-2);white-space:nowrap;padding:11px 16px;font-weight:700;animation:.25s tin;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 12px 32px -8px #000c}@keyframes tin{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toastdot{background:var(--gr);width:6px;height:6px;box-shadow:0 0 6px var(--gr);border-radius:50%;flex-shrink:0}.auth-screen{background:radial-gradient(900px 500px at 50% -10%, #f47b201f, transparent 65%), radial-gradient(600px 400px at 20% 110%, #6fb1ff0f, transparent 60%), var(--bg);min-height:100dvh;padding:var(--sp-8) var(--sp-5) 48px;justify-content:center;align-items:center;gap:var(--sp-1);flex-direction:column;display:flex}.auth-logo{font-size:var(--fs-4xl);letter-spacing:4px;text-transform:uppercase;color:var(--tx);margin-bottom:var(--sp-1);font-weight:900;line-height:1}.auth-logo span{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.auth-tagline{font-size:var(--fs-md);color:var(--tm);margin-bottom:var(--sp-6);text-align:center;font-weight:500}.oauth-btns{gap:var(--sp-2);flex-direction:column;width:100%;max-width:380px;display:flex}.oauth-btn{justify-content:center;align-items:center;gap:var(--sp-2);border-radius:var(--r-md);width:100%;font-size:var(--fs-md);border:1px solid var(--b2);background:var(--s1);color:var(--tx);transition:background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);min-height:46px;padding:14px;font-weight:700;display:flex}.oauth-btn:hover{background:var(--s2);border-color:var(--b3);transform:translateY(-1px)}.oauth-btn:disabled{opacity:.5;cursor:not-allowed}.divider{align-items:center;gap:var(--sp-2);color:var(--td);font-size:var(--fs-sm);margin:var(--sp-1) 0;text-transform:uppercase;letter-spacing:1px;font-weight:600;display:flex}.divider:before,.divider:after{content:"";background:var(--b2);flex:1;height:1px}.auth-form{gap:var(--sp-4);flex-direction:column;width:100%;max-width:380px;display:flex}.field{flex-direction:column;gap:6px;display:flex;position:relative}.field label{font-size:var(--fs-sm);color:var(--tm);text-transform:uppercase;letter-spacing:.7px;font-weight:700}.field input{background:var(--s1);border:1px solid var(--b2);border-radius:var(--r-md);font-size:var(--fs-lg);color:var(--tx);transition:border-color var(--t-fast), background var(--t-fast);outline:none;width:100%;padding:14px}.field input:focus{border-color:var(--accent);background:var(--s2)}.field input::placeholder{color:var(--td)}.forgot-link{color:var(--accent);font-size:var(--fs-sm);text-align:right;background:0 0;border:none;align-self:flex-end;padding:0;font-weight:700}.forgot-link:hover{text-decoration:underline}.auth-error{color:var(--re);border-radius:var(--r-md);font-size:var(--fs-md);background:#ef5a5a1a;border:1px solid #ef5a5a4d;padding:12px 14px;font-weight:500}.auth-success{color:var(--gr);border-radius:var(--r-md);font-size:var(--fs-md);background:#35d3871a;border:1px solid #35d3874d;padding:12px 14px;font-weight:500}.auth-submit{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);color:#fff;border-radius:var(--r-md);width:100%;font-size:var(--fs-lg);cursor:pointer;transition:filter var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);margin-top:var(--sp-1);text-transform:uppercase;letter-spacing:1px;box-shadow:0 8px 22px -6px var(--glow);border:none;padding:15px;font-weight:900}.auth-submit:hover{filter:brightness(1.08);box-shadow:0 10px 26px -6px var(--glow);transform:translateY(-1px)}.auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-switch{text-align:center;font-size:var(--fs-md);color:var(--tm);font-weight:500}.auth-switch button{color:var(--accent);font-size:var(--fs-md);background:0 0;border:none;padding:0;font-weight:700}.auth-switch button:hover{text-decoration:underline}.onboarding-screen{background:radial-gradient(900px 500px at 50% -10%, #f47b2014, transparent 65%), var(--bg);flex-direction:column;min-height:100dvh;display:flex}.onboarding-progress{background:var(--s2);flex-shrink:0;height:4px}.onboarding-progress-fill{background:linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 100%);height:100%;box-shadow:0 0 8px var(--glow);transition:width .35s}.onboarding-body{padding:48px var(--sp-5) 120px;flex-direction:column;flex:1;align-items:center;width:100%;max-width:520px;margin:0 auto;display:flex}.onboarding-step{align-items:center;gap:var(--sp-4);flex-direction:column;width:100%;animation:.3s fadein;display:flex}@keyframes fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.step-ico{margin-bottom:var(--sp-1);filter:drop-shadow(0 4px 12px #f47b204d);font-size:48px}.onboarding-step h2{font-size:var(--fs-2xl);color:var(--tx);text-align:center;letter-spacing:-.5px;font-weight:900}.onboarding-step p{font-size:var(--fs-md);color:var(--tm);text-align:center;line-height:1.5}.onboarding-input{background:var(--s1);border:1px solid var(--b2);border-radius:var(--r-md);width:100%;font-size:var(--fs-lg);color:var(--tx);transition:border-color var(--t-fast), background var(--t-fast);text-align:center;outline:none;padding:14px 16px;font-weight:600}.onboarding-input:focus{border-color:var(--accent);background:var(--s2)}.char-count{font-size:var(--fs-sm);color:var(--td);align-self:flex-end;font-weight:500}.sport-option{background:var(--s1);border:1.5px solid var(--b2);border-radius:var(--r-lg);cursor:pointer;transition:background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);flex-direction:column;align-items:center;gap:6px;padding:16px 10px;display:flex;position:relative}.sport-option:hover{background:var(--s2);border-color:var(--b3);transform:translateY(-1px)}.sport-option.selected{border-color:var(--accent);box-shadow:0 0 12px -2px var(--glow);background:#f47b201a}.sport-option-ico{font-size:28px}.sport-option-label{font-size:var(--fs-sm);color:var(--tm);text-transform:uppercase;letter-spacing:.4px;font-weight:700}.sport-option.selected .sport-option-label{color:var(--tx)}.sport-check{font-size:var(--fs-sm);color:var(--accent);font-weight:900;position:absolute;top:8px;right:10px}.skill-options{gap:var(--sp-2);flex-direction:column;width:100%;display:flex}.skill-option{background:var(--s1);border:1.5px solid var(--b2);border-radius:var(--r-lg);cursor:pointer;transition:background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);text-align:left;padding:16px 18px;position:relative}.skill-option:hover{background:var(--s2);border-color:var(--b3)}.skill-option.selected{border-color:var(--accent);box-shadow:0 0 12px -2px var(--glow);background:#f47b201a}.skill-label{font-size:var(--fs-lg);color:var(--tx);letter-spacing:-.2px;font-weight:800}.skill-desc{font-size:var(--fs-md);color:var(--tm);margin-top:2px;font-weight:500}.skill-check{color:var(--accent);font-weight:900;font-size:var(--fs-lg);position:absolute;top:50%;right:16px;transform:translateY(-50%)}.location-confirmed{font-size:var(--fs-md);color:var(--gr);border-radius:var(--r-md);text-align:center;background:#35d3871a;border:1px solid #35d38740;width:100%;padding:12px 16px;font-weight:600}.detect-btn{background:var(--s1);border:1.5px solid var(--b2);border-radius:var(--r-md);width:100%;font-size:var(--fs-md);color:var(--tx);transition:background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);padding:14px;font-weight:700}.detect-btn:hover{background:var(--s2);border-color:var(--b3);transform:translateY(-1px)}.detect-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.skip-link{color:var(--td);font-size:var(--fs-md);background:0 0;border:none;padding:0;font-weight:500}.skip-link:hover{color:var(--tm)}.onboarding-error{color:var(--re);border-radius:var(--r-md);font-size:var(--fs-md);background:#ef5a5a1a;border:1px solid #ef5a5a4d;width:100%;padding:12px 14px;font-weight:500}.onboarding-cta{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);color:#fff;border-radius:var(--r-md);width:100%;font-size:var(--fs-lg);transition:filter var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);margin-top:var(--sp-2);text-transform:uppercase;letter-spacing:1px;box-shadow:0 8px 22px -6px var(--glow);border:none;padding:16px;font-weight:900}.onboarding-cta:hover{filter:brightness(1.08);box-shadow:0 10px 26px -6px var(--glow);transform:translateY(-1px)}.onboarding-cta:disabled{opacity:.5;cursor:not-allowed;transform:none}.onboarding-back{color:var(--tm);font-size:var(--fs-md);padding:var(--sp-2);background:0 0;border:none;font-weight:600}.onboarding-back:hover{color:var(--tx)}@media (width>=720px){header{height:64px;padding:0 var(--sp-6)}.logo{font-size:var(--fs-2xl)}.loc-pill{max-width:240px;font-size:var(--fs-md);padding:7px 14px}.btn-post{font-size:var(--fs-md);padding:11px 18px}.sport-bar{padding:var(--sp-4) var(--sp-6) var(--sp-3);gap:var(--sp-3)}.sport-btn,.sbar-btn{min-width:70px;min-height:68px;padding:12px 14px}.sbar-ico,.sport-ico{font-size:24px}.nav-tabs{padding:0 var(--sp-6) var(--sp-3)}.ntab{font-size:var(--fs-md);padding:12px 18px}.main{padding:var(--sp-5) var(--sp-6) 120px}.gcard{padding:var(--sp-5)}.ctitle{font-size:var(--fs-xl)}.spotnum,.snum{font-size:var(--fs-4xl)}.venue-top,.vtop{padding:var(--sp-5)}}@media (width>=1100px){.games{gap:var(--sp-4);grid-template-columns:repeat(2,1fr);display:grid}}::selection{background:var(--accent);color:#fff}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
