/* shared/ui/components.css — Composants UI communs "Minijeux de la Loutre".
 *
 * Préfixe `.mj-*` systématique. Les jeux existants (motloutre, démineur) gardent leurs propres
 * classes (.btn-primary, .toast, etc.) intactes — ce fichier est ADDITIF, pas un remplacement.
 *
 * Utilise les tokens de tokens.css (var(--mj-*)). À importer APRÈS tokens.css.
 *
 * Composants :
 *   - .mj-card       : surface élevée (carte de jeu, panneau de stats)
 *   - .mj-btn        : bouton (variantes : primary, secondary, ghost, danger)
 *   - .mj-input      : champ texte
 *   - .mj-toast      : toast bottom-center
 *   - .mj-overlay    : fond modal sombre
 *   - .mj-modal      : conteneur de modal centré
 *   - .mj-avatar     : avatar circulaire (cf. avatar.js pour le rendu dynamique)
 *   - .mj-stack      : flex column avec gap
 *   - .mj-cluster    : flex row avec gap (wrap)
 *   - .mj-header     : header de page (logo + actions)
 */

/* === Reset doux === */

.mj-card,
.mj-btn,
.mj-input {
    box-sizing: border-box;
    font-family: var(--mj-font-family);
}

/* === Accessibilité === */

.mj-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.mj-focus-ring:focus-visible,
.mj-btn:focus-visible,
.mj-input:focus-visible,
.mj-card[tabindex]:focus-visible {
    outline: 2px solid var(--mj-color-accent);
    outline-offset: 2px;
}

/* === Card === */

.mj-card {
    background: var(--mj-color-bg-elevated);
    border: 1px solid var(--mj-color-border);
    border-radius: var(--mj-radius-lg);
    padding: var(--mj-space-5);
    box-shadow: var(--mj-shadow-md);
    transition: transform var(--mj-transition-base), box-shadow var(--mj-transition-base);
}

.mj-card--interactive {
    cursor: pointer;
}
.mj-card--interactive:hover {
    transform: translateY(-2px);
    box-shadow: var(--mj-shadow-lg);
    border-color: var(--mj-color-accent-dim);
}

.mj-card__title {
    font-size: var(--mj-text-lg);
    font-weight: 600;
    margin: 0 0 var(--mj-space-2) 0;
    color: var(--mj-color-text);
}

.mj-card__subtitle {
    font-size: var(--mj-text-sm);
    color: var(--mj-color-text-soft);
    margin: 0 0 var(--mj-space-3) 0;
}

/* === Boutons === */

.mj-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--mj-space-2);
    padding: var(--mj-space-3) var(--mj-space-5);
    border: 1px solid transparent;
    border-radius: var(--mj-radius-md);
    font-size: var(--mj-text-base);
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: background var(--mj-transition-fast), border-color var(--mj-transition-fast),
                color var(--mj-transition-fast), transform var(--mj-transition-fast);
    text-decoration: none;
    user-select: none;
}
.mj-btn:active {
    transform: scale(0.98);
}
.mj-btn:disabled,
.mj-btn[aria-disabled="true"] {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.mj-btn--primary {
    background: var(--mj-color-accent);
    color: #fff;
}
.mj-btn--primary:hover {
    background: var(--mj-color-accent-hover);
}

.mj-btn--secondary {
    background: var(--mj-color-surface);
    color: var(--mj-color-text);
    border-color: var(--mj-color-border);
}
.mj-btn--secondary:hover {
    background: var(--mj-color-border);
}

.mj-btn--ghost {
    background: transparent;
    color: var(--mj-color-text);
}
.mj-btn--ghost:hover {
    background: var(--mj-color-surface);
}

.mj-btn--danger {
    background: var(--mj-color-danger);
    color: #fff;
}
.mj-btn--danger:hover {
    background: #c62828;
}

.mj-btn--sm {
    padding: var(--mj-space-2) var(--mj-space-3);
    font-size: var(--mj-text-sm);
}
.mj-btn--lg {
    padding: var(--mj-space-4) var(--mj-space-6);
    font-size: var(--mj-text-lg);
}

/* === Input === */

.mj-input {
    display: block;
    width: 100%;
    padding: var(--mj-space-3) var(--mj-space-4);
    background: var(--mj-color-bg);
    border: 1px solid var(--mj-color-border);
    border-radius: var(--mj-radius-md);
    color: var(--mj-color-text);
    font-size: var(--mj-text-base);
    transition: border-color var(--mj-transition-fast), background var(--mj-transition-fast);
}
.mj-input:focus {
    outline: none;
    border-color: var(--mj-color-accent);
    background: var(--mj-color-bg-elevated);
}
.mj-input::placeholder {
    color: var(--mj-color-text-dim);
}

/* === Overlay & Modal === */

.mj-overlay {
    position: fixed;
    inset: 0;
    background: var(--mj-color-bg-overlay);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: var(--mj-z-overlay);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--mj-space-4);
}

