.popup{display:flex;justify-content:center;align-items:center;width:100%;height:100vh;position:fixed;top:0;left:0;padding:24px;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:100;animation:popupFadeIn .18s ease-out}@keyframes popupFadeIn{0%{opacity:0}to{opacity:1}}.popupInner{position:relative;width:100%;max-width:560px;padding:32px;background:var(--bg-elev-1);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);color:var(--text-primary);animation:popupSlideUp .2s ease-out}@keyframes popupSlideUp{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.popupInner h2{margin:0 0 16px;font-family:var(--font-mono);font-size:20px;background:linear-gradient(135deg,var(--accent-x) 0%,var(--accent-o) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.popupInner p,.popupInner li{color:var(--text-muted);line-height:1.6}.popupInner ol,.popupInner ul{padding-left:20px}.popupInner strong{color:var(--text-primary)}.popupInner em{color:var(--accent-x);font-style:normal}.popupInner .closeBtn{position:absolute;top:14px;right:14px;padding:6px 12px;background:#f871711f;border:1px solid rgba(248,113,113,.3);color:var(--accent-danger);border-radius:var(--radius-sm);font-size:13px}.popupInner .closeBtn:hover{background:#f8717133;border-color:var(--accent-danger);box-shadow:0 0 0 2px #f871712e}.popupResult{text-align:center}.popupResult h2{font-size:28px;margin-bottom:24px}.popupResult button.playAgain{background:var(--btn-primary-bg);border-color:transparent;color:var(--btn-primary-text);font-weight:600;padding:12px 28px}.popupResult button.playAgain:hover{box-shadow:var(--shadow-glow-x)}@media(max-width:768px){.popup{padding:16px}.popupInner{padding:24px 20px}.popupInner h2{font-size:18px}}@media(max-width:480px){.popup{padding:12px}.popupInner{padding:20px 16px}.popupResult h2{font-size:22px;margin-bottom:18px}.popupInner .closeBtn{top:10px;right:10px;font-size:12px}}.navBar{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 32px;margin:0 auto 16px;max-width:1200px;border-bottom:1px solid var(--border-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);position:sticky;top:0;z-index:10;background:#0b0f17b3}.navBar a:has(h1){text-decoration:none}.navBar h1{font-family:var(--font-mono);font-size:22px;font-weight:700;letter-spacing:.05em;background:linear-gradient(135deg,var(--accent-x) 0%,var(--accent-o) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.navBar h1:before{content:"> ";color:var(--accent-success);-webkit-text-fill-color:var(--accent-success)}ul.navUl{list-style:none;margin:0;padding:6px 8px;display:flex;gap:4px;background:var(--bg-elev-1);border:1px solid var(--border-soft);border-radius:999px;box-shadow:var(--shadow-soft)}ul.navUl li{display:inline-block}ul.navUl li a{display:inline-block;padding:8px 18px;color:var(--text-muted);font-size:14px;font-weight:500;border-radius:999px;transition:color .2s ease,background .2s ease;position:relative}ul.navUl li a:hover,ul.navUl li a:focus{color:var(--text-primary);background:#ffffff0a}ul.navUl li a.active{color:var(--btn-primary-text);background:var(--btn-primary-bg);font-weight:600}.navActions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}@media(max-width:768px){.navBar{flex-wrap:wrap;gap:10px;padding:12px 16px}.navBar h1{font-size:18px}ul.navUl{order:3;width:100%;justify-content:center}ul.navUl li a{padding:6px 14px;font-size:13px}}@media(max-width:480px){.navBar{padding:10px 12px}.navBar h1{font-size:16px}ul.navUl{padding:4px 6px}ul.navUl li a{padding:6px 12px;font-size:12px}.navUser{font-size:12px;gap:6px}}.authPage{max-width:420px;margin:60px auto;padding:36px 32px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.authPage h2{font-family:var(--font-mono);font-size:20px;margin-bottom:28px;color:var(--text-primary)}.authPage h2:before{content:"> ";color:var(--accent-success)}.authField{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.authField label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);font-family:var(--font-mono)}.authField input{background:var(--bg-elev-1);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;padding:10px 14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.authField input:focus{border-color:var(--accent-x);box-shadow:0 0 0 2px var(--accent-x-glow)}.authSubmit{width:100%;background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;font-weight:600;font-size:14px;padding:12px;border-radius:var(--radius-md);margin-top:8px;justify-content:center}.authSubmit:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-glow-x);border:none}.authError{color:var(--accent-danger);font-size:13px;margin-bottom:12px;font-family:var(--font-mono)}.authSwitch{margin-top:20px;text-align:center;font-size:13px;color:var(--text-muted)}.authSwitch a{color:var(--accent-x);cursor:pointer;text-decoration:underline}.navUser{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted);font-family:var(--font-mono)}.navUser span{color:var(--accent-success)}@media(max-width:768px){.authPage{margin:32px auto;padding:28px 22px}}@media(max-width:480px){.authPage{margin:16px auto;padding:22px 16px}.authPage h2{font-size:18px;margin-bottom:20px}.authField input{font-size:16px;padding:11px 14px}}.gameHub{display:flex;flex-direction:column;align-items:center;gap:40px;padding:48px 0}.gameHub__header{text-align:center;display:flex;flex-direction:column;gap:12px}.gameHub__title{font-family:var(--font-mono);font-size:2rem;font-weight:700;letter-spacing:.04em;background:linear-gradient(135deg,var(--accent-x) 0%,var(--accent-o) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.gameHub__subtitle{font-size:15px;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.02em}.gameHub__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;width:100%;max-width:780px}.gameCard{position:relative;display:flex;flex-direction:column;align-items:center;gap:18px;padding:40px 32px 32px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer;text-decoration:none;color:var(--text-primary);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;overflow:hidden}.gameCard:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;opacity:.7;transition:opacity .2s ease}.gameCard--xo:before{background:linear-gradient(90deg,transparent,var(--accent-x),var(--accent-o),transparent)}.gameCard--chess:before{background:linear-gradient(90deg,transparent,var(--accent-chess),var(--accent-o),transparent)}.gameCard:hover{transform:translateY(-4px)}.gameCard--xo:hover{border-color:var(--accent-x);box-shadow:var(--shadow-soft),0 0 32px var(--accent-x-glow)}.gameCard--chess:hover{border-color:var(--accent-chess);box-shadow:var(--shadow-soft),0 0 32px var(--accent-chess-glow)}.gameCard__icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-lg);font-size:36px;flex-shrink:0}.gameCard--xo .gameCard__icon{background:#22d3ee1f;color:var(--accent-x);border:1px solid rgba(34,211,238,.25)}.gameCard--chess .gameCard__icon{background:#a855f71f;color:var(--accent-chess);border:1px solid rgba(168,85,247,.25)}.gameCard__xoMark{font-family:var(--font-mono);font-size:26px;font-weight:700;letter-spacing:.04em;background:linear-gradient(135deg,var(--accent-x) 0%,var(--accent-o) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}.gameCard__body{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.gameCard__name{font-size:20px;font-weight:700;letter-spacing:-.01em;color:var(--text-primary)}.gameCard__desc{font-size:13px;color:var(--text-muted);line-height:1.55;max-width:240px}.gameCard__cta{margin-top:4px;padding:11px 28px;font-size:14px;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;font-family:var(--font-sans)}.gameCard--xo .gameCard__cta{background:linear-gradient(135deg,var(--accent-x) 0%,#6366f1 100%);color:var(--btn-primary-text)}.gameCard--xo .gameCard__cta:hover{box-shadow:var(--shadow-glow-x);transform:translateY(-1px)}.gameCard--chess .gameCard__cta{background:linear-gradient(135deg,var(--accent-chess) 0%,#6366f1 100%);color:var(--btn-primary-text)}.gameCard--chess .gameCard__cta:hover{box-shadow:var(--accent-chess-glow);transform:translateY(-1px)}@media(max-width:768px){.gameHub{padding:32px 0;gap:28px}.gameHub__title{font-size:1.6rem}.gameHub__grid{grid-template-columns:1fr;gap:18px;max-width:420px}.gameCard{padding:28px 24px 24px;flex-direction:row;align-items:flex-start;gap:20px;text-align:left}.gameCard__body{align-items:flex-start;text-align:left}.gameCard__desc{max-width:none}.gameCard__icon{width:56px;height:56px;font-size:28px;flex-shrink:0}.gameCard__xoMark{font-size:20px}}@media(max-width:480px){.gameHub{padding:24px 0;gap:20px}.gameHub__title{font-size:1.35rem}.gameHub__grid{max-width:100%}.gameCard{padding:22px 18px 20px;gap:14px}.gameCard__name{font-size:17px}.gameCard__icon{width:48px;height:48px;font-size:24px}.gameCard__xoMark{font-size:17px}.gameCard__cta{padding:9px 22px;font-size:13px}}.inputSizeForm{max-width:520px;margin:48px auto;padding:40px 32px;display:flex;flex-direction:column;align-items:stretch;gap:16px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);position:relative;overflow:hidden}.inputSizeForm:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-x),var(--accent-o),transparent);opacity:.7}.inputSizeForm label{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.inputSizeForm input{width:100%;padding:14px 16px;font-size:18px;font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-elev-1);border:1px solid var(--border-strong);border-radius:var(--radius-md);margin:0;transition:border-color .15s ease,box-shadow .15s ease}.inputSizeForm input:focus{outline:none;border-color:var(--accent-x);box-shadow:0 0 0 3px var(--accent-x-glow)}.inputSizeForm input::placeholder{color:var(--text-dim)}.inputSizeForm input[type=number]::-webkit-outer-spin-button,.inputSizeForm input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.inputSizeForm input[type=number]{-moz-appearance:textfield}.formError{color:var(--accent-danger);font-family:var(--font-mono);font-size:13px;margin:0}.difficultyLabel{margin-top:6px}.difficultyGroup{display:flex;gap:8px;padding:4px;background:var(--bg-elev-1);border:1px solid var(--border-soft);border-radius:999px;width:fit-content}.difficultyChip{padding:8px 18px;background:transparent;border:1px solid transparent;border-radius:999px;color:var(--text-muted);font-size:13px;font-weight:500;font-family:var(--font-mono);cursor:pointer;transition:color .15s ease,background .15s ease}.difficultyChip:hover{color:var(--text-primary);background:#ffffff0a;transform:none;box-shadow:none}.difficultyChip.active{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btnBottomForm{display:flex;gap:12px;margin-top:8px}.btnBottomForm button{flex:1;justify-content:center;padding:14px 18px;font-size:15px;font-weight:600;border-radius:var(--radius-md)}.btnBottomForm button.singlePlayer{background:linear-gradient(135deg,#f472b6,#c084fc);border-color:transparent;color:var(--btn-primary-text)}.btnBottomForm button.singlePlayer:hover:not(:disabled){box-shadow:var(--shadow-glow-o)}.btnBottomForm button.multiPlayer{background:var(--btn-primary-bg);border-color:transparent;color:var(--btn-primary-text)}.btnBottomForm button.multiPlayer:hover:not(:disabled){box-shadow:var(--shadow-glow-x)}.btnBottomForm button.onlinePlayer{background:linear-gradient(135deg,#4ade80,#22d3ee);border-color:transparent;color:var(--btn-primary-text)}.btnBottomForm button.onlinePlayer:hover:not(:disabled){box-shadow:0 0 18px #4ade8066}@media(max-width:768px){.inputSizeForm{margin:24px auto;padding:28px 20px;gap:14px}.btnBottomForm{flex-direction:column;gap:10px}.btnBottomForm button{padding:12px 14px;font-size:14px}}@media(max-width:480px){.inputSizeForm{margin:16px auto;padding:22px 16px}.inputSizeForm input{font-size:16px;padding:12px 14px}.difficultyGroup{width:100%;justify-content:center}.difficultyChip{flex:1;text-align:center;padding:8px 12px}}.chessHomeWrap{max-width:520px;margin:48px auto;padding:40px 32px;display:flex;flex-direction:column;align-items:stretch;gap:20px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);position:relative;overflow:hidden}.chessHomeWrap:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-chess),var(--accent-x),transparent);opacity:.8}.chessHomeTitle{text-align:center;font-family:var(--font-mono);font-size:22px;font-weight:700;letter-spacing:.02em;color:var(--text-primary)}.chessHomePiece{font-size:2rem;margin-right:8px}.chessHomeSubtitle{text-align:center;font-family:var(--font-mono);font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin-top:-8px}.chessHomeDivider{height:1px;background:var(--border-soft)}.chessHomeModeLabel{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.chessModeBtns{display:flex;gap:12px;margin-top:4px}.chessModeBtns button{flex:1;justify-content:center;padding:14px 18px;font-size:15px;font-weight:600;border-radius:var(--radius-md)}.chessModeBtns .singlePlayer{background:linear-gradient(135deg,var(--accent-chess) 0%,#6366f1 100%);border-color:transparent;color:var(--btn-primary-text)}.chessModeBtns .singlePlayer:hover:not(:disabled){box-shadow:0 0 18px var(--accent-chess-glow);transform:translateY(-2px)}.chessModeBtns .multiPlayer{background:var(--btn-primary-bg);border-color:transparent;color:var(--btn-primary-text)}.chessModeBtns .multiPlayer:hover:not(:disabled){box-shadow:var(--shadow-glow-x);transform:translateY(-2px)}.chessHomeBack{display:flex;justify-content:center;margin-top:4px}.chessHomeBack a,.chessHomeBack button{font-family:var(--font-mono);font-size:13px;color:var(--text-dim);background:transparent;border:none;cursor:pointer;padding:4px 8px;text-decoration:none;transition:color .15s ease}.chessHomeBack a:hover,.chessHomeBack button:hover{color:var(--text-muted);transform:none;box-shadow:none;border-color:transparent}@media(max-width:768px){.chessHomeWrap{margin:24px auto;padding:28px 20px;gap:16px}.chessModeBtns{flex-direction:column;gap:10px}.chessModeBtns button{padding:12px 14px;font-size:14px}}@media(max-width:480px){.chessHomeWrap{margin:16px auto;padding:22px 16px}.chessHomeTitle{font-size:18px}}:root{--accent-chess-light: #d4c9a8;--accent-chess-dark: #7a6242;--accent-chess-light-hover: #e8dfc0;--accent-chess-dark-hover: #8c7250;--sq-size: clamp(40px, 9vw, 64px)}.chessBoardWrap{display:flex;flex-direction:column;align-items:center;gap:12px}.chessBoardOuter{display:flex;align-items:center;gap:4px}.rankLabels{display:flex;flex-direction:column;gap:0}.rankLabel{width:18px;height:var(--sq-size);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;color:var(--text-dim);-webkit-user-select:none;user-select:none}.fileLabels{display:flex;margin-left:22px}.fileLabel{width:var(--sq-size);text-align:center;font-family:var(--font-mono);font-size:11px;color:var(--text-dim);-webkit-user-select:none;user-select:none}.chessBoard{display:grid;grid-template-columns:repeat(8,var(--sq-size));grid-template-rows:repeat(8,var(--sq-size));border:2px solid var(--border-strong);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-soft),0 0 0 1px #a855f726;cursor:pointer}.chessSquare{width:var(--sq-size);height:var(--sq-size);display:flex;align-items:center;justify-content:center;position:relative;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;transition:filter .1s ease}.chessSquare.light{background:var(--accent-chess-light)}.chessSquare.dark{background:var(--accent-chess-dark)}.chessSquare:hover{filter:brightness(1.12)}.chessSquare.selected{outline:3px solid var(--accent-x);outline-offset:-3px;z-index:1}.chessSquare.legalMove:after{content:"";position:absolute;width:30%;height:30%;border-radius:50%;background:#4ade80bf;pointer-events:none}.chessSquare.captureTarget:after{content:"";position:absolute;inset:4px;border-radius:50%;border:3px solid rgba(248,113,113,.85);pointer-events:none}.chessSquare.inCheck{background:#f8717173!important;animation:checkPulse 1s ease-in-out infinite alternate}@keyframes checkPulse{0%{background:#f8717159}to{background:#f87171a6}}.chessPiece{font-size:clamp(22px,5.5vw,42px);line-height:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%;pointer-events:none;transition:transform .1s ease}.chessPiece.white{color:#fff8f0;text-shadow:0 0 2px #333,1px 1px 0 #444,-1px -1px 0 #444,1px -1px 0 #444,-1px 1px 0 #444;filter:drop-shadow(0 1px 3px rgba(0,0,0,.6))}.chessPiece.black{color:#1a1008;text-shadow:0 0 2px rgba(255,255,255,.5),1px 1px 0 rgba(200,180,120,.5),-1px -1px 0 rgba(200,180,120,.5);filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}.chessSquare.selected .chessPiece{transform:scale(1.1)}.chessTurnBar{display:flex;align-items:center;gap:10px;padding:10px 18px;background:var(--bg-elev-1);border:1px solid var(--border-soft);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:14px;color:var(--text-muted)}.chessTurnDot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.chessTurnDot.white{background:#fff8f0;box-shadow:0 0 6px #fff9}.chessTurnDot.black{background:#2a1f0e;border:1px solid rgba(255,255,255,.2)}.chessStatus{padding:6px 14px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:13px;font-weight:600}.chessStatus.check{background:#fbbf2426;color:var(--accent-warn);border:1px solid rgba(251,191,36,.3)}.chessStatus.checkmate{background:#f8717126;color:var(--accent-danger);border:1px solid rgba(248,113,113,.3)}.chessStatus.stalemate,.chessStatus.draw{background:#94a3b81a;color:var(--text-muted);border:1px solid var(--border-soft)}.chessBoardActions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.chessMoveHistory{max-width:320px;width:100%;max-height:200px;overflow-y:auto;background:var(--bg-elev-1);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:10px 14px;font-family:var(--font-mono);font-size:12px;color:var(--text-dim);scrollbar-width:thin}.chessMoveHistory::-webkit-scrollbar{width:4px}.chessMoveHistory::-webkit-scrollbar-thumb{background:var(--border-soft);border-radius:2px}@media(max-width:768px){:root{--sq-size: clamp(36px, 11vw, 54px)}.chessTurnBar{font-size:13px;padding:8px 14px}.fileLabel,.rankLabel{font-size:10px}}@media(max-width:480px){:root{--sq-size: clamp(32px, 11.5vw, 46px)}.chessPiece{font-size:clamp(18px,6vw,30px)}.chessBoardActions button{font-size:12px;padding:8px 12px}}.boardGame{display:grid;gap:6px;padding:18px;margin:24px auto;width:fit-content;background:var(--bg-elev-1);border:1px solid var(--border-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-soft)}.cell{aspect-ratio:1 / 1;width:clamp(40px,8vw,64px);display:flex;justify-content:center;align-items:center;background:var(--bg-elev-2);border:1px solid var(--border-soft);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:clamp(18px,4vw,30px);font-weight:700;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;transition:background .12s ease,border-color .12s ease,transform .08s ease}.cell:focus,.cell:focus-visible{outline:none}.cell:hover{background:#22d3ee14;border-color:var(--accent-x)}.cell:active{transform:scale(.96)}.cell:has(>:not(:empty)),.cell:not(:empty){cursor:default}.cell{text-shadow:0 0 12px transparent}.cell.x{color:var(--accent-x);text-shadow:0 0 12px var(--accent-x-glow);border-color:#22d3ee59}.cell.o{color:var(--accent-o);text-shadow:0 0 12px var(--accent-o-glow);border-color:#f472b659}.boardActions{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:16px}.resetBtn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--btn-secondary-bg);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;cursor:pointer}.undoRedoBtn{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;background:var(--btn-secondary-bg);border:1px solid var(--border-soft);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;cursor:pointer;transition:background .12s ease,border-color .12s ease,opacity .12s ease}.undoRedoBtn:hover:not(:disabled){background:#22d3ee1a;border-color:var(--accent-x)}.undoRedoBtn:disabled{opacity:.35;cursor:not-allowed}.boardGameWrap{display:flex;flex-direction:column;align-items:center}@media(max-width:768px){.boardGame{gap:4px;padding:12px;margin:16px auto}}@media(max-width:480px){.boardGame{gap:3px;padding:8px;margin:12px auto}.cell{width:clamp(34px,9vw,50px);font-size:clamp(16px,5vw,24px)}.resetBtn{font-size:13px;padding:9px 14px}}.replayList{max-width:800px;margin:32px auto;display:flex;flex-direction:column;gap:14px}.replayEmpty{text-align:center;margin-top:64px;color:var(--text-muted);font-family:var(--font-mono);font-size:15px}.replay{width:100%;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:22px 26px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);position:relative;overflow:hidden;transition:border-color .2s ease,transform .15s ease}.replay:hover{border-color:var(--accent-x);transform:translateY(-2px)}.replay:before{content:"";position:absolute;top:0;left:0;bottom:0;width:3px}.replay.single:before{background:linear-gradient(180deg,var(--accent-o),transparent)}.replay.multi:before{background:linear-gradient(180deg,var(--accent-x),transparent)}.replay.online:before{background:linear-gradient(180deg,#c084fc,transparent)}.replay.online .modeBadge{color:#c084fc}.replayInner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.replayInfo{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:6px 24px;flex:1;font-size:14px;color:var(--text-muted);font-family:var(--font-mono)}.replayInfo span.label{color:var(--text-dim);font-size:11px;text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:2px}.replayInfo span.value{color:var(--text-primary);font-size:14px}.replay.single .modeBadge{color:var(--accent-o)}.replay.multi .modeBadge{color:var(--accent-x)}.manageBtn{display:flex;gap:10px}.manageBtn .delete{background:#f871711a;border-color:#f8717152;color:var(--accent-danger)}.manageBtn .delete:hover:not(:disabled){background:#f871712e;border-color:var(--accent-danger);box-shadow:0 0 0 2px #f871712e}@media(max-width:768px){.replay{padding:18px}.replayInner{align-items:stretch}.replayInfo{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.manageBtn{width:100%;justify-content:flex-end}}@media(max-width:480px){.replay{padding:16px 14px}.replayInfo{grid-template-columns:1fr 1fr;gap:10px 12px;font-size:13px}.replayInfo span.value{font-size:13px}.manageBtn{flex-direction:column;gap:8px}.manageBtn button{width:100%;justify-content:center}}.replayDetail{max-width:800px;margin:32px auto;padding:28px;display:flex;flex-direction:column;gap:18px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.detailText{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px 24px;padding-bottom:16px;border-bottom:1px solid var(--border-soft);font-family:var(--font-mono);font-size:14px}.detailText p{margin:0;color:var(--text-muted)}.detailText p b{display:block;font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-weight:500;margin-bottom:4px}.detailText p span{color:var(--text-primary)}.stepIndicator{text-align:center;font-family:var(--font-mono);font-size:18px;color:var(--text-muted);margin-top:8px}.stepIndicator b{color:var(--accent-x);margin-right:6px}.stepIndicator .stepNum{color:var(--text-primary);font-weight:600}.stepNav{display:flex;justify-content:space-between;align-items:center;gap:12px}.stepNav button{flex:1;justify-content:center;padding:12px 18px}@media(max-width:768px){.replayDetail{margin:16px auto;padding:20px 18px}.detailText{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px 18px;font-size:13px}}@media(max-width:480px){.replayDetail{margin:12px auto;padding:16px 14px}.detailText{grid-template-columns:1fr 1fr;gap:8px 12px}.stepNav button{padding:10px 12px;font-size:13px}}.onlineCard{max-width:480px;margin:48px auto;padding:36px 32px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;flex-direction:column;gap:20px}.onlineTitle{font-family:var(--font-mono);font-size:20px;color:var(--text-primary)}.onlineTitle:before{content:"> ";color:var(--accent-success)}.onlineSubtitle{font-family:var(--font-mono);font-size:13px;color:var(--text-muted);margin:-12px 0 0}.onlineMsg{font-size:16px;color:var(--text-primary);text-align:center}.onlineSection{display:flex;flex-direction:column;gap:14px}.onlineCreateBlock{display:flex;flex-direction:column;gap:8px}.onlineSizeInput{background:var(--bg-elev-1);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:16px;padding:10px 14px;outline:none;transition:border-color .2s,box-shadow .2s}.onlineSizeInput:focus{border-color:var(--accent-x);box-shadow:0 0 0 2px var(--accent-x-glow)}.onlineSizeInput::placeholder{color:var(--text-dim)}.onlineSizeInput[type=number]::-webkit-outer-spin-button,.onlineSizeInput[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.onlineSizeInput[type=number]{-moz-appearance:textfield}.onlineError{color:var(--accent-danger);font-size:13px;font-family:var(--font-mono);margin:0}.onlineBtn{width:100%;justify-content:center;font-size:15px;font-weight:600;padding:13px;border-radius:var(--radius-md)}.onlineBtn.create{background:var(--btn-primary-bg);border-color:transparent;color:var(--btn-primary-text)}.onlineBtn.create:hover:not(:disabled){box-shadow:var(--shadow-glow-x)}.onlineBtn.join{background:linear-gradient(135deg,#f472b6,#c084fc);border-color:transparent;color:var(--btn-primary-text);width:auto;flex-shrink:0;min-width:88px}.onlineBtn.join:hover:not(:disabled){box-shadow:var(--shadow-glow-o)}.onlineDivider{text-align:center;font-size:12px;color:var(--text-dim);font-family:var(--font-mono)}.onlineJoinRow{display:flex;gap:10px}.onlineInput{flex:1;background:var(--bg-elev-1);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:18px;letter-spacing:.2em;padding:10px 14px;text-transform:uppercase;outline:none;transition:border-color .2s,box-shadow .2s}.onlineInput:focus{border-color:var(--accent-o);box-shadow:0 0 0 2px var(--accent-o-glow)}.onlineWaiting{display:flex;flex-direction:column;align-items:center;gap:12px}.onlineCode{font-family:var(--font-mono);font-size:36px;font-weight:700;letter-spacing:.25em;color:var(--accent-x);text-shadow:var(--shadow-glow-x);padding:12px 24px;background:var(--bg-elev-1);border:1px solid rgba(34,211,238,.35);border-radius:var(--radius-md)}.onlineLabel{font-size:13px;color:var(--text-muted);font-family:var(--font-mono)}.onlineHint{font-size:13px;color:var(--text-dim);font-family:var(--font-mono);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.onlineBackBtn{align-self:flex-start;background:transparent;border:none;color:var(--text-muted);font-size:13px;padding:0;cursor:pointer}.onlineBackBtn:hover{color:var(--text-primary);transform:none;box-shadow:none;border:none}.onlineStatus{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:var(--bg-elev-1);border:1px solid var(--border-soft);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:13px;margin-bottom:8px}.onlinePlayer.x{color:var(--accent-x)}.onlinePlayer.o{color:var(--accent-o)}.onlineTurnBadge{font-size:12px;color:var(--accent-success);background:#4ade801a;border:1px solid rgba(74,222,128,.25);border-radius:999px;padding:4px 12px}@media(max-width:768px){.onlineCard{margin:24px auto;padding:28px 22px}.onlineCode{font-size:30px;padding:10px 18px}.onlineStatus{flex-wrap:wrap;font-size:12px;padding:10px 12px;gap:8px;justify-content:center;text-align:center}}@media(max-width:480px){.onlineCard{margin:14px auto;padding:22px 16px;gap:16px}.onlineTitle{font-size:18px}.onlineCode{font-size:24px;letter-spacing:.18em;padding:8px 14px}.onlineSizeInput,.onlineInput{font-size:16px;padding:10px 12px}.onlineJoinRow{flex-direction:column;gap:8px}.onlineBtn.join{width:100%}.onlineBtn{font-size:14px;padding:11px}}.notFoundPage{max-width:480px;margin:80px auto;padding:48px 36px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);text-align:center}.notFoundCode{font-family:var(--font-mono);font-size:72px;font-weight:700;letter-spacing:-.04em;background:linear-gradient(135deg,var(--accent-x) 0%,var(--accent-o) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;display:block;margin-bottom:12px}.notFoundPage h2{font-family:var(--font-mono);font-size:20px;color:var(--text-primary);margin-bottom:12px}.notFoundPage h2:before{content:"> ";color:var(--accent-danger)}.notFoundDesc{font-size:14px;color:var(--text-muted);margin-bottom:28px;line-height:1.6}.notFoundBtn{background:var(--btn-primary-bg);color:var(--btn-primary-text);border:none;font-weight:600;font-size:14px;padding:12px 32px;border-radius:var(--radius-md);cursor:pointer}.notFoundBtn:hover{opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-glow-x);border:none}@media(max-width:768px){.notFoundPage{margin:40px auto;padding:36px 24px}.notFoundCode{font-size:56px}}@media(max-width:480px){.notFoundPage{margin:24px auto;padding:28px 16px}.notFoundCode{font-size:48px}.notFoundPage h2{font-size:18px}}:root{--bg-base: #0b0f17;--bg-elev-1: #111826;--bg-elev-2: #1a2333;--bg-glass: rgba(17, 24, 38, .72);--border-soft: rgba(148, 163, 184, .18);--border-strong: rgba(148, 163, 184, .32);--text-primary: #e2e8f0;--text-muted: #94a3b8;--text-dim: #64748b;--accent-x: #22d3ee;--accent-x-glow: rgba(34, 211, 238, .35);--accent-o: #f472b6;--accent-o-glow: rgba(244, 114, 182, .35);--accent-chess: #a855f7;--accent-chess-glow: rgba(168, 85, 247, .35);--accent-success: #4ade80;--accent-danger: #f87171;--accent-warn: #fbbf24;--btn-primary-bg: linear-gradient(135deg, #22d3ee 0%, #6366f1 100%);--btn-primary-text: #0b0f17;--btn-secondary-bg: rgba(255, 255, 255, .04);--btn-secondary-border: var(--border-strong);--btn-danger-bg: linear-gradient(135deg, #f87171 0%, #ec4899 100%);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--shadow-soft: 0 4px 24px rgba(0, 0, 0, .35);--shadow-glow-x: 0 0 18px var(--accent-x-glow);--shadow-glow-o: 0 0 18px var(--accent-o-glow);--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", ui-monospace, Menlo, Consolas, monospace;--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:radial-gradient(circle at 20% -10%,rgba(99,102,241,.12),transparent 40%),radial-gradient(circle at 90% 10%,rgba(34,211,238,.1),transparent 40%),var(--bg-base);color:var(--text-primary);font-family:var(--font-sans);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em}button{font-family:var(--font-sans);border:1px solid var(--btn-secondary-border);background:var(--btn-secondary-bg);color:var(--text-primary);padding:10px 18px;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}button:hover:not(:disabled){transform:translateY(-1px);border-color:var(--accent-x);box-shadow:0 0 0 1px var(--accent-x-glow)}button:disabled{opacity:.4;cursor:not-allowed}.btnWithIcon{display:inline-flex;align-items:center;gap:8px}code{font-family:var(--font-mono);background:var(--bg-elev-2);border:1px solid var(--border-soft);border-radius:4px;padding:1px 6px;font-size:.9em;color:var(--accent-x)}.container{max-width:1200px;min-height:80vh;margin:0 auto;padding:0 24px 48px}.boxContent{max-width:800px;margin:32px auto;padding:28px;background:var(--bg-glass);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}@media(max-width:768px){.container{padding:0 14px 32px}.boxContent{margin:16px auto;padding:20px 16px;border-radius:var(--radius-md)}}@media(max-width:480px){button{padding:9px 14px;font-size:13px}.container{padding:0 10px 24px}.boxContent{margin:12px auto;padding:16px 12px}}
