:root{
  --bg:#0F172A;--card:#111827;--card2:#172033;--text:#F8FAFC;--muted:#CBD5E1;
  --orange:#FF7A00;--teal:#009688;--blue:#1E88E5;--blue2:#42A5F5;--white:#fff;
  --line:rgba(255,255,255,.18);--danger:#F97316;--good:#22C55E;
}
*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at 20% 0%,rgba(255,122,0,.22),transparent 30%),radial-gradient(circle at 80% 20%,rgba(0,150,136,.2),transparent 28%),var(--bg);color:var(--text)}
.app{width:min(1180px,94vw);margin:0 auto;padding:28px 0 60px}.hero{display:flex;justify-content:space-between;gap:20px;align-items:center;padding:24px;border:1px solid var(--line);border-radius:28px;background:linear-gradient(135deg,rgba(17,24,39,.95),rgba(15,23,42,.86));box-shadow:0 28px 90px rgba(0,0,0,.32)}
.eyebrow{margin:0 0 8px;color:var(--orange);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:12px}h1{margin:0;font-size:clamp(30px,5vw,58px);line-height:.95}.sub{color:var(--muted);max-width:680px;font-size:17px}.badge{display:inline-block;margin:4px 6px 0 0;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.08);font-weight:800;font-size:13px}.hero-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-end}.score-call{font-size:34px;font-weight:900;padding:16px 22px;border-radius:22px;background:linear-gradient(135deg,var(--orange),var(--teal));color:white;white-space:nowrap}.lang{display:flex;background:rgba(255,255,255,.08);border:1px solid var(--line);border-radius:999px;padding:4px}.lang button,.tab,.pick,.action,.ghost,.quiz-answer{border:0;color:var(--text);cursor:pointer;font-weight:800}.lang button{background:transparent;padding:8px 14px;border-radius:999px}.lang button.active{background:white;color:#0F172A}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0}.tab{padding:13px 18px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid var(--line)}.tab.active{background:linear-gradient(135deg,var(--orange),var(--teal));border-color:transparent}.panel{display:none}.panel.active{display:block}.layout{display:grid;grid-template-columns:380px 1fr;gap:18px}.quiz-layout{display:grid;grid-template-columns:1.35fr .65fr;gap:18px}.card{border:1px solid var(--line);background:rgba(17,24,39,.9);border-radius:26px;padding:22px;box-shadow:0 20px 70px rgba(0,0,0,.25)}h2{margin:0 0 18px;font-size:24px}h3{margin:0 0 8px}label{display:block;margin:16px 0 8px;color:var(--muted);font-size:14px;font-weight:800}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:8px}.pick,.action,.ghost,.quiz-answer{padding:13px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid var(--line)}.pick.active[data-value="orange"],.action.orange{background:var(--orange);border-color:var(--orange)}.pick.active[data-value="teal"],.action.teal{background:var(--teal);border-color:var(--teal)}.pick.active:not([data-value="orange"]):not([data-value="teal"]){background:linear-gradient(135deg,var(--orange),var(--teal));border-color:transparent}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}input{width:100%;background:#0B1220;border:1px solid var(--line);border-radius:14px;color:white;padding:13px;font-size:18px;font-weight:900}.ghost{margin-top:16px;width:100%;background:transparent}.small{font-size:13px;color:var(--muted);line-height:1.45}.court-topline{display:flex;justify-content:space-between;gap:12px;align-items:center}.pill{padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid var(--line);font-size:13px;font-weight:900}.court-wrap{position:relative;padding:24px 28px 12px}.dim{position:absolute;color:var(--muted);font-size:12px;font-weight:900;letter-spacing:.08em}.dim-w{top:4px;left:50%;transform:translateX(-50%)}.dim-h{right:0;top:50%;transform:translateY(-50%) rotate(90deg)}
.court{position:relative;width:min(100%,760px);aspect-ratio:44/20;margin:0 auto 18px;background:var(--blue);border:5px solid var(--white);border-radius:14px;overflow:hidden;box-shadow:inset 0 0 80px rgba(0,0,0,.18)}
.net{position:absolute;left:50%;top:0;bottom:0;width:10px;background:#0F172A;transform:translateX(-50%);z-index:7;display:flex;align-items:center;justify-content:center;color:white;font-size:10px;letter-spacing:.08em;writing-mode:vertical-rl}.nvz{position:absolute;top:0;bottom:0;width:15.909%;background:rgba(66,165,245,.92);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.92);font-size:11px;font-weight:900;text-align:center;padding:4px;z-index:1}.nvz-left{left:34.091%;border-left:4px solid white;border-right:4px solid white}.nvz-right{right:34.091%;border-left:4px solid white;border-right:4px solid white}.service-area{position:absolute;top:0;bottom:0;width:34.091%;z-index:2}.service-area.left{left:0}.service-area.right{right:0}.center-service{position:absolute;top:50%;height:4px;background:white;transform:translateY(-50%);z-index:4}.center-service.left{left:0;width:34.091%}.center-service.right{right:0;width:34.091%}.baseline{position:absolute;top:0;bottom:0;width:4px;background:white;z-index:5}.baseline.left{left:0}.baseline.right{right:0}.zone-label{position:absolute;color:rgba(255,255,255,.88);font-size:11px;font-weight:900;text-transform:uppercase}.top-label{top:10px}.bottom-label{bottom:10px}.service-area.left .zone-label{left:12px}.service-area.right .zone-label{right:12px}.team-label{position:absolute;top:50%;transform:translateY(-50%);font-weight:950;font-size:14px;letter-spacing:.06em;text-transform:uppercase;padding:8px 10px;background:rgba(15,23,42,.72);border-radius:999px;z-index:8}.team-label.orange{left:12px;color:#FFD7B0}.team-label.teal{right:12px;color:#B8FFF7}.player{position:absolute;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-weight:950;border:3px solid white;z-index:10;box-shadow:0 12px 25px rgba(0,0,0,.35);transition:left .28s ease,top .28s ease,transform .2s}.player.orange{background:var(--orange)}.player.teal{background:var(--teal)}.player.server{outline:5px solid rgba(255,255,255,.72);box-shadow:0 0 0 9px rgba(255,122,0,.25),0 18px 32px rgba(0,0,0,.4)}.player.receiver{outline:4px dashed rgba(255,255,255,.75)}.serve-line{position:absolute;height:4px;background:linear-gradient(90deg,#fff,rgba(255,255,255,.1));transform-origin:left center;z-index:6;opacity:0;pointer-events:none}.serve-line.show{opacity:.9}.result-box{border:1px solid var(--line);border-radius:20px;padding:16px;background:rgba(255,255,255,.06)}.result-box.gamepoint{border-color:var(--orange);background:rgba(255,122,0,.12)}.result-box.win{border-color:var(--good);background:rgba(34,197,94,.12)}.feedback{min-height:24px;font-weight:900}.feedback.good{color:var(--good)}.feedback.bad{color:#FCA5A5}.answers{display:grid;gap:10px;margin-top:14px}.quiz-answer:hover{background:rgba(255,255,255,.14)}.quiz-question{font-size:19px;line-height:1.45;color:white}.quiz-visual{margin:14px 0}.mini-court{position:relative;aspect-ratio:44/20;border:3px solid white;border-radius:12px;background:var(--blue);overflow:hidden}.mini-court .mini-nvz{position:absolute;top:0;bottom:0;width:15.909%;background:rgba(66,165,245,.9);border-left:3px solid white;border-right:3px solid white}.mini-court .l{left:34.091%}.mini-court .r{right:34.091%}.mini-court:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:7px;background:#0F172A;transform:translateX(-50%);z-index:4}.mini-court:after{content:"";position:absolute;left:0;right:0;top:50%;height:3px;background:white;transform:translateY(-50%)}.mini-player{position:absolute;width:34px;height:34px;border-radius:50%;border:2px solid white;display:grid;place-items:center;font-size:12px;font-weight:950;z-index:8}.mini-player.orange{background:var(--orange)}.mini-player.teal{background:var(--teal)}.mini-player.server{box-shadow:0 0 0 6px rgba(255,255,255,.38)}.mini-arrow{position:absolute;height:3px;background:white;transform-origin:left center;z-index:7;opacity:.9}.number-row{display:flex;gap:10px}.number-row input{max-width:180px}.team-choice{display:grid;grid-template-columns:1fr 1fr;gap:10px}.team-choice button[data-team="orange"]{background:var(--orange)}.team-choice button[data-team="teal"]{background:var(--teal)}.rule-item,.guide-item{padding:14px 0;border-top:1px solid var(--line);color:var(--muted);line-height:1.5}.rule-item b,.guide-item b{color:white}.quiz-guide h3{margin-top:0}.quiz-guide p{color:var(--muted);line-height:1.5}
@media(max-width:900px){.hero{flex-direction:column;align-items:flex-start}.hero-actions{align-items:flex-start}.layout,.quiz-layout{grid-template-columns:1fr}.court{aspect-ratio:20/44}.court-wrap{padding:24px 12px 12px}.dim-h{display:none}.net{left:0;right:0;top:50%;bottom:auto;width:auto;height:10px;transform:translateY(-50%);writing-mode:horizontal-tb}.nvz{left:0!important;right:0!important;width:auto;height:15.909%;top:auto;bottom:auto}.nvz-left{top:34.091%;border-top:4px solid white;border-bottom:4px solid white;border-left:0;border-right:0}.nvz-right{bottom:34.091%;border-top:4px solid white;border-bottom:4px solid white;border-left:0;border-right:0}.service-area{left:0!important;right:0!important;width:100%;height:34.091%;top:auto;bottom:auto}.service-area.left{top:0}.service-area.right{bottom:0}.center-service{left:50%!important;right:auto!important;top:auto;width:4px!important;height:34.091%;transform:translateX(-50%);}.center-service.left{top:0}.center-service.right{bottom:0}.top-label{top:10px}.bottom-label{bottom:10px}.team-label{top:auto;transform:none}.team-label.orange{left:12px;top:12px}.team-label.teal{right:12px;bottom:12px}.dim-w{display:none}}

/* v4 regulation court + quiz visual additions */
.mini-dim{position:absolute;z-index:12;color:rgba(255,255,255,.86);font-size:10px;font-weight:950;letter-spacing:.06em;background:rgba(15,23,42,.55);padding:3px 6px;border-radius:999px}.mini-dim.top{top:6px;left:50%;transform:translateX(-50%)}.mini-dim.side{right:6px;top:50%;transform:translateY(-50%) rotate(90deg)}.mini-nvz{display:grid;place-items:center;color:white;font-size:10px;font-weight:950}.mini-service-label{position:absolute;z-index:5;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.85);font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.05em}.mini-service-label.left{left:8%}.mini-service-label.right{right:8%}
.court:before{content:"20 ft × 44 ft regulation court";position:absolute;left:50%;top:8px;transform:translateX(-50%);z-index:9;background:rgba(15,23,42,.55);color:white;font-size:11px;font-weight:950;letter-spacing:.06em;padding:4px 9px;border-radius:999px}.court:after{content:"Kitchen 7 ft each side · Service area 15 ft";position:absolute;left:50%;bottom:8px;transform:translateX(-50%);z-index:9;background:rgba(15,23,42,.55);color:white;font-size:11px;font-weight:950;letter-spacing:.04em;padding:4px 9px;border-radius:999px}
@media(max-width:900px){.court:before{content:"20 × 44 ft"}.court:after{content:"Kitchen 7 ft"}.mini-service-label{display:none}}

/* v7 Quiz Mode: final ball path / IN-OUT landing visual */
.mini-court-stage{position:relative;width:100%;max-width:760px;margin:0 auto;border-radius:18px;background:rgba(30,136,229,.35);padding:10px;overflow:visible;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.mini-court-svg{display:block;width:100%;height:auto;overflow:visible}
.mini-outer{fill:#1E88E5;opacity:.55}
.mini-court-bg{fill:#1E88E5}
.mini-kitchen{fill:#42A5F5;opacity:.92;stroke:#fff;stroke-width:.22}
.mini-boundary{fill:none;stroke:#fff;stroke-width:.42}
.mini-line{stroke:#fff;stroke-width:.28;stroke-linecap:square}
.mini-net{stroke:#0F172A;stroke-width:.72;stroke-linecap:square}
.mini-ft{fill:rgba(255,255,255,.86);font-size:1.05px;font-weight:900;letter-spacing:.08em paint-order:stroke;stroke:#0F172A;stroke-width:.08px}
.mini-ft.side{writing-mode:tb;glyph-orientation-vertical:0}
.mini-player-svg circle{stroke:#fff;stroke-width:.32;filter:drop-shadow(0 .55px .8px rgba(0,0,0,.38))}
.mini-player-svg.orange circle{fill:var(--orange)}
.mini-player-svg.teal circle{fill:var(--teal)}
.mini-player-svg text{fill:#fff;font-size:1.45px;font-weight:950;pointer-events:none}
.mini-player-svg.mini-server circle{stroke-width:.42;filter:drop-shadow(0 0 .8px rgba(255,255,255,.95)) drop-shadow(0 .55px .8px rgba(0,0,0,.38))}
.last-shot{stroke:#050505;stroke-width:.36;stroke-dasharray:1.05 .72;stroke-linecap:round;fill:none}
.landing-dot{fill:#EF4444;stroke:#fff;stroke-width:.16;filter:drop-shadow(0 .3px .45px rgba(0,0,0,.55))}
.landing-label{font-size:1.7px;font-weight:950;paint-order:stroke;stroke:#fff;stroke-width:.22px;letter-spacing:.05em}.landing-label.in{fill:#16A34A}.landing-label.out{fill:#EF4444}


/* v8 Quiz Mode: question-specific visuals */
.switch-arrow{stroke:#050505;stroke-width:.36;fill:none;stroke-linecap:round;stroke-dasharray:.9 .65;marker-end:url(#arrowHead)}
.serve-target-line{stroke:#050505;stroke-width:.38;fill:none;stroke-linecap:round;marker-end:url(#arrowHead)}
.target-ring{fill:none;stroke:#EF4444;stroke-width:.3;filter:drop-shadow(0 .25px .35px rgba(0,0,0,.45))}
.measure-arrow{stroke:#050505;stroke-width:.36;fill:none;stroke-linecap:round;marker-end:url(#arrowHead)}
.concept-label{font-size:1.25px;font-weight:950;fill:#0F172A;paint-order:stroke;stroke:#fff;stroke-width:.25px;letter-spacing:.03em}

/* v9 generated quiz templates */
.template-tag{display:inline-block;margin:0 8px 8px 0;padding:6px 10px;border-radius:999px;background:rgba(255,122,0,.16);border:1px solid rgba(255,122,0,.38);color:#FFD7B0;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}
.no-visual{border:1px dashed var(--line);border-radius:18px;padding:18px;background:rgba(255,255,255,.05);color:var(--muted);font-weight:800;text-align:center}
#textAnswer{max-width:220px;text-align:center}

/* v13 Monetization + Ads placeholders */
.shop-layout{display:grid;gap:18px}.shop-hero{background:linear-gradient(135deg,rgba(255,122,0,.16),rgba(0,150,136,.16)),rgba(17,24,39,.9)}.shop-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.ad-strip{margin-top:16px}.sim-ad-slot{margin-top:14px}.ad-card{display:flex;justify-content:space-between;gap:16px;align-items:center;border:1px solid var(--line);border-radius:22px;padding:18px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.035));box-shadow:0 14px 40px rgba(0,0,0,.18)}.ad-card.compact{padding:14px;margin-top:12px}.ad-card.orange{border-color:rgba(255,122,0,.38);background:linear-gradient(135deg,rgba(255,122,0,.16),rgba(255,255,255,.04))}.ad-card.teal{border-color:rgba(0,150,136,.45);background:linear-gradient(135deg,rgba(0,150,136,.18),rgba(255,255,255,.04))}.ad-card.blue,.ad-card.court{border-color:rgba(66,165,245,.38);background:linear-gradient(135deg,rgba(30,136,229,.2),rgba(255,255,255,.04))}.ad-card.coach{border-color:rgba(255,122,0,.32);background:linear-gradient(135deg,rgba(255,122,0,.15),rgba(0,150,136,.12))}.ad-label{display:inline-block;margin-bottom:8px;padding:5px 9px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid var(--line);color:#E2E8F0;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.1em}.ad-card h3{margin:0 0 6px}.ad-card p{margin:0;color:var(--muted);line-height:1.45}.ad-cta{flex:0 0 auto;text-decoration:none;color:white;font-weight:950;border-radius:999px;padding:11px 14px;background:linear-gradient(135deg,var(--orange),var(--teal));box-shadow:0 10px 24px rgba(0,0,0,.22)}.monetization-note p{color:var(--muted);line-height:1.55;margin-bottom:0}@media(max-width:760px){.shop-grid{grid-template-columns:1fr}.ad-card{align-items:flex-start;flex-direction:column}.ad-cta{width:100%;text-align:center}}

/* v14 monetization cleanup */
.ad-card.service{border-color:rgba(0,150,136,.45);background:linear-gradient(135deg,rgba(0,150,136,.16),rgba(255,122,0,.08),rgba(255,255,255,.04))}
.ad-card[data-slot="shop_local_services"] .ad-label{background:rgba(0,150,136,.18);border-color:rgba(0,150,136,.35)}
.ad-card[data-slot="shop_local_services"] p{max-width:720px}


.about-card{max-width:880px;margin:0 auto}.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0}.about-tile{padding:16px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.06);display:flex;flex-direction:column;gap:8px}.about-tile strong{font-size:15px}.about-tile span{font-size:13px;color:var(--muted);line-height:1.45}.contact-button{display:inline-flex;align-items:center;justify-content:center;margin-top:8px;padding:13px 18px;border-radius:999px;background:linear-gradient(135deg,var(--orange),var(--teal));color:#fff;text-decoration:none;font-weight:900}.template-tag{display:none!important}
@media(max-width:760px){.about-grid{grid-template-columns:1fr}.hero{align-items:flex-start}.hero-actions{width:100%;align-items:stretch}.score-call{text-align:center}}

/* v23 singles mode + clean player indicators */
.mode-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.mode-tab{border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.08);color:var(--text);font-weight:950;padding:10px 16px;cursor:pointer}.mode-tab.active{background:linear-gradient(135deg,var(--orange),var(--teal));border-color:transparent;color:white}
.singles-helper{display:none;margin:10px 0 0;color:var(--muted);font-size:13px;line-height:1.45}body.singles-mode .doubles-only{display:none!important}body.singles-mode .singles-helper{display:block}body.singles-mode #orange2,body.singles-mode #teal2{display:none!important}
.player{background:transparent!important;box-shadow:none!important;border:0!important;overflow:visible!important}.player-token{width:58px;height:58px;display:grid;place-items:center;border-radius:18px 18px 22px 22px;position:relative;color:#fff;font-weight:1000;font-size:18px;border:4px solid #fff;box-shadow:0 12px 30px rgba(0,0,0,.28);transform:rotate(-7deg)}.player-token::after{content:"";position:absolute;left:50%;bottom:-16px;width:12px;height:22px;transform:translateX(-50%);border-radius:0 0 9px 9px;background:inherit;border:4px solid #fff;border-top:0}.player-token.orange{background:var(--orange)}.player-token.teal{background:var(--teal)}.player.server{outline:none!important}.player.server .player-token{box-shadow:0 0 0 7px rgba(255,255,255,.45),0 0 32px rgba(255,255,255,.65),0 12px 30px rgba(0,0,0,.28);transform:rotate(-7deg) scale(1.06)}.player.receiver .player-token{box-shadow:0 0 0 7px rgba(255,255,255,.18),0 12px 30px rgba(0,0,0,.28)}
body.singles-mode .team-label.orange::after{content:''!important}body.singles-mode .team-label.orange,body.singles-mode .team-label.teal{font-size:16px}

/* v24 clean serve line + SVG pickleball/paddle indicators */
.player{background:transparent!important;border:0!important;box-shadow:none!important;overflow:visible!important;width:64px!important;height:82px!important;display:grid!important;place-items:center!important}
.player-token{display:block;width:64px;height:82px;position:relative;filter:drop-shadow(0 12px 18px rgba(0,0,0,.28))}
.player-token-svg{width:64px;height:82px;overflow:visible;display:block;transform:rotate(-8deg);transform-origin:center}
.player-token .paddle-shadow{fill:rgba(15,23,42,.32)}
.player-token .paddle-face{stroke:#fff;stroke-width:5;paint-order:stroke;filter:drop-shadow(0 0 0 rgba(0,0,0,0))}
.player-token .paddle-handle{stroke:#fff;stroke-width:5}
.player-token.orange .paddle-face,.player-token.orange .paddle-handle{fill:var(--orange)}
.player-token.teal .paddle-face,.player-token.teal .paddle-handle{fill:var(--teal)}
.player-token .pickleball-cue{fill:#FFD21F;stroke:#0F172A;stroke-width:2.2}
.player-token .pickleball-hole{fill:#0F172A;opacity:.85}
.player-token .paddle-label{fill:#fff;font-weight:1000;font-size:20px;font-family:Inter,ui-sans-serif,system-ui,sans-serif;dominant-baseline:middle;paint-order:stroke;stroke:rgba(15,23,42,.35);stroke-width:1.5}
.player.server{outline:none!important;transform:none!important}
.player.server .player-token-svg{filter:drop-shadow(0 0 12px rgba(255,255,255,.95)) drop-shadow(0 0 0 rgba(255,255,255,0));transform:rotate(-8deg) scale(1.08)}
.player.receiver{outline:none!important;transform:none!important}
.player.receiver .player-token-svg{filter:drop-shadow(0 0 8px rgba(255,255,255,.36))}
.serve-line{height:5px!important;background:linear-gradient(90deg,rgba(255,255,255,.95),rgba(255,255,255,.18))!important;transform-origin:left center!important;border-radius:999px!important;z-index:6!important}
body.singles-mode .serve-line{opacity:.78!important}
/* Mini court SVG tokens */
.mini-player-svg circle{display:none!important}
.mini-player-svg .mini-paddle-face{stroke:#fff;stroke-width:.32;filter:drop-shadow(0 .55px .8px rgba(0,0,0,.38))}
.mini-player-svg .mini-paddle-handle{stroke:#fff;stroke-width:.24}
.mini-player-svg.orange .mini-paddle-face,.mini-player-svg.orange .mini-paddle-handle{fill:var(--orange)}
.mini-player-svg.teal .mini-paddle-face,.mini-player-svg.teal .mini-paddle-handle{fill:var(--teal)}
.mini-player-svg.mini-server .mini-paddle-face{stroke-width:.44;filter:drop-shadow(0 0 .8px rgba(255,255,255,.95)) drop-shadow(0 .55px .8px rgba(0,0,0,.38))}
.mini-player-svg .mini-ball-cue,.landing-ball-face{fill:#FFD21F;stroke:#0F172A;stroke-width:.16}
.mini-player-svg .mini-ball-hole,.landing-ball-hole{fill:#0F172A;opacity:.9}
.mini-player-svg text{fill:#fff;font-size:1.22px;font-weight:950;pointer-events:none;paint-order:stroke;stroke:rgba(15,23,42,.35);stroke-width:.08}
.landing-dot{display:none!important}

/* v25 paddle indicator + server ball logic */
.player{background:transparent!important;border:0!important;box-shadow:none!important;outline:0!important;width:58px!important;height:66px!important}
.player.server,.player.receiver{outline:0!important;box-shadow:none!important}
.player-token{display:block;width:58px;height:66px;filter:drop-shadow(0 12px 18px rgba(0,0,0,.36))}
.player-token-svg{width:100%;height:100%;display:block;overflow:visible}
.player-token .paddle-shadow{fill:rgba(15,23,42,.28)}
.player-token .paddle-face{stroke:#ffffff;stroke-width:4.2;paint-order:stroke}
.player-token .paddle-throat,.player-token .paddle-handle{stroke:#ffffff;stroke-width:3.5;paint-order:stroke}
.player-token.orange .paddle-face,.player-token.orange .paddle-throat,.player-token.orange .paddle-handle{fill:var(--orange)}
.player-token.teal .paddle-face,.player-token.teal .paddle-throat,.player-token.teal .paddle-handle{fill:var(--teal)}
.player-token .handle-grip{fill:none;stroke:rgba(15,23,42,.55);stroke-width:1.6;stroke-linecap:round}
.player-token .paddle-label{fill:#fff;font-weight:1000;font-size:19px;font-family:Inter,ui-sans-serif,system-ui,sans-serif;dominant-baseline:middle;paint-order:stroke;stroke:rgba(15,23,42,.38);stroke-width:1.6}
.player-token .server-ball{display:none}
.player.server .server-ball{display:block}
.player-token .pickleball-cue{fill:#FFD21F;stroke:#0F172A;stroke-width:2.1}
.player-token .pickleball-hole{fill:#0F172A;opacity:.88}
.player.server .player-token{filter:drop-shadow(0 0 7px rgba(255,255,255,.75)) drop-shadow(0 12px 18px rgba(0,0,0,.38))}
.player.receiver .player-token{opacity:.96}

.mini-player-svg .mini-paddle-face{stroke:#fff;stroke-width:.34;filter:drop-shadow(0 .55px .8px rgba(0,0,0,.38))}
.mini-player-svg .mini-paddle-handle{stroke:#fff;stroke-width:.24}
.mini-player-svg.orange .mini-paddle-face,.mini-player-svg.orange .mini-paddle-handle{fill:var(--orange)}
.mini-player-svg.teal .mini-paddle-face,.mini-player-svg.teal .mini-paddle-handle{fill:var(--teal)}
.mini-player-svg .mini-server-ball{display:none}
.mini-player-svg.mini-server .mini-server-ball{display:block}
.mini-player-svg .mini-ball-cue,.landing-ball-face{fill:#FFD21F;stroke:#0F172A;stroke-width:.16}
.mini-player-svg .mini-ball-hole,.landing-ball-hole{fill:#0F172A;opacity:.9}
.mini-player-svg text{fill:#fff;font-size:1.22px;font-weight:950;pointer-events:none;paint-order:stroke;stroke:rgba(15,23,42,.35);stroke-width:.08}


/* v26 real uploaded paddle image indicators */
.player{background:transparent!important;border:0!important;box-shadow:none!important;outline:0!important;width:72px!important;height:92px!important;display:grid!important;place-items:center!important;overflow:visible!important}
.player.server,.player.receiver{outline:0!important;box-shadow:none!important}
.player-token{position:relative;display:block;width:72px;height:92px;filter:drop-shadow(0 12px 18px rgba(0,0,0,.36))}
.player-token .paddle-img{position:absolute;left:50%;top:50%;width:76px;height:96px;object-fit:contain;transform:translate(-50%,-50%) rotate(-10deg);transform-origin:center;display:block}
.player-token .paddle-server-img{display:none}
.player.server .paddle-receiver-img{display:none}
.player.server .paddle-server-img{display:block}
.player.server .player-token{filter:drop-shadow(0 0 9px rgba(255,255,255,.85)) drop-shadow(0 12px 18px rgba(0,0,0,.38))}
.player.receiver .player-token{filter:drop-shadow(0 0 6px rgba(255,255,255,.35)) drop-shadow(0 12px 18px rgba(0,0,0,.32))}
.player-label-badge{position:absolute;left:50%;top:47%;transform:translate(-50%,-50%);display:grid;place-items:center;width:28px;height:28px;border-radius:999px;color:#fff;font-weight:1000;font-size:15px;border:2px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.3);text-shadow:0 1px 2px rgba(0,0,0,.35)}
.player-token.orange .player-label-badge{background:var(--orange)}
.player-token.teal .player-label-badge{background:var(--teal)}
.mini-player-svg .mini-paddle-face,.mini-player-svg .mini-paddle-handle,.mini-player-svg .mini-server-ball{display:none!important}
.mini-player-svg .mini-paddle-img{filter:drop-shadow(0 .55px .8px rgba(0,0,0,.42))}
.mini-player-svg.mini-server .mini-paddle-img{filter:drop-shadow(0 0 .8px rgba(255,255,255,.95)) drop-shadow(0 .55px .8px rgba(0,0,0,.42))}
.mini-player-svg .mini-label-bg{stroke:#fff;stroke-width:.18;filter:drop-shadow(0 .2px .25px rgba(0,0,0,.45))}
.mini-player-svg.orange .mini-label-bg{fill:var(--orange)}
.mini-player-svg.teal .mini-label-bg{fill:var(--teal)}
.mini-player-svg text{fill:#fff;font-size:1.12px;font-weight:1000;pointer-events:none;paint-order:stroke;stroke:rgba(15,23,42,.35);stroke-width:.08}

/* v27 hard reset old drawn paddle layers. Use ONLY uploaded PNG assets. */
.player{
  background:transparent!important;
  border:0!important;
  outline:0!important;
  box-shadow:none!important;
  overflow:visible!important;
  width:76px!important;
  height:100px!important;
  display:block!important;
  transform:none!important;
}
.player::before,
.player::after{
  content:none!important;
  display:none!important;
}
.player.server,
.player.receiver{
  outline:0!important;
  border:0!important;
  box-shadow:none!important;
  transform:none!important;
}
.player-token{
  position:relative!important;
  display:block!important;
  width:76px!important;
  height:100px!important;
  background:transparent!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
  transform:none!important;
  color:inherit!important;
  font-size:inherit!important;
  filter:drop-shadow(0 10px 16px rgba(0,0,0,.34));
}
.player-token::before,
.player-token::after{
  content:none!important;
  display:none!important;
}
.player-token-svg,
.player-token .player-token-svg,
.player-token .paddle-face,
.player-token .paddle-handle,
.player-token .paddle-shadow,
.player-token .pickleball-cue,
.player-token .pickleball-hole{
  display:none!important;
}
.player-token .paddle-img{
  position:absolute!important;
  left:50%!important;
  top:50%!important;
  width:76px!important;
  height:100px!important;
  object-fit:contain!important;
  transform:translate(-50%,-50%)!important;
  transform-origin:center!important;
  display:block!important;
  pointer-events:none!important;
}
.player-token .paddle-server-img{display:none!important;}
.player.server .paddle-receiver-img{display:none!important;}
.player.server .paddle-server-img{display:block!important;}
.player.server .player-token{
  filter:drop-shadow(0 0 10px rgba(255,255,255,.92)) drop-shadow(0 10px 16px rgba(0,0,0,.34));
}
.player.receiver .player-token{
  filter:drop-shadow(0 0 5px rgba(255,255,255,.28)) drop-shadow(0 10px 16px rgba(0,0,0,.28));
}
.player-label-badge{
  position:absolute!important;
  left:50%!important;
  top:45%!important;
  transform:translate(-50%,-50%)!important;
  display:grid!important;
  place-items:center!important;
  width:28px!important;
  height:28px!important;
  border-radius:999px!important;
  color:#fff!important;
  font-weight:1000!important;
  font-size:14px!important;
  border:2px solid #fff!important;
  box-shadow:0 4px 12px rgba(0,0,0,.28)!important;
  text-shadow:0 1px 2px rgba(0,0,0,.35)!important;
  z-index:3!important;
}
.player-token.orange .player-label-badge{background:var(--orange)!important;}
.player-token.teal .player-label-badge{background:var(--teal)!important;}

/* v30 serve-line logic fix: show serve path from server paddle face clearly */
.serve-line{
  z-index:30!important;
  height:5px!important;
  background:linear-gradient(90deg,rgba(255,255,255,.98),rgba(255,255,255,.35))!important;
  box-shadow:0 0 10px rgba(255,255,255,.35);
}
.player{z-index:20!important}
.player.server{z-index:25!important}

/* v31: prevent stale serve-line coordinates during 2v2 <-> 1v1 mode switch */
body.mode-switching .player{
  transition:none!important;
}
body.mode-switching .serve-line{
  opacity:0!important;
}

/* v32 mode selector guidance + ad banner recommendation */
.mode-selector-card{margin-top:14px;padding:14px;border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.mode-selector-card strong{display:block;color:#fff;font-size:15px;margin-bottom:4px}.mode-selector-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.35}.mode-selector-card .mode-tabs{margin-top:0}.mode-tab{position:relative}.mode-tab:not(.active)::after{content:'Tap';position:absolute;right:-8px;top:-9px;font-size:9px;background:rgba(255,255,255,.14);border:1px solid var(--line);padding:2px 5px;border-radius:999px;color:var(--muted)}.mode-tab.active::after{content:'Selected';position:absolute;right:-10px;top:-9px;font-size:9px;background:rgba(0,150,136,.35);border:1px solid rgba(0,150,136,.55);padding:2px 5px;border-radius:999px;color:#fff}.headline-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.headline-link{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid var(--line);color:var(--text);font-weight:900;cursor:pointer}.headline-link:hover{background:rgba(255,255,255,.14)}
.ad-card.court:before{content:'Recommended ad banner: 1200 × 300 px'!important;position:absolute!important;left:50%!important;top:8px!important;transform:translateX(-50%)!important;z-index:2!important;background:rgba(15,23,42,.55)!important;color:white!important;font-size:11px!important;font-weight:950!important;letter-spacing:.04em!important;padding:4px 9px!important;border-radius:999px!important;display:block!important}.ad-card.court:after{content:'Mobile safe area: keep logo + CTA centered'!important;position:absolute!important;left:50%!important;bottom:8px!important;transform:translateX(-50%)!important;z-index:2!important;background:rgba(15,23,42,.55)!important;color:white!important;font-size:11px!important;font-weight:950!important;letter-spacing:.04em!important;padding:4px 9px!important;border-radius:999px!important;display:block!important}.ad-card.court{position:relative;min-height:220px;padding-top:70px;padding-bottom:54px}.ad-card.court.compact{min-height:185px}
@media(max-width:760px){.mode-selector-card{align-items:stretch}.mode-selector-card .mode-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}.headline-links{width:100%}.headline-link{flex:1}.ad-card.court:before{content:'Ad banner: 1200 × 300 px'!important;white-space:nowrap}.ad-card.court:after{content:'Mobile safe: centered text + CTA'!important;white-space:nowrap}}


/* v33 header polish + ad banner cleanup */
.feature-notes{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.feature-note{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13px;font-weight:850;line-height:1.25}.feature-note::before{content:'•';color:var(--teal);font-size:18px;line-height:0}.hero .badge{display:none!important}.headline-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;margin-bottom:14px}.headline-link{border:0!important;color:#fff!important;font-weight:950!important;box-shadow:0 12px 26px rgba(0,0,0,.20);padding:11px 16px!important}.headline-link.about-shortcut{background:#123A73!important}.headline-link.shop-shortcut{background:linear-gradient(135deg,var(--orange),var(--teal))!important}.headline-link:hover{filter:brightness(1.08)}.mode-selector-card{margin-top:0!important}.ad-card.court:after{content:none!important;display:none!important}.ad-card.court{padding-bottom:34px!important}.ad-card.court:before{content:'Recommended ad banner: 1200 × 300 px'!important}@media(max-width:760px){.feature-notes{margin-top:12px}.headline-links{width:100%;display:grid;grid-template-columns:1fr 1fr}.headline-link{width:100%}.ad-card.court:after{content:none!important;display:none!important}.ad-card.court:before{content:'Ad banner: 1200 × 300 px'!important}}


/* v34 user-facing cleanup + quiz score inputs */
.monetization-note{display:none!important}
.mini-player-svg .mini-label-bg{fill:#fff!important;stroke-width:.12!important}
.mini-player-svg.orange text{fill:var(--orange)!important;stroke:none!important;font-size:.78px!important;font-weight:1000!important}
.mini-player-svg.teal text{fill:var(--teal)!important;stroke:none!important;font-size:.78px!important;font-weight:1000!important}
.score-call-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px}.score-call-row .score-part{width:86px;max-width:26vw;text-align:center}.score-dash{font-size:28px;font-weight:1000;color:#fff;line-height:1}.score-call-row .quiz-answer{min-width:140px}
@media(max-width:760px){.score-call-row{gap:8px}.score-call-row .score-part{width:72px}.score-call-row .quiz-answer{width:100%}}

/* v35 onboarding flow from About */
.about-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.get-started-button{display:inline-flex;align-items:center;justify-content:center;padding:13px 20px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--orange),var(--teal));color:#fff;font-weight:950;cursor:pointer;box-shadow:0 14px 34px rgba(0,0,0,.24)}.contact-button.secondary{background:rgba(255,255,255,.08);border:1px solid var(--line);box-shadow:none}.onboarding-modal{position:fixed;inset:0;display:none;z-index:9999;align-items:center;justify-content:center;padding:22px}.onboarding-modal.active{display:flex}.onboarding-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.76);backdrop-filter:blur(10px)}.onboarding-card{position:relative;width:min(720px,94vw);border:1px solid var(--line);border-radius:28px;padding:26px;background:linear-gradient(135deg,rgba(17,24,39,.98),rgba(15,23,42,.95));box-shadow:0 34px 120px rgba(0,0,0,.55)}.modal-close{position:absolute;right:16px;top:16px;width:40px;height:40px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.08);color:#fff;font-size:26px;line-height:1;cursor:pointer}.onboarding-options{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}.onboarding-option{border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.06);color:#fff;text-align:left;padding:18px;cursor:pointer;display:flex;flex-direction:column;gap:8px;min-height:160px}.onboarding-option.featured{border-color:rgba(255,122,0,.4);background:linear-gradient(135deg,rgba(255,122,0,.18),rgba(0,150,136,.14))}.onboarding-option:hover{transform:translateY(-1px);background:rgba(255,255,255,.1)}.option-kicker{font-size:12px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:#FFB86B}.onboarding-option strong{font-size:34px}.onboarding-option small{font-size:15px;line-height:1.45;color:var(--muted)}@media(max-width:760px){.onboarding-options{grid-template-columns:1fr}.about-actions>*{width:100%;text-align:center}.onboarding-card{padding:22px}.onboarding-option{min-height:auto}}

/* v36 paddle indicator scale adjustment */
:root{--paddle-scale-factor:.6}
.player{
  width:46px!important;
  height:60px!important;
}
.player-token{
  width:46px!important;
  height:60px!important;
  filter:drop-shadow(0 7px 10px rgba(0,0,0,.34))!important;
}
.player-token .paddle-img{
  width:46px!important;
  height:60px!important;
}
.player.server .player-token{
  filter:drop-shadow(0 0 6px rgba(255,255,255,.85)) drop-shadow(0 7px 10px rgba(0,0,0,.34))!important;
}
.player.receiver .player-token{
  filter:drop-shadow(0 0 3px rgba(255,255,255,.28)) drop-shadow(0 7px 10px rgba(0,0,0,.28))!important;
}
.player-label-badge{
  width:18px!important;
  height:18px!important;
  font-size:9px!important;
  border-width:1.5px!important;
  top:45%!important;
}
.mini-player-svg .mini-paddle-img{
  filter:drop-shadow(0 .32px .48px rgba(0,0,0,.42))!important;
}
.mini-player-svg.mini-server .mini-paddle-img{
  filter:drop-shadow(0 0 .48px rgba(255,255,255,.95)) drop-shadow(0 .32px .48px rgba(0,0,0,.42))!important;
}
.mini-player-svg .mini-label-bg{
  stroke-width:.08!important;
}
.mini-player-svg.orange text,
.mini-player-svg.teal text{
  font-size:.47px!important;
}

/* v39 kitchen scenario quiz */
.kitchen-highlight{fill:rgba(255,255,255,.16);stroke:rgba(255,255,255,.72);stroke-width:.18;stroke-dasharray:.8 .55}
.foot-icon{font-size:2px;text-anchor:middle;dominant-baseline:central;filter:drop-shadow(0 .25px .35px rgba(0,0,0,.45))}
.kitchen-momentum{fill:none;stroke:#050505;stroke-width:.33;stroke-dasharray:.9 .55;stroke-linecap:round;marker-end:url(#arrowHead)}

/* v40 Quiz portrait layout for mobile Safari */
.mini-court-stage.portrait{
  width:100%;
  max-width:420px;
  margin:0 auto;
  padding:12px;
  border-radius:18px;
  background:rgba(30,136,229,.32);
  overflow:visible;
}
.mini-court-svg.portrait{
  display:block;
  width:min(100%,360px);
  max-height:560px;
  margin:0 auto;
  overflow:visible;
}
.mini-court-svg.portrait .mini-player-svg .mini-paddle-img{
  filter:drop-shadow(0 .65px .9px rgba(0,0,0,.46));
}
.mini-court-svg.portrait .mini-player-svg.mini-server .mini-paddle-img{
  filter:drop-shadow(0 0 1.1px rgba(255,255,255,.98)) drop-shadow(0 .65px .9px rgba(0,0,0,.46));
}
.mini-court-svg.portrait .mini-label-bg{
  stroke:#fff;
  stroke-width:.16;
  filter:drop-shadow(0 .25px .35px rgba(0,0,0,.46));
}
.mini-court-svg.portrait .mini-player-svg.orange .mini-label-bg{fill:var(--orange)!important}
.mini-court-svg.portrait .mini-player-svg.teal .mini-label-bg{fill:var(--teal)!important}
.mini-court-svg.portrait .mini-player-svg text{
  fill:#fff!important;
  font-size:1.08px!important;
  font-weight:1000!important;
  stroke:rgba(15,23,42,.25)!important;
  stroke-width:.06!important;
}
.mini-court-svg.portrait .concept-label{font-size:1.05px}
@media(max-width:760px){
  .mini-court-stage.portrait{max-width:360px;padding:10px}
  .mini-court-svg.portrait{width:min(100%,315px);max-height:540px}
  .quiz-visual{margin:10px 0 14px}
}


/* v41 quiz note placement */
.mini-court-stage.portrait{padding-top:18px!important;}
.mini-court-svg.portrait .concept-label{
  font-size:1.12px!important;
  fill:#F8FAFC!important;
  stroke:#0F172A!important;
  stroke-width:.18px!important;
  paint-order:stroke!important;
}
@media(max-width:760px){.mini-court-stage.portrait{padding-top:20px!important;}}


/* v42 New Question CTA */
#newQuiz,
#newQuiz.ghost{
  background:#FF6B35!important;
  color:#FFFFFF!important;
  border:none!important;
  font-weight:900!important;
  box-shadow:0 8px 24px rgba(255,107,53,.35)!important;
}
#newQuiz:hover,
#newQuiz.ghost:hover{
  background:#FF7F50!important;
}

/* v43 Mobile sync for New Question CTA */
button#newQuiz,
button#newQuiz.ghost,
#quiz button#newQuiz,
#quiz button#newQuiz.ghost{
  background:#FF6B35!important;
  background-image:none!important;
  color:#FFFFFF!important;
  border:0!important;
  font-weight:950!important;
  box-shadow:0 8px 24px rgba(255,107,53,.38)!important;
  text-shadow:none!important;
}
button#newQuiz:hover,
button#newQuiz.ghost:hover,
#quiz button#newQuiz:hover,
#quiz button#newQuiz.ghost:hover{
  background:#FF7F50!important;
  color:#FFFFFF!important;
}
@media(max-width:900px){
  button#newQuiz,
  button#newQuiz.ghost,
  #quiz button#newQuiz,
  #quiz button#newQuiz.ghost{
    width:100%!important;
    min-height:52px!important;
    background:#FF6B35!important;
    color:#FFFFFF!important;
    border:0!important;
    font-size:16px!important;
    font-weight:950!important;
    box-shadow:0 10px 26px rgba(255,107,53,.42)!important;
  }
}
@media(max-width:760px){
  button#newQuiz,
  button#newQuiz.ghost,
  #quiz button#newQuiz,
  #quiz button#newQuiz.ghost{
    background:#FF6B35!important;
    color:#FFFFFF!important;
  }
}

/* v44: hide quiz visual area when a question does not need a court diagram */
.quiz-visual:empty{display:none!important;}
.no-visual{display:none!important;}


/* v45 hero cleanup: language flags + score only inside simulator */
.hero{position:relative}
.language-row{margin-top:18px;margin-bottom:10px;display:flex;align-items:center;gap:10px}
.flag-lang{display:inline-flex;background:rgba(255,255,255,.08);border:1px solid var(--line);border-radius:999px;padding:5px;gap:4px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.flag-lang button{font-size:24px;line-height:1;padding:9px 14px;border-radius:999px;background:transparent;filter:saturate(.9);min-width:58px}
.flag-lang button.active{background:#fff;filter:saturate(1.1);box-shadow:0 10px 24px rgba(0,0,0,.2)}
.hero-actions{display:none!important}
.sim-score-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:8px}
.sim-score-header h2{margin-bottom:0}.sim-score-call{font-size:24px;padding:10px 16px;border-radius:18px;min-width:130px;text-align:center;flex:0 0 auto}
@media(max-width:760px){.language-row{margin-top:16px}.flag-lang{width:auto}.flag-lang button{font-size:26px;min-width:64px;padding:10px 16px}.sim-score-header{flex-direction:column}.sim-score-call{width:100%;font-size:30px;padding:14px 18px}}


/* v49: mobile simulator HUD and compact court. Desktop layout is intentionally unchanged. */
.mobile-sim-hud{display:none;}
@media(max-width:760px){
  #simulator .layout{display:flex;flex-direction:column;gap:12px;}
  #simulator .court-card{order:1;padding:14px 12px 14px;border-radius:24px;}
  #simulator .controls{order:2;display:none;}
  #simulator .court-topline{margin-bottom:8px;align-items:flex-start;}
  #simulator .court-topline h2{font-size:26px;margin-bottom:0;}
  #simulator #statusPill{display:none;}

  .mobile-sim-hud{display:block;margin:0 0 8px;}
  .mobile-hud-main{display:grid;grid-template-columns:1fr;gap:4px;padding:10px 12px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,rgba(255,122,0,.18),rgba(0,150,136,.16));box-shadow:0 12px 26px rgba(0,0,0,.2);}
  .mobile-score-call{font-size:28px;line-height:1;font-weight:1000;text-align:center;color:#fff;letter-spacing:.02em;}
  .mobile-status{text-align:center;font-size:13px;font-weight:950;color:#EAF2FF;}
  .mobile-rally-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;}
  .mobile-rally-actions .action{min-height:46px;border-radius:16px;font-size:13px;line-height:1.15;padding:10px 8px;}
  .mobile-reset{margin-top:8px;min-height:42px;border-radius:16px;font-size:13px;}

  #simulator .court-wrap{padding:6px 0 2px;overflow:visible;}
  #simulator .dim{display:none;}
  #simulator .court{
    width:calc(100% - 78px);
    aspect-ratio:20/35.2; /* v49: mobile court length shortened to 80% of the regulation visual height */
    max-height:48vh;
    margin:0 auto 10px;
    overflow:visible;
    border-width:4px;
    border-radius:14px;
  }
  #simulator .court:before{content:"20 × 44 ft";font-size:9px;top:6px;padding:3px 7px;white-space:nowrap;}
  #simulator .court:after{content:"Kitchen 7 ft";font-size:9px;bottom:6px;padding:3px 7px;white-space:nowrap;}
  #simulator .zone-label{font-size:9px;max-width:42%;line-height:1.15;letter-spacing:.02em;}
  #simulator .service-area.left .zone-label{left:8px;}
  #simulator .service-area.right .zone-label{right:8px;}

  #simulator .team-label{font-size:10px;padding:5px 7px;line-height:1;white-space:nowrap;z-index:30;box-shadow:0 8px 18px rgba(0,0,0,.28);}
  #simulator .team-label.orange{left:-46px;top:14%;right:auto;bottom:auto;}
  #simulator .team-label.teal{right:-46px;bottom:14%;left:auto;top:auto;}
  #simulator .player{width:52px!important;height:66px!important;}
  #simulator .player-token{width:52px!important;height:66px!important;}
  #simulator .player-token .paddle-img{width:54px!important;height:68px!important;}
  #simulator .player-label-badge{width:21px!important;height:21px!important;font-size:11px!important;border-width:1.5px!important;}
  #simulator .result-box{margin-top:8px;padding:12px 14px;border-radius:18px;}
  #simulator .result-box h3{font-size:16px;margin-bottom:5px;}
  #simulator .result-box p{font-size:13px;line-height:1.3;margin:0;}
  #simulator .sim-ad-slot{display:none;}
}
@media(max-width:420px){
  .mobile-score-call{font-size:26px;}
  #simulator .court{width:calc(100% - 70px);max-height:46vh;}
  #simulator .team-label.orange{left:-42px;}
  #simulator .team-label.teal{right:-42px;}
}


/* v51: team-specific uploaded paddle PNGs + locked setup controls */
.locked-control{opacity:.72;position:relative;}
.locked-control .pick{cursor:not-allowed!important;}
.locked-control .pick:not(.active){background:rgba(15,23,42,.38)!important;color:rgba(238,245,255,.62)!important;}
.locked-control .pick.active{box-shadow:inset 0 0 0 1px rgba(255,255,255,.22);}
.player-token .paddle-img{width:82px!important;height:104px!important;}
@media(max-width:760px){
  #simulator .player-token .paddle-img{width:58px!important;height:73px!important;}
}


/* v52: regulation court ratio, runoff area, baseline positions, serve-arrow styling */
#simulator .court-wrap{overflow:visible;padding-left:54px;padding-right:54px;}
#simulator .court{overflow:visible;box-shadow:0 0 0 22px rgba(59,130,246,.18), inset 0 0 80px rgba(0,0,0,.18);}
#simulator .player{background:transparent!important;border:0!important;box-shadow:none!important;outline:0!important;}
#simulator .player-label-badge{left:auto!important;right:-6px!important;top:auto!important;bottom:2px!important;transform:none!important;}
#simulator .serve-line{height:0!important;border-top:4px dashed rgba(255,255,255,.9)!important;background:transparent!important;box-shadow:0 0 10px rgba(255,255,255,.3)!important;z-index:18!important;}
#simulator .serve-line::after{content:"";position:absolute;left:50%;top:0;transform:translate(-50%,-50%);width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:14px solid rgba(255,255,255,.96);filter:drop-shadow(0 0 5px rgba(255,255,255,.55));}
#simulator .serve-line.show{opacity:.96!important;}
.serve-target-line{stroke-dasharray:1.05 .72!important;marker-end:none!important;marker-mid:url(#arrowHead)!important;}
.last-shot{stroke-dasharray:1.05 .72!important;marker-mid:url(#arrowHead)!important;}
.mini-player-svg .mini-label-bg{cx:.74!important;cy:1.28!important;}

@media(max-width:760px){
  #simulator .court-wrap{padding:20px 0 28px;overflow:visible;}
  #simulator .court{width:calc(100% - 88px);aspect-ratio:20/44;max-height:55vh;box-shadow:0 0 0 16px rgba(59,130,246,.18), inset 0 0 80px rgba(0,0,0,.18);}
  #simulator .player-label-badge{right:-4px!important;bottom:0!important;}
  #simulator .serve-line{border-top-width:3px!important;}
  #simulator .serve-line::after{border-top-width:6px;border-bottom-width:6px;border-left-width:11px;}
}
@media(max-width:420px){
  #simulator .court{width:calc(100% - 82px);max-height:54vh;}
}

/* v53 polish: solid serve line with arrow, safer ready positions, larger mobile text */
#simulator .serve-line{
  height:4px!important;
  border-top:0!important;
  background:rgba(255,255,255,.96)!important;
  box-shadow:0 0 10px rgba(255,255,255,.28)!important;
  border-radius:999px!important;
  z-index:18!important;
}
#simulator .serve-line::after{
  content:""!important;
  position:absolute!important;
  right:-13px!important;
  left:auto!important;
  top:50%!important;
  transform:translateY(-50%)!important;
  width:0!important;
  height:0!important;
  border-top:7px solid transparent!important;
  border-bottom:7px solid transparent!important;
  border-left:13px solid rgba(255,255,255,.98)!important;
  filter:drop-shadow(0 0 5px rgba(255,255,255,.45))!important;
}
#simulator .serve-line.show{opacity:.96!important;}
@media(max-width:760px){
  .tab{font-size:16px!important;padding:15px 18px!important;line-height:1.12!important;}
  .tabs{gap:9px!important;}
  .mode-tab{font-size:16px!important;padding:14px 18px!important;}
  .headline-link{font-size:16px!important;padding:13px 16px!important;}
  .get-started-button{font-size:22px!important;padding:19px 30px!important;min-height:58px!important;}
  #simulator .serve-line{height:3px!important;}
  #simulator .serve-line::after{right:-11px!important;border-top-width:6px!important;border-bottom-width:6px!important;border-left-width:11px!important;}
}
