.landing{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.landing-content{text-align:center;max-width:560px;width:100%}.landing-title{font-size:3rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text) 0%,var(--green) 50%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-subtitle{color:var(--text-muted);margin-bottom:2.5rem;font-size:1.1rem;line-height:1.5}.game-roster{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.game-card{position:relative;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem 1.5rem;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:18px;color:var(--text);text-align:center;text-decoration:none;transition:border-color .2s,transform .15s,background .2s;cursor:pointer;font-family:inherit;font-size:inherit;aspect-ratio:1}.game-card:hover{transform:translateY(-4px)}.game-card--chess:hover{border-color:var(--green);background:#4ecca30f}.game-card--tictactoe:hover{border-color:var(--accent);background:#e945600f}.game-card--go:hover{border-color:var(--text-muted);background:#ffffff0a}.game-card--indy5:hover{border-color:var(--green);background:#4ecca30f}.game-card--babytrivia:hover{border-color:#f0a500;background:#f0a5000f}.game-card-external{position:absolute;top:.75rem;right:.75rem;color:var(--text-muted);opacity:.5;transition:opacity .15s}.game-card:hover .game-card-external{opacity:.9}.game-card-icon{flex:1;display:flex;align-items:center;justify-content:center;font-size:5rem;line-height:1}.game-card--chess .game-card-icon{filter:drop-shadow(0 4px 12px rgba(78,204,163,.35))}.game-card--tictactoe .game-card-icon{font-weight:800;font-size:4.5rem;color:var(--accent);filter:drop-shadow(0 4px 12px rgba(233,69,96,.35))}.game-card-yin-yang{width:5rem;height:5rem;color:var(--text);filter:drop-shadow(0 4px 14px rgba(0,0,0,.35))}.game-card--go .game-card-icon{color:var(--text)}.game-card--babytrivia .game-card-icon{font-size:4.5rem;filter:drop-shadow(0 4px 12px rgba(240,165,0,.35))}.game-card-info{flex-shrink:0}.game-card-name{font-size:1.15rem;font-weight:700;margin-bottom:.3rem}.game-card-desc{font-size:.8rem;color:var(--text-muted);line-height:1.4}.landing-footer{position:fixed;bottom:.75rem;right:1rem;font-size:.7rem;color:var(--text-muted);opacity:.45;pointer-events:none;font-variant-numeric:tabular-nums;transition:opacity .6s ease}.landing-footer--hidden{opacity:0}@media(max-width:480px){.game-roster{grid-template-columns:1fr;max-width:260px;margin:0 auto}}.home{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.home-card{text-align:center;max-width:420px;width:100%}.home-back-link{display:inline-block;margin-bottom:1.5rem;color:var(--text-muted);font-size:.9rem;transition:color .15s}.home-back-link:hover{color:var(--text)}.home-icon{font-size:4rem;margin-bottom:.5rem;filter:drop-shadow(0 2px 8px rgba(78,204,163,.4))}.home-title{font-size:2.5rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text) 0%,var(--green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.5}.time-controls{display:flex;flex-direction:column;gap:.75rem}.time-btn{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-card);border:2px solid rgba(255,255,255,.06);border-radius:12px;color:var(--text);font-size:1rem;transition:border-color .2s,transform .15s,background .2s}.time-btn:hover:not(:disabled){border-color:var(--green);background:#4ecca314;transform:translateY(-2px)}.time-btn:disabled{opacity:.5;cursor:not-allowed}.time-btn-label{font-size:1.3rem;font-weight:700}.time-btn-desc{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.square{position:relative;width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none}.square.light{background-color:var(--square-light)}.square.dark{background-color:var(--square-dark)}.square.selected{background-color:var(--square-selected)!important;box-shadow:inset 0 0 0 3px #ffff50b3}.square.last-move{background-color:var(--square-last-move)}.square.light.last-move{background-color:#f5f682}.square.dark.last-move{background-color:#baca44}.square.check{background:radial-gradient(circle,#ff0000 0%,#cc0000 40%,transparent 70%)}.legal-dot{position:absolute;width:28%;height:28%;border-radius:50%;background-color:var(--square-legal);pointer-events:none;z-index:1}.piece{top:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:2}.piece img{width:85%;height:85%;object-fit:contain;filter:drop-shadow(1px 1px 1px rgba(0,0,0,.3))}.promotion-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;border-radius:4px}.promotion-modal{background:var(--bg-card);padding:1rem 1.5rem;border-radius:12px;text-align:center}.promotion-modal p{margin-bottom:.75rem;font-weight:600}.promotion-options{display:flex;gap:.5rem}.promotion-btn{width:56px;height:56px;background:var(--bg-surface);border:2px solid transparent;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:border-color .15s,transform .15s}.promotion-btn:hover{border-color:var(--accent);transform:scale(1.1)}.promotion-btn img{width:40px;height:40px}.board-container{position:relative;display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:0;width:min(85vmin,560px);-webkit-user-select:none;user-select:none}.board{position:relative;display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);border:3px solid #333;border-radius:4px;overflow:hidden;grid-column:2;grid-row:1;aspect-ratio:1}.file-labels{grid-column:2;grid-row:2;display:flex;justify-content:space-around;padding-top:4px}.rank-labels{grid-column:1;grid-row:1;display:flex;flex-direction:column;justify-content:space-around;align-items:center;padding-right:6px}.coord-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.captured-col{display:flex;flex-direction:column;justify-content:space-between;align-self:stretch;width:120px;flex-shrink:0;padding:4px 0}.captured-group{display:flex;flex-wrap:wrap;gap:2px;max-width:120px}.captured-piece{width:28px;height:28px;object-fit:contain;opacity:.85;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.clock-container{display:flex;flex-direction:column;gap:.75rem;min-width:120px}.clock-face{display:flex;flex-direction:column;align-items:center;padding:.75rem 1rem;background:var(--bg-card);border-radius:10px;border:2px solid transparent;transition:border-color .2s,background .2s}.clock-face.active{border-color:var(--green);background:#4ecca31a}.clock-face.low .clock-time{color:var(--danger)}.clock-face.active.low{border-color:var(--danger);background:#e945601a;animation:pulse-danger 1s ease-in-out infinite}@keyframes pulse-danger{0%,to{opacity:1}50%{opacity:.7}}.clock-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600;margin-bottom:.25rem}.clock-time{font-size:1.6rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.02em}.game-expired-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.game-expired-card{text-align:center;background:var(--bg-card);padding:2.5rem 3rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);max-width:480px;width:100%}.game-expired-card h2{margin-bottom:1rem;font-weight:700}.game-expired-subtext{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem}.game-expired-btn{padding:.75rem 2rem;background:var(--green);color:#111;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .15s}.game-expired-btn:hover{background:var(--green-hover)}.gameover-modal{background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2.5rem 3rem;text-align:center;animation:modal-in .3s ease-out}@keyframes modal-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.gameover-title{font-size:2rem;font-weight:800;margin-bottom:.5rem}.gameover-subtitle{font-size:1rem;color:var(--text-muted);margin-bottom:1.5rem}.gameover-btn{background:var(--green);color:#111;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;transition:background .15s,transform .15s}.gameover-btn:hover{background:var(--green-hover);transform:translateY(-1px)}.game-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.game-layout{display:flex;gap:2rem;align-items:flex-start}.game-sidebar{display:flex;flex-direction:column;gap:1rem;width:160px;flex-shrink:0}.game-meta{text-align:center}.you-are{font-size:.9rem;color:var(--text-muted)}.you-are strong{color:var(--text)}.turn-indicator{font-size:1rem;font-weight:600;margin-top:.25rem;color:var(--green)}.options-accordion{background:var(--bg-surface);border:1px solid rgba(255,255,255,.08);border-radius:10px}.options-toggle{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem .8rem;font-size:.78rem;font-weight:600;color:var(--text-muted);cursor:pointer;list-style:none;transition:color .15s;-webkit-user-select:none;user-select:none}.options-toggle::-webkit-details-marker{display:none}.options-toggle:after{content:"▸";font-size:.7rem;transition:transform .25s ease}.options-accordion[open] .options-toggle:after{transform:rotate(90deg)}.options-toggle:hover{color:var(--text)}.options-body-wrapper{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease;overflow:hidden}.options-accordion[open] .options-body-wrapper{grid-template-rows:1fr}.options-body{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:0 .8rem;min-height:0;overflow:hidden;transition:padding .25s ease}.options-accordion[open] .options-body{padding:0 .8rem .8rem}.options-body>*+*{padding-top:.75rem;border-top:1px solid rgba(255,255,255,.08)}.resign-btn{padding:.5rem 1rem;width:100%;background:transparent;border:2px solid var(--danger);color:var(--danger);border-radius:8px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.resign-btn:hover{background:var(--danger);color:#fff}.anim-selector{display:flex;flex-direction:column;align-items:center;gap:.3rem;width:100%}.anim-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.anim-toggle{display:flex;width:100%;background:#0003;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.anim-toggle button{flex:1;padding:.3rem .5rem;font-size:.75rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.anim-toggle button:hover:not(.active){color:var(--text)}.anim-toggle button.active{background:var(--green);color:#111;font-weight:600}.game-status-card{text-align:center;background:var(--bg-card);padding:2.5rem 3rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);max-width:480px;width:100%}.game-status-card h2{margin-bottom:1rem;font-weight:700}.share-hint{color:var(--text-muted);font-size:.9rem;margin-bottom:.75rem}.share-row{display:flex;gap:.5rem}.share-input{flex:1;padding:.65rem .8rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-family:monospace;font-size:.85rem;outline:none}.share-input:focus{border-color:var(--green)}.copy-btn{padding:.65rem 1.2rem;background:var(--green);color:#111;border:none;border-radius:8px;font-weight:600;font-size:.85rem;white-space:nowrap;transition:background .15s}.copy-btn:hover{background:var(--green-hover)}.name-input-row{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.25rem}.name-display-row{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.25rem;min-height:2.5rem}.name-value{font-size:1.1rem;font-weight:600;color:var(--text)}.name-edit-btn{display:inline-flex;align-items:center;justify-content:center;padding:.3rem;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.name-edit-btn:hover{color:var(--text);border-color:#ffffff4d}.name-label{font-size:.8rem;color:var(--text-muted);text-align:left}.name-input{padding:.65rem .8rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-size:.95rem;outline:none;text-align:center;transition:border-color .15s}.name-input:focus{border-color:var(--green)}.join-btn{padding:.75rem 2rem;background:var(--green);color:#111;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .15s}.join-btn:hover{background:var(--green-hover)}.share-buttons{display:flex;gap:.5rem;margin-top:.75rem;justify-content:center}.share-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;text-decoration:none;transition:opacity .15s,transform .15s;cursor:pointer}.share-btn:hover{opacity:.85;transform:scale(1.08)}.share-whatsapp{background:#25d366;color:#fff}.share-sms{background:#3b82f6;color:#fff}.player-names{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.player-name-w,.player-name-b{color:var(--text)}.spectator-label{font-weight:600;color:var(--text-muted);font-style:italic}.error-text{color:var(--danger);font-weight:600}.spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.leave-warning{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:.4rem 1rem;font-size:.75rem;color:var(--text-muted);background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:.02em}.disconnect-banner{position:fixed;top:0;left:0;right:0;text-align:center;padding:.5rem 1rem 0;font-size:.85rem;font-weight:600;color:#111;background:var(--warning, #f59e0b);z-index:100}.disconnect-countdown-bar{height:4px;background:#0003;margin-top:.5rem;overflow:hidden;border-radius:0 0 4px 4px}.disconnect-countdown-fill{height:100%;background:#00000059;transition:width .2s linear}@media(max-width:700px){.game-layout{flex-direction:column-reverse;gap:1rem}.game-sidebar{flex-direction:row;align-items:center;justify-content:center;flex-wrap:wrap;width:auto}.clock-container{flex-direction:row}.captured-col{flex-direction:row;justify-content:space-between;min-width:auto;width:100%}}.ttt-home{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.ttt-home-card{text-align:center;max-width:420px;width:100%}.ttt-back-link{display:inline-block;margin-bottom:1.5rem;color:var(--text-muted);font-size:.9rem;transition:color .15s}.ttt-back-link:hover{color:var(--text)}.ttt-home-icon{font-size:4rem;font-weight:800;margin-bottom:.5rem;color:var(--accent);filter:drop-shadow(0 2px 8px rgba(233,69,96,.4))}.ttt-home-title{font-size:2.5rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ttt-home-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.5}.ttt-create-btn{padding:1rem 3rem;background:var(--accent);border:none;border-radius:12px;color:#fff;font-size:1.15rem;font-weight:700;transition:background .15s,transform .15s}.ttt-create-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px)}.ttt-create-btn:disabled{opacity:.5;cursor:not-allowed}.ttt-board{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:min(400px,85vw);aspect-ratio:1;background:#ffffff14;border-radius:16px;padding:6px}.ttt-cell{aspect-ratio:1;background:var(--bg-card);border:none;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:default;position:relative;transition:background .15s}.ttt-cell--clickable{cursor:pointer}.ttt-cell--clickable:hover{background:#ffffff0f}.ttt-cell--winning{background:#4ecca326}.ttt-ghost{position:absolute;font-size:2.5rem;opacity:0;transition:opacity .15s;pointer-events:none;-webkit-user-select:none;user-select:none}.ttt-ghost--x{color:var(--accent)}.ttt-ghost--o{color:var(--green)}.ttt-cell--clickable:hover .ttt-ghost{opacity:.2}.ttt-mark{width:55%;height:55%}.ttt-x{stroke:var(--accent);stroke-width:10;stroke-linecap:round;fill:none;animation:ttt-draw .3s ease-out}.ttt-o{stroke:var(--green);stroke-width:8;stroke-linecap:round;fill:none;animation:ttt-draw .35s ease-out}.ttt-winning{filter:drop-shadow(0 0 8px currentColor)}.ttt-x.ttt-winning{filter:drop-shadow(0 0 8px var(--accent))}.ttt-o.ttt-winning{filter:drop-shadow(0 0 8px var(--green))}@keyframes ttt-draw{0%{stroke-dasharray:200;stroke-dashoffset:200}to{stroke-dashoffset:0}}@media(max-width:500px){.ttt-board{gap:4px;padding:4px;border-radius:12px}.ttt-cell{border-radius:8px}}.ttt-gameover-modal{background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2.5rem 3rem;text-align:center;animation:ttt-modal-in .3s ease-out;min-width:320px}@keyframes ttt-modal-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.ttt-gameover-title{font-size:2rem;font-weight:800;margin-bottom:.5rem}.ttt-gameover-subtitle{font-size:1rem;color:var(--text-muted);margin-bottom:1.5rem}.ttt-gameover-actions{display:flex;flex-direction:column;gap:.6rem;align-items:center}.ttt-gameover-play-again{background:var(--green);color:#111;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;width:100%;transition:background .15s,transform .15s}.ttt-gameover-play-again:hover{background:var(--green-hover);transform:translateY(-1px)}.ttt-gameover-leave{background:transparent;color:var(--text-muted);border:1px solid rgba(255,255,255,.1);padding:.6rem 1.5rem;border-radius:8px;font-size:.85rem;font-weight:500;width:100%;transition:color .15s,border-color .15s}.ttt-gameover-leave:hover{color:var(--text);border-color:#ffffff40}.ttt-gameover-waiting{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.75rem 1rem;color:var(--text-muted);font-size:.9rem}.ttt-gameover-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--green);border-radius:50%;animation:ttt-modal-spin .8s linear infinite}@keyframes ttt-modal-spin{to{transform:rotate(360deg)}}.ttt-game-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.ttt-game-layout{display:flex;gap:2rem;align-items:center}.ttt-game-sidebar{display:flex;flex-direction:column;gap:1rem;width:160px;flex-shrink:0}.ttt-game-meta{text-align:center}.ttt-you-are{font-size:.9rem;color:var(--text-muted)}.ttt-you-are strong{color:var(--text)}.ttt-mark-X{color:var(--accent)!important}.ttt-mark-O{color:var(--green)!important}.ttt-player-names{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.ttt-pname-x{color:var(--accent)}.ttt-pname-o{color:var(--green)}.ttt-turn-indicator{font-size:1rem;font-weight:600;margin-top:.5rem;color:var(--green)}.ttt-spectator-label{font-weight:600;color:var(--text-muted);font-style:italic}.ttt-resign-btn{padding:.5rem 1rem;width:100%;background:transparent;border:2px solid var(--danger);color:var(--danger);border-radius:8px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.ttt-resign-btn:hover{background:var(--danger);color:#fff}.ttt-status-card{text-align:center;background:var(--bg-card);padding:2.5rem 3rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);max-width:480px;width:100%}.ttt-status-card h2{margin-bottom:1rem;font-weight:700}.ttt-share-hint{color:var(--text-muted);font-size:.9rem;margin-bottom:.75rem}.ttt-share-row{display:flex;gap:.5rem}.ttt-share-input{flex:1;padding:.65rem .8rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-family:monospace;font-size:.85rem;outline:none}.ttt-share-input:focus{border-color:var(--accent)}.ttt-copy-btn{padding:.65rem 1.2rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.85rem;white-space:nowrap;transition:background .15s}.ttt-copy-btn:hover{background:var(--accent-hover)}.ttt-name-input-row{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.25rem}.ttt-name-display-row{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.25rem;min-height:2.5rem}.ttt-name-value{font-size:1.1rem;font-weight:600;color:var(--text)}.ttt-name-edit-btn{display:inline-flex;align-items:center;justify-content:center;padding:.3rem;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.ttt-name-edit-btn:hover{color:var(--text);border-color:#ffffff4d}.ttt-name-input{padding:.65rem .8rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-size:.95rem;outline:none;text-align:center;transition:border-color .15s}.ttt-name-input:focus{border-color:var(--accent)}.ttt-join-btn{padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .15s}.ttt-join-btn:hover{background:var(--accent-hover)}.ttt-share-buttons{display:flex;gap:.5rem;margin-top:.75rem;justify-content:center}.ttt-share-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;text-decoration:none;transition:opacity .15s,transform .15s;cursor:pointer}.ttt-share-btn:hover{opacity:.85;transform:scale(1.08)}.ttt-share-whatsapp{background:#25d366;color:#fff}.ttt-share-sms{background:#3b82f6;color:#fff}.ttt-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:ttt-spin .8s linear infinite;margin:0 auto 1rem}@keyframes ttt-spin{to{transform:rotate(360deg)}}.ttt-error-text{color:var(--danger);font-weight:600}.ttt-leave-warning{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:.4rem 1rem;font-size:.75rem;color:var(--text-muted);background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:.02em}.ttt-disconnect-banner{position:fixed;top:0;left:0;right:0;text-align:center;padding:.5rem 1rem 0;font-size:.85rem;font-weight:600;color:#111;background:var(--warning, #f59e0b);z-index:100}.ttt-disconnect-countdown-bar{height:4px;background:#0003;margin-top:.5rem;overflow:hidden;border-radius:0 0 4px 4px}.ttt-disconnect-countdown-fill{height:100%;background:#00000059;transition:width .2s linear}@media(max-width:700px){.ttt-game-layout{flex-direction:column-reverse;gap:1rem}.ttt-game-sidebar{flex-direction:row;align-items:center;justify-content:center;flex-wrap:wrap;width:auto}}.go-home{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.go-home-card{text-align:center;max-width:420px;width:100%}.go-back-link{display:inline-block;margin-bottom:1.5rem;color:var(--text-muted);font-size:.9rem;transition:color .15s}.go-back-link:hover{color:var(--text)}.go-home-icon{display:flex;align-items:center;justify-content:center;gap:.2em;font-size:4rem;line-height:1;margin-bottom:.5rem;filter:drop-shadow(0 2px 8px rgba(233,69,96,.35))}.go-home-icon-w{filter:brightness(1.15) drop-shadow(0 1px 4px rgba(0,0,0,.4))}.go-home-title{font-size:2.5rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.go-home-subtitle{color:var(--text-muted);margin-bottom:1.25rem;font-size:1.05rem;line-height:1.5}.go-size-picker{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}.go-size-option{min-width:4.25rem;padding:.55rem .85rem;font-size:.95rem;font-weight:600;font-family:inherit;color:var(--text-muted);background:var(--bg-surface, rgba(255, 255, 255, .06));border:2px solid rgba(255,255,255,.12);border-radius:10px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.go-size-option:hover:not(:disabled){color:var(--text);border-color:#ffffff38}.go-size-option:disabled{opacity:.55;cursor:not-allowed}.go-size-option--active{color:#fff;background:var(--accent);border-color:var(--accent)}.go-size-option--active:hover:not(:disabled){color:#fff;border-color:var(--accent-hover);background:var(--accent-hover)}.go-create-btn{padding:1rem 3rem;background:var(--accent);border:none;border-radius:12px;color:#fff;font-size:1.15rem;font-weight:700;transition:background .15s,transform .15s}.go-create-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px)}.go-create-btn:disabled{opacity:.5;cursor:not-allowed}.go-board-wrap{display:flex;flex-direction:column;align-items:center;gap:1rem;flex-shrink:0}.go-board{display:grid;width:min(92vw,560px);aspect-ratio:1;min-width:0;min-height:0;background:linear-gradient(145deg,#c9a574,#a67c52,#8b6914);border:3px solid #5c4018;border-radius:4px;box-shadow:inset 0 0 0 2px #ffffff1f,0 8px 24px #00000059;padding:0;overflow:hidden}.go-point{position:relative;margin:0;padding:0;border:none;background:transparent;cursor:default;min-width:0;min-height:0;width:100%;height:100%;box-sizing:border-box;align-self:stretch;justify-self:stretch}.go-point:before,.go-point:after{content:"";position:absolute;background:#1e160ce0;pointer-events:none}.go-point:before{left:50%;top:0;bottom:0;width:1px;transform:translate(-50%)}.go-point:after{top:50%;left:0;right:0;height:1px;transform:translateY(-50%)}.go-hoshi-dot{position:absolute;left:50%;top:50%;width:22%;max-width:6px;aspect-ratio:1;border-radius:50%;background:#1e160c;transform:translate(-50%,-50%);z-index:1;pointer-events:none}.go-point--last-move .go-stone{box-shadow:0 0 0 2px #e94560,0 2px 6px #00000073}.go-point--clickable{cursor:pointer}.go-point--clickable:hover:not(:disabled){background:#e945601f}.go-stone{position:absolute;left:50%;top:50%;width:72%;max-width:22px;aspect-ratio:1;border-radius:50%;transform:translate(-50%,-50%);z-index:2;pointer-events:none;box-shadow:0 2px 5px #0006}.go-stone--black{background:radial-gradient(circle at 30% 30%,#4a4a4a,#0a0a0a 60%);border:1px solid #000}.go-stone--white{background:radial-gradient(circle at 30% 30%,#fff,#d8d8d8 55%,#a8a8a8);border:1px solid #666}.go-pass-btn{padding:.55rem 1.4rem;background:var(--surface-elevated, #2a2a35);border:2px solid var(--text-muted, #888);color:var(--text, #eee);border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}.go-pass-btn:hover:not(:disabled){border-color:var(--accent, #e94560);color:var(--accent, #e94560)}.go-pass-btn:disabled{opacity:.38;cursor:not-allowed}@media(max-width:520px){.go-board-wrap{width:100%;max-width:100%}.go-board{width:100%;max-width:560px;margin-inline:auto;border-width:2px;box-shadow:inset 0 0 0 1px #ffffff1a,0 4px 16px #0000004d}.go-stone{max-width:min(26px,11vmin)}}.gameover-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.go-gameover-modal{background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2.5rem 3rem;text-align:center;animation:go-modal-in .3s ease-out;min-width:320px}@keyframes go-modal-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.go-gameover-title{font-size:2rem;font-weight:800;margin-bottom:.5rem}.go-gameover-subtitle{font-size:1rem;color:var(--text-muted);margin-bottom:1.5rem}.go-gameover-actions{display:flex;flex-direction:column;gap:.6rem;align-items:center}.go-gameover-play-again{background:var(--green);color:#111;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;width:100%;transition:background .15s,transform .15s}.go-gameover-play-again:hover{background:var(--green-hover);transform:translateY(-1px)}.go-gameover-leave{background:transparent;color:var(--text-muted);border:1px solid rgba(255,255,255,.1);padding:.6rem 1.5rem;border-radius:8px;font-size:.85rem;font-weight:500;width:100%;transition:color .15s,border-color .15s}.go-gameover-leave:hover{color:var(--text);border-color:#ffffff40}.go-gameover-waiting{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.75rem 1rem;color:var(--text-muted);font-size:.9rem}.go-gameover-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--green);border-radius:50%;animation:go-modal-spin .8s linear infinite}@keyframes go-modal-spin{to{transform:rotate(360deg)}}.go-game-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.go-game-layout{display:flex;gap:2rem;align-items:center}.go-game-sidebar{display:flex;flex-direction:column;gap:1rem;width:160px;flex-shrink:0}.go-game-meta{text-align:center}.go-you-are{font-size:.9rem;color:var(--text-muted)}.go-you-are strong{color:var(--text)}.go-mark-B{color:var(--accent)!important}.go-mark-W{color:var(--green)!important}.go-player-names{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.go-pname-b{color:var(--accent)}.go-pname-w{color:var(--green)}.go-board-size-meta,.go-prisoners-meta{font-size:.72rem;color:var(--text-muted);margin-top:.35rem;line-height:1.35}.go-turn-indicator{font-size:1rem;font-weight:600;margin-top:.5rem;color:var(--green);min-height:1.35em}.go-spectator-label{font-weight:600;color:var(--text-muted);font-style:italic}.go-resign-btn{padding:.5rem 1rem;width:100%;background:transparent;border:2px solid var(--danger);color:var(--danger);border-radius:8px;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.go-resign-btn:hover{background:var(--danger);color:#fff}.go-status-card{text-align:center;background:var(--bg-card);padding:2.5rem 3rem;border-radius:16px;border:1px solid rgba(255,255,255,.06);max-width:480px;width:100%}.go-status-card h2{margin-bottom:1rem;font-weight:700}.go-share-hint{color:var(--text-muted);font-size:.9rem;margin-bottom:.75rem}.go-share-row{display:flex;gap:.5rem}.go-share-input{flex:1;padding:.65rem .8rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-family:monospace;font-size:.85rem;outline:none}.go-share-input:focus{border-color:var(--accent)}.go-copy-btn{padding:.65rem 1.2rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.85rem;white-space:nowrap;transition:background .15s}.go-copy-btn:hover{background:var(--accent-hover)}.go-name-input-row{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.25rem}.go-name-display-row{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.25rem;min-height:2.5rem}.go-name-value{font-size:1.1rem;font-weight:600;color:var(--text)}.go-name-edit-btn{display:inline-flex;align-items:center;justify-content:center;padding:.3rem;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.go-name-edit-btn:hover{color:var(--text);border-color:#ffffff4d}.go-name-input{padding:.65rem .8rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-size:.95rem;outline:none;text-align:center;transition:border-color .15s}.go-name-input:focus{border-color:var(--accent)}.go-join-btn{padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .15s}.go-join-btn:hover{background:var(--accent-hover)}.go-share-buttons{display:flex;gap:.5rem;margin-top:.75rem;justify-content:center}.go-share-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;text-decoration:none;transition:opacity .15s,transform .15s;cursor:pointer}.go-share-btn:hover{opacity:.85;transform:scale(1.08)}.go-share-whatsapp{background:#25d366;color:#fff}.go-share-sms{background:#3b82f6;color:#fff}.go-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:go-spin .8s linear infinite;margin:0 auto 1rem}@keyframes go-spin{to{transform:rotate(360deg)}}.go-error-text{color:var(--danger);font-weight:600}.go-leave-warning{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:.4rem 1rem;font-size:.75rem;color:var(--text-muted);background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:.02em}.go-disconnect-banner{position:fixed;top:0;left:0;right:0;text-align:center;padding:.5rem 1rem 0;font-size:.85rem;font-weight:600;color:#111;background:var(--warning, #f59e0b);z-index:100}.go-disconnect-countdown-bar{height:4px;background:#0003;margin-top:.5rem;overflow:hidden;border-radius:0 0 4px 4px}.go-disconnect-countdown-fill{height:100%;background:#00000059;transition:width .2s linear}@media(max-width:700px){.go-game-page{align-items:flex-start;justify-content:flex-start}.go-game-layout{flex-direction:column-reverse;gap:1rem;align-items:stretch;width:100%;max-width:100%}.go-game-sidebar{flex-direction:row;align-items:center;justify-content:center;flex-wrap:wrap;width:auto;align-self:center}}@media(max-width:520px){.go-game-page{padding:.5rem}}.indy5-home{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.indy5-home-card{text-align:center;max-width:440px;width:100%}.indy5-back-link{display:inline-block;margin-bottom:1.5rem;color:var(--text-muted);font-size:.9rem;transition:color .15s}.indy5-home-icon{font-size:5rem;line-height:1;margin-bottom:.5rem;filter:drop-shadow(0 4px 14px rgba(233,69,96,.4))}.indy5-home-title{font-size:2.5rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text) 0%,var(--green) 60%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.indy5-home-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:1rem;line-height:1.7}.indy5-home-subtitle{margin-bottom:1.25rem}.indy5-home-controls{display:flex;flex-direction:column;gap:.75rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1rem 1.25rem;text-align:left;margin-bottom:2rem}.indy5-home-ctrl-group{display:flex;flex-direction:column;gap:.3rem}.indy5-home-ctrl-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.indy5-home-ctrl-row{font-size:.85rem;color:var(--text-muted);line-height:1.6}.indy5-home-ctrl-divider{height:1px;background:#ffffff12}.indy5-joy-icon{font-size:1rem;margin-right:.2em}.indy5-home-subtitle kbd{display:inline-block;padding:.1em .4em;background:var(--bg-surface);border:1px solid rgba(255,255,255,.18);border-radius:4px;font-size:.85em;font-family:monospace;color:var(--text)}.indy5-create-btn{padding:1rem 3.5rem;background:var(--accent);border:none;border-radius:12px;color:#fff;font-size:1.15rem;font-weight:700;font-family:inherit;cursor:pointer;transition:background .15s,transform .15s}.indy5-create-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px)}.indy5-create-btn:disabled{opacity:.5;cursor:not-allowed}.indy5-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.indy5-status-card{text-align:center;background:var(--bg-card);padding:2.5rem 3rem;border-radius:18px;border:1px solid rgba(255,255,255,.06);max-width:480px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}.indy5-lobby-card{max-width:520px}.indy5-home-icon-sm{font-size:3rem;line-height:1}.indy5-status-card h2{font-size:1.6rem;font-weight:700}.indy5-hint{color:var(--text-muted);font-size:.9rem;line-height:1.5}.indy5-back-link{color:var(--text-muted);font-size:.85rem;align-self:flex-start;transition:color .15s}.indy5-back-link:hover{color:var(--text)}.indy5-name-row{width:100%}.indy5-name-input{width:100%;padding:.65rem .9rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-size:.95rem;font-family:inherit;outline:none;text-align:center;transition:border-color .15s}.indy5-name-input:focus{border-color:var(--accent)}.indy5-name-display{display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:1.05rem;font-weight:600;cursor:pointer}.indy5-edit-btn{background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:5px;color:var(--text-muted);font-size:.8rem;padding:.1rem .4rem;cursor:pointer;transition:color .15s,border-color .15s}.indy5-edit-btn:hover{color:var(--text);border-color:#ffffff4d}.indy5-roster{width:100%;display:flex;flex-direction:column;gap:.4rem}.indy5-roster-entry{display:flex;align-items:center;gap:.55rem;padding:.4rem .6rem;background:var(--bg-surface);border-radius:8px;font-size:.9rem}.indy5-kart-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.indy5-creator-badge{margin-left:auto;font-size:.7rem;color:var(--text-muted);background:#ffffff12;padding:.1rem .4rem;border-radius:4px}.indy5-share-row{display:flex;gap:.5rem;width:100%}.indy5-share-input{flex:1;padding:.6rem .8rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text);font-family:monospace;font-size:.8rem;outline:none;min-width:0}.indy5-copy-btn{padding:.6rem 1.1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.85rem;white-space:nowrap;cursor:pointer;transition:background .15s}.indy5-copy-btn:hover{background:var(--accent-hover)}.indy5-btn-primary{display:inline-block;padding:.8rem 2.5rem;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;text-align:center;text-decoration:none;transition:background .15s,transform .15s}.indy5-btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px)}.indy5-btn-primary:disabled{opacity:.45;cursor:not-allowed}.indy5-start-btn{width:100%;padding:.9rem;font-size:1.1rem}.indy5-waiting-hint{display:flex;align-items:center;gap:.6rem}.indy5-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:indy5-spin .8s linear infinite}.indy5-spinner-inline{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:indy5-spin .8s linear infinite;flex-shrink:0}@keyframes indy5-spin{to{transform:rotate(360deg)}}.indy5-countdown-page{background:#0009}.indy5-countdown-overlay{display:flex;align-items:center;justify-content:center}.indy5-countdown-num{font-size:14rem;font-weight:900;color:#fff;text-shadow:0 0 60px var(--accent),0 4px 20px rgba(0,0,0,.8);animation:indy5-pop .35s ease-out}.indy5-countdown-go{font-size:8rem;font-weight:900;color:var(--green);text-shadow:0 0 60px var(--green),0 4px 20px rgba(0,0,0,.8);animation:indy5-pop .35s ease-out}@keyframes indy5-pop{0%{transform:scale(1.5);opacity:0}60%{transform:scale(.95);opacity:1}to{transform:scale(1);opacity:1}}.indy5-race-page{align-items:start;justify-content:start;padding:1.25rem 1.5rem;display:grid;gap:.85rem;min-height:100vh;grid-template-columns:190px 1fr;grid-template-rows:auto auto auto 1fr;grid-template-areas:"back  track" "stand track" "stats track" "hints track"}.indy5-grid-back{grid-area:back}.indy5-grid-stand{grid-area:stand}.indy5-grid-stats{grid-area:stats}.indy5-grid-hints{grid-area:hints}.indy5-grid-track{grid-area:track}.indy5-track-wrap{display:flex;align-items:center;justify-content:center}.indy5-standings{background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:.75rem}.indy5-standings-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem}.indy5-standing-row{display:flex;align-items:center;gap:.4rem;padding:.3rem .2rem;font-size:.82rem;border-radius:6px}.indy5-standing-row--me{background:#e945601f}.indy5-pos{color:var(--text-muted);font-size:.8rem;min-width:1.2rem}.indy5-standing-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.indy5-standing-lap{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.indy5-dc{color:var(--danger);font-size:.7em}.indy5-my-stats{background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:.75rem;display:flex;flex-direction:column;gap:.4rem}.indy5-stat{display:flex;justify-content:space-between;align-items:center;font-size:.82rem}.indy5-stat-label{color:var(--text-muted)}.indy5-stat-value{font-weight:700;color:var(--green)}.indy5-controls-hint{font-size:.72rem;color:var(--text-muted);line-height:1.7}.indy5-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:50;padding:1.5rem}.indy5-modal{background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2.5rem 3rem;text-align:center;max-width:420px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.indy5-modal-title{font-size:2rem;font-weight:800}.indy5-modal-rankings{width:100%;display:flex;flex-direction:column;gap:.5rem}.indy5-modal-rank{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:var(--bg-surface);border-radius:10px;font-size:.95rem}.indy5-modal-rank--me{background:#e9456026;border:1px solid rgba(233,69,96,.3)}.indy5-modal-rank-name{flex:1;text-align:left;font-weight:600}.indy5-you-badge{font-size:.7rem;background:var(--accent);color:#fff;padding:.1rem .5rem;border-radius:999px}.indy5-modal-home-btn{margin-top:.5rem;padding:.8rem 2.5rem}.indy5-touch-controls{display:none}@media(hover:none)and (pointer:coarse){.indy5-touch-controls{display:flex;align-items:center;justify-content:space-between;position:fixed;bottom:1.25rem;left:1.25rem;right:1.25rem;z-index:20;user-select:none;-webkit-user-select:none;pointer-events:none}}.indy5-pedals{display:flex;flex-direction:column;gap:.6rem;pointer-events:all}.indy5-pedal{width:68px;height:68px;border-radius:50%;border:2px solid rgba(255,255,255,.25);background:#ffffff14;color:#ffffffb3;font-size:1.3rem;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;transition:background .08s,transform .08s}.indy5-pedal:active,.indy5-pedal-accel:active{background:#4ecca359;transform:scale(.93)}.indy5-pedal-reverse:active{background:#e9456059;transform:scale(.93)}.indy5-pedal-accel{border-color:#4ecca373;color:#4ecca3d9}.indy5-pedal-reverse{border-color:#e9456073;color:#e94560d9}.indy5-steer-wrap{display:flex;flex-direction:column;align-items:center;gap:.3rem;pointer-events:all}.indy5-joystick-outer{position:relative;border-radius:50%;background:#ffffff12;border:2px solid rgba(255,255,255,.2);touch-action:none}.indy5-joy-arrow{position:absolute;font-size:.65rem;color:#ffffff59;line-height:1}.indy5-joy-left{left:6px;top:50%;transform:translateY(-50%)}.indy5-joy-right{right:6px;top:50%;transform:translateY(-50%)}.indy5-joystick-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle at 35% 35%,#ffffff59,#ffffff14);border:2px solid rgba(255,255,255,.4);box-shadow:0 2px 8px #0006;touch-action:none}.indy5-joy-hint{font-size:.65rem;color:#ffffff4d;white-space:nowrap}@media(max-width:900px){.indy5-race-page{grid-template-columns:1fr;grid-template-rows:auto auto auto;grid-template-areas:"track" "stats" "stand";padding:.75rem;padding-bottom:180px}.indy5-grid-back,.indy5-grid-hints{display:none}.indy5-track-wrap{width:100%}.indy5-my-stats{flex-direction:row;justify-content:space-around;gap:.5rem}.indy5-stat{flex-direction:column;align-items:center;gap:.1rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--bg-surface: #16213e;--bg-card: #1e2a47;--text: #eef0f4;--text-muted: #8892a4;--accent: #e94560;--accent-hover: #ff6b81;--green: #4ecca3;--green-hover: #6ee6bb;--square-light: #ebd8b2;--square-dark: #b58863;--square-selected: rgba(255, 255, 80, .5);--square-legal: rgba(0, 0, 0, .15);--square-last-move: rgba(255, 255, 0, .25);--danger: #e94560}html,body,#root{height:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}
