:root{
  --paper:#FFFFFF; --paper-2:#FAFAFA; --ink:#0A0A0A; --muted:#6B6B6B;
  --line:#E6E6E6; --rouge:#FF2900; --rouge-soft:rgba(255,41,0,.08);
  --display:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --body:"Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --maxw:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit}

/* ---------- Marque ---------- */
.brand{font-family:var(--display);font-weight:700;letter-spacing:-.02em;display:inline-flex;align-items:baseline;gap:1px}
.brand .colon{color:var(--rouge)}

/* ================= LOGIN ================= */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.login-side{background:var(--ink);color:#fff;padding:56px 52px;display:flex;flex-direction:column;justify-content:space-between}
.login-side .brand{font-size:30px;color:#fff}
.login-side h1{font-family:var(--display);font-weight:700;font-size:clamp(26px,3vw,38px);letter-spacing:-.025em;line-height:1.08;margin-top:auto;max-width:14ch}
.login-side .quote{color:#bdbdbd;font-size:14px;margin-top:18px;max-width:34ch}
.login-side .quote .colon{color:var(--rouge)}
.login-main{display:flex;align-items:center;justify-content:center;padding:40px}
.login-card{width:100%;max-width:360px}
.login-logo{height:56px;width:auto;display:block;margin-bottom:26px}
.login-card .eyebrow{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.login-card .eyebrow .colon{color:var(--rouge)}
.login-card h2{font-family:var(--display);font-weight:700;font-size:26px;letter-spacing:-.02em;margin:8px 0 26px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:600;letter-spacing:.03em;color:var(--muted);margin-bottom:7px;text-transform:uppercase}
.field input{width:100%;font-family:var(--body);font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--paper);transition:border-color .15s ease}
.field input:focus{outline:none;border-color:var(--ink)}
.btn-primary{width:100%;font-family:var(--body);font-weight:600;font-size:15px;color:#fff;background:var(--ink);border:0;border-radius:10px;padding:13px;cursor:pointer;transition:opacity .15s ease;display:flex;align-items:center;justify-content:center;gap:9px}
.btn-primary:hover{opacity:.88}
.btn-primary:disabled{opacity:.5;cursor:default}
.login-error{background:var(--rouge-soft);border:1px solid rgba(255,41,0,.3);color:var(--ink);font-size:13.5px;border-radius:9px;padding:11px 13px;margin-bottom:16px;display:none}
.login-error.show{display:block}
.login-foot{margin-top:24px;font-size:12px;color:var(--muted)}
@media (max-width:820px){
  .login-wrap{grid-template-columns:1fr}
  .login-side{display:none}
}

/* ================= DASHBOARD ================= */
.topbar{border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;background:rgba(255,255,255,.9);backdrop-filter:saturate(140%) blur(8px)}
.topbar-in{max-width:var(--maxw);margin:0 auto;padding:18px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.topbar .brand{font-size:22px}
.brand-div{width:1px;height:22px;background:var(--line);margin:0 4px}
.client-logo{height:36px;width:auto;display:block}
.brand-sub{font-weight:500;font-size:13px;color:var(--muted)}
.brand-sub strong{color:var(--ink);font-weight:600}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.status{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;letter-spacing:.02em;padding:6px 11px;border:1px solid var(--line);border-radius:999px;color:var(--muted)}
.status .dot{width:7px;height:7px;border-radius:50%;background:var(--muted)}
.status.is-live{color:var(--ink);border-color:rgba(255,41,0,.35)}
.status.is-live .dot{background:var(--rouge);box-shadow:0 0 0 3px var(--rouge-soft)}
.btn-ghost{font-family:var(--body);font-size:13px;font-weight:600;cursor:pointer;background:transparent;color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:7px 14px;transition:border-color .15s ease}
.btn-ghost:hover{border-color:var(--ink)}
.btn-dark{font-family:var(--body);font-size:13px;font-weight:600;cursor:pointer;background:var(--ink);color:#fff;border:0;border-radius:999px;padding:8px 15px;display:inline-flex;align-items:center;gap:8px}
.btn-dark:hover{opacity:.85}
.btn-dark svg{transition:transform .6s ease}
.btn-dark.spinning svg{transform:rotate(360deg)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px}
.eyebrow .colon{color:var(--rouge)}
.hero{padding:40px 0 4px}
.hero-top{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.range{display:inline-flex;border:1px solid var(--line);border-radius:999px;padding:3px;gap:2px}
.range button{font-family:var(--body);font-size:12.5px;font-weight:600;color:var(--muted);background:transparent;border:0;border-radius:999px;padding:6px 14px;cursor:pointer;transition:background .15s ease,color .15s ease}
.range button:hover{color:var(--ink)}
.range button.active{background:var(--ink);color:#fff}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(26px,4vw,42px);letter-spacing:-.025em;line-height:1.06;margin:12px 0 8px;max-width:18ch}
.hero .lede{color:var(--muted);font-size:15px;max-width:54ch}
.updated{font-size:12px;color:var(--muted);margin-top:8px}

/* Ligne de totaux */
.summary{display:flex;flex-wrap:wrap;margin-top:26px;border:1px solid var(--line);border-radius:16px;overflow:hidden}
.summary .stat{flex:1;min-width:120px;padding:18px 22px;border-left:1px solid var(--line)}
.summary .stat:first-child{border-left:0}
.summary .s-val{font-family:var(--display);font-weight:700;font-size:28px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.summary .s-lab{font-size:12px;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;margin-top:4px}

/* Grille de versions (1..N) */
.versions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:16px}
.vcard{border:1px solid var(--line);border-radius:16px;padding:22px 24px;display:flex;flex-direction:column;gap:14px;transition:background .3s ease,border-color .3s ease}
.vcard.is-leader{background:var(--rouge-soft);border-color:rgba(255,41,0,.35)}
.vcard-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.rank{font-family:var(--display);font-weight:700;font-size:14px;color:var(--muted);font-variant-numeric:tabular-nums}
.vcard.is-leader .rank{color:var(--rouge)}
.vlabel{font-family:var(--display);font-weight:700;font-size:19px}
.vmeta{font-size:12.5px;color:var(--muted);margin-top:3px}
.vmeta code{font-family:var(--display);font-size:12px;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-radius:5px;padding:1px 6px}
.lead-tag{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--rouge);border-radius:999px;padding:4px 9px;white-space:nowrap}
.vmetrics{display:flex;gap:26px}
.metric .m-val{font-family:var(--display);font-weight:700;font-size:clamp(26px,5vw,36px);line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.metric .m-lab{font-size:12px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:6px}
.share{margin-top:2px}
.share-head{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-bottom:6px}
.share-track{height:8px;border-radius:5px;background:var(--line);overflow:hidden}
.share-fill{height:100%;width:0;background:var(--ink);transition:width .9s cubic-bezier(.2,.7,.2,1)}
.vcard.is-leader .share-fill{background:var(--rouge)}
.vcta{margin-top:auto;padding-top:4px}
.vcta a{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;text-decoration:none;border-bottom:2px solid var(--rouge);padding-bottom:2px}
.vcta a:hover{color:var(--rouge)}

.banner{background:var(--rouge-soft);border:1px solid rgba(255,41,0,.25);border-radius:12px;padding:12px 16px;margin-top:22px;font-size:13px;display:none;align-items:center;gap:10px}
.banner.show{display:flex}

/* Panneau Top pays */
.panel{margin-top:16px;border:1px solid var(--line);border-radius:16px;padding:22px 26px}
.panel-title{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.04em;color:var(--muted);margin-bottom:18px;text-transform:uppercase}
.country-row{display:grid;grid-template-columns:1fr auto;gap:7px 12px;align-items:center;margin-bottom:15px}
.country-row:last-child{margin-bottom:0}
.country-name{font-weight:600;font-size:14px}
.country-val{font-family:var(--display);font-weight:600;font-variant-numeric:tabular-nums;font-size:13.5px;color:var(--muted)}
.country-track{grid-column:1 / -1;height:8px;border-radius:5px;background:var(--line);overflow:hidden}
.country-fill{height:100%;width:0;background:var(--ink);transition:width .9s cubic-bezier(.2,.7,.2,1)}
.country-row:first-child .country-fill{background:var(--rouge)}
.foot{max-width:var(--maxw);margin:44px auto 40px;padding:22px 24px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.foot .note{font-size:12px;color:var(--muted);max-width:60ch}
.foot .sign{font-family:var(--display);font-weight:700;font-size:15px}
.foot .sign .colon{color:var(--rouge)}

@media (max-width:720px){
  .brand-sub{display:none}
}
@media (prefers-reduced-motion:reduce){.share-fill,.country-fill{transition:none}.btn-dark svg{transition:none}}
