﻿/* ===== CSS VARIABLES & RESET ===== */
:root {
  --gold: #c9a84c;
  --gold-light: #e8c96a;
  --gold-dark: #8a6a1e;
  --gold-glow: rgba(201, 168, 76, 0.4);
  --parchment: #d4b483;
  --parchment-dark: #a0824a;
  --ink: #1a0e05;
  --wood-dark: #1a0d04;
  --wood-mid: #2d1a08;
  --wood-light: #3d2410;
  --felt-green: #1b3a2a;
  --felt-dark: #0f2218;
  --felt-shadow: #0a1810;
  --blood-red: #7a1c1c;
  --ember: #c4551a;
  --ember-glow: rgba(196, 85, 26, 0.5);
  --cream: #f0e0c0;
  --cream-dim: #c8b090;
  --shadow: rgba(0,0,0,0.7);
  --dice-white: #f5ead8;
  --dice-pip: #1a0e05;
  --selected-glow: rgba(201, 168, 76, 0.6);
  --scoring-glow: rgba(100, 200, 100, 0.5);
  --farkle-red: rgba(200, 50, 50, 0.6);
}

* { margin:0; padding:0; box-sizing:border-box; }

html, body {
  width:100%; height:100%;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: 'Crimson Text', Georgia, serif;
  background: #0d0703;
  color: var(--cream);
  min-height: 100vh;
  min-height: 100dvh;
  position: relative;
}

.sfx-toggle {
  position: fixed;
  top: 10px;
  left: 10px;
  z-index: 170;
  min-width: 78px;
  height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(201,168,76,0.32);
  background: linear-gradient(180deg, rgba(27,17,7,0.95), rgba(12,8,3,0.95));
  color: var(--cream);
  font-family: 'Cinzel', serif;
  font-size: 0.67rem;
  letter-spacing: 0.09em;
  cursor: pointer;
  box-shadow: 0 3px 9px rgba(0,0,0,0.42), inset 0 1px 0 rgba(255,255,255,0.04);
  transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.sfx-toggle:hover {
  transform: translateY(-1px);
  border-color: rgba(201,168,76,0.58);
}

.sfx-toggle.off {
  border-color: rgba(180, 90, 80, 0.5);
  color: #dfb6ae;
}

.made-by-credit {
  position: fixed;
  right: 10px;
  bottom: max(6px, env(safe-area-inset-bottom));
  z-index: 180;
  font-family: 'Cinzel', serif;
  font-size: 0.52rem;
  letter-spacing: 0.08em;
  color: rgba(212, 180, 131, 0.62);
  text-shadow: 0 1px 2px rgba(0,0,0,0.75);
  pointer-events: none;
  user-select: none;
}

/* ===== BACKGROUND ===== */
.bg-layer {
  position: fixed;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(90,40,5,0.5) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 20% 50%, rgba(60,20,5,0.3) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 80% 50%, rgba(60,20,5,0.3) 0%, transparent 60%),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 40px,
      rgba(0,0,0,0.03) 40px,
      rgba(0,0,0,0.03) 41px
    ),
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 40px,
      rgba(0,0,0,0.03) 40px,
      rgba(0,0,0,0.03) 41px
    ),
    linear-gradient(160deg, #1a0a03 0%, #0d0703 40%, #0a0500 100%);
}

/* Wood grain texture overlay */
.bg-layer::after {
  content:'';
  position:absolute;
  inset:0;
  background-image:
    repeating-linear-gradient(
      12deg,
      transparent,
      transparent 3px,
      rgba(0,0,0,0.04) 3px,
      rgba(0,0,0,0.04) 4px
    );
  pointer-events:none;
}

/* Candle flicker particles */
.candle { position:fixed; z-index:1; pointer-events:none; }
.candle-left { left:3%; top:10%; }
.candle-right { right:3%; top:10%; }

.flame {
  width:14px; height:26px;
  background: radial-gradient(ellipse 60% 80% at 50% 80%, #ff9f00 0%, #ff6600 40%, #c43300 70%, transparent 100%);
  border-radius: 50% 50% 20% 20%;
  animation: flicker 1.8s ease-in-out infinite alternate;
  position:relative;
  filter: blur(1px);
  box-shadow: 0 0 12px 6px rgba(255,140,0,0.4), 0 0 30px 10px rgba(200,80,0,0.2);
}
.candle-body {
  width:14px; height:50px;
  background: linear-gradient(to bottom, #e8dcc8, #c8b898, #a09070);
  margin:0 auto;
  border-radius:2px 2px 0 0;
  position:relative;
}
.candle-body::after {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0; height:8px;
  background: rgba(0,0,0,0.2);
  border-radius:0 0 2px 2px;
}
.candle-light {
  position:absolute;
  width:120px; height:120px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(255,160,40,0.15) 0%, transparent 70%);
  top:-50px; left:50%;
  transform:translateX(-50%);
  animation: flicker-light 1.8s ease-in-out infinite alternate;
}

@keyframes flicker {
  0%   { transform: scaleX(1)   scaleY(1)   rotate(-1deg); opacity:1; }
  25%  { transform: scaleX(0.95) scaleY(1.05) rotate(1deg);  opacity:0.95; }
  50%  { transform: scaleX(1.05) scaleY(0.95) rotate(-2deg); opacity:1; }
  75%  { transform: scaleX(0.9) scaleY(1.08) rotate(0.5deg); opacity:0.9; }
  100% { transform: scaleX(1)   scaleY(1)   rotate(1deg);  opacity:1; }
}
@keyframes flicker-light {
  0%   { opacity:0.8; transform:translateX(-50%) scale(1); }
  50%  { opacity:0.6; transform:translateX(-50%) scale(1.1); }
  100% { opacity:0.9; transform:translateX(-50%) scale(0.9); }
}

/* ===== MAIN LAYOUT ===== */
#game-wrapper {
  position:relative;
  z-index:2;
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding: var(--wrap-pad);
  padding-left: max(8px, env(safe-area-inset-left));
  padding-right: max(8px, env(safe-area-inset-right));
  padding-bottom: max(20px, env(safe-area-inset-bottom));
}

/* ===== TITLE ===== */
.game-title {
  text-align:center;
  padding: 18px 0 10px;
}
.game-title h1 {
  font-family:'Cinzel', serif;
  font-size: clamp(2rem, 5vw, 3.4rem);
  font-weight:700;
  letter-spacing:0.12em;
  color: var(--gold-light);
  text-shadow:
    0 0 20px var(--gold-glow),
    0 0 60px rgba(201,168,76,0.2),
    2px 3px 8px rgba(0,0,0,0.8);
}
.game-title .subtitle {
  font-family:'IM Fell English', serif;
  font-style:italic;
  color: var(--parchment-dark);
  font-size:1.05rem;
  letter-spacing:0.1em;
  margin-top:2px;
}

.identity-bar {
  width: 100%;
  max-width: 800px;
  display: flex;
  gap: 10px;
  margin: 2px auto 8px;
  align-items: center;
}

.identity-input {
  flex: 1;
  background: rgba(20,12,4,0.8);
  border: 1px solid rgba(201,168,76,0.3);
  border-radius: 4px;
  padding: 8px 12px;
  font-family: 'Crimson Text', serif;
  font-size: 0.95rem;
  color: var(--cream);
  outline: none;
}

.identity-input:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(201,168,76,0.12);
}

.identity-bar .btn-restart {
  flex: 0;
  min-width: 140px;
}

/* ===== DECORATIVE DIVIDER ===== */
.divider {
  display:flex;
  align-items:center;
  gap:12px;
  width:100%;
  max-width:800px;
  margin:6px auto;
}
.divider-line {
  flex:1;
  height:1px;
  background: linear-gradient(to right, transparent, var(--gold-dark), var(--gold), var(--gold-dark), transparent);
}
.divider-gem {
  width:10px; height:10px;
  background: var(--gold);
  transform:rotate(45deg);
  box-shadow:0 0 8px var(--gold-glow);
}

/* ===== SCOREBOARD ===== */
.scoreboard {
  display:flex;
  gap:14px;
  width:100%;
  max-width:800px;
  margin: 8px auto;
}
.player-card {
  flex:1;
  background: linear-gradient(135deg, rgba(45,25,8,0.95) 0%, rgba(30,15,4,0.98) 100%);
  border:1px solid var(--gold-dark);
  border-radius:6px;
  padding: var(--card-pad);
  position:relative;
  overflow:hidden;
  transition: all 0.4s ease;
  box-shadow: inset 0 1px 0 rgba(201,168,76,0.1), 0 4px 20px rgba(0,0,0,0.5);
}
.player-card::before {
  content:'';
  position:absolute;
  inset:0;
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 10px,
    rgba(201,168,76,0.015) 10px,
    rgba(201,168,76,0.015) 11px
  );
}
.player-card.active {
  border-color: var(--gold);
  box-shadow:
    inset 0 1px 0 rgba(201,168,76,0.2),
    0 0 0 1px rgba(201,168,76,0.3),
    0 0 30px rgba(201,168,76,0.15),
    0 4px 20px rgba(0,0,0,0.5);
}
.player-card.active::after {
  content:'';
  position:absolute;
  top:0; left:0; right:0; height:2px;
  background: linear-gradient(to right, transparent, var(--gold-light), transparent);
  animation: shimmer 2s ease-in-out infinite;
}
@keyframes shimmer {
  0%,100% { opacity:0.6; }
  50%      { opacity:1; }
}

.player-name {
  font-family:'Cinzel', serif;
  font-size:0.85rem;
  letter-spacing:0.12em;
  color: var(--gold-dark);
  text-transform:uppercase;
  margin-bottom:2px;
}
.player-card.active .player-name { color:var(--gold-light); }

.player-score {
  font-family:'Cinzel', serif;
  font-size: var(--score-font);
  font-weight:700;
  color: var(--cream);
  line-height:1;
  text-shadow: 0 0 15px rgba(201,168,76,0.3), 2px 2px 4px rgba(0,0,0,0.8);
}
.player-card.active .player-score {
  color: var(--gold-light);
  text-shadow: 0 0 20px var(--gold-glow), 2px 2px 4px rgba(0,0,0,0.8);
}

.turn-indicator {
  position:absolute;
  top:10px; right:12px;
  font-size:0.7rem;
  font-family:'Cinzel', serif;
  letter-spacing:0.1em;
  color: var(--gold);
  opacity:0;
  transition: opacity 0.3s;
}
.player-card.active .turn-indicator { opacity:1; }

