/* ══════════════════════════════════════════════════
   race-config.css — Bandeau de mode + UI officiel
   ══════════════════════════════════════════════════ */

/* ─── Bandeau de mode (visible sur toutes les vues) ─── */
#race-mode-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 16px;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-align: center;
    transition: background 0.3s, color 0.3s;
    position: sticky;
    top: 0;
    z-index: 50;
}

/* Zone gauche : libellé du mode courant */
.race-mode-label-zone {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    justify-content: center;
}

/* Zone droite : badge statut cible */
.race-mode-target-status {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    min-width: 0;
}

#race-mode-banner.mode-offline      { background: #16a34a; color: #f0fdf4; }
#race-mode-banner.mode-training     { background: #1d4ed8; color: #eff6ff; }
#race-mode-banner.mode-zeroing      { background: #b45309; color: #fffbeb; }
#race-mode-banner.mode-race         { background: #b91c1c; color: #fef2f2; }
#race-mode-banner.mode-race-u15     { background: #7e22ce; color: #faf5ff; }
#race-mode-banner.mode-maintenance  { background: #064e3b; color: #ecfdf5; }

/* badge sous-type (ex: Sprint, Poursuite) */
#race-mode-banner .mode-subtype {
    font-size: 0.75rem;
    opacity: 0.85;
    font-weight: 400;
    padding: 1px 8px;
    border-radius: 20px;
    background: rgba(255,255,255,0.2);
}

/* ─── Bloc officiel dans le dashboard ─── */
.race-config-panel {
    background: var(--bg-card, #1e293b);
    border-radius: 12px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.race-config-panel h3 {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary, #f1f5f9);
}

/* Rangée de gros boutons de mode principal */
.race-mode-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

@media (min-width: 600px) {
    .race-mode-buttons { grid-template-columns: repeat(4, 1fr); }
}

.race-mode-btn {
    padding: 18px 8px;
    font-size: 0.95rem;
    font-weight: 700;
    border: 2px solid transparent;
    border-radius: 10px;
    cursor: pointer;
    transition: transform 0.1s, box-shadow 0.2s, border-color 0.2s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    line-height: 1.2;
    text-align: center;
}

.race-mode-btn:active { transform: scale(0.97); }

.race-mode-btn.btn-training  { background: #1d4ed8; color: #eff6ff; }
.race-mode-btn.btn-zeroing   { background: #b45309; color: #fffbeb; }
.race-mode-btn.btn-race      { background: #b91c1c; color: #fef2f2; }
.race-mode-btn.btn-race-u15  { background: #7e22ce; color: #faf5ff; }
.race-mode-btn.btn-offline   { background: #15803d; color: #f0fdf4; }

.race-mode-btn.active {
    border-color: #fff;
    box-shadow: 0 0 0 3px rgba(255,255,255,0.4);
}

/* Sous-types de course (Sprint, Poursuite…) */
.race-subtype-row {
    display: none;
    flex-direction: row;
    gap: 8px;
    flex-wrap: wrap;
}

.race-subtype-row.visible { display: flex; }

.race-subtype-btn {
    padding: 10px 18px;
    font-size: 0.88rem;
    font-weight: 600;
    border: 2px solid rgba(255,255,255,0.25);
    border-radius: 8px;
    background: rgba(255,255,255,0.08);
    color: var(--text-primary, #f1f5f9);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
}

.race-subtype-btn:hover  { background: rgba(255,255,255,0.15); }
.race-subtype-btn.active { border-color: #fff; background: rgba(255,255,255,0.22); }

/* Sélecteur limite sprint */
.sprint-limit-row {
    display: none;
    align-items: center;
    gap: 10px;
    font-size: 0.88rem;
    color: var(--text-secondary, #94a3b8);
}

.sprint-limit-row.visible { display: flex; }

.sprint-limit-row input[type="number"] {
    width: 70px;
    padding: 6px 8px;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.08);
    color: var(--text-primary, #f1f5f9);
    font-size: 0.9rem;
    text-align: center;
}

.sprint-limit-help { font-size: 0.78rem; opacity: 0.7; }

/* Bouton Appliquer */
.race-apply-btn {
    align-self: flex-end;
    padding: 10px 28px;
    font-size: 0.95rem;
    font-weight: 700;
    border: none;
    border-radius: 8px;
    background: #16a34a;
    color: #f0fdf4;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s;
}

.race-apply-btn:hover  { background: #15803d; }
.race-apply-btn:active { transform: scale(0.97); }

.race-apply-btn.idle {
    background: #334155;
    color: #94a3b8;
    cursor: not-allowed;
    opacity: 0.75;
}
.race-apply-btn.idle:hover { background: #334155; }

/* Dark mode — les variables CSS gèrent déjà l'essentiel */
body.dark-mode .race-config-panel {
    background: #0f172a;
    border: 1px solid rgba(255,255,255,0.07);
}

/* ── Panneau Session ─────────────────────────────────────────────────────── */
.race-panels-wrapper {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    flex-wrap: wrap;
}

.race-panels-wrapper .race-config-panel {
    flex: 1;
    min-width: 260px;
}

.race-session-select {
    width: 100%;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid var(--border-color, #334155);
    background: var(--surface-color, #1e293b);
    color: var(--text-primary, #f1f5f9);
    font-size: 0.9rem;
}

.race-session-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.race-session-btn {
    padding: 18px 8px;
    font-size: 0.95rem;
    font-weight: 700;
    border: 2px solid transparent;
    border-radius: 10px;
    cursor: pointer;
    transition: transform 0.1s, box-shadow 0.2s, border-color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-align: center;
}

.race-session-btn:active { transform: scale(0.97); }
.race-session-btn:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }

.race-session-btn.btn-start  { background: #15803d; color: #f0fdf4; }
.race-session-btn.btn-stop   { background: #b91c1c; color: #fef2f2; }

.race-session-btn.active {
    border-color: #fff;
    box-shadow: 0 0 0 3px rgba(255,255,255,0.4);
}

.race-session-status {
    font-size: 0.85rem;
    padding: 8px 10px;
    border-radius: 8px;
    background: rgba(255,255,255,0.05);
    color: var(--text-secondary, #94a3b8);
}

.race-session-status.active { color: #4ade80; }
.race-session-status.closed { color: #f87171; }
