/* ==========================================================================
   UpTenUp — Couche de composants & accessibilité
   Importer APRÈS design-tokens.css. Conçue pour être additive : n'écrase
   pas les styles existants des templates, sauf pour l'accessibilité
   (focus-visible) et la sécurité mobile (overflow-x, tap targets).
   ========================================================================== */

/* ---------- Accessibilité globale : focus-visible cohérent ---------- */
/* On ne supprime JAMAIS l'outline globalement : on n'enlève l'outline
   par défaut que pour les éléments qui reçoivent notre anneau via
   :focus-visible. Tout autre élément keyboard-focusable garde l'outline
   natif comme filet de sécurité. */

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible,
[role="tab"]:focus-visible,
[role="link"]:focus-visible,
[tabindex]:not([tabindex="-1"]):focus-visible,
summary:focus-visible {
    outline: none;
    box-shadow: var(--up-shadow-focus, 0 0 0 3px rgba(195, 90, 31, 0.35));
    border-radius: var(--up-radius-sm, 6px);
    transition: box-shadow var(--up-dur-fast, 120ms) var(--up-ease, ease);
}

/* Lien d'évitement (skip link) caché par défaut, visible au focus clavier */
.up-skip-link {
    position: absolute;
    top: -40px;
    left: 8px;
    background: var(--up-ink-900);
    color: var(--up-white);
    padding: 8px 14px;
    border-radius: var(--up-radius-sm);
    text-decoration: none;
    font-weight: var(--up-fw-semibold);
    z-index: var(--up-z-toast);
    transition: top var(--up-dur-base) var(--up-ease);
}
.up-skip-link:focus { top: 8px; }

/* ---------- Sécurité mobile : pas de scroll horizontal accidentel ---------- */
html { -webkit-text-size-adjust: 100%; }
html, body { max-width: 100%; }
body { overflow-x: hidden; }
img, video, canvas, svg, iframe { max-width: 100%; }

/* ---------- Tap targets minimum 44px sur mobile ---------- */
@media (max-width: 768px) {
    button,
    a.btn, .btn,
    input[type="button"],
    input[type="submit"],
    input[type="reset"],
    [role="button"] {
        min-height: 44px;
    }
    a {
        min-height: 24px;
    }
}

/* ---------- Scrollbar discrète & cohérente ---------- */
* {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.25) transparent;
}
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.22);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
}
*::-webkit-scrollbar-thumb:hover { background: rgba(0, 0, 0, 0.4); background-clip: padding-box; border: 2px solid transparent; }

/* ---------- Sélection texte cohérente ---------- */
::selection {
    background: var(--up-accent, #C35A1F);
    color: #fff;
}

/* ---------- Composants utilitaires partagés (opt-in via classe) ---------- */

/* Boutons */
.up-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--up-space-2);
    padding: 10px 18px;
    min-height: 40px;
    font-family: var(--up-font-sans);
    font-size: var(--up-fs-md);
    font-weight: var(--up-fw-semibold);
    line-height: 1;
    border-radius: var(--up-radius-md);
    border: 1px solid transparent;
    cursor: pointer;
    user-select: none;
    text-decoration: none;
    transition:
        transform var(--up-dur-fast) var(--up-ease),
        box-shadow var(--up-dur-base) var(--up-ease),
        background-color var(--up-dur-base) var(--up-ease),
        border-color var(--up-dur-base) var(--up-ease),
        color var(--up-dur-base) var(--up-ease);
}
.up-btn:active { transform: translateY(1px); }
.up-btn[disabled], .up-btn:disabled {
    opacity: 0.55; cursor: not-allowed; transform: none;
}

.up-btn-primary {
    background: linear-gradient(135deg, var(--up-accent-strong), var(--up-accent));
    color: var(--up-white);
    box-shadow: var(--up-shadow-sm);
}
.up-btn-primary:hover:not(:disabled) {
    box-shadow: var(--up-shadow-md);
    filter: brightness(1.05);
}

