/* ════════════════════════════════════════════════════════
   board.css — сетки игровых полей 10×10
   Используется на экранах расстановки и игры (Этапы 2–3)
   ════════════════════════════════════════════════════════ */

.grid-scroll {
  overflow-x: auto;
}

.col-labels {
  display: flex;
  margin-left: 22px;
  gap: 1px;
  margin-bottom: 1px;
}

.col-lbl {
  width: 26px;
  text-align: center;
  font-size: 10px;
  color: #000;
  font-weight: 500;
  flex-shrink: 0;
}

.grid-row {
  display: flex;
  gap: 1px;
  align-items: center;
}

.row-lbl {
  width: 22px;
  font-size: 10px;
  color: #000;
  font-weight: 500;
  text-align: right;
  padding-right: 4px;
  flex-shrink: 0;
}

/* ── Базовая клетка ── */
.cell {
  width: 26px;
  height: 26px;
  border-radius: 3px;
  border: 1px solid #9eb6d5;
  background: #eef3f8;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: visible;
  transition: background .08s, border-color .08s;
}

/* ── Состояния: своё поле (расстановка и бой) ── */
.cell.ship        { background: #8db8e5; border-color: #85B7EB; cursor: pointer; }
.cell.ship-sel     { background: #185FA5; border-color: #0C447C; cursor: pointer; }
.cell.my-hit       { background: #B5D4F4; border-color: #85B7EB; }
.cell.my-miss      { background: #f0eee8; border-color: #d3d1c7; }
.cell.deadzone     { background: #e8e6e0; border-color: #ccc8bc; }

/* ── Состояния: поле атаки на противника ── */
.cell.en-water { background: #eef3f8; border-color: 9eb6d5; cursor: crosshair; }
.cell.en-water:hover { background: #e6f1fb; border-color: #85B7EB; }
.cell.en-hit   { background: #B5D4F4; border-color: #85B7EB; }
.cell.en-sunk  { background: #e24b4a; border-color: #a32d2d; }
.cell.en-miss  { background: #f0eee8; border-color: #d3d1c7; }

/* ── Превью при расстановке ── */
.cell.preview     { background: #c8eaaa; border-color: #7ab830; }
.cell.preview-bad { background: #ffc8c8; border-color: #e06060; }

/* ── Маркеры внутри клетки ── */
.dot-hit  { width: 10px; height: 10px; border-radius: 50%; background: #0C447C; flex-shrink: 0; }
.dot-miss { width: 6px;  height: 6px;  border-radius: 50%; background: #8a8a88; flex-shrink: 0; }
.dot-sunk { width: 10px; height: 10px; border-radius: 50%; background: #fff;    flex-shrink: 0; }

/* ════════════════════════════════════════════════════════
   Расстановка — прогресс, список кораблей, кнопки действий
   ════════════════════════════════════════════════════════ */

.prog-wrap { height: 4px; background: #e0e8f0; border-radius: 2px; overflow: hidden; }
.prog-bar  { height: 100%; background: #185FA5; border-radius: 2px; transition: width .3s; }

.ship-group-row { display: flex; align-items: center; gap: 10px; padding: 4px 0; }

.ship-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px; border-radius: 6px;
  border: 1.5px solid #c0ccd8; background: #f8fafc;
  cursor: pointer; font-size: 12px; font-weight: 600; color: #334455;
  user-select: none; transition: all .12s; white-space: nowrap;
}
.ship-btn:hover { border-color: #85B7EB; background: #e6f1fb; }
.ship-btn.sel {
  background: #cce0ff; border-color: #185FA5; color: #0C447C;
  box-shadow: 0 0 0 2px rgba(24,95,165,0.15);
}
.ship-btn.empty { opacity: .35; pointer-events: none; }

.ship-btn-cells { display: flex; gap: 2px; }
.ship-btn-cell { width: 11px; height: 11px; border-radius: 2px; background: #B5D4F4; border: 1px solid #85B7EB; }
.ship-btn.sel .ship-btn-cell { background: #185FA5; border-color: #0C447C; }

.ship-counter {
  width: 28px; height: 28px;
  border: 1.5px solid #c0ccd8; border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; color: #445566; background: #fff;
  flex-shrink: 0;
}
.ship-counter.zero { color: #ccd8e4; border-color: #dde4ec; }

.btn-act {
  font-size: 12px; font-weight: 600;
  border-color: #c0ccd8; color: #445566; background: #f8fafc;
}
.btn-act:hover { background: #e2eaf0; border-color: #aabbcc; color: #334455; }

/* ════════════════════════════════════════════════════════
   Флот противника — инфографика оставшихся кораблей по типам
   (только для поля врага; десктоп — колонка справа, мобиль —
   под сеткой поля врага). Аналог ship-btn/ship-btn-cell с расстановки.
   ════════════════════════════════════════════════════════ */

.fleet-row {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid #eef1f4;
}
.fleet-row:last-child { border-bottom: none; }

.fleet-cells { display: flex; gap: 2px; flex-shrink: 0; }
.fleet-cell {
  width: 11px; height: 11px; border-radius: 2px;
  background: #8db8e5; border: 1px solid #85B7EB;
}

.fleet-count {
  font-size: 12px; font-weight: 700; color: #000;
  margin-left: auto;
}

/* ════════════════════════════════════════════════════════
   Игровой экран — статистика, вкладки, журнал, анимации
   ════════════════════════════════════════════════════════ */

.stat-val { font-size: 15px; font-weight: 700; color: #334455; }
.stat-lbl { font-size: 10px; color: #000; text-transform: uppercase; letter-spacing: .5px; }

.field-tabs .nav-link {
  font-size: 12px; font-weight: 600; color: #000;
  border-radius: 6px; padding: 6px 16px; border: 1px solid transparent;
  background: #f8fafc; cursor: pointer;
}
.field-tabs .nav-link.active {
  background: #e6f1fb; color: #0C447C; border: 1px solid #85B7EB;
}

.log-item {
  font-size: 11px; padding: 2px 8px; border-radius: 12px;
  border: 1px solid #d0d8e0; white-space: nowrap;
}
.log-item.h { background: #fcebeb; border-color: #f09595; color: #791f1f; }
.log-item.m { background: #f0eee8; border-color: #d3d1c7; color: #000; }

/* ── Анимации выстрела ── */
@keyframes shellfall  { 0%{transform:translate(-50%,-200%) scale(.6);opacity:1} 80%{transform:translate(-50%,-50%) scale(1);opacity:1} 100%{transform:translate(-50%,-50%) scale(1);opacity:0} }
@keyframes explode    { 0%{transform:translate(-50%,-50%) scale(.2);opacity:1} 60%{transform:translate(-50%,-50%) scale(1.4);opacity:.8} 100%{transform:translate(-50%,-50%) scale(1.8);opacity:0} }
@keyframes splash     { 0%{transform:translate(-50%,-50%) scale(.1);opacity:1} 50%{transform:translate(-50%,-50%) scale(1.2);opacity:.6} 100%{transform:translate(-50%,-50%) scale(2);opacity:0} }
@keyframes ripple     { 0%{transform:translate(-50%,-50%) scale(0);opacity:.7} 100%{transform:translate(-50%,-50%) scale(4);opacity:0} }
@keyframes fadeup      { 0%{opacity:1;transform:translateX(-50%) translateY(0)} 100%{opacity:0;transform:translateX(-50%) translateY(-24px)} }
@keyframes shake      { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-3px)} 75%{transform:translateX(3px)} }
@keyframes bouncein   { 0%{transform:scale(0)} 60%{transform:scale(1.3)} 100%{transform:scale(1)} }

.anim-shell   { position:absolute; width:7px;  height:7px;  border-radius:50%; background:#633806; top:50%; left:50%; pointer-events:none; animation:shellfall .22s ease-out forwards; z-index:10; }
.anim-explode { position:absolute; width:22px; height:22px; border-radius:50%; background:rgba(226,75,74,.45); top:50%; left:50%; pointer-events:none; animation:explode .4s ease-out forwards; z-index:10; }
.anim-splash  { position:absolute; width:22px; height:22px; border-radius:50%; background:rgba(24,95,165,.18); border:1px solid rgba(24,95,165,.3); top:50%; left:50%; pointer-events:none; animation:splash .5s ease-out forwards; z-index:10; }
.anim-ripple  { position:absolute; width:18px; height:18px; border-radius:50%; background:transparent; border:1.5px solid rgba(24,95,165,.3); top:50%; left:50%; pointer-events:none; animation:ripple .5s ease-out forwards; z-index:10; }
.anim-label   { position:absolute; top:50%; left:50%; font-size:10px; font-weight:600; white-space:nowrap; pointer-events:none; animation:fadeup .7s ease-out .1s forwards; opacity:0; z-index:20; transform:translateX(-50%); }
.anim-label.hit  { color:#a32d2d; }
.anim-label.miss { color:#185FA5; }
.cell.shake   { animation: shake .3s ease; }
.dot-bounce   { animation: bouncein .3s ease .15s both; }