.turn-score-label {
  font-size:0.72rem;
  color: var(--parchment-dark);
  font-style:italic;
  margin-top:4px;
}
.turn-score-val {
  font-family:'Cinzel', serif;
  font-size:1rem;
  color: var(--gold);
}

/* ===== STATUS BAR ===== */
.status-bar {
  width:100%;
  max-width:800px;
  margin:6px auto;
  text-align:center;
  min-height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.status-msg {
  font-family:'IM Fell English', serif;
  font-style:italic;
  font-size: clamp(0.85rem, 2.5vw, 1.1rem);
  color: var(--cream-dim);
  padding:6px 20px;
  border-radius:4px;
  transition:all 0.4s ease;
  letter-spacing:0.03em;
}
.status-msg.farkle {
  color:#ff6060;
  font-size:1.4rem;
  text-shadow:0 0 20px rgba(255,60,60,0.6);
  animation: farkle-shake 0.5s ease-in-out;
}
.status-msg.bank {
  color:var(--gold-light);
  text-shadow:0 0 15px var(--gold-glow);
}
.status-msg.win {
  color:var(--gold-light);
  font-size:1.5rem;
  text-shadow:0 0 30px var(--gold-glow);
  animation: win-pulse 1s ease-in-out infinite alternate;
}

.toast-stack {
  position: fixed;
  top: 14px;
  right: 14px;
  z-index: 120;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}

.toast {
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.24s ease, transform 0.24s ease;
  font-family: 'Cinzel', serif;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  padding: 8px 12px;
  border-radius: 4px;
  border: 1px solid rgba(201,168,76,0.35);
  background: rgba(12,8,3,0.92);
  color: var(--cream);
  box-shadow: 0 6px 16px rgba(0,0,0,0.45);
}

.toast.show {
  opacity: 1;
  transform: translateY(0);
}

.toast.success {
  border-color: rgba(90, 180, 70, 0.6);
  color: #c5f0b8;
}

.toast.error {
  border-color: rgba(220, 80, 80, 0.65);
  color: #ffd0d0;
}
@keyframes farkle-shake {
  0%,100% { transform:translateX(0); }
  20%     { transform:translateX(-8px); }
  40%     { transform:translateX(8px); }
  60%     { transform:translateX(-6px); }
  80%     { transform:translateX(6px); }
}
@keyframes win-pulse {
  0%   { text-shadow:0 0 20px var(--gold-glow); }
  100% { text-shadow:0 0 50px rgba(201,168,76,0.8), 0 0 80px rgba(201,168,76,0.4); }
}

/* ===== DICE TABLE ===== */
.dice-table-wrap {
  width:100%;
  max-width:800px;
  margin:6px auto;
  position:relative;
}
.table-border {
  position:absolute;
  inset: -8px;
  border-radius:16px;
  background: linear-gradient(135deg, #4a2e0e, #2a1806, #3d2410, #1e0f04);
  box-shadow:
    0 0 0 2px rgba(201,168,76,0.3),
    0 0 0 4px rgba(0,0,0,0.8),
    0 8px 40px rgba(0,0,0,0.8),
    inset 0 1px 0 rgba(255,255,255,0.05);
}
.table-border::before {
  content:'';
  position:absolute;
  inset:3px;
  border-radius:13px;
  border:1px solid rgba(201,168,76,0.15);
}

.dice-table {
  position:relative;
  background:
    radial-gradient(ellipse 60% 50% at 50% 40%, rgba(30,70,40,0.3) 0%, transparent 70%),
    linear-gradient(160deg, #1e4230 0%, #163322 40%, #0f2218 100%);
  border-radius:12px;
  padding: var(--table-pad);
  min-height: clamp(130px, 28vw, 200px);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:
    inset 0 2px 20px rgba(0,0,0,0.5),
    inset 0 -2px 10px rgba(0,0,0,0.3);
}

/* Felt texture */
.dice-table::before {
  content:'';
  position:absolute;
  inset:0;
  border-radius:12px;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,0.03) 2px, rgba(0,0,0,0.03) 3px),
    repeating-linear-gradient(90deg, transparent, transparent 2px, rgba(0,0,0,0.03) 2px, rgba(0,0,0,0.03) 3px);
  pointer-events:none;
}

.dice-container {
  display:flex;
  flex-wrap:wrap;
  gap: var(--gap);
  justify-content:center;
  align-items:center;
  position:relative;
  z-index:1;
}

/* ===== DICE ===== */
.die-wrap {
  perspective: 500px;
  cursor:pointer;
  position:relative;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.die {
  width: var(--die-size);
  height: var(--die-size);
  position:relative;
  transform-style: preserve-3d;
  transition: transform 0.15s ease;
}
.die-wrap:hover .die:not(.rolling) { transform: translateY(-3px) rotateX(5deg); }

.die-face {
  position:absolute;
  inset:0;
  background: linear-gradient(135deg, var(--dice-white) 0%, #e8d8b8 60%, #d4c4a0 100%);
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  padding:8px;
  box-shadow:
    inset 0 2px 4px rgba(255,255,255,0.5),
    inset 0 -2px 4px rgba(0,0,0,0.2),
    2px 4px 12px rgba(0,0,0,0.6),
    0 0 0 1px rgba(0,0,0,0.2);
}

/* Parchment texture on dice */
.die-face::before {
  content:'';
  position:absolute;
  inset:0;
  border-radius:10px;
  background-image: radial-gradient(ellipse 80% 80% at 30% 30%, rgba(255,255,255,0.15), transparent);
  pointer-events:none;
}

.pip-grid {
  display:grid;
  width:100%;
  height:100%;
  position:relative;
}

/* Pip layouts per face value */
.pip-grid[data-val="1"] { place-items:center; }
.pip-grid[data-val="2"] { grid-template-rows:1fr 1fr; grid-template-columns:1fr; }
.pip-grid[data-val="3"] { grid-template-rows:1fr 1fr 1fr; grid-template-columns:1fr; }
.pip-grid[data-val="4"] { grid-template-rows:1fr 1fr; grid-template-columns:1fr 1fr; }
.pip-grid[data-val="5"] { grid-template-rows:1fr 1fr 1fr; grid-template-columns:1fr 1fr; }
.pip-grid[data-val="6"] { grid-template-rows:1fr 1fr 1fr; grid-template-columns:1fr 1fr; }

.pip {
  width: var(--pip-size); height: var(--pip-size);
  background: radial-gradient(circle at 40% 35%, #3d2818, var(--dice-pip));
  border-radius:50%;
  box-shadow: inset 0 1px 2px rgba(255,255,255,0.1), 0 1px 2px rgba(0,0,0,0.4);
}

/* Pip positions */
.pip-grid[data-val="1"] .pip { grid-area:1/1/2/2; place-self:center; }
.pip-grid[data-val="2"] .pip:nth-child(1) { place-self:start end; }
.pip-grid[data-val="2"] .pip:nth-child(2) { place-self:end start; }
.pip-grid[data-val="3"] .pip:nth-child(1) { place-self:start end; }
.pip-grid[data-val="3"] .pip:nth-child(2) { place-self:center; }
.pip-grid[data-val="3"] .pip:nth-child(3) { place-self:end start; }
.pip-grid[data-val="4"] .pip { place-self:center; }
.pip-grid[data-val="4"] .pip:nth-child(1) { place-self:start start; margin:2px; }
.pip-grid[data-val="4"] .pip:nth-child(2) { place-self:start end; margin:2px; }
.pip-grid[data-val="4"] .pip:nth-child(3) { place-self:end start; margin:2px; }
.pip-grid[data-val="4"] .pip:nth-child(4) { place-self:end end; margin:2px; }
.pip-grid[data-val="5"] {
  grid-template-areas:
    "a . b"
    ". c ."
    "d . e";
  grid-template-rows:1fr 1fr 1fr;
  grid-template-columns:1fr 1fr 1fr;
}
.pip-grid[data-val="5"] .pip:nth-child(1) { grid-area:a; place-self:start center; }
.pip-grid[data-val="5"] .pip:nth-child(2) { grid-area:b; place-self:start center; }
.pip-grid[data-val="5"] .pip:nth-child(3) { grid-area:c; place-self:center center; }
.pip-grid[data-val="5"] .pip:nth-child(4) { grid-area:d; place-self:end center; }
.pip-grid[data-val="5"] .pip:nth-child(5) { grid-area:e; place-self:end center; }
.pip-grid[data-val="6"] { grid-template-rows:1fr 1fr 1fr; grid-template-columns:1fr 1fr; }
.pip-grid[data-val="6"] .pip { place-self:center; margin:2px; }

/* Die states */
.die-wrap.selected .die-face {
  background: linear-gradient(135deg, #ffe8a0 0%, #f0c84a 60%, #d4a820 100%);
  box-shadow:
    inset 0 2px 4px rgba(255,255,255,0.5),
    inset 0 -2px 4px rgba(0,0,0,0.2),
    2px 4px 12px rgba(0,0,0,0.4),
    0 0 0 2px var(--gold),
    0 0 20px var(--selected-glow),
    0 0 40px rgba(201,168,76,0.3);
  animation: selected-pulse 1.5s ease-in-out infinite alternate;
}
@keyframes selected-pulse {
  0%   { box-shadow: inset 0 2px 4px rgba(255,255,255,0.5),inset 0 -2px 4px rgba(0,0,0,0.2),2px 4px 12px rgba(0,0,0,0.4),0 0 0 2px var(--gold),0 0 15px var(--selected-glow); }
  100% { box-shadow: inset 0 2px 4px rgba(255,255,255,0.5),inset 0 -2px 4px rgba(0,0,0,0.2),2px 4px 12px rgba(0,0,0,0.4),0 0 0 2px var(--gold-light),0 0 30px rgba(201,168,76,0.7),0 0 50px rgba(201,168,76,0.3); }
}

.die-wrap.locked {
  cursor:default;
  opacity:0.45;
  filter:grayscale(0.3);
}
.die-wrap.locked .die-face {
  background: linear-gradient(135deg, #c0b098, #a89070, #90785a);
}

.die-wrap.farkle-flash .die-face {
  animation: farkle-flash 0.5s ease-in-out 3;
}
@keyframes farkle-flash {
  0%,100% { box-shadow:inset 0 2px 4px rgba(255,255,255,0.5),inset 0 -2px 4px rgba(0,0,0,0.2),2px 4px 12px rgba(0,0,0,0.6); }
  50%     { box-shadow:inset 0 2px 4px rgba(255,80,80,0.5),inset 0 -2px 4px rgba(0,0,0,0.2),2px 4px 12px rgba(255,60,60,0.6),0 0 20px rgba(255,60,60,0.8); }
}

/* Roll animation - JS-driven per die, CSS handles keyframes */
@keyframes die-roll-1 {
  0%   { transform: translate(0,0) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1); }
  15%  { transform: translate(-18px,-28px) rotateX(220deg) rotateY(140deg) rotateZ(80deg) scale(1.18); }
  35%  { transform: translate(12px,-38px) rotateX(480deg) rotateY(300deg) rotateZ(160deg) scale(1.22); }
  55%  { transform: translate(-8px,-18px) rotateX(680deg) rotateY(460deg) rotateZ(240deg) scale(1.08); }
  72%  { transform: translate(6px,-8px) rotateX(820deg) rotateY(580deg) rotateZ(290deg) scale(1.03); }
  85%  { transform: translate(-3px,-3px) rotateX(900deg) rotateY(640deg) rotateZ(320deg) scale(1.01); }
  93%  { transform: translate(2px,0px) rotateX(930deg) rotateY(670deg) rotateZ(338deg) scale(1); }
  100% { transform: translate(0,0) rotateX(960deg) rotateY(700deg) rotateZ(360deg) scale(1); }
}
@keyframes die-roll-2 {
  0%   { transform: translate(0,0) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1); }
  12%  { transform: translate(22px,-32px) rotateX(180deg) rotateY(260deg) rotateZ(110deg) scale(1.2); }
  30%  { transform: translate(-14px,-44px) rotateX(400deg) rotateY(480deg) rotateZ(220deg) scale(1.25); }
  52%  { transform: translate(10px,-22px) rotateX(620deg) rotateY(660deg) rotateZ(290deg) scale(1.1); }
  70%  { transform: translate(-5px,-10px) rotateX(780deg) rotateY(780deg) rotateZ(330deg) scale(1.04); }
  84%  { transform: translate(3px,-3px) rotateX(870deg) rotateY(840deg) rotateZ(352deg) scale(1.01); }
  100% { transform: translate(0,0) rotateX(900deg) rotateY(900deg) rotateZ(360deg) scale(1); }
}
@keyframes die-roll-3 {
  0%   { transform: translate(0,0) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1); }
  18%  { transform: translate(-24px,-24px) rotateX(300deg) rotateY(180deg) rotateZ(60deg) scale(1.15); }
  38%  { transform: translate(16px,-40px) rotateX(540deg) rotateY(380deg) rotateZ(140deg) scale(1.2); }
  58%  { transform: translate(-10px,-16px) rotateX(720deg) rotateY(520deg) rotateZ(220deg) scale(1.07); }
  76%  { transform: translate(5px,-6px) rotateX(850deg) rotateY(620deg) rotateZ(295deg) scale(1.02); }
  100% { transform: translate(0,0) rotateX(1080deg) rotateY(720deg) rotateZ(360deg) scale(1); }
}
@keyframes die-roll-4 {
  0%   { transform: translate(0,0) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1); }
  14%  { transform: translate(26px,-18px) rotateX(260deg) rotateY(200deg) rotateZ(90deg) scale(1.16); }
  32%  { transform: translate(-20px,-48px) rotateX(610deg) rotateY(450deg) rotateZ(205deg) scale(1.24); }
  56%  { transform: translate(14px,-22px) rotateX(840deg) rotateY(650deg) rotateZ(290deg) scale(1.1); }
  78%  { transform: translate(-6px,-8px) rotateX(980deg) rotateY(760deg) rotateZ(330deg) scale(1.03); }
  100% { transform: translate(0,0) rotateX(1120deg) rotateY(840deg) rotateZ(360deg) scale(1); }
}
@keyframes die-roll-5 {
  0%   { transform: translate(0,0) rotateX(0deg) rotateY(0deg) rotateZ(0deg) scale(1); }
  10%  { transform: translate(-16px,-30px) rotateX(240deg) rotateY(140deg) rotateZ(75deg) scale(1.14); }
  28%  { transform: translate(24px,-46px) rotateX(520deg) rotateY(410deg) rotateZ(180deg) scale(1.22); }
  50%  { transform: translate(-18px,-24px) rotateX(760deg) rotateY(620deg) rotateZ(265deg) scale(1.11); }
  72%  { transform: translate(8px,-10px) rotateX(920deg) rotateY(760deg) rotateZ(318deg) scale(1.04); }
  100% { transform: translate(0,0) rotateX(1080deg) rotateY(900deg) rotateZ(360deg) scale(1); }
}
@keyframes die-shadow-pulse {
  0%,100% { box-shadow: 2px 4px 12px rgba(0,0,0,0.6), 0 0 0 1px rgba(0,0,0,0.2); }
  40%     { box-shadow: 6px 14px 28px rgba(0,0,0,0.8), 0 0 0 1px rgba(0,0,0,0.3); }
}
.die.rolling {
  animation: die-shadow-pulse 0.9s ease-in-out;
}

.dice-container.rolling {
  animation: table-rumble 380ms linear infinite;
}

.die-wrap.rolling {
  z-index: 2;
}

.die-wrap.rolling .die-face {
  animation: die-face-strobe 120ms linear infinite;
}

@keyframes table-rumble {
  0%   { transform: translateX(0) translateY(0); }
  25%  { transform: translateX(-1px) translateY(1px); }
  50%  { transform: translateX(1px) translateY(-1px); }
  75%  { transform: translateX(-1px) translateY(-1px); }
  100% { transform: translateX(0) translateY(0); }
}

@keyframes die-face-strobe {
  0%   { filter: blur(0.2px) brightness(1.05); }
  50%  { filter: blur(0.9px) brightness(1.2); }
  100% { filter: blur(0.2px) brightness(1.05); }
}

/* ===== INFO STRIP ===== */
.info-strip {
  display:flex;
  gap:10px;
  width:100%;
  max-width:800px;
  margin:8px auto;
}
.info-chip {
  flex:1;
  background: rgba(20,10,3,0.8);
  border:1px solid rgba(201,168,76,0.2);
  border-radius:6px;
  padding:8px 14px;
  text-align:center;
}
.info-chip .label {
  font-size:0.68rem;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color: var(--parchment-dark);
  font-family:'Cinzel', serif;
}
.info-chip .value {
  font-family:'Cinzel', serif;
  font-size:1.3rem;
  color: var(--gold-light);
  text-shadow:0 0 10px rgba(201,168,76,0.4);
}
.info-chip.highlight { border-color:rgba(201,168,76,0.5); background:rgba(30,18,5,0.9); }

/* ===== BUTTONS ===== */
.action-bar {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  width:100%;
  max-width:800px;
  margin:8px auto;
}

.is-hidden {
  display: none !important;
}

.btn {
  font-family:'Cinzel', serif;
  font-size: var(--btn-font);
  letter-spacing:0.1em;
  font-weight:600;
  padding: var(--btn-pad);
  border:none;
  border-radius:5px;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transition: all 0.25s ease;
  text-transform:uppercase;
  flex:1;
  min-width:120px;
  max-width:200px;
}

.btn::before {
  content:'';
  position:absolute;
  top:0; left:-100%;
  width:100%; height:100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
  transition:left 0.4s ease;
}
.btn:hover::before { left:100%; }

.btn:disabled {
  opacity:0.35;
  cursor:not-allowed;
  filter:grayscale(0.5);
}
.btn:disabled::before { display:none; }

/* Roll button */
.btn-roll {
  background: linear-gradient(135deg, #c43300 0%, #9a2800 50%, #7a1c00 100%);
  color: #ffd0a0;
  box-shadow:
    0 3px 0 #4a0e00,
    0 4px 15px rgba(196,51,0,0.4),
    inset 0 1px 0 rgba(255,180,120,0.2);
  border:1px solid rgba(196,80,0,0.3);
  text-shadow:1px 1px 3px rgba(0,0,0,0.6);
}
.btn-roll:not(:disabled):hover {
  background: linear-gradient(135deg, #d84800 0%, #b03200 50%, #8a2400 100%);
  transform:translateY(-2px);
  box-shadow:
    0 5px 0 #4a0e00,
    0 6px 20px rgba(220,80,0,0.5),
    inset 0 1px 0 rgba(255,180,120,0.2);
}
.btn-roll:not(:disabled):active { transform:translateY(1px); box-shadow:0 2px 0 #4a0e00,0 3px 10px rgba(196,51,0,0.4),inset 0 1px 0 rgba(255,180,120,0.2); }

/* Bank button */
.btn-bank {
  background: linear-gradient(135deg, #4a7a1e 0%, #355a12 50%, #254508 100%);
  color: #c0e890;
  box-shadow:
    0 3px 0 #122800,
    0 4px 15px rgba(50,120,20,0.3),
    inset 0 1px 0 rgba(160,255,80,0.1);
  border:1px solid rgba(80,160,30,0.2);
  text-shadow:1px 1px 3px rgba(0,0,0,0.6);
}
.btn-bank:not(:disabled):hover {
  background: linear-gradient(135deg, #5a9028 0%, #456a1c 50%, #355510 100%);
  transform:translateY(-2px);
  box-shadow:
    0 5px 0 #122800,
    0 6px 20px rgba(60,160,20,0.4),
    inset 0 1px 0 rgba(160,255,80,0.1);
}
.btn-bank:not(:disabled):active { transform:translateY(1px); }

/* Reset turn button */
.btn-reset {
  background: linear-gradient(135deg, #3a2a18 0%, #2a1e0e 50%, #1e1408 100%);
  color: var(--parchment-dark);
  box-shadow:
    0 3px 0 #0a0804,
    0 4px 10px rgba(0,0,0,0.4),
    inset 0 1px 0 rgba(201,168,76,0.08);
  border:1px solid rgba(201,168,76,0.15);
  flex:0.5;
  min-width:90px;
}
.btn-reset:not(:disabled):hover {
  background: linear-gradient(135deg, #4a3a28 0%, #3a2e1e 50%, #2e2010 100%);
  transform:translateY(-1px);
  color:var(--parchment);
}

#btn-offline-play {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.15em;
}

/* Restart button */
.btn-restart {
  background: linear-gradient(135deg, #1a1005 0%, #0f0802 100%);
  color: var(--gold-dark);
  box-shadow:
    0 3px 0 #050302,
    0 4px 10px rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(201,168,76,0.05);
  border:1px solid rgba(201,168,76,0.1);
  flex:0.5;
  min-width:90px;
  font-size:0.8rem;
}
.btn-restart:hover {
  border-color:rgba(201,168,76,0.3);
  color:var(--gold);
  transform:translateY(-1px);
}

.btn-disconnect {
  background: linear-gradient(135deg, #4b1111 0%, #2c0a0a 100%);
  color: #f0c2c2;
  border: 1px solid rgba(195, 88, 88, 0.35);
  box-shadow:
    0 3px 0 #180404,
    0 4px 12px rgba(90,20,20,0.45),
    inset 0 1px 0 rgba(255,170,170,0.08);
  flex: 0.95;
  min-width: 132px;
  max-width: 196px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  white-space: nowrap;
  letter-spacing: 0.07em;
}

.btn-disconnect:hover {
  border-color: rgba(220, 112, 112, 0.55);
  color: #ffd7d7;
  transform: translateY(-1px);
}

.lobby-actions .btn-disconnect,
.lobby-actions #btn-rejoin-room {
  flex: 0.95;
  min-width: 132px;
  max-width: 196px;
}

/* ===== SCORING COMBOS DISPLAY ===== */
.score-combos {
  width:100%;
  max-width:800px;
  margin:6px auto;
  background: rgba(10,6,2,0.7);
  border:1px solid rgba(201,168,76,0.1);
  border-radius:6px;
  padding:10px 16px;
  min-height:36px;
}
.combos-title {
  font-family:'Cinzel', serif;
  font-size:0.65rem;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--parchment-dark);
  margin-bottom:6px;
}
.combo-tags {
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.combo-tag {
  background: rgba(201,168,76,0.1);
  border:1px solid rgba(201,168,76,0.25);
  border-radius:3px;
  padding:3px 10px;
  font-size:0.78rem;
  color:var(--gold-light);
  font-family:'Cinzel', serif;
  letter-spacing:0.05em;
  animation: tag-appear 0.3s ease;
}
@keyframes tag-appear {
  from { opacity:0; transform:scale(0.8) translateY(4px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}

/* ===== RULES PANEL ===== */
.rules-toggle {
  background:none;
  border:1px solid rgba(201,168,76,0.15);
  color:var(--parchment-dark);
  font-family:'Cinzel', serif;
  font-size:0.7rem;
  letter-spacing:0.1em;
  padding:5px 14px;
  border-radius:3px;
  cursor:pointer;
  transition:all 0.25s;
  width:100%;
  max-width:800px;
  margin:4px auto;
  display:block;
}
.rules-toggle:hover { border-color:rgba(201,168,76,0.4); color:var(--parchment); }

.rules-panel {
  width:100%;
  max-width:800px;
  margin:0 auto;
  background: rgba(10,6,2,0.85);
  border:1px solid rgba(201,168,76,0.15);
  border-radius:6px;
  padding:16px 20px;
  display:none;
}
.rules-panel.open { display:block; animation:fade-in 0.3s ease; }
@keyframes fade-in {
  from { opacity:0; transform:translateY(-8px); }
  to   { opacity:1; transform:translateY(0); }
}

.chat-fab {
  position: fixed;
  right: 14px;
  bottom: max(16px, env(safe-area-inset-bottom));
  z-index: 165;
  min-width: 88px;
  height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(201,168,76,0.35);
  background: linear-gradient(180deg, rgba(30,19,8,0.95), rgba(14,9,4,0.95));
  color: var(--cream);
  font-family: 'Cinzel', serif;
  font-size: 0.72rem;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,0.42), inset 0 1px 0 rgba(255,255,255,0.06);
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.chat-fab:hover {
  transform: translateY(-1px);
  border-color: rgba(201,168,76,0.58);
}

.chat-fab.has-unread {
  border-color: rgba(140, 186, 104, 0.68);
  box-shadow: 0 6px 18px rgba(0,0,0,0.42), 0 0 18px rgba(140, 186, 104, 0.24);
  animation: chat-fab-pulse 1.8s ease-in-out infinite;
}

.chat-fab-badge {
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: rgba(130, 182, 94, 0.18);
  border: 1px solid rgba(130, 182, 94, 0.5);
  color: #bfe8a1;
  font-size: 0.6rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.chat-panel {
  position: fixed;
  right: 14px;
  bottom: calc(max(16px, env(safe-area-inset-bottom)) + 48px);
  z-index: 166;
  width: min(360px, calc(100vw - 20px));
  height: min(420px, 62vh);
  display: flex;
  flex-direction: column;
  border-radius: 12px;
  border: 1px solid rgba(201,168,76,0.24);
  background: linear-gradient(170deg, rgba(30,17,7,0.95), rgba(12,8,3,0.95));
  box-shadow: 0 22px 48px rgba(0,0,0,0.56), inset 0 1px 0 rgba(255,255,255,0.05);
  overflow: hidden;
  opacity: 0;
  transform: translateY(10px) scale(0.97);
  pointer-events: none;
  transition: opacity 0.22s ease, transform 0.22s ease;
}

.chat-panel.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

@media (min-width: 600px) {
  .chat-fab {
    bottom: max(22px, env(safe-area-inset-bottom));
  }

  .chat-panel {
    bottom: calc(max(22px, env(safe-area-inset-bottom)) + 48px);
  }
}

.chat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(201,168,76,0.14);
  background: rgba(0,0,0,0.16);
}

.chat-head h3 {
  margin: 0;
  font-family: 'Cinzel', serif;
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-light);
}

.chat-close {
  all: unset;
  box-sizing: border-box;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  border: 1px solid rgba(201,168,76,0.24);
  color: var(--parchment);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color 0.18s ease, color 0.18s ease;
}

.chat-close:hover {
  border-color: rgba(201,168,76,0.54);
  color: var(--cream);
}

.chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 10px 10px 8px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.chat-empty {
  margin: auto;
  text-align: center;
  color: var(--parchment-dark);
  font-family: 'IM Fell English', serif;
  font-style: italic;
  font-size: 0.95rem;
}

.chat-msg {
  max-width: 88%;
  padding: 7px 9px;
  border-radius: 10px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.14);
  color: var(--cream);
  align-self: flex-start;
  animation: chat-msg-in 0.18s ease;
}

.chat-msg.mine {
  align-self: flex-end;
  background: rgba(108, 158, 80, 0.14);
  border-color: rgba(120, 180, 92, 0.3);
}

.chat-msg-name {
  font-family: 'Cinzel', serif;
  font-size: 0.58rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gold);
  margin-bottom: 2px;
}

.chat-msg-text {
  font-size: 0.9rem;
  line-height: 1.35;
  word-break: break-word;
}

.chat-msg-time {
  margin-top: 4px;
  font-size: 0.64rem;
  color: var(--parchment-dark);
  text-align: right;
}

.chat-input-row {
  display: flex;
  gap: 8px;
  padding: 8px;
  border-top: 1px solid rgba(201,168,76,0.14);
  background: rgba(0,0,0,0.14);
}

#chat-input {
  flex: 1;
  min-width: 0;
  height: 34px;
  border-radius: 8px;
  border: 1px solid rgba(201,168,76,0.26);
  background: rgba(20,12,4,0.82);
  color: var(--cream);
  font-family: 'Crimson Text', serif;
  font-size: 0.95rem;
  padding: 0 10px;
  outline: none;
}

#chat-input:focus {
  border-color: rgba(201,168,76,0.6);
  box-shadow: 0 0 0 2px rgba(201,168,76,0.12);
}

#btn-chat-send {
  min-width: 70px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid rgba(201,168,76,0.35);
  background: linear-gradient(180deg, rgba(34,22,9,0.95), rgba(16,10,4,0.95));
  color: var(--cream);
  font-family: 'Cinzel', serif;
  font-size: 0.64rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
}

#btn-chat-send:hover {
  border-color: rgba(201,168,76,0.62);
}

@keyframes chat-msg-in {
  from { opacity: 0; transform: translateY(5px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes chat-fab-pulse {
  0%, 100% { box-shadow: 0 6px 18px rgba(0,0,0,0.42), 0 0 14px rgba(140, 186, 104, 0.2); }
  50% { box-shadow: 0 6px 18px rgba(0,0,0,0.42), 0 0 24px rgba(140, 186, 104, 0.32); }
}

.rules-panel h3 {
  font-family:'Cinzel', serif;
  color:var(--gold);
  font-size:0.85rem;
  letter-spacing:0.12em;
  margin-bottom:10px;
  text-align:center;
}
.rules-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px 20px;
}
.rule-row {
  display:flex;
  justify-content:space-between;
  font-size:0.8rem;
  color:var(--cream-dim);
  padding:3px 0;
  border-bottom:1px solid rgba(201,168,76,0.06);
}
.rule-row span:last-child { color:var(--gold); font-family:'Cinzel', serif; }

/* Init roll button override */
#btn-init-roll {
  flex: none;
  width: auto;
  min-width: 160px;
  max-width: 200px;
  margin: 0 auto;
}

/* ===== START SCREEN ===== */
#start-screen {
  position:fixed;
  inset:0;
  z-index:100;
  background: linear-gradient(160deg, #1a0a03 0%, #0d0703 50%, #0a0500 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: clamp(16px, 4vw, 40px);
  padding-bottom: max(16px, env(safe-area-inset-bottom));
  overflow-y: auto;
  overscroll-behavior: contain;
  gap: 0;
}

#start-screen > * {
  width: min(560px, 94vw);
}

#start-screen .start-dice-row,
#start-screen .name-inputs,
#start-screen .target-select,
#start-screen .action-bar,
#start-screen .rules-open-btn,
#start-screen .ready-panel,
#start-screen .ready-toggle,
#start-screen .start-primary-actions,
#start-screen #btn-start-online,
#start-screen #lobby-status,
#start-screen .menu-mini-actions {
  margin-left: auto;
  margin-right: auto;
}

.start-title {
  font-family:'Cinzel', serif;
  font-size:clamp(1.8rem, 8vw, 5rem);
  color:var(--gold-light);
  text-shadow:0 0 40px var(--gold-glow), 0 0 80px rgba(201,168,76,0.2), 3px 5px 10px rgba(0,0,0,0.9);
  letter-spacing:0.15em;
  margin-bottom:8px;
  animation:title-glow 3s ease-in-out infinite alternate;
}
@keyframes title-glow {
  0%   { text-shadow:0 0 30px var(--gold-glow),0 0 60px rgba(201,168,76,0.15),3px 5px 10px rgba(0,0,0,0.9); }
  100% { text-shadow:0 0 60px rgba(201,168,76,0.6),0 0 100px rgba(201,168,76,0.3),3px 5px 10px rgba(0,0,0,0.9); }
}

.start-sub {
  font-family:'IM Fell English', serif;
  font-style:italic;
  color:var(--parchment-dark);
  font-size:clamp(0.85rem, 2.5vw, 1.1rem);
  letter-spacing:0.1em;
  margin-bottom: clamp(16px, 4vh, 40px);
}

.start-dice-row {
  display:flex;
  gap: clamp(8px, 2vw, 14px);
  justify-content:center;
  margin-bottom: clamp(16px, 4vh, 40px);
  flex-wrap: wrap;
}
.start-die {
  width:56px; height:56px;
  background: linear-gradient(135deg, #f5ead8 0%, #e8d8b8 60%, #d4c4a0 100%);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem;
  box-shadow:3px 5px 15px rgba(0,0,0,0.7), inset 0 2px 4px rgba(255,255,255,0.4);
  color:var(--dice-pip);
  animation: float-die 2s ease-in-out infinite alternate;
}
.start-die:nth-child(1) { animation-delay:0s; }
.start-die:nth-child(2) { animation-delay:0.3s; }
.start-die:nth-child(3) { animation-delay:0.6s; }
.start-die:nth-child(4) { animation-delay:0.9s; }
.start-die:nth-child(5) { animation-delay:1.2s; }
.start-die:nth-child(6) { animation-delay:1.5s; }
#easter-d20-trigger {
  cursor: pointer;
}
@keyframes float-die {
  from { transform:translateY(0) rotate(0deg); }
  to   { transform:translateY(-8px) rotate(4deg); }
}

.d20-easter-egg {
  position: fixed;
  inset: 0;
  z-index: 185;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: radial-gradient(circle at 50% 50%, rgba(201,168,76,0.2), rgba(0,0,0,0.78) 70%);
  pointer-events: none;
}

.d20-easter-egg.show {
  display: flex;
  animation: d20-overlay-in 0.25s ease-out;
}

.d20-easter-card {
  text-align: center;
  display: grid;
  justify-items: center;
  gap: 14px;
  animation: d20-card-pop 0.38s cubic-bezier(0.22, 1, 0.36, 1);
}

.d20-easter-text {
  font-family: 'Cinzel', serif;
  font-size: clamp(0.95rem, 3.1vw, 1.7rem);
  letter-spacing: 0.12em;
  color: #ffe7b5;
  text-shadow: 0 0 18px rgba(201,168,76,0.6), 0 2px 8px rgba(0,0,0,0.75);
}

.d20-die {
  width: clamp(120px, 24vw, 260px);
  height: auto;
  display: block;
  filter: drop-shadow(0 12px 24px rgba(0,0,0,0.45)) drop-shadow(0 0 20px rgba(201,168,76,0.35));
  animation: d20-spin-settle 1.05s cubic-bezier(0.2, 0.8, 0.2, 1);
}

@keyframes d20-overlay-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes d20-card-pop {
  from { transform: scale(0.9) translateY(8px); opacity: 0; }
  to { transform: scale(1) translateY(0); opacity: 1; }
}

@keyframes d20-spin-settle {
  0% { transform: rotate(-24deg) scale(0.82); filter: brightness(1.22); }
  50% { transform: rotate(10deg) scale(1.06); }
  100% { transform: rotate(0deg) scale(1); filter: brightness(1); }
}

.name-inputs {
  display:flex;
  gap:16px;
  margin-bottom: clamp(14px, 3vh, 28px);
  flex-wrap:wrap;
  justify-content:center;
}
.name-group {
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-start;
}
.name-group label {
  font-family:'Cinzel', serif;
  font-size:0.75rem;
  letter-spacing:0.1em;
  color:var(--gold-dark);
  text-transform:uppercase;
}
.name-input {
  background: rgba(20,12,4,0.8);
  border:1px solid rgba(201,168,76,0.3);
  border-radius:4px;
  padding:10px 16px;
  font-family:'Crimson Text', serif;
  font-size:1rem;
  color:var(--cream);
  width:180px;
  outline:none;
  transition:border-color 0.3s, box-shadow 0.3s;
}
.name-input:focus {
  border-color:var(--gold);
  box-shadow:0 0 0 2px rgba(201,168,76,0.15), 0 0 15px rgba(201,168,76,0.1);
}
.name-input::placeholder { color:var(--parchment-dark); opacity:0.5; }

.ready-panel {
  width: min(420px, 92vw);
  margin: 6px auto 10px;
  background: rgba(15, 9, 3, 0.88);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 6px;
  padding: 8px 12px;
}

.ready-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'Cinzel', serif;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  color: var(--cream-dim);
  padding: 5px 0;
  border-bottom: 1px solid rgba(201,168,76,0.08);
}

.ready-row:last-child {
  border-bottom: 0;
}

.ready-good {
  color: #9ae07f;
}

.ready-bad {
  color: #d6bca0;
}

.ready-toggle {
  all: unset;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  height: 38px;
  padding: 0 18px;
  margin: 4px auto 0;
  border-radius: 999px;
  border: 1px solid rgba(201,168,76,0.35);
  background: linear-gradient(180deg, rgba(28,18,8,0.95), rgba(14,9,4,0.95));
  color: var(--parchment);
  font-family: 'Cinzel', serif;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.04);
}

.ready-toggle::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #a88d64;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.35);
}