.up-btn-secondary {
    background: var(--up-white);
    color: var(--up-ink-800);
    border-color: var(--up-ink-300);
    box-shadow: var(--up-shadow-xs);
}
.up-btn-secondary:hover:not(:disabled) {
    border-color: var(--up-accent);
    color: var(--up-accent-strong);
    box-shadow: var(--up-shadow-sm);
}

.up-btn-ghost {
    background: transparent;
    color: var(--up-ink-700);
}
.up-btn-ghost:hover:not(:disabled) {
    background: var(--up-ink-100);
    color: var(--up-ink-900);
}

/* Cards */
.up-card {
    background: var(--up-white);
    border-radius: var(--up-radius-lg);
    padding: var(--up-space-6);
    box-shadow: var(--up-shadow-md);
    border: 1px solid var(--up-ink-200);
}
.up-card--flat { box-shadow: var(--up-shadow-xs); }

/* Variantes de cartes consolidées depuis les classes legacy
   `.card`, `.profil-card`, `.summary-card`, `.stats-bar`, `.player-card`.
   Toutes héritent du look `.up-card` (radius / padding / border) et n'écrasent
   que ce qui est nécessaire pour préserver le rendu de chaque variante. */

/* Carte principale d'une page (rendu legacy `.card` de index.html :
   ombre marquée, marge basse pour aérer les blocs successifs). */
.up-card--page {
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    margin-bottom: var(--up-space-5);
}

/* Carte profil joueur : layout grille (photo / infos / actions). */
.up-card--profile {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 25px;
    align-items: center;
    position: relative;
}

/* Carte résumé saison : hero coloré tennis. */
.up-card--summary {
    background: linear-gradient(135deg, var(--up-success), var(--up-success));
    color: var(--up-on-accent);
    border-left: 5px solid var(--up-perf);
    border-color: transparent;
    font-size: 1.05em;
    line-height: 1.6;
    margin-bottom: var(--up-space-5);
}

/* Bandeau de stats (club_players.html). S'adapte au thème clair/sombre. */
.up-card--stats {
    display: flex;
    gap: 15px;
    padding: 15px 20px;
    background: var(--up-ink-100);
    border-color: transparent;
    box-shadow: none;
    border-radius: var(--up-radius-md);
    margin-bottom: 20px;
}

/* Tuile joueur/équipe cliquable. S'adapte au thème clair/sombre. */
.up-card--player {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px;
    background: var(--up-ink-100);
    border-color: var(--up-ink-200);
    box-shadow: none;
    border-radius: var(--up-radius-md);
    text-decoration: none;
    color: inherit;
    transition: background var(--up-dur-base) var(--up-ease),
                transform var(--up-dur-base) var(--up-ease);
}
.up-card--player:hover {
    background: var(--up-ink-200);
    transform: translateY(-2px);
}

/* Inputs */
.up-input,
.up-select,
.up-textarea {
    width: 100%;
    padding: 12px 14px;
    font-family: var(--up-font-sans);
    font-size: var(--up-fs-md);
    color: var(--up-ink-900);
    background: var(--up-white);
    border: 1px solid var(--up-ink-300);
    border-radius: var(--up-radius-md);
    transition: border-color var(--up-dur-base) var(--up-ease),
                box-shadow var(--up-dur-base) var(--up-ease);
}
.up-input:focus,
.up-select:focus,
.up-textarea:focus {
    outline: none;
    border-color: var(--up-accent);
    box-shadow: var(--up-shadow-focus);
}

/* Badges */
.up-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    font-size: var(--up-fs-xs);
    font-weight: var(--up-fw-semibold);
    line-height: 1.4;
    border-radius: var(--up-radius-pill);
    background: var(--up-ink-100);
    color: var(--up-ink-800);
    letter-spacing: 0.02em;
}
.up-badge--success { background: var(--up-success-bg); color: var(--up-success); }
.up-badge--warning { background: var(--up-warning-bg); color: var(--up-warning); }
.up-badge--danger  { background: var(--up-danger-bg);  color: var(--up-danger); }
.up-badge--info    { background: var(--up-info-bg);    color: var(--up-info); }
.up-badge--accent  { background: var(--up-accent-soft); color: var(--up-accent-strong); }

