@import"https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap";:root{font-family:Bebas Neue,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--layout-max-width: 2200px;--layout-gutter: clamp(1rem, 2.2vw, 3.2rem);text-align:center}body{margin:0;display:block;min-width:320px;min-height:100vh}#root{width:100%;max-width:var(--layout-max-width);min-height:100vh;margin:0 auto;padding:clamp(.95rem,1.9vw,1.9rem) var(--layout-gutter) clamp(1.8rem,2.7vw,3rem);box-sizing:border-box}h1{font-size:6.2rem;line-height:1.1}h2{font-size:clamp(3rem,4.5vw,4rem);line-height:1.1}h3{font-size:clamp(2.2rem,3.3vw,3rem);line-height:1.1}h4{font-size:1.4rem;line-height:1.1}h5{font-size:1.2rem;line-height:1.1}p{font-size:clamp(1.2rem,1.45vw,1.55rem);line-height:1.5;margin-bottom:1.5rem}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}ul{padding:0}li{list-style:none;font-size:1.4rem}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--ocean-blue);cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(max-width:900px){h1{font-size:clamp(3.2rem,12vw,5rem)}h2{font-size:clamp(2rem,8vw,2.8rem)}h3{font-size:clamp(1.5rem,6vw,2.2rem)}p,li{font-size:clamp(1.05rem,4vw,1.25rem)}}@media(min-width:1920px){#root{--layout-gutter: clamp(2.3rem, 3.3vw, 5rem)}}@media(max-height:980px)and (min-width:900px){#root{padding-top:clamp(.35rem,.75vw,.8rem);padding-bottom:clamp(.6rem,1vw,1.1rem);gap:clamp(.45rem,.9vh,.8rem)}}@media(min-width:900px){html.game-active,body.game-active{height:100dvh;max-height:100dvh;overflow:hidden}body.game-active #root{height:100dvh;min-height:100dvh;max-height:100dvh;overflow:hidden;padding-top:clamp(.2rem,.45vw,.45rem);padding-bottom:clamp(.2rem,.45vw,.45rem)}}@media(max-width:899px){html.game-active,body.game-active,body.game-active #root{height:auto;min-height:100vh;max-height:none;overflow:auto}}:root{--navy-dark: #0a1628;--navy-blue: #788799;--ocean-blue: #2c3e50;--steel-blue: #34495e;--radar-green: #00ff41;--warning-orange: #ff6b35;--danger-red: #e63946;--gold: #ffb703;--white: #f8f9fa;--light-gray: #adb5bd;--mid-gray: #6c757d;--dark-gray: #343a40;--water: #2e86ab;--water-hover: #3a9fbf;--ship-gray: #495057;--hit: #e63946;--miss: #dee2e6;--sunk: #6c757d;--carrier: #ff69b4;--battleship: #e63946;--cruiser: #ffb703;--submarine: #356f44;--destroyer: #005275ff;--font-primary: "Bebas Neue", sans-serif;--cell-size: 46px;--border-radius: 4px;--background-primary: #0a1628;--background-secondary: #34495e;--text-primary: rgba(255, 255, 255, .87);--text-secondary: rgba(255, 255, 255, .6);color-scheme:dark;color:var(--text-primary);background-color:var(--background-primary)}:root.light-mode{--navy-dark: #d4e3f0;--navy-blue: #4a5c6e;--ocean-blue: #6fade4;--steel-blue: #7a9eb8;--background-primary: #a7dff7;--background-secondary: rgb(198, 235, 255);--text-primary: #1a2332;--text-secondary: #4a5c6e;color-scheme:light;color:var(--text-primary);background-color:var(--background-primary)}:root.dark-mode{--navy-dark: #0a1628;--navy-blue: #788799;--ocean-blue: #2c3e50;--steel-blue: #34495e;--background-primary: #0a1628;--background-secondary: #34495e;--text-primary: rgba(255, 255, 255, .87);--text-secondary: rgba(255, 255, 255, .6);color-scheme:dark;color:var(--text-primary);background-color:var(--background-primary)}body{background-color:var(--background-primary);color:var(--text-primary)}#root{display:flex;flex-direction:column;justify-content:space-between;gap:clamp(1rem,2vh,1.75rem)}.app-shell{display:flex;flex-direction:column;gap:clamp(.8rem,1.6vh,1.4rem);min-height:100%}.app-shell.game-active{height:100dvh;min-height:100dvh;max-height:100dvh;overflow:hidden;gap:0}.app-shell.game-active .game-screen{flex:1 1 auto;min-height:0;max-height:100%;overflow:hidden}@media(max-width:899px){.app-shell.game-active{height:auto;min-height:100%;max-height:none;overflow:visible;gap:clamp(.8rem,1.6vh,1.4rem)}.app-shell.game-active .game-screen{flex:0 0 auto;min-height:auto;max-height:none;overflow:visible}}.start-screen{width:min(100%,1760px);margin:0 auto;padding:clamp(1rem,2.5vw,2.4rem);box-sizing:border-box}.start-screen h1{margin:0 0 clamp(.9rem,2vh,1.6rem)}.game-options{display:flex;justify-content:center;align-items:center;margin:0 auto;gap:clamp(.6rem,1.6vw,1.2rem);width:min(100%,1320px);flex-wrap:wrap}.game-options li{flex:1 1 180px}.game-options button{width:100%;min-height:clamp(54px,6vh,66px)}.start-mode-icon{font-size:1rem;margin-right:.45rem;vertical-align:-.1em}.start-button{transition:background-color .3s ease}.start-button:hover{background-color:var(--radar-green);border:var(--radar-green)}.how-to-play{transition:background-color .3s ease}.how-to-play:hover{background-color:var(--gold);border:var(--gold)}.settings-button{transition:background-color .3s ease}.settings-button:hover{background-color:var(--danger-red);border:var(--danger-red)}.modal-overlay{position:fixed;inset:0;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);animation:startMenuFadeIn .26s ease-out}.modal-content{background:var(--background-secondary);border:2px solid var(--steel-blue);border-radius:8px;padding:clamp(1.4rem,2vw,2rem);min-width:300px;max-width:460px;box-shadow:0 4px 20px #0000004d;animation:startMenuScaleIn .26s ease-out}.modal-overlay.is-closing{animation:startMenuFadeOut .26s ease-in forwards}.modal-content.is-closing{animation:startMenuScaleOut .26s ease-in forwards;pointer-events:none}@keyframes startMenuFadeIn{0%{background-color:#0000}to{background-color:#000000d9}}@keyframes startMenuFadeOut{0%{background-color:#000000d9}to{background-color:#0000}}@keyframes startMenuScaleIn{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}@keyframes startMenuScaleOut{0%{transform:scale(1);opacity:1}to{transform:scale(.96);opacity:0}}.username-modal{display:flex;flex-direction:column;gap:clamp(.75rem,1.5vh,1rem)}.username-modal h2{margin:0;text-align:center;color:var(--text-primary)}.username-modal input{width:100%;padding:.75rem;margin:0;border:2px solid var(--steel-blue);border-radius:4px;background-color:var(--background-primary);color:var(--text-primary);font-size:1rem;box-sizing:border-box}.username-modal input:focus{outline:none;border-color:var(--radar-green);box-shadow:0 0 8px #4caf504d}.username-modal input::placeholder{color:var(--text-secondary)}.modal-buttons{display:flex;gap:1rem;justify-content:center;margin-top:.25rem}.modal-submit,.modal-cancel{padding:.75rem 1.5rem;border:2px solid var(--steel-blue);border-radius:4px;background-color:var(--background-primary);color:var(--text-primary);cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease}.modal-submit{background-color:var(--radar-green);border-color:var(--radar-green);color:#fff}.modal-submit:hover{background-color:#45a049;border-color:#45a049}.modal-cancel{background-color:var(--danger-red);border-color:var(--danger-red);color:#fff}.modal-cancel:hover{background-color:#c41c3b;border-color:#c41c3b}.multiplayer-modal{gap:.85rem}.multiplayer-mode-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.multiplayer-mode-button{padding:.55rem .75rem;border:1px solid var(--steel-blue);border-radius:6px;background:#0f1e32e6;color:var(--text-primary);cursor:pointer;font-weight:700}.multiplayer-mode-button.is-active{background:var(--radar-green);border-color:var(--radar-green);color:#fff}.multiplayer-board-size{display:flex;flex-direction:column;gap:.35rem;color:var(--text-secondary);font-weight:600}.multiplayer-board-size select{width:100%;padding:.6rem;border:2px solid var(--steel-blue);border-radius:4px;background-color:var(--background-primary);color:var(--text-primary);font-size:1rem}.multiplayer-error{margin:0;color:#ff9aa7;font-size:.95rem;font-weight:600}.resume-live-chip{display:inline-flex;align-items:center;gap:.35rem;margin-left:.6rem;padding:.12rem .45rem;border-radius:999px;border:1px solid rgba(255,130,130,.65);background:#be141442;color:#ffd9d9;font-size:.75rem;font-weight:800;letter-spacing:.04em}.resume-live-dot{width:.5rem;height:.5rem;border-radius:50%;background:#ff4545;box-shadow:0 0 #ff454599;animation:resumeLivePulse 1.25s ease-out infinite}@keyframes resumeLivePulse{0%{transform:scale(1);box-shadow:0 0 #ff4545a6}70%{transform:scale(1.08);box-shadow:0 0 0 9px #ff454500}to{transform:scale(1);box-shadow:0 0 #ff454500}}.dev-mode-indicator{position:fixed;bottom:10px;right:10px;background-color:#ffc10733;border:1px solid var(--gold);color:var(--gold);padding:.5rem 1rem;border-radius:4px;font-size:.85rem;font-weight:600;z-index:100;pointer-events:none}@media(max-width:768px){.start-screen{width:100%;padding:.5rem 0 1rem}.game-options{gap:.6rem}.game-options li{flex:1 1 100%}.modal-content{min-width:min(100%,280px);width:min(94vw,400px);padding:1.2rem}.modal-buttons{flex-direction:column}}@media(min-width:1900px){.start-screen{width:min(100%,1800px)}}.overlay{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;text-align:left;z-index:1000;background-color:transparent!important;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{background-color:#0000}to{background-color:#000000b3}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fadeOut{0%{background-color:#000000b3}to{background-color:#0000}}@keyframes scaleOut{0%{transform:scale(1);opacity:1}to{transform:scale(.96);opacity:0}}:root.no-animations .overlay{animation:none!important}:root.no-animations .overlay-content{animation:none!important}:root.no-animations *{transition:none!important;animation:none!important}.overlay-content{position:relative;--overlay-pad: clamp(1.25rem, 2vw, 2rem);--overlay-gap: clamp(.85rem, 1.6vh, 1.2rem);background-color:var(--background-secondary);border-radius:12px;padding:var(--overlay-pad);width:min(92vw,920px);max-height:82vh;overflow-y:auto;box-shadow:0 4px 6px #0000004d;animation:scaleIn .3s ease-out;color:var(--text-primary)}.overlay-content .close-button{position:absolute;background-color:var(--ocean-blue)!important;top:var(--overlay-pad);right:var(--overlay-pad);background:transparent;border:none;font-size:2rem;color:#fff;cursor:pointer;padding:1.2rem .5rem 1rem;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.overlay-content .close-button:hover{background-color:#ffffff1a}.overlay-content .close-button:focus{outline:none}.overlay.is-closing{animation:fadeOut .26s ease-in forwards}.overlay-content.is-closing{animation:scaleOut .26s ease-in forwards;pointer-events:none}.how-to-play .how-to-play-screen{display:flex;flex-direction:column;gap:var(--overlay-gap);width:min(100%,760px);margin:0 auto;padding-top:.2rem}.how-to-play .controls-guide{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem;margin:.25rem 0 .1rem}.how-to-play .control-figure{display:flex;flex-direction:column;align-items:center;gap:.65rem;padding:.95rem;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);text-align:center}.how-to-play .control-figure-title{color:var(--text-primary);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.78}.how-to-play .control-figure-copy{display:flex;flex-direction:column;gap:.2rem}.how-to-play .control-figure-copy strong{color:var(--gold);font-size:1rem}.how-to-play .control-figure-copy span{color:var(--text-secondary);font-size:.92rem;line-height:1.35}.how-to-play .mouse-figure{position:relative;width:4.1rem;height:6.15rem;border-radius:2.2rem;background:linear-gradient(180deg,#ffffff2e,#ffffff14);border:2px solid rgba(255,255,255,.22);box-shadow:inset 0 -10px 18px #00000029}.how-to-play .mouse-button{position:absolute;top:.45rem;width:1.35rem;height:2.1rem;border-radius:999px;background:#ffffff14;border:1px solid rgba(255,255,255,.15)}.how-to-play .mouse-button.left{left:.38rem}.how-to-play .mouse-click .mouse-button.left{background:#ffb70357;border-color:#ffb703b3;box-shadow:0 0 0 3px #ffb7031f}.how-to-play .mouse-button.right{right:.38rem}.how-to-play .mouse-wheel{position:absolute;top:.9rem;left:50%;transform:translate(-50%);width:.34rem;height:1rem;border-radius:999px;background:var(--steel-blue);opacity:.95}.how-to-play .mouse-button.active{background:#ffb70352;border-color:#ffb7038c;box-shadow:0 0 0 3px #ffb7031f}.how-to-play .mouse-drag-arrow,.how-to-play .mouse-double-badge{position:absolute;right:-.55rem;bottom:.35rem;display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:999px;background:var(--ocean-blue);color:var(--gold);font-size:1rem;font-weight:700;box-shadow:0 0 0 3px #0a1628bf}.how-to-play h2{text-align:center;margin:0;color:var(--gold)!important}.how-to-play h3{text-decoration:underline;margin:0;font-size:2rem}.how-to-play p{margin:0}.how-to-play ol{margin:0;padding-left:1.5rem}.how-to-play ol li{list-style:decimal!important;margin-left:0;padding-left:1rem}.settings.overlay:not(.is-closing){animation:none}.settings .overlay-content:not(.is-closing){animation:none}.settings .settings-screen{display:flex;flex-direction:column;gap:var(--overlay-gap);width:min(100%,760px);margin:0 auto;padding-top:.2rem}.settings h2{text-align:center;margin:0;color:var(--danger-red)!important}.settings .settings-group{margin:0;display:flex;flex-direction:column;gap:clamp(.55rem,1.1vh,.9rem)}.settings .settings-group h3{color:var(--danger-red);margin:0;font-size:1.2rem;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:.5rem}.settings .setting-item{display:flex;justify-content:space-between;align-items:center;margin:0;padding:.5rem 0}.settings .setting-item label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.settings .setting-item select{padding:.5rem 2.75rem .5rem 1rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background-color:var(--ocean-blue);background-image:linear-gradient(45deg,transparent 50%,var(--text-primary) 50%),linear-gradient(135deg,var(--text-primary) 50%,transparent 50%);background-position:right 1.1rem center,right .75rem center;background-size:.4rem .4rem,.4rem .4rem;background-repeat:no-repeat;color:var(--text-primary);font-family:inherit;cursor:pointer;min-width:150px;appearance:none;-webkit-appearance:none;-moz-appearance:none}.settings .setting-item select:focus{outline:2px solid var(--danger-red)}.settings .setting-item select option{background-color:var(--steel-blue);color:var(--text-primary)}.settings .setting-item input[type=checkbox]{width:1.2rem;height:1.2rem;cursor:pointer;accent-color:var(--danger-red)}@media(max-width:768px){.overlay-content{width:min(94vw,700px);max-height:88vh}.how-to-play .controls-guide{grid-template-columns:1fr}.settings .setting-item{gap:.7rem;flex-wrap:wrap}}footer{text-align:center;padding:.75rem .5rem;opacity:.75}footer p{margin:0;font-size:clamp(.72rem,.55rem + .35vw,.9rem);line-height:1.2;letter-spacing:.03em}footer a{color:inherit;text-decoration:underline;text-underline-offset:.12em}.board-screen{display:flex;flex-direction:column;align-items:center;gap:1.2rem;padding:1.15rem;width:min(100%,1100px);margin:0 auto;box-sizing:border-box}.app-shell.game-active .board-screen{gap:.6rem;padding:.45rem .5rem}.app-shell.game-active .game-screen.is-setup .board-screen{flex:1 1 auto;min-height:0;justify-content:flex-start;gap:.35rem;padding:.3rem .45rem}.app-shell.game-active .board-placement-area{gap:.22rem}.app-shell.game-active .board-direction{gap:.28rem;padding:.58rem .56rem;min-width:4rem}.app-shell.game-active .board-direction-label{font-size:.6rem}.app-shell.game-active .board-direction-arrow{width:1.55rem;height:1.55rem;font-size:.9rem}.app-shell.game-active .board-direction-text{font-size:.7rem}.app-shell.game-active .game-board{--board-cell-size: clamp(24px, min(3.8vw, 4.35vh), 52px)}.app-shell.game-active .game-board[style*="--grid-size: 8"]{--board-cell-size: clamp(28px, min(4.2vw, 5vh), 62px)}.app-shell.game-active .game-board[style*="--grid-size: 10"]{--board-cell-size: clamp(24px, min(3.8vw, 4.35vh), 52px)}.app-shell.game-active .game-board[style*="--grid-size: 12"]{--board-cell-size: clamp(21px, min(3.25vw, 3.75vh), 45px)}.app-shell.game-active #start-game-button{margin-top:.4rem;padding:.72rem 1.35rem;min-width:180px;font-size:1rem}.board-placement-area{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:.3rem;width:min(100%,980px);max-width:980px;margin:0 auto}.board-direction-left{justify-self:end}.board-direction-right{justify-self:start}.board-direction{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem;padding:1rem .85rem;min-width:5.1rem;border-radius:16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:var(--text-primary);box-shadow:0 6px 16px #0000001f}.board-direction-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.board-direction-arrow{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:var(--ocean-blue);color:var(--gold);font-size:1.1rem;font-weight:700;box-shadow:inset 0 0 0 1px #ffffff14}.board-direction-text{font-size:.88rem;font-weight:700;letter-spacing:.03em}#start-game-button{background-color:var(--ocean-blue);color:var(--text-primary);border:2px solid transparent;font-size:1.4rem;font-weight:700;padding:1.05rem 2.2rem;min-width:230px;border-radius:var(--border-radius);cursor:pointer;transition:border-color .4s ease,background-color .3s ease;outline:none;margin-top:1rem}#start-game-button:not(:disabled){background-color:var(--radar-green);color:var(--navy-dark)}#start-game-button:hover:not(:disabled){border-color:var(--gold)}#start-game-button:focus{border-color:var(--radar-green);outline:none}#start-game-button:disabled{background-color:var(--background-secondary);cursor:not-allowed;border-color:transparent}#start-game-button:disabled:hover{border-color:var(--warning-orange)}#start-game-button:active:not(:disabled){border-color:var(--gold)!important}.game-board{--board-cell-size: clamp(22px, min(3.6vw, 3.6vh), 46px);border-collapse:separate;border-spacing:1.5px;border:2px solid var(--ocean-blue);background-color:var(--ocean-blue);box-shadow:0 4px 8px #0000004d;padding:2px;margin:0 auto;max-width:100%}.board-label{background-color:var(--steel-blue);color:var(--white);font-weight:700;text-align:center;font-size:.85rem;padding:0;border:1px solid var(--ocean-blue);width:var(--board-cell-size);height:var(--board-cell-size)}.board-label.corner{background-color:var(--background-secondary);border:none;color:var(--danger-red);font-size:1rem}.board-cell{width:var(--board-cell-size);height:var(--board-cell-size);border:1px solid var(--ocean-blue);background-color:var(--water);cursor:pointer;transition:background-color .2s;position:relative}.board-cell:hover{background-color:var(--water-hover)}.board-cell.occupied{cursor:pointer;position:relative}.board-cell.occupied:before{content:"";position:absolute;top:2px;right:2px;width:8px;height:8px;background-color:var(--warning-orange);border-radius:50%;opacity:0;transition:opacity .2s}.board-cell.occupied:hover:before{opacity:.8}.board-cell.occupied:hover{box-shadow:inset 0 0 8px #ff6b354d}.board-cell.hover-preview{background-color:#00ff414d;border:2px solid var(--radar-green)}.board-cell.preview-placement{border:2px solid var(--radar-green)}.board-cell.preview-placement:after{content:"";position:absolute;inset:0;background:var(--preview-ship-color, rgba(255, 255, 255, .35));opacity:.55;pointer-events:none}.board-cell .ship-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:clamp(.5rem,1.5vw,.7rem);font-weight:700;color:#fff;line-height:1;letter-spacing:0;text-shadow:none;-webkit-user-select:none;user-select:none;z-index:1}.board-cell .ship-label.ship-label-preview{opacity:.95}.game-board[style*="--grid-size: 8"]{--board-cell-size: clamp(26px, min(3.9vw, 3.9vh), 54px)}.game-board[style*="--grid-size: 10"]{--board-cell-size: clamp(24px, min(3.35vw, 3.35vh), 46px)}.game-board[style*="--grid-size: 12"]{--board-cell-size: clamp(22px, min(2.9vw, 2.9vh), 41px)}.board-cell.ship{background-color:var(--ship-cell-color, var(--ship-gray))}.board-cell.hit{background-color:var(--hit)}.board-cell.miss{background-color:var(--miss)}.board-cell.miss:after{content:"•";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--mid-gray);font-size:1.5rem}.board-cell.hit:after{content:"✕";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--white);font-size:1.5rem;font-weight:700}.board-cell.sunk{background-color:var(--sunk)}.board-marker-legend{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;flex-wrap:wrap;margin-top:.35rem}.board-marker-legend-item{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .4rem;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}.board-marker-swatch{width:1.05rem;height:1.05rem;display:inline-flex;align-items:center;justify-content:center;border-radius:3px;font-size:.8rem;font-weight:800;line-height:1}.board-marker-swatch.is-miss{background:var(--miss);color:var(--mid-gray)}.board-marker-swatch.is-hit{background:var(--hit);color:var(--white)}.board-marker-swatch.is-sunk{background:var(--sunk);color:var(--white)}.board-marker-text{font-size:.74rem;font-weight:700;color:var(--text-secondary);letter-spacing:.02em}.board-cell.sunk-exploding{overflow:hidden}.sunk-explosion{position:absolute;inset:0;pointer-events:none;z-index:5}.sunk-explosion-core,.sunk-explosion-ring,.sunk-explosion-sparks{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.sunk-explosion-core{width:38%;height:38%;border-radius:50%;background:radial-gradient(circle,#fffbe8,#ffb703 45%,#e63946);animation:sunkExplosionCore .65s ease-out forwards}.sunk-explosion-ring{width:24%;height:24%;border-radius:50%;border:2px solid rgba(255,202,58,.9);animation:sunkExplosionRing .7s ease-out forwards}.sunk-explosion-sparks{width:94%;height:94%}.sunk-explosion-sparks:before,.sunk-explosion-sparks:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 25%,rgba(255,183,3,.95) 0 7%,transparent 8%),radial-gradient(circle at 72% 16%,rgba(255,214,102,.9) 0 6%,transparent 7%),radial-gradient(circle at 84% 68%,rgba(255,107,53,.9) 0 7%,transparent 8%),radial-gradient(circle at 30% 80%,rgba(255,233,196,.9) 0 6%,transparent 7%)}.sunk-explosion-sparks:before{animation:sunkExplosionSparks .62s ease-out forwards}.sunk-explosion-sparks:after{animation:sunkExplosionSparks .7s ease-out forwards;transform:rotate(28deg);opacity:.75}@keyframes sunkExplosionCore{0%{opacity:0;transform:translate(-50%,-50%) scale(.35);filter:blur(.5px)}18%{opacity:1;transform:translate(-50%,-50%) scale(1.18);filter:blur(0)}to{opacity:0;transform:translate(-50%,-50%) scale(.75)}}@keyframes sunkExplosionRing{0%{opacity:0;transform:translate(-50%,-50%) scale(.25)}20%{opacity:1}to{opacity:0;transform:translate(-50%,-50%) scale(2.2)}}@keyframes sunkExplosionSparks{0%{opacity:0;transform:scale(.45)}24%{opacity:1}to{opacity:0;transform:scale(1.18)}}:root.no-animations .board-cell{transition:none}:root.no-animations .sunk-explosion{display:none}@media(max-width:768px){.board-screen{width:100%;padding:.6rem .25rem}.board-placement-area{grid-template-columns:1fr;justify-items:center}.board-direction{width:min(100%,520px);flex-direction:row;justify-content:center;gap:.6rem}.game-board{--board-cell-size: clamp(15px, min(4.9vw, 4.2vh), 30px)}.board-label.column-label,.board-label.row-label{min-width:var(--board-cell-size);min-height:var(--board-cell-size);font-size:clamp(.65rem,1.8vw,.9rem)}.board-cell .ship-label{font-size:clamp(.4rem,2vw,.6rem)}.board-marker-legend{gap:.4rem}.board-marker-legend-item{padding:.16rem .34rem}}@media(max-width:480px){.board-screen{padding:.35rem 0}.board-direction{padding:.75rem .65rem}.game-board{--board-cell-size: clamp(13px, min(6vw, 4.7vh), 26px)}.board-label.column-label,.board-label.row-label{min-width:var(--board-cell-size);min-height:var(--board-cell-size);font-size:clamp(.55rem,2.2vw,.8rem)}.board-cell .ship-label{font-size:clamp(.35rem,2.5vw,.55rem)}.game-board{border-spacing:1px}}@media(min-width:1900px){.game-board[style*="--grid-size: 8"]{--board-cell-size: clamp(28px, min(2.2vw, 2.2vh), 48px)}.game-board[style*="--grid-size: 10"]{--board-cell-size: clamp(24px, min(1.9vw, 1.9vh), 42px)}.game-board[style*="--grid-size: 12"]{--board-cell-size: clamp(20px, min(1.7vw, 1.7vh), 35px)}}@media(max-height:980px)and (min-width:900px){.board-screen{gap:.7rem;padding:.55rem .6rem}.board-placement-area{gap:.2rem}.board-direction{gap:.3rem;padding:.66rem .62rem;min-width:4.2rem}.board-direction-label{font-size:.62rem}.board-direction-arrow{width:1.65rem;height:1.65rem;font-size:.95rem}.board-direction-text{font-size:.74rem}.game-board{--board-cell-size: clamp(20px, min(3.05vw, 2.45vh), 39px)}.game-board[style*="--grid-size: 8"]{--board-cell-size: clamp(23px, min(3.4vw, 2.75vh), 46px)}.game-board[style*="--grid-size: 10"]{--board-cell-size: clamp(20px, min(3.05vw, 2.45vh), 39px)}.game-board[style*="--grid-size: 12"]{--board-cell-size: clamp(18px, min(2.7vw, 2.2vh), 34px)}#start-game-button{margin-top:.5rem;padding:.78rem 1.5rem;min-width:190px;font-size:1.08rem}}#ships-container{display:flex;flex-direction:column;align-items:center;gap:1.15rem;width:min(100%,980px);margin:0 auto}#ships-container #header-buttons{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;margin:0}#ships-container #header-buttons button{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;background-color:var(--ocean-blue);color:var(--text-primary);border:2px solid transparent;font-size:1.15rem;padding:.85rem 1.15rem;margin:0;min-width:160px;border-radius:999px;cursor:pointer;transition:border-color .25s ease,background-color .25s ease,transform .18s ease,box-shadow .25s ease;outline:none;box-shadow:0 8px 20px #0000002e}#ships-container #header-buttons button:hover{border-color:var(--gold);transform:translateY(-1px)}#ships-container #header-buttons button:focus{border-color:var(--radar-green);outline:none;box-shadow:0 0 0 3px #00ff412e,0 8px 20px #0000002e}#ships-container #header-buttons button:disabled{background-color:var(--background-secondary);cursor:not-allowed;border-color:transparent}#ships-container #header-buttons button:disabled:hover{border-color:var(--warning-orange)}#ships-container #header-buttons button:active{border-color:var(--gold)!important;transform:translateY(0)}#ships-container #header-buttons #finish-setup-button:not(:disabled){background-color:var(--radar-green);color:var(--navy-dark);font-weight:700}#ships-container #ships-row{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:1rem;width:100%}#ships-container #ships-row>div{white-space:nowrap;cursor:pointer;margin:0rem;padding:0rem;border:2px solid transparent;border-radius:var(--border-radius);transition:border-color .4s ease,opacity .3s ease}#ships-container #ships-row>div.placed{opacity:.4;pointer-events:none}#ships-container #ships-row>div .ship-name{color:var(--text-primary);text-align:center;margin-bottom:.5rem}#ships-container #ships-row>div .ship-preview{display:flex;flex-direction:row;gap:2px;padding:0;justify-content:center;transition:all .3s ease;background-color:transparent}#ships-container #ships-row>div .ship-preview.vertical{flex-direction:column}#ships-container #ships-row>div .ship-preview:active .ship-cell{opacity:.5}#ships-container #ships-row>div .ship-preview.is-dragging .ship-cell{opacity:.35}#ships-container #ships-row>div .ship-preview.is-dragging .ship-label{opacity:.8}#ships-container #ships-row>div .ship-preview .ship-cell{width:var(--cell-size);height:var(--cell-size);background-color:var(--ship-gray);border:1px solid var(--dark-gray);border-radius:var(--border-radius);display:flex;align-items:center;margin:0 auto;transition:opacity .2s ease}#ships-container #ships-row>div .ship-preview .ship-label{margin:0 auto;color:#fff;font-size:clamp(.5rem,1.5vw,.7rem);font-weight:700;line-height:1;letter-spacing:0;text-shadow:none;-webkit-user-select:none;user-select:none}#ships-container #ships-row>div .ship-length{text-align:center;margin-top:.5rem;color:var(--text-secondary)}.app-shell.game-active #ships-container,.app-shell.game-active #ships-container #ships-row{gap:.55rem}.app-shell.game-active #ships-container #ships-row>div .ship-name{margin-bottom:.2rem;font-size:.9rem}.app-shell.game-active #ships-container #ships-row>div .ship-length{margin-top:.2rem;font-size:.8rem}.app-shell.game-active #ships-container #header-buttons button{font-size:.95rem;padding:.56rem .78rem;min-width:128px}.app-shell.game-active .orientation-button-arrow{width:1.45rem;height:1.45rem;font-size:.84rem}.orientation-button-arrow{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;background:#ffffff14;color:var(--gold);font-size:1rem;line-height:1;box-shadow:inset 0 0 0 1px #ffffff14}.orientation-button-text{white-space:nowrap}@media(max-width:768px){#ships-container{gap:.95rem}#ships-container #header-buttons{flex-direction:column;width:min(100%,520px)}#ships-container #header-buttons .orientation-indicator,#ships-container #header-buttons button{width:100%}#ships-container #header-buttons button{min-width:0}}@media(max-height:980px)and (min-width:900px){#ships-container{gap:.7rem}#ships-container #ships-row{gap:.65rem}#ships-container #ships-row>div .ship-name{margin-bottom:.28rem;font-size:.95rem}#ships-container #ships-row>div .ship-length{margin-top:.28rem;font-size:.86rem}#ships-container #header-buttons button{font-size:1rem;padding:.62rem .88rem;min-width:138px}.orientation-button-arrow{width:1.52rem;height:1.52rem;font-size:.92rem}}h2,p{margin-bottom:1rem}.setup-options{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.9rem}.setup-option{display:inline-flex;align-items:center;gap:.45rem}.setup-option label{font-size:1rem;color:var(--text-secondary);white-space:nowrap}.setup-option select{min-width:168px;font-size:1rem;padding:.3rem .45rem;border-radius:6px;border:1px solid rgba(255,255,255,.24);background:#0a16288c;color:var(--text-primary)}.setup-option select:focus{outline:none;border-color:var(--gold)}.game-screen{position:relative;width:min(100%,2050px);margin:0 auto;padding:clamp(1.2rem,2.4vw,2.8rem);border-radius:14px;box-sizing:border-box}.game-screen.is-setup{padding-top:clamp(.45rem,1vw,.9rem)}.setup-stage{display:flex;flex-direction:column;gap:.45rem}.setup-controls{display:flex;flex-direction:column;gap:.2rem}.setup-board-stage{width:100%}.app-shell.game-active .game-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;width:min(100%,1900px);padding:clamp(.45rem,.9vw,.95rem) clamp(.55rem,1.2vw,1.25rem)}.app-shell.game-active .game-screen.is-setup{padding-top:clamp(.22rem,.5vw,.5rem)}.app-shell.game-active .setup-header{margin-bottom:.25rem}.app-shell.game-active .setup-header h2{margin-bottom:.15rem;font-size:clamp(1.75rem,2.2vw,2.2rem);line-height:1}.app-shell.game-active .setup-header p{margin-bottom:.15rem;font-size:clamp(.9rem,.9vw,1.02rem);line-height:1.2}.app-shell.game-active .setup-options{margin-bottom:.25rem;gap:.45rem}.app-shell.game-active .game-screen.is-setup{display:flex;flex-direction:column;min-height:0;justify-content:flex-start;align-items:center;overflow-y:auto;overflow-x:hidden}.app-shell.game-active .game-screen.is-setup .setup-stage{flex:1 1 auto;min-height:0;gap:.25rem;justify-content:center}.app-shell.game-active .game-screen.is-setup .setup-controls{flex:0 0 auto;gap:.05rem}.app-shell.game-active .game-screen.is-setup .setup-board-stage{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center}.app-shell.game-active .game-screen:not(.is-setup){align-items:center}.app-shell.game-active .game-screen:not(.is-setup) .battle-boards{align-self:center}.app-shell.game-active .game-screen:not(.is-setup) .battle-marker-legend-row{align-self:center}.app-shell.game-active .back-to-menu-button{padding:.48rem .8rem;font-size:.9rem}.setup-header{margin-bottom:.65rem}.setup-header h2{margin-top:0;margin-bottom:.45rem}.setup-header p{margin-top:0;margin-bottom:.4rem}.back-to-menu-button{position:absolute;top:0;left:0;z-index:3;display:inline-flex;align-items:center;gap:.55rem;padding:.72rem 1.08rem;border:none;background:linear-gradient(180deg,#ff5a5f,#d62839);color:#fff2f2;font-weight:700;letter-spacing:.01em;border-radius:var(--border-radius);box-shadow:0 8px 18px #d6283957,0 0 0 1px #ff7e7e29;transition:border-color .25s ease,filter .25s ease,box-shadow .25s ease}.back-to-menu-button:hover{filter:brightness(1.04);box-shadow:0 10px 24px #d628396b,0 0 0 1px #ffb0b038}.back-to-menu-button:focus,.back-to-menu-button:focus-visible{box-shadow:0 0 0 3px #d6283947,0 10px 24px #d628396b;outline:none}.back-arrow-icon{display:inline-flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;border-radius:999px;border:1px solid rgba(255,255,255,.45);background:#78081852;color:#fff7f7;font-size:1rem;line-height:1}.battle-subtitle{margin:0 0 .2rem;color:var(--text-secondary);font-size:clamp(.9rem,.9vw,1.02rem);line-height:1.2}.battle-status{font-weight:600;margin:0 0 .2rem;font-size:clamp(.92rem,.95vw,1.06rem);line-height:1.2}.battle-header-title{margin:0 0 .15rem;font-size:clamp(1.75rem,2.2vw,2.2rem);line-height:1}.multiplayer-room-pin-highlight{display:inline-flex;align-items:center;padding:.08rem .45rem;border-radius:999px;border:1px solid rgba(255,183,3,.5);background:#ffb70329;color:var(--gold);letter-spacing:.06em;font-weight:900}.battle-turn{display:inline-flex;align-items:center;gap:.45rem;color:var(--radar-green);margin-bottom:.6rem;padding:.55rem 1rem;border-radius:999px;border:1px solid rgba(0,255,65,.28);background:#00ff4114;font-size:1.15rem;font-weight:800;letter-spacing:.02em;box-shadow:0 0 0 1px #00ff4114,0 0 18px #00ff411f}.battle-winner{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .9rem;margin-bottom:0;border-radius:12px;font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:800;letter-spacing:.01em;border:1px solid transparent;box-shadow:0 10px 26px #0a162826}.battle-winner.winner-player{color:#e5fff0;background:linear-gradient(180deg,#00ff4147,#00bf3429);border-color:#00ff4161;text-shadow:0 1px 2px rgba(0,0,0,.25)}.battle-winner.winner-bot{color:#ffe8eb;background:linear-gradient(180deg,#e6394640,#ab1c2824);border-color:#e6394666;text-shadow:0 1px 2px rgba(0,0,0,.25)}.app-shell.game-active .battle-header-title,.app-shell.game-active .battle-subtitle,.app-shell.game-active .battle-status{margin-bottom:.12rem}.win-confetti{position:fixed;inset:0;pointer-events:none;z-index:1200;overflow:hidden}.confetti-piece{position:absolute;top:-12px;border-radius:2px;opacity:0;animation-name:confettiFall;animation-timing-function:cubic-bezier(.2,.95,.28,1);animation-fill-mode:forwards}@keyframes confettiFall{0%{opacity:0;transform:translate3d(0,-20px,0) rotate(0)}10%{opacity:1}to{opacity:0;transform:translate3d(0,105vh,0) rotate(540deg)}}.battle-boards{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,480px),1fr));width:min(100%,1820px);margin:0 auto;align-items:start;gap:clamp(1.15rem,2.3vw,2.4rem)}.battle-boards.is-compact{grid-template-columns:repeat(2,minmax(0,1fr));width:min(100%,1700px);gap:clamp(.6rem,1.2vw,1.15rem)}.battle-boards.has-summary,.battle-boards.has-middle-column{--middle-column-width: 160px;grid-template-columns:minmax(0,1fr) minmax(0,var(--middle-column-width)) minmax(0,1fr);align-items:center}.battle-middle-column{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:var(--middle-column-width);max-width:var(--middle-column-width);justify-self:center;flex:0 1 auto}.battle-marker-legend-row{display:flex;justify-content:center;margin-top:.35rem}.battle-rematch-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;margin-top:1.2rem;width:100%}.rematch-button-group{display:flex;gap:.8rem;justify-content:center;align-items:center;flex-wrap:wrap}.battle-rematch-section .battle-new-button{background-color:var(--radar-green);color:var(--navy-dark)}.battle-marker-legend{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;width:fit-content;align-self:center;padding:.3rem .34rem;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:#ffffff0d;box-shadow:0 5px 10px #0000001f}.battle-marker-legend-item{display:grid;grid-template-columns:auto auto;align-items:center;justify-content:start;gap:.28rem;padding:.06rem 0}.battle-marker-swatch{width:.92rem;height:.92rem;display:grid;place-items:center;border-radius:3px;font-size:1rem;font-weight:800;line-height:1;padding:0}.battle-marker-swatch.is-miss{background:var(--miss);color:var(--mid-gray);transform:translateY(-.5px)}.battle-marker-swatch.is-hit{background:var(--hit);color:var(--white);transform:translateY(-.25px)}.battle-marker-swatch.is-sunk{background:var(--sunk);color:var(--white);transform:translateY(-.25px)}.battle-marker-text{font-size:1rem;font-weight:700;color:var(--text-secondary);letter-spacing:.02em;white-space:nowrap}.battle-summary-column{display:flex;flex-direction:column;align-items:stretch;gap:.4rem;width:100%;max-width:100%;min-width:0;box-sizing:border-box;padding:.85rem .8rem;border-radius:14px;border:1px solid rgba(255,255,255,.2);background:linear-gradient(165deg,#081426e0,#12243ad1);box-shadow:0 10px 24px #0003}.battle-summary-kicker{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:1rem;color:var(--text-secondary)}.battle-summary-title{margin:0;font-size:1.15rem;color:var(--gold);text-align:center}.battle-summary-subtitle{margin:0 0 .15rem;font-size:1rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.battle-summary-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.4rem}.battle-summary-item{display:flex;justify-content:space-between;align-items:center;gap:.65rem;padding:.42rem .48rem;border-radius:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}.battle-summary-label{font-size:1rem;color:var(--text-secondary)}.battle-summary-value{font-size:1rem;font-weight:800;color:var(--text-primary)}.battle-board-wrap{display:flex;flex-direction:column;align-items:center;gap:.7rem;width:100%;min-width:0;padding:1.05rem 1.05rem 1.15rem;border-radius:18px;transition:opacity .22s ease}.battle-board-content{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%}.ships-remaining-panel{width:172px;padding:.72rem .62rem;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;box-shadow:0 6px 14px #00000024;align-self:center}.ships-remaining-panel.panel-left{order:0}.board-center-column{order:1;display:flex;flex-direction:column;align-items:center;gap:.65rem;position:relative;padding-bottom:.6rem}.board-center-column:after{content:"";width:min(100%,460px);height:3px;border-radius:999px;background:linear-gradient(90deg,#ffb7031a,#ffb7031a);opacity:0;transition:opacity .22s ease,background .22s ease}.ships-remaining-panel.panel-right{order:2}.battle-board-title{margin:0;text-align:center;transition:color .22s ease}.ships-remaining-title{margin:0 0 .45rem;font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}.ships-remaining-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.35rem}.ships-remaining-item{display:grid;grid-template-columns:14px 28px 1fr auto;align-items:center;gap:.4rem;font-size:1rem;color:var(--text-primary)}.ships-remaining-swatch{width:12px;height:12px;border-radius:3px;border:1px solid rgba(255,255,255,.24)}.ships-remaining-label{font-weight:700;color:var(--gold)}.ships-remaining-name{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ships-remaining-length{color:var(--text-primary);font-size:1rem;font-weight:700;letter-spacing:.04em;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:.12rem .35rem;background:#ffffff12}.battle-board-wrap.is-active{opacity:1}.battle-board-wrap.is-active .battle-board-title{color:var(--gold)}.battle-board-wrap.is-active .board-center-column:after{opacity:1;background:linear-gradient(90deg,#ffb70340,#ffb703e6,#ffb70340)}.battle-board-wrap.is-inactive{opacity:.85}.battle-board-wrap.is-inactive .battle-board-title{color:var(--text-secondary)}.battle-actions{margin-top:1.2rem;display:flex;justify-content:center;align-items:center;gap:.75rem;width:100%;margin-left:auto;margin-right:auto}.battle-actions .battle-new-button,.battle-actions .battle-quit-button{border:2px solid transparent;font-size:1.4rem;font-weight:700;padding:1.05rem 2.2rem;width:230px;min-width:230px;border-radius:var(--border-radius);cursor:pointer;transition:border-color .4s ease,background-color .3s ease;outline:none;margin-top:1rem}.battle-actions .battle-new-button{background-color:var(--radar-green);color:var(--navy-dark)}.battle-actions .battle-new-button:hover{border-color:var(--gold)}.battle-actions .battle-new-button:focus{border-color:var(--radar-green);outline:none}.battle-actions .battle-new-button:active{border-color:var(--gold)!important}.battle-quit-button{color:#fff5f5;background-color:#e63946}.battle-quit-button:hover{border-color:var(--gold)}.battle-quit-button:focus{border-color:#e63946;outline:none}.battle-quit-button:active{border-color:var(--gold)!important}.leaderboard{width:calc(100% - 4vw);margin:0 auto;box-sizing:border-box;background:#ffffff1a;border:1px solid var(--steel-blue);border-radius:var(--border-radius);padding:clamp(.8rem,1.6vw,1.2rem);overflow-x:auto}.leaderboard-title{margin:0 0 1rem;font-size:1.3rem;color:var(--text-primary)}.leaderboard-status{margin:0 0 .85rem;padding:.6rem .75rem;border-radius:6px;border:1px solid transparent;font-size:1rem}.leaderboard-status-warning{color:#8a6d00;background:#ffc10724;border-color:#ffc10773}.leaderboard-status-error{color:#a71d2a;background:#dc354526;border-color:#dc354573}.leaderboard-status-info{color:var(--text-primary);background:#4682b41f;border-color:#4682b466}.leaderboard-empty{color:var(--text-secondary);margin:0}.leaderboard-controls{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin:0 0 .85rem}.leaderboard-filter-toggle{padding:.42rem .78rem;border-radius:999px;border:1px solid rgba(255,183,3,.45);background:#ffb70324;color:var(--gold);font-size:.92rem;font-weight:800;letter-spacing:.03em;cursor:pointer}.leaderboard-filter-toggle.is-active{background:#ffb7033d;border-color:#ffb703bf}.leaderboard-quick-group{display:inline-flex;align-items:center;gap:.42rem;flex-wrap:wrap}.leaderboard-quick-label{color:var(--text-secondary);font-size:.9rem;font-weight:700;margin-right:.1rem}.leaderboard-quick-button{padding:.34rem .64rem;border-radius:999px;border:1px solid rgba(255,255,255,.26);background:#0a16288f;color:var(--text-primary);font-size:.86rem;font-weight:700;text-transform:capitalize;cursor:pointer;transition:border-color .2s ease,background-color .2s ease}.leaderboard-quick-button:hover{border-color:var(--gold)}.leaderboard-quick-button.is-active{background:#ffb70338;border-color:#ffb703bf;color:#ffe9b8}.leaderboard-control{display:inline-flex;align-items:center;gap:.45rem}.leaderboard-control label{font-size:1rem;color:var(--text-secondary);white-space:nowrap}.leaderboard-control select{min-width:150px;font-size:1rem;padding:.3rem .45rem;border-radius:6px;border:1px solid rgba(255,255,255,.24);background:#0a16288c;color:var(--text-primary)}.leaderboard-control select:focus{outline:none;border-color:var(--gold)}.leaderboard-table{width:100%;min-width:860px;border-collapse:collapse;font-size:1rem}.leaderboard-table thead{background:#0000001a;border-bottom:2px solid var(--steel-blue)}.leaderboard-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text-primary);white-space:nowrap}.leaderboard-table tbody tr{border-bottom:1px solid rgba(0,0,0,.1);transition:background-color .2s ease}.leaderboard-table tbody tr:hover{background-color:#0000000d}.leaderboard-table td{padding:.65rem .75rem;color:var(--text-primary)}.col-rank{width:50px;font-weight:700;color:var(--gold);text-align:left}.col-rank.rank-gold{color:gold;font-size:1.05rem}.col-rank.rank-silver{color:silver}.col-rank.rank-bronze{color:#cd7f32}.col-player{min-width:120px;font-weight:500;text-align:left}.col-result{width:80px;font-weight:600;text-align:left}.col-result.victory{color:var(--radar-green)}.col-result.defeat{color:var(--danger-red)}.col-difficulty{width:90px;text-align:left}.col-grid{width:70px;text-align:left;color:var(--text-secondary)}.col-score{width:70px;text-align:left;font-weight:600;color:var(--gold)}.col-stats{width:70px;text-align:left;color:var(--text-secondary)}.col-date{min-width:160px;color:var(--text-secondary);font-size:1rem;text-align:left}.col-action{width:50px;text-align:center}.delete-button{background:none;border:none;color:var(--danger-red);cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.delete-button:hover{background-color:#dc354533;color:#ff6b7b}@media(max-width:768px){.game-screen{width:100%;padding:.8rem .25rem 1rem}.back-to-menu-button{position:static;margin:0 0 .8rem;width:100%;justify-content:center}.battle-boards,.battle-boards.has-middle-column,.battle-boards.is-compact{grid-template-columns:1fr}.battle-middle-column{width:min(100%,560px);margin:0 auto}.battle-boards.has-summary{grid-template-columns:1fr}.battle-board-content{display:block}.leaderboard{width:100%}.leaderboard-table{font-size:1rem;min-width:700px}.leaderboard-controls{gap:.5rem}.leaderboard-control{width:100%;justify-content:space-between}.leaderboard-control select{min-width:170px}.leaderboard-table th,.leaderboard-table td{padding:.5rem}.col-date{min-width:120px}.col-player{min-width:100px}}@media(max-width:1180px){.ships-remaining-panel{display:none}}@media(max-height:980px)and (min-width:900px){.game-screen{padding:clamp(.45rem,.9vw,.9rem) clamp(.55rem,1.2vw,1.3rem) clamp(.6rem,1.2vw,1.05rem)}.game-screen.is-setup{padding-top:clamp(.25rem,.55vw,.55rem)}.setup-header{margin-bottom:.3rem}.setup-header h2{font-size:clamp(1.85rem,2.4vw,2.35rem);margin-bottom:.2rem;line-height:1}.setup-header p{font-size:clamp(.95rem,.95vw,1.08rem);margin-bottom:.2rem;line-height:1.25}.setup-options{margin-bottom:.4rem;gap:.5rem}.back-to-menu-button{padding:.54rem .88rem;font-size:.95rem}}.board-cell.targetable{cursor:crosshair;box-shadow:inset 0 0 0 1px #fff3}.board-cell.targetable:hover{background-color:var(--water-hover);box-shadow:inset 0 0 0 2px var(--gold)}@media(max-width:768px){.battle-boards{gap:1rem}.leaderboard-item{grid-template-columns:44px 1fr}.leaderboard-meta{grid-column:1 / -1;justify-content:flex-start}}@media(min-width:1200px)and (max-width:1700px){.battle-boards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:2100px){.game-screen{width:min(100%,2000px)}.battle-boards{width:min(100%,1750px)}}
