.player-board{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;min-width:0;overflow-x:visible;overflow-y:visible}.remote-board.player-board{padding:5px}.player-board-header{margin-bottom:15px}.player-board-header h4{margin-bottom:10px;color:#333}.ready-badge{display:inline-block;padding:4px 8px;background-color:#4caf50;color:#fff;border-radius:4px;font-size:12px;font-weight:600;margin-left:10px}.board-with-controls{display:flex;gap:20px;align-items:flex-start}.ship-placement-controls{display:flex;flex-direction:column;gap:10px;flex-shrink:0;min-width:180px}.ship-legend{flex-shrink:0;min-width:180px;padding:15px;background-color:#f9f9f9;border-radius:8px;border:1px solid #ddd}.ship-legend h5{margin:0 0 12px;color:#333;font-size:14px;font-weight:600}.legend-items{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:10px;font-size:13px}.legend-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.legend-text{color:#333;font-weight:500}.btn-orientation{padding:8px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:18px;width:100%}.btn-orientation:hover{background-color:#0b7dda}.ship-buttons{display:flex;flex-direction:column;gap:8px;width:100%}.btn-ship{padding:10px;background-color:#f5f5f5;border:2px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s;text-align:left;width:100%}.btn-ship:hover:not(:disabled){background-color:#e0e0e0}.btn-ship.active{background-color:#2196f3;color:#fff;border-color:#2196f3}.btn-ship.placed{background-color:#4caf50;color:#fff;border-color:#4caf50;cursor:not-allowed}.btn-ship:disabled{opacity:.6;cursor:not-allowed}.btn-ready{padding:10px 20px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600}.btn-ready:hover{background-color:#45a049}.board-grid{display:inline-block;border:1px solid #ccc;margin-bottom:15px;box-sizing:border-box;width:fit-content;max-width:100%;margin-left:auto;margin-right:auto}.board-row{display:flex;margin:0;padding:0;gap:0}.board-corner{width:30px;height:30px;flex-shrink:0;flex-basis:30px;min-width:30px;min-height:30px;max-width:30px;max-height:30px;background-color:#f0f0f0;border-right:1px solid #ccc;border-bottom:1px solid #ccc;box-sizing:border-box;margin:0;padding:0}.board-label{width:30px;height:30px;flex-shrink:0;flex-basis:30px;min-width:30px;min-height:30px;max-width:30px;max-height:30px;display:flex;align-items:center;justify-content:center;background-color:#f0f0f0;border-right:1px solid #ccc;border-bottom:1px solid #ccc;font-weight:600;font-size:12px;box-sizing:border-box;margin:0;padding:0}.cell{width:30px;height:30px;flex-shrink:0;flex-basis:30px;min-width:30px;min-height:30px;max-width:30px;max-height:30px;border-right:1px solid #ccc;border-bottom:1px solid #ccc;display:flex;align-items:center;justify-content:center;cursor:pointer;background-color:#e3f2fd;transition:background-color .2s;box-sizing:border-box;position:relative;overflow:hidden;margin:0;padding:0}.cell:hover{background-color:#bbdefb}.cell-ship{background-color:#90caf9}.cell-ship-hit,.cell-hit{background-color:#f44336;color:#fff}.cell-sunk-ship{background-color:#d32f2f;border:2px solid #b71c1c;box-shadow:inset 0 0 0 1px #ffffff4d}.cell-miss{background-color:#e0e0e0}.cell-preview{background-color:#fff59d}.cell-preview-invalid{background-color:#ffcdd2}.shots-list{margin-top:15px;padding:10px;background-color:#f9f9f9;border-radius:4px;border:1px solid #ddd;max-height:150px;overflow-y:auto}.shots-list h5{margin-bottom:8px;font-size:14px;color:#666}.shots-list-content{display:flex;flex-direction:column;gap:4px}.shot-item{font-size:12px;padding:4px;background:#fff;border-radius:2px;color:#333}.chat{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:100%;min-height:0;max-height:100%;overflow:hidden;box-sizing:border-box}.chat h3{margin-bottom:15px;color:#333;flex-shrink:0}.chat-messages{flex:1 1 0;overflow-y:auto;overflow-x:hidden;margin-bottom:15px;padding:10px;background:#f9f9f9;border-radius:4px;border:1px solid #ddd;min-height:0;box-sizing:border-box}.chat-empty{text-align:center;color:#999;padding:20px}.chat-message{display:flex;gap:8px;margin-bottom:8px;padding:8px;background:#fff;border-radius:4px;font-size:14px}.chat-author{font-weight:600;color:#2196f3}.chat-text{flex:1;color:#333}.chat-time{color:#999;font-size:12px}.chat-input-form{display:flex;gap:10px;flex-shrink:0}.chat-input{flex:1;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.chat-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.chat-send-btn{padding:10px 20px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600}.chat-send-btn:hover:not(:disabled){background-color:#0b7dda}.chat-send-btn:disabled{background-color:#ccc;cursor:not-allowed}.game-board-container{display:flex;flex-direction:column;gap:20px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.player-boards-section{display:flex;flex-direction:column;gap:20px}.player-boards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:20px;max-width:100%;overflow:visible}@media (min-width: 1200px){.player-boards-row{grid-template-columns:repeat(4,1fr)}}.player-board-wrapper{min-width:0}.own-player-row{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:20px;margin-bottom:20px;align-items:stretch;min-height:0}.player-board-wrapper{min-width:0;display:flex;flex-direction:column;overflow:visible}.own-player-row .player-board-wrapper{height:100%;min-height:0;max-height:100%}.own-player-row .player-board-wrapper .player-board{height:100%;min-height:0;max-height:100%;overflow:auto}.chat-wrapper{min-width:0;display:flex;flex-direction:column;height:100%;min-height:0;max-height:100%;overflow:hidden}@media (max-width: 1200px){.own-player-row{grid-template-columns:1fr;grid-template-rows:auto auto}.own-player-row .chat-wrapper{grid-row:1;height:auto;min-height:300px;max-height:400px}.own-player-row .player-board-wrapper{grid-row:2}.player-boards-row{grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}}@media (max-width: 900px){.player-boards-row{grid-template-columns:1fr}.own-player-row .chat-wrapper{min-height:250px;max-height:350px}}.connection-details{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.connection-details h3{margin-bottom:15px;color:#333}.connection-info{margin-bottom:15px}.info-row{display:flex;justify-content:space-between;margin-bottom:8px;padding:8px;background:#f9f9f9;border-radius:4px}.label{font-weight:600;color:#666}.value{color:#333}.value.connected{color:#4caf50;font-weight:600}.value.disconnected{color:#f44336;font-weight:600}.connection-actions{display:flex;flex-direction:column;gap:10px}.name-input,.game-id-input{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.button-group{display:flex;gap:10px}.btn-primary{padding:10px 20px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;flex:1}.btn-primary:hover:not(:disabled){background-color:#0b7dda}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.join-section{display:flex;flex-direction:column;gap:10px;margin-top:10px;padding-top:15px;border-top:1px solid #e0e0e0}.join-divider{text-align:center;color:#999;font-size:12px;font-weight:600;text-transform:uppercase;margin:5px 0}.info-message{padding:10px;background-color:#e3f2fd;border-radius:4px;color:#1976d2;font-size:14px}.game-mode-selection{margin:15px 0;padding:15px;background-color:#f9f9f9;border-radius:4px;border:1px solid #ddd}.mode-label{display:block;font-weight:600;margin-bottom:10px;color:#333;font-size:14px}.mode-options{display:flex;flex-direction:column;gap:10px}.mode-option{display:flex;align-items:flex-start;gap:10px;padding:10px;background-color:#fff;border:2px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s}.mode-option:hover{border-color:#2196f3;background-color:#f0f8ff}.mode-option input[type=radio]{margin-top:2px;cursor:pointer;flex-shrink:0}.mode-option-content{display:flex;flex-direction:column;flex:1;gap:4px}.mode-option-title{font-size:14px;font-weight:500;color:#333;display:block}.mode-option input[type=radio]:checked~.mode-option-content .mode-option-title{font-weight:600;color:#2196f3}.mode-option-description{display:block;color:#666;font-size:12px;font-style:italic;line-height:1.4}.all-shots-list{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:100%;min-height:300px;max-height:100%;box-sizing:border-box;width:100%;position:relative;overflow:hidden;min-width:0}.all-shots-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:15px}.all-shots-header:hover{opacity:.8}.all-shots-header h3{margin:0;color:#333;flex-shrink:0}.collapse-toggle{background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s;flex-shrink:0}.collapse-toggle:hover{background-color:#f0f0f0}.drawer-toggle-button{position:fixed;left:0;top:50%;transform:translateY(-50%);background:#fff;border:none;border-radius:0 8px 8px 0;padding:12px 8px;box-shadow:2px 0 4px #0000001a;cursor:pointer;font-size:18px;color:#666;z-index:1001;transition:background-color .2s}.drawer-toggle-button:hover{background-color:#f0f0f0}.shots-list-content{flex:1 1 0;overflow-y:auto;overflow-x:hidden;padding:10px;background:#f9f9f9;border-radius:4px;border:1px solid #ddd;min-height:200px;box-sizing:border-box;transition:opacity .3s ease}.shots-empty{text-align:center;color:#999;padding:20px}.shot-item{display:flex;gap:10px;padding:8px;margin-bottom:4px;background:#fff;border-radius:4px;font-size:14px;align-items:center}.shot-player{font-weight:600;color:#2196f3}.shot-target{font-weight:600;color:#666}.shot-coords{font-family:monospace;background:#f0f0f0;padding:2px 6px;border-radius:3px;font-weight:600}.shot-result{padding:2px 8px;border-radius:3px;font-weight:600;font-size:12px}.shot-result.hit{background-color:#f44336;color:#fff}.shot-result.miss{background-color:#e0e0e0;color:#666}.shot-time{margin-left:auto;color:#999;font-size:12px}.app{min-height:100vh;padding:20px;max-width:100%;margin:0;display:flex;flex-direction:column}.game-layout{display:flex;flex-direction:column;flex:1;min-height:0;gap:0}.game-content-layout{display:grid;grid-template-columns:350px 1fr;gap:20px;flex:1;min-height:0;align-items:start;position:relative;transition:grid-template-columns .3s ease,gap .3s ease}.game-content-layout.drawer-collapsed{grid-template-columns:1fr;gap:0}.game-content-layout.drawer-collapsed .all-shots-sidebar{display:none}.game-content-layout.drawer-collapsed .game-board-main{width:100%;grid-column:1}.all-shots-sidebar{display:flex;flex-direction:column;min-height:300px;height:100%;box-sizing:border-box;width:100%;max-width:100%;transition:transform .3s ease,opacity .3s ease;overflow:hidden;position:relative;min-width:0;max-width:350px}.all-shots-sidebar.collapsed{display:none}.game-board-main{display:flex;flex-direction:column;min-height:0;overflow:hidden;width:100%;transition:width .3s ease}.game-banners-container{display:flex;flex-direction:column;gap:15px}@media (max-width: 1200px){.game-content-layout{grid-template-columns:300px 1fr}.game-content-layout.drawer-collapsed{grid-template-columns:1fr;gap:0}.game-content-layout.drawer-collapsed .game-board-main{grid-column:1;width:100%}}@media (max-width: 900px){.game-content-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.game-content-layout.drawer-collapsed{grid-template-columns:1fr;grid-template-rows:1fr}.all-shots-sidebar{max-height:400px;min-height:300px;height:auto}.game-content-layout.drawer-collapsed .all-shots-sidebar{display:none}.game-content-layout.drawer-collapsed .game-board-main{width:100%;grid-row:1}}.address-bar{display:flex;gap:10px;margin-bottom:20px;padding:10px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.address-input{flex:1;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.btn-connect,.btn-disconnect{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600}.btn-connect{background-color:#4caf50;color:#fff}.btn-connect:hover{background-color:#45a049}.btn-disconnect{background-color:#f44336;color:#fff}.btn-disconnect:hover{background-color:#da190b}.connection-panel{margin-bottom:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.connection-panel-toggle{width:100%;padding:12px 20px;background-color:#f5f5f5;border:none;border-bottom:1px solid #ddd;cursor:pointer;font-size:14px;font-weight:600;text-align:left;display:flex;align-items:center;gap:10px}.connection-panel-toggle:hover{background-color:#e0e0e0}.connection-panel-content{padding:20px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
