*{box-sizing:border-box;margin:0;padding:0}:root{--navy: #0a1628;--dark-blue: #0d2137;--mid-blue: #1a3a5c;--accent: #00c6ff;--accent2: #0072ff;--gold: #ffd700;--danger: #ff4757;--success: #2ed573;--miss: #546e7a;--text: #e8f4f8;--text-muted: #8fa8c8;--border: #1e4976}body{background:var(--navy);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;min-height:100vh}.page{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1200px;margin:0 auto;padding:0 1rem;width:100%}.navbar{background:var(--dark-blue);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.navbar-brand{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none;letter-spacing:1px}.navbar-nav{display:flex;align-items:center;gap:1rem;list-style:none}.nav-link{color:var(--text-muted);text-decoration:none;padding:.4rem .8rem;border-radius:6px;transition:all .2s;font-weight:500}.nav-link:hover,.nav-link.active{color:var(--accent);background:#00c6ff14}.nav-user{color:var(--text-muted);font-size:.9rem}.nav-user span{color:var(--accent);font-weight:600}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#0d2137,#0a1628 70%)}.auth-card{background:var(--dark-blue);border:1px solid var(--border);border-radius:16px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 60px #00000080}.auth-title{text-align:center;margin-bottom:2rem}.auth-title h1{font-size:2rem;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.25rem}.auth-title p{color:var(--text-muted);font-size:.95rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;margin-bottom:.4rem;color:var(--text-muted);font-size:.875rem;font-weight:500}.form-input{width:100%;padding:.75rem 1rem;background:var(--navy);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00c6ff26}.form-error{color:var(--danger);font-size:.8rem;margin-top:.3rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent2),var(--accent));color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #0072ff66}.btn-secondary{background:var(--mid-blue);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:var(--navy)}.btn-gold{background:var(--gold);color:var(--navy)}.btn-sm{padding:.4rem .9rem;font-size:.85rem}.btn-lg{padding:1rem 2rem;font-size:1.1rem}.btn-full{width:100%}.card{background:var(--dark-blue);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.card-title{font-size:1.1rem;font-weight:700;margin-bottom:1rem;color:var(--accent)}.lobby-header{padding:2rem 0 1rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.lobby-header h1{font-size:1.8rem;font-weight:800}.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding-bottom:2rem}@media (max-width: 768px){.lobby-grid{grid-template-columns:1fr}}.game-list{display:flex;flex-direction:column;gap:.75rem}.game-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--navy);border:1px solid var(--border);border-radius:10px;transition:border-color .2s;gap:1rem}.game-item:hover{border-color:var(--accent)}.game-item-info{flex:1}.game-item-info strong{display:block;color:var(--text);margin-bottom:.2rem}.game-item-info span{font-size:.8rem;color:var(--text-muted)}.badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.badge-easy{background:#2ed57333;color:var(--success)}.badge-medium{background:#ffd70033;color:var(--gold)}.badge-hard{background:#ff475733;color:var(--danger)}.game-page{padding:1rem 0 2rem}.game-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.game-status-bar{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:var(--dark-blue);border:1px solid var(--border);border-radius:10px;font-size:.95rem}.turn-indicator{font-weight:700;color:var(--accent)}.turn-indicator.your-turn{color:var(--success)}.turn-indicator.enemy-turn{color:var(--danger)}.boards-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}@media (max-width: 900px){.boards-container{grid-template-columns:1fr}}.board-section{display:flex;flex-direction:column;align-items:center;gap:.75rem}.board-label{font-size:1rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.game-board{display:inline-block;border:2px solid var(--border);border-radius:8px;overflow:hidden;background:#061525}.board-row{display:flex}.board-cell{width:38px;height:38px;border:1px solid rgba(30,73,118,.5);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:background .15s;cursor:default;position:relative}.board-cell.water{background:#061525}.board-cell.ship{background:#1a3a5c}.board-cell.hit{background:#ff475766}.board-cell.miss{background:#546e7a4d}.board-cell.sunk{background:#ff4757b3}.board-cell.clickable{cursor:crosshair}.board-cell.clickable:hover{background:#00c6ff33}.board-cell.clickable.hit,.board-cell.clickable.miss{cursor:not-allowed}.board-cell .cell-icon{font-size:1rem;line-height:1}.board-wrapper{display:flex;flex-direction:column;align-items:flex-start;gap:0}.board-col-labels{display:flex;margin-left:22px}.board-col-label{width:38px;text-align:center;font-size:.65rem;color:var(--text-muted);font-weight:600}.board-with-row-labels{display:flex}.board-row-labels{display:flex;flex-direction:column}.board-row-label{width:22px;height:38px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--text-muted);font-weight:600}.placement-area{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:start}@media (max-width: 800px){.placement-area{grid-template-columns:1fr}}.ships-panel{min-width:180px}.ships-panel h3{font-size:.9rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem}.ship-option{display:flex;align-items:center;gap:.75rem;padding:.6rem .8rem;border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;cursor:pointer;transition:all .15s;background:var(--navy)}.ship-option:hover:not(.placed):not(.disabled){border-color:var(--accent);background:#00c6ff0d}.ship-option.selected{border-color:var(--accent);background:#00c6ff1a}.ship-option.placed{opacity:.4;cursor:default}.ship-visual{display:flex;gap:2px}.ship-cell-vis{width:14px;height:14px;background:var(--mid-blue);border:1px solid var(--accent);border-radius:2px}.ship-option.selected .ship-cell-vis{background:var(--accent)}.ship-name{font-size:.8rem;color:var(--text-muted)}.placement-controls{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.leaderboard-page{padding:2rem 0}.leaderboard-page h1{font-size:2rem;font-weight:800;margin-bottom:1.5rem}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-table th{text-align:left;padding:.75rem 1rem;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.leaderboard-table td{padding:.9rem 1rem;border-bottom:1px solid rgba(30,73,118,.3);color:var(--text)}.leaderboard-table tr:hover td{background:#00c6ff08}.rank-1 td{color:var(--gold)}.rank-2 td{color:silver}.rank-3 td{color:#cd7f32}.rank-medal{font-size:1.1rem}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.alert-error{background:#ff475726;border:1px solid rgba(255,71,87,.3);color:#ff6b7a}.alert-success{background:#2ed57326;border:1px solid rgba(46,213,115,.3);color:var(--success)}.alert-info{background:#00c6ff1a;border:1px solid rgba(0,198,255,.2);color:var(--accent)}.ships-tracker{display:flex;flex-wrap:wrap;gap:.4rem}.ship-tracker-item{display:flex;gap:2px}.ship-tracker-cell{width:12px;height:20px;border-radius:2px;background:var(--mid-blue);border:1px solid var(--border)}.ship-tracker-cell.sunk{background:var(--danger);border-color:var(--danger)}.ship-tracker-cell.hit{background:#ff475780}.game-result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.game-result-card{background:var(--dark-blue);border:2px solid var(--border);border-radius:20px;padding:3rem;text-align:center;max-width:400px;width:90%;animation:pop-in .3s ease}@keyframes pop-in{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.result-icon{font-size:4rem;margin-bottom:1rem}.result-title{font-size:2rem;font-weight:800;margin-bottom:.5rem}.result-win{color:var(--success)}.result-lose{color:var(--danger)}.spinner{display:flex;align-items:center;justify-content:center;padding:3rem}.spinner-ring{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}a.link{color:var(--accent);text-decoration:none}a.link:hover{text-decoration:underline}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.flex{display:flex}.gap-1{gap:.5rem}.gap-2{gap:1rem}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}
