/* tglgames.com — Last Card Standing CSS
   Extracted from last-card-standing/index.html (Phase A1 of the modularization).
   Loads after assets/theme.css so theme tokens (--bg, --text, etc.) are in scope.

   Only LCS-specific styles live here. Cross-game widgets (drawer, .btn family,
   conn-dot, debug-log) will move to /css/shared/ in a later phase.
*/

:root {
	--drawer-w: 320px;
	--lcs-red:    #e74c3c;
	--lcs-yellow: #f1c40f;
	--lcs-green:  #2ecc71;
	--lcs-blue:   #3498db;
	--lcs-card-bg: #ffffff;
	--lcs-card-border: #1c1f26;
	--lcs-back-1: #2b3242;
	--lcs-back-2: #0f1115;
	--lcs-active-glow: 0 0 0 3px rgba(96, 165, 250, .55);
	--lcs-uno-pulse: #ff5466;
	--lcs-felt-1: #16361f;
	--lcs-felt-2: #0a1c11;
	--lcs-felt-edge: #051208;
	--lcs-text-on-felt: #f3eddc;
	--gold: #f5c042;
}
:root[data-theme="light"] {
	--lcs-card-border: #2a3042;
	--lcs-back-1: #cbd5e1;
	--lcs-back-2: #94a3b8;
	--lcs-felt-1: #1f5a36;
	--lcs-felt-2: #144025;
	--lcs-felt-edge: #0a2515;
	--lcs-text-on-felt: #f3eddc;
}
* { box-sizing: border-box; }
html, body {
	margin: 0; min-height: 100%;
	background: var(--bg); color: var(--text);
	font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	overscroll-behavior: none;
	touch-action: manipulation;
}
main {
	min-height: 100vh; display: flex; flex-direction: column;
	align-items: center; padding: 12px; gap: 10px;
}
header {
	display: flex; align-items: center; gap: 10px;
	width: min(880px, 100%);
	flex-wrap: wrap;
}
h1 { font-size: 1.25rem; font-weight: 600; margin: 0; letter-spacing: 0.5px; }
.home { color: var(--muted); text-decoration: none; font-size: 0.85rem; }
.home:hover { color: var(--accent); }
.user-chip {
	font-size: 0.75rem; color: var(--muted);
	padding: 2px 8px; border-radius: 999px;
	background: var(--grid); border: 1px solid transparent;
	cursor: pointer;
}
.user-chip:hover { border-color: var(--accent); color: var(--text); }

