*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#e0e0e0;background-color:#0a0a0a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh}#root{min-height:100vh}button{font-family:inherit}.app{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:#0a0a0a;color:#e0e0e0;font-family:system-ui,-apple-system,sans-serif;-webkit-tap-highlight-color:transparent;touch-action:pan-y}.container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem}h1{margin:0;font-size:2rem;font-weight:300;letter-spacing:.1em;color:#fff}.controls{display:flex;gap:2rem;align-items:center;width:100%;max-width:640px;justify-content:space-between}.mode-selector{display:flex;gap:.5rem;background:#1a1a1a;padding:.25rem;border-radius:.5rem}.mode-selector button{padding:.5rem 1rem;background:transparent;border:none;color:gray;cursor:pointer;font-size:.875rem;border-radius:.375rem;transition:all .2s;font-weight:500}.mode-selector button:hover{color:#b0b0b0}.mode-selector button.active{background:#2a2a2a;color:#fff}.game-info{display:flex;gap:1rem;align-items:center}.current-player{font-size:.875rem;color:#b0b0b0;font-weight:500}.reset-btn{padding:.5rem 1rem;background:#2a2a2a;border:1px solid #3a3a3a;color:#e0e0e0;cursor:pointer;font-size:.875rem;border-radius:.375rem;transition:all .2s}.reset-btn:hover{background:#3a3a3a;border-color:#4a4a4a}.leave-btn{padding:.5rem 1rem;background:#3a2a2a;border:1px solid #4a3a3a;color:#e0e0e0;cursor:pointer;font-size:.875rem;border-radius:.375rem;transition:all .2s}.leave-btn:hover{background:#4a3a3a;border-color:#5a4a4a}.mode-selector button:disabled{opacity:.5;cursor:not-allowed}.multiplayer-info{display:flex;gap:2rem;padding:1rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:.5rem;width:100%;max-width:640px;justify-content:space-between}.room-info,.player-info{display:flex;gap:.5rem;align-items:center;font-size:.875rem}.label{color:gray}.room-code{font-family:monospace;color:#fff;background:#0f0f0f;padding:.25rem .5rem;border-radius:.25rem;font-size:.875rem}.copy-btn{padding:.25rem .75rem;background:#2a2a2a;border:1px solid #3a3a3a;color:#e0e0e0;cursor:pointer;font-size:.75rem;border-radius:.25rem;transition:all .2s}.copy-btn:hover{background:#3a3a3a}.player-color{font-weight:600}.player-color.white{color:#f0f0f0}.player-color.black{color:gray}.waiting{color:#d0a040;font-style:italic}.game-error{width:100%;max-width:640px;padding:1rem;background:#3a1a1a;border:1px solid #5a2a2a;border-radius:.5rem;color:#ff6b6b;text-align:center;font-weight:500}.turn-indicator{color:gray;font-size:.75rem}.turn-indicator.your-turn{color:#6a9a6a}.captured-bar{width:100%;max-width:640px;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem .75rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:.375rem;min-height:2.5rem}.timer{font-family:Courier New,monospace;font-size:1rem;font-weight:700;color:#e0e0e0;min-width:4rem;text-align:center;background:#0f0f0f;padding:.25rem .5rem;border-radius:.25rem;border:1px solid #2a2a2a}.captured-pieces-inline{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;flex:1}.no-captures-inline{color:#4a4a4a;font-size:.875rem}.advantage-badge{font-size:.875rem;font-weight:700;padding:.25rem .5rem;border-radius:.25rem;background:#2a3a2a;color:#8aba8a;white-space:nowrap}.board-wrapper{display:flex;flex-direction:column;align-items:center}.board-container{display:flex;flex-direction:column}.board-markers-top{display:flex;margin-bottom:.25rem}.corner-spacer{width:30px;flex-shrink:0}.column-marker{width:80px;height:30px;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;color:#b0b0b0;-webkit-user-select:none;user-select:none}.board-with-side-markers{display:flex}.board-markers-left{display:flex;flex-direction:column;margin-right:.25rem}.row-marker{width:30px;height:80px;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;color:#b0b0b0;-webkit-user-select:none;user-select:none}.board{display:inline-block;border:2px solid #2a2a2a;border-radius:.5rem;overflow:hidden;box-shadow:0 8px 32px #0009}.board-row{display:flex}.square{width:80px;height:80px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .15s ease;-webkit-tap-highlight-color:transparent;touch-action:none}.square.light{background:#c8c4b0}.square.dark{background:#3a6a3a}.square:hover{filter:brightness(1.2)}.square.selected{background:#5a9ad5!important;box-shadow:inset 0 0 0 3px #3a6aa5}.square.possible-move{background:#d4a437!important}.square.possible-move:after{content:"";position:absolute;width:20px;height:20px;background:#aa8420;border-radius:50%;opacity:.8}.square.last-move{background:#ffff6459!important;box-shadow:inset 0 0 0 2px #ffd70080}.square.fog{background:#2a2a2a!important;cursor:default}.square.fog:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(80,80,100,.1),transparent 40%),radial-gradient(circle at 80% 70%,rgba(60,60,80,.15),transparent 40%)}.piece-image{width:90%;height:90%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.captured-piece-image{height:1.5rem;width:auto;object-fit:contain;opacity:.8;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.promotion-piece-image{width:80px;height:80px;object-fit:contain}.mode-description{font-size:.875rem;color:gray;text-align:center;max-width:640px}.mode-description p{margin:0}@media(max-width:768px){.container{padding:1rem;gap:1rem}.captured-bar{padding:.4rem .6rem;min-height:2rem}.advantage-badge{font-size:.75rem;padding:.2rem .4rem}.timer{font-size:.875rem;min-width:3.5rem;padding:.2rem .4rem}.column-marker{width:70px;height:28px;font-size:.8rem}.row-marker{width:28px;height:70px;font-size:.8rem}.corner-spacer{width:28px}.square{width:70px;height:70px}.captured-piece-image{height:1.3rem}.promotion-piece-image{width:70px;height:70px}.controls{flex-direction:column;gap:.75rem}h1{font-size:1.75rem}.multiplayer-info{flex-direction:column;gap:.75rem;padding:.75rem}.game-info{flex-wrap:wrap;justify-content:center}.mode-selector button{padding:.5rem .75rem;font-size:.8rem}}@media(max-width:480px){.app{padding:.5rem}.container{padding:.5rem;gap:.75rem;width:100%}.captured-bar{padding:.3rem .5rem;min-height:1.75rem;gap:.5rem}.advantage-badge{font-size:.7rem;padding:.15rem .35rem}.timer{font-size:.75rem;min-width:3rem;padding:.15rem .3rem}.column-marker{width:11vw;max-width:45px;height:24px;font-size:.7rem}.row-marker{width:24px;height:11vw;max-height:45px;font-size:.7rem}.corner-spacer{width:24px}.square{width:11vw;height:11vw;max-width:45px;max-height:45px}.captured-piece-image{height:1.1rem}.promotion-piece-image{width:60px;height:60px}.square.possible-move:after{width:12px;height:12px}h1{font-size:1.25rem;letter-spacing:.05em}.controls{gap:.5rem}.mode-selector{width:100%;gap:.25rem}.mode-selector button{flex:1;padding:.5rem .25rem;font-size:.7rem}.game-info{width:100%;justify-content:space-between;font-size:.75rem}.current-player{font-size:.75rem}.reset-btn,.leave-btn{padding:.4rem .75rem;font-size:.75rem}.multiplayer-info{padding:.5rem;gap:.5rem;font-size:.75rem}.room-code{font-size:.7rem;padding:.2rem .4rem}.copy-btn{padding:.2rem .5rem;font-size:.7rem}.mode-description{font-size:.75rem;padding:0 .5rem}.board{border:1px solid #2a2a2a}}@media(max-width:360px){.column-marker{width:10vw;max-width:40px;height:20px;font-size:.65rem}.row-marker{width:20px;height:10vw;max-height:40px;font-size:.65rem}.corner-spacer{width:20px}.square{width:10vw;height:10vw;max-width:40px;max-height:40px}.captured-piece-image{height:1rem}.promotion-piece-image{width:50px;height:50px}h1{font-size:1.1rem}.mode-selector button{font-size:.65rem;padding:.4rem .2rem}}.promotion-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.promotion-dialog{background:#1a1a1a;border:2px solid #3a3a3a;border-radius:.75rem;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 16px 64px #000c}.promotion-dialog h2{margin:0;font-size:1.5rem;font-weight:400;color:#fff;text-align:center}.promotion-options{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.promotion-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem;background:#2a2a2a;border:2px solid #3a3a3a;color:#e0e0e0;cursor:pointer;border-radius:.5rem;transition:all .2s;font-size:.875rem;font-weight:500}.promotion-btn:hover{background:#3a3a3a;border-color:#5a7a9a;transform:translateY(-2px)}.promotion-btn .piece{font-size:3rem}@media(max-width:480px){.promotion-dialog{padding:1.5rem;margin:1rem}.promotion-dialog h2{font-size:1.25rem}.promotion-options{gap:.75rem}.promotion-btn{padding:1rem .75rem}}.game-end-dialog{min-width:400px;max-width:90vw}.game-end-title{font-size:2rem;font-weight:600;color:#fff;margin:0 0 1rem;text-align:center}.game-end-result{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;background:#0f0f0f;border-radius:.5rem;border:1px solid #2a2a2a}.winner-icon{width:80px;height:80px;border-radius:50%;border:4px solid #3a3a3a}.winner-icon.winner-white{background:radial-gradient(circle,#fff,#d0d0d0);box-shadow:0 4px 12px #ffffff4d}.winner-icon.winner-black{background:radial-gradient(circle,#2a2a2a,#0a0a0a);box-shadow:0 4px 12px #0009}.game-end-result p{margin:0;font-size:1.25rem;font-weight:500;color:#e0e0e0;text-align:center}.game-end-actions{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.game-end-btn{padding:1rem 2rem;border:2px solid #3a3a3a;cursor:pointer;border-radius:.5rem;transition:all .2s;font-size:1rem;font-weight:600}.menu-btn{background:#2a2a2a;color:#e0e0e0}.menu-btn:hover{background:#3a3a3a;border-color:#4a4a4a;transform:translateY(-2px)}.rematch-btn{background:#2a3a2a;color:#8aba8a;border-color:#3a4a3a}.rematch-btn:hover{background:#3a4a3a;border-color:#4a5a4a;transform:translateY(-2px)}@media(max-width:480px){.game-end-dialog{min-width:unset;padding:1.5rem 1rem;margin:1rem}.game-end-title{font-size:1.5rem}.winner-icon{width:60px;height:60px}.game-end-result p{font-size:1rem}.game-end-actions{grid-template-columns:1fr}.game-end-btn{padding:.875rem 1.5rem;font-size:.875rem}}.lobby{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0a0a0a;padding:2rem}.lobby-container{max-width:600px;width:100%;display:flex;flex-direction:column;gap:2rem}.lobby h1{margin:0;font-size:2.5rem;font-weight:300;letter-spacing:.1em;color:#fff;text-align:center}.lobby-subtitle{text-align:center;color:gray;margin:-1rem 0 0;font-size:.875rem}.lobby-section{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:.5rem;padding:1.5rem}.lobby-section h2{margin:0 0 1rem;font-size:1.125rem;font-weight:500;color:#fff}.mode-selector-lobby{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.mode-selector-lobby button{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem .5rem;background:#0f0f0f;border:2px solid #2a2a2a;color:gray;cursor:pointer;border-radius:.375rem;transition:all .2s}.mode-selector-lobby button:hover{border-color:#3a3a3a;color:#b0b0b0}.mode-selector-lobby button.active{background:#2a2a2a;border-color:#5a7a9a;color:#fff}.mode-title{font-size:.875rem;font-weight:600}.mode-desc{font-size:.75rem;opacity:.7}.lobby-actions{display:flex;flex-direction:column;gap:1rem}.lobby-btn{padding:.875rem 1.5rem;background:#2a2a2a;border:1px solid #3a3a3a;color:#e0e0e0;cursor:pointer;font-size:1rem;border-radius:.375rem;transition:all .2s;font-weight:500}.lobby-btn:hover{background:#3a3a3a;border-color:#4a4a4a}.lobby-btn.primary{background:#3a4a5a;border-color:#5a7a9a}.lobby-btn.primary:hover{background:#4a5a6a;border-color:#6a8aaa}.lobby-btn.secondary{background:transparent;border-color:#3a3a3a;width:100%}.join-room{display:flex;gap:.5rem}.join-room input{flex:1;padding:.875rem 1rem;background:#0f0f0f;border:1px solid #3a3a3a;color:#e0e0e0;font-size:1rem;border-radius:.375rem;font-family:inherit}.join-room input:focus{outline:none;border-color:#5a7a9a}.join-room input::placeholder{color:#606060}.game-modes-info{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#0f0f0f;border-radius:.375rem}.info-item{font-size:.875rem;color:gray;line-height:1.5}.info-item strong{color:#b0b0b0}.error-message{background:#3a1a1a;border:1px solid #5a2a2a;color:#ff6b6b;padding:.875rem;border-radius:.375rem;font-size:.875rem;text-align:center}.searching-message{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:.5rem;margin:1rem 0}.searching-message span{font-size:1rem;color:#b0b0b0}.spinner{width:40px;height:40px;border:4px solid #2a2a2a;border-top-color:#5a7a9a;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.cancel-btn{background:#3a2a2a!important;border-color:#4a3a3a!important}.cancel-btn:hover{background:#4a3a3a!important;border-color:#5a4a4a!important}.auto-match{background:#2a4a3a!important;border-color:#3a5a4a!important;font-weight:600;font-size:1.1rem}.auto-match:hover{background:#3a5a4a!important;border-color:#4a6a5a!important}.divider{display:flex;align-items:center;text-align:center;margin:.5rem 0;color:#606060;font-size:.875rem}.divider span{padding:0 .5rem}@media(max-width:768px){.mode-selector-lobby{grid-template-columns:1fr}.join-room{flex-direction:column}.lobby h1{font-size:2rem}.lobby-container{padding:0 1rem}}@media(max-width:480px){.lobby{padding:1rem}.lobby-container{gap:1.5rem}.lobby h1{font-size:1.75rem}.lobby-subtitle{font-size:.8rem}.lobby-section{padding:1rem}.lobby-section h2{font-size:1rem}.lobby-btn{padding:.75rem 1.25rem;font-size:.9rem}.join-room input{padding:.75rem .875rem;font-size:.9rem}.mode-title{font-size:.8rem}.mode-desc{font-size:.7rem}.info-item{font-size:.8rem}}