.ready-toggle:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: rgba(201,168,76,0.55);
  color: var(--cream);
}

.ready-toggle:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.ready-toggle.is-ready {
  border-color: rgba(80,170,70,0.7);
  color: #c8f0bf;
  box-shadow: 0 2px 10px rgba(44,122,50,0.25), inset 0 1px 0 rgba(160,255,80,0.12);
}

.ready-toggle.is-ready::before {
  background: #73d85e;
  box-shadow: 0 0 8px rgba(115,216,94,0.65);
}

#btn-start-online {
  margin: 0;
}

.start-primary-actions {
  width: min(560px, 94vw);
  margin-top: 10px;
  display: flex;
  align-items: stretch;
  gap: 10px;
}

.start-primary-actions #btn-start-online,
.start-primary-actions #btn-offline-play {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 56px;
  padding: 0 12px;
  border: none;
  border-radius: 5px;
  font-family: 'Cinzel', serif;
  font-size: 1.1rem;
  letter-spacing: 0.15em;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1;
  position: relative;
  overflow: hidden;
  background-size: 200% 100%;
  transition: all 0.3s ease;
  animation: btn-shimmer 3s ease infinite;
}

.start-primary-actions #btn-start-online {
  flex: 0.6 1 0;
  width: auto;
  min-width: 0;
  background: linear-gradient(135deg, #c9a84c 0%, #a07828 50%, #c9a84c 100%);
  color: #1a0d04;
  box-shadow:
    0 4px 0 #5a4010,
    0 5px 20px rgba(201,168,76,0.4),
    inset 0 1px 0 rgba(255,255,255,0.3);
  text-shadow: 0 1px 2px rgba(255,255,255,0.2);
}