/* Multiplayer connection state — green ok, yellow connecting, red lost */
.conn-dot {
	width: 11px; height: 11px; border-radius: 50%;
	background: rgba(255,255,255,0.18);
	box-shadow: 0 0 0 0 rgba(0,0,0,0);
	transition: background 200ms, box-shadow 600ms;
}
.conn-dot[data-state="off"]    { background: rgba(255,255,255,0.18); }
.conn-dot[data-state="connecting"] {
	background: #f1c40f;
	box-shadow: 0 0 0 4px rgba(241,196,15,0.18);
	animation: conn-pulse 1.2s ease-in-out infinite;
}
.conn-dot[data-state="open"]   { background: #2ecc71; box-shadow: 0 0 0 3px rgba(46,204,113,0.18); }
.conn-dot[data-state="closed"] { background: #e74c3c; box-shadow: 0 0 0 3px rgba(231,76,60,0.22); }
@keyframes conn-pulse {
	0%,100% { box-shadow: 0 0 0 4px rgba(241,196,15,0.18); }
	50%     { box-shadow: 0 0 0 7px rgba(241,196,15,0.05); }
}
.scoreboard {
	margin-left: auto; display: flex; gap: 14px;
	font-variant-numeric: tabular-nums; font-size: 0.9rem;
	color: var(--muted);
}
.scoreboard b { color: var(--text); font-weight: 600; }
.scoreboard .timer { font-family: ui-monospace, Menlo, Consolas, monospace; }
.scoreboard .pts { color: var(--gold); font-weight: 700; }

.table {
	position: relative;
	width: min(880px, 100%);
	min-height: 600px;
	border-radius: 28px;
	background:
		radial-gradient(ellipse at 50% 32%, var(--lcs-felt-1) 0%, var(--lcs-felt-2) 60%, var(--lcs-felt-edge) 100%);
	box-shadow:
		0 10px 40px rgba(0,0,0,0.45),
		inset 0 0 0 6px #4a2a14,
		inset 0 0 0 12px #2b1708;
	padding: 28px 18px 12px;
	color: var(--lcs-text-on-felt);
	display: flex; flex-direction: column; gap: 12px;
	overflow: hidden;
}
.table::before {
	content: ""; position: absolute; inset: 14px;
	border-radius: 22px;
	border: 1px solid rgba(255,255,255,0.06);
	pointer-events: none;
}

/* Opponents — horizontal carousel; renderOpponents rotates the
   list so the current player lands in the center slot. With many
   seats (up to 9 opponents) the row scrolls horizontally with
   scroll-snap so each seat snaps cleanly to the center. */
.opponents {
	display: flex; flex-direction: row;
	gap: 12px;
	width: 100%;
	padding: 6px 50% 6px;
	overflow-x: auto;
	overflow-y: visible;
	scroll-snap-type: x mandatory;
	scroll-padding: 50%;
	scrollbar-width: thin;
	-webkit-overflow-scrolling: touch;
}
.opponents::-webkit-scrollbar { height: 6px; }
.opponents::-webkit-scrollbar-thumb {
	background: color-mix(in srgb, var(--text) 22%, transparent);
	border-radius: 3px;
}
.opp {
	position: relative;
	flex: 0 0 140px;
	padding: 10px 12px 8px;
	border-radius: 14px;
	background: rgba(0,0,0,0.22);
	border: 1px solid rgba(255,255,255,0.05);
	min-height: 86px;
	scroll-snap-align: center;
	transition: border-color 180ms ease, box-shadow 180ms ease,
	            transform 220ms cubic-bezier(.2,.8,.2,1),
	            opacity 180ms ease;
	opacity: 0.78;
	transform: scale(0.94);
}
.opp.active {
	border-color: var(--gold);
	box-shadow: 0 0 0 3px rgba(245,192,66,.28);
	opacity: 1;
	transform: scale(1.06);
	z-index: 2;
}
.opp.eliminated {
	opacity: 0.42;
	filter: grayscale(0.7);
	border-color: rgba(231, 76, 60, 0.5);
}
.opp.at-cap {
	border-color: rgba(231, 76, 60, 0.7);
	box-shadow: 0 0 0 2px rgba(231, 76, 60, 0.25);
}
.opp-out-badge {
	background: rgba(231, 76, 60, 0.85);
	color: #fff;
	font-weight: 800;
	font-size: 0.66rem;
	padding: 1px 6px;
	border-radius: 6px;
	letter-spacing: 1.5px;
}
.opp-cap-badge {
	background: rgba(231, 76, 60, 0.7);
	color: #fff;
	font-weight: 700;
	font-size: 0.62rem;
	padding: 1px 5px;
	border-radius: 5px;
	letter-spacing: 1px;
}
@media (max-width: 600px) {
	.opp { flex: 0 0 120px; }
}
.opp-head {
	display: flex; align-items: center; justify-content: space-between;
	gap: 6px; font-size: 0.78rem; letter-spacing: 1px;
	color: rgba(255,255,255,0.7);
	text-transform: uppercase;
	margin-bottom: 4px;
}
.opp-name { font-weight: 600; }
.opp-pts {
	background: rgba(0,0,0,0.4); color: #fff;
	padding: 1px 8px; border-radius: 10px;
	font-weight: 700; font-variant-numeric: tabular-nums;
	min-width: 28px; text-align: center;
	letter-spacing: 0;
}
.opp-hand {
	display: flex; gap: -16px; min-height: 46px;
	align-items: flex-end; justify-content: center;
}
.opp-hand .mini-back {
	width: 26px; height: 38px;
	border-radius: 5px;
	background:
		repeating-linear-gradient(45deg,
			var(--lcs-back-1) 0 5px,
			var(--lcs-back-2) 5px 10px);
	border: 1px solid var(--lcs-card-border);
	box-shadow: 0 1px 4px rgba(0,0,0,0.45);
	margin-left: -10px;
}
.opp-hand .mini-back:first-child { margin-left: 0; }
.opp-hand .uno-tag {
	background: var(--lcs-uno-pulse);
	color: #fff;
	border-radius: 8px;
	padding: 2px 6px;
	font-size: 0.66rem;
	font-weight: 800;
	letter-spacing: 1px;
	animation: unoPulse 800ms ease-in-out infinite;
	margin-left: 6px;
}
@keyframes unoPulse {
	0%,100% { transform: scale(1); filter: brightness(1); }
	50%     { transform: scale(1.1); filter: brightness(1.25); }
}

/* Center table */
.center-row {
	display: flex; gap: 18px; justify-content: center; align-items: center;
	padding: 16px 0 4px;
}
.pile {
	position: relative;
	width: 84px; height: 124px;
	border-radius: 12px;
	display: flex; align-items: center; justify-content: center;
}
.pile.draw {
	cursor: pointer;
}
.pile.draw .card-back-art {
	width: 84px; height: 124px;
	border-radius: 12px;
	background:
		repeating-linear-gradient(45deg,
			var(--lcs-back-1) 0 8px,
			var(--lcs-back-2) 8px 16px);
	border: 2px solid var(--lcs-card-border);
	box-shadow: 0 6px 16px rgba(0,0,0,0.55);
	position: relative;
}
.pile.draw .card-back-art::after {
	content: "LCS";
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	color: rgba(255,255,255,0.55);
	font-weight: 800; font-size: 1.1rem;
	letter-spacing: 2px;
	text-shadow: 0 1px 2px rgba(0,0,0,0.6);
}
.pile.discard .top-card-wrap {
	position: relative;
}
.pile.discard .wild-ring {
	position: absolute; inset: -6px;
	border-radius: 16px;
	border: 3px solid transparent;
	pointer-events: none;
}
.pile.discard .wild-ring.r { border-color: var(--lcs-red); }
.pile.discard .wild-ring.y { border-color: var(--lcs-yellow); }
.pile.discard .wild-ring.g { border-color: var(--lcs-green); }
.pile.discard .wild-ring.b { border-color: var(--lcs-blue); }

.center-meta {
	display: flex; flex-direction: column; gap: 8px;
	align-items: center; min-width: 90px;
}
.color-dots {
	display: flex; gap: 6px;
}
.color-dot {
	width: 14px; height: 14px; border-radius: 50%;
	background: rgba(255,255,255,0.15);
	border: 1px solid rgba(255,255,255,0.2);
	transition: transform 120ms ease, box-shadow 120ms ease;
}
.color-dot.r { background: var(--lcs-red);    }
.color-dot.y { background: var(--lcs-yellow); }
.color-dot.g { background: var(--lcs-green);  }
.color-dot.b { background: var(--lcs-blue);   }
.color-dot.dim { opacity: 0.3; }
.color-dot.active { transform: scale(1.35); box-shadow: 0 0 6px currentColor; }
/* Color-blind mode: stretch the dots and stamp the letter inside. */
body.colorblind .color-dot {
	width: auto; height: auto; padding: 1px 6px;
	border-radius: 6px;
	font-size: 0.65rem; font-weight: 800;
	color: #fff; line-height: 1.2;
	text-shadow: 0 1px 2px rgba(0,0,0,0.7);
}
body.colorblind .color-dot::before { content: attr(data-cb); }

.dir-arrow {
	font-size: 1.5rem;
	line-height: 1;
	color: rgba(255,255,255,0.85);
	transition: transform 380ms ease;
}
.dir-arrow.flip { transform: rotate(180deg); }

.round-info {
	font-size: 0.72rem;
	letter-spacing: 1.5px;
	color: rgba(255,255,255,0.55);
	text-transform: uppercase;
}

/* Card art */
.card {
	width: 78px; height: 116px;
	border-radius: 11px;
	background: var(--lcs-card-bg);
	border: 2px solid var(--lcs-card-border);
	color: var(--lcs-card-border);
	position: relative;
	overflow: hidden;
	box-shadow: 0 5px 14px rgba(0,0,0,0.45);
	user-select: none; -webkit-user-select: none;
	animation: dealIn 220ms ease;
}
.card.no-anim { animation: none; }
.card.col-r { --col: var(--lcs-red); }
.card.col-y { --col: var(--lcs-yellow); }
.card.col-g { --col: var(--lcs-green); }
.card.col-b { --col: var(--lcs-blue); }
.card.col-w { --col: #1c1f26; }

/* Color-blind mode: render the color name across each card. Two paths
   so it survives stale JS caches:
   1. .cb-name child element (set by render.js cardEl) — primary path.
   2. ::after pseudo-element reading from data-c / data-r attributes
      on the card — fallback that fires even when the cached JS hasn't
      added the .cb-name child yet.
   Hidden by default; shown when body has the .colorblind class. */
.card .cb-name {
	display: none;
	position: absolute;
	bottom: 4px; left: 6px;
	z-index: 3;
	font-size: 0.5rem; font-weight: 700;
	letter-spacing: 0.04em;
	color: #000;
	pointer-events: none;
}
.card.col-w .cb-name { color: #000; }
body.colorblind .card .cb-name { display: block; }

/* CSS-only fallback (works even when stale JS hasn't appended the
   .cb-name child yet). Renders via ::after reading from data-c /
   data-r. We DON'T hide the .cb-name child — it just sits underneath
   the same labels and they overlap exactly, so visually it's one
   label either way. */
body.colorblind .card::after {
	display: block;
	position: absolute;
	bottom: 4px; left: 6px;
	z-index: 4;
	font-size: 0.5rem; font-weight: 700;
	letter-spacing: 0.04em;
	color: #000;
	pointer-events: none;
}
body.colorblind .card[data-c="r"]::after { content: 'RED'; }
body.colorblind .card[data-c="y"]::after { content: 'YELLOW'; }
body.colorblind .card[data-c="g"]::after { content: 'GREEN'; }
body.colorblind .card[data-c="b"]::after { content: 'BLUE'; }
/* d6/d8/d10 (stacker) are colored cards — color label still stamps via [data-c]. */
body.colorblind .card[data-c="w"][data-r="wild"]::after { content: 'WILD'; color: #000; }
body.colorblind .card[data-c="w"][data-r="wd4"]::after { content: 'WILD+4'; color: #000; }
/* Colored DUMP cards: append " DUMP" to the color name. */
body.colorblind .card[data-c="r"][data-r="dac"]::after { content: 'RED DUMP'; }
body.colorblind .card[data-c="y"][data-r="dac"]::after { content: 'YELLOW DUMP'; }
body.colorblind .card[data-c="g"][data-r="dac"]::after { content: 'GREEN DUMP'; }
body.colorblind .card[data-c="b"][data-r="dac"]::after { content: 'BLUE DUMP'; }
.card .oval {
	position: absolute;
	top: 14%; left: 12%; right: 12%; bottom: 14%;
	background: var(--col);
	border-radius: 50% / 40%;
	transform: rotate(-22deg);
	box-shadow: inset 0 0 0 2px rgba(0,0,0,0.18);
}
.card.col-w .oval {
	background: conic-gradient(from 45deg,
		var(--lcs-red) 0 25%,
		var(--lcs-yellow) 25% 50%,
		var(--lcs-green) 50% 75%,
		var(--lcs-blue) 75% 100%);
}
.card .corner {
	position: absolute;
	font-weight: 800;
	font-size: 0.8rem;
	line-height: 1;
	letter-spacing: 0;
	text-shadow: 0 1px 0 rgba(255,255,255,0.4);
	color: var(--col);
}
.card.col-w .corner { color: #1c1f26; }
.card .corner.tl { top: 5px; left: 6px; }
.card .corner.br { bottom: 5px; right: 6px; transform: rotate(180deg); }
.card .glyph {
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	font-weight: 800;
	font-size: 2.2rem;
	color: #fff;
	text-shadow:
		 1px  1px 0 rgba(0,0,0,.55),
		-1px  1px 0 rgba(0,0,0,.55),
		 1px -1px 0 rgba(0,0,0,.55),
		-1px -1px 0 rgba(0,0,0,.55);
	letter-spacing: 0;
}
.card .glyph.small { font-size: 1.4rem; }
.card.col-w .glyph { color: #fff; }

@keyframes dealIn {
	0%   { transform: translate(60px, -120px) rotate(-25deg); opacity: 0; }
	100% { transform: translate(0, 0) rotate(0); opacity: 1; }
}

.wild-burst {
	position: absolute; inset: -10px;
	pointer-events: none;
	border-radius: 50%;
	animation: wildBurst 600ms ease-out forwards;
	z-index: 4;
}
@keyframes wildBurst {
	0%   { opacity: 0.9; transform: scale(0.4); }
	100% { opacity: 0;   transform: scale(2.4); }
}

/* Player area */
.player {
	margin-top: auto;
	display: flex; flex-direction: column; gap: 8px;
	padding: 8px 4px 4px;
}
.player-head {
	display: flex; align-items: center; justify-content: space-between;
	gap: 8px;
	font-size: 0.78rem; letter-spacing: 1px;
	color: rgba(255,255,255,0.65);
	text-transform: uppercase;
}
.player-head .you-pts {
	background: rgba(0,0,0,0.4); color: #fff;
	padding: 1px 8px; border-radius: 10px;
	font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: 0;
}
.player-head .uno-armed {
	background: var(--lcs-uno-pulse); color: #fff;
	border-radius: 999px; padding: 2px 10px;
	font-weight: 800; font-size: 0.7rem;
	animation: unoPulse 800ms ease-in-out infinite;
}
.hand {
	display: flex; gap: 4px; justify-content: center;
	flex-wrap: wrap;
	min-height: 130px;
}
.hand .card { cursor: pointer; transition: transform 120ms ease, box-shadow 120ms ease; }
.hand .card:hover { transform: translateY(-6px); box-shadow: 0 10px 22px rgba(0,0,0,0.5); }
.hand .card.disabled {
	opacity: 0.45; pointer-events: none;
	filter: grayscale(0.2);
}
.hand .card.active { box-shadow: var(--lcs-active-glow); }

/* Buttons */
.actions {
	display: flex; gap: 8px; justify-content: center;
	flex-wrap: wrap; padding-top: 4px;
}
.btn {
	appearance: none; border: 0;
	background: var(--accent); color: #0b1220;
	padding: 9px 16px; border-radius: 10px;
	font: inherit; font-weight: 700; cursor: pointer;
	letter-spacing: 0.5px;
	min-width: 80px;
	transition: filter 80ms ease, transform 60ms ease;
}
.btn:hover:not([disabled]) { filter: brightness(1.1); }
.btn:active:not([disabled]) { transform: translateY(1px); }
.btn[disabled] { opacity: 0.35; cursor: not-allowed; }
.btn.gold   { background: var(--gold); color: #4a2a14; }
.btn.danger { background: #c2293c; color: #fff; }
.btn.ghost  {
	background: var(--grid);
	color: var(--text);
	border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
}
.btn.ghost:hover:not([disabled]) {
	background: color-mix(in srgb, var(--text) 12%, var(--grid));
	border-color: color-mix(in srgb, var(--text) 32%, transparent);
}
.btn.uno    { background: var(--lcs-uno-pulse); color: #fff; animation: unoPulse 800ms ease-in-out infinite; }
@keyframes wiggle {
	0%, 100% { transform: translateX(0) rotate(0); }
	15% { transform: translateX(-4px) rotate(-3deg); }
	30% { transform: translateX(4px)  rotate(3deg); }
	45% { transform: translateX(-3px) rotate(-2deg); }
	60% { transform: translateX(3px)  rotate(2deg); }
	75% { transform: translateX(-1px) rotate(-1deg); }
}
.btn.wiggle:not([disabled]) {
	animation: wiggle 700ms ease-in-out infinite;
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 35%, transparent);
}

.message {
	text-align: center;
	font-size: 0.92rem; color: #fff;
	min-height: 1.4em;
	padding: 4px 0;
	letter-spacing: 0.3px;
}
.message .win  { color: #6ee7b7; font-weight: 700; }
.message .lose { color: #fca5a5; font-weight: 700; }

/* Pregame screen — title → mode tabs → swappable card → CTA → seed hint. */
.pregame {
	position: absolute; inset: 0;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	gap: 14px; padding: 24px; text-align: center;
	background: rgba(0,0,0,0.78); backdrop-filter: blur(4px);
	border-radius: 28px;
	z-index: 9;
}
.pregame[hidden] { display: none; }
.pregame-title {
	margin: 0; font-size: 1.35rem; color: #fff;
	letter-spacing: 0.02em;
}
.pregame p { margin: 0; color: rgba(255,255,255,0.85); max-width: 36ch; }

/* Card that holds the per-mode content. Solo and Friend swap inside it. */
.pregame-card {
	width: min(92vw, 380px);
	padding: 18px 18px 20px;
	border-radius: 18px;
	background: rgba(255,255,255,0.045);
	border: 1px solid rgba(255,255,255,0.10);
	box-shadow: 0 6px 28px rgba(0,0,0,0.35);
	display: flex; flex-direction: column; gap: 14px;
	align-items: center;
}
.pregame-section { display: flex; flex-direction: column; gap: 12px; align-items: center; width: 100%; }
.pregame-section[hidden] { display: none; }

/* Single CTA — fixed below the card. */
.pregame-cta { min-width: 180px; padding: 10px 22px; font-size: 1rem; }

/* Footer hint that opens the drawer. */
.pregame-seed-hint {
	background: transparent; border: 0; padding: 4px 8px;
	color: rgba(255,255,255,0.6); font-size: 0.78rem;
	cursor: pointer; font-family: inherit;
	transition: color 120ms;
}
.pregame-seed-hint:hover { color: var(--gold); }
.pregame-seed-hint b { color: var(--gold); font-weight: 700; }

/* Friend sub-tabs (Host / Join). */
.friend-mode-picker { display: flex; gap: 6px; }
.friend-mode-pick {
	padding: 6px 12px; border-radius: 999px;
	border: 1px solid rgba(255,255,255,0.18);
	background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.85);
	font-weight: 600; font-size: 0.82rem; cursor: pointer;
	transition: border-color 120ms, background 120ms, color 120ms;
}
.friend-mode-pick:hover { border-color: var(--gold); color: #fff; }
.friend-mode-pick.sel {
	border-color: var(--gold); background: rgba(245,192,66,0.18);
	color: #fff;
}
.friend-sub { width: 100%; }
.friend-sub[hidden] { display: none; }
.opp-picker {
	display: flex; gap: 8px; align-items: center;
}
.opp-picker[hidden] { display: none; }
.opp-picker-label {
	font-weight: 700; color: rgba(255,255,255,0.85);
	margin-right: 4px; font-size: 0.95rem;
}
.opp-pick {
	width: 56px; height: 56px;
	border-radius: 14px;
	border: 2px solid rgba(255,255,255,0.2);
	background: rgba(255,255,255,0.06);
	color: #fff;
	font-weight: 800; font-size: 1.5rem;
	cursor: pointer;
	transition: border-color 120ms ease, transform 80ms ease;
}
.opp-pick:hover { border-color: var(--gold); }
.opp-pick.sel   { border-color: var(--gold); background: rgba(245,192,66,0.18); transform: translateY(-2px); }

/* Mode picker — Solo / Friend match */
.mode-picker { display: flex; gap: 8px; }
.mode-pick {
	padding: 8px 16px; border-radius: 12px;
	border: 2px solid rgba(255,255,255,0.18);
	background: rgba(255,255,255,0.05); color: #fff;
	font-weight: 700; font-size: 0.9rem; cursor: pointer;
	transition: border-color 120ms, background 120ms;
}
.mode-pick:hover { border-color: var(--gold); }
.mode-pick.sel   { border-color: var(--gold); background: rgba(245,192,66,0.18); }
.friend-row {
	display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
	max-width: 36ch;
}
.friend-row input {
	flex: 1 1 8ch;
	padding: 7px 9px; border-radius: 8px;
	border: 2px solid rgba(255,255,255,0.18);
	background: rgba(0,0,0,0.3); color: #fff;
	text-transform: uppercase; letter-spacing: 0.12em;
	font-family: inherit; font-weight: 700;
}
.friend-row .btn { padding: 7px 14px; font-size: 0.85rem; }
.friend-or {
	width: 100%; text-align: center;
	color: rgba(255,255,255,0.65); font-size: 0.78rem;
	margin-top: 2px;
}
.invite-banner {
	background: rgba(245,192,66,0.16);
	border: 1px solid var(--gold);
	color: var(--text); padding: 8px 12px; border-radius: 10px;
	font-size: 0.85rem; margin-top: 8px;
}
.invite-banner b { color: var(--gold); letter-spacing: 0.15em; }

/* Drawer-specific overrides for moved sections */
.drawer .rule-picker.drawer-rules { max-width: none; }
.drawer .rule-pick {
	background: color-mix(in srgb, var(--text) 5%, transparent);
	border-color: color-mix(in srgb, var(--text) 14%, transparent);
}
.debug-log {
	width: 100%; min-height: 110px; resize: vertical;
	background: var(--bg);
	color: var(--text);
	font-family: ui-monospace, 'SF Mono', Menlo, monospace;
	font-size: 0.72rem; line-height: 1.4;
	border-radius: 8px;
	border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
	padding: 8px 10px;
	white-space: pre;
	overflow: auto;
}
.debug-row {
	display: flex; gap: 6px; align-items: center; margin-top: 6px;
	flex-wrap: wrap;
}
.debug-row .btn { padding: 5px 10px; font-size: 0.78rem; min-width: 0; }
.debug-status {
	font-size: 0.74rem; color: var(--muted);
}
.drawer .seed-row.drawer-seed {
	margin-top: 6px; flex-wrap: wrap;
	color: var(--text);
}
.drawer .seed-row.drawer-seed .seed-label b { color: var(--gold); }
.drawer .friend-row.drawer-friend { max-width: none; gap: 6px; }
.drawer .friend-row.drawer-friend input {
	background: var(--bg);
	color: var(--text);
	border-color: color-mix(in srgb, var(--text) 18%, transparent);
}
.drawer .local-opt.drawer-opt {
	background: color-mix(in srgb, var(--text) 5%, transparent);
	color: var(--text);
}
.drawer .local-opt.drawer-opt:hover {
	background: color-mix(in srgb, var(--text) 10%, transparent);
}

/* Player status bar — hand size, actions, turn time, total time. */
.status-bar {
	display: flex; flex-wrap: wrap; gap: 16px;
	padding: 8px 14px; margin-top: 6px;
	border-radius: 12px;
	background: color-mix(in srgb, var(--text) 8%, transparent);
	border: 1px solid color-mix(in srgb, var(--text) 14%, transparent);
	color: var(--text); font-size: 0.78rem;
	align-items: baseline; justify-content: space-around;
	font-variant-numeric: tabular-nums;
}
.status-bar[hidden] { display: none; }
.sb-cell { display: inline-flex; align-items: baseline; gap: 4px; }
.sb-label {
	color: var(--muted); text-transform: uppercase;
	letter-spacing: 0.08em; font-size: 0.7rem;
}
.sb-cell b { font-weight: 700; font-size: 0.95rem; }
.sb-unit { color: var(--muted); font-size: 0.7rem; margin-left: 1px; }
.sb-delta {
	font-size: 0.72rem; font-weight: 700;
	padding: 1px 6px; border-radius: 999px;
	margin-left: 4px;
}
.sb-delta.under { background: rgba(96,165,250,0.18); color: var(--accent); }
.sb-delta.over  { background: rgba(231, 76, 60, 0.20); color: #e74c3c; }
.sb-delta.zero  { display: none; }

/* Friend-match — three mutually-exclusive states */
.friend-panel, .friend-host, .friend-joined {
	display: flex; flex-direction: column; gap: 8px;
	max-width: 38ch; width: 100%;
	padding: 4px 0;
}
.friend-panel[hidden], .friend-host[hidden], .friend-joined[hidden] { display: none; }

/* (1) Initial: Host/Join sub-content lives here. The sub-tab picker
   above gives it visual identity; no border needed inside the card. */
.friend-panel { background: transparent; border: 0; padding: 0; }
.friend-instruction {
	font-size: 0.82rem; color: rgba(255,255,255,0.82);
}
.friend-row { display: flex; gap: 8px; }
.friend-row input {
	flex: 1 1 auto;
	padding: 8px 10px; border-radius: 8px;
	border: 2px solid rgba(255,255,255,0.18);
	background: rgba(0,0,0,0.3); color: #fff;
	text-transform: uppercase; letter-spacing: 0.18em;
	font-family: inherit; font-weight: 700; font-size: 0.95rem;
	text-align: center;
}
.friend-row .btn { padding: 8px 14px; font-size: 0.9rem; white-space: nowrap; }
.lobby-config {
	display: flex; flex-direction: column; gap: 6px;
}
.lobby-row { display: flex; align-items: center; gap: 8px; }
.lobby-label {
	font-size: 0.78rem; color: rgba(255,255,255,0.78);
	min-width: 9ch; text-align: right;
}
.stepper {
	display: inline-flex; align-items: center; gap: 4px;
	background: rgba(0,0,0,0.25); border-radius: 999px;
	padding: 2px 4px;
	border: 1px solid rgba(255,255,255,0.15);
}
.step-btn {
	width: 26px; height: 26px; border-radius: 50%;
	border: 0; background: rgba(255,255,255,0.06);
	color: #fff; font-size: 1rem; line-height: 1; cursor: pointer;
	padding: 0;
	transition: background 100ms;
}
.step-btn:hover { background: rgba(255,255,255,0.18); }
.step-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.step-val {
	min-width: 24px; text-align: center;
	color: var(--gold); font-weight: 700; font-size: 0.95rem;
	font-variant-numeric: tabular-nums;
}
.lobby-summary {
	font-size: 0.74rem; color: rgba(255,255,255,0.65);
	text-align: center;
}

/* (2) Hosting: code + status + (Begin game = main btnStart) */
.friend-host {
	border: 2px solid var(--gold);
	background: rgba(245,192,66,0.14);
}
.friend-host-label {
	font-size: 0.82rem; color: rgba(255,255,255,0.85);
}
.friend-host-row { display: flex; align-items: center; gap: 8px; }
.friend-invite-code {
	flex: 1 1 auto;
	padding: 8px 12px;
	background: rgba(0,0,0,0.3);
	border-radius: 8px;
	color: var(--gold);
	font-family: monospace;
	font-weight: 700;
	font-size: 1.35rem;
	letter-spacing: 0.3em;
	text-align: center;
}
.friend-host-row .btn { padding: 7px 14px; font-size: 0.85rem; }
.icon-btn {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 7px 9px; min-width: 36px;
}
.icon-btn svg { display: block; }
.icon-btn .icon-success { display: none; color: var(--gold); }
.icon-btn.copied .icon-default { display: none; }
.icon-btn.copied .icon-success { display: block; }
.friend-host-status {
	font-size: 0.82rem; color: rgba(255,255,255,0.85);
	text-align: center;
}

/* (3) Joined: status only, no buttons (host drives start) */
.friend-joined {
	border: 1px solid rgba(96,165,250,0.55);
	background: rgba(96,165,250,0.10);
	text-align: center;
}
.friend-joined-title {
	font-size: 1rem; font-weight: 700; color: #fff;
}
.friend-joined-status {
	font-size: 0.85rem; color: rgba(255,255,255,0.78);
}

/* Rule-seed picker (custom-game checkboxes) */
.rule-picker {
	display: flex; flex-direction: column; gap: 6px;
	max-width: 38ch; width: 100%;
}
.rule-pick {
	display: flex; align-items: flex-start; gap: 10px;
	padding: 10px 12px;
	border-radius: 12px;
	border: 2px solid color-mix(in srgb, var(--text) 18%, transparent);
	background: color-mix(in srgb, var(--text) 6%, transparent);
	color: var(--text);
	text-align: left;
	cursor: pointer;
	transition: border-color 120ms ease, background 120ms ease;
}
.rule-pick:hover { border-color: var(--gold); }
.rule-pick.sel   { border-color: var(--gold); background: rgba(245,192,66,0.14); }
/* Sub-rules indent under their parent and dim when parent is off. */
.rule-pick.rule-sub { margin-left: 22px; padding: 6px 10px; font-size: 0.85em; }
.rule-pick.rule-sub input:disabled ~ .rule-text { opacity: 0.45; }
.rule-pick.rule-sub input:disabled { cursor: not-allowed; }
.rule-pick input { margin-top: 3px; accent-color: var(--gold); }
.rule-pick .rule-text { display: flex; flex-direction: column; gap: 2px; }
.rule-pick .rule-label { font-weight: 700; font-size: 0.92rem; color: var(--text); }
.rule-pick .rule-desc  { font-size: 0.78rem; color: var(--muted); }
.a11y-row {
	display: flex; align-items: center; gap: 8px;
	font-size: 0.85rem; color: var(--text);
	cursor: pointer; user-select: none;
}
.a11y-row input { margin: 0; cursor: pointer; }
.leaders-bot-toggle {
	display: inline-flex; align-items: center; gap: 4px;
	margin-left: 10px; font-size: 0.7rem; font-weight: 500;
	color: var(--muted); cursor: pointer; user-select: none;
}
.leaders-bot-toggle input { margin: 0; cursor: pointer; }
.leaders-bot-toggle:hover { color: var(--text); }
.rule-picker.locked .rule-pick { opacity: 0.55; cursor: not-allowed; }
.rule-picker.locked .rule-pick:hover {
	border-color: color-mix(in srgb, var(--text) 18%, transparent);
}
.seed-row {
	display: flex; align-items: center; gap: 12px;
	font-size: 0.82rem; color: var(--text);
}
.seed-row .seed-label b { color: var(--gold); font-weight: 700; }
.seed-row .btn { padding: 6px 12px; font-size: 0.82rem; }

/* Local options — UI-only, never seed/leaderboard */
.local-opts {
	display: flex; flex-direction: column; gap: 4px;
	max-width: 38ch; width: 100%;
	padding-top: 6px; border-top: 1px dashed rgba(255,255,255,0.12);
}
.local-opts .local-opts-title {
	font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em;
	color: rgba(255,255,255,0.55); padding-bottom: 2px;
}
.local-opts label.local-opt {
	display: flex; align-items: flex-start; gap: 10px;
	padding: 8px 10px; border-radius: 10px;
	background: rgba(255,255,255,0.03);
	color: #fff; cursor: pointer;
}
.local-opts label.local-opt:hover { background: rgba(255,255,255,0.07); }
.local-opts label.local-opt input { margin-top: 3px; accent-color: var(--accent, #60a5fa); }
.local-opts .local-opt .lo-text { display: flex; flex-direction: column; gap: 2px; }
.local-opts .local-opt .lo-label { font-weight: 600; font-size: 0.86rem; }
.local-opts .local-opt .lo-desc  { font-size: 0.74rem; color: rgba(255,255,255,0.7); }

/* Wild color picker */
.color-picker {
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	background: rgba(0,0,0,0.6); backdrop-filter: blur(2px);
	z-index: 9;
}
.color-picker[hidden] { display: none; }
.color-picker-inner {
	background: var(--panel); color: var(--text);
	padding: 18px 22px; border-radius: 18px;
	display: flex; flex-direction: column; align-items: center; gap: 12px;
	box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}
.color-picker-inner h3 {
	margin: 0; font-size: 0.85rem; color: var(--muted);
	letter-spacing: 0.6px; text-transform: uppercase; font-weight: 500;
}
.color-grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
/* Color picker buttons styled like a miniature card face: same body
   color + border + radius as .card, with the tilted colored oval
   inside via ::before so the picker visually matches the deck. */
.color-btn {
	position: relative;
	width: 72px; height: 72px;
	border-radius: 11px;
	background: var(--lcs-card-bg);
	border: 2px solid var(--lcs-card-border);
	cursor: pointer;
	overflow: hidden;
	box-shadow: 0 5px 14px rgba(0,0,0,0.45);
	transition: transform 80ms ease;
}
.color-btn::before {
	content: '';
	position: absolute;
	top: 14%; left: 12%; right: 12%; bottom: 14%;
	background: var(--col);
	border-radius: 50% / 40%;
	transform: rotate(-22deg);
	box-shadow: inset 0 0 0 2px rgba(0,0,0,0.18);
}
.color-btn:hover { transform: scale(1.05); }
.color-btn:focus-visible { outline: 2px solid var(--accent, #fff); outline-offset: 2px; }
.color-btn.r { --col: var(--lcs-red); }
.color-btn.y { --col: var(--lcs-yellow); }
.color-btn.g { --col: var(--lcs-green); }
.color-btn.b { --col: var(--lcs-blue); }
.color-cancel {
	margin-top: 6px; font-size: 0.8rem; padding: 6px 14px;
	color: var(--muted);
}
.color-cancel:hover { color: var(--text); }

/* Stack pill — visible during the-stacker rule when pendingDraw>0. */
.stack-pill {
	position: absolute;
	top: -10px; right: -16px;
	background: #c0392b; color: #fff;
	font-size: 0.78rem; font-weight: 800;
	padding: 4px 10px; border-radius: 999px;
	letter-spacing: 0.06em;
	box-shadow: 0 3px 10px rgba(0,0,0,0.4);
	border: 2px solid rgba(255,255,255,0.18);
	animation: stackPulse 1.2s ease-in-out infinite;
	z-index: 5;
	pointer-events: none;
}
@keyframes stackPulse {
	0%, 100% { transform: scale(1); }
	50%      { transform: scale(1.08); }
}

/* Stack feed — readable, persistent log of stack events.
   Mounts above the player area; lines fade out after ~6s. */
.stack-feed {
	display: flex; flex-direction: column; gap: 4px;
	margin: 6px auto 0; padding: 6px 10px;
	max-width: 38ch; min-height: 0;
	background: rgba(0,0,0,0.45);
	border: 1px solid rgba(192,57,43,0.45);
	border-radius: 10px;
	font-size: 0.78rem; color: #fff;
	box-shadow: 0 2px 10px rgba(0,0,0,0.35);
}
.stack-feed[hidden] { display: none; }
.stack-feed .feed-row {
	display: flex; gap: 8px; align-items: baseline;
	font-variant-numeric: tabular-nums;
	animation: feedIn 200ms ease;
}
.stack-feed .feed-row.fade { opacity: 0.45; }
.stack-feed .feed-row.you  { color: #f5c042; font-weight: 700; }
.stack-feed .feed-row.bad  { color: #ff8a80; }
.stack-feed .feed-actor { min-width: 7ch; color: rgba(255,255,255,0.75); font-weight: 600; }
@keyframes feedIn {
	from { opacity: 0; transform: translateY(-3px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* Color Dump SVG glyph — fan-of-cards over the colored oval. The glyph
   container's text alignment doesn't matter; the SVG fills it. */
.card .glyph.dac-glyph {
	display: flex; align-items: center; justify-content: center;
	font-size: 0;  /* hide any text fallback bleed */
}
.card .glyph .dump-svg {
	width: 78%; height: 78%;
	display: block;
	filter: drop-shadow(0 1px 1px rgba(0,0,0,0.4));
}

/* Round / game over overlay */
.overlay {
	position: absolute; inset: 0;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	gap: 10px; padding: 28px; text-align: center;
	background: rgba(0,0,0,0.65); backdrop-filter: blur(4px);
	border-radius: 28px;
	z-index: 10;
}
.overlay[hidden] { display: none; }
.overlay h2 { margin: 0; font-size: 1.6rem; color: #fff; }
.overlay p  { margin: 0; color: rgba(255,255,255,0.85); max-width: 38ch; }
.overlay .stat-line { font-size: 0.85rem; color: rgba(255,255,255,0.7); font-variant-numeric: tabular-nums; }
.overlay .status { font-size: 0.78rem; color: var(--gold); font-family: ui-monospace, monospace; }
.overlay .btn-row { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }

footer {
	font-size: 0.78rem; color: var(--muted);
	width: min(880px, 100%);
	display: flex; justify-content: space-between;
	gap: 8px; flex-wrap: wrap;
}
kbd {
	font: inherit; font-size: 0.72rem;
	background: var(--grid); border: 1px solid #2a3042;
	border-radius: 4px; padding: 1px 6px;
}

/* Drawer */
.drawer-toggle, .fs-btn, .share-btn {
	background: transparent; color: var(--muted);
	border: 0; padding: 6px 8px; cursor: pointer;
	font-size: 1.2rem;
}
.drawer-toggle:hover, .fs-btn:hover, .share-btn:hover { color: var(--text); }
.fs-btn[aria-pressed="true"] { color: var(--text); }
.share-btn svg { width: 18px; height: 18px; vertical-align: middle; }
/* ===== Drawer accordion ===== */
.accordion-section { transition: padding 160ms ease; }
.accordion-head {
	cursor: pointer; user-select: none;
	display: flex; align-items: center; justify-content: space-between;
	gap: 8px; margin: 0 0 6px;
}
.accordion-head .acc-chev {
	display: inline-block; transition: transform 160ms ease;
	color: var(--muted); font-size: 0.78em;
}
.accordion-section.collapsed > *:not(.accordion-head):not(h3) { display: none !important; }
.accordion-section.collapsed { padding-bottom: 0; }
.accordion-section.collapsed .acc-chev { transform: rotate(-90deg); }
.accordion-head:focus-visible { outline: 2px solid var(--accent, #60a5fa); outline-offset: 2px; }

.share-targets {
	display: grid; grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
	gap: 6px; margin-bottom: 8px;
}
.share-target {
	display: flex; flex-direction: column; align-items: center; gap: 3px;
	padding: 8px 4px; border-radius: 8px;
	background: var(--grid, #1b2030); border: 1px solid var(--rail-border, rgba(255,255,255,0.08));
	color: var(--text); cursor: pointer; font: inherit;
	transition: transform 80ms ease, border-color 120ms ease;
}
.share-target:hover { transform: translateY(-1px); border-color: var(--share-color, var(--accent, #60a5fa)); }
.share-target:active { transform: translateY(0); }
.share-target-icon {
	width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center;
	color: var(--share-color, currentColor);
}
.share-target-icon svg { width: 22px; height: 22px; }
.share-target-label { font-size: 0.66rem; color: var(--muted); letter-spacing: 0.02em; }

.share-row { display: flex; gap: 6px; align-items: center; }
.share-row input {
	flex: 1; background: var(--grid, #1b2030); border: 1px solid var(--rail-border, rgba(255,255,255,0.08));
	color: var(--text); padding: 6px 8px; border-radius: 6px; font-size: 0.78rem;
	font-family: ui-monospace, Menlo, Consolas, monospace;
}
.share-status { font-size: 0.72rem; color: var(--ok, #6ee7b7); margin-top: 4px; min-height: 1em; }

/* Drawer game-chat (room_type='game'). Per-match chat (.lcs-chat-*) is separate. */
.game-chat-section .game-chat-msgs {
	list-style: none; margin: 0; padding: 6px;
	background: rgba(0,0,0,0.18); border: 1px solid var(--rail-border, rgba(255,255,255,0.08));
	border-radius: 6px;
	max-height: 220px; overflow-y: auto;
	font-size: 0.82rem;
}
.game-chat-section .game-chat-msgs li { padding: 3px 4px; border: 0; display: block; }
.game-chat-section .game-chat-msgs li.empty { color: var(--muted); }
.game-chat-section .game-chat-msgs .chat-line b { color: var(--accent, #60a5fa); margin-right: 4px; }
.game-chat-section .game-chat-msgs .chat-reactions { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 2px; }
.game-chat-section .game-chat-msgs .chat-react-chip,
.game-chat-section .game-chat-msgs .chat-react-add {
	display: inline-flex; align-items: center; gap: 3px;
	background: rgba(255,255,255,0.06); border: 1px solid var(--rail-border, rgba(255,255,255,0.08));
	color: var(--text); border-radius: 999px; padding: 1px 8px;
	font-size: 0.78rem; cursor: pointer; line-height: 1.4;
}
.game-chat-section .game-chat-msgs .chat-react-chip.mine { background: rgba(96,165,250,0.18); border-color: rgba(96,165,250,0.45); }
.game-chat-form { display: flex; gap: 6px; margin-top: 6px; }
.game-chat-form input {
	flex: 1; background: var(--grid, #1b2030); border: 1px solid var(--rail-border, rgba(255,255,255,0.08));
	color: var(--text); padding: 6px 8px; border-radius: 6px; font-size: 0.85rem;
}
.game-chat-form button {
	background: var(--accent, #60a5fa); color: #0a1320; border: 0;
	padding: 6px 12px; border-radius: 6px; cursor: pointer; font-weight: 600;
}

/* iOS hardening — drop blur over the redrawing surface, lock viewport
 * height to a JS-set --app-h (set by /js/shared/ios.js). */
html.is-ios body, html.is-ios main { min-height: 0; height: var(--app-h, 100dvh); }
html.is-ios .overlay,
html.is-ios .drawer-backdrop,
html.is-ios .lcs-chat-panel {
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
}
.drawer-backdrop {
	position: fixed; inset: 0; background: rgba(0,0,0,0.4);
	opacity: 0; pointer-events: none;
	transition: opacity 180ms ease;
	z-index: 20;
}
.drawer-backdrop.open { opacity: 1; pointer-events: auto; }
.drawer {
	position: fixed; top: 0; right: 0; bottom: 0;
	width: var(--drawer-w); max-width: 90vw;
	background: var(--panel);
	box-shadow: -10px 0 40px rgba(0,0,0,0.5);
	transform: translateX(100%);
	transition: transform 200ms ease;
	padding: 20px 18px; overflow-y: auto;
	z-index: 21;
	display: flex; flex-direction: column; gap: 16px;
	color: var(--text);
}
.drawer.open { transform: translateX(0); }
.drawer h3 {
	margin: 0 0 6px; font-size: 0.85rem;
	color: var(--muted); font-weight: 500;
	letter-spacing: 0.6px; text-transform: uppercase;
}
.drawer section { border-bottom: 1px solid var(--grid); padding-bottom: 14px; }
.drawer section:last-child { border-bottom: 0; }
.drawer .close {
	position: absolute; top: 12px; right: 12px;
	background: transparent; color: var(--muted);
	border: 0; font-size: 1.2rem; cursor: pointer;
}
.drawer .close:hover { color: var(--text); }
.current-name {
	display: flex; align-items: baseline; gap: 8px;
	padding: 6px 10px; margin-bottom: 8px;
	background: var(--bg); border: 1px solid var(--grid);
	border-radius: 6px;
}
.current-name-label { font-size: 0.72rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; }
.current-name-value { font-size: 0.95rem; color: var(--text); font-weight: 600; font-family: ui-monospace, Menlo, Consolas, monospace; }
.current-name-value .verified { color: #6ee7b7; margin-left: 4px; }
.rename-form { display: flex; gap: 6px; align-items: stretch; }
.rename-form input {
	flex: 1; background: var(--bg); color: var(--text);
	border: 1px solid var(--grid); border-radius: 6px;
	padding: 6px 10px; font: inherit; font-size: 0.9rem;
}
.rename-form input:focus { outline: 1px solid var(--accent); border-color: var(--accent); }
.rename-form button {
	background: var(--accent); color: #0b1220;
	border: 0; border-radius: 6px; padding: 6px 12px;
	font: inherit; font-weight: 600; cursor: pointer;
}
.rename-msg { font-size: 0.78rem; color: var(--muted); margin-top: 6px; min-height: 1.2em; }
.rename-msg.ok   { color: #6ee7b7; }
.rename-msg.err  { color: #fca5a5; }
.suggestion { display: inline-block; margin: 2px 4px 0 0; padding: 2px 6px;
              background: var(--grid); border-radius: 6px; font-size: 0.72rem;
              color: var(--text); cursor: pointer; }
.suggestion:hover { background: var(--accent); color: #0b1220; }

.leaders { list-style: none; margin: 0; padding: 0; font-size: 0.82rem; }
.leaders li {
	display: grid; grid-template-columns: 22px 1fr auto auto;
	gap: 8px; align-items: baseline;
	padding: 3px 0;
}
.leaders li.me { color: var(--accent); font-weight: 600; }
.leaders .rank { color: var(--muted); font-variant-numeric: tabular-nums; }
.leaders .name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.leaders .score { font-variant-numeric: tabular-nums; }
.leaders .time { color: var(--muted); font-size: 0.7rem; font-variant-numeric: tabular-nums; }
.empty { color: var(--muted); font-size: 0.8rem; font-style: italic; }

.stats { display: grid; grid-template-columns: 1fr auto; gap: 4px 12px; margin: 0; font-size: 0.85rem; }
.stats dt { color: var(--muted); }
.stats dd { margin: 0; font-variant-numeric: tabular-nums; font-weight: 600; }

@media (max-width: 480px) {
	.card { width: 60px; height: 90px; }
	.card .glyph { font-size: 1.7rem; }
	.card .glyph.small { font-size: 1.05rem; }
	.card .corner { font-size: 0.7rem; }
	.pile, .pile.draw .card-back-art { width: 70px; height: 100px; }
	.btn { min-width: 72px; padding: 8px 12px; font-size: 0.85rem; }
	.opp { min-height: 70px; padding: 6px 8px; }
	.opp-hand .mini-back { width: 18px; height: 26px; }
	.table { padding: 18px 10px 8px; min-height: 540px; }
}

/* ============================================================
   Phase E — in-match chat dock + host invite list + seat kick
   ============================================================ */

.lcs-chat-dock {
	/* The match chat lives in the site-wide social panel as a Match
	   pill (see /assets/social.js — Gamehub.social.setMatchRoom). The
	   standalone dock would be a duplicate floating element on phones,
	   so we hide it unconditionally. The DOM and JS wiring stay in
	   place as a fallback path if Gamehub.social ever fails to load. */
	display: none !important;
	position: fixed;
	left: 16px;
	bottom: 16px;
	z-index: 50;
	flex-direction: column; align-items: flex-start;
	gap: 8px;
	font: 13px/1.4 system-ui, -apple-system, Segoe UI, sans-serif;
}
.lcs-chat-toggle {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px;
	border-radius: 22px;
	background: var(--panel);
	color: var(--text);
	border: 1px solid var(--grid);
	cursor: pointer;
	box-shadow: 0 6px 14px rgba(0,0,0,0.32);
	font-weight: 600;
}
.lcs-chat-toggle:hover { border-color: var(--accent); }
.lcs-chat-toggle .dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: #22c55e;
	box-shadow: 0 0 0 2px rgba(34,197,94,0.18);
}
.lcs-chat-toggle .badge {
	min-width: 18px; height: 18px; padding: 0 5px;
	border-radius: 9px;
	background: var(--accent); color: #0b0d12;
	font: 700 11px/18px system-ui;
	margin-left: 2px;
}
.lcs-chat-toggle .badge[data-count="0"] { display: none; }

.lcs-chat-panel {
	width: 320px;
	max-width: 90vw;
	height: 360px;
	max-height: 60vh;
	display: flex; flex-direction: column;
	background: var(--panel);
	border: 1px solid var(--grid);
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 14px 38px rgba(0,0,0,0.45);
}
.lcs-chat-head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 6px 8px 6px 12px;
	border-bottom: 1px solid var(--grid);
	font: 700 12px/1 system-ui;
	color: var(--text);
}
.lcs-chat-close {
	border: 0;
	background: transparent;
	color: var(--muted);
	font: 700 18px/1 system-ui;
	cursor: pointer;
	width: 24px; height: 24px;
	border-radius: 6px;
	opacity: 0.75;
}
.lcs-chat-close:hover { opacity: 1; color: var(--text); background: rgba(255,255,255,0.05); }
.lcs-chat-msgs {
	flex: 1; overflow-y: auto;
	padding: 8px 10px;
	display: flex; flex-direction: column; gap: 4px;
}
.lcs-chat-msgs .lcs-chat-msg {
	font-size: 12.5px;
	color: var(--text);
}
.lcs-chat-msgs .lcs-chat-msg .who {
	font-weight: 700; color: var(--accent); margin-right: 4px;
}
.lcs-chat-msgs .lcs-chat-msg .when {
	color: var(--muted); font-size: 10.5px; margin-left: 4px;
}
.lcs-chat-msgs .lcs-chat-empty {
	margin: auto;
	color: var(--muted);
	font: 500 12px/1.4 system-ui;
	text-align: center;
}
.lcs-chat-form {
	display: flex; gap: 6px;
	padding: 8px;
	border-top: 1px solid var(--grid);
}
.lcs-chat-form input {
	flex: 1;
	padding: 6px 9px;
	border: 1px solid var(--grid);
	border-radius: 8px;
	background: var(--bg);
	color: var(--text);
	font: 12.5px/1.4 system-ui;
}
.lcs-chat-form input:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
.lcs-chat-form button {
	padding: 6px 10px;
	border: 0;
	border-radius: 8px;
	background: var(--accent);
	color: #0b0d12;
	font: 700 12px/1 system-ui;
	cursor: pointer;
}

/* host invite-friend mini list */
.friend-host-actions {
	margin-top: 8px;
	display: flex;
	justify-content: center;
}
.invite-friend-list {
	margin-top: 8px;
	border: 1px solid var(--grid);
	border-radius: 10px;
	background: var(--bg);
	padding: 8px;
	max-height: 220px;
	overflow-y: auto;
}
.invite-friend-list-head {
	display: flex; align-items: center; justify-content: space-between;
	font: 700 12px/1 system-ui;
	color: var(--muted);
	margin-bottom: 6px;
}
.invite-list-close {
	border: 0; background: transparent; color: var(--muted);
	font: 700 16px/1 system-ui;
	cursor: pointer;
}
.invite-friend-row {
	display: flex; align-items: center; gap: 8px;
	padding: 6px 4px;
}
.invite-friend-row .name {
	flex: 1;
	font: 600 13px/1 system-ui;
	color: var(--text);
}
.invite-friend-row .online {
	width: 7px; height: 7px; border-radius: 50%; background: #22c55e;
}
.invite-friend-row .offline {
	width: 7px; height: 7px; border-radius: 50%; background: var(--muted);
}
.invite-friend-row button {
	padding: 4px 9px;
	border: 0; border-radius: 6px;
	background: var(--accent); color: #0b0d12;
	font: 700 11px/1 system-ui;
	cursor: pointer;
}
.invite-friend-row button.sent {
	background: transparent;
	color: var(--muted);
	border: 1px solid var(--grid);
	pointer-events: none;
}
.invite-empty {
	padding: 10px;
	text-align: center;
	color: var(--muted);
	font: 500 12px/1.3 system-ui;
}

/* host kick button on seat tile */
.opp .opp-kick {
	position: absolute;
	top: 4px; right: 4px;
	padding: 2px 6px;
	border: 1px solid rgba(255,255,255,0.18);
	border-radius: 6px;
	background: rgba(0,0,0,0.4);
	color: var(--danger, #fca5a5);
	font: 700 10px/1 system-ui;
	cursor: pointer;
	opacity: 0.85;
}
.opp .opp-kick:hover { opacity: 1; border-color: var(--danger, #fca5a5); }
.opp { position: relative; }

/* Mobile: LCS in-match dock stays visible but the toggle pill is
   tighter and the panel collapses to a sensible width when opened. */
:root[data-viewport="mobile"] .lcs-chat-dock {
	left: 8px;
	bottom: 8px;
}
:root[data-viewport="mobile"] .lcs-chat-toggle {
	padding: 6px 10px;
	font-size: 12px;
}
:root[data-viewport="mobile"] .lcs-chat-panel {
	width: 86vw;
	max-width: 86vw;
	height: 50vh;
	max-height: 50vh;
}
