:root{--vert:#1a7a3d;--or:#e8a13b;--sombre:#0f2419;--gris-clair:#f4f6f5}*{box-sizing:border-box}body{background:var(--gris-clair);color:#1a1a1a;margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif}button{cursor:pointer;background:var(--vert);color:#fff;border:none;border-radius:8px;padding:10px 16px;font-size:15px;transition:opacity .15s}button:hover{opacity:.9}button:disabled{opacity:.5;cursor:not-allowed}input,select{border:1px solid #ccc;border-radius:8px;width:100%;margin:6px 0 14px;padding:10px;font-size:15px}.page-auth{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.carte-auth{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:380px;padding:32px;box-shadow:0 4px 20px #00000014}.carte-auth h1{color:var(--vert);margin-bottom:4px}.sous-titre{color:#666;margin-bottom:20px}.carte-auth form{text-align:left}.carte-auth button{width:100%;margin-top:8px}.lien-bas{margin-top:16px;font-size:14px}.erreur{color:#c0392b;font-size:14px}.champ-mdp{margin:6px 0 14px;position:relative}.champ-mdp input{width:100%;margin:0;padding-right:44px}.champ-mdp .bouton-oeil{background:0 0;width:auto;margin:0;padding:6px 8px;font-size:18px;line-height:1;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.page-accueil{max-width:700px;margin:0 auto;padding:24px}.page-accueil .grille-stats{margin-top:20px}.page-confirmation{max-width:500px;margin:0 auto;padding:24px}.carte-seance{background:#fff;border-radius:12px;margin:14px 0;padding:16px;box-shadow:0 2px 8px #0000000f}.boutons-reponse{gap:10px;margin-top:10px;display:flex}.boutons-reponse button{color:#333;background:#ddd;flex:1}.boutons-reponse button.actif{background:var(--vert);color:#fff}.info{color:#666;font-size:14px}.compteur-confirmes{color:#333;margin-top:12px;font-size:14px}.formats-possibles{color:#666}.page-pointeur{max-width:800px;margin:0 auto;padding:20px}.bloc{background:#fff;border-radius:12px;margin-bottom:16px;padding:18px;box-shadow:0 2px 8px #0000000f}.ligne-saisie{gap:8px;display:flex}.ligne-saisie input{margin:0}.ligne-saisie button{white-space:nowrap}.liste-arrivees{max-height:160px;padding-left:20px;overflow-y:auto}.equipes-terrain{justify-content:space-between;gap:12px;margin-top:12px;display:flex}.equipe{background:var(--gris-clair);border-radius:10px;flex:1;padding:10px}.equipe h3{margin-top:0;font-size:15px}.equipe ul{margin:0;padding-left:18px}.chrono{flex-direction:column;justify-content:center;align-items:center;gap:10px;min-width:120px;display:flex}.temps{color:var(--sombre);font-size:32px;font-weight:700}.file-attente{margin-top:16px}.mini-equipe{background:#fff4e0;border-radius:8px;margin:6px 0;padding:8px 12px;font-size:14px}.alerte-action{text-align:center;background:#fdecea;border-radius:10px;margin-top:16px;padding:14px}.alerte-action button{margin:6px}.onglets{flex-wrap:wrap;gap:10px;margin:14px 0 20px;display:flex}.onglets a,.onglets button{color:#333;background:#fff;border:1px solid #ddd;border-radius:20px;padding:8px 14px;font-size:14px;text-decoration:none}.onglets button.actif,.onglets a.active{background:var(--vert);color:#fff;border-color:var(--vert)}.page-tresorier,.page-tournois,.page-detail-tournoi{max-width:900px;margin:0 auto;padding:20px}.grille-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;display:grid}.carte-stat{text-align:center;background:#fff;border-radius:12px;padding:18px;box-shadow:0 2px 8px #0000000f}.carte-stat .valeur{color:var(--vert);font-size:24px;font-weight:700;display:block}.carte-stat.alerte .valeur{color:#c0392b}.carte-stat .libelle{color:#666;font-size:13px}.carte-stat.lien{color:inherit;text-decoration:none;display:block}.page-cotisations{padding:4px}.resume-caisse{margin-bottom:12px;font-size:16px}.recherche{max-width:300px}.tableau-scroll{overflow-x:auto}.grille-cotisations{border-collapse:collapse;background:#fff;border-radius:10px;width:100%}.grille-cotisations th,.grille-cotisations td{text-align:center;border-bottom:1px solid #eee;padding:8px 10px;font-size:13px}.nom-membre{white-space:nowrap;font-weight:600;text-align:left!important}.case-mois{cursor:pointer;min-width:34px}.case-mois.paye{color:var(--vert);background:#d7f0dd;font-weight:700}.case-mois.futur{color:#bbb;background:#f5f5f5}.retard{color:#c0392b;font-weight:600}.entete-solidarite{margin-bottom:14px}.formulaire-evenement{background:#fff;border-radius:12px;max-width:400px;margin-bottom:16px;padding:16px}.carte-evenement{background:#fff;border-radius:12px;margin-bottom:14px;padding:16px;box-shadow:0 2px 8px #0000000f}.carte-evenement.remis{opacity:.7}.entete-evenement{justify-content:space-between;align-items:center;font-weight:600;display:flex}.description{color:#666;font-size:14px}.badge{background:#eee;border-radius:12px;padding:3px 10px;font-size:12px}.badge.remis{color:var(--vert);background:#d7f0dd}.badge.ouvert{color:#a6720d;background:#fff4e0}.badge.externe{color:#2361b0;background:#e0eefd;margin-left:6px}.contributions{padding-left:18px;font-size:14px}.ligne-contribution{align-items:center;gap:8px;margin-top:10px;display:flex}.ligne-contribution select,.ligne-contribution input{flex:1;margin:0}button.secondaire{color:#333;background:#eee}.formulaire-tournoi{background:#fff;border-radius:12px;max-width:400px;margin:14px 0;padding:16px}.liste-tournois{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:16px;display:grid}.carte-tournoi{color:#1a1a1a;background:#fff;border-radius:12px;padding:16px;text-decoration:none;display:block;box-shadow:0 2px 8px #0000000f}.liste-equipes{padding:0;list-style:none}.liste-equipes li{background:var(--gris-clair);border-radius:8px;justify-content:space-between;align-items:center;margin:6px 0;padding:8px 12px;display:flex}.case-externe{white-space:nowrap;align-items:center;gap:4px;font-size:13px;display:flex}.classement{border-collapse:collapse;width:100%;margin:10px 0}.classement th,.classement td{text-align:left;border-bottom:1px solid #eee;padding:6px 10px;font-size:14px}.ligne-match{flex-wrap:wrap;align-items:center;gap:8px;margin:8px 0;display:flex}.ligne-match input{text-align:center;width:50px;margin:0;padding:6px}.page-admin{max-width:700px;margin:0 auto;padding:20px}.ligne-demande{background:var(--gris-clair);border-radius:10px;justify-content:space-between;align-items:center;margin:10px 0;padding:12px 14px;display:flex}.detail-demande{color:#666;font-size:13px}.boutons-demande{gap:8px;display:flex}.boutons-demande button:disabled{color:#aaa;cursor:not-allowed;background:#eee}.bandeau-succes{color:#124d29;background:#d7f0dd;border-radius:10px;margin-bottom:16px;padding:14px;font-size:14px}.boutons-bandeau{gap:8px;margin-top:10px;display:flex}.tableau-roles{border-collapse:collapse;width:100%}.tableau-roles th,.tableau-roles td{text-align:center;border-bottom:1px solid #eee;padding:8px}.tableau-roles input[type=checkbox]{width:18px;height:18px}.tableau-annuaire{border-collapse:collapse;width:100%;margin-top:12px}.tableau-annuaire th,.tableau-annuaire td{text-align:left;border-bottom:1px solid #eee;padding:8px 10px;font-size:14px}.app-shell-sidebar{min-height:100vh;display:flex}.barre-mobile{background:var(--sombre);color:#fff;z-index:20;align-items:center;gap:12px;padding:12px 16px;display:none;position:sticky;top:0}.bouton-burger{color:#fff;background:0 0;padding:2px 6px;font-size:22px}.barre-mobile .titre-app{font-size:15px;font-weight:700}.overlay-menu{z-index:25;background:#00000080;position:fixed;inset:0}.barre-laterale{background:var(--sombre);color:#fff;flex-direction:column;width:250px;min-width:250px;height:100vh;padding:20px 0;display:flex;position:sticky;top:0}.entete-sidebar{border-bottom:1px solid #ffffff1f;align-items:center;gap:10px;margin-bottom:14px;padding:0 20px 20px;display:flex}.logo-sidebar{font-size:30px}.nom-app-sidebar{font-size:15px;font-weight:700}.nom-utilisateur{color:#fff9;margin-top:2px;font-size:12px}.nav-sidebar{flex-direction:column;flex:1;gap:2px;padding:0 10px;display:flex}.nav-sidebar a{color:#ffffffd9;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-sidebar a:hover{background:#ffffff14}.nav-sidebar a.lien-actif{background:var(--vert);color:#fff}.icone-lien{text-align:center;width:22px;font-size:18px}.bouton-deco-sidebar{color:#fff;background:#ffffff1a;border-radius:10px;margin:14px 16px 0;padding:12px;font-size:14px;font-weight:600}.bouton-deco-sidebar:hover{background:#fff3}.contenu-app-sidebar{flex:1;min-width:0}@media (width<=820px){.barre-mobile{display:flex}.barre-laterale{z-index:30;width:250px;height:100vh;transition:left .2s;position:fixed;top:0;left:-280px}.barre-laterale.ouverte{left:0}.app-shell-sidebar{flex-direction:column}}.page-ma-cotisation{max-width:600px;margin:0 auto;padding:20px}.grille-mois-membre{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin:18px 0;display:grid}.case-mois-membre{text-align:center;background:#fff;border-radius:10px;padding:12px;box-shadow:0 2px 6px #0000000f}.case-mois-membre span{color:#666;margin-bottom:4px;font-size:13px;display:block}.case-mois-membre strong{color:#c0392b;font-size:14px}.case-mois-membre.paye strong{color:var(--vert)}.case-mois-membre.futur{opacity:.5}.case-mois-membre.futur strong{color:#999}.info.petit{color:#999;font-size:12px}.page-annuaire-membre{max-width:600px;margin:0 auto;padding:20px}.liste-annuaire-membre{margin-top:14px}.carte-annuaire-membre{background:#fff;border-radius:10px;justify-content:space-between;align-items:center;margin:8px 0;padding:12px 14px;display:flex;box-shadow:0 2px 6px #0000000f}.bouton-whatsapp-annuaire{color:#fff;background:#25d366;border-radius:8px;padding:8px 12px;font-size:16px;text-decoration:none}.page-equipe-jour{max-width:800px;margin:0 auto;padding:20px}.explication-formation{margin-top:20px}.liste-explication{padding-left:20px;line-height:1.7}.liste-explication li{margin-bottom:8px}.formulaire-buteur{background:#fff;border-radius:12px;max-width:400px;margin-bottom:16px;padding:16px}.page-buteurs{max-width:600px;margin:0 auto;padding:20px}.classement-buteurs{padding-left:24px;list-style:decimal}.classement-buteurs li{background:var(--gris-clair);border-radius:8px;justify-content:space-between;margin:6px 0;padding:10px 14px;display:flex}.classement-buteurs strong{color:var(--vert)}.historique-buteurs{padding:0;list-style:none}.historique-buteurs li{border-bottom:1px solid #eee;align-items:center;gap:12px;padding:8px 12px;font-size:14px;display:flex}.date-historique{color:#888;min-width:90px;font-size:13px}.historique-buteurs strong{color:var(--vert);margin-left:auto}.page-attente,.chargement-global{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.page-attente button{margin-top:16px}
