.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--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--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}@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-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)}.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}}*,*: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}
