
/* Ensure sidebar width matches other pages */
:root {
  --sidebar-w: 200px;
}

/* Page-specific play styles */

/* Right panel - no margin; adsense-rail sits immediately next to it in flex */
.right-panel {
  width: 340px;
  min-width: 280px;
  max-width: 380px;
  background: var(--bg-panel);
  border-left: 1px solid rgba(255,255,255,0.06);
  border-right: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 10;
  flex-shrink: 0;
}

/* ── AdSense Slot — coloană fixă 160px, imediat la dreapta panel-ului ── */
.adsense-rail {
  width: 160px;
  min-width: 160px;
  max-width: 160px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 12px 0;
  gap: 12px;
  background: var(--bg-app);
  border-left: none;
  overflow: hidden;
  flex-shrink: 0;
}

/* Placeholder vizual pentru AdSense (îl scoți când AdSense e activ) */
.adsense-placeholder {
  width: 160px;
  height: 600px;
  background: rgba(255,255,255,0.02);
  border: 1px dashed rgba(255,255,255,0.07);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: rgba(255,255,255,0.12);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-align: center;
  padding: 12px;
}
.adsense-placeholder i { font-size: 22px; opacity: 0.3; }
.adsense-placeholder--small {
  height: 300px;
}

/* Ascunde rail-ul pe mobile */
@media (max-width: 900px) {
  .adsense-rail { display: none; }
  .right-panel  { margin-right: 0; border-right: none; }
}

/* ══════════════════════════════════════════════════════════
   PLAYER STRIPS
══════════════════════════════════════════════════════════ */
.player-strip {
  width: 100%;
  max-width: var(--board);
  display: flex;
  align-items: center;
  padding: 6px 2px;
  gap: 10px;
  flex-shrink: 0;
}

.pav-wrapper { position: relative; flex-shrink: 0; }
.pav {
  width: 36px; height: 36px;
  border-radius: 6px;
  background: var(--bg-card);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; color: var(--text-3);
  overflow: hidden;
}
.pav img { width: 100%; height: 100%; object-fit: cover; }
.status-dot {
  position: absolute;
  bottom: -2px; right: -2px;
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--text-3);
  border: 2px solid var(--bg-app);
}
.status-dot.online { background: var(--success); }

.pinfo { flex: 1; min-width: 0; }
.pname-row { display: flex; align-items: center; gap: 8px; }
.pname { font-weight: 700; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.prating { font-size: 11px; color: var(--text-3); flex-shrink: 0; }
.pstatus {
    font-size: 10px;
    color: var(--danger);
    font-weight: 700;
    margin-top: 2px;
    display: none;
}

.pcap-container { display: flex; align-items: center; gap: 4px; margin-top: 2px; flex-wrap: wrap; }
.pcap { display: flex; flex-wrap: wrap; align-items: center; gap: 0; line-height: 1; }
.pcap-adv { font-size: 11px; font-weight: 700; color: var(--accent); margin-left: 2px; }

/* Piesele capturate*/
.cap-piece {
  font-size: 14px;
  line-height: 1;
  display: inline-block;
  margin-right: -3px; /* suprapunere */
  opacity: 0.85;
}

/* ── Clock ── */
.clock {
  background: var(--bg-card);
  padding: 5px 12px;
  border-radius: 5px;
  font-family: 'JetBrains Mono', 'Courier New', monospace;
  font-size: 22px;
  font-weight: 700;
  color: var(--text-3);
  min-width: 88px;
  text-align: center;
  border: 1px solid rgba(255,255,255,0.05);
  flex-shrink: 0;
  transition: all .3s ease;
}
.clock.active { background: #fff; color: #0e0e10; border-color: var(--accent); box-shadow: 0 0 12px rgba(195,160,94,0.3); }
.clock.low { color: var(--danger); border-color: var(--danger); animation: lpulse 1s infinite; }
@keyframes lpulse { 0%,100%{opacity:1} 50%{opacity:.6} }

/* ══════════════════════════════════════════════════════════
   BOARD WRAPPER
══════════════════════════════════════════════════════════ */
.board-wrap {
  display: flex;
  align-items: flex-start;
  gap: 0;
  position: relative;
  flex-shrink: 0;
}

.board-viewport { display: flex; flex-direction: column; }
.board-main-row { display: flex; align-items: stretch; }

.bwrap {
  position: relative;
  width: var(--board);
  height: var(--board);
  box-shadow: 0 12px 48px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04);
  border-radius: 3px;
  overflow: hidden;
}

#chessBoard {
  display: grid;
  grid-template-columns: repeat(8, var(--sq));
  grid-template-rows:    repeat(8, var(--sq));
  width: var(--board);
  height: var(--board);
}

#boardArrowSvg {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 20;
}