.start-primary-actions #btn-start-online:hover:not(:disabled) {
  transform: translateY(-3px);
  box-shadow: 0 7px 0 #5a4010, 0 8px 30px rgba(201,168,76,0.6), inset 0 1px 0 rgba(255,255,255,0.3);
}

.start-primary-actions #btn-start-online:active:not(:disabled) {
  transform: translateY(1px);
}

.start-primary-actions #btn-offline-play {
  flex: 0.4 1 0;
  min-width: 0;
  max-width: none;
  background: linear-gradient(135deg, #8b6a3a 0%, #6a4b27 50%, #8b6a3a 100%);
  color: #f1debd;
  box-shadow:
    0 4px 0 #3f2b14,
    0 5px 20px rgba(122,86,40,0.4),
    inset 0 1px 0 rgba(255,245,220,0.2);
  text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}

.start-primary-actions #btn-offline-play::before {
  display: none;
}

.start-primary-actions #btn-offline-play:hover:not(:disabled) {
  transform: translateY(-3px);
  box-shadow: 0 7px 0 #3f2b14, 0 8px 30px rgba(122,86,40,0.55), inset 0 1px 0 rgba(255,245,220,0.25);
}

.start-primary-actions #btn-offline-play:active:not(:disabled) {
  transform: translateY(1px);
}