.mj-modal {
    background: var(--mj-color-bg-elevated);
    border: 1px solid var(--mj-color-border);
    border-radius: var(--mj-radius-lg);
    padding: var(--mj-space-6);
    box-shadow: var(--mj-shadow-lg);
    max-width: 480px;
    width: 100%;
    max-height: calc(100vh - var(--mj-space-7));
    overflow-y: auto;
    z-index: var(--mj-z-modal);
}

/* === Toast === */

.mj-toast {
    position: fixed;
    bottom: var(--mj-space-5);
    left: 50%;
    transform: translateX(-50%);
    padding: var(--mj-space-3) var(--mj-space-5);
    background: var(--mj-color-bg-elevated);
    color: var(--mj-color-text);
    border: 1px solid var(--mj-color-border);
    border-radius: var(--mj-radius-pill);
    box-shadow: var(--mj-shadow-md);
    z-index: var(--mj-z-toast);
    font-size: var(--mj-text-sm);
    animation: mj-toast-in var(--mj-transition-base);
    max-width: calc(100vw - var(--mj-space-5) * 2);
}

@keyframes mj-toast-in {
    from { opacity: 0; transform: translate(-50%, 12px); }
    to   { opacity: 1; transform: translate(-50%, 0); }
}

/* === Layouts utilitaires === */

.mj-stack {
    display: flex;
    flex-direction: column;
    gap: var(--mj-space-4);
}
.mj-stack--sm { gap: var(--mj-space-2); }
.mj-stack--lg { gap: var(--mj-space-6); }

.mj-cluster {
    display: flex;
    flex-wrap: wrap;
    gap: var(--mj-space-3);
    align-items: center;
}

/* === Header === */

.mj-header {
    /* Layout 3 zones (Activité gauche / Brand centré / Avatar droite). Grid plutôt que
       flex+space-between : on garantit que le brand reste VISUELLEMENT centré même quand
       la zone gauche est vide (ce que `space-between` ne ferait pas). */
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding: var(--mj-space-4) var(--mj-space-5);
    background: var(--mj-color-bg);
    border-bottom: 1px solid var(--mj-color-border-soft);
    z-index: var(--mj-z-header);
}

.mj-header__actions-left {
    display: flex;
    align-items: center;
    gap: var(--mj-space-3);
    justify-self: start;
}

.mj-header__brand {
    display: flex;
    align-items: center;
    gap: var(--mj-space-3);
    font-size: var(--mj-text-lg);
    font-weight: 600;
    color: var(--mj-color-text);
    text-decoration: none;
    justify-self: center;
    /* Le texte ne doit pas wrapper sous les mascottes (le grid `auto` peut tasser la zone si
       les zones gauches/droites sont chargées). */
    white-space: nowrap;
}

.mj-header__brand-emoji {
    font-size: 1.3em;
}