/* ── Squares ── */
.sq {
  position: relative;
  width: var(--sq); height: var(--sq);
  display: flex; align-items: center; justify-content: center;
  user-select: none; /* Prevent text selection during drag */
  -webkit-user-select: none;
  transition: background-color 0.12s ease, box-shadow 0.12s ease;
  will-change: background-color, box-shadow;
}
.sq.light { background: var(--light-sq); }
.sq.dark  { background: var(--dark-sq); }
.sq.lm    { background: var(--last-move) !important; box-shadow: inset 0 0 10px rgba(0,0,0,0.1); }
/* Selecție piesă — background colorat ca WorldChess, nu outline */
.sq.sel.light { background: rgb(255, 255, 51, 0.5) !important; }
.sq.sel.dark  { background: rgba(255, 255, 51, 0.5) !important; }
.sq.sel { box-shadow: inset 0 0 0 3px rgba(255,255,255,0.12); }
.sq.check { background: radial-gradient(circle, #ff5e5e 0%, #b33434 100%) !important; }

/* Legal move hints */
.sq.hint::after {
  content:''; position:absolute;
  width:28%; height:28%; border-radius:50%;
  background:rgba(0,0,0,0.18);
  pointer-events:none;
  transition: opacity 0.15s ease, transform 0.15s ease;
}
.sq.hint-cap::after {
  content:''; position:absolute; inset:0; border-radius:0;
  box-shadow:inset 0 0 0 5px rgba(0,0,0,0.15);
  pointer-events:none;
  transition: opacity 0.15s ease;
}

/* Drag-over highlight removed — now unused */

/* Board themes (8 themes from SettingsManager BOARD_COLORS) */
body.board-theme-arena-green { --light-sq:#dee3e6; --dark-sq:#8ca2ad; --last-move:rgba(155,199,0,.45); }
body.board-theme-classic     { --light-sq:#f0d9b5; --dark-sq:#b58863; --last-move:rgba(205,210,20,.75); }
body.board-theme-tournament  { --light-sq:#ffffdd; --dark-sq:#86a666; --last-move:rgba(155,199,0,.45); }
body.board-theme-midnight    { --light-sq:#2a3550; --dark-sq:#182238; --last-move:rgba(90,140,255,.40); }
body.board-theme-slate       { --light-sq:#d4dde8; --dark-sq:#607080; --last-move:rgba(96,125,139,.40); }
body.board-theme-dark-arena  { --light-sq:#4d4d4d; --dark-sq:#2a2a2a; --last-move:rgba(130,150,50,.60); }
body.board-theme-walnut      { --light-sq:#e8cfa0; --dark-sq:#8b5e3c; --last-move:rgba(130,150,50,.60); }
body.board-theme-ice         { --light-sq:#e8f4f8; --dark-sq:#6a9ab5; --last-move:rgba(14,165,233,.35); }

/* ── Pieces ── */
.piece {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  cursor:grab; z-index:5;
  background-size:contain; background-repeat:no-repeat; background-position:center;
  /* Fără tranziție — piesele apar instant pe noua poziție */
  transition: none;
  will-change: transform;
}
.piece img { width:100%; height:100%; pointer-events:none; display:block; color:transparent; }

/* Lifted state — piece scales up slightly with enhanced shadow */
.piece.is-lifted {
  transform: scale(1.08);
  filter: drop-shadow(0 12px 28px rgba(0,0,0,0.65));
  cursor: grabbing;
}

/* Dragging — hide original piece (ghost shown instead) */
.piece.is-dragging {
  opacity: 0 !important;
  transition: opacity 0.05s ease;
}

/* Ghost piece — follows cursor */
.piece-ghost {
  position: fixed; pointer-events: none; z-index: 9999;
  /* Folosim transform pentru poziționare — GPU compositing, zero reflow */
  /* left/top sunt fixe la 0,0 — poziția e dată de translate() */
  left: 0; top: 0;
  opacity: 0.92;
  filter: drop-shadow(0 10px 30px rgba(0,0,0,0.7)) drop-shadow(0 4px 8px rgba(0,0,0,0.4));
  /* ZERO tranziție pe poziție —  */
  transition: none;
  will-change: transform;
}

/* Smooth piece movement animation (used for move playback/replay) */
.piece-animate {
  position: fixed; pointer-events: none; z-index: 9998;
  transition: left 0.18s cubic-bezier(0.23, 0.92, 0.35, 0.98), top 0.18s cubic-bezier(0.23, 0.92, 0.35, 0.98);
  will-change: left, top;
}

/* Drag-over CSS removed — unused */

/* Coordinates */
.coords { display:flex; }
.coords.ranks { flex-direction:column; width:16px; flex-shrink:0; }
.coords.files { flex-direction:row; height:16px; margin-left:16px; width:var(--board); }
.coords div { flex:1; display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:700; color:var(--text-3); }

/* ── Eval bar ── */
.eval-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 18px;
  margin-right: 6px;
  height: var(--board);
  flex-shrink: 0;
}
.eval-bar {
  position: relative;
  width: 10px;
  height: 100%;
  background: #f0f0f0;
  border-radius: 3px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.4);
  box-shadow: inset -1px 0 3px rgba(0,0,0,0.1), 0 4px 10px rgba(0,0,0,0.25);
}
.eval-black {
  position: absolute;
  top: 0; left: 0; width: 100%;
  background: linear-gradient(to bottom, #1a1a1a, #333);
  transition: height .7s cubic-bezier(0.23,1,0.32,1);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.eval-bar::after { content:''; position:absolute; top:50%; left:0; width:100%; height:1px; background:rgba(100,100,100,0.4); z-index:2; }
.eval-score { font-size:9px; font-weight:800; color:var(--text-2); margin-top:4px; text-align:center; }

/* ── Resize handle ── */
.resize-handle {
  position: absolute; bottom: 2px; right: 2px;
  width: 14px; height: 14px;
  background: linear-gradient(135deg, transparent 50%, var(--accent) 50%);
  border-radius: 0 0 3px 0;
  cursor: se-resize; opacity: 0.35; z-index: 100; transition: opacity .2s;
}
.resize-handle:hover { opacity: 1; }

/* ══════════════════════════════════════════════════════════
   RIGHT PANEL INTERNALS
══════════════════════════════════════════════════════════ */
.status-bar {
  padding: 8px 12px;
  font-size: 10px; font-weight: 800;
  text-align: center;
  color: var(--text-3);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  background: rgba(0,0,0,0.2);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  flex-shrink: 0;
}
.status-bar.ok { color: var(--accent); }

.result-banner {
  margin: 12px;
  padding: 16px;
  background: linear-gradient(145deg, var(--bg-card), #161618);
  border: 1px solid rgba(195,160,94,0.25);
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.4);
  flex-shrink: 0;
}
.result-title { font-size: 16px; font-weight: 800; color: var(--accent); text-transform: uppercase; }
.result-sub   { font-size: 12px; color: var(--text-3); margin-top: 4px; }

.panel-play {
  flex: 1; display: flex; flex-direction: column;
  padding: 14px; gap: 10px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--accent) transparent;
}
.panel-play::-webkit-scrollbar { width: 4px; }
.panel-play::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 4px; }

.panel-title {
  font-size: 10px; font-weight: 800; color: var(--accent);
  text-transform: uppercase; letter-spacing: 1px;
  margin-bottom: 2px;
  border-left: 3px solid var(--accent);
  padding-left: 8px;
}

/* Time control select */
.tc-select {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  color: var(--text-1);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  outline: none;
}
.tc-select:focus { border-color: var(--accent); }

/* Panel buttons */
.pbtn {
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 11px 12px;
  border-radius: 6px; cursor: pointer;
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.03);
  color: var(--text-1);
  transition: all .2s;
}
.pbtn:hover { background: rgba(255,255,255,0.07); border-color: rgba(195,160,94,0.4); transform: translateY(-1px); }
.pbtn.go { background: var(--accent); border: none; color: #000; box-shadow: 0 4px 16px rgba(195,160,94,0.25); }
.pbtn.go:hover { background: #d4b47a; transform: translateY(-2px); }
.pbtn-ico { font-size: 18px; width: 24px; flex-shrink: 0; }
.pbtn-lbl { font-size: 13px; font-weight: 700; }
.pbtn-sub { font-size: 11px; color: var(--text-3); margin-top: 1px; }
.pbtn.go .pbtn-sub { color: rgba(0,0,0,0.55); }
.pbtn.friend { border-color: rgba(76,175,125,0.3); }
.pbtn.friend:hover { border-color: var(--success); background: rgba(76,175,125,0.08); }
.pbtn.friend .pbtn-ico { color: var(--success); }

/* ── Friends Section ── */
.friends-section { display: flex; flex-direction: column; gap: 6px; }
.friends-search-wrap { display: flex; gap: 6px; }
.friends-search-input {
  flex: 1; padding: 8px 10px;
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  color: var(--text-1); font-size: 12px;
  outline: none; transition: border-color .2s;
}
.friends-search-input:focus { border-color: var(--accent); }
.friends-search-btn {
  padding: 8px 10px;
  background: var(--accent); border: none;
  border-radius: 6px; color: #000;
  font-size: 12px; font-weight: 700;
  cursor: pointer; white-space: nowrap;
  transition: background .2s;
}
.friends-search-btn:hover { background: #d4b47a; }
.friends-search-result {
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px; padding: 8px 10px;
  font-size: 12px; color: var(--text-2);
  display: none; align-items: center; gap: 8px;
}
.friends-search-result.visible { display: flex; }
.friends-result-name { flex: 1; font-weight: 700; color: var(--text-1); }
.friends-result-rating { color: var(--accent); font-size: 11px; }
.friends-add-btn {
  padding: 4px 10px; border-radius: 4px;
  background: rgba(76,175,125,0.15);
  border: 1px solid rgba(76,175,125,0.35);
  color: var(--success); font-size: 11px; font-weight: 700;
  cursor: pointer; transition: all .2s;
}
.friends-add-btn:hover { background: rgba(76,175,125,0.25); }
.friends-list { display: flex; flex-direction: column; gap: 4px; max-height: 180px; overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--accent) transparent; }
.friend-item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px;
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 6px; transition: border-color .2s;
}
.friend-item:hover { border-color: rgba(195,160,94,0.25); }
.friend-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--accent-dim);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; color: var(--accent);
  flex-shrink: 0;
}
.friend-info { flex: 1; min-width: 0; }
.friend-name { font-size: 12px; font-weight: 700; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.friend-status { font-size: 10px; color: var(--text-3); }
.friend-online-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); flex-shrink: 0; }
.friend-offline-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--text-3); flex-shrink: 0; }
.friend-challenge-btn {
  padding: 4px 9px; border-radius: 4px;
  background: rgba(195,160,94,0.12);
  border: 1px solid rgba(195,160,94,0.3);
  color: var(--accent); font-size: 10px; font-weight: 700;
  cursor: pointer; white-space: nowrap; transition: all .2s;
}
.friend-challenge-btn:hover { background: rgba(195,160,94,0.22); }
.friend-challenge-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.friend-remove-btn {
  padding: 4px 7px; border-radius: 4px;
  background: transparent;
  border: 1px solid rgba(224,82,82,0.2);
  color: var(--danger); font-size: 10px;
  cursor: pointer; transition: all .2s;
}
.friend-remove-btn:hover { background: rgba(224,82,82,0.1); }
.friends-empty { font-size: 12px; color: var(--text-3); text-align: center; padding: 12px 0; }
.friends-msg { font-size: 11px; padding: 4px 6px; border-radius: 4px; display: none; }
.friends-msg.ok  { background: rgba(76,175,125,0.12); color: var(--success); border: 1px solid rgba(76,175,125,0.2); display: block; }
.friends-msg.err { background: rgba(224,82,82,0.12);  color: var(--danger);  border: 1px solid rgba(224,82,82,0.2);  display: block; }

/* Challenge overlay extras */
.challenge-tc-row { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.chtc-btn {
  flex: 1; min-width: 60px; padding: 7px 4px;
  background: var(--bg-card); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 5px; color: var(--text-2); font-size: 11px; font-weight: 700;
  cursor: pointer; transition: all .2s; text-align: center;
}
.chtc-btn:hover, .chtc-btn.sel { background: var(--accent-dim); border-color: var(--accent); color: var(--accent); }

/* Theme swatches */
.theme-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; }
.tsw { padding: 5px; border-radius: 5px; background: #111; border: 2px solid transparent; cursor: pointer; transition: all .2s; }
.tsw.active { border-color: var(--accent); }
.tsw-p { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; border-radius: 2px; overflow: hidden; margin-bottom: 4px; }
.tsw-p span { display: block; height: 10px; }
.tsw-n { font-size: 9px; text-align: center; color: var(--text-3); font-weight: 700; }

/* Piece set select */
.piece-sel {
  width: 100%; padding: 9px 12px;
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  color: var(--text-1);
  font-size: 13px; cursor: pointer; outline: none;
}
.piece-sel:focus { border-color: var(--accent); }

/* Engine controls */
.eng-row { display: flex; flex-direction: column; gap: 4px; }
.eng-info { display: flex; justify-content: space-between; align-items: center; }
.eng-lbl { font-size: 12px; color: var(--text-2); }
.slider-v { font-size: 12px; font-weight: 700; color: var(--accent); }
.slider { -webkit-appearance:none; appearance:none; width:100%; height:4px; background:#2a2a2a; border-radius:2px; outline:none; }
.slider::-webkit-slider-thumb { -webkit-appearance:none; appearance:none; width:14px; height:14px; background:var(--accent); border-radius:50%; cursor:pointer; }

.tog-group { display: flex; flex-direction: column; gap: 6px; }
.tog-row { display: flex; align-items: center; justify-content: space-between; }
.tog-lbl { font-size: 12px; color: var(--text-2); }
.tog-cb { width: 36px; height: 20px; cursor: pointer; accent-color: var(--accent); }

/* Move list */
.move-list {
  flex: 1; overflow-y: auto; padding: 6px;
  background: rgba(0,0,0,0.1);
  scrollbar-width: thin;
  scrollbar-color: rgba(195,160,94,0.3) transparent;
}
.move-list::-webkit-scrollbar { width: 3px; }
.move-list::-webkit-scrollbar-thumb { background: rgba(195,160,94,0.4); border-radius: 3px; }
.move-pair { display: grid; grid-template-columns: 32px 1fr 1fr; align-items: center; border-radius: 3px; margin-bottom: 1px; }
.move-pair:nth-child(odd) { background: rgba(255,255,255,0.02); }
.move-num { color: var(--text-3); font-size: 10px; font-weight: 700; text-align: center; }
.move-cell { padding: 5px 8px; border-radius: 3px; cursor: pointer; color: var(--text-2); font-size: 13px; font-weight: 600; }
.move-cell:hover { background: rgba(255,255,255,0.05); color: var(--text-1); }
.move-cell.current { background: var(--accent) !important; color: #000 !important; box-shadow: 0 2px 8px rgba(195,160,94,0.3); }
.move-empty { padding: 16px; text-align: center; color: var(--text-3); font-size: 12px; }
.move-placeholder { padding: 20px; text-align: center; color: var(--text-3); font-size: 12px; display: flex; flex-direction: column; align-items: center; gap: 8px; }

/* Nav row */
.nav-row {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 12px;
  background: rgba(0,0,0,0.2);
  border-top: 1px solid rgba(255,255,255,0.04);
  flex-shrink: 0;
}
.nav-btn-group { display: flex; gap: 4px; flex: 1; }
.nbtn {
  flex: 1; height: 34px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 5px;
  color: var(--text-2); font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .15s;
}
.nbtn:hover { background: var(--accent); color: #000; border-color: var(--accent); }
.flip-btn { padding: 0 12px; height: 34px; display: flex; align-items: center; gap: 6px; font-size: 12px; }

/* Game controls */
.game-ctrl {
  padding: 10px 12px;
  background: rgba(0,0,0,0.15);
  border-top: 1px solid rgba(255,255,255,0.04);
  flex-shrink: 0;
}
.ctrl-row { display: flex; gap: 8px; margin-bottom: 6px; }
.ctrl-row:last-child { margin-bottom: 0; }
.cbtn {
  flex: 1; padding: 9px 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 5px;
  cursor: pointer; color: var(--text-2);
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
  transition: all .2s;
}
.cbtn:hover { background: rgba(255,255,255,0.08); color: var(--text-1); transform: translateY(-1px); }
.cbtn.danger { color: #ff6b6b; border-color: rgba(255,107,107,0.2); }
.cbtn.danger:hover { background: rgba(255,107,107,0.1); border-color: #ff6b6b; }
.cbtn.primary { background: var(--accent); border: none; color: #000; }
.cbtn.primary:hover { background: #d4b47a; box-shadow: 0 4px 12px rgba(195,160,94,0.3); }
.secondary-action { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06); color: var(--text-2); padding: 9px; border-radius: 5px; font-size: 11px; font-weight: 700; cursor: pointer; flex: 1; }
.secondary-action:hover { background: rgba(255,255,255,0.08); }

/* old chat styles — replaced above */

/* ══════════════════════════════════════════════════════════
    CHAT — NEW SYSTEM
   ══════════════════════════════════════════════════════════ */

/* Chat wrap */
.chat-wrap {
   display: flex;
   flex-direction: column;
   flex: 0 0 auto;
   min-height: 0;
   height: auto;
   max-height: 580px;
   overflow-y: auto;
   background: var(--bg-panel);
}

/* Chat header */
.chat-header {
   display: flex;
   align-items: center;
   justify-content: space-between;
   padding: 8px 10px;
   background: rgba(0,0,0,0.2);
   border-bottom: 1px solid rgba(255,255,255,0.05);
   flex-shrink: 0;
}

.chat-header .chat-status {
   display: flex;
   align-items: center;
   gap: 6px;
   font-size: 12px;
   font-weight: 700;
   color: var(--text-2);
   text-transform: uppercase;
   letter-spacing: .8px;
}

.chat-online-dot {
   width: 7px; height: 7px;
   border-radius: 50%;
   background: var(--success);
   flex-shrink: 0;
   animation: chatPulse 2s infinite;
}
@keyframes chatPulse {
   0%,100% { opacity: 1; }
   50% { opacity: .5; }
}

/* Chat controls (mute + emote) */
.chat-controls {
   display: flex;
   align-items: center;
   gap: 4px;
}

/* Mute button */
.chat-mute-btn {
   display: inline-flex;
   align-items: center;
   gap: 4px;
   padding: 4px 8px;
   border-radius: 5px;
   background: rgba(255,255,255,0.05);
   border: 1px solid rgba(255,255,255,0.08);
   color: var(--text-3);
   font-size: 10px;
   font-weight: 600;
   cursor: pointer;
   transition: all .2s;
   white-space: nowrap;
}
.chat-mute-btn:hover {
   background: rgba(255,255,255,0.08);
   color: var(--text-2);
   border-color: rgba(195,160,94,0.3);
}
.chat-mute-btn.muted {
   color: var(--danger);
   border-color: rgba(224,82,82,0.3);
   background: rgba(224,82,82,0.08);
}

/* Emote trigger in header */
.emote-trigger-wrap {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   width: 28px; height: 28px;
   border-radius: 6px;
   background: rgba(255,255,255,0.04);
   border: 1px solid rgba(255,255,255,0.06);
   color: var(--text-3);
   font-size: 14px;
   cursor: pointer;
   transition: all .15s;
}
.emote-trigger-wrap:hover {
   background: rgba(255,255,255,0.08);
   color: var(--accent);
}

/* Quick Chat row (sablon) */
.quick-chat-row {
   display: flex;
   gap: 4px;
   padding: 6px 10px;
   background: rgba(0,0,0,0.12);
   border-bottom: 1px solid rgba(255,255,255,0.03);
   flex-wrap: wrap;
   flex-shrink: 0;
}
.quick-chat-btn {
   flex: 1;
   min-width: 70px;
   padding: 5px 6px;
   border-radius: 4px;
   background: var(--bg-card);
   border: 1px solid rgba(255,255,255,0.06);
   color: var(--text-2);
   font-size: 10px;
   font-weight: 600;
   cursor: pointer;
   transition: all .15s;
   white-space: nowrap;
}
.quick-chat-btn:hover {
   background: var(--accent);
   color: #000;
   border-color: var(--accent);
   transform: translateY(-1px);
}

/* Emote picker */
.emote-picker {
   display: none;
   padding: 6px 10px;
   gap: 4px;
   background: rgba(0,0,0,0.15);
   border-bottom: 1px solid rgba(255,255,255,0.04);
   flex-shrink: 0;
   flex-wrap: wrap;
}
.emote-picker.open { display: flex; }
.emote-picker span {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   width: 30px; height: 30px;
   border-radius: 6px;
   background: var(--bg-card);
   border: 1px solid rgba(255,255,255,0.06);
   font-size: 16px;
   cursor: pointer;
   transition: all .12s;
   user-select: none;
}
.emote-picker span:hover {
   background: var(--accent);
   border-color: var(--accent);
   transform: scale(1.15);
}

/* Chat messages area */
.chat-msgs {
   flex: 1;
   overflow-y: auto;
   padding: 8px 10px;
   min-height: 280px;
   scrollbar-width: thin;
   scrollbar-color: rgba(195,160,94,0.3) transparent;
}
.chat-msgs::-webkit-scrollbar { width: 3px; }
.chat-msgs::-webkit-scrollbar-thumb { background: rgba(195,160,94,0.4); border-radius: 3px; }

/* Muted state */
.chat-msgs.muted { opacity: 0.4; }
.chat-msgs.muted .chat-msg:not(.system) { display: none; }
.chat-msgs.muted .chat-msg.system { opacity: 0.6; font-style: italic; }

/* Individual messages */
.chat-msg {
   margin-bottom: 4px;
   padding: 5px 8px;
   border-radius: 6px;
   font-size: 12px;
   line-height: 1.4;
   animation: msgIn .2s ease;
}
@keyframes msgIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
.chat-msg.system { color: var(--text-3); font-style: italic; }
.chat-msg.user-msg { color: var(--text-1); background: rgba(255,255,255,0.03); }
.chat-msg .chat-user { font-weight: 700; color: var(--accent); margin-right: 4px; }

/* Chat input row */
.chat-row {
   display: flex;
   align-items: center;
   gap: 4px;
   padding: 6px 10px 8px;
   background: rgba(0,0,0,0.2);
   border-top: 1px solid rgba(255,255,255,0.04);
   flex-shrink: 0;
}
.chat-row .emote-trigger {
   font-size: 20px;
   cursor: pointer;
   color: var(--text-3);
   transition: color .15s;
   flex-shrink: 0;
}
.chat-row .emote-trigger:hover { color: var(--accent); }
.chat-in {
   flex: 1;
   padding: 8px 10px;
   background: var(--bg-card);
   border: 1px solid rgba(255,255,255,0.08);
   border-radius: 6px;
   color: var(--text-1);
   font-size: 13px;
   outline: none;
   transition: border-color .2s;
}
.chat-in:focus { border-color: var(--accent); }
.chat-send {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   width: 36px; height: 36px;
   border-radius: 6px;
   background: var(--accent);
   border: none;
   color: #000;
   font-size: 14px;
   cursor: pointer;
   transition: all .2s;
   flex-shrink: 0;
}
.chat-send:hover { background: #d4b47a; }

/* ── Report Button (langa numele adversarului) ── */
.report-btn {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   width: 26px; height: 26px;
   border-radius: 50%;
   background: rgba(224,82,82,0.12);
   border: 1px solid rgba(224,82,82,0.2);
   color: var(--danger);
   font-size: 11px;
   cursor: pointer;
   transition: all .2s;
   margin-left: 4px;
   vertical-align: middle;
}
.report-btn:hover {
   background: rgba(224,82,82,0.2);
   border-color: var(--danger);
}

/* ── Report Modal ── */
.report-reasons {
   display: flex;
   flex-direction: column;
   gap: 6px;
   margin: 12px 0;
}
.report-reason-btn {
   display: flex;
   align-items: center;
   gap: 8px;
   padding: 9px 12px;
   border-radius: 6px;
   background: var(--bg-card);
   border: 1px solid rgba(255,255,255,0.06);
   color: var(--text-2);
   font-size: 12px;
   font-weight: 600;
   cursor: pointer;
   transition: all .15s;
   text-align: left;
}
.report-reason-btn:hover { background: rgba(255,255,255,0.06); color: var(--text-1); }
.report-reason-btn.sel { background: rgba(224,82,82,0.1); border-color: var(--danger); color: var(--danger); }
.report-textarea {
   width: 100%;
   padding: 8px 10px;
   border-radius: 6px;
   background: var(--bg-card);
   border: 1px solid rgba(255,255,255,0.08);
   color: var(--text-1);
   font-size: 12px;
   resize: vertical;
   outline: none;
   margin-top: 8px;
}
.report-textarea:focus { border-color: var(--danger); }

/* ══════════════════════════════════════════════════════════
   OVERLAYS / MODALS — Glassmorphism
══════════════════════════════════════════════════════════ */
.overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,0.8);
  backdrop-filter: blur(15px);
  z-index: 1000;
  align-items: center; justify-content: center;
  animation: fadeIn .25s ease;
}
.overlay.open { display: flex; }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }

.mbox {
  background: linear-gradient(145deg, rgba(28,28,32,0.98), rgba(20,20,24,0.98));
  border: 1px solid rgba(195,160,94,0.2);
  border-radius: 14px;
  padding: 32px 28px;
  text-align: center;
  width: 90%; max-width: 360px;
  box-shadow: 0 30px 60px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.06);
  animation: slideUp .35s cubic-bezier(0.23,1,0.32,1);
}
@keyframes slideUp { from{transform:translateY(24px);opacity:0} to{transform:translateY(0);opacity:1} }
.mico { font-size: 40px; margin-bottom: 14px; }
.mtit { font-size: 19px; font-weight: 800; color: #fff; margin-bottom: 6px; text-transform: uppercase; letter-spacing: 1px; }
.msub { font-size: 13px; color: var(--text-3); margin-bottom: 22px; line-height: 1.5; }
.spinner { width: 48px; height: 48px; margin: 0 auto 18px; border: 3px solid rgba(195,160,94,0.15); border-top-color: var(--accent); border-radius: 50%; animation: spin .8s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }
.seek-sec { font-family:'JetBrains Mono',monospace; font-size: 26px; font-weight: 800; color: var(--accent); margin: 8px 0; }
.mbrow { display: flex; gap: 10px; }
.mbtn { flex: 1; padding: 11px; border-radius: 6px; cursor: pointer; font-size: 13px; font-weight: 700; border: 1px solid rgba(255,255,255,0.06); transition: all .2s; }
.mbtn.acc { background: var(--accent); border: none; color: #000; }
.mbtn.acc:hover { background: #d4b47a; transform: translateY(-2px); }
.mbtn.dec { background: rgba(255,255,255,0.06); color: #fff; }
.mbtn.dec:hover { background: rgba(255,255,255,0.1); }

/* Promotion overlay */
.promo-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  z-index: 2000;
}
.promo-card { background: var(--bg-panel); border: 1px solid rgba(195,160,94,0.3); border-radius: 12px; padding: 24px; text-align: center; }
.promo-title { font-size: 13px; font-weight: 800; color: var(--accent); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.promo-options { display: flex; gap: 12px; }
.promo-opt { padding: 12px; border-radius: 8px; cursor: pointer; background: var(--bg-card); border: 1px solid rgba(255,255,255,0.06); transition: all .2s; min-width: 64px; }
.promo-opt:hover { background: var(--accent-dim); border-color: var(--accent); }
.promo-sym { font-size: 28px; }
.promo-name { font-size: 10px; color: var(--text-3); margin-top: 4px; font-weight: 700; }

/* ══ Chat Request Modal ═══════════════════════════════════════ */
.chat-request-modal .mico { font-size: 42px; }
.chat-request-modal .msub { font-size: 14px; color: var(--text-2); margin-bottom: 20px; line-height: 1.5; }

/* Indicator dot — flashing next to chat header when request received */
.chat-request-indicator {
    display: none;
    width: 10px; height: 10px;
    background: var(--accent);
    border-radius: 50%;
    margin-left: 6px;
    animation: chatReqPulse 1.2s infinite;
    vertical-align: middle;
    flex-shrink: 0;
}
.chat-request-indicator.visible { display: inline-block; }
@keyframes chatReqPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.4; transform: scale(0.8); }
}

/* ════════════════════════════════════════════════════════════
    MOBILE GAME-OVER TOAST
    Bypasses the .right-panel { display: none } hiding issue.
   ═══════════════════════════════════════════════════════════ */
.mobile-gameover-toast {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10001;
  background: linear-gradient(145deg, var(--bg-card), #1a1a1e);
  border: 1px solid rgba(195,160,94,0.3);
  border-radius: 16px;
  padding: 20px 24px;
  max-width: 320px;
  width: 88vw;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.06);
  animation: toastIn .3s cubic-bezier(0.23,1,0.32,1);
  text-align: center;
  gap: 12px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.mobile-gameover-toast.open { display: flex; }
@keyframes toastIn { from{opacity:0;transform:translate(-50%,-50%) scale(.92)} to{opacity:1;transform:translate(-50%,-50%) scale(1)} }
.toast-icon { font-size: 40px; margin-bottom: 6px; }
.toast-title { font-size: 16px; font-weight: 800; color: var(--accent); text-transform: uppercase; letter-spacing: .8px; }
.toast-subtitle { font-size: 13px; color: var(--text-3); margin-top: 2px; line-height: 1.4; }
.toast-close {
  position: absolute; top: 10px; right: 12px;
  background: none; border: none; color: var(--text-3);
  font-size: 16px; cursor: pointer; padding: 4px 6px;
  border-radius: 6px; transition: .15s;
  line-height: 1;
}
.toast-close:hover { background: rgba(255,255,255,0.07); color: #fff; }

/* Overlay backdrop behind the toast */
.mobile-gameover-backdrop {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  z-index: 10000;
}
.mobile-gameover-backdrop.open { display: block; }

/* Landscape phones — toast still centered but smaller */
@media (max-width: 900px) and (orientation: landscape) {
  .mobile-gameover-toast { max-width: 420px; width: 70vw; }
}

/* ── COPPA/GDPR Minor Protection Badge ── */
.minor-badge {
   display: inline-flex;
   align-items: center;
   gap: 6px;
   padding: 4px 10px;
   background: rgba(224,82,82,0.12);
   border: 1px solid rgba(224,82,82,0.25);
   border-radius: 6px;
   font-size: 10px;
   font-weight: 700;
   color: var(--danger);
   white-space: nowrap;
   flex-shrink: 0;
}
.minor-badge i:first-child { font-size: 12px; }
.minor-badge .fa-info-circle { font-size: 11px; opacity: 0.6; cursor: help; }

/* Chat wrap under minor protection */
.chat-wrap.minor-protected {
   opacity: 0.85;
}
.chat-wrap.minor-protected .chat-row,
.chat-wrap.minor-protected .quick-chat-row,
.chat-wrap.minor-protected .emote-trigger-wrap {
   display: none !important;
}
.chat-wrap.minor-protected .chat-in {
   background: var(--bg-card);
   border-color: rgba(224,82,82,0.3);
   color: var(--text-3);
   font-style: italic;
}

/* ══════════════════════════════════════════════════════════
   NOTIFICATIONS (existing, bottom-anchored)
   ══════════════════════════════════════════════════════════ */
.notif {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: rgba(28,28,32,0.95);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 11px 22px;
  font-size: 13px; font-weight: 700; color: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
  z-index: 9999; white-space: nowrap;
  pointer-events: none;
  animation: nIn .35s cubic-bezier(0.175,0.885,0.32,1.275), nOut .35s cubic-bezier(0.6,-0.28,0.735,0.045) 3.5s forwards;
}
.notif.success { border-left: 3px solid var(--accent); color: var(--accent); }
.notif.error   { border-left: 3px solid var(--danger); color: #ff6b6b; }
@keyframes nIn  { from{opacity:0;transform:translateX(-50%) translateY(16px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }
@keyframes nOut { to{opacity:0;transform:translateX(-50%) translateY(-16px)} }

/* ══════════════════════════════════════════════════════════
   GENERAL BUTTONS
══════════════════════════════════════════════════════════ */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:9px 18px; border-radius:6px; font-size:13px; font-weight:700; cursor:pointer; border:1px solid transparent; text-decoration:none; text-transform:uppercase; letter-spacing:.5px; transition:all .2s; }
.btn-p { background:var(--accent); color:#000; box-shadow:0 4px 12px rgba(195,160,94,0.2); }
.btn-p:hover { background:#d4b47a; transform:translateY(-1px); }
.btn-s { background:rgba(255,255,255,0.05); border-color:rgba(255,255,255,0.1); color:var(--text-2); }
.btn-s:hover { background:rgba(255,255,255,0.1); color:#fff; border-color:var(--accent); }

/* ══════════════════════════════════════════════════════════
   GLOBAL SCROLLBARS
══════════════════════════════════════════════════════════ */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }


/* ══════════════════════════════════════════════════════════
   ░░  RESPONSIVE — TABLET (≤ 1024px)  ░░
══════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .right-panel {
    width: 280px;
    min-width: 260px;
  }
}

/* ══════════════════════════════════════════════════════════
   ░░  RESPONSIVE — MOBILE (≤ 768px)  ░░
   King layout: board fills the screen, no sidebars.
══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* ═══════════════════════════════════════════════════════════════════
     MOBILE PORTRAIT — layout Chess.com style
     
     CSS Grid com 3 rânduri exacte (robust, fara calcule JS fragile):
       [topnav - fixed, ~48px]
       [board-zone - grid: auto 1fr auto]
         ├── #stripOpp  — rând fix sus (avatar + nume + ceas adversar)
         ├── .board-center — tablă, umple spațiul rămas
         └── #stripMe   — rând fix jos (avatar + nume + ceas tu)
       [dock - fixed jos]
  ═══════════════════════════════════════════════════════════════════ */

  body {
    margin: 0;
    overflow: hidden;
  }

  /* Ascunde chrome desktop */
  .icon-sidebar  { display: none !important; }
  .topnav-links  { display: none !important; }
  .mob-menu-btn  { display: flex !important; }
  .btn-support    { display: none; }
  .topnav-logo   { width: 48px !important; font-size: 18px !important; border-right: none !important; }

  /* app-shell */
  .app-shell {
    left: 0 !important;
    flex-direction: column;
    overflow: hidden;
  }

  /* ── board-zone: CSS Grid cu 3 rânduri (auto | 1fr | auto) ──
     !important necesar — app-shell.css are @media 768px cu display:block si padding:12px
     care altfel suprascrie stilurile noastre                                           */
  .board-zone {
    position: fixed !important;
    top: var(--topbar-h, 48px) !important;
    left: 0 !important;
    right: 0 !important;
    bottom: var(--dock-h, 56px) !important;
    display: grid !important;
    grid-template-rows: auto 1fr auto !important;
    grid-template-columns: 100% !important;
    overflow: hidden !important;
    padding: 0 !important;
    width: 100% !important;
    align-items: unset !important;
    justify-content: unset !important;
    flex-direction: unset !important;
    height: unset !important;
  }

  /* ── Strip adversar (SUS) — rândul 1, înălțime naturală garantată ── */
  #stripOpp {
    grid-row: 1 !important;
    grid-column: 1 !important;
    padding: 6px 12px !important;
    background: var(--bg-panel, #18181b);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    display: flex !important;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
  }

  /* ── Zona tablei — rândul 2 (1fr), umple EXACT spațiul rămas ── */
  .board-center {
    grid-row: 2 !important;
    grid-column: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    position: relative !important;
    background: var(--bg-app, #0a0c10);
    min-height: 0 !important;
    min-width: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* board-wrap: centrat */
  .board-wrap {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }

  .board-viewport {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

  .board-main-row {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .bwrap {
    box-shadow: none;
    border-radius: 0;
    flex-shrink: 0;
  }

  #chessBoard {
    display: grid !important;
  }

  /* Eval bar si coordonate ascunse pe mobile */
  .eval-wrapper  { display: none !important; }
  #coordsRank, #coordsFile { display: none !important; }

  /* ── Strip EU (JOS) — rândul 3, înălțime naturală, MEREU vizibil ── */
  #stripMe {
    grid-row: 3 !important;
    grid-column: 1 !important;
    padding: 6px 12px !important;
    background: var(--bg-panel, #18181b);
    border-top: 1px solid rgba(255,255,255,0.08);
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    display: flex !important;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
  }

  /* player-strip: full width în grid, override max-width:var(--board) */
  .player-strip {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
  }
  
  /* Asigurăm că .player-strip direct în #stripOpp/#stripMe nu adaugă layout extra */
  #stripOpp.player-strip,
  #stripMe.player-strip {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
  }

  /* Ceas: font adaptat mobile */
  .clock { font-size: 20px; min-width: 80px; }

  /* Panel dreapta: ascuns */
  .right-panel { display: none !important; }

  /* Legal footer: ascuns pe pagina de joc */
  #sc-legal-footer { display: none !important; }

  /* ── DOCK MOBIL ── */
  .mobile-dock {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: var(--dock-h, 56px);
    background: rgba(18,18,20,0.96);
    backdrop-filter: blur(16px);
    border-top: 1px solid rgba(195,160,94,0.12);
    display: flex !important;
    align-items: center;
    justify-content: space-around;
    z-index: 300;
    box-shadow: 0 -4px 24px rgba(0,0,0,0.5);
    padding: 0 8px;
    padding-bottom: env(safe-area-inset-bottom);
  }

  .dock-btn {
    flex: 1;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 3px;
    height: 100%;
    background: transparent; border: none;
    color: var(--text-3);
    cursor: pointer; font-family: inherit;
    border-radius: 0;
    transition: color .15s;}
  .dock-btn:hover, .dock-btn.active { color: var(--accent); }
  .dock-btn i { font-size: 19px; }
  .dock-btn span { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; }
  .dock-btn.danger { color: #ff6b6b; }
  .dock-btn.danger:hover { color: #ff4444; }

  .dock-sep { width: 1px; height: 32px; background: rgba(255,255,255,0.06); }

  /* Body: padding-bottom pentru dock + safe area */
  body { padding-bottom: calc(var(--dock-h, 56px) + env(safe-area-inset-bottom, 0px)); }

  /* Notificari deasupra dock-ului */
  .notif { bottom: calc(var(--dock-h, 56px) + 12px); }

  /* Nav drawer mobile */
  .mob-nav {
    display: none;
    position: fixed;
    top: var(--topbar-h, 48px); left: 0; right: 0;
    background: var(--bg-panel);
    border-bottom: 1px solid rgba(255,255,255,0.05);
    z-index: 998;
    flex-direction: column;
    padding: 8px 0;
    box-shadow: 0 10px 25px rgba(0,0,0,0.5);
  }
  .mob-nav.open { display: flex; }
  .mob-nav a {
    padding: 14px 20px; color: var(--text-2); text-decoration: none;
    font-size: 14px; font-weight: 600;
    border-bottom: 1px solid rgba(255,255,255,0.03);
    transition: all .2s;
  }
  .mob-nav a:last-child { border-bottom: none; }
  .mob-nav a:hover, .mob-nav a.active {
    background: var(--bg-card); color: var(--accent);
  }

  /* Sheet mobil pentru istoricul mutarilor */
  .mobile-sheet {
    position: fixed;
    bottom: var(--dock-h, 56px);
    left: 0; right: 0;
    background: rgba(20,20,24,0.97);
    backdrop-filter: blur(16px);
    border-top: 1px solid rgba(195,160,94,0.15);
    z-index: 280;
    border-radius: 16px 16px 0 0;
    transform: translateY(100%);
    transition: transform .3s cubic-bezier(0.23,1,0.32,1);
    max-height: 70vh;
    overflow-y: auto;
    display: none;
  }
  .mobile-sheet.open {
    transform: translateY(0);
    display: block;
  }
  .sheet-handle {
    width: 36px; height: 4px;
    background: rgba(255,255,255,0.15);
    border-radius: 2px;
    margin: 10px auto 6px;
  }
  .sheet-content { padding: 0 16px 20px; }
}


/* Landscape phones — shorter board */
@media (max-width: 900px) and (orientation: landscape) {
  .app-shell { flex-direction: row; }
  .board-zone { flex-direction: row; grid-template-rows: none; grid-template-columns: auto 1fr auto; }
  #stripOpp, #stripMe { writing-mode: vertical-rl; width: auto; height: 100%; padding: 8px 4px; border: none; border-right: 1px solid rgba(255,255,255,0.04); border-left: 1px solid rgba(255,255,255,0.04); }
  .board-center { flex: 1; }
  .clock { font-size: 16px; writing-mode: horizontal-tb; }
}

/* ══ Hide mobile dock on desktop ══ */
@media (min-width: 769px) {
  .mobile-dock   { display: none !important; }
  .mobile-sheet  { display: none !important; }
}

/* ══════════════════════════════════════════════════════════
   COMMAND CENTER SIDEBAR — icon-sidebar
══════════════════════════════════════════════════════════ */
.icon-sidebar {
  position: fixed;
  left: 0;
  top: var(--topbar-h);
  bottom: 0;
  width: var(--sidebar-w);
  background: var(--bg-panel);
  border-right: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
  z-index: 190;
}

/* Brand section */
.cmd-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 14px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  text-decoration: none;
  flex-shrink: 0;
}
.cmd-brand-icon {
  width: 34px; height: 34px;
  background: linear-gradient(135deg, var(--accent), rgba(195,160,94,0.5));
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  box-shadow: 0 4px 12px rgba(195,160,94,0.2);
  flex-shrink: 0;
}
.cmd-brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.cmd-brand-name { font-size: 13px; font-weight: 800; color: var(--text-1); letter-spacing: .5px; }
.cmd-brand-sub  { font-size: 9px;  font-weight: 600; color: var(--text-3); letter-spacing: 1.2px; text-transform: uppercase; }

/* Nav scroll area */
.cmd-scroll {
  flex: 1;
  overflow-y: auto;
  padding: 10px 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  scrollbar-width: none;
}
.cmd-scroll::-webkit-scrollbar { display: none; }

/* Section labels */
.cmd-section-label {
  font-size: 13px;
  font-weight: 800;
  color: white;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  padding: 8px 8px 4px;
  margin-top: 4px;
}

/* Nav items */
.sbi {
  width: 100%;
  height: 38px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 10px;
  border-radius: 7px;
  cursor: pointer;
  color: var(--text-3);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  transition: all .15s ease;
  background: transparent;
  border: none;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
}
.sbi i { font-size: 14px; flex-shrink: 0; width: 16px; text-align: center; }
.sbi:hover { background: rgba(255,255,255,0.05); color: var(--text-1); }
.sbi.active { background: var(--accent-dim); color: var(--accent); box-shadow: inset 3px 0 0 var(--accent); }
.sbi-label { font-size: 13px; font-weight: 600; }
.sbi-divider { height: 1px; background: rgba(255,255,255,0.05); margin: 8px 2px; flex-shrink: 0; }

/* Play button */
.cmd-play-wrap { position: relative; }
.cmd-play-btn {
  width: 100%;
  height: 40px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 10px;
  border-radius: 7px;
  cursor: pointer;
  background: var(--accent);
  color: #0e0e10;
  font-size: 13px;
  font-weight: 800;
  border: none;
  white-space: nowrap;
  margin-bottom: 4px;
  letter-spacing: .3px;
  transition: all .15s;
  box-shadow: 0 4px 16px rgba(195,160,94,0.2);
}
.cmd-play-btn i { font-size: 14px; flex-shrink: 0; }
.cmd-play-chevron { margin-left: auto; font-size: 10px; transition: transform .2s; }
.cmd-play-btn:hover { background: #d4b47a; }
.cmd-play-wrap:hover .cmd-play-chevron { transform: rotate(180deg); }

.cmd-play-dropdown {
  display: none;
  flex-direction: column;
  gap: 1px;
  overflow: hidden;
  border-radius: 7px;
  background: rgba(14,14,16,0.6);
  border: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 4px;
}
.cmd-play-wrap:hover .cmd-play-dropdown { display: flex; }

.cmd-dd-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  color: var(--text-2);
  text-decoration: none;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  background: transparent;
  border: none;
  width: 100%;
  text-align: left;
  transition: all .12s;
}
.cmd-dd-item i { font-size: 13px; color: var(--accent); flex-shrink: 0; width: 14px; text-align: center; }
.cmd-dd-item:hover { background: rgba(195,160,94,0.08); color: var(--text-1); }
.cmd-dd-label { flex: 1; }
.cmd-dd-sub { font-size: 10px; color: var(--text-3); font-weight: 500; }

/* Sidebar footer */
.cmd-footer {
  padding: 10px 8px 12px;
  border-top: 1px solid rgba(255,255,255,0.05);
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex-shrink: 0;
}
.cmd-auth-row { display: flex; gap: 6px; margin-bottom: 6px; }
.cmd-auth-btn {
  flex: 1;
  padding: 7px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  letter-spacing: .3px;
  transition: all .15s;
}
.cmd-signin {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-2);
}
.cmd-signin:hover { background: rgba(255,255,255,0.09); color: #fff; }
.cmd-signup {
  background: var(--accent);
  border: 1px solid transparent;
  color: #0e0e10;
}
.cmd-signup:hover { background: #d4b47a; }
.cmd-lang {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 8px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,0.07);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  width: 100%;
}
.cmd-lang select {
  background: transparent;
  border: none;
  color: inherit;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  flex: 1;
  outline: none;
  appearance: none;
}
.cmd-lang select option { background: var(--bg-panel); color: var(--text-1); }

/* ══════════════════════════════════════════════════════════
   UTILITY: Rating hidden on very small screens
══════════════════════════════════════════════════════════ */
@media (max-width: 380px) {
  .prating { display: none; }
  .clock { font-size: 20px; min-width: 72px; }
}

/* ══════════════════════════════════════════════════════════
   TOUCH / MOBILE — Îmbunătățiri interacțiune piesă
══════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* Hint dots mai mari pe mobile — mai ușor de atins */
  .sq.hint::after {
    width: 40% !important;
    height: 40% !important;
    background: rgba(0,0,0,0.22) !important;
  }
  /* Border hint-cap mai gros pe touch */
  .sq.hint-cap::after {
    box-shadow: inset 0 0 0 6px rgba(0,0,0,0.2) !important;
  }
  /* Ghost mai mare și mai vizibil pe telefon */
  .piece-ghost {
    filter: drop-shadow(0 16px 40px rgba(0,0,0,0.85))
            drop-shadow(0 4px 12px rgba(0,0,0,0.55)) !important;
  }
  /* Piesa selectată — highlight mai puternic pe touch */
  .sq.sel.light { background: rgba(255, 255, 51, 0.5) !important; }
  .sq.sel.dark  { background: rgba(255, 255, 51, 0.5) !important; }
  .sq.sel { box-shadow: inset 0 0 0 4px rgba(255,255,255,0.18) !important; }
}



/* ═══ AUTH MODAL STYLES ═══════════════════════════════════════════════════ */
/* ═══ AUTH MODAL STYLES (play.html) ═══════════════════════════════════════ */
.modal-bg {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.85); z-index: 9000;
  align-items: center; justify-content: center;
}
.modal-bg.open { display: flex; }
.modal-play {
  background: #18181b;
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 16px;
  padding: 32px 36px;
  width: min(420px, 92vw);
  box-shadow: 0 30px 80px rgba(0,0,0,.85);
  position: relative;
}
.modal-play h2 { font-size: 22px; margin-bottom: 4px; color: #fff; }
.modal-sub { color: var(--text-3); font-size: 13px; margin-bottom: 22px; }
.modal-close-play {
  position: absolute; top: 14px; right: 14px;
  background: none; border: none; color: var(--text-3);
  font-size: 20px; cursor: pointer; line-height: 1;
  padding: 4px 8px; border-radius: 6px; transition: .15s;
}
.modal-close-play:hover { background: rgba(255,255,255,.07); color: #fff; }
.modal-tabs { display: flex; gap: 4px; margin-bottom: 20px; }
.tab-btn {
  flex: 1; padding: 8px; border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.09);
  background: none; color: var(--text-3);
  font-size: 13px; font-weight: 600;
  cursor: pointer; transition: .15s; font-family: inherit;
}
.tab-btn.active { background: var(--accent); border-color: var(--accent); color: #0e0e10; }
.modal-field { margin-bottom: 14px; }
.modal-field label { display: block; font-size: 12px; color: var(--text-3); margin-bottom: 5px; font-weight: 600; }
.modal-field input {
  width: 100%; padding: 10px 12px; border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.09);
  background: rgba(255,255,255,.05);
  color: #fff; font-size: 14px; outline: none;
  font-family: inherit; transition: .15s;
}
.modal-field input:focus { border-color: var(--accent); background: rgba(255,255,255,.08); }
.modal-field input::placeholder { color: var(--text-3); }
.modal-submit-btn {
  width: 100%; padding: 12px; border: none; border-radius: 10px;
  background: var(--accent); color: #0e0e10;
  font-weight: 700; font-size: 15px;
  cursor: pointer; transition: .15s; margin-top: 4px; font-family: inherit;
}
.modal-submit-btn:hover { background: #d4b47a; }
.form-error { color: #e05252; font-size: 12px; margin-top: 8px; display: none; }
.form-ok    { color: #4caf7d; font-size: 12px; margin-top: 8px; display: none; }
.modal-divider { border: none; border-top: 1px solid rgba(255,255,255,0.07); margin: 16px 0; }
.modal-guest-link {
  display: block; text-align: center; color: var(--text-3);
  font-size: 13px; cursor: pointer; margin-top: 12px;
  transition: color .15s;
}
.modal-guest-link:hover { color: #fff; }

/* ── Chat Mute Button ── */
.chat-mute-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  margin-right: 6px;
}
.chat-mute-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-2);
  border-color: rgba(195, 160, 94, 0.3);
}
.chat-mute-btn i {
  font-size: 12px;
}

/* Chat muted state (default) - messages don't appear */
.chat-msgs.muted {
  opacity: 0.4;
}

/* ══════════════════════════════════════════════════════════════════
   MOBILE CHAT SHEET — chat modal pentru mobil
   ══════════════════════════════════════════════════════════════════ */

/* Badge de notificare pe butonul Chat din dock */
.dock-chat-badge {
  position: absolute;
  top: 4px;
  right: 10px;
  width: 8px;
  height: 8px;
  background: var(--accent, #4caf50);
  border-radius: 50%;
  display: none;
  animation: badgePulse 1.5s infinite;
}
.dock-chat-badge.visible { display: block; }
@keyframes badgePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.3); }
}

/* Sheet-ul de chat — slide-up din jos, peste dock */
#sheetChat {
  /* Override înălțimea default a .mobile-sheet */
  max-height: 72vh;
  display: flex;
  flex-direction: column;
}
#sheetChat.open { transform: translateY(0); }

/* Inner wrapper — flex column, umple sheet-ul */
.mobile-chat-sheet-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: calc(72vh - 28px); /* 28px = sheet-handle */
  overflow: hidden;
}

/* ── Header ── */
.mcs-header {
  flex-shrink: 0;
  padding: 0 14px 8px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.mcs-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0 8px;
}

.mcs-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1, #e8dcc8);
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.mcs-controls {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Mute button — pill cu icon + text */
.mcs-mute-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px;
  border-radius: 20px;
  border: 1px solid rgba(195,160,94,0.3);
  background: rgba(195,160,94,0.08);
  color: var(--accent, #c3a05e);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.18s ease;
  white-space: nowrap;
}
.mcs-mute-btn:hover { background: rgba(195,160,94,0.18); }
.mcs-mute-btn.muted {
  background: rgba(255,100,100,0.1);
  border-color: rgba(255,100,100,0.35);
  color: #ff7070;
}
.mcs-mute-btn i { font-size: 13px; }

.mcs-emote-btn, .mcs-close-btn {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.06);
  color: var(--text-2, #a89880);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  transition: background 0.15s, color 0.15s;
}
.mcs-emote-btn:hover, .mcs-close-btn:hover {
  background: rgba(255,255,255,0.13);
  color: var(--text-1, #e8dcc8);
}

/* Quick chat row */
.mcs-quick-row {
  display: flex;
  gap: 6px;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: none;
}
.mcs-quick-row::-webkit-scrollbar { display: none; }

.mcs-quick-btn {
  flex-shrink: 0;
  padding: 5px 11px;
  border-radius: 14px;
  border: 1px solid rgba(195,160,94,0.2);
  background: rgba(195,160,94,0.07);
  color: var(--text-2, #a89880);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.mcs-quick-btn:hover {
  background: rgba(195,160,94,0.18);
  color: var(--accent, #c3a05e);
}

/* Mobile emote picker */
.mobile-emote-picker {
  display: none;
  flex-wrap: wrap;
  gap: 4px;
  padding: 8px 0 4px;
  border-top: 1px solid rgba(255,255,255,0.06);
  margin-top: 6px;
}
.mobile-emote-picker.open { display: flex; }
.mobile-emote-picker span {
  font-size: 22px;
  cursor: pointer;
  padding: 3px 5px;
  border-radius: 6px;
  transition: background 0.12s;
  line-height: 1;
}
.mobile-emote-picker span:hover { background: rgba(255,255,255,0.1); }

/* ── Messages area ── */
.mcs-messages {
  flex: 1 1 0;
  min-height: 150px;
  overflow-y: auto;
  padding: 10px 14px 6px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  scroll-behavior: smooth;
}
.mcs-messages::-webkit-scrollbar { width: 3px; }
.mcs-messages::-webkit-scrollbar-thumb { background: rgba(195,160,94,0.3); border-radius: 3px; }

.mcs-messages.muted .chat-msg:not(.system) { display: none; }
.mcs-messages.muted .chat-msg.system { opacity: 0.5; font-style: italic; }

/* ── Input row ── */
.mcs-input-row {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px 14px;
  border-top: 1px solid rgba(255,255,255,0.07);
  background: rgba(10,12,16,0.6);
}

.mcs-input {
  flex: 1;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(195,160,94,0.2);
  border-radius: 20px;
  color: var(--text-1, #e8dcc8);
  font-size: 14px;
  padding: 9px 14px;
  outline: none;
  transition: border-color 0.15s;
}
.mcs-input:focus { border-color: var(--accent, #c3a05e); }
.mcs-input::placeholder { color: var(--text-3, #7a7060); }

.mcs-send-btn {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: none;
  background: var(--accent, #c3a05e);
  color: #0a0c10;
  font-size: 15px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.15s, transform 0.1s;
}
.mcs-send-btn:hover { background: #d4b47a; }
.mcs-send-btn:active { transform: scale(0.92); }

/* ── Asigură că sheet-ul Chat e visible pe mobile ── */
@media (max-width: 768px) {
  #sheetChat { display: flex !important; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   GAME END MODAL  —  Chess.com-style overlay centred on the board
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── Hidden state ─────────────────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════════════════════
   GAME END MODAL
   Arhitectură: modalul (#game-end-modal) trăiește în #resizableBoard.
   • .game-end-backdrop  → position:absolute inset:0  → acoperă EXACT tabla
                           (clipat corect de overflow:hidden al .bwrap)
   • .game-end-card      → position:fixed, centrat pe viewport
                           → vizibil în afara tablei, scroll propriu pe mobil
   ═══════════════════════════════════════════════════════════════════════════ */

#game-end-modal.modal-hidden {
  display: none !important;
}

/* Containerul modal: acoperă tabla (pentru backdrop), fără a intercepta click-uri pe card */
.game-end-modal {
  position: absolute;
  inset: 0;
  z-index: 5000;
  /* Nu centrăm card-ul aici — card-ul e position:fixed */
  pointer-events: none; /* backdrop și card au pointer-events proprii */
  animation: geIn .35s cubic-bezier(0.23, 1, 0.32, 1);
}

/* Backdrop: acoperă EXACT tabla, clipat de overflow:hidden al .bwrap */
.game-end-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  border-radius: inherit;
  pointer-events: auto; /* click pe backdrop închide modalul */
}

@keyframes geIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}



/* ── Card ─────────────────────────────────────────────────────────────────── */
.game-end-card {
  /* Fixed pe centrul viewport-ului: vizibil pe orice ecran, indiferent de tabla */
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(360px, 92vw);
  max-width: 380px;
  /* Scroll propriu pe mobil când card-ul e mai înalt decât ecranul */
  max-height: 90dvh;
  overflow-y: auto;
  overscroll-behavior: contain;
  pointer-events: auto;
  background: linear-gradient(160deg, rgba(38, 36, 33, 0.99) 0%, rgba(18, 17, 15, 0.99) 100%);
  border: 1px solid rgba(195, 160, 94, 0.22);
  border-radius: 18px;
  padding: 28px 24px 22px;
  text-align: center;
  box-shadow:
    0 28px 64px rgba(0, 0, 0, 0.75),
    0 0  0  1px rgba(255, 255, 255, 0.04) inset;
  z-index: 5100; /* deasupra backdrop-ului (5000) și a altor elemente */
  animation: geCardIn .4s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

@keyframes geCardIn {
  from {
    opacity: 0;
    /* Păstrăm translate(-50%,-50%) de centrare + animăm doar Y și scale */
    transform: translate(-50%, calc(-50% + 24px)) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
}

.game-end-close {
  position: absolute;
  top: 10px;
  right: 12px;
  background: none;
  border: none;
  color: var(--text-3, #7d7d7d);
  font-size: 16px;
  cursor: pointer;
  line-height: 1;
  padding: 4px 6px;
  border-radius: 6px;
  transition: background 0.15s, color 0.15s;
}
.game-end-close:hover {
  background: rgba(255, 255, 255, 0.07);
  color: var(--text-1, #ffffff);
}

/* ── Icon ─────────────────────────────────────────────────────────────────── */
.ge-icon {
  font-size: 42px;
  margin-bottom: 6px;
  line-height: 1;
  color: var(--accent, #c3a05e);
  filter: drop-shadow(0 0 12px rgba(195, 160, 94, 0.45));
}

/* ── Title / Subtitle ─────────────────────────────────────────────────────── */
.ge-title {
  font-size: 17px;
  font-weight: 800;
  color: var(--text-1, #ffffff);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 4px;
}
.ge-subtitle {
  font-size: 12px;
  color: var(--text-3, #7d7d7d);
  line-height: 1.45;
}

/* ── Divider ──────────────────────────────────────────────────────────────── */
.ge-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.06);
  margin: 16px 0;
}

/* ── Player rows ──────────────────────────────────────────────────────────── */
.ge-players {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ge-player {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.04);
  transition: background 0.18s, border-color 0.18s;
}
.ge-player--winner {
  background: rgba(195, 160, 94, 0.09);
  border-color: rgba(195, 160, 94, 0.22);
}

.ge-player-rank {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.ge-player--black .ge-player-rank {
  background: rgba(0, 0, 0, 0.55);
}
.ge-player--white .ge-player-rank {
  background: rgba(255, 255, 255, 0.12);
}

.ge-player-info {
  flex: 1;
  min-width: 0;
  text-align: left;
}
.ge-player-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1, #ffffff);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ge-player--black .ge-player-name { color: #c8c8c8; }
.ge-player--white .ge-player-name { color: #ffffff; }

.ge-player-meta {
  font-size: 11px;
  color: var(--text-3, #7d7d7d);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.ge-player-result--win  { color: var(--accent, #c3a05e); font-weight: 700; }
.ge-player-result--lose { color: var(--danger, #b33434); font-weight: 700; }
.ge-player-result--draw { color: var(--text-3, #7d7d7d); font-weight: 700; }

.ge-sep {
  opacity: 0.4;
}

/* Progress / material bar */
.ge-player-bar-wrap {
  height: 3px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.05);
  margin-top: 6px;
  overflow: hidden;
}
.ge-player-bar {
  height: 100%;
  border-radius: 2px;
  transition: width 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}

/* ── Reason line ──────────────────────────────────────────────────────────── */
.ge-reason {
  font-size: 11px;
  color: var(--text-3, #7d7d7d);
  margin-top: 6px;
  font-style: italic;
}

/* ── Stats ────────────────────────────────────────────────────────────────── */

/* Analyzing loader */
.ge-analyzing {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 0;
  color: var(--text-3, #7d7d7d);
  font-size: 12px;
}
.ge-analyzing-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(195, 160, 94, 0.2);
  border-top-color: var(--accent, #c3a05e);
  border-radius: 50%;
  animation: geSpin 0.75s linear infinite;
  flex-shrink: 0;
}
@keyframes geSpin {
  to { transform: rotate(360deg); }
}

/* Player outcome badge */
.ge-player-outcome {
  font-size: 16px;
  font-weight: 900;
  min-width: 22px;
  text-align: center;
  flex-shrink: 0;
}
.ge-outcome--win  { color: var(--green, #81b64c); }
.ge-outcome--lose { color: var(--danger, #b33434); }
.ge-outcome--draw { color: var(--text-3, #7d7d7d); }

/* ELO + Accuracy badges in meta row */
.ge-elo-badge {
  color: var(--accent, #c3a05e);
  font-weight: 700;
}
.ge-accuracy-badge {
  color: #64b5f6;
  font-weight: 700;
}

/* White / Black player bars */
.ge-player-bar--white { background: rgba(230, 230, 210, 0.75); }
.ge-player-bar--black { background: rgba(100, 120, 100, 0.75); }

/* Analysis done section */
.ge-analysis-done {
  margin: 4px 0 8px;
}

/* Section header per player */
.ge-stats-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 4px 2px;
  margin-bottom: 2px;
}
.ge-stats-header--white .ge-stats-player-label { color: rgba(230,230,210,0.9); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; }
.ge-stats-header--black .ge-stats-player-label { color: rgba(100,140,100,0.9); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; }

.ge-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin: 4px 0 10px;
  padding: 0 4px;
  gap: 5px;
}
.ge-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 7px 4px 6px;
  border-radius: 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  transition: transform 0.2s, box-shadow 0.2s;
  min-width: 0;
}
.ge-stat:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,0.3); }

.ge-stat-icon {
  font-size: 16px;
  line-height: 1;
}
.ge-stat-value {
  font-size: 18px;
  font-weight: 900;
  min-width: 24px;
  text-align: center;
  line-height: 1;
}
.ge-stat-label {
  font-size: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 700;
  opacity: 0.7;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* ── Genius: purple/violet ── */
.ge-stat--genius {
  border-color: rgba(160, 100, 255, 0.30);
  background: rgba(160, 100, 255, 0.09);
}
.ge-stat--genius .ge-stat-value { color: #b47fff; }
.ge-stat--genius .ge-stat-label { color: #b47fff; }

/* ── Best: green ── */
.ge-stat--best {
  border-color: rgba(100, 200, 100, 0.25);
  background: rgba(100, 200, 100, 0.07);
}
.ge-stat--best .ge-stat-value { color: #5dbb63; }
.ge-stat--best .ge-stat-label { color: #5dbb63; }

/* ── Excellent: electric cyan ── */
.ge-stat--excellent {
  border-color: rgba(0, 200, 220, 0.25);
  background: rgba(0, 200, 220, 0.07);
}
.ge-stat--excellent .ge-stat-value { color: #00c8dc; }
.ge-stat--excellent .ge-stat-label { color: #00c8dc; }

/* ── Great: gold/amber ── */
.ge-stat--great {
  border-color: rgba(255, 185, 40, 0.25);
  background: rgba(255, 185, 40, 0.07);
}
.ge-stat--great .ge-stat-value { color: #ffb928; }
.ge-stat--great .ge-stat-label { color: #ffb928; }

/* ── Good: light green ── */
.ge-stat--good {
  border-color: rgba(130, 200, 80, 0.22);
  background: rgba(130, 200, 80, 0.06);
}
.ge-stat--good .ge-stat-value { color: #8ec44a; }
.ge-stat--good .ge-stat-label { color: #8ec44a; }

/* ── Inaccuracy: blue ── */
.ge-stat--inaccuracy {
  border-color: rgba(80, 140, 255, 0.25);
  background: rgba(80, 140, 255, 0.07);
}
.ge-stat--inaccuracy .ge-stat-value { color: #6b9fff; }
.ge-stat--inaccuracy .ge-stat-label { color: #6b9fff; }

/* ── Mistake: yellow ── */
.ge-stat--mistake {
  border-color: rgba(240, 200, 30, 0.25);
  background: rgba(240, 200, 30, 0.07);
}
.ge-stat--mistake .ge-stat-value { color: #f0c41e; }
.ge-stat--mistake .ge-stat-label { color: #f0c41e; }

/* ── Miss: orange ── */
.ge-stat--miss {
  border-color: rgba(255, 140, 30, 0.25);
  background: rgba(255, 140, 30, 0.07);
}
.ge-stat--miss .ge-stat-value { color: #ff8c1e; }
.ge-stat--miss .ge-stat-label { color: #ff8c1e; }

/* ── Blunder: red ── */
.ge-stat--blunder {
  border-color: rgba(220, 60, 60, 0.28);
  background: rgba(220, 60, 60, 0.08);
}
.ge-stat--blunder .ge-stat-value { color: #e85555; }
.ge-stat--blunder .ge-stat-label { color: #e85555; }

/* Non-zero pop animation */
.ge-stat-nonzero {
  font-weight: 900;
}
/* Top-3 mode: 3 badges fill the full width with slightly larger icons/values */
.ge-stats--top3 {
  grid-template-columns: repeat(3, 1fr);
}
.ge-stats--top3 .ge-stat {
  padding: 10px 6px 9px;
}
.ge-stats--top3 .ge-stat-icon {
  font-size: 20px;
}
.ge-stats--top3 .ge-stat-value {
  font-size: 22px;
}
.ge-stats--top3 .ge-stat-label {
  font-size: 10px;
}
@keyframes geStatPop {
  0%   { transform: scale(0.7); opacity: 0; }
  70%  { transform: scale(1.15); }
  100% { transform: scale(1);   opacity: 1; }
}


/* ── Action buttons ───────────────────────────────────────────────────────── */
.ge-actions {
  display: flex;
  gap: 8px;
  margin-top: 14px;
}
.ge-actions--secondary {
  margin-top: 7px;
}

.ge-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 11px 10px;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
  border: 1px solid transparent;
  white-space: nowrap;
}
.ge-btn i { font-size: 12px; }

/* Primary — filled accent */
.ge-btn--primary {
  background: var(--accent, #c3a05e);
  color: #000;
  border: none;
  box-shadow: 0 5px 18px rgba(195, 160, 94, 0.28);
}
.ge-btn--primary:hover {
  background: #d4b47a;
  box-shadow: 0 8px 24px rgba(195, 160, 94, 0.42);
  transform: translateY(-1px);
}

/* Default — outlined */
.ge-btn {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--text-2, #bababa);
}
.ge-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-1, #ffffff);
  transform: translateY(-1px);
}

/* Ghost — transparent, accent border */
.ge-btn--ghost {
  background: transparent;
  border-color: rgba(195, 160, 94, 0.2);
  color: var(--accent, #c3a05e);
}
.ge-btn--ghost:hover {
  background: rgba(195, 160, 94, 0.09);
  border-color: var(--accent, #c3a05e);
  color: var(--accent, #c3a05e);
}

/* ── Header: trophy + heading + congratulatory message ─────────────────────── */
.ge-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  margin-bottom: 4px;
}

.ge-trophy {
  font-size: 44px;
  line-height: 1;
  filter: drop-shadow(0 0 18px rgba(195, 160, 94, 0.55));
  color: var(--accent, #c3a05e);
}

.ge-heading {
  font-size: 22px;
  font-weight: 900;
  color: var(--text-1, #ffffff);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin: 4px 0 0;
  font-style: italic;
  font-family: Georgia, 'Times New Roman', serif;
}

.ge-congrats {
  font-size: 13px;
  color: var(--text-3, #7d7d7d);
  margin: 2px 0 0;
  font-style: italic;
  font-weight: 400;
}

/* ── Result detail group ───────────────────────────────────────────────────── */
.ge-detail {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  margin-top: 8px;
}

/* ── Responsive: tabletă / mobil ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .game-end-card {
    width: min(340px, 92vw);
    max-width: 340px;
    padding: 20px 16px 16px;
    /* Pe ecrane mici: card-ul poate fi mai înalt decât ecranul → scroll */
    max-height: 88dvh;
    top: 50%;
  }
  .ge-heading {
    font-size: 18px;
    letter-spacing: 1.5px;
  }
  .ge-trophy {
    font-size: 34px;
  }
  .mobile-gameover-toast { max-width: 420px; width: 70vw; }
}

@media (max-width: 480px) {
  .game-end-card {
    width: 94vw;
    max-width: none;
    padding: 16px 14px 14px;
    max-height: 85dvh;
    border-radius: 14px;
  }
  .ge-stat-label { font-size: 8px; }
  .ge-stat-value { font-size: 16px; }
  .ge-btn { padding: 9px 10px; font-size: 12px; }
}

/* ══ OPPONENT PROFILE POPUP (chess.com style) ══ */
.opp-clickable {
  cursor: pointer;
  transition: color 0.15s;
}
.opp-clickable:hover {
  color: var(--accent);
  text-decoration: underline dotted;
}

.opp-profile-popup {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999;
  min-width: 230px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.45), 0 2px 8px rgba(0,0,0,0.25);
  padding: 14px;
  animation: oppPopupIn 0.15s cubic-bezier(0.22,1,0.36,1);
}

@keyframes oppPopupIn {
  from { opacity: 0; transform: scale(0.92) translateY(-6px); }
  to   { opacity: 1; transform: scale(1)   translateY(0); }
}

.opp-popup-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.opp-popup-avatar {
  width: 44px; height: 44px;
  border-radius: 8px;
  background: var(--bg-2, #2a2a2a);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: var(--text-3);
  flex-shrink: 0;
  overflow: hidden;
  border: 2px solid var(--border);
}

.opp-popup-info {
  flex: 1; min-width: 0;
}

.opp-popup-username {
  font-weight: 700;
  font-size: 15px;
  color: var(--text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.opp-popup-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 3px;
}

.opp-popup-elo {
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  padding: 1px 7px;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
}

.opp-popup-status-dot {
  font-size: 11px;
  color: var(--success, #4caf50);
}

.opp-popup-wdl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 8px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: 10px;
}

.opp-popup-wdl-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 40px;
}

.opp-popup-wdl-item span {
  font-weight: 700;
  font-size: 16px;
}

.opp-wdl-w span { color: var(--success, #4caf50); }
.opp-wdl-d span { color: var(--text-3); }
.opp-wdl-l span { color: var(--danger, #f44336); }

.opp-popup-wdl-item small {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-3);
  margin-top: 1px;
}

.opp-popup-wdl-sep {
  color: var(--border);
  font-size: 18px;
  padding: 0 2px;
}

.opp-popup-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.opp-popup-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 7px 10px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
}

.opp-popup-btn:active { transform: scale(0.97); }

.opp-popup-btn--friend {
  background: var(--accent);
  color: #fff;
}
.opp-popup-btn--friend:hover { filter: brightness(1.12); }

.opp-popup-btn--more {
  flex: 0 0 34px;
  background: var(--bg-2, #2a2a2a);
  color: var(--text-2);
  border: 1px solid var(--border);
}
.opp-popup-btn--more:hover { background: var(--bg-3, #333); }

.opp-more-menu {
  margin-top: 8px;
  border-top: 1px solid var(--border);
  padding-top: 6px;
  animation: oppPopupIn 0.12s ease;
}

.opp-more-item {
  display: flex;
  align-items: center;
  gap: 9px;
  width: 100%;
  background: none;
  border: none;
  color: var(--text-1);
  font-size: 13px;
  padding: 8px 6px;
  border-radius: 6px;
  cursor: pointer;
  text-align: left;
  transition: background 0.12s;
}
.opp-more-item:hover { background: var(--bg-2, rgba(255,255,255,0.06)); }
.opp-more-item--danger { color: var(--danger, #f44336); }
.opp-more-item--danger:hover { background: color-mix(in srgb, var(--danger,#f44336) 10%, transparent); }
.opp-more-item i { width: 16px; text-align: center; flex-shrink: 0; }

/* Ensure board-zone is positioned so popup can be absolutely placed */
main.board-zone {
  position: relative;
}

/* ══ PREMOVE HIGHLIGHTS ══ */
.sq.premove-from {
  background-color: rgba(200, 80, 80, 0.55) !important;
}
.sq.premove-to {
  background-color: rgba(200, 80, 80, 0.45) !important;
}
/* Show a small dot on premove-to square (like chess.com) */
.sq.premove-to::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 3px solid rgba(220, 60, 60, 0.75);
  pointer-events: none;
  box-sizing: border-box;
}