#lobby-status {
  margin-top: 16px;
  margin-bottom: 0;
  width: min(460px, 92vw);
  line-height: 1.35;
  font-size: clamp(0.82rem, 2.2vw, 1rem);
}

.menu-mini-actions {
  margin-top: 10px;
}

.menu-reset-btn {
  all: unset;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(181, 112, 96, 0.38);
  background: linear-gradient(180deg, rgba(44,17,13,0.92), rgba(20,8,7,0.92));
  color: #dcb5ad;
  font-family: 'Cinzel', serif;
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.menu-reset-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(205, 132, 118, 0.6);
  color: #f0cbc5;
}

.target-select {
  margin-bottom: clamp(14px, 3vh, 28px);
  text-align:center;
}
.target-select label {
  font-family:'Cinzel', serif;
  font-size:0.75rem;
  letter-spacing:0.1em;
  color:var(--gold-dark);
  text-transform:uppercase;
  display:block;
  margin-bottom:8px;
}
.target-select select {
  background: rgba(20,12,4,0.8);
  border:1px solid rgba(201,168,76,0.3);
  border-radius:4px;
  padding:10px 20px;
  font-family:'Cinzel', serif;
  font-size:0.9rem;
  color:var(--cream);
  outline:none;
  cursor:pointer;
}
.target-select select option { background:#1a0d04; }

.btn-start {
  font-family:'Cinzel', serif;
  font-size:1.1rem;
  letter-spacing:0.15em;
  font-weight:700;
  padding:16px 50px;
  border:none;
  border-radius:5px;
  cursor:pointer;
  background: linear-gradient(135deg, #c9a84c 0%, #a07828 50%, #c9a84c 100%);
  background-size:200% 100%;
  color:#1a0d04;
  text-transform:uppercase;
  position:relative;
  overflow:hidden;
  box-shadow:
    0 4px 0 #5a4010,
    0 5px 20px rgba(201,168,76,0.4),
    inset 0 1px 0 rgba(255,255,255,0.3);
  text-shadow:0 1px 2px rgba(255,255,255,0.2);
  transition:all 0.3s ease;
  animation: btn-shimmer 3s ease infinite;
}
@keyframes btn-shimmer {
  0%   { background-position:200% 0; }
  50%  { background-position:0% 0; }
  100% { background-position:200% 0; }
}
.btn-start:hover {
  transform:translateY(-3px);
  box-shadow:0 7px 0 #5a4010,0 8px 30px rgba(201,168,76,0.6),inset 0 1px 0 rgba(255,255,255,0.3);
}
.btn-start:active { transform:translateY(1px); }

@media (max-width: 599px) {
  .ready-toggle {
    height: 40px;
    padding: 0 19px;
    font-size: 0.78rem;
    letter-spacing: 0.1em;
  }

  .ready-toggle::before {
    width: 8px;
    height: 8px;
  }

  #lobby-status {
    margin-top: 16px;
    margin-bottom: 0;
    line-height: 1.25;
  }

  #start-screen .action-bar.lobby-actions {
    gap: 8px;
  }

  #start-screen .action-bar.lobby-actions .btn {
    flex: 1 1 calc(50% - 8px);
    max-width: none;
    min-width: 120px;
  }

  #start-screen #btn-rules-menu,
  #start-screen .ready-toggle {
    width: min(320px, 88vw);
  }

  #start-screen .start-primary-actions {
    width: min(320px, 88vw);
    gap: 8px;
  }

  .menu-reset-btn {
    min-height: 28px;
    font-size: 0.58rem;
    padding: 0 10px;
  }

  .chat-fab {
    right: 10px;
    bottom: max(10px, env(safe-area-inset-bottom));
    min-width: 78px;
    height: 34px;
    font-size: 0.66rem;
    padding: 0 12px;
  }

  .chat-panel {
    right: 10px;
    width: min(94vw, 360px);
    bottom: calc(max(10px, env(safe-area-inset-bottom)) + 42px);
    height: min(56vh, 380px);
  }
}

