@font-face{font-family:Syne;font-style:normal;font-weight:400 800;font-display:swap;src:url(../media/ab624315db63c58d-s.1487dfs7-.~d~.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:400 800;font-display:swap;src:url(../media/e94b8ab81811a983-s.02fsf_1p_avhz.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Syne;font-style:normal;font-weight:400 800;font-display:swap;src:url(../media/0c795a286deabae8-s.p.14tvuu96~wkr0.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Syne Fallback;src:local(Arial);ascent-override:93.93%;descent-override:27.93%;line-gap-override:0.0%;size-adjust:98.47%}.syne_89eecdd9-module__ON88Zq__className{font-family:Syne,Syne Fallback;font-style:normal}.syne_89eecdd9-module__ON88Zq__variable{--font-syne:"Syne", "Syne Fallback"}
@font-face{font-family:Space Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/4ba802ed8e67eac5-s.04ygcc0k6zvvf.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/d7a0600e467cf0bd-s.18awt9904y5ei.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/dc0d9adbac686440-s.p.0~z396rbj0t4w.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/b8f2b92a9960dd69-s.09-.4z_6a6fti.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/28e60ca39c9ae554-s.1841exvy3.1-g.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/8d05cfa5faa8406c-s.p.0kbulo~7o8gic.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Mono Fallback;src:local(Arial);ascent-override:81.58%;descent-override:26.3%;line-gap-override:0.0%;size-adjust:137.28%}.space_mono_d8eecc30-module__bEIZiG__className{font-family:Space Mono,Space Mono Fallback;font-style:normal}.space_mono_d8eecc30-module__bEIZiG__variable{--font-mono:"Space Mono", "Space Mono Fallback"}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-display:var(--font-syne), "Segoe UI", sans-serif;--font-symbol:var(--font-mono), "Courier New", monospace;--bg-card-white:#f4f8ff;--bg:#080c14;--bg-card:#ffffff0a;--bg-card-hover:#ffffff12;--border:#ffffff14;--border-strong:#ffffff29;--x-color:#ff6b6b;--x-glow:#ff6b6b59;--o-color:#4ecdc4;--o-glow:#4ecdc459;--win-color:#ffd93d;--win-glow:#ffd93d66;--text-primary:#f0f4ff;--text-muted:#fff8f8;--text-faint:#fff;--accent:#7c6aff;--accent-dim:#7c6aff2e;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--ease-out:cubic-bezier(.22, 1, .36, 1)}body{font-family:var(--font-display);background-color:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle,#ffffff0f 1px,#0000 1px);background-size:28px 28px;min-height:100dvh}.main{grid-template-rows:auto 1fr;gap:1.25rem;height:100dvh;padding:1.5rem;display:grid;overflow:hidden}.header{text-align:center}.header__title{font-family:var(--font-display);letter-spacing:-.04em;background:linear-gradient(135deg, #f0f4ff 30%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.6rem,4vw,2.8rem);font-weight:800;line-height:1}.header__subtitle{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;margin-top:.3rem;margin-bottom:.3rem;margin-left:.4rem;font-size:.8rem}.header__subtitle2{color:var(--text-muted);letter-spacing:.12em;margin-top:.2rem;margin-bottom:.2rem;font-size:.75rem}.game{width:100%;height:100%;min-height:0}.game__layout{grid-template-columns:160px 1fr 160px;gap:1.25rem;height:100%;min-height:0;display:grid}.game__col{min-width:0;min-height:0}.game__col--left{align-items:flex-start;display:flex}.game__col--centre{justify-content:center;align-items:center;display:flex}.game__col--right{align-items:flex-start;display:flex}.game-controls{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;width:100%;display:flex;overflow:hidden}.game-controls__section{padding:1rem}.game-controls__section+.game-controls__section{border-top:1px solid var(--border)}.game-controls__label{text-transform:uppercase;letter-spacing:.12em;color:var(--text-faint);margin-bottom:.65rem;font-size:.65rem;font-weight:700;display:block}.game-controls__sizes{flex-direction:column;gap:.4rem;display:flex}.game-controls__size-btn{font-family:var(--font-display);border-radius:var(--radius-sm);border:1px solid var(--border-strong);color:var(--text-muted);cursor:pointer;transition:all .18s var(--ease-out);letter-spacing:.04em;text-align:left;background:0 0;width:100%;padding:.45rem .75rem;font-size:.8rem;font-weight:600}.game-controls__size-btn:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--accent)}.game-controls__size-btn--active{background:var(--accent-dim);border-color:var(--accent);color:var(--text-primary)}.game-controls__reset{font-family:var(--font-display);border-radius:var(--radius-sm);border:1px solid var(--border-strong);color:var(--text-primary);cursor:pointer;letter-spacing:.06em;text-transform:uppercase;transition:all .18s var(--ease-out);background:0 0;width:100%;padding:.5rem .75rem;font-size:.78rem;font-weight:700}.game-controls__reset:hover{background:var(--accent);border-color:var(--accent);box-shadow:0 0 18px #7c6aff66}.status{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.01em;align-items:center;gap:.6rem;min-height:1.5rem;margin-bottom:1.25rem;font-size:.95rem;font-weight:600;transition:color .2s;display:flex}.status--win{color:var(--win-color)}.status--draw{color:var(--text-primary)}.status__indicator{border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .2s,box-shadow .2s}.status__indicator--x{background:var(--x-color);box-shadow:0 0 8px var(--x-glow)}.status__indicator--o{background:var(--o-color);box-shadow:0 0 8px var(--o-glow)}.board-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:min(100%,100dvh - 160px,480px);padding:1.25rem;container:board/inline-size}.board{grid-template-columns:repeat(var(--board-size,3), 1fr);gap:clamp(4px,1.2cqi,8px);display:grid}.square{aspect-ratio:1;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card-white);cursor:pointer;width:100%;transition:background .14s, border-color .14s, transform .12s var(--ease-out), box-shadow .14s;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.square:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-strong);transform:scale(1.04)}.square:active:not(:disabled){transform:scale(.96)}.square:disabled{cursor:default}.square--x{background:#ff6b6b0f;border-color:#ff6b6b4d}.square--o{background:#4ecdc40f;border-color:#4ecdc44d}.square--winning{box-shadow:0 0 16px var(--win-glow);animation:1.4s ease-in-out infinite winPulse;border-color:var(--win-color)!important;background:#ffd93d1a!important}@keyframes winPulse{0%,to{box-shadow:0 0 14px var(--win-glow)}50%{box-shadow:0 0 28px var(--win-glow), inset 0 0 10px #ffd93d14}}.square__symbol{font-family:var(--font-symbol);font-size:clamp(.9rem, 18cqi / var(--board-size,3), 3rem);animation:popIn .18s var(--ease-out);font-weight:700;line-height:1}.square--x .square__symbol{color:var(--x-color);text-shadow:0 0 12px var(--x-glow)}.square--o .square__symbol{color:var(--o-color);text-shadow:0 0 12px var(--o-glow)}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.move-history{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.75rem;width:100%;max-height:100%;padding:1.25rem 1rem;display:flex;overflow:hidden}.move-history__title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);border-bottom:1px solid var(--border);padding-bottom:.5rem;font-size:.7rem;font-weight:700}.move-history__list{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;flex-direction:column;gap:.3rem;list-style:none;display:flex;overflow-y:auto}.move-history__item{width:100%}.move-history__btn{border-radius:var(--radius-sm);width:100%;color:var(--text-muted);font-family:var(--font-display);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:1px solid #0000;align-items:center;gap:.5rem;padding:.45rem .6rem;font-size:.78rem;font-weight:500;transition:all .14s;display:flex}.move-history__btn:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border)}.move-history__btn--current{background:var(--accent-dim);border-color:var(--accent);color:var(--text-primary)}.move-history__dot{opacity:.5;background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.move-history__btn--current .move-history__dot{background:var(--accent);opacity:1;box-shadow:0 0 6px var(--accent)}.move-history__tag{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);opacity:.8;margin-left:auto;font-size:.62rem;font-weight:700}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}@media (max-width:699px){.main{gap:1rem;height:auto;min-height:100dvh;padding:1.5rem 1rem 2.5rem;overflow:auto}.game{height:auto}.game__layout{grid-template-rows:auto auto auto;grid-template-columns:1fr;height:auto}.game__col--left,.game__col--right,.game__col--centre{display:block}.game-controls{border-radius:var(--radius-md);flex-flow:wrap;align-items:center}.game-controls__section{flex:auto}.game-controls__section+.game-controls__section{border-top:none;border-left:1px solid var(--border)}.game-controls__sizes{flex-direction:row;gap:.4rem}.game-controls__size-btn{text-align:center;width:auto}.game-controls__reset{width:100%}.board-wrapper{width:100%;max-width:100%}.move-history{max-height:none;padding:.75rem}.move-history__title{display:none}.move-history__list{flex-direction:row;gap:.4rem;overflow:auto hidden}.move-history__item{flex-shrink:0}}@media (max-width:399px){.main{padding:1rem .75rem 2rem}.header__title{font-size:1.6rem}.header__subtitle{display:none}.game-controls__size-btn{padding:.35rem .55rem;font-size:.72rem}}@media (max-height:499px) and (min-width:700px){.main{gap:.75rem;padding:.75rem 1.25rem}.header__subtitle{display:none}.header__title{font-size:1.4rem}.game__layout{grid-template-columns:140px 1fr 140px;gap:.875rem}.board-wrapper{width:min(100%,100dvh - 100px,380px);padding:.875rem}}