/* Mascotte image (alternative à l'emoji 🦦). Posée à côté du label "Minijeux de la Loutre". */
.mj-header__brand-mascot {
    width: 36px;
    height: 36px;
    object-fit: contain;
    flex-shrink: 0;
}
@media (max-width: 500px) {
    .mj-header__brand-mascot {
        width: 30px;
        height: 30px;
    }
    /* Sur petit écran on masque la mascotte droite pour préserver l'espace du label/actions. */
    .mj-header__brand-mascot--right {
        display: none;
    }
}

.mj-header__actions {
    display: flex;
    align-items: center;
    gap: var(--mj-space-3);
    /* Avec le layout grid 3 zones du `.mj-header`, on est dans la 3e colonne ; justify-self
       à end nous colle au bord droit sans aucun calcul. */
    justify-self: end;
}

/* === Avatar (le rendu dynamique vit dans avatar.js) === */

.mj-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--mj-color-surface);
    color: #fff;
    font-weight: 600;
    overflow: hidden;
    user-select: none;
    flex-shrink: 0;
}

.mj-avatar img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* === Hero (landing hub) === */

.mj-hero {
    padding: var(--mj-space-7) var(--mj-space-5);
    text-align: center;
}

.mj-hero__title {
    font-size: var(--mj-text-3xl);
    font-weight: 700;
    color: var(--mj-color-text);
    margin: 0 0 var(--mj-space-3) 0;
}

.mj-hero__subtitle {
    font-size: var(--mj-text-lg);
    color: var(--mj-color-text-soft);
    margin: 0;
    max-width: 560px;
    margin-inline: auto;
}

/* === Tags / Badges === */

.mj-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--mj-space-1);
    padding: 2px var(--mj-space-2);
    font-size: var(--mj-text-xs);
    font-weight: 500;
    border-radius: var(--mj-radius-pill);
    background: var(--mj-color-surface);
    color: var(--mj-color-text-soft);
}
.mj-badge--success {
    background: rgba(76, 175, 80, 0.15);
    color: var(--mj-color-success);
}
.mj-badge--pending {
    background: rgba(255, 167, 38, 0.15);
    color: var(--mj-color-warning);
}

/* ============ SCROLLBARS ============
   Styling cohérent des barres de défilement sur tous les jeux de la plateforme.
   - WebKit (Chrome/Edge/Safari) via ::-webkit-scrollbar
   - Firefox via scrollbar-width / scrollbar-color
   Chaque jeu peut surcharger via les tokens --mj-scroll-* (ex. motloutre les passe en violet). */

:root {
    --mj-scroll-thumb:       var(--mj-color-border);
    --mj-scroll-thumb-hover: var(--mj-color-accent-dim, var(--mj-color-accent));
    --mj-scroll-track:       transparent;
    --mj-scroll-width:       10px;
}

/* Firefox : applique aux scrollbars de tout l'arbre via héritage. */
html {
    scrollbar-width: thin;
    scrollbar-color: var(--mj-scroll-thumb) var(--mj-scroll-track);
}

/* WebKit : tous les éléments scrollables. */
*::-webkit-scrollbar {
    width: var(--mj-scroll-width);
    height: var(--mj-scroll-width);
}
*::-webkit-scrollbar-track {
    background: var(--mj-scroll-track);
}
*::-webkit-scrollbar-thumb {
    background: var(--mj-scroll-thumb);
    border-radius: var(--mj-radius-pill, 999px);
    /* Padding visuel : la bordure transparente combinée à background-clip:padding-box
       donne l'effet d'un thumb plus fin avec de l'air autour. */
    border: 2px solid transparent;
    background-clip: padding-box;
}
*::-webkit-scrollbar-thumb:hover {
    background: var(--mj-scroll-thumb-hover);
    background-clip: padding-box;
}
*::-webkit-scrollbar-corner {
    background: transparent;
}
