/* Lobby — online game setup pages (start.form.inc, join.form.inc) */

.lobby {
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    background: var(--bg);
    background-image: var(--page-surface-image);
    color: var(--text);
    font-family: var(--font);
}

/* ── Header ── */
.lobby-header {
    height: 56px;
    background: var(--bg-header);
    background-image: var(--header-surface-image);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    padding: 0 20px;
    justify-content: space-between;
    flex-shrink: 0;
}

.lobby-logo {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--gold);
    text-decoration: none;
}

/* ── Centre column ── */
.lobby-main {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 16px;
}

.lobby-card {
    background: var(--bg-card);
    background-image: var(--card-surface-image);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 32px;
    width: 100%;
    max-width: 480px;
}

.lobby-heading {
    margin: 0 0 24px;
    font-size: 1.05rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
}

/* ── Table-ID row ── */
.lobby-table-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 24px;
    padding: 10px 14px;
    background: var(--bg);
    background-image: var(--inset-surface-image);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-size: 0.875rem;
}

.lobby-table-row .table-id {
    flex: 1;
    font-family: monospace;
    font-size: 0.82rem;
    color: var(--muted);
    word-break: break-all;
}

.lobby-table-row a {
    color: var(--gold);
    text-decoration: none;
    font-size: 0.82rem;
    white-space: nowrap;
}

.lobby-table-row a:hover { text-decoration: underline; }

/* ── Player list ── */
.lobby-players {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 24px;
}

.lobby-player {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--bg);
    background-image: var(--inset-surface-image);
    border: 1px solid var(--border);
    border-left: 3px solid transparent;
    border-radius: var(--radius);
    font-size: 0.875rem;
    min-height: 44px;
}

.lobby-player[data-color="red"]    { border-left-color: hsl(0,   100%, 55%); }
.lobby-player[data-color="orange"] { border-left-color: hsl(30,  100%, 55%); }
.lobby-player[data-color="yellow"] { border-left-color: hsl(55,  100%, 50%); }
.lobby-player[data-color="green"]  { border-left-color: hsl(120,  70%, 45%); }
.lobby-player[data-color="blue"]   { border-left-color: hsl(240, 100%, 68%); }
.lobby-player[data-color="violet"] { border-left-color: hsl(300,  70%, 58%); }

.player-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}

.lobby-player[data-color="red"]    .player-dot { background: hsl(0,   100%, 50%); }
.lobby-player[data-color="orange"] .player-dot { background: hsl(30,  100%, 50%); }
.lobby-player[data-color="yellow"] .player-dot { background: hsl(60,  100%, 50%); }
.lobby-player[data-color="green"]  .player-dot { background: hsl(120, 100%, 45%); }
.lobby-player[data-color="blue"]   .player-dot { background: hsl(240, 100%, 65%); }
.lobby-player[data-color="violet"] .player-dot { background: hsl(300, 100%, 60%); }

.player-info {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.player-name {
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.player-name.empty {
    color: var(--muted);
    font-style: italic;
}

.player-tag {
    font-size: 0.72rem;
    padding: 2px 7px;
    border-radius: 3px;
    background: var(--accent);
    color: #fff;
    font-weight: 600;
    flex-shrink: 0;
}

.player-tag.ai {
    background: var(--green);
}

/* ── Inline join form (inside a player row) ── */
.join-form {
    display: flex;
    gap: 6px;
    flex: 1;
}

.join-form input[type="text"] {
    flex: 1;
    min-width: 0;
    height: 30px;
    padding: 0 10px;
    background: var(--bg-card);
    background-image: var(--card-surface-image);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-family: var(--font);
    font-size: 0.85rem;
    outline: none;
    transition: border-color 120ms;
}

.join-form input[type="text"]:focus { border-color: var(--accent); }

.join-form button {
    height: 30px;
    padding: 0 14px;
    font-size: 0.82rem;
    background: var(--accent);
    color: #fff;
    border-radius: var(--radius);
}

/* ── Action bar ── */
.lobby-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.dice-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--muted);
    cursor: pointer;
    user-select: none;
}

.dice-label input[type="checkbox"] {
    accent-color: var(--accent);
    width: 14px;
    height: 14px;
    cursor: pointer;
}

.btn-start {
    background: var(--green);
    color: #fff;
}

.btn-refresh {
    background: transparent;
    color: var(--accent);
    border: 1.5px solid var(--accent);
}

.lobby-form {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
}

.lobby-form label {
    font-size: 0.78rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.lobby-form input[type="text"] {
    height: 36px;
    padding: 0 12px;
    background: var(--bg);
    background-image: var(--inset-surface-image);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-family: var(--font);
    font-size: 0.9rem;
    outline: none;
    transition: border-color 120ms;
}

.lobby-form input[type="text"]:focus {
    border-color: var(--accent);
}

.lobby-form button {
    align-self: flex-start;
}

.lobby-actions form {
    margin: 0;
}

/* ── Refresh notice ── */
.refresh-notice {
    margin-top: 20px;
    font-size: 0.78rem;
    color: var(--muted);
    text-align: center;
}

/* ── Link inside a player row (host view: per-player rejoin link) ── */
.player-link {
    font-size: 0.78rem;
    color: var(--gold);
    text-decoration: none;
    flex-shrink: 0;
}

.player-link:hover { text-decoration: underline; }