/* ===== WIN SCREEN ===== */
#win-screen {
  position:fixed;
  inset:0;
  z-index:160;
  background: radial-gradient(circle at 50% 22%, rgba(255,216,120,0.08), rgba(6,3,1,0.94) 56%), rgba(5,3,1,0.95);
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: clamp(20px, 5vw, 50px);
  overflow: hidden;
  isolation: isolate;
}
#win-screen.show { display:flex; animation:result-fade-in 0.7s ease both; }

.result-aura,
.result-vignette,
.result-particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.result-aura {
  background:
    radial-gradient(circle at 50% 28%, rgba(233, 193, 100, 0.35) 0%, rgba(233, 193, 100, 0.1) 28%, transparent 62%),
    radial-gradient(circle at 20% 80%, rgba(170, 65, 25, 0.18) 0%, transparent 44%),
    radial-gradient(circle at 78% 76%, rgba(170, 65, 25, 0.2) 0%, transparent 40%);
  filter: saturate(1.05);
  animation: aura-breathe 2.6s ease-in-out infinite;
  z-index: -3;
}

.result-vignette {
  background: radial-gradient(circle, transparent 30%, rgba(0, 0, 0, 0.5) 100%);
  z-index: -2;
}

.result-particles {
  overflow: hidden;
  z-index: -1;
}

.game-alert {
  position: fixed;
  inset: 0;
  z-index: 220;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(5, 3, 1, 0.72);
  padding: 20px;
}

.game-alert.show {
  display: flex;
  animation: fade-in 0.22s ease;
}

.game-alert-card {
  width: min(420px, 92vw);
  border-radius: 12px;
  border: 1px solid rgba(201,168,76,0.35);
  background: linear-gradient(160deg, rgba(34,22,9,0.96), rgba(12,8,3,0.96));
  box-shadow: 0 20px 44px rgba(0,0,0,0.58), inset 0 1px 0 rgba(255,255,255,0.05);
  padding: 18px 18px 16px;
  text-align: center;
}

.game-alert-title {
  font-family: 'Cinzel', serif;
  font-size: 1rem;
  letter-spacing: 0.1em;
  color: var(--gold-light);
  margin-bottom: 10px;
  text-transform: uppercase;
}

.game-alert-message {
  font-family: 'IM Fell English', serif;
  font-size: 1rem;
  color: var(--cream);
  line-height: 1.35;
  margin-bottom: 14px;
}

.game-alert-btn {
  min-width: 120px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid rgba(201,168,76,0.38);
  background: linear-gradient(180deg, rgba(34,22,9,0.95), rgba(16,10,4,0.95));
  color: var(--cream);
  font-family: 'Cinzel', serif;
  font-size: 0.74rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.game-alert-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(201,168,76,0.62);
}

.rules-open-btn {
  margin-top: 10px;
  background: linear-gradient(135deg, #3c2710 0%, #211306 100%);
  color: var(--gold-light);
  border: 1px solid rgba(201,168,76,0.34);
  border-radius: 4px;
  font-family: 'Cinzel', serif;
  font-size: 0.72rem;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  padding: 8px 14px;
  cursor: pointer;
  transition: transform 0.22s ease, border-color 0.22s ease, color 0.22s ease;
  box-shadow: inset 0 1px 0 rgba(255,220,150,0.18), 0 4px 12px rgba(0,0,0,0.35), 0 0 12px rgba(201,168,76,0.18);
}

.rules-open-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(201,168,76,0.62);
  color: #ffe8a8;
}

.rules-modal {
  position: fixed;
  inset: 0;
  z-index: 190;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(6, 3, 1, 0.78);
  backdrop-filter: blur(2px);
}

.rules-modal.show {
  display: flex;
}

.rules-modal-card {
  width: min(760px, 92vw);
  max-height: 86vh;
  overflow: auto;
  border-radius: 10px;
  border: 1px solid rgba(201,168,76,0.28);
  background: linear-gradient(165deg, rgba(30,17,7,0.98), rgba(12,8,3,0.98));
  box-shadow: 0 24px 62px rgba(0,0,0,0.62), inset 0 1px 0 rgba(255,255,255,0.04);
  padding: 20px 22px;
}

.rules-modal-title {
  font-family: 'Cinzel', serif;
  color: var(--gold-light);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.96rem;
  margin-bottom: 12px;
}

.rules-modal-content {
  color: var(--cream);
}

.rules-modal-content h4 {
  margin-top: 12px;
  margin-bottom: 6px;
  font-family: 'Cinzel', serif;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  color: var(--gold);
}

.rules-modal-content p {
  margin: 0 0 6px;
  font-size: 0.94rem;
  line-height: 1.5;
  color: var(--parchment);
}

.rules-modal-btn {
  margin-top: 12px;
  min-width: 124px;
  height: 36px;
  border-radius: 8px;
  border: 1px solid rgba(201,168,76,0.35);
  background: linear-gradient(180deg, rgba(34,22,9,0.95), rgba(15,10,4,0.95));
  color: var(--cream);
  font-family: 'Cinzel', serif;
  font-size: 0.74rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.rules-modal-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(201,168,76,0.62);
}

.result-piece {
  position: absolute;
  display: block;
  transform: translate3d(0, 0, 0);
  animation-name: result-fall;
  animation-timing-function: cubic-bezier(0.18, 0.74, 0.28, 1.02);
  animation-fill-mode: both;
}

.result-piece.win {
  background: linear-gradient(180deg, #ffe8a8, #e7b94f 60%, #b7852e);
  box-shadow: 0 0 16px rgba(231, 185, 79, 0.45);
  border-radius: 999px;
}

.result-piece.lose {
  background: linear-gradient(180deg, #a7412d, #5a1a11);
  box-shadow: 0 0 12px rgba(160, 52, 42, 0.4);
  border-radius: 999px;
}

#win-screen .win-icon,
#win-screen .win-title,
#win-screen .win-name,
#win-screen .win-score,
#win-screen .win-sub,
#win-screen #btn-main-menu {
  position: relative;
  z-index: 2;
}

.win-icon {
  font-size: clamp(3.8rem, 9vw, 6.4rem);
  margin-bottom: 14px;
  animation: result-pop-in 0.84s cubic-bezier(0.18, 0.88, 0.22, 1.2) both;
  filter: drop-shadow(0 0 24px rgba(233, 193, 100, 0.45));
}
@keyframes bounce-in {
  0%   { transform:scale(0) rotate(-30deg); opacity:0; }
  60%  { transform:scale(1.2) rotate(10deg); opacity:1; }
  80%  { transform:scale(0.9) rotate(-5deg); }
  100% { transform:scale(1) rotate(0deg); }
}

.win-title {
  font-family:'Cinzel', serif;
  font-size:clamp(1.8rem,6vw,3.8rem);
  color:var(--gold-light);
  text-shadow: 0 0 30px var(--gold-glow), 0 0 72px rgba(201, 168, 76, 0.26);
  margin-bottom: 8px;
  letter-spacing:0.1em;
  animation: result-pop-in 0.84s 90ms cubic-bezier(0.18, 0.88, 0.22, 1.2) both;
}
.win-name {
  font-family:'IM Fell English', serif;
  font-style:italic;
  font-size:clamp(1.15rem,4vw,2rem);
  color:var(--parchment);
  margin-bottom: 8px;
  animation: result-pop-in 0.82s 140ms cubic-bezier(0.18, 0.88, 0.22, 1.2) both;
}
.win-score {
  font-family:'Cinzel', serif;
  color: var(--gold);
  font-size: clamp(0.96rem, 2.8vw, 1.15rem);
  letter-spacing:0.1em;
  margin-bottom: 8px;
  animation: result-pop-in 0.82s 200ms cubic-bezier(0.18, 0.88, 0.22, 1.2) both;
}

.win-sub {
  font-family: 'IM Fell English', serif;
  font-style: italic;
  color: var(--cream-dim);
  font-size: clamp(0.94rem, 2.6vw, 1.2rem);
  letter-spacing: 0.05em;
  margin-bottom: 26px;
  animation: result-pop-in 0.82s 260ms cubic-bezier(0.18, 0.88, 0.22, 1.2) both;
}

#btn-main-menu {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 158px;
  height: 42px;
  padding: 0 22px;
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(34,22,9,0.95), rgba(15,10,4,0.95));
  color: var(--cream);
  font-family: 'Cinzel', serif;
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.06);
  transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  animation: result-pop-in 0.82s 320ms cubic-bezier(0.18, 0.88, 0.22, 1.2) both;
}

#btn-main-menu:hover {
  transform: translateY(-1px);
  border-color: rgba(201,168,76,0.6);
  color: var(--gold-light);
}

#btn-main-menu:active {
  transform: translateY(1px);
}

