*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #3CB371;--bg-card: #ffffff;--bg-card2: #f5f5f5;--border: rgba(0,0,0,.15);--color-x: #e05c5c;--color-o: #0a0a0a;--color-win: #f5c400;--text: #0a0a0a;--text-muted: #1a5c38;--accent: #0a0a0a;--accent2: #0a0a0a;--radius: 16px;--radius-sm: 12px;--shadow: 0 8px 32px rgba(0,0,0,.12);--cell-size: 68px;--font: "Inter", system-ui, sans-serif}html,body,#root{height:100%;overflow:hidden}@media (max-height: 680px){html,body,#root{height:auto;overflow:visible}.game-screen{height:auto;min-height:100dvh;overflow:visible}.board-scroller{flex:0 0 auto;overflow:visible}}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:var(--font);cursor:pointer;border:none;background:none}input{font-family:var(--font)}.screen{height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px;overflow-y:auto}.home-screen{gap:0;justify-content:center;padding:40px 24px}.home-logo{display:grid;grid-template-columns:1fr 1fr;gap:3px;width:52px;height:52px;margin:0 auto 20px}.home-logo-cell{background:#0a0a0a;color:#3cb371;display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-weight:900;font-size:1rem;border-radius:3px}.home-title-serif{font-family:Georgia,serif;font-size:2.4rem;font-weight:700;color:#0a0a0a;text-align:center;margin-bottom:10px;letter-spacing:-.5px}.home-tagline{font-family:Georgia,serif;font-size:1rem;color:#0a0a0a;text-align:center;margin-bottom:28px;max-width:260px;line-height:1.45}.game-selector{display:flex;gap:6px;width:100%;max-width:260px;margin-bottom:10px}.game-tab{flex:1;background:transparent;color:#0a0a0a;border:2px solid rgba(0,0,0,.2);border-radius:999px;padding:.5rem 0;font-family:Inter,system-ui,sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.game-tab:hover{border-color:#00000073}.game-tab.active{background:#0a0a0a;color:#fff;border-color:#0a0a0a}.game-desc{font-family:Georgia,serif;font-size:.82rem;color:#0a0a0a;text-align:center;max-width:240px;margin-bottom:20px;line-height:1.4;min-height:2.4em}.home-mode-label{font-family:Inter,system-ui,sans-serif;font-size:.8rem;font-weight:700;letter-spacing:1.5px;color:#0a0a0a;text-align:center;margin-bottom:12px}.home-buttons-new{display:flex;flex-direction:column;gap:10px;width:100%;max-width:260px;margin-bottom:28px}.btn-pill-primary{background:#0a0a0a;color:#fff;border-radius:999px;padding:.85rem 1.5rem;font-family:Inter,system-ui,sans-serif;font-weight:700;font-size:.95rem;border:none;width:100%;cursor:pointer;transition:opacity .12s,transform .08s}.btn-pill-primary:hover{opacity:.85}.btn-pill-primary:active{transform:scale(.97)}.btn-pill-primary:disabled{opacity:.35;cursor:not-allowed}.btn-pill-secondary{background:transparent;color:#0a0a0a;border-radius:999px;border:2px solid #0a0a0a;padding:.85rem 1.5rem;font-family:Inter,system-ui,sans-serif;font-weight:700;font-size:.95rem;width:100%;cursor:pointer;transition:opacity .12s,transform .08s}.btn-pill-secondary:hover{opacity:.7}.btn-pill-secondary:active{transform:scale(.97)}.btn-pill-secondary:disabled{opacity:.35;cursor:not-allowed}.home-date{font-family:Inter,system-ui,sans-serif;font-size:.78rem;font-weight:700;color:#0a0a0a;text-align:center}.btn{display:flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;padding:12px 22px;transition:transform .12s,box-shadow .12s,opacity .12s}.btn:active{transform:scale(.97)}.btn-large{flex-direction:column;align-items:flex-start;padding:18px 22px;border-radius:var(--radius);width:100%}.btn-primary{background:#0a0a0a;color:#fff;border-radius:999px;box-shadow:none}.btn-primary:hover{opacity:.85;box-shadow:none}.btn-secondary{background:transparent;color:#0a0a0a;border:2px solid #0a0a0a;border-radius:999px}.btn-secondary:hover{background:#0000000f}.btn-outline{background:transparent;color:#0a0a0a;border:2px solid #0a0a0a;border-radius:999px}.btn-outline:hover{background:#0000000f;color:#0a0a0a}.btn-ghost{background:transparent;color:var(--text-muted);padding:10px 20px}.btn-ghost:hover{color:var(--text)}.btn-small{font-size:.8rem;padding:8px 14px}.btn-disabled{opacity:.45;cursor:not-allowed}.btn-disabled:hover{box-shadow:none}.btn-icon{font-size:1.4rem}.btn-hint{font-size:.75rem;font-weight:400;color:#ffffffb3;margin-top:2px}.back-btn{position:absolute;top:16px;left:16px;color:var(--text-muted);font-size:.85rem;font-weight:500;padding:6px 12px;border-radius:var(--radius-sm);transition:color .15s,background .15s}.back-btn:hover{color:var(--text);background:var(--bg-card)}.entry-screen{position:relative}.entry-title{font-family:Georgia,serif;font-size:1.6rem;font-weight:800;color:#0a0a0a;letter-spacing:-.5px;margin-bottom:6px;text-align:center}.entry-subtitle{color:var(--text-muted);font-size:.88rem;text-align:center;margin-bottom:24px;max-width:280px}.entry-form{display:flex;flex-direction:column;gap:18px;width:100%;max-width:340px;margin-top:24px}.player-input-group{display:flex;flex-direction:column;gap:8px}.input-label{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--text-muted)}.text-input{background:#fff;border:2px solid rgba(0,0,0,.15);border-radius:12px;color:#0a0a0a;font-size:1rem;font-weight:500;padding:12px 16px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.text-input::placeholder{color:#aaa}.text-input:focus{border-color:#0a0a0a;box-shadow:0 0 0 3px #00000014}.vs-divider{text-align:center;font-size:.75rem;font-weight:700;letter-spacing:2px;color:var(--text-muted);position:relative}.vs-divider:before,.vs-divider:after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--border)}.vs-divider:before{left:0}.vs-divider:after{right:0}.player-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;font-size:.7rem;font-weight:800}.x-badge{background:#ff6b6b33;color:var(--color-x)}.o-badge{background:#4ecdc433;color:var(--color-o)}.scoreboard{display:flex;align-items:center;gap:12px;padding:0 16px;width:100%;max-width:640px;flex-shrink:0}.score-card{flex:1;background:#ffffff8c;border:none;border-radius:12px;padding:10px 14px;display:flex;flex-direction:column;gap:4px;transition:background .2s,box-shadow .2s;min-width:0}.score-card.active{background:#fff;box-shadow:0 2px 8px #0000001a}.score-card.winner{background:#fff;box-shadow:0 0 0 2px #f5c400}.score-card:not(.active):not(.winner) svg{opacity:.5}.score-name{font-size:.82rem;font-weight:700;color:#0a0a0a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.score-record{font-size:.7rem;color:#555}.score-center{display:flex;flex-direction:column;align-items:center;flex-shrink:0;min-width:80px}.turn-indicator{display:flex;flex-direction:column;align-items:center;gap:4px}.turn-dot{width:8px;height:8px;border-radius:50%;animation:pulse 1.4s ease-in-out infinite}.dot-x{background:var(--color-x);box-shadow:0 0 8px var(--color-x)}.dot-o{background:var(--color-o);box-shadow:0 0 8px var(--color-o)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.7)}}.turn-text{font-size:.65rem;font-weight:600;color:var(--text-muted);text-align:center;white-space:nowrap}.won-badge{font-size:.75rem;font-weight:700;color:var(--color-win);text-align:center;white-space:nowrap}.game-screen{display:flex;flex-direction:column;height:100dvh;overflow:hidden;position:relative;gap:12px;padding:12px 0 16px}.game-header{display:flex;align-items:center;gap:12px;padding:0 16px;flex-shrink:0}.game-title-small{font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.5px;flex:1;text-align:center;margin-right:60px}.game-header .back-btn{position:static;flex-shrink:0}.board-scroller{flex:1;overflow:auto;display:flex;align-items:safe center;justify-content:safe center;padding:16px;background:transparent;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.board-scroller::-webkit-scrollbar{width:4px;height:4px}.board-scroller::-webkit-scrollbar-track{background:transparent}.board-scroller::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.board-inner{position:relative;display:inline-flex}.win-line-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.board-grid.has-winner .cell:not(.cell-win){opacity:.4}.board-grid.has-winner .cell.cell-win{opacity:1}.cell{width:var(--cell-size, 68px);height:var(--cell-size, 68px);display:flex;align-items:center;justify-content:center;border-radius:10px;background:#fff;border:none;font-size:1.6rem;font-weight:900;cursor:default;transition:background .12s,border-color .12s,transform .08s,box-shadow .12s,opacity .3s ease;position:relative;overflow:hidden}.cell-value{display:block;animation:pop-in .18s cubic-bezier(.34,1.56,.64,1) both}@keyframes pop-in{0%{transform:scale(.3) rotate(-10deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.cell-x .cell-value{color:var(--color-x)}.cell-o .cell-value{color:var(--color-o)}.cell-win{background:#fffbe6;border:none;box-shadow:0 0 0 3px #f5c400;animation:win-glow 1.2s ease-in-out infinite alternate}@keyframes win-glow{0%{box-shadow:0 0 0 3px #f5c400}to{box-shadow:0 0 0 3px #f5c400,0 0 16px #f5c40066}}.cell-at-risk{opacity:.55;outline:2px dashed rgba(0,0,0,.4);outline-offset:-4px}.cell-empty{cursor:pointer}.cell-empty:hover{background:#f0f0f0;border-color:transparent;transform:scale(1.04)}.cell-hover-x:hover:after{content:"X";position:absolute;font-size:1.6rem;font-weight:900;pointer-events:none;color:var(--color-x);opacity:.3}.cell-hover-o:hover:after{content:"O";position:absolute;font-size:1.6rem;font-weight:900;pointer-events:none;color:var(--color-o);opacity:.3}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fade-in .2s ease both}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:#fff;border:none;border-radius:var(--radius);padding:32px 28px;max-width:360px;width:100%;text-align:center;box-shadow:0 8px 32px #0000002e;animation:slide-up .25s cubic-bezier(.34,1.56,.64,1) both}@keyframes slide-up{0%{transform:translateY(40px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-symbol{line-height:1;margin-bottom:8px;display:flex;justify-content:center;animation:pop-in .3s cubic-bezier(.34,1.56,.64,1) .1s both}.modal-title{font-family:Georgia,serif;font-size:1.6rem;font-weight:800;color:#0a0a0a;letter-spacing:-.5px;margin-bottom:6px}.modal-subtitle{color:#555;font-size:.88rem;margin-bottom:20px}.modal-scores{background:#f5f5f5;border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:24px;display:flex;flex-direction:column;gap:8px}.modal-score-row{display:flex;align-items:center;gap:8px;font-size:.85rem;color:#0a0a0a}.modal-score-val{margin-left:auto;font-weight:600;color:#0a0a0a}.modal-buttons{display:flex;flex-direction:column;gap:10px}.modal-home-btn{background:transparent;border:none;color:#555;font-family:Inter,system-ui,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;padding:6px;transition:color .12s}.modal-home-btn:hover{color:#0a0a0a}.result-replay-btn{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#0a0a0a;color:#fff;border:none;border-radius:999px;padding:12px 28px;font-family:Inter,system-ui,sans-serif;font-weight:700;font-size:.9rem;cursor:pointer;z-index:50;box-shadow:0 4px 16px #00000040;white-space:nowrap}.ios-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#0a0a0a;color:#fff;padding:12px 16px;flex-shrink:0}.ios-banner-content{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.ios-banner-icon{font-size:1.2rem;flex-shrink:0}.ios-banner-text{font-size:.8rem;line-height:1.4;color:#ffffffe6}.ios-banner-text strong{color:#fff;font-weight:700}.ios-banner-text em{font-style:normal;font-weight:600;color:#3cb371}.ios-banner-close{flex-shrink:0;color:#ffffff80;font-size:.85rem;padding:4px 8px;border-radius:4px;transition:color .15s}.ios-banner-close:hover{color:#fff}.modal-session{font-size:.72rem;color:#555;text-align:center;padding-top:4px;border-top:1px solid #e0e0e0;margin-top:4px}.waiting-screen,.loading-screen{position:relative}.waiting-content{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:360px;text-align:center}.waiting-spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent2);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.waiting-title{font-size:1.3rem;font-weight:700}.waiting-sub{color:var(--text-muted);font-size:.88rem}.waiting-hint{color:var(--text-muted);font-size:.78rem}.share-box{display:flex;gap:8px;width:100%}.share-input{flex:1;background:var(--bg-card2);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.78rem;padding:10px 12px;outline:none;min-width:0}.error-screen{gap:20px}.error-message{color:var(--color-x);font-size:.92rem;text-align:center;max-width:320px;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.25);border-radius:var(--radius-sm);padding:14px 18px}@media (max-width: 480px){:root{--cell-size: 52px}.cell{border-radius:7px;font-size:1.2rem}.modal-card{padding:24px 18px}.scoreboard{gap:8px;padding:0 10px}.score-card{padding:8px 10px}.score-name{font-size:.72rem}.score-center{min-width:60px}}@media (min-width: 900px){:root{--cell-size: 76px}}
