/* layout.css — Structure globale : header, table, sièges, pot, barre du bas */

/* ---------- STEP INDICATOR ---------- */
.step-indicator {
  text-align: center; font-size: 11px; color: var(--gold);
  text-transform: uppercase; letter-spacing: 0.15em;
  padding: 4px; background: rgba(0,0,0,0.4);
  border-bottom: 1px solid var(--b);
}

/* ---------- HEADER ---------- */
.header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 10px; gap: 6px;
  background: var(--s1);
  border-bottom: 1px solid var(--b); z-index: 10;
  flex-wrap: wrap;
}
.header-left {
  display: flex; align-items: center; gap: 6px;
  flex-wrap: wrap;
}
.blinds-block { display: flex; flex-direction: column; gap: 3px; }
.ante-block { display: flex; flex-direction: column; gap: 3px; }
.label {
  font-size: 9px; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--gold); font-weight: 600;
}
.blinds-inputs, .ante-inputs { display: flex; align-items: center; gap: 3px; }

.players-block { display: flex; flex-direction: column; gap: 3px; align-items: flex-end; }

@media (max-width: 430px) {
  .header { padding: 5px 8px; gap: 5px; flex-wrap: nowrap; }
  .header-left { gap: 5px; flex-wrap: nowrap; }
  .header .label { display: none; }
  .blinds-block, .ante-block, .players-block { gap: 0; }
  .blind-input, .ante-input { width: 36px; padding: 4px 2px; font-size: 11px; }
  .blinds-inputs, .ante-inputs { gap: 2px; }
  .toggle-pill { padding: 5px 5px; font-size: 9px; }
  .pc-btn { width: 28px; height: 28px; font-size: 14px; }
}
.player-count-control {
  display: flex; align-items: center; gap: 5px;
  background: var(--s2); border: 1px solid var(--b); border-radius: 6px; padding: 3px;
}
.pc-value { min-width: 20px; text-align: center; font-size: 14px; font-weight: 700; color: var(--gold); }

/* ---------- TABLE AREA ---------- */
.table-area {
  flex: 1; min-height: 0; position: relative;
  display: flex; align-items: center; justify-content: center;
  padding: 10px; overflow: hidden;
}
.table-svg { width: 100%; height: 100%; max-width: 600px; }

/* ---------- SIÈGES ---------- */
.seat {
  position: absolute; width: 64px; height: 64px;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--s3) 0%, var(--s2) 100%);
  border: 2px solid var(--bm);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  color: var(--cream); font-size: 14px; font-weight: 800;
  cursor: pointer;
  transition: left 0.5s cubic-bezier(0.4,0,0.2,1), top 0.5s cubic-bezier(0.4,0,0.2,1),
              transform 0.3s cubic-bezier(0.4,0,0.2,1), background 0.3s, border-color 0.3s, box-shadow 0.3s;
  transform: translate(-50%, -50%);
  box-shadow: 0 4px 16px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.06);
  z-index: 2;
}
.seat-pos { font-size: 13px; letter-spacing: 0.05em; line-height: 1; }
.seat-stack { font-size: 9px; color: var(--gold); font-weight: 600; margin-top: 2px; line-height: 1; }
.seat-handvalue {
  position: absolute; bottom: -22px; left: 50%;
  transform: translateX(-50%);
  font-size: 9px; font-weight: 700; color: var(--cream);
  background: rgba(0,0,0,0.85); padding: 2px 6px; border-radius: 4px;
  white-space: nowrap; text-transform: uppercase; letter-spacing: 0.05em;
}

/* Chip de mise devant le siège */
.seat-bet-chip {
  position: absolute;
  font-size: 11px; font-weight: 800; color: var(--ink);
  background: var(--gold); padding: 3px 10px; border-radius: 12px;
  white-space: nowrap; box-shadow: 0 2px 8px rgba(0,0,0,0.6);
  transform: translate(-50%, -50%); border: 1px solid rgba(0,0,0,0.3);
}
.seat-bet-chip.is-blind { background: var(--gold-hi); }

.dealer-btn {
  position: absolute;
  width: 31px; height: 31px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #ffffff 0%, #f1f5f9 60%, #cbd5e1 100%);
  color: #000000; font-size: 17px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid #475569;
  box-shadow: 0 2px 6px rgba(0,0,0,0.7), inset 0 0 0 1px rgba(255,255,255,0.6);
  transform: translate(-50%, -50%); z-index: 3;
  pointer-events: none; letter-spacing: 0;
}

.seat-cards {
  position: absolute; top: -26px; left: 50%;
  transform: translateX(-50%); display: flex; gap: 3px;
}

