:root {
    --bg: #08101f;
    --panel: rgba(10, 22, 42, 0.9);
    --panel-soft: rgba(18, 34, 64, 0.92);
    --text: #edf6ff;
    --muted: #b8c5da;
    --accent: #58d7ff;
    --accent-2: #7dffb0;
    --danger: #ff6a7f;
    --gold: #ffca54;
    --border: rgba(255,255,255,0.08);
    --shadow: 0 24px 80px rgba(0,0,0,0.35);
}

* { box-sizing: border-box; }
body {
    margin: 0;
    font-family: Inter, Arial, Helvetica, sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at top left, rgba(88,215,255,0.15), transparent 35%),
        radial-gradient(circle at top right, rgba(125,255,176,0.12), transparent 30%),
        linear-gradient(180deg, #08101f 0%, #0d1730 100%);
    min-height: 100vh;
}
a { color: var(--accent); text-decoration: none; }
a:hover { opacity: 0.9; }
img { max-width: 100%; display: block; }
.site-wrap { max-width: 1280px; margin: 0 auto; padding: 20px; }
.top-nav {
    display: flex; justify-content: space-between; gap: 16px; align-items: center;
    padding: 16px 20px; margin-bottom: 24px;
    background: rgba(6, 14, 28, 0.78); border: 1px solid var(--border); border-radius: 20px;
    backdrop-filter: blur(12px);
}
.top-nav nav { display: flex; gap: 16px; flex-wrap: wrap; }
.brand { font-size: 1.25rem; font-weight: 800; color: #fff; }
.brand-with-icon { display: inline-flex; align-items: center; gap: 10px; }
.brand-with-icon img { width: 28px; height: 28px; }
.card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: var(--shadow);
}
.hero-grid, .dashboard-grid, .leaderboard-layout { display: grid; gap: 24px; }
.hero-card, .welcome-card, .leaderboard-hero {
    display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 24px; padding: 32px;
    align-items: center;
}
.glow-card { position: relative; overflow: hidden; }
.glow-card::after {
    content: ''; position: absolute; inset: auto -10% -35% auto; width: 280px; height: 280px;
    background: radial-gradient(circle, rgba(88,215,255,0.2), transparent 65%);
}
.eyebrow { display: inline-block; color: var(--accent-2); letter-spacing: 0.08em; text-transform: uppercase; font-size: 0.78rem; margin-bottom: 10px; }
h1 { font-size: clamp(2rem, 4vw, 3.4rem); line-height: 1.05; margin: 0 0 14px; }
h2 { margin-top: 0; }
.accent { color: var(--accent); }
p { color: var(--muted); line-height: 1.6; }
.actions { display: flex; gap: 12px; flex-wrap: wrap; }
.inline-actions { margin-top: 20px; }
.stacked { display: grid; }
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    border: 1px solid var(--border); color: #fff; background: rgba(255,255,255,0.06);
    border-radius: 14px; padding: 13px 18px; font-weight: 700; cursor: pointer;
}
.btn.primary { background: linear-gradient(135deg, var(--accent), #2c8cff); color: #04101f; border: 0; }
.btn.danger { background: linear-gradient(135deg, #ff8394, var(--danger)); color: #20050a; border: 0; }
.btn.btn-multi { background: linear-gradient(135deg, #c97bff, #7b3fe4); color: #fff; border: 0; }
.btn.btn-bot { background: linear-gradient(135deg, #ff9030, #ff5010); color: #fff; border: 0; }
.btn.secondary { background: rgba(255,255,255,0.08); }
.mode-actions { flex-wrap: wrap; gap: 10px; }
.btn:disabled { opacity: 0.35; cursor: default; pointer-events: none; }
.full { width: 100%; }
.feature-panel { padding: 28px; }
.feature-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature-list article { padding: 18px; border-radius: 18px; background: rgba(255,255,255,0.04); }
.feature-list img, .stat-card img { width: 42px; height: 42px; margin-bottom: 10px; }
.page-center { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.form-card { width: min(460px, 100%); padding: 28px; }
.form-card label { display: grid; gap: 8px; margin-bottom: 14px; color: #fff; }
.form-card input {
    border-radius: 14px; border: 1px solid var(--border); background: rgba(255,255,255,0.06);
    color: #fff; padding: 14px 16px; font-size: 1rem;
}
.form-hero { width: 72px; height: 72px; margin: 0 auto 12px; }
.form-hero img { width: 72px; height: 72px; }
.alert { padding: 12px 14px; border-radius: 14px; margin-bottom: 16px; }
.alert.error { background: rgba(255,106,127,0.12); color: #ffd0d7; border: 1px solid rgba(255,106,127,0.25); }
.muted { color: var(--muted); }
.center { text-align: center; }
/* Conteneur de section stats (solo / bot) */
.stats-section { display: grid; gap: 10px; }
.stats-section-label {
    font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--accent); opacity: 0.85;
}
.stats-section-label--bot { color: #ff8844; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.stat-card { padding: 22px; text-align: center; }
.stat-card span { display: block; color: var(--muted); margin-bottom: 10px; }
.stat-card strong { font-size: 2rem; }
.side-illustration { width: min(360px, 100%); margin-left: auto; }
.side-illustration.small { width: 180px; }
.table-card { padding: 18px; overflow: hidden; }
.leaderboard-table { width: 100%; border-collapse: collapse; }
.leaderboard-table th, .leaderboard-table td { padding: 14px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.leaderboard-table th { color: #fff; }

/* ── Onglets leaderboard ── */
.lb-tabs {
    display: flex; gap: 8px;
}
.lb-tab {
    padding: 11px 22px; border-radius: 14px; font-weight: 700; font-size: 0.9rem;
    border: 1px solid var(--border); background: rgba(255,255,255,0.05);
    color: var(--muted); cursor: pointer; transition: background 0.18s, color 0.18s, border-color 0.18s;
}
.lb-tab--solo.active {
    background: rgba(88,215,255,0.12); border-color: var(--accent); color: var(--accent);
}
.lb-tab--bot.active {
    background: rgba(255,100,20,0.12); border-color: #ff8844; color: #ff8844;
}
.lb-tab:not(.active):hover { background: rgba(255,255,255,0.09); color: var(--text); }

/* ── Ligne du joueur connecté ── */
.lb-row--me td { background: rgba(88,215,255,0.07); }
.lb-row--me td:first-child { border-left: 3px solid var(--accent); }
.lb-you {
    display: inline-block; margin-left: 7px;
    font-size: 0.68rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--accent); background: rgba(88,215,255,0.13);
    border: 1px solid rgba(88,215,255,0.3); border-radius: 6px; padding: 1px 6px;
    vertical-align: middle;
}

/* ── Message tableau vide ── */
.lb-empty { padding: 24px 12px; color: var(--muted); text-align: center; }
.game-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 24px; align-items: start; }
.board-column { display: flex; flex-direction: column; gap: 12px; }
.board-panel, .sidebar-panel { padding: 18px; }
.cosmic-panel { position: relative; overflow: hidden; }
.cosmic-panel::before {
    content: ''; position: absolute; inset: -20% auto auto -15%; width: 260px; height: 260px;
    background: radial-gradient(circle, rgba(125,255,176,0.16), transparent 70%);
}
#gameCanvas {
    width: 100%; height: min(66vh, 680px); display: block; border-radius: 18px;
    background: linear-gradient(180deg, #0d1730 0%, #111f3d 100%);
}
.hud-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 18px; }
.hud-item { padding: 14px; border-radius: 18px; background: rgba(255,255,255,0.05); }
.hud-item span { display: block; color: var(--muted); margin-bottom: 6px; }
.hud-item strong { font-size: 1.4rem; }
.legend { margin-top: 18px; padding: 16px; display: grid; gap: 10px; }
.legend div { display: flex; align-items: center; gap: 10px; }
.legend img { width: 22px; height: 22px; }
.dot { width: 16px; height: 16px; border-radius: 50%; display: inline-block; }
.dot.exit { background: #7dffb0; box-shadow: 0 0 20px rgba(125,255,176,0.6); }
.message-box { margin-top: 18px; padding: 16px; border-radius: 18px; background: rgba(255,255,255,0.05); min-height: 76px; }
.touch-controls { display: none; gap: 10px; margin-top: 14px; }
.touch-controls button {
    border: 1px solid var(--border); background: rgba(255,255,255,0.08); color: #fff;
    border-radius: 14px; padding: 12px 16px; min-width: 84px;
}
.touch-row { display: flex; gap: 10px; justify-content: center; }
.game-overlay {
    position: fixed; inset: 0; width: 100vw; height: 100vh; background: rgba(0,0,0,0.78);
    display: flex; align-items: center; justify-content: center; z-index: 99999; padding: 20px;
}
.game-overlay.hidden { display: none; }
.game-overlay-box {
    width: min(540px, 100%); background: #101b35; border: 1px solid var(--border); color: #fff;
    border-radius: 24px; padding: 34px 24px; text-align: center; box-shadow: var(--shadow);
}
@media (max-width: 980px) {
    .hero-card, .welcome-card, .leaderboard-hero, .game-layout { grid-template-columns: 1fr; }
    .stats-grid, .feature-list { grid-template-columns: 1fr 1fr; }
    .touch-controls { display: grid; }
    .tools-bar { flex-wrap: wrap; gap: 10px; }
    .tool-sep { display: none; }
}
@media (max-width: 640px) {
    .site-wrap { padding: 12px; }
    .top-nav { padding: 14px; }
    .stats-grid, .feature-list, .hud-grid { grid-template-columns: 1fr; }
    .hero-card, .welcome-card, .leaderboard-hero, .feature-panel, .sidebar-panel, .board-panel { padding: 20px; }
    h1 { font-size: 2.1rem; }
    .tool-buttons { flex-direction: row; }
}

/* ════════════════════════════════════════
   Barre d'outils sous le canvas
   ════════════════════════════════════════ */
.tools-bar {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 20px;
    box-shadow: var(--shadow);
}

/* Groupe de boutons-outils */
.tool-buttons {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex-shrink: 0;
}

/* Bouton d'outil individuel */
.tool-btn {
    position: relative;
    width: 54px; height: 54px;
    border-radius: 14px;
    border: 2px solid var(--border);
    background: rgba(255,255,255,0.05);
    color: var(--muted);
    font-size: 1.55rem;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background 0.18s, border-color 0.18s, color 0.18s, box-shadow 0.18s;
}
.tool-btn:hover:not(.selected) {
    background: rgba(255,255,255,0.09);
    color: var(--text);
}
.tool-btn.selected {
    background: rgba(255,202,84,0.15);
    border-color: var(--gold);
    color: var(--gold);
    box-shadow: 0 0 16px rgba(255,202,84,0.30);
}
/* SVG dans les boutons d'outils — hérite de currentColor */
.tool-btn-svg {
    width: 26px; height: 26px;
    flex-shrink: 0;
    pointer-events: none;
}
/* SVG dans le centre du D-pad */
.dig-center svg { width: 22px; height: 22px; }

/* Badge compteur d'utilisations */
.tool-btn-count {
    position: absolute;
    bottom: 4px; right: 6px;
    font-size: 0.62rem;
    font-weight: 700;
    color: var(--accent-2);
    line-height: 1;
    pointer-events: none;
}
.tool-btn.tool-empty .tool-btn-count { color: var(--danger); }

/* Séparateur vertical */
.tool-sep {
    width: 1px;
    align-self: stretch;
    background: var(--border);
    flex-shrink: 0;
}

/* ── D-pad partagé ── */
.tool-dpad {
    display: grid;
    grid-template-areas:
        ".    up    ."
        "left ctr   right"
        ".    down  .";
    grid-template-columns: 48px 48px 48px;
    grid-template-rows:    48px 48px 48px;
    gap: 5px;
    flex-shrink: 0;
}
#digUp    { grid-area: up; }
#digLeft  { grid-area: left; }
#digRight { grid-area: right; }
#digDown  { grid-area: down; }
.dig-center {
    grid-area: ctr;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.45rem;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.04);
    color: var(--gold);
    user-select: none;
    transition: color 0.18s, opacity 0.18s;
}
.dig-center.no-tool { color: var(--muted); opacity: 0.30; }
.dig-btn {
    width: 48px; height: 48px; padding: 0;
    font-size: 1.1rem; border-radius: 13px;
    border: 1px solid var(--border);
    background: rgba(255,202,84,0.10);
    color: var(--gold);
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background 0.15s, opacity 0.15s;
}
.dig-btn:hover:not(:disabled) { background: rgba(255,202,84,0.24); }
.dig-btn:disabled { opacity: 0.22; cursor: default; }

/* ── Zone de statut de l'outil actif ── */
.tool-status {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 80px;
    font-size: 0.82rem;
    color: var(--muted);
}
.tool-status.hidden { display: none; }
.tool-status-name {
    font-weight: 700;
    font-size: 0.88rem;
    color: var(--gold);
    letter-spacing: 0.02em;
}
.tool-status-count { font-size: 0.82rem; color: var(--muted); }
.tool-status-empty {
    display: none;
    padding: 4px 8px;
    border-radius: 8px;
    background: rgba(255,106,127,0.13);
    border: 1px solid rgba(255,106,127,0.30);
    color: var(--danger);
    font-size: 0.78rem;
    font-weight: 600;
    white-space: nowrap;
}
.tool-status.is-empty .tool-status-count { display: none; }
.tool-status.is-empty .tool-status-empty { display: block; }

/* ════════════════════════════════════════
   Modal de sélection du mode de jeu
   ════════════════════════════════════════ */
.mode-selection-box { max-width: 500px; }

.mode-choice-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin: 20px 0 16px;
}
.mode-choice-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 22px 14px;
    border-radius: 18px;
    border: 2px solid var(--border);
    background: rgba(255,255,255,0.05);
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.mode-choice-btn:hover {
    background: rgba(255,255,255,0.09);
}
.mode-choice-icon { font-size: 2.2rem; line-height: 1; }
.mode-choice-name { font-size: 1rem; font-weight: 700; color: #fff; }
.mode-choice-desc {
    font-size: 0.72rem; font-weight: 400;
    color: var(--muted); text-align: center; line-height: 1.4;
}
.mode-choice-btn.active-solo {
    border-color: var(--accent);
    background: rgba(88,215,255,0.12);
    box-shadow: 0 0 20px rgba(88,215,255,0.18);
}
.mode-choice-btn.active-bot {
    border-color: #ff8844;
    background: rgba(255,100,20,0.12);
    box-shadow: 0 0 20px rgba(255,100,20,0.18);
}

/* Sélecteur de difficulté dans le modal */
.bot-diff-inline {
    display: grid;
    gap: 6px;
    margin-bottom: 16px;
}
.bot-diff-inline label {
    font-size: 0.78rem;
    color: var(--muted);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.bot-diff-inline select {
    background: rgba(255,255,255,0.07);
    border: 1px solid var(--border);
    border-radius: 12px;
    color: #fff;
    padding: 10px 34px 10px 14px;
    font-size: 0.9rem;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath stroke='%2358d7ff' stroke-width='1.8' fill='none' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
}
.bot-diff-inline select:focus { outline: none; border-color: var(--accent); }

/* Badge mode actif (lecture seule) */
.mode-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 12px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--muted);
    margin-bottom: 12px;
    letter-spacing: 0.03em;
}
.mode-badge.mode-bot {
    background: rgba(255,100,20,0.08);
    border-color: rgba(255,100,20,0.28);
    color: #ff9966;
}

/* ════════════════════════════════════════
   Bloc joueur (sidebar) — miroir du bloc Bot en mode Contre le Bot
   ════════════════════════════════════════ */
.hud-player {
    border-radius: 18px;
    margin-bottom: 12px;
}
/* En mode bot : encadré bleu symétrique du bloc orange Bot */
.sidebar-panel.bot-active .hud-player {
    padding: 14px;
    background: rgba(88, 215, 255, 0.08);
    border: 1px solid rgba(88, 215, 255, 0.28);
}
.hud-player-title {
    display: none;
    font-size: 0.78rem; font-weight: 700; letter-spacing: 0.07em;
    text-transform: uppercase; color: var(--accent);
    margin-bottom: 10px;
}
.sidebar-panel.bot-active .hud-player-title { display: block; }
.hud-player-grid { margin-bottom: 0 !important; }
.sidebar-panel.bot-active .hud-player-grid .hud-item strong { color: var(--accent); }
/* Stats secondaires (Meilleur, Pièces rest., Outils) */
.hud-secondary { margin-bottom: 18px; }

/* ════════════════════════════════════════
   HUD Bot adversaire
   ════════════════════════════════════════ */
.hud-bot {
    margin-bottom: 16px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(255, 100, 20, 0.08);
    border: 1px solid rgba(255, 100, 20, 0.28);
}
.hud-bot-title {
    font-size: 0.78rem;
    font-weight: 700;
    color: #ff8844;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    margin-bottom: 10px;
}
.hud-bot-grid { margin-bottom: 0 !important; }
.hud-bot-grid .hud-item strong { color: #ff9966; }
.hud-bot-eliminated {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--danger);
    text-align: center;
    padding: 6px 0 2px;
    letter-spacing: 0.06em;
}

/* ── Flash rouge au contact d'un piège ── */
@keyframes hitFlash {
    0%        { outline: 0px solid rgba(255,60,60,0);    box-shadow: none; }
    12%, 42%, 72% {
        outline: 4px solid rgba(255, 70, 70, 0.95);
        box-shadow: 0 0 48px 14px rgba(255,50,50,0.65), 0 0 90px 24px rgba(255,30,30,0.30);
    }
    27%, 57%  {
        outline: 1px solid rgba(255,70,70,0.25);
        box-shadow: 0 0 8px 2px rgba(255,50,50,0.10);
    }
    100%      { outline: 0px solid rgba(255,60,60,0);    box-shadow: none; }
}
#gameCanvas.hit-flash {
    animation: hitFlash 1.5s ease-out forwards;
}

/* ── Bouton déploiement DEV (visible uniquement si APP_ENV=development) ──── */
.dev-deploy-btn {
    position: fixed;
    bottom: 24px;
    right: 24px;
    display: flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #1a1a2e;
    font-weight: 700;
    font-size: .85rem;
    padding: 10px 18px;
    border-radius: 50px;
    text-decoration: none;
    box-shadow: 0 4px 18px rgba(245, 158, 11, 0.45);
    transition: transform .15s, box-shadow .15s;
    z-index: 9999;
}
.dev-deploy-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 24px rgba(245, 158, 11, 0.65);
}

/* ── Toggle FR / EN ──────────────────────────────────────────────────────── */
.lang-toggle {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-left: 8px;
    font-size: .8rem;
}
.lang-toggle a {
    color: #637a9a;
    text-decoration: none;
    padding: 2px 6px;
    border-radius: 4px;
    transition: color .15s, background .15s;
    font-weight: 500;
}
.lang-toggle a:hover   { color: #edf6ff; background: rgba(88,215,255,.1); }
.lang-toggle a.lang-active {
    color: #58d7ff;
    font-weight: 700;
}
.lang-toggle span { color: #2a3a55; font-size: .7rem; }

/* Standalone sur login/register (hors nav) */
.lang-toggle-standalone {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 8px;
}
.lang-toggle-standalone .lang-toggle { margin-left: 0; }

/* ── Footer ──────────────────────────────────────────────────────────────── */
.site-footer {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    padding: 28px 20px 20px;
    margin-top: 40px;
    color: var(--muted);
    font-size: .74rem;
    opacity: 0.65;
    transition: opacity .2s;
}
.site-footer:hover { opacity: 1; }
.site-footer a { color: var(--muted); }
.site-footer a:hover { color: var(--accent); }
.footer-sep { color: #2a3a55; font-size: .65rem; }

/* ── Page mentions légales ───────────────────────────────────────────────── */
.legal-page .legal-content {
    max-width: 780px;
    margin: 0 auto;
    padding: 40px 48px;
    line-height: 1.7;
}
.legal-content h1 { font-size: 1.8rem; margin-bottom: 32px; color: var(--accent); }
.legal-content h2 { font-size: 1.1rem; color: var(--text); margin: 32px 0 10px; border-bottom: 1px solid var(--border); padding-bottom: 6px; }
.legal-content h3 { font-size: .95rem; color: var(--accent-2); margin: 20px 0 6px; font-weight: 600; }
.legal-content p  { color: var(--muted); margin: 0 0 12px; }
.legal-content a  { color: var(--accent); }
.legal-content section { margin-bottom: 8px; }
@media (max-width: 600px) { .legal-page .legal-content { padding: 24px 20px; } }

/* ── Page Contact ────────────────────────────────────────────────────────── */
.contact-page .contact-wrap {
    max-width: 600px;
    margin: 0 auto;
}
.contact-card { padding: 40px 48px; }
.contact-card h1 { font-size: 1.8rem; margin-bottom: 8px; color: var(--accent); }
.contact-intro { color: var(--muted); margin-bottom: 28px; }
.contact-form { display: flex; flex-direction: column; gap: 18px; }
.form-label { display: flex; flex-direction: column; gap: 6px; font-size: .88rem; color: var(--muted); font-weight: 500; }
.form-label input,
.form-label select,
.form-label textarea {
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    border-radius: 10px;
    color: var(--text);
    padding: 10px 14px;
    font-size: .92rem;
    font-family: inherit;
    transition: border-color .2s;
    width: 100%;
}
.form-label input:focus,
.form-label select:focus,
.form-label textarea:focus {
    outline: none;
    border-color: var(--accent);
}
.form-label select { cursor: pointer; }
.form-label select option { background: #0d1a30; }
.form-label textarea { resize: vertical; min-height: 120px; }
.required { color: var(--danger); margin-left: 2px; }
.form-error {
    background: rgba(255, 106, 127, 0.12);
    border: 1px solid rgba(255, 106, 127, 0.3);
    border-radius: 10px;
    color: var(--danger);
    padding: 12px 16px;
    font-size: .88rem;
}
.contact-success {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(125, 255, 176, 0.1);
    border: 1px solid rgba(125, 255, 176, 0.3);
    border-radius: 12px;
    color: var(--accent-2);
    padding: 20px;
    font-size: .95rem;
}
.contact-success-icon {
    font-size: 1.4rem;
    flex-shrink: 0;
}
/* Honeypot : totalement invisible pour les humains */
.hp-field {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    tab-index: -1;
}
@media (max-width: 600px) { .contact-card { padding: 24px 20px; } }

/* ── Cookie Consent Banner ────────────────────────────────────────────────── */
.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9999;
    background: rgba(8, 21, 40, 0.97);
    border-top: 1px solid rgba(88, 215, 255, 0.2);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 16px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.4);
}
.cookie-text {
    margin: 0;
    font-size: .88rem;
    color: var(--muted);
    flex: 1;
    min-width: 200px;
    line-height: 1.5;
}
.cookie-text a {
    color: var(--accent-1);
    text-decoration: underline;
}
.cookie-text a:hover { color: var(--accent-2); }
.cookie-actions {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
    flex-wrap: wrap;
}
.cookie-btn {
    padding: 8px 18px;
    font-size: .85rem;
    border-radius: 8px;
    cursor: pointer;
    white-space: nowrap;
}
.cookie-btn-muted {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--muted);
}
.cookie-btn-muted:hover {
    border-color: rgba(255, 255, 255, 0.35);
    color: var(--text);
}
@media (max-width: 600px) {
    .cookie-banner {
        flex-direction: column;
        align-items: flex-start;
        padding: 14px 16px;
    }
    .cookie-actions { width: 100%; }
    .cookie-btn { flex: 1; text-align: center; }
}

/* ── Google OAuth Button ─────────────────────────────────────────────────── */
.oauth-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 18px 0 14px;
    color: var(--muted);
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.oauth-divider::before,
.oauth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255,255,255,.1);
}
.btn-google {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #fff;
    color: #3c4043;
    border: 1px solid #dadce0;
    border-radius: 10px;
    padding: 10px 16px;
    font-size: .92rem;
    font-weight: 500;
    cursor: pointer;
    transition: background .15s, box-shadow .15s;
    text-decoration: none;
    width: 100%;
    box-sizing: border-box;
}
.btn-google:hover {
    background: #f8f9fa;
    box-shadow: 0 2px 8px rgba(0,0,0,.15);
    color: #3c4043;
    text-decoration: none;
}
.google-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* ── HUD Multijoueur ─────────────────────────────────────────────────────── */
.hud-multi {
    margin-top: 12px;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(201,123,255,0.08);
    border: 1px solid rgba(201,123,255,0.2);
}
.hud-multi-title {
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: #c97bff;
    margin-bottom: 8px;
}
.hud-multi-row {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .88rem;
    padding: 5px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}
.hud-multi-row:last-child { border-bottom: none; }
.hud-multi-stat {
    margin-left: auto;
    color: var(--muted);
    font-size: .82rem;
}
.mode-badge.mode-multi { background: rgba(201,123,255,0.15); border-color: rgba(201,123,255,0.3); }