#win-screen.lose #btn-main-menu {
  border-color: rgba(170, 80, 68, 0.55);
  color: #e2c7c2;
}

#win-screen.lose #btn-main-menu:hover {
  border-color: rgba(196, 98, 86, 0.8);
}

#win-screen.win .win-title {
  color: #f1d88f;
  animation: result-pop-in 0.84s 90ms cubic-bezier(0.18, 0.88, 0.22, 1.2) both, result-victory-glow 1.4s ease-in-out 0.5s infinite alternate;
}

#win-screen.lose {
  background: radial-gradient(circle at 50% 25%, rgba(163, 56, 42, 0.18), rgba(4, 2, 2, 0.96) 58%), rgba(8, 3, 3, 0.97);
}

#win-screen.lose .result-aura {
  background:
    radial-gradient(circle at 50% 24%, rgba(167, 56, 42, 0.35) 0%, rgba(167, 56, 42, 0.1) 36%, transparent 60%),
    radial-gradient(circle at 18% 82%, rgba(98, 32, 22, 0.25) 0%, transparent 42%),
    radial-gradient(circle at 80% 80%, rgba(108, 35, 25, 0.22) 0%, transparent 42%);
  animation-duration: 2s;
}

#win-screen.lose .win-icon {
  filter: drop-shadow(0 0 20px rgba(160, 52, 42, 0.45));
}

#win-screen.lose .win-title {
  color: #df8e83;
  text-shadow: 0 0 28px rgba(167, 56, 42, 0.5);
}

#win-screen.lose .win-score {
  color: #d9ad9d;
}

@keyframes result-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes result-pop-in {
  0% { opacity: 0; transform: translateY(20px) scale(0.92); }
  70% { opacity: 1; transform: translateY(-4px) scale(1.02); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes aura-breathe {
  0% { transform: scale(1); opacity: 0.85; }
  50% { transform: scale(1.04); opacity: 1; }
  100% { transform: scale(1); opacity: 0.85; }
}

@keyframes result-fall {
  0% { transform: translate3d(0, -12vh, 0) rotate(0deg); opacity: 0; }
  12% { opacity: 1; }
  100% { transform: translate3d(var(--drift), 112vh, 0) rotate(420deg); opacity: 0; }
}

@keyframes result-victory-glow {
  from { text-shadow: 0 0 30px var(--gold-glow), 0 0 66px rgba(201, 168, 76, 0.22); }
  to { text-shadow: 0 0 45px rgba(231, 193, 100, 0.6), 0 0 110px rgba(201, 168, 76, 0.33); }
}

/* ===== FLOATING SCORE POP ===== */
.score-pop {
  position:absolute;
  font-family:'Cinzel', serif;
  font-size:1.2rem;
  color:var(--gold-light);
  text-shadow:0 0 10px var(--gold-glow);
  pointer-events:none;
  z-index:50;
  animation:score-float 1.5s ease forwards;
}
@keyframes score-float {
  0%   { opacity:0; transform:translateY(0) scale(0.8); }
  20%  { opacity:1; transform:translateY(-10px) scale(1.1); }
  80%  { opacity:1; transform:translateY(-40px) scale(1); }
  100% { opacity:0; transform:translateY(-60px) scale(0.9); }
}

/* ===== PROGRESS BAR ===== */
.progress-section {
  width:100%;
  max-width:800px;
  margin:0 auto 4px;
  display:flex;
  gap:10px;
}
.progress-bar-wrap {
  flex:1;
  position:relative;
}
.progress-label {
  font-family:'Cinzel', serif;
  font-size:0.6rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--parchment-dark);
  margin-bottom:3px;
}
.progress-bar {
  height:6px;
  background: rgba(0,0,0,0.4);
  border-radius:3px;
  border:1px solid rgba(201,168,76,0.1);
  overflow:hidden;
}
.progress-fill {
  height:100%;
  border-radius:3px;
  background: linear-gradient(90deg, var(--gold-dark), var(--gold-light));
  box-shadow:0 0 8px rgba(201,168,76,0.4);
  transition:width 0.6s cubic-bezier(0.4,0,0.2,1);
}
.progress-fill.p2 {
  background: linear-gradient(90deg, #4a1a7a, #a060e0);
  box-shadow:0 0 8px rgba(160,96,224,0.4);
}

/* ===== ROLL HISTORY ===== */
.roll-history {
  width:100%;
  max-width:800px;
  margin:4px auto;
  display:flex;
  gap:6px;
  align-items:center;
  min-height:24px;
}
.history-label {
  font-size:0.65rem;
  color:var(--parchment-dark);
  font-family:'Cinzel', serif;
  letter-spacing:0.08em;
  white-space:nowrap;
}
.history-pips {
  display:flex;
  flex-wrap:wrap;
  gap:4px;
}
.history-pip {
  width:18px; height:18px;
  background:rgba(201,168,76,0.12);
  border:1px solid rgba(201,168,76,0.2);
  border-radius:3px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:0.65rem;
  font-family:'Cinzel', serif;
  color:var(--gold-dark);
}

/* ===== RESPONSIVE - FLUID SYSTEM ===== */

/* -- Base: fluid die size via CSS custom property -- */
:root {
  --die-size: 68px;
  --pip-size: 10px;
  --gap: 16px;
  --table-pad: 28px 24px;
  --btn-pad: 12px 26px;
  --btn-font: 0.88rem;
  --card-pad: 14px 18px;
  --score-font: 2.2rem;
  --wrap-pad: 0 12px 30px;
}

/* -- Large desktop (>=1200px) -- */
@media (min-width: 1200px) {
  :root {
    --die-size: 76px;
    --pip-size: 11px;
    --gap: 20px;
  }
  #game-wrapper { max-width: 900px; margin: 0 auto; }
  .scoreboard, .info-strip, .progress-section,
  .dice-table-wrap, .score-combos, .action-bar,
  .roll-history, .rules-toggle, .rules-panel,
  .divider, .status-bar { max-width: 900px; }
}

/* -- Standard desktop (900-1199px) already handled by base -- */

/* -- Tablet landscape (768-899px) -- */
@media (max-width: 899px) {
  :root {
    --die-size: 62px;
    --pip-size: 9px;
    --gap: 14px;
    --table-pad: 22px 18px;
  }
}

/* -- Tablet portrait (600-767px) -- */
@media (max-width: 767px) {
  :root {
    --die-size: 58px;
    --pip-size: 8px;
    --gap: 12px;
    --table-pad: 18px 14px;
    --btn-pad: 11px 18px;
    --btn-font: 0.82rem;
    --score-font: 2rem;
    --wrap-pad: 0 10px 24px;
  }
  .game-title h1 { font-size: clamp(1.6rem, 5vw, 2.4rem); }
  .info-strip { gap: 8px; }
  .info-chip { padding: 7px 10px; }
  .info-chip .value { font-size: 1.1rem; }
  .rules-grid { grid-template-columns: 1fr 1fr; gap: 3px 12px; }
  .candle { display: none; } /* hide candles on tablet to free space */
}

/* -- Mobile landscape (<=599px, orientation: landscape) -- */
@media (max-width: 599px) and (orientation: landscape) {
  :root {
    --die-size: 50px;
    --pip-size: 7px;
    --gap: 10px;
    --table-pad: 14px 10px;
    --btn-pad: 9px 14px;
    --btn-font: 0.76rem;
    --score-font: 1.6rem;
  }
  #game-wrapper { padding-bottom: 16px; }
  .game-title { padding: 8px 0 4px; }
  .game-title .subtitle { display: none; }
  .divider { margin: 3px auto; }
  .scoreboard { gap: 8px; }
  .progress-section { margin-bottom: 2px; }
  .status-bar { min-height: 28px; }
  .status-msg { font-size: 0.9rem; padding: 4px 12px; }
  .score-combos { padding: 6px 10px; }
  .roll-history { margin: 2px auto; }
  .rules-toggle { margin: 2px auto; }
}

/* -- Mobile portrait (<=599px) -- */
@media (max-width: 599px) {
  :root {
    --die-size: 56px;
    --pip-size: 8px;
    --gap: 12px;
    --table-pad: 20px 14px;
    --btn-pad: 11px 14px;
    --btn-font: 0.8rem;
    --score-font: 1.9rem;
    --card-pad: 11px 14px;
    --wrap-pad: 0 8px 20px;
  }
  #game-wrapper { padding: var(--wrap-pad); }
  .game-title h1 { font-size: clamp(1.5rem, 7vw, 2rem); letter-spacing: 0.08em; }
  .game-title .subtitle { font-size: 0.85rem; }
  .game-title { padding: 12px 0 6px; }

  .scoreboard { gap: 8px; }
  .player-card { padding: var(--card-pad); }
  .player-score { font-size: var(--score-font); }
  .player-name { font-size: 0.75rem; }
  .turn-score-label { font-size: 0.65rem; }

  .info-strip { gap: 6px; }
  .info-chip { padding: 6px 8px; }
  .info-chip .label { font-size: 0.58rem; }
  .info-chip .value { font-size: 1rem; }

  .dice-table { padding: var(--table-pad); min-height: 150px; }
  .dice-container { gap: var(--gap); }

  /* 3-column grid on small phones so 6 dice fit in 2 rows */
  @media (max-width: 400px) {
    .dice-container { 
      display: grid; 
      grid-template-columns: repeat(3, var(--die-size));
      gap: 10px;
    }
  }

  .btn { padding: var(--btn-pad); font-size: var(--btn-font); min-width: 0; }
  .action-bar { gap: 8px; flex-wrap: wrap; }
  .btn-roll { flex: 1 1 45%; max-width: none; }
  .btn-bank { flex: 1 1 45%; max-width: none; }
  .btn-restart { flex: 1 1 100%; max-width: none; font-size: 0.75rem; }

  .score-combos { padding: 8px 12px; }
  .combo-tag { font-size: 0.7rem; padding: 2px 8px; }

  .rules-grid { grid-template-columns: 1fr 1fr; gap: 3px 10px; }
  .rule-row { font-size: 0.72rem; }

  .progress-section { gap: 6px; }
  .progress-label { font-size: 0.55rem; }
  .progress-bar { height: 5px; }

  .roll-history { gap: 4px; }
  .history-pip { width: 16px; height: 16px; font-size: 0.6rem; }

  .status-msg { font-size: 0.95rem; }

  .candle { display: none; }

  /* Start screen */
  #start-screen .start-primary-actions {
    margin: 14px auto 0;
  }

  .start-dice-row {
    display: none;
  }

  #lobby-status {
    display: block;
    width: min(320px, 90vw);
    margin: 14px auto 0;
    padding-top: 2px;
    line-height: 1.3;
  }

  .name-inputs { flex-direction: column; align-items: center; gap: 12px; }
  .name-input { width: min(220px, 80vw); }
  .start-die { width: 44px; height: 44px; font-size: 1.4rem; }

  .sfx-toggle {
    top: 8px;
    left: 8px;
    height: 28px;
    min-width: 74px;
    font-size: 0.62rem;
    padding: 0 9px;
  }

  #btn-main-menu {
    min-width: 144px;
    height: 40px;
    font-size: 0.76rem;
    padding: 0 18px;
  }
}