/* États des sièges */
.seat.is-hero {
  border-color: var(--gold);
  background: linear-gradient(145deg, rgba(200,156,60,0.28) 0%, rgba(200,156,60,0.12) 100%);
  box-shadow: 0 0 20px rgba(200,156,60,0.45), 0 4px 16px rgba(0,0,0,0.6);
}
.seat.is-active-in-hand {
  border-color: rgba(255,255,255,0.35);
  background: linear-gradient(145deg, rgba(14,61,38,0.7) 0%, rgba(11,44,28,0.6) 100%);
}
.seat.is-folded { opacity: 0.28; filter: grayscale(0.8); }
.seat.is-out { opacity: 0.3; border-style: dashed; }
.seat.is-acting {
  transform: translate(-50%, -50%) scale(1.5); z-index: 6;
  border-color: var(--gold);
  box-shadow: 0 0 28px rgba(200,156,60,0.75);
}
.seat.is-allin {
  border-color: #ef4444;
  background: linear-gradient(145deg, #7f1d1d 0%, #450a0a 100%);
  box-shadow: 0 0 16px rgba(239,68,68,0.55);
}
.seat.is-winner {
  border-color: var(--win);
  background: linear-gradient(145deg, #166534 0%, #14532d 100%);
  transform: translate(-50%, -50%) scale(1.5);
  box-shadow: 0 0 28px rgba(67,160,71,0.7); z-index: 5;
}
.seat.is-tie {
  border-color: var(--tie);
  background: linear-gradient(145deg, #a16207 0%, #713f12 100%);
  transform: translate(-50%, -50%) scale(1.5);
  box-shadow: 0 0 24px rgba(251,140,0,0.65); z-index: 5;
}
.seat.is-loser {
  border-color: var(--fold);
  background: linear-gradient(145deg, #7f1d1d 0%, #450a0a 100%);
  opacity: 0.8;
}

/* ---------- POT & BOARD ---------- */
.center-info {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  z-index: 1; pointer-events: none;
}
.pot-display {
  background: rgba(0,0,0,0.65);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--gold-border);
  border-radius: 14px; padding: 4px 14px;
  font-size: 13px; font-weight: 700; color: var(--gold);
  white-space: nowrap; text-align: center;
}
.ante-display {
  background: var(--gold); border: 1px solid rgba(0,0,0,0.3);
  border-radius: 12px; padding: 3px 10px;
  font-size: 11px; font-weight: 800; color: var(--ink);
  white-space: nowrap; text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.winner-display {
  background: rgba(0,70,25,0.9);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(67,160,71,0.6);
  border-radius: 10px; padding: 3px 10px;
  font-size: 11px; font-weight: 700; color: #d4f4dd;
  white-space: nowrap; text-align: center; line-height: 1.3;
}
.winner-display.tie {
  background: rgba(100,65,0,0.9); border-color: rgba(251,140,0,0.6); color: #fef3c7;
}
.board { display: flex; gap: 6px; }

/* ---------- ACTION PANEL ---------- */
.action-panel {
  position: absolute;
  background: rgba(7,9,11,0.92);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1.5px solid var(--gold-border);
  border-radius: 14px; padding: 10px; z-index: 8;
  box-shadow: 0 12px 32px rgba(0,0,0,0.75);
  display: flex; flex-direction: column; gap: 6px;
  min-width: 200px; max-width: 240px;
}
.action-panel-info {
  font-size: 11px; color: var(--cream); text-align: center;
  background: var(--gold-bg); border: 1px solid var(--gold-border);
  border-radius: 6px; padding: 5px 6px; line-height: 1.3;
}
.action-panel-info strong { color: var(--gold); }
.action-row-inline { display: grid; grid-template-columns: 1fr 1fr; gap: 5px; }
.action-row-inline.three { grid-template-columns: 1fr 1fr 1fr; }

/* ---------- SWITCH JETONS/BB ---------- */
.unit-switch-wrap {
  position: absolute; bottom: 8px; right: 14px;
  display: flex; align-items: center; gap: 6px; z-index: 5;
}
.unit-switch {
  position: relative; width: 78px; height: 30px;
  background: var(--s2); border: 1px solid var(--b);
  border-radius: 15px; cursor: pointer; overflow: hidden;
}
.unit-switch-thumb {
  position: absolute; top: 2px; left: 2px;
  width: 36px; height: 24px;
  background: var(--gold); border-radius: 10px;
  transition: left 0.25s cubic-bezier(0.4,0,0.2,1);
}
.unit-switch.bb .unit-switch-thumb { left: 38px; }
.unit-switch-labels {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: space-around;
  font-size: 10px; font-weight: 800;
  text-transform: lowercase; letter-spacing: 0.05em;
  pointer-events: none;
}
.unit-switch-labels span {
  width: 36px; text-align: center; color: var(--cream);
  transition: color 0.2s; z-index: 1;
}
.unit-switch:not(.bb) .unit-switch-labels span:first-child { color: var(--ink); }
.unit-switch.bb .unit-switch-labels span:last-child { color: var(--ink); }

/* ---------- BARRE DU HAUT ---------- */
.top-bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 12px;
  background: var(--s1);
  border-bottom: 1px solid var(--b); z-index: 10;
}

/* ---------- BARRE DU BAS ---------- */
.bottom-bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 12px;
  background: var(--s1);
  border-top: 1px solid var(--b); z-index: 10; gap: 8px;
}
