:root{
  --bg:#f1f4f3; --card:#ffffff; --ink:#1c2a27; --muted:#7c8a85; --line:#e6ece9;
  --primary:#20907d; --primary-d:#176558; --accent:#94c033; --accent-d:#6f9626;
  --ok:#3f9d52; --err:#d9482e; --gold:#e0a100;
  --shadow:0 8px 24px rgba(20,90,75,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5;
  -webkit-font-smoothing:antialiased}
.wrap{max-width:480px;margin:0 auto;padding:16px 16px 48px;min-height:100vh}
a{color:var(--primary);text-decoration:none}
.anton{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.5px;line-height:1}

/* App bar */
/* Barre du haut : retour (gauche) + bouton déconnexion (droite), même niveau */
.topnav{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 2px 2px;min-height:34px}
.topnav .home{color:var(--muted);font-size:24px;line-height:1;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--card);box-shadow:var(--shadow)}
.topnav .out{font-size:13px;font-weight:700;color:var(--primary);background:var(--card);border:1.5px solid var(--line);border-radius:10px;padding:8px 14px}
.topnav > span{width:34px}

/* Case de consentement (inscription) */
.consent{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted);margin:14px 0 2px;line-height:1.45}
.consent input{margin-top:3px;width:18px;height:18px;flex:0 0 18px;accent-color:var(--primary)}
.consent a{font-weight:700}

/* Cards & buttons */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;margin:12px 0;box-shadow:var(--shadow)}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;border:none;cursor:pointer;
  background:var(--primary);color:#fff;font-family:inherit;font-size:16px;font-weight:700;padding:15px 18px;border-radius:13px;transition:.15s}