@media (max-height: 1100px) {
  #start-screen {
    justify-content: flex-start;
    padding-top: 14px;
    padding-bottom: 14px;
    gap: 0;
  }

  .start-title {
    margin-bottom: 4px;
  }

  .start-sub {
    margin-bottom: 12px;
  }

  .name-inputs,
  .target-select {
    margin-bottom: 10px;
  }

  #start-screen .start-primary-actions {
    margin-top: 8px;
  }

  #lobby-status {
    margin-top: 10px;
    margin-bottom: 0;
    line-height: 1.28;
  }
}

@media (max-height: 920px) {
  :root {
    --die-size: 60px;
    --pip-size: 8px;
    --gap: 11px;
    --table-pad: 16px 14px;
    --btn-pad: 10px 14px;
    --btn-font: 0.78rem;
    --score-font: 1.85rem;
    --card-pad: 10px 12px;
    --wrap-pad: 0 8px 14px;
  }

  #game-wrapper {
    padding: var(--wrap-pad);
  }

  .game-title {
    padding: 8px 0 5px;
  }

  .game-title h1 {
    font-size: clamp(1.45rem, 3.2vw, 2rem);
  }

  .game-title .subtitle {
    font-size: 0.82rem;
  }

  .identity-bar {
    margin: 0 auto 6px;
    gap: 8px;
  }

  .divider {
    margin: 4px auto;
  }

  .scoreboard,
  .info-strip,
  .action-bar,
  .roll-history {
    margin-top: 4px;
    margin-bottom: 4px;
  }

  .turn-indicator {
    top: 8px;
    right: 10px;
    font-size: 0.62rem;
  }

  .player-name {
    font-size: 0.74rem;
  }

  .turn-score-label {
    font-size: 0.62rem;
  }

  .info-chip {
    padding: 5px 8px;
  }

  .info-chip .value {
    font-size: 0.96rem;
  }

  .dice-table {
    min-height: 120px;
  }

  .btn {
    min-width: 100px;
  }

  .rules-toggle {
    margin: 2px auto;
  }

  .rules-panel {
    padding: 10px 12px;
    max-height: 34vh;
    overflow-y: auto;
  }

  .win-icon {
    font-size: clamp(3rem, 6vw, 4.2rem);
    margin-bottom: 8px;
  }

  .win-title {
    font-size: clamp(1.35rem, 3.5vw, 2rem);
    margin-bottom: 4px;
  }

  .win-name {
    font-size: clamp(0.95rem, 2.6vw, 1.3rem);
    margin-bottom: 4px;
  }

  .win-score {
    font-size: clamp(0.85rem, 2.3vw, 1rem);
    margin-bottom: 4px;
  }

  .win-sub {
    font-size: clamp(0.78rem, 2vw, 0.95rem);
    margin-bottom: 12px;
  }

  #btn-main-menu {
    height: 38px;
    min-width: 136px;
    font-size: 0.72rem;
  }
}

@media (max-height: 820px) {
  .start-dice-row {
    display: none;
  }

  #start-screen {
    padding-top: 10px;
    padding-bottom: 10px;
  }

  #start-screen .rules-open-btn,
  #start-screen .ready-toggle,
  #start-screen .start-primary-actions {
    width: min(320px, 90vw);
  }

  #start-screen .start-primary-actions #btn-start-online,
  #start-screen .start-primary-actions #btn-offline-play {
    width: auto;
    min-width: 0;
  }

  #start-screen #lobby-status {
    margin-top: 8px;
    font-size: 0.86rem;
  }

  .ready-panel {
    margin: 4px auto 8px;
    padding: 7px 10px;
    max-height: 24vh;
    overflow-y: auto;
  }

  .ready-row {
    font-size: 0.7rem;
    padding: 4px 0;
  }

  .action-bar {
    gap: 8px;
  }

  .btn {
    padding: 9px 12px;
    font-size: 0.74rem;
  }

  .progress-section {
    margin-bottom: 2px;
  }

  .status-bar {
    min-height: 28px;
  }

  .status-msg {
    font-size: 0.86rem;
    padding: 4px 10px;
  }

  .chat-panel {
    height: min(48vh, 330px);
  }

  .roll-history {
    min-height: 18px;
  }

  .history-pip {
    width: 15px;
    height: 15px;
    font-size: 0.56rem;
  }
}

@media (max-height: 740px) {
  .start-title {
    font-size: clamp(1.5rem, 5vw, 2.2rem);
    letter-spacing: 0.1em;
  }

  .start-sub {
    margin-bottom: 8px;
  }

  .name-group label,
  .target-select label {
    font-size: 0.68rem;
  }

  .name-input {
    padding: 8px 12px;
    font-size: 0.9rem;
  }

  .target-select select {
    padding: 8px 14px;
    font-size: 0.8rem;
  }

  .ready-toggle {
    height: 36px;
    padding: 0 16px;
    font-size: 0.74rem;
  }

  #start-screen .start-primary-actions #btn-start-online,
  #start-screen .start-primary-actions #btn-offline-play {
    height: 50px;
    font-size: 0.92rem;
    letter-spacing: 0.12em;
  }

  #game-wrapper {
    padding-bottom: 10px;
  }

  .scoreboard,
  .info-strip,
  .progress-section,
  .status-bar,
  .roll-history,
  .action-bar {
    margin-top: 2px;
    margin-bottom: 2px;
  }

  .info-chip {
    padding: 4px 6px;
  }

  .info-chip .label {
    font-size: 0.56rem;
  }

  .info-chip .value {
    font-size: 0.88rem;
  }

  .dice-table {
    min-height: 104px;
    padding: 12px 10px;
  }

  .action-bar {
    gap: 6px;
  }

  .btn-roll,
  .btn-bank {
    flex: 1 1 calc(50% - 6px);
  }

  .btn-restart {
    flex: 1 1 100%;
  }

  .rules-toggle {
    margin: 1px auto;
  }

  .rules-panel {
    max-height: 30vh;
  }

  .chat-fab {
    height: 32px;
    min-width: 74px;
    font-size: 0.62rem;
  }

  .chat-panel {
    height: min(44vh, 300px);
  }

  .identity-input {
    padding: 6px 10px;
    font-size: 0.86rem;
  }

  .identity-bar .btn-restart {
    min-width: 112px;
  }

  .rule-row {
    font-size: 0.66rem;
  }

  #win-screen {
    padding: 14px;
  }

  #btn-main-menu {
    height: 34px;
    min-width: 128px;
    padding: 0 14px;
  }
}

@media (orientation: portrait) and (max-height: 900px) {
  #start-screen {
    padding-top: 12px;
  }

  .name-inputs {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .name-input {
    width: min(240px, 82vw);
  }

  .action-bar.lobby-actions {
    gap: 8px;
  }

  #lobby-status {
    width: min(360px, 90vw);
    font-size: 0.92rem;
  }

  .rules-panel {
    max-height: 38vh;
  }
}

/* -- Very small phones (<=360px) -- */
@media (max-width: 360px) {
  :root {
    --die-size: 50px;
    --pip-size: 7px;
    --gap: 8px;
    --score-font: 1.6rem;
  }
  .game-title h1 { font-size: 1.3rem; }
  .player-name { font-size: 0.68rem; }
  .btn { font-size: 0.72rem; padding: 9px 10px; }
  .info-chip .value { font-size: 0.9rem; }
  .rules-grid { grid-template-columns: 1fr; }
}

/* ===== TOOLTIP ===== */
.die-wrap[data-tip]:hover::after {
  content:attr(data-tip);
  position:absolute;
  bottom:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  background:rgba(10,6,2,0.95);
  border:1px solid rgba(201,168,76,0.3);
  color:var(--gold-light);
  font-size:0.65rem;
  font-family:'Cinzel', serif;
  letter-spacing:0.05em;
  padding:4px 8px;
  border-radius:3px;
  white-space:nowrap;
  z-index:10;
  pointer-events:none;
}

/* ===== INIT ROLL OVERLAY ===== */
#init-roll-overlay {
  position:fixed;
  inset:0;
  z-index:80;
  background:rgba(5,3,1,0.9);
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: clamp(12px, 3vw, 24px);
  text-align:center;
  padding: clamp(20px, 5vw, 40px);
  overflow-y: auto;
}
#init-roll-overlay.show { display:flex; animation:fade-in 0.4s ease; }
.init-title {
  font-family:'Cinzel', serif;
  font-size:1.5rem;
  color:var(--gold-light);
  letter-spacing:0.15em;
}
.init-sub {
  font-family:'IM Fell English', serif;
  font-style:italic;
  color:var(--parchment-dark);
  font-size:1rem;
}
.init-dice-row {
  display:flex;
  gap:30px;
  align-items:center;
  justify-content:center;
}
.init-player-die {
  text-align:center;
}
.init-player-die .init-name {
  font-family:'Cinzel', serif;
  font-size:0.75rem;
  color:var(--gold-dark);
  letter-spacing:0.1em;
  margin-bottom:8px;
  text-transform:uppercase;
}
.init-die-face {
  width: clamp(50px, 12vw, 70px); height: clamp(50px, 12vw, 70px);
  background: linear-gradient(135deg, #f5ead8 0%, #e8d8b8 60%, #d4c4a0 100%);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Cinzel', serif;
  font-size:2rem;
  color:var(--dice-pip);
  box-shadow:3px 5px 15px rgba(0,0,0,0.7), inset 0 2px 4px rgba(255,255,255,0.4);
  margin:0 auto;
}
.init-vs {
  font-family:'Cinzel', serif;
  font-size:1.2rem;
  color:var(--gold-dark);
}
.init-result {
  font-family:'IM Fell English', serif;
  font-style:italic;
  color:var(--cream);
  font-size:1.1rem;
}
