.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}}.game-entry{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.game-entry-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:40px;max-width:450px;width:100%}.game-entry-container h1{margin:0 0 10px;text-align:center;color:#333;font-size:2.5em}.game-entry-form{display:flex;flex-direction:column;gap:20px}.btn-join{padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:10px}.btn-join:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-join:disabled{opacity:.6;cursor:not-allowed}.admin-link{margin-top:25px;padding-top:25px;border-top:1px solid #eee;text-align:center}.btn-admin-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;text-decoration:underline;padding:5px}.btn-admin-link:hover{color:#764ba2}.admin-panel{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.admin-panel-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:40px;max-width:500px;width:100%}.admin-panel-container h1{margin:0 0 10px;text-align:center;color:#333;font-size:2.5em}.subtitle{text-align:center;color:#666;margin-bottom:30px;font-size:1.1em}.admin-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-input{padding:12px;border:2px solid #ddd;border-radius:6px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#667eea}.form-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.mode-options{display:flex;flex-direction:column;gap:12px}.mode-option{display:flex;align-items:flex-start;gap:12px;padding:12px;border:2px solid #ddd;border-radius:6px;cursor:pointer;transition:border-color .3s,background-color .3s}.mode-option:hover{border-color:#667eea;background-color:#f8f9ff}.mode-option input[type=radio]{margin-top:2px;cursor:pointer}.mode-option-content{flex:1;display:flex;flex-direction:column;gap:4px}.mode-option-title{font-weight:600;color:#333}.mode-option-description{color:#666;font-size:.9em}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;border:1px solid #fcc;font-size:14px;text-align:center}.button-group{display:flex;gap:12px;margin-top:10px}.btn-create{flex:1;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-create:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-create:disabled{opacity:.6;cursor:not-allowed}.btn-back{padding:14px 24px;background:#f5f5f5;color:#333;border:2px solid #ddd;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s}.btn-back:hover:not(:disabled){background-color:#e5e5e5}.btn-back:disabled{opacity:.6;cursor:not-allowed}.game-created{text-align:center}.success-message h2{color:#4caf50;margin-bottom:20px}.success-message p{color:#666;margin-bottom:15px}.game-id-display{display:flex;gap:10px;margin-bottom:25px}.game-id-input{flex:1;padding:14px;border:2px solid #4caf50;border-radius:6px;font-size:18px;font-weight:600;text-align:center;letter-spacing:2px;background-color:#f1f8f4;color:#2e7d32}.btn-copy{padding:14px 20px;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s}.btn-copy:hover{background-color:#45a049}.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}