.btn:hover{background:var(--primary-d)}
.btn.ghost{background:transparent;border:2px solid var(--line);color:var(--ink)}
.btn.accent{background:var(--accent);color:#163a00}.btn.accent:hover{background:var(--accent-d)}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.note{border:1px solid var(--line);border-left-width:4px;border-radius:10px;padding:11px 13px;margin:12px 0;font-size:14px;background:#fafcfb}
.note.ok{border-left-color:var(--ok)} .note.err{border-left-color:var(--err)}

/* Logo centré (toutes les pages) */
.brandlogo{text-align:center;margin:6px 0 8px}
.brandlogo img{max-width:200px;max-height:100px;width:auto;height:auto}

/* Hero / accueil non connecté */
.hero{text-align:center;padding:18px 8px 8px}
.pronos-row{display:flex;align-items:center;justify-content:center;gap:14px}
.pronos-row .ball{font-size:30px}
.hero h1{font-size:48px;color:var(--ink);margin:2px 0}
.hero .sub{font-family:'Anton';text-transform:uppercase;color:var(--accent-d);letter-spacing:2px;font-size:18px}
.hero p{color:var(--muted);margin:14px 4px 16px;font-size:15px}
.badge-players{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:30px;padding:8px 16px;box-shadow:var(--shadow);font-size:14px}
.badge-players .dot{width:9px;height:9px;border-radius:50%;background:var(--ok)}
.badge-players strong{font-weight:800}

/* Tuiles d'action (accueil) */
.actions{display:flex;flex-direction:column;gap:11px;margin-top:18px}
.action{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:15px;padding:15px 16px;box-shadow:var(--shadow)}
.action .ic{width:46px;height:46px;border-radius:12px;background:#eef4f2;display:flex;align-items:center;justify-content:center;font-size:22px;flex:0 0 46px}
.action .tx{flex:1;min-width:0}
.action .tx b{display:block;font-size:16px}
.action .tx span{font-size:13px;color:var(--muted)}
.action .chev{color:var(--muted);font-size:22px}
.action.primary{background:var(--primary);border-color:var(--primary);color:#fff}
.action.primary .ic{background:rgba(255,255,255,.18)}
.action.primary .tx span{color:rgba(255,255,255,.85)}
.action.primary .chev{color:rgba(255,255,255,.7)}
.reglement{display:block;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:14px;margin-top:14px;box-shadow:var(--shadow);font-weight:700;text-decoration:underline;color:var(--ink)}

/* Mini-récap dashboard */
.recap{display:flex;gap:10px;margin:4px 0 14px}
.recap .box{flex:1;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px;text-align:center;box-shadow:var(--shadow)}
.recap .n{font-family:'Anton';font-size:26px;color:var(--primary)}
.recap .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}

/* Tuiles de phase */
.ptiles{display:flex;flex-direction:column;gap:11px;margin-top:6px}
.ptile{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:15px;
  padding:15px 16px;box-shadow:var(--shadow);position:relative}
.ptile .ic{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:21px;flex:0 0 42px}
.ptile .mid{flex:1;min-width:0}
.ptile .name{font-weight:800;font-size:16px}
.ptile .st{font-size:13px;color:var(--muted);margin-top:1px}
.ptile .chev{color:var(--muted);font-size:22px}
.ptile .badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:20px}
/* états */
.ptile.is-open{border-color:var(--primary);box-shadow:0 8px 22px rgba(32,144,125,.20)}
.ptile.is-open .ic{background:rgba(32,144,125,.12);color:var(--primary)}
.ptile.is-open .badge{background:var(--primary);color:#fff}
.ptile.is-upcoming{opacity:.62}
.ptile.is-upcoming .ic{background:#eef1f0;color:var(--muted)}
.ptile.is-locked .ic{background:rgba(224,161,0,.14);color:var(--gold)}
.ptile.is-done .ic{background:rgba(63,157,82,.14);color:var(--ok)}
.ptile.is-done .badge{background:rgba(63,157,82,.14);color:var(--ok)}
.train-tag{display:inline-block;font-size:10px;background:var(--accent);color:#163a00;border-radius:6px;padding:1px 6px;margin-left:6px;font-weight:700;vertical-align:middle}

/* Écran de prono : matchs */
.phead{text-align:center;margin:6px 0 4px}
.phead h1{font-family:'Anton';text-transform:uppercase;font-size:30px;color:var(--ink)}
.phead .s{color:var(--muted);font-size:14px}
.prog{height:8px;background:var(--line);border-radius:6px;overflow:hidden;margin:14px 0 6px}
.prog > i{display:block;height:100%;background:var(--accent);width:0;transition:.3s}
.match{background:var(--card);border:1px solid var(--line);border-radius:15px;padding:12px;margin:11px 0;box-shadow:var(--shadow)}
.match .mno{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.teams{display:flex;align-items:stretch;gap:8px}
.team{flex:1;border:2px solid var(--line);background:#fafcfb;border-radius:12px;padding:13px 8px;text-align:center;cursor:pointer;
  font-weight:700;font-size:15px;transition:.12s}
.team:hover{border-color:var(--primary)}
.team.sel{background:var(--primary);border-color:var(--primary);color:#fff}
.team .res{display:block;font-size:11px;font-weight:600;margin-top:3px;opacity:.8}
/* lecture seule (résultats) */
.team.good{background:rgba(63,157,82,.14);border-color:var(--ok);color:var(--ink)}
.team.bad{background:rgba(217,72,46,.10);border-color:var(--err);color:var(--ink)}
.team.win-real{box-shadow:inset 0 0 0 2px var(--ok)}
.vs{align-self:center;color:var(--muted);font-size:12px;font-weight:700;padding:0 2px}
.kick{text-align:center;font-size:12px;color:var(--muted);margin-top:8px}

/* Confirmation */
.confirm{text-align:center;padding:22px}
.confirm .big{font-size:42px}
.confirm h2{margin:8px 0 4px}

/* Classement — entête */
.lb-kicker{font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--primary);font-size:12px;margin-top:2px}
.lb-title{font-family:'Anton';text-transform:uppercase;font-size:52px;line-height:.92;margin:6px 0 0}
.lb-title .l1{color:var(--ink)} .lb-title .l2{color:var(--accent-d)}
.lb-status{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:13px;margin:10px 0 4px}

/* Podium top 3 */
.podium{display:flex;align-items:flex-end;justify-content:center;gap:10px;margin:6px 0 14px}
.pod{flex:1;min-width:0;background:var(--card);border:1.5px solid var(--line);border-radius:16px;padding:14px 8px;text-align:center;box-shadow:var(--shadow)}
.pod .medal{width:34px;height:34px;border-radius:50%;margin:0 auto 7px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.pod .pname{font-weight:700;font-size:13px;line-height:1.2;word-break:break-word;min-height:2.4em;display:flex;align-items:center;justify-content:center}
.pod .pscore{font-family:'Anton';font-size:30px;line-height:1;margin-top:2px}
.pod .plabel{font-size:10px;color:var(--muted);letter-spacing:1.5px;margin-top:2px}
.pod.p1{order:2;border-color:var(--gold);background:#fffdf4;padding-top:20px}
.pod.p1 .medal{background:var(--gold)} .pod.p1 .pscore{color:var(--gold)}
.pod.p2{order:1} .pod.p2 .medal{background:#9aa7a2} .pod.p2 .pscore{color:#8b9499}
.pod.p3{order:3;border-color:#dcab78} .pod.p3 .medal{background:#c8824a} .pod.p3 .pscore{color:#b9803f}

/* Liste (rangs 4+) */
.lblist{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.lbrow{display:flex;align-items:center;gap:14px;padding:14px 16px;border-top:1px solid var(--line)}
.lbrow:first-child{border-top:none}
.lbrow .rk{font-weight:700;color:var(--muted);width:26px;text-align:center;font-size:15px}
.lbrow .nm{flex:1;font-weight:700;min-width:0}
.lbrow .pt{font-weight:800;color:var(--primary);font-size:16px}
.lbrow.me{background:rgba(32,144,125,.07)}

/* Formulaires */
.field{display:block;margin:12px 0}
.field .lbl{display:block;font-size:13px;font-weight:700;margin-bottom:5px}
.field input{width:100%;border:2px solid var(--line);border-radius:11px;padding:13px;font-size:16px;font-family:inherit;background:#fafcfb}
.field input:focus{outline:none;border-color:var(--primary)}
.center{text-align:center} .muted{color:var(--muted)} .mt{margin-top:14px}
.foot{text-align:center;color:var(--muted);font-size:12px;margin-top:22px}