/* Loader points */
.up-dots {
    display: inline-flex;
    gap: 4px;
}
.up-dots span {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: currentColor;
    animation: up-dots-pulse 1.2s var(--up-ease) infinite both;
}
.up-dots span:nth-child(2) { animation-delay: 0.15s; }
.up-dots span:nth-child(3) { animation-delay: 0.3s; }
@keyframes up-dots-pulse {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40% { transform: scale(1); opacity: 1; }
}

/* Hover subtil sur les cards interactives existantes (opt-in) */
.up-hoverable {
    transition: transform var(--up-dur-base) var(--up-ease),
                box-shadow var(--up-dur-base) var(--up-ease);
}
.up-hoverable:hover {
    transform: translateY(-2px);
    box-shadow: var(--up-shadow-lg);
}

/* ---------- Garde-fous mobile (320px / 375px) ---------- */
@media (max-width: 380px) {
    body { padding-left: 10px; padding-right: 10px; }
    .up-card { padding: var(--up-space-4); border-radius: var(--up-radius-md); }
}

/* ---------- Visually hidden (a11y label) ---------- */
.up-sr-only {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ---------- En-tête partagé des pages secondaires (_nav.html) ---------- */
/* Fond coloré thématique cohérent sur toutes les pages utilisant _nav.html
   (club, équipes, joueurs, carte…). La couleur suit le thème Grand Slam actif
   via --up-accent (vert pour Wimbledon, orange pour Roland-Garros, etc.). */
.header {
    background: linear-gradient(135deg, var(--up-accent) 0%, var(--up-accent-strong) 100%);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.site-logo-link {
    color: var(--up-on-accent, #fff);
    text-decoration: none;
    font-size: 1.8rem;
    font-weight: 700;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
    display: inline-block;
    line-height: 1;
}
.site-logo-link:hover { opacity: 0.9; }

.site-nav-subtitle {
    color: rgba(255,255,255,0.85);
    font-size: 0.85em;
    margin-top: 4px;
}

.nav-back-row {
    padding: 10px 20px 4px;
}

/* Burger bouton + dropdown — styles partagés (surchargeables inline) */
.burger-btn {
    background: rgba(255,255,255,0.2);
    border: none;
    width: 42px; height: 42px;
    border-radius: 50%;
    cursor: pointer;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 5px;
    transition: background 0.3s;
}
.burger-btn:hover { background: rgba(255,255,255,0.35); }
.burger-btn span {
    display: block; width: 20px; height: 2px;
    background: white; border-radius: 2px;
    transition: all 0.3s;
}
.burger-dropdown {
    position: absolute; top: 50px; right: 0;
    background: var(--up-white, #fff); border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.18);
    min-width: 200px; overflow: hidden;
    opacity: 0; visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.25s; z-index: 100;
}
.burger-dropdown.show { opacity: 1; visibility: visible; transform: translateY(0); }
.burger-dropdown a {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 18px; color: var(--up-ink-700, #4a4e5c);
    text-decoration: none; font-size: 14px;
    border-bottom: 1px solid var(--up-ink-200, #e8ebf1);
    transition: background 0.2s;
}
.burger-dropdown a:last-child { border-bottom: none; }
.burger-dropdown a:hover { background: var(--up-ink-100, #f4f5f9); }
.burger-dropdown a .icon { font-size: 1.2em; }
.burger-dropdown a.logout-link { color: #dc3545; }
.burger-dropdown a.logout-link:hover { background: #fff5f5; }

/* Bouton retour générique */
.btn-back {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(255,255,255,0.2);
    color: white;
    border: none; border-radius: 10px;
    padding: 8px 16px; font-size: 14px;
    cursor: pointer; text-decoration: none;
    transition: background 0.2s;
}
.btn-back:hover { background: rgba(255,255,255,0.35); }
