/* ======================================================================
   Ligue 1 V4 — feuille de style. Ambiance stade sous les projecteurs.
   Vert pelouse + bleu nuit + accent lime. Mobile d'abord.
   ====================================================================== */
:root{
  --pitch:#0a2e22; --night:#061a2b; --green:#19a35a; --green-2:#22c55e;
  --lime:#c6f24e; --gold:#f8c33b; --red:#ef4444; --blue:#3b82f6;
  --ink:#0c241b; --muted:#5c7468; --line:#e2ece6; --card:#fff; --soft:#f4f8f6;
  --radius:20px; --shadow:0 18px 44px rgba(3,18,12,.28);
  --font-display:'Anton','Archivo Black',system-ui,sans-serif;
  --font-body:'Archivo',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{
  font-family:var(--font-body); color:#eaf6ef;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(198,242,78,.16) 0%, transparent 45%),
    radial-gradient(140% 120% at 50% 120%, #03110b 0%, transparent 55%),
    linear-gradient(160deg, var(--pitch) 0%, #082018 38%, var(--night) 100%);
  background-attachment:fixed; -webkit-font-smoothing:antialiased;
}
.wrap{max-width:780px;margin:0 auto;padding:18px 14px 60px}
.hidden{display:none!important}
button{cursor:pointer;border:0;font:inherit;color:inherit}

/* topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}
.brand{display:flex;align-items:center;gap:10px}
.logo{width:42px;height:42px;border-radius:13px;background:var(--lime);color:#172800;
  display:grid;place-items:center;font-family:var(--font-display);font-size:22px;box-shadow:0 8px 20px rgba(198,242,78,.3)}
.brand b{display:block;font-family:var(--font-display);font-weight:400;letter-spacing:.02em;
  text-transform:uppercase;font-size:20px;line-height:1}
.brand small{color:#bfe6d2;font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.btn{display:inline-flex;align-items:center;gap:7px;min-height:42px;padding:9px 15px;border-radius:12px;
  font-weight:800;background:rgba(255,255,255,.1);color:#eaf6ef;border:1px solid rgba(255,255,255,.18);
  transition:transform .08s,filter .15s}
.btn:active{transform:translateY(1px)}
.btn.lime{background:var(--lime);color:#172800;border:0;box-shadow:0 10px 24px rgba(198,242,78,.3)}
.btn.sm{min-height:36px;padding:7px 12px;font-size:13px;border-radius:10px}

/* hero meta */
.hero{margin-bottom:14px}
.kicker{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:#04140c;background:var(--lime);padding:6px 11px;border-radius:999px}
.hero h1{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,8vw,46px);line-height:.95;
  margin:12px 0 6px;text-transform:uppercase;text-shadow:0 4px 24px rgba(0,0,0,.35)}
.metaline{color:#bfe6d2;font-weight:600;font-size:13px;display:flex;flex-wrap:wrap;gap:6px 14px}
.metaline b{color:#eaf6ef}

/* alerte santé scraping */
.alert{background:#3a0f12;border:1px solid rgba(239,68,68,.5);color:#fecaca;border-radius:14px;
  padding:12px 14px;margin-bottom:14px;font-weight:700;font-size:13px;line-height:1.5}
.alert b{color:#fff}

/* note honnêteté */
.note{background:rgba(255,255,255,.06);border:1px dashed rgba(255,255,255,.18);color:#bfe6d2;
  border-radius:14px;padding:11px 13px;margin:16px 0;font-size:12px;font-weight:600;line-height:1.5}

/* carte match */
.match{background:var(--card);color:var(--ink);border-radius:var(--radius);padding:15px;margin-bottom:13px;
  box-shadow:var(--shadow);overflow:hidden}
.mtop{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:11px}
.when{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.conf{font-size:11px;font-weight:900;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}
.conf.fort{background:#dcfce7;color:#14532d}
.conf.moyen{background:#fef3c7;color:#92400e}
.conf.faible{background:#fee2e2;color:#7f1d1d}
.conf.indéterminé,.conf.faible\/à\ éviter{background:#f1f5f9;color:#475569}

.teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin-bottom:12px}
.team{display:flex;flex-direction:column;gap:5px;min-width:0}
.team.away{align-items:flex-end;text-align:right}
.tname{font-family:var(--font-display);font-weight:400;font-size:19px;line-height:1;letter-spacing:.01em;
  text-transform:uppercase;color:var(--ink)}
.vs{font-weight:900;color:var(--muted);font-size:13px}
.formpills{display:flex;gap:3px}
.away .formpills{justify-content:flex-end}
.pill{width:17px;height:17px;border-radius:5px;font-size:10px;font-weight:900;color:#fff;display:grid;place-items:center}
.pill.V{background:var(--green)} .pill.N{background:#94a3b8} .pill.D{background:var(--red)}
.badges{display:flex;gap:6px;flex-wrap:wrap}
.away .badges{justify-content:flex-end}
.bdg{font-size:10px;font-weight:800;padding:3px 7px;border-radius:7px;background:var(--soft);color:var(--muted)}
.bdg.inj{background:#fee2e2;color:#b91c1c}
.bdg.up{background:#dcfce7;color:#15803d} .bdg.down{background:#fee2e2;color:#b91c1c}

/* barre de probas */
.probbar{display:flex;height:34px;border-radius:11px;overflow:hidden;font-weight:900;font-size:13px;color:#fff}
.seg{display:flex;align-items:center;justify-content:center;min-width:30px;transition:flex-basis .3s}
.seg.h{background:linear-gradient(135deg,var(--green),var(--green-2))}
.seg.d{background:#94a3b8}
.seg.a{background:linear-gradient(135deg,#2563eb,var(--blue))}
.seg.win{outline:3px solid var(--lime);outline-offset:-3px}
.problbl{display:flex;justify-content:space-between;margin-top:7px;font-size:11px;font-weight:800;color:var(--muted)}
.problbl span{flex:1;text-align:center}
.problbl span:last-child{text-align:right}.problbl span:first-child{text-align:left}

.pickline{margin-top:11px;display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:var(--soft);border-radius:12px;padding:9px 12px}
.pickline .lab{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.pickline .val{font-family:var(--font-display);font-weight:400;font-size:17px;color:var(--ink);text-transform:uppercase}
.expandbtn{font-size:12px;font-weight:800;color:var(--green);background:none;text-decoration:underline;text-underline-offset:3px}

/* détail dépliable */
.detail{margin-top:13px;border-top:1px solid var(--line);padding-top:13px}
.dcols{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.dcard{background:var(--soft);border-radius:13px;padding:11px}
.dcard h4{margin:0 0 6px;font-family:var(--font-display);font-weight:400;font-size:15px;text-transform:uppercase}
.dyn{font-size:12px;font-weight:700;color:#334155;line-height:1.45}
.tag{display:inline-block;font-size:10px;font-weight:900;padding:2px 8px;border-radius:999px;margin-bottom:6px}
.tag.up{background:#dcfce7;color:#15803d}.tag.down{background:#fee2e2;color:#b91c1c}.tag.flat{background:#e2e8f0;color:#475569}
.injlist{margin:8px 0 0;padding:0;list-style:none}
.injlist li{font-size:11.5px;font-weight:700;color:#334155;padding:4px 0;border-top:1px dashed #d6e2db;line-height:1.35}
.injlist li:first-child{border-top:0}
.injlist .ko{color:#b91c1c}
.newsbtn{margin-top:11px}
.newslist{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.newsitem{background:#fff;border:1px solid var(--line);border-radius:11px;padding:9px 11px}
.newsitem a{color:var(--ink);font-weight:700;font-size:12.5px;text-decoration:none;line-height:1.35}
.newsitem .meta{font-size:10px;font-weight:800;color:var(--muted);margin-top:4px;display:flex;gap:6px;flex-wrap:wrap}
.ntag{font-size:9px;font-weight:900;padding:2px 6px;border-radius:6px;background:#fef3c7;color:#92400e}
.ntag.bless{background:#fee2e2;color:#b91c1c}.ntag.retour{background:#dcfce7;color:#15803d}

.loading{text-align:center;color:#bfe6d2;font-weight:700;padding:40px 0}
.spin{width:34px;height:34px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--lime);
  border-radius:50%;animation:sp 1s linear infinite;margin:0 auto 14px}
@keyframes sp{to{transform:rotate(360deg)}}

@media(min-width:600px){ .tname{font-size:22px} }
@media(max-width:560px){ .dcols{grid-template-columns:1fr} }

/* ===== Login ===== */
.loginwrap{max-width:440px;display:flex;flex-direction:column;justify-content:center;min-height:90vh}
.logo.big{width:64px;height:64px;border-radius:18px;font-size:32px;margin:0 auto 10px}
.field input{width:100%;min-height:50px;padding:13px 14px;border-radius:13px;border:1.5px solid var(--line);
  background:#fff;color:var(--ink);font-size:16px;outline:none}
.field input:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(25,163,90,.14)}
.field label{display:block;font-size:13px;font-weight:800;color:#173b2c;margin:0 0 6px}
.btn.block{width:100%}
.loginmsg{display:none;margin-top:12px;padding:11px 13px;border-radius:11px;font-weight:800;font-size:14px}
.loginmsg.show{display:block}
.loginmsg.err{background:#fee2e2;color:#7f1d1d}
.loginmsg.ok{background:#dcfce7;color:#14532d}

/* ===== Onglets ===== */
.tabs{display:flex;gap:5px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  border-radius:13px;padding:5px;margin-bottom:14px}
.tab{flex:1;background:transparent;color:#bfe6d2;border-radius:9px;min-height:40px;font-weight:800;font-size:14px}
.tab.active{background:var(--lime);color:#172800}

/* ===== Tableau des matchs ===== */
.ptable{width:100%;border-collapse:collapse;background:var(--card);color:var(--ink);
  border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.ptable thead th{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted);padding:10px 4px;text-align:center;background:var(--soft)}
.ptable thead th:first-child{text-align:left;padding-left:14px}
.prow{cursor:pointer;border-top:1px solid var(--line)}
.prow:hover{background:#f8fbf9}
.prow td{padding:10px 4px;vertical-align:middle}
.mcell{padding-left:14px!important;max-width:0;width:99%}
.mteams{font-family:var(--font-display);font-weight:400;font-size:16px;line-height:1;text-transform:uppercase;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mteams .msep{color:var(--muted);margin:0 5px}
.mteams .ma{color:#1f3d2e}
.msub{display:flex;align-items:center;gap:6px;margin-top:5px;font-size:10.5px;font-weight:700;color:var(--muted)}
.cdot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:none}
.cdot.fort{background:var(--green)} .cdot.moyen{background:var(--gold)} .cdot.faible{background:#cbd5e1}
.rowbadge.inj{background:#fee2e2;color:#b91c1c;border-radius:6px;padding:1px 5px;font-size:9.5px;font-weight:900}
.pc{text-align:center;font-weight:800;font-size:13px;width:38px;color:#64748b}
.pc.win{font-weight:900;color:#0c241b}
.pc.h.win{background:rgba(25,163,90,.16)} .pc.d.win{background:rgba(148,163,184,.22)} .pc.a.win{background:rgba(37,99,235,.14)}
.acell{width:54px;text-align:center}
.actubtn{background:#eef6f1;color:#0c241b;border:1px solid #cfe3d7;border-radius:9px;
  padding:7px 9px;font-size:11px;font-weight:900}
.actubtn:active{transform:translateY(1px)}

/* ligne de détail dépliée */
.detailrow td{background:var(--soft);padding:12px}
.detailrow .dcols{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.dlbl{margin-top:9px;font-size:11px;font-weight:900;color:#475569;text-transform:uppercase;letter-spacing:.05em}
@media(max-width:560px){ .detailrow .dcols{grid-template-columns:1fr} .mteams{font-size:15px} .pc{width:34px;font-size:12px} }

/* actu : flux plein écran (onglet Actualité) */
.newslist.big .newsitem{background:var(--card);box-shadow:0 6px 18px rgba(3,18,12,.12);border:0;margin-bottom:9px;padding:12px 14px}
.newslist.big .newsitem a{font-size:14px}
