fix(client_web): center board and points panels
This commit is contained in:
parent
874a302524
commit
4550b1d66a
1 changed files with 36 additions and 17 deletions
|
|
@ -249,12 +249,15 @@ body {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ── Game container ─────────────────────────────────────────────────── */
|
/* ── Game container ─────────────────────────────────────────────────── */
|
||||||
|
/* No width: 100% — let it size to content (the board wrapper, ~832px).
|
||||||
|
This keeps the board pinned at the same horizontal position whether or
|
||||||
|
not the side panel is visible, and aligns the status bar / score panels
|
||||||
|
with the board rather than with the viewport edge. */
|
||||||
.game-container {
|
.game-container {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
gap: 0.6rem;
|
gap: 0.6rem;
|
||||||
width: 100%;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ── Language switcher (in-game) ────────────────────────────────────── */
|
/* ── Language switcher (in-game) ────────────────────────────────────── */
|
||||||
|
|
@ -325,17 +328,25 @@ body {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ── Player score panel ─────────────────────────────────────────────── */
|
/* ── Player score panel ─────────────────────────────────────────────── */
|
||||||
|
/* Horizontal banner: name on the left, score bars expanding to fill the
|
||||||
|
board width — no more empty right half on large screens. */
|
||||||
.player-score-panel {
|
.player-score-panel {
|
||||||
background: var(--ui-parchment);
|
background: var(--ui-parchment);
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
padding: 0.45rem 1rem;
|
padding: 0.45rem 1.25rem;
|
||||||
font-size: 0.88rem;
|
font-size: 0.88rem;
|
||||||
box-shadow: 0 2px 6px rgba(0,0,0,0.25);
|
box-shadow: 0 2px 6px rgba(0,0,0,0.25);
|
||||||
width: 100%;
|
width: 100%;
|
||||||
border-top: 2px solid var(--ui-gold-dark);
|
border-top: 2px solid var(--ui-gold-dark);
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
gap: 1.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.player-score-header { margin-bottom: 0.35rem; }
|
.player-score-header {
|
||||||
|
flex-shrink: 0;
|
||||||
|
min-width: 90px;
|
||||||
|
}
|
||||||
|
|
||||||
.player-name {
|
.player-name {
|
||||||
font-family: var(--font-display);
|
font-family: var(--font-display);
|
||||||
|
|
@ -345,25 +356,28 @@ body {
|
||||||
letter-spacing: 0.02em;
|
letter-spacing: 0.02em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.score-bars { display: flex; flex-direction: column; gap: 5px; }
|
/* Bars sit side-by-side (points | holes) filling remaining width */
|
||||||
|
.score-bars { display: flex; flex-direction: row; gap: 1.5rem; flex: 1; align-items: center; }
|
||||||
|
|
||||||
.score-bar-row {
|
.score-bar-row {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
gap: 0.5rem;
|
gap: 0.5rem;
|
||||||
|
flex: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.score-bar-label {
|
.score-bar-label {
|
||||||
font-size: 0.75rem;
|
font-size: 0.75rem;
|
||||||
color: #665544;
|
color: #665544;
|
||||||
width: 3.5rem;
|
width: 3rem;
|
||||||
text-align: right;
|
text-align: right;
|
||||||
flex-shrink: 0;
|
flex-shrink: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ── Points bar ─────────────────────────────────────────────────────── */
|
/* ── Points bar ─────────────────────────────────────────────────────── */
|
||||||
.score-bar {
|
.score-bar {
|
||||||
width: 140px;
|
flex: 1;
|
||||||
|
max-width: 220px;
|
||||||
height: 8px;
|
height: 8px;
|
||||||
background: rgba(0,0,0,0.1);
|
background: rgba(0,0,0,0.1);
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
|
|
@ -424,18 +438,21 @@ body {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ── Board + side panel ─────────────────────────────────────────────── */
|
/* ── Board + side panel ─────────────────────────────────────────────── */
|
||||||
|
/* .board-and-panel is sized to the board wrapper only; the side panel is
|
||||||
|
positioned absolutely so it floats to the right without pushing the
|
||||||
|
board and breaking its horizontal alignment. */
|
||||||
.board-and-panel {
|
.board-and-panel {
|
||||||
display: flex;
|
position: relative;
|
||||||
flex-direction: row;
|
|
||||||
align-items: flex-start;
|
|
||||||
gap: 1rem;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.side-panel {
|
.side-panel {
|
||||||
|
position: absolute;
|
||||||
|
left: calc(100% + 1rem);
|
||||||
|
top: 0;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
gap: 0.65rem;
|
gap: 0.65rem;
|
||||||
min-width: 160px;
|
width: 200px;
|
||||||
padding-top: 0.15rem;
|
padding-top: 0.15rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -785,8 +802,10 @@ body {
|
||||||
.board-quarter .field.zone-petit:nth-child(even),
|
.board-quarter .field.zone-petit:nth-child(even),
|
||||||
.board-quarter .field.zone-grand:nth-child(even) { --fc: var(--field-ivory); }
|
.board-quarter .field.zone-grand:nth-child(even) { --fc: var(--field-ivory); }
|
||||||
|
|
||||||
/* Opponent's grand-jan — cooler: dark teal / silvery-green ivory */
|
/* Opponent's grand-jan — deep slate-blue / silvery-green ivory.
|
||||||
.board-quarter .field.zone-opponent:nth-child(odd) { --fc: #1e3d32; }
|
Previously #1e3d32 was nearly identical to the felt (#1d3d28); now using
|
||||||
|
a clearly distinguishable cool blue that reads well against the green. */
|
||||||
|
.board-quarter .field.zone-opponent:nth-child(odd) { --fc: #1a4f72; }
|
||||||
.board-quarter .field.zone-opponent:nth-child(even) { --fc: #e5eadc; }
|
.board-quarter .field.zone-opponent:nth-child(even) { --fc: #e5eadc; }
|
||||||
|
|
||||||
/* Jan de retour — warmer: amber-brown / warm amber ivory */
|
/* Jan de retour — warmer: amber-brown / warm amber ivory */
|
||||||
|
|
@ -872,10 +891,10 @@ body {
|
||||||
font-variant-numeric: tabular-nums;
|
font-variant-numeric: tabular-nums;
|
||||||
}
|
}
|
||||||
|
|
||||||
.board-quarter .field.zone-petit:nth-child(odd) .field-num,
|
.board-quarter .field.zone-petit:nth-child(odd) .field-num,
|
||||||
.board-quarter .field.zone-grand:nth-child(odd) .field-num,
|
.board-quarter .field.zone-grand:nth-child(odd) .field-num,
|
||||||
.board-quarter .field.zone-retour:nth-child(odd) .field-num,
|
.board-quarter .field.zone-retour:nth-child(odd) .field-num,
|
||||||
.board-quarter .field.zone-dernier:nth-child(odd) .field-num {
|
.board-quarter .field.zone-opponent:nth-child(odd) .field-num {
|
||||||
color: rgba(240,215,190,0.38);
|
color: rgba(240,215,190,0.38);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue