:root{
  --bg:#030812;
  --bg2:#071221;
  --card:#101827;
  --card2:#151f31;
  --text:#f8fafc;
  --muted:#9aa7b8;
  --green:#38d72f;
  --green2:#1fb718;
  --green-soft:rgba(56,215,47,.16);
  --blue:#38bdf8;
  --yellow:#facc15;
  --gold:#f5b301;
  --orange:#f97316;
  --red:#ef4444;
  --border:rgba(255,255,255,.11);
  --shadow:0 24px 80px rgba(0,0,0,.38);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:radial-gradient(circle at top left,#132038,#030812 52%);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;min-height:100vh}
a{color:inherit}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px clamp(18px,3vw,50px);background:rgba(3,8,18,.84);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.08)}.topbar-home{position:fixed;left:0;right:0;background:linear-gradient(180deg,rgba(1,7,16,.78),rgba(1,7,16,.42));border-bottom:1px solid rgba(255,255,255,.08)}.brand{color:#fff;text-decoration:none}.brand-village{display:flex;align-items:center;gap:14px;min-width:max-content}.brand-crest{width:54px;height:64px;display:grid;place-items:center;filter:drop-shadow(0 8px 26px rgba(0,0,0,.45))}.brand-crest svg{width:100%;height:100%}.crest-shield{fill:rgba(2,12,24,.88);stroke:#fff;stroke-width:3}.crest-tower{fill:#fff}.crest-ball{fill:#fff}.brand-text strong{display:block;font-weight:1000;letter-spacing:.12em;font-size:clamp(18px,2.1vw,29px);line-height:1}.brand-text em{font-style:normal;color:var(--green)}.primary-nav,.user-nav{display:flex;align-items:center;gap:clamp(12px,1.7vw,28px)}.primary-nav a,.user-nav a{font-weight:650;text-decoration:none;color:rgba(255,255,255,.86);white-space:nowrap}.primary-nav a{position:relative;padding:10px 0}.primary-nav a.active:after,.primary-nav a:hover:after{content:"";position:absolute;left:0;right:0;bottom:-11px;height:3px;border-radius:99px;background:var(--green);box-shadow:0 0 20px rgba(56,215,47,.7)}.nav-toggle{display:none;background:transparent;border:1px solid var(--border);color:#fff;border-radius:12px;padding:8px 12px;font-size:22px}.container{width:min(1180px,92vw);margin:0 auto;padding:34px 0 80px}.home-main{width:100%;padding:0;overflow:hidden}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:14px;background:linear-gradient(135deg,var(--gold),var(--orange));color:#07120c;font-weight:900;padding:12px 18px;text-decoration:none;cursor:pointer;box-shadow:0 16px 34px rgba(0,0,0,.22);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 20px 42px rgba(0,0,0,.32)}.btn-small{padding:10px 16px;border-radius:10px}.btn-xl{min-height:70px;padding:0 30px;border-radius:10px;font-size:18px}.btn-green{background:linear-gradient(135deg,#3be02f,#159e16);color:#fff;box-shadow:0 18px 48px rgba(30,210,37,.32)}.btn.ghost,.ghost{background:rgba(3,8,18,.34);border:1px solid rgba(255,255,255,.25);color:#fff;box-shadow:none}.btn.ghost:hover{background:rgba(255,255,255,.08)}.card,.hero-card,.auth-card{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid var(--border);border-radius:24px;padding:24px;box-shadow:0 18px 60px rgba(0,0,0,.22)}.hero{display:grid;grid-template-columns:1.3fr .7fr;gap:28px;align-items:center;padding:50px 0}.hero h1{font-size:clamp(38px,6vw,72px);line-height:.95;margin:16px 0}.hero p{font-size:18px;color:var(--muted);max-width:720px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.hero-card{min-height:260px}.pill{display:inline-block;background:rgba(245,179,1,.12);border:1px solid rgba(245,179,1,.35);color:#fed76a;border-radius:999px;padding:6px 10px;font-size:13px;font-weight:800}.wallet-row{display:flex;justify-content:space-between;border-bottom:1px solid var(--border);padding:18px 0}.muted{color:var(--muted)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.auth-card{max-width:560px;margin:40px auto}.form{display:grid;gap:14px}.form label{display:grid;gap:7px;color:var(--muted);font-weight:700}.form input,.form select,.inline-form input{width:100%;padding:13px 14px;border-radius:12px;border:1px solid var(--border);background:#0b1020;color:var(--text)}.inline-form{display:flex;gap:10px;align-items:center}.flash{position:relative;z-index:5;padding:14px 18px;border-radius:14px;margin:16px auto;border:1px solid var(--border);width:min(1180px,92vw)}.container .flash{width:auto;margin-bottom:16px}.flash.success{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.4)}.flash.error{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.4)}.flash.warning{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.4)}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:11px;border-bottom:1px solid var(--border)}th{color:#fed76a}.match-list{display:grid;gap:14px}.match-card{display:flex;justify-content:space-between;gap:20px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:20px;padding:18px}.match-card h3{margin:10px 0}.wallet strong{font-size:34px}.wallet.free{border-color:rgba(34,197,94,.35)}.wallet.premium{border-color:rgba(245,179,1,.35)}.map-card{margin-bottom:22px}.map-box{height:420px;border-radius:24px;background:linear-gradient(135deg,#0f172a,#172554);border:1px solid var(--border);position:relative;overflow:hidden}.map-box:before{content:'Carte symbolique du Grand Vaucluse';position:absolute;inset:auto 20px 20px auto;color:rgba(255,255,255,.22);font-size:32px;font-weight:900}.territory{position:absolute;width:28px;height:28px;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 8px rgba(255,255,255,.08),0 0 22px currentColor}.shop-item{display:flex;flex-direction:column;gap:10px}.admin-nav{display:flex;gap:12px;flex-wrap:wrap;margin:10px 0 22px}.admin-nav a{color:#fff;text-decoration:none;border:1px solid var(--border);padding:9px 12px;border-radius:12px}.footer{border-top:1px solid rgba(255,255,255,.08);padding:24px;text-align:center;color:var(--muted);background:#030812}code{background:#0b1020;border:1px solid var(--border);padding:2px 6px;border-radius:7px}

/* Nouvelle page d'accueil nationale */
.jt-hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:125px clamp(20px,5vw,100px) 90px;isolation:isolate}.jt-hero-bg{position:absolute;inset:0;background-image:url('../img/home-stadium.svg');background-size:cover;background-position:center;z-index:-3;transform:scale(1.02)}.jt-hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(1,8,18,.95) 0%,rgba(1,8,18,.78) 36%,rgba(1,8,18,.42) 64%,rgba(1,8,18,.72) 100%),linear-gradient(180deg,rgba(0,0,0,.18) 0%,rgba(0,0,0,.08) 48%,rgba(2,8,18,.92) 100%);z-index:-2}.jt-hero-content{width:100%;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(410px,.7fr);gap:clamp(34px,6vw,80px);align-items:end}.jt-hero-copy{max-width:900px}.jt-tricolor{width:360px;max-width:50vw;height:7px;display:flex;margin-bottom:24px;transform:skewX(-18deg)}.jt-tricolor span{height:100%;flex:1}.jt-tricolor span:nth-child(1){background:#145de0}.jt-tricolor span:nth-child(2){background:#fff}.jt-tricolor span:nth-child(3){background:#f04444}.jt-kicker{text-transform:uppercase;letter-spacing:.18em;color:var(--green);font-weight:900;font-size:13px;margin:0 0 12px}.jt-hero h1{margin:0 0 10px;font-size:clamp(72px,11vw,185px);line-height:.78;font-style:italic;font-weight:1000;letter-spacing:-.08em;text-transform:uppercase;color:#fff;text-shadow:0 16px 36px rgba(0,0,0,.55)}.jt-hero h1 span{display:block}.jt-hero h1 strong{display:inline-block;color:var(--green);font-style:italic;margin-right:.07em}.jt-subtitle{font-size:clamp(28px,3.2vw,54px);line-height:1.05;margin:25px 0 28px;letter-spacing:.05em;color:rgba(255,255,255,.94);text-shadow:0 8px 24px rgba(0,0,0,.7);position:relative}.jt-subtitle:after{content:"";display:block;width:min(360px,55vw);height:4px;background:var(--green);border-radius:99px;margin-top:16px;box-shadow:0 0 20px rgba(56,215,47,.8);transform:skewX(-16deg)}.jt-benefits{display:flex;gap:clamp(22px,4vw,55px);margin:28px 0 30px;flex-wrap:wrap}.jt-benefit{display:grid;grid-template-columns:58px auto;grid-template-rows:auto auto;column-gap:16px;align-items:center}.jt-benefit-icon{grid-row:1/3;width:58px;height:58px;border:1px solid rgba(56,215,47,.7);border-radius:50%;display:grid;place-items:center;color:#fff;background:rgba(6,22,12,.56);box-shadow:0 0 22px rgba(56,215,47,.18)}.jt-benefit-icon.jt-yellow{border-color:rgba(250,204,21,.75);color:#facc15}.jt-benefit-icon.jt-blue{border-color:rgba(56,189,248,.75)}.jt-benefit strong{text-transform:uppercase;letter-spacing:.05em;font-size:15px}.jt-benefit small{color:#c8d1df;font-size:14px}.jt-actions{display:flex;gap:22px;align-items:center;flex-wrap:wrap;margin-top:16px}.jt-social-proof{display:flex;align-items:center;gap:18px;margin-top:34px;color:rgba(255,255,255,.9)}.jt-social-proof p{margin:0;max-width:360px;color:#e7edf7}.jt-avatars{display:flex;align-items:center}.jt-avatars span,.jt-avatars strong{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;margin-left:-10px;border:2px solid rgba(255,255,255,.4);background:linear-gradient(135deg,#334155,#020617);font-size:13px;font-weight:900}.jt-avatars span:first-child{margin-left:0}.jt-avatars strong{background:linear-gradient(135deg,#31d82d,#0a7612);width:54px}.jt-live-card{align-self:center;background:linear-gradient(180deg,rgba(24,80,11,.76),rgba(7,35,7,.72));border:1px solid rgba(72,255,73,.22);box-shadow:0 24px 80px rgba(0,0,0,.36),inset 0 1px rgba(255,255,255,.1);border-radius:28px;padding:28px;backdrop-filter:blur(12px)}.jt-card-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}.jt-card-head h2{font-size:15px;text-transform:uppercase;letter-spacing:.07em;margin:0;color:#74ff71}.jt-card-head a{margin-left:auto;text-decoration:none;color:#fff;font-weight:800;font-size:14px}.jt-live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 18px var(--green)}.jt-match-list{display:grid;gap:10px}.jt-match-row{display:grid;grid-template-columns:minmax(0,1fr) 92px minmax(0,1fr);gap:16px;align-items:center;text-decoration:none;color:#fff;border:1px solid rgba(255,255,255,.06);background:rgba(0,0,0,.32);padding:15px 16px;border-radius:12px;transition:transform .18s ease,background .18s ease}.jt-match-row:hover{transform:translateY(-1px);background:rgba(0,0,0,.42)}.jt-team{display:flex;align-items:center;gap:12px;min-width:0;font-weight:900;font-size:14px}.jt-team-away{justify-content:flex-end;text-align:right}.team-crest{flex:0 0 auto;width:38px;height:42px;clip-path:polygon(50% 0,92% 18%,82% 85%,50% 100%,18% 85%,8% 18%);display:grid;place-items:center;background:linear-gradient(135deg,#0f172a,#14532d);border:1px solid rgba(255,255,255,.22);font-size:12px;font-weight:1000;color:#fff}.team-crest.alt{background:linear-gradient(135deg,#0f172a,#1d4ed8)}.jt-time{text-align:center;display:grid;gap:3px}.jt-time strong{font-size:17px}.jt-time small{font-size:12px;color:#cbd5e1}.jt-empty-live{background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:18px;display:grid;gap:6px}.jt-empty-live span{color:#cbd5e1}.jt-scroll{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);display:grid;gap:10px;text-align:center;text-decoration:none;text-transform:uppercase;letter-spacing:.45em;color:rgba(255,255,255,.64);font-size:12px}.jt-scroll span{width:34px;height:34px;border:1px solid rgba(255,255,255,.35);border-radius:50%;display:grid;place-items:center;margin:auto;color:#fff;letter-spacing:0}.jt-section{width:min(1240px,92vw);margin:0 auto;padding:92px 0}.jt-stats-section{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-top:40px}.jt-stat{border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border-radius:24px;padding:24px;box-shadow:var(--shadow)}.jt-stat strong{font-size:40px;display:block}.jt-stat span{color:var(--muted);text-transform:uppercase;letter-spacing:.09em;font-size:13px}.jt-section-title{max-width:820px;margin-bottom:34px}.jt-section-title h2,.jt-about-card h2{font-size:clamp(34px,5vw,68px);line-height:.95;margin:0 0 16px;letter-spacing:-.04em}.jt-section-title p:not(.jt-kicker),.jt-about-card p{color:#cbd5e1;font-size:18px;line-height:1.6}.jt-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.jt-step,.jt-city-card,.jt-league-card,.jt-about-card{border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.03));border-radius:26px;padding:28px;box-shadow:var(--shadow)}.jt-step span{color:var(--green);font-weight:1000;letter-spacing:.18em}.jt-step h3{font-size:24px;margin:18px 0 10px}.jt-step p{color:#cbd5e1;line-height:1.55}.jt-city-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}.jt-city-card{text-align:center;padding:24px 14px}.city-bell{width:48px;height:58px;display:block;margin:0 auto 14px;background:linear-gradient(180deg,#fff,#dbeafe);clip-path:polygon(50% 0,64% 28%,78% 28%,78% 76%,92% 76%,92% 91%,8% 91%,8% 76%,22% 76%,22% 28%,36% 28%)}.jt-city-card strong{display:block;font-size:18px}.jt-city-card small{color:var(--muted)}.jt-league-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.jt-league-card{text-decoration:none;color:#fff;min-height:145px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}.jt-league-card:before{content:"";position:absolute;inset:auto -20% -40% -20%;height:90px;background:radial-gradient(circle,var(--green-soft),transparent 62%)}.jt-league-card strong{font-size:28px;position:relative}.jt-league-card span{color:#cbd5e1;position:relative}.jt-about-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:30px;align-items:center;background:linear-gradient(135deg,rgba(28,144,35,.18),rgba(255,255,255,.04))}.jt-about-card .btn{white-space:nowrap}

/* V5 Sync FFF */
.table-wrap{overflow:auto;width:100%;}.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0;}.chip{display:inline-flex;padding:.45rem .75rem;border:1px solid rgba(255,255,255,.14);border-radius:999px;text-decoration:none;color:inherit;background:rgba(255,255,255,.04)}.chip.active{background:rgba(245,179,1,.18);border-color:rgba(245,179,1,.65);}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:1rem 0;}.stat-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:1rem;}.stat-card strong{display:block;font-size:1.7rem;line-height:1.1;}.stat-card span{color:rgba(255,255,255,.7);font-size:.9rem;}.checkbox-line{display:flex!important;gap:.55rem;align-items:center;}.checkbox-line input{width:auto!important;}.pill.success,.pill.warning,.pill.error{padding:.2rem .55rem;border-radius:999px;font-size:.82rem;}.pill.success{background:rgba(34,197,94,.18);color:#86efac;}.pill.warning{background:rgba(245,158,11,.18);color:#fcd34d;}.pill.error{background:rgba(239,68,68,.18);color:#fca5a5;}.warning-card{border-color:rgba(245,158,11,.35)!important;}.notice-info{background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.35);color:#bfdbfe;border-radius:14px;padding:12px 14px;margin:14px 0;}

@media(max-width:1180px){.topbar{align-items:flex-start}.primary-nav{display:none}.nav-toggle{display:block;margin-left:auto}.nav-open .primary-nav{display:flex;position:absolute;left:18px;right:18px;top:92px;background:rgba(3,8,18,.96);border:1px solid var(--border);border-radius:18px;padding:18px;flex-direction:column;align-items:flex-start}.jt-hero-content{grid-template-columns:1fr}.jt-live-card{max-width:760px;width:100%}.jt-city-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:800px){.topbar{padding:14px;gap:10px}.brand-crest{width:42px;height:52px}.brand-text strong{font-size:17px}.user-nav{width:100%;gap:8px;flex-wrap:wrap}.user-nav .btn{flex:1;min-width:138px}.jt-hero{min-height:auto;padding:118px 20px 72px}.jt-tricolor{width:230px;max-width:75vw}.jt-hero h1{font-size:72px}.jt-subtitle{font-size:28px}.jt-benefits,.jt-actions,.jt-social-proof{align-items:stretch;flex-direction:column}.jt-benefit{grid-template-columns:50px auto}.jt-benefit-icon{width:50px;height:50px}.btn-xl{width:100%;min-height:58px}.jt-live-card{padding:18px;border-radius:22px}.jt-match-row{grid-template-columns:1fr;gap:10px}.jt-team-away{justify-content:flex-start;text-align:left;flex-direction:row-reverse}.jt-time{text-align:left}.jt-stats-section,.jt-steps,.jt-league-cards,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.jt-city-grid{grid-template-columns:repeat(2,1fr)}.jt-about-card{grid-template-columns:1fr}.match-card{flex-direction:column;align-items:flex-start}.inline-form{flex-direction:column}.container{padding-top:24px}.admin-nav{gap:8px}}
@media(max-width:480px){.jt-hero h1{font-size:58px}.jt-section{padding:62px 0}.jt-city-grid{grid-template-columns:1fr}.jt-stat strong{font-size:32px}}



/* ==========================================================================
   V10.8 — Audit commando UX responsive
   Objectifs :
   - supprimer les boutons rognés sur mobile ;
   - stabiliser le header avec un vrai panneau menu ;
   - empêcher tout scroll horizontal ;
   - améliorer la lisibilité mobile sans casser la home desktop.
   ========================================================================== */

html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

body {
  -webkit-text-size-adjust: 100%;
  text-rendering: geometricPrecision;
}

img, svg, video, canvas {
  max-width: 100%;
}

.topbar {
  width: 100%;
  min-width: 0;
}

.nav-panel {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(22px, 3vw, 48px);
  margin-left: auto;
  min-width: 0;
}

.nav-backdrop {
  display: none;
}

.nav-toggle {
  width: 52px;
  height: 52px;
  padding: 0;
  place-items: center;
  border-radius: 16px;
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: none;
}

.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  margin: 3px 0;
  border-radius: 99px;
  background: #fff;
  transition: transform .2s ease, opacity .2s ease;
}

.nav-open .nav-toggle span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

.brand-village {
  flex: 0 0 auto;
}

.home-main {
  max-width: 100vw;
  overflow-x: clip;
}

.jt-hero, .jt-section, .jt-live-card, .jt-hero-content, .jt-hero-copy {
  max-width: 100%;
}

.jt-hero {
  min-height: 100svh;
}

.jt-hero h1 {
  overflow-wrap: normal;
  word-break: normal;
}

.jt-match-row {
  min-width: 0;
}

.jt-team {
  min-width: 0;
}

.jt-team > span:last-child,
.jt-team {
  overflow-wrap: anywhere;
}

@media (max-width: 1280px) {
  .topbar {
    padding-left: clamp(18px, 2vw, 34px);
    padding-right: clamp(18px, 2vw, 34px);
  }

  .nav-panel {
    gap: 22px;
  }

  .primary-nav {
    gap: 18px;
  }

  .user-nav {
    gap: 12px;
  }

  .primary-nav a,
  .user-nav a {
    font-size: 15px;
  }
}

/* Tablette + mobile : un seul point d'entrée, plus de boutons qui dépassent. */
@media (max-width: 1080px) {
  .topbar,
  .topbar-home {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    min-height: 82px;
    align-items: center !important;
    padding: calc(12px + env(safe-area-inset-top)) 18px 12px;
    background: rgba(3,8,18,.94);
    border-bottom: 1px solid rgba(255,255,255,.09);
    backdrop-filter: blur(18px);
  }

  .topbar-home {
    position: fixed;
  }

  .brand-village {
    flex: 1 1 auto;
    min-width: 0;
    max-width: calc(100vw - 96px);
    gap: 12px;
  }

  .brand-crest {
    width: 48px;
    height: 58px;
    flex: 0 0 auto;
  }

  .brand-text {
    min-width: 0;
  }

  .brand-text strong {
    font-size: clamp(18px, 4.8vw, 26px);
    letter-spacing: .16em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .nav-toggle {
    display: grid !important;
    flex: 0 0 auto;
    margin-left: auto;
    z-index: 90;
  }

  .nav-panel {
    display: none;
    position: fixed;
    z-index: 85;
    left: 16px;
    right: 16px;
    top: calc(88px + env(safe-area-inset-top));
    max-height: calc(100svh - 108px - env(safe-area-inset-top));
    overflow-y: auto;
    overscroll-behavior: contain;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 16px;
    margin: 0;
    padding: 18px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 24px;
    background:
      radial-gradient(circle at top right, rgba(56,215,47,.14), transparent 38%),
      linear-gradient(180deg, rgba(7,14,29,.98), rgba(2,7,17,.98));
    box-shadow: 0 28px 90px rgba(0,0,0,.55);
  }

  .nav-open {
    overflow: hidden;
  }

  .nav-open .nav-panel {
    display: flex;
  }

  .nav-open .nav-backdrop {
    display: block;
    position: fixed;
    z-index: 80;
    inset: 0;
    background: rgba(0,0,0,.48);
    border: 0;
    padding: 0;
  }

  .primary-nav,
  .user-nav {
    display: flex !important;
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .primary-nav {
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255,255,255,.10);
  }

  .primary-nav a,
  .user-nav a {
    width: 100%;
    white-space: normal;
    text-align: left;
  }

  .primary-nav a {
    padding: 13px 14px;
    border-radius: 14px;
    color: rgba(255,255,255,.92);
    background: rgba(255,255,255,.035);
  }

  .primary-nav a.active,
  .primary-nav a:hover {
    color: #fff;
    background: rgba(56,215,47,.12);
  }

  .primary-nav a.active:after,
  .primary-nav a:hover:after {
    display: none;
  }

  .user-nav .btn {
    justify-content: center;
    min-height: 50px;
    border-radius: 14px;
    font-size: 15px;
  }

  .jt-hero {
    padding-top: calc(108px + env(safe-area-inset-top));
  }
}

@media (max-width: 900px) {
  .jt-hero {
    min-height: auto;
    display: block;
    padding-left: clamp(18px, 5vw, 34px);
    padding-right: clamp(18px, 5vw, 34px);
    padding-bottom: 64px;
  }

  .jt-hero-bg {
    background-position: center top;
    opacity: .68;
  }

  .jt-hero-overlay {
    background:
      linear-gradient(180deg, rgba(1,8,18,.82) 0%, rgba(1,8,18,.76) 46%, rgba(2,8,18,.96) 100%),
      linear-gradient(90deg, rgba(1,8,18,.96), rgba(1,8,18,.62));
  }

  .jt-hero-content {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 28px;
    align-items: start;
  }

  .jt-hero-copy {
    max-width: 720px;
  }

  .jt-tricolor {
    width: min(360px, 78vw);
    height: 6px;
    margin-bottom: 30px;
  }

  .jt-kicker {
    max-width: 92vw;
    line-height: 1.55;
    letter-spacing: .24em;
    font-size: 12px;
  }

  .jt-hero h1 {
    font-size: clamp(64px, 18vw, 116px);
    line-height: .82;
    letter-spacing: -.075em;
    margin-bottom: 18px;
  }

  .jt-subtitle {
    font-size: clamp(31px, 8vw, 48px);
    line-height: 1.18;
    letter-spacing: .055em;
    margin: 24px 0 28px;
    max-width: 720px;
  }

  .jt-subtitle:after {
    width: min(360px, 78vw);
    height: 5px;
    margin-top: 24px;
  }

  .jt-benefits {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    margin: 30px 0;
  }

  .jt-benefit {
    grid-template-columns: 58px minmax(0, 1fr);
    padding: 14px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 20px;
    background: rgba(255,255,255,.035);
    backdrop-filter: blur(8px);
  }

  .jt-benefit strong {
    font-size: 16px;
  }

  .jt-benefit small {
    font-size: 15px;
    line-height: 1.35;
  }

  .jt-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: stretch;
    width: 100%;
    margin-top: 18px;
  }

  .btn-xl {
    width: 100%;
    min-height: 60px;
    padding: 0 18px;
    font-size: 16px;
  }

  .jt-social-proof {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
    margin-top: 26px;
  }

  .jt-social-proof p {
    max-width: 100%;
    line-height: 1.45;
  }

  .jt-live-card {
    width: 100%;
    margin-top: 16px;
    padding: 18px;
    border-radius: 22px;
  }

  .jt-card-head {
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 8px;
  }

  .jt-card-head h2 {
    flex: 1 1 auto;
    min-width: 170px;
  }

  .jt-card-head a {
    margin-left: 0;
    font-size: 13px;
  }

  .jt-match-row {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 14px;
  }

  .jt-team {
    width: 100%;
    justify-content: flex-start;
  }

  .jt-team-away {
    justify-content: flex-start;
    text-align: left;
    flex-direction: row-reverse;
  }

  .jt-time {
    text-align: left;
    grid-template-columns: auto auto;
    justify-content: start;
    align-items: baseline;
    gap: 10px;
    padding-left: 50px;
  }

  .jt-scroll {
    display: none;
  }

  .jt-section {
    width: min(100% - 36px, 760px);
    padding: 68px 0;
  }

  .jt-stats-section {
    padding-top: 36px;
  }
}

@media (max-width: 560px) {
  .topbar,
  .topbar-home {
    min-height: 78px;
    padding-left: 14px;
    padding-right: 14px;
  }

  .brand-crest {
    width: 44px;
    height: 54px;
  }

  .brand-text strong {
    font-size: clamp(15px, 5vw, 20px);
    letter-spacing: .13em;
  }

  .nav-toggle {
    width: 48px;
    height: 48px;
    border-radius: 15px;
  }

  .nav-panel {
    left: 10px;
    right: 10px;
    top: calc(82px + env(safe-area-inset-top));
    padding: 14px;
    border-radius: 20px;
  }

  .jt-hero {
    padding-top: calc(104px + env(safe-area-inset-top));
    padding-left: 20px;
    padding-right: 20px;
  }

  .jt-tricolor {
    width: min(320px, 82vw);
    margin-bottom: 28px;
  }

  .jt-kicker {
    font-size: 11px;
    letter-spacing: .28em;
  }

  .jt-hero h1 {
    font-size: clamp(64px, 19vw, 88px);
    letter-spacing: -.07em;
  }

  .jt-subtitle {
    font-size: clamp(30px, 9.5vw, 42px);
  }

  .jt-benefit {
    grid-template-columns: 54px minmax(0, 1fr);
  }

  .jt-benefit-icon {
    width: 54px;
    height: 54px;
  }

  .jt-avatars span,
  .jt-avatars strong {
    width: 38px;
    height: 38px;
  }

  .jt-avatars strong {
    width: 50px;
  }

  .jt-stat {
    padding: 20px;
  }
}

/* Très petits écrans : priorité à la lisibilité, pas au spectaculaire. */
@media (max-width: 390px) {
  .brand-text strong {
    font-size: 14px;
    letter-spacing: .10em;
  }

  .brand-crest {
    width: 40px;
    height: 50px;
  }

  .jt-hero h1 {
    font-size: 58px;
  }

  .jt-subtitle {
    font-size: 28px;
  }

  .jt-benefit strong {
    font-size: 14px;
  }

  .jt-benefit small {
    font-size: 14px;
  }
}

/* ==========================================================================
   V10.9 — Rescue mobile : menu fermé par défaut + header compact
   Objectif : neutraliser les règles V10.8 trop agressives et éviter tout
   panneau ouvert/rogné sur mobile.
   ========================================================================== */

@media (max-width: 900px) {
  html, body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  body.nav-open {
    overflow: hidden !important;
  }

  .topbar,
  .topbar-home {
    position: sticky !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 54px !important;
    align-items: center !important;
    gap: 12px !important;
    min-height: 82px !important;
    padding: calc(12px + env(safe-area-inset-top)) 16px 12px !important;
    background: rgba(3, 8, 18, .96) !important;
    border-bottom: 1px solid rgba(255,255,255,.09) !important;
    backdrop-filter: blur(18px) !important;
  }

  .brand-village {
    min-width: 0 !important;
    max-width: 100% !important;
    width: auto !important;
    overflow: hidden !important;
    gap: 11px !important;
  }

  .brand-crest {
    width: 46px !important;
    height: 56px !important;
    flex: 0 0 46px !important;
  }

  .brand-text {
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .brand-text strong {
    font-size: clamp(17px, 5.2vw, 23px) !important;
    letter-spacing: .14em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .nav-toggle {
    display: grid !important;
    grid-column: 2 !important;
    place-items: center !important;
    width: 52px !important;
    height: 52px !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background: rgba(255,255,255,.045) !important;
    color: #fff !important;
    box-shadow: none !important;
    z-index: 1003 !important;
  }

  .nav-toggle span {
    display: block !important;
    width: 22px !important;
    height: 2px !important;
    margin: 3px 0 !important;
    border-radius: 999px !important;
    background: #fff !important;
    transform: none !important;
    opacity: 1 !important;
  }

  /* Neutralise les anciens sélecteurs body.nav-open de V10.8 */
  body.nav-open .nav-panel,
  .nav-panel {
    display: none !important;
  }

  .nav-panel.is-open {
    display: flex !important;
    position: fixed !important;
    left: 14px !important;
    right: 14px !important;
    top: calc(92px + env(safe-area-inset-top)) !important;
    z-index: 1002 !important;
    max-height: min(620px, calc(100svh - 118px - env(safe-area-inset-top))) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 16px !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    border-radius: 22px !important;
    background:
      radial-gradient(circle at top right, rgba(56,215,47,.16), transparent 40%),
      linear-gradient(180deg, rgba(7,14,29,.98), rgba(2,7,17,.98)) !important;
    box-shadow: 0 32px 90px rgba(0,0,0,.62) !important;
  }

  .nav-backdrop {
    display: none !important;
  }

  .nav-backdrop.is-open {
    display: block !important;
    position: fixed !important;
    z-index: 1001 !important;
    inset: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: rgba(0,0,0,.58) !important;
  }

  .primary-nav,
  .user-nav {
    display: flex !important;
    width: 100% !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
  }

  .primary-nav {
    padding-bottom: 14px !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
  }

  .primary-nav a,
  .user-nav a,
  .user-nav .btn {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 52px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 13px 14px !important;
    border-radius: 14px !important;
    text-align: center !important;
    white-space: normal !important;
    font-size: 15px !important;
  }

  .primary-nav a {
    justify-content: flex-start !important;
    background: rgba(255,255,255,.045) !important;
  }

  .primary-nav a.active,
  .primary-nav a:hover {
    background: rgba(56,215,47,.14) !important;
  }

  .primary-nav a:after,
  .primary-nav a.active:after,
  .primary-nav a:hover:after {
    display: none !important;
    content: none !important;
  }

  .nav-panel.is-open + * {
    pointer-events: none;
  }

  .nav-panel.is-open ~ * {
    pointer-events: none;
  }

  .jt-hero {
    min-height: auto !important;
    display: block !important;
    padding: calc(116px + env(safe-area-inset-top)) 20px 58px !important;
  }

  .jt-hero-content {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 28px !important;
    align-items: start !important;
  }

  .jt-tricolor {
    width: min(330px, 82vw) !important;
    max-width: 82vw !important;
    height: 6px !important;
    margin-bottom: 26px !important;
  }

  .jt-kicker {
    font-size: 11px !important;
    line-height: 1.5 !important;
    letter-spacing: .26em !important;
    max-width: 92vw !important;
  }

  .jt-hero h1 {
    font-size: clamp(62px, 19vw, 90px) !important;
    line-height: .82 !important;
    letter-spacing: -.07em !important;
    margin-bottom: 18px !important;
  }

  .jt-subtitle {
    font-size: clamp(30px, 9.5vw, 42px) !important;
    line-height: 1.18 !important;
    max-width: 92vw !important;
  }

  .jt-subtitle:after {
    width: min(330px, 82vw) !important;
    height: 5px !important;
    margin-top: 22px !important;
  }

  .jt-benefits {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin: 30px 0 !important;
  }

  .jt-benefit {
    display: grid !important;
    grid-template-columns: 56px minmax(0,1fr) !important;
    padding: 14px !important;
    border-radius: 20px !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    background: rgba(255,255,255,.035) !important;
    backdrop-filter: blur(8px) !important;
  }

  .jt-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    width: 100% !important;
  }

  .btn-xl,
  .jt-actions .btn {
    width: 100% !important;
    min-height: 58px !important;
    font-size: 16px !important;
  }

  .jt-live-card {
    width: 100% !important;
    margin-top: 18px !important;
    padding: 18px !important;
    border-radius: 22px !important;
  }

  .jt-match-row {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .jt-team,
  .jt-team-away {
    justify-content: flex-start !important;
    text-align: left !important;
  }

  .jt-time {
    text-align: left !important;
    padding-left: 50px !important;
  }
}

@media (max-width: 390px) {
  .brand-crest { width: 40px !important; height: 50px !important; flex-basis: 40px !important; }
  .brand-text strong { font-size: 14px !important; letter-spacing: .11em !important; }
  .nav-toggle { width: 48px !important; height: 48px !important; }
  .jt-hero h1 { font-size: 58px !important; }
  .jt-subtitle { font-size: 28px !important; }
}

/* ========================================================================== 
   V10.11 — Fix final header desktop + mobile spacing
   Objectifs :
   - empêcher le logo de passer au-dessus du menu desktop ;
   - supprimer le grand vide entre header mobile et hero ;
   - conserver un menu hamburger fiable sans superposition parasite.
   ========================================================================== */

/* Desktop / laptop : header en grille, logo contenu dans sa colonne. */
@media (min-width: 981px) {
  .topbar,
  .topbar-home {
    display: grid !important;
    grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) !important;
    align-items: center !important;
    gap: clamp(18px, 2.4vw, 42px) !important;
    min-height: 96px !important;
    padding: 18px clamp(28px, 3vw, 52px) !important;
    overflow: visible !important;
  }

  .topbar-home {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
  }

  .brand-village {
    grid-column: 1 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 330px !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    gap: 13px !important;
    z-index: 2 !important;
  }

  .brand-crest {
    width: 58px !important;
    height: 70px !important;
    flex: 0 0 58px !important;
  }

  .brand-text {
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .brand-text strong {
    font-size: clamp(20px, 1.45vw, 25px) !important;
    letter-spacing: .125em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .nav-toggle,
  .nav-backdrop {
    display: none !important;
  }

  .nav-panel {
    grid-column: 2 !important;
    position: static !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: clamp(16px, 2vw, 32px) !important;
    width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  .primary-nav {
    display: flex !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: clamp(14px, 1.35vw, 25px) !important;
    flex-direction: row !important;
  }

  .user-nav {
    display: flex !important;
    flex: 0 0 auto !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 12px !important;
    flex-direction: row !important;
    width: auto !important;
  }

  .primary-nav a,
  .user-nav a {
    font-size: clamp(14px, .9vw, 16px) !important;
    white-space: nowrap !important;
  }

  .user-nav .btn,
  .user-nav .btn-small {
    width: auto !important;
    min-width: 0 !important;
    min-height: 48px !important;
    padding: 12px 18px !important;
    border-radius: 12px !important;
    white-space: nowrap !important;
  }
}

/* Desktop un peu serré : priorité à la non-superposition. */
@media (min-width: 981px) and (max-width: 1320px) {
  .topbar,
  .topbar-home {
    grid-template-columns: minmax(220px, 280px) minmax(0, 1fr) !important;
    gap: 18px !important;
  }

  .brand-crest {
    width: 50px !important;
    height: 60px !important;
    flex-basis: 50px !important;
  }

  .brand-text strong {
    font-size: 18px !important;
    letter-spacing: .105em !important;
  }

  .primary-nav {
    gap: 14px !important;
  }

  .primary-nav a,
  .user-nav a {
    font-size: 14px !important;
  }

  .user-nav .btn,
  .user-nav .btn-small {
    padding-left: 13px !important;
    padding-right: 13px !important;
  }
}

/* Mobile : header propre + hero rapproché. */
@media (max-width: 980px) {
  html, body {
    overflow-x: hidden !important;
    max-width: 100% !important;
  }

  .topbar,
  .topbar-home {
    position: sticky !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 58px !important;
    align-items: center !important;
    gap: 12px !important;
    min-height: 82px !important;
    padding: calc(12px + env(safe-area-inset-top)) 20px 12px !important;
    background: rgba(3,8,18,.97) !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
    backdrop-filter: blur(18px) !important;
  }

  .brand-village {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    gap: 12px !important;
  }

  .brand-crest {
    width: 50px !important;
    height: 60px !important;
    flex: 0 0 50px !important;
  }

  .brand-text strong {
    font-size: clamp(18px, 5.2vw, 25px) !important;
    letter-spacing: .145em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .nav-toggle {
    display: grid !important;
    grid-column: 2 !important;
    place-items: center !important;
    width: 56px !important;
    height: 56px !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 18px !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background: rgba(255,255,255,.045) !important;
    box-shadow: none !important;
    z-index: 1003 !important;
  }

  .nav-toggle span {
    display: block !important;
    width: 25px !important;
    height: 2px !important;
    margin: 3.5px 0 !important;
    border-radius: 999px !important;
    background: #fff !important;
    opacity: 1 !important;
  }

  .nav-panel {
    display: none !important;
    position: fixed !important;
    left: 14px !important;
    right: 14px !important;
    top: calc(92px + env(safe-area-inset-top)) !important;
    z-index: 1002 !important;
    max-height: calc(100svh - 112px - env(safe-area-inset-top)) !important;
    overflow-y: auto !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 16px !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    border-radius: 22px !important;
    background: radial-gradient(circle at top right, rgba(56,215,47,.16), transparent 42%), linear-gradient(180deg, rgba(7,14,29,.985), rgba(2,7,17,.985)) !important;
    box-shadow: 0 32px 90px rgba(0,0,0,.62) !important;
  }

  body.nav-open .nav-panel,
  .nav-panel.is-open {
    display: flex !important;
  }

  .nav-backdrop {
    display: none !important;
  }

  body.nav-open .nav-backdrop,
  .nav-backdrop.is-open {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 1001 !important;
    border: 0 !important;
    background: rgba(0,0,0,.55) !important;
  }

  .primary-nav,
  .user-nav {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    width: 100% !important;
  }

  .primary-nav {
    padding-bottom: 14px !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
  }

  .primary-nav a,
  .user-nav a,
  .user-nav .btn {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 52px !important;
    padding: 13px 15px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.045) !important;
    color: #fff !important;
    text-align: left !important;
    white-space: normal !important;
    font-size: 15px !important;
  }

  .user-nav .btn-green,
  .user-nav a.btn-green {
    justify-content: center !important;
    background: linear-gradient(135deg,#3be02f,#159e16) !important;
  }

  .primary-nav a:after,
  .primary-nav a.active:after,
  .primary-nav a:hover:after {
    display: none !important;
    content: none !important;
  }

  .nav-panel.is-open + *,
  .nav-panel.is-open ~ * {
    pointer-events: auto !important;
  }

  .jt-hero {
    min-height: auto !important;
    padding: 26px 20px 58px !important;
  }

  .jt-hero-content {
    grid-template-columns: 1fr !important;
    gap: 26px !important;
    align-items: start !important;
  }

  .jt-tricolor {
    width: min(330px, 84vw) !important;
    max-width: 84vw !important;
    height: 6px !important;
    margin: 0 0 26px !important;
  }

  .jt-kicker {
    font-size: 11px !important;
    line-height: 1.5 !important;
    letter-spacing: .26em !important;
    max-width: 92vw !important;
  }

  .jt-hero h1 {
    font-size: clamp(62px, 19vw, 90px) !important;
    line-height: .82 !important;
    letter-spacing: -.07em !important;
    margin: 22px 0 18px !important;
  }

  .jt-subtitle {
    font-size: clamp(29px, 9.2vw, 42px) !important;
    line-height: 1.18 !important;
    max-width: 92vw !important;
  }

  .jt-subtitle:after {
    width: min(330px, 84vw) !important;
    height: 5px !important;
    margin-top: 22px !important;
  }

  .jt-benefits {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin: 30px 0 !important;
  }
}

@media (max-width: 390px) {
  .topbar,
  .topbar-home {
    grid-template-columns: minmax(0, 1fr) 52px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  .brand-crest { width: 42px !important; height: 52px !important; flex-basis: 42px !important; }
  .brand-text strong { font-size: 15px !important; letter-spacing: .11em !important; }
  .nav-toggle { width: 50px !important; height: 50px !important; }
  .jt-hero { padding-top: 22px !important; }
  .jt-hero h1 { font-size: 58px !important; }
  .jt-subtitle { font-size: 28px !important; }
}

/* ========================================================================== 
   V10.12 — HEADER FINAL AUTORITAIRE
   Corrige définitivement :
   1) desktop : aucun chevauchement logo / menu / boutons compte ;
   2) mobile : hamburger visible, menu ouvert au clic, fermé par défaut ;
   3) reset des anciens patches V10.8 → V10.11 contradictoires.
   ========================================================================== */

.nav-state{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

/* ---------- Desktop ---------- */
@media (min-width: 981px){
  .topbar,
  .topbar-home{
    position: sticky !important;
    top: 0 !important;
    left: auto !important;
    right: auto !important;
    z-index: 1000 !important;
    display: grid !important;
    grid-template-columns: minmax(190px, 245px) minmax(0, 1fr) !important;
    align-items: center !important;
    column-gap: clamp(18px, 2vw, 34px) !important;
    min-height: 86px !important;
    padding: 14px clamp(22px, 2.6vw, 44px) !important;
    overflow: visible !important;
    background: rgba(3,8,18,.92) !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
    backdrop-filter: blur(18px) !important;
  }

  .topbar-home{
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: 0 !important;
  }

  .brand-village{
    grid-column: 1 !important;
    min-width: 0 !important;
    width: 100% !important;
    max-width: 245px !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    overflow: hidden !important;
    z-index: 2 !important;
  }

  .brand-crest{
    flex: 0 0 46px !important;
    width: 46px !important;
    height: 56px !important;
  }

  .brand-text{
    min-width: 0 !important;
    display: block !important;
    overflow: hidden !important;
  }

  .brand-text strong{
    display: block !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    font-size: clamp(16px, 1.25vw, 21px) !important;
    letter-spacing: .115em !important;
    line-height: 1 !important;
  }

  .nav-toggle,
  .nav-backdrop{
    display: none !important;
  }

  .nav-panel,
  .nav-state:checked ~ .nav-panel,
  body.nav-open .nav-panel,
  .nav-panel.is-open{
    grid-column: 2 !important;
    position: static !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: clamp(12px, 1.35vw, 22px) !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  .primary-nav{
    grid-column: 1 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: clamp(10px, 1.05vw, 20px) !important;
    min-width: 0 !important;
    width: 100% !important;
    overflow: hidden !important;
    padding: 0 !important;
    border: 0 !important;
  }

  .user-nav{
    grid-column: 2 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: 0 !important;
    overflow: visible !important;
  }

  .primary-nav a,
  .user-nav a,
  .user-nav .btn{
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    font-size: clamp(12px, .82vw, 15px) !important;
    line-height: 1 !important;
    padding-top: 9px !important;
    padding-bottom: 9px !important;
    text-decoration: none !important;
  }

  .primary-nav a{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .user-nav .btn,
  .user-nav .btn-small{
    min-height: 44px !important;
    padding: 10px 14px !important;
    border-radius: 11px !important;
  }

  .primary-nav a.active:after,
  .primary-nav a:hover:after{
    bottom: -12px !important;
  }
}

/* Desktop moyen : on garde les actions joueur, on retire seulement les liens secondaires du header. */
@media (min-width: 981px) and (max-width: 1500px){
  .topbar,
  .topbar-home{
    grid-template-columns: minmax(170px, 215px) minmax(0,1fr) !important;
    column-gap: 16px !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
  }
  .brand-village{max-width:215px !important;gap:10px !important;}
  .brand-crest{width:42px !important;height:52px !important;flex-basis:42px !important;}
  .brand-text strong{font-size:16px !important;letter-spacing:.095em !important;}
  .primary-nav{gap:12px !important;}
  .primary-nav a{font-size:13px !important;}
  .user-nav{gap:8px !important;}
  .user-nav .btn,.user-nav .btn-small{font-size:13px !important;padding-left:11px !important;padding-right:11px !important;}
  .primary-nav a[href$="#comment-ca-marche"],
  .primary-nav a[href$="#a-propos"]{display:none !important;}
}

/* Desktop très serré mais pas mobile : bascule volontaire en hamburger pour éviter toute collision. */
@media (min-width: 981px) and (max-width: 1180px){
  .topbar,
  .topbar-home{
    grid-template-columns: minmax(0,1fr) 56px !important;
  }
  .brand-village{max-width:360px !important;}
  .nav-toggle{display:grid !important;grid-column:2 !important;}
  .nav-panel{display:none !important;}
  .nav-state:checked ~ .nav-panel,
  body.nav-open .nav-panel,
  .nav-panel.is-open{display:flex !important;}
}

/* ---------- Mobile / tablet ---------- */
@media (max-width: 980px){
  html, body{
    overflow-x: hidden !important;
    max-width: 100% !important;
  }

  .topbar,
  .topbar-home{
    position: sticky !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
    display: grid !important;
    grid-template-columns: minmax(0,1fr) 58px !important;
    align-items: center !important;
    gap: 12px !important;
    min-height: 86px !important;
    padding: calc(12px + env(safe-area-inset-top)) 20px 12px !important;
    background: rgba(3,8,18,.98) !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
    backdrop-filter: blur(18px) !important;
    overflow: visible !important;
  }

  .brand-village{
    grid-column: 1 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    gap: 12px !important;
    overflow: hidden !important;
  }

  .brand-crest{
    width: 52px !important;
    height: 62px !important;
    flex: 0 0 52px !important;
  }

  .brand-text{
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .brand-text strong{
    font-size: clamp(18px, 5.4vw, 25px) !important;
    letter-spacing: .135em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
  }

  .nav-toggle{
    display: grid !important;
    grid-column: 2 !important;
    place-items: center !important;
    width: 58px !important;
    height: 58px !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 18px !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background: rgba(255,255,255,.045) !important;
    cursor: pointer !important;
    z-index: 1004 !important;
  }

  .nav-toggle span{
    display:block !important;
    width:26px !important;
    height:2px !important;
    margin:4px 0 !important;
    border-radius:999px !important;
    background:#fff !important;
    transition: transform .18s ease, opacity .18s ease !important;
  }

  .nav-state:checked + .nav-toggle span:nth-child(1),
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(10px) rotate(45deg) !important;}
  .nav-state:checked + .nav-toggle span:nth-child(2),
  body.nav-open .nav-toggle span:nth-child(2){opacity:0 !important;}
  .nav-state:checked + .nav-toggle span:nth-child(3),
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-10px) rotate(-45deg) !important;}

  .nav-panel{
    display: none !important;
    position: fixed !important;
    left: 16px !important;
    right: 16px !important;
    top: calc(92px + env(safe-area-inset-top)) !important;
    z-index: 1003 !important;
    max-height: calc(100svh - 112px - env(safe-area-inset-top)) !important;
    overflow-y: auto !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 16px !important;
    border: 1px solid rgba(255,255,255,.15) !important;
    border-radius: 22px !important;
    background: radial-gradient(circle at top right, rgba(56,215,47,.20), transparent 44%), linear-gradient(180deg, rgba(8,15,31,.99), rgba(2,7,17,.99)) !important;
    box-shadow: 0 32px 90px rgba(0,0,0,.72) !important;
    backdrop-filter: blur(20px) !important;
  }

  .nav-state:checked ~ .nav-panel,
  body.nav-open .nav-panel,
  .nav-panel.is-open{
    display: flex !important;
  }

  .nav-backdrop{
    display:none !important;
    position:fixed !important;
    inset:0 !important;
    z-index:1002 !important;
    background:rgba(0,0,0,.58) !important;
    border:0 !important;
    cursor:pointer !important;
  }

  .nav-state:checked ~ .nav-backdrop,
  body.nav-open .nav-backdrop,
  .nav-backdrop.is-open{
    display:block !important;
  }

  .primary-nav,
  .user-nav{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
    width:100% !important;
    padding:0 !important;
    border:0 !important;
  }

  .primary-nav{padding-bottom:14px !important;border-bottom:1px solid rgba(255,255,255,.10) !important;}

  .primary-nav a,
  .user-nav a,
  .user-nav .btn{
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    width:100% !important;
    min-width:0 !important;
    min-height:52px !important;
    padding:14px 15px !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.055) !important;
    color:#fff !important;
    font-size:16px !important;
    text-align:left !important;
    white-space:normal !important;
    box-shadow:none !important;
  }

  .user-nav .btn-green,
  .user-nav a.btn-green{
    justify-content:center !important;
    background:linear-gradient(135deg,#3be02f,#159e16) !important;
    box-shadow:0 16px 45px rgba(56,215,47,.20) !important;
  }

  .primary-nav a:after,
  .primary-nav a.active:after,
  .primary-nav a:hover:after{display:none !important;content:none !important;}

  .jt-hero{
    min-height:auto !important;
    padding:32px 20px 58px !important;
  }

  .jt-hero-content{
    grid-template-columns:1fr !important;
    gap:28px !important;
    align-items:start !important;
  }
}

@media (max-width: 430px){
  .topbar,
  .topbar-home{
    grid-template-columns:minmax(0,1fr) 54px !important;
    min-height:82px !important;
    padding-left:18px !important;
    padding-right:18px !important;
  }
  .brand-crest{width:48px !important;height:58px !important;flex-basis:48px !important;}
  .brand-text strong{font-size:19px !important;letter-spacing:.12em !important;}
  .nav-toggle{width:54px !important;height:54px !important;}
  .nav-panel{top:calc(88px + env(safe-area-inset-top)) !important;left:14px !important;right:14px !important;}
  .jt-hero{padding-top:28px !important;}
}

/* V11.15 — PWA installable */
.jtv-install-banner{
  position:fixed;
  left:max(14px, env(safe-area-inset-left));
  right:max(14px, env(safe-area-inset-right));
  bottom:max(14px, env(safe-area-inset-bottom));
  z-index:2000;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  background:radial-gradient(circle at top left, rgba(56,215,47,.22), transparent 40%), linear-gradient(180deg, rgba(8,15,31,.97), rgba(2,7,17,.97));
  box-shadow:0 28px 80px rgba(0,0,0,.55);
  backdrop-filter:blur(18px);
  color:#fff;
}
.jtv-install-text{display:flex;flex-direction:column;gap:3px;min-width:0;}
.jtv-install-text strong{font-size:15px;line-height:1.2;}
.jtv-install-text span{font-size:13px;color:rgba(255,255,255,.72);line-height:1.35;}
.jtv-install-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto;}
.jtv-install-btn,.jtv-install-close{
  appearance:none;
  border:0;
  border-radius:14px;
  min-height:42px;
  padding:10px 13px;
  font-weight:800;
  cursor:pointer;
}
.jtv-install-btn{background:linear-gradient(135deg,#3be02f,#159e16);color:#031104;box-shadow:0 12px 30px rgba(56,215,47,.24);}
.jtv-install-close{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.10);}
body.is-offline::before{
  content:"Connexion hors ligne";
  position:fixed;
  left:50%;
  top:max(10px, env(safe-area-inset-top));
  transform:translateX(-50%);
  z-index:2100;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,186,73,.95);
  color:#201400;
  font-size:13px;
  font-weight:900;
  box-shadow:0 10px 28px rgba(0,0,0,.28);
}
@media (max-width:640px){
  .jtv-install-banner{align-items:stretch;flex-direction:column;padding:13px;}
  .jtv-install-actions{width:100%;}
  .jtv-install-btn,.jtv-install-close{flex:1;}
}

/* V11.15.1 — Correctif critique menu mobile + PWA iPhone.
   Ce bloc neutralise les anciens correctifs contradictoires du header. */
.nav-state{position:absolute !important;inline-size:1px !important;block-size:1px !important;opacity:0 !important;pointer-events:none !important;}

@media (min-width:1181px){
  .topbar,
  .topbar-home{
    position:sticky !important;
    top:0 !important;
    z-index:1000 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:18px !important;
    min-height:84px !important;
    padding:18px clamp(18px,3vw,50px) !important;
    overflow:visible !important;
  }
  .brand-village{flex:0 0 auto !important;min-width:0 !important;max-width:310px !important;}
  .brand-crest{width:52px !important;height:62px !important;flex:0 0 52px !important;}
  .brand-text strong{font-size:clamp(17px,1.5vw,24px) !important;white-space:nowrap !important;}
  .nav-toggle,.nav-backdrop{display:none !important;}
  .nav-panel,
  body.nav-open .nav-panel,
  .nav-panel.is-open{
    position:static !important;
    display:flex !important;
    flex:1 1 auto !important;
    min-width:0 !important;
    max-height:none !important;
    overflow:visible !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:18px !important;
    padding:0 !important;
    margin:0 !important;
    border:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
  }
  .primary-nav{display:flex !important;flex:1 1 auto !important;align-items:center !important;justify-content:center !important;gap:14px !important;width:auto !important;min-width:0 !important;padding:0 !important;border:0 !important;flex-wrap:wrap !important;}
  .user-nav{display:flex !important;flex:0 0 auto !important;align-items:center !important;justify-content:flex-end !important;gap:8px !important;width:auto !important;padding:0 !important;border:0 !important;flex-wrap:nowrap !important;}
  .primary-nav a,.user-nav a,.user-nav .btn{
    width:auto !important;min-width:0 !important;min-height:0 !important;padding:9px 10px !important;background:transparent !important;border-radius:10px !important;font-size:13px !important;white-space:nowrap !important;text-align:center !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;box-shadow:none !important;
  }
  .user-nav .btn,.user-nav .btn-small{padding:9px 12px !important;}
  .user-nav .btn-green,.user-nav a.btn-green{background:linear-gradient(135deg,#3be02f,#159e16) !important;color:#fff !important;box-shadow:0 12px 28px rgba(56,215,47,.18) !important;}
}

@media (max-width:1180px){
  html,body{max-width:100% !important;overflow-x:hidden !important;}
  body.nav-open{overflow:hidden !important;touch-action:none !important;}
  .topbar,
  .topbar-home{
    position:sticky !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    z-index:1000 !important;
    display:grid !important;
    grid-template-columns:minmax(0,1fr) 56px !important;
    align-items:center !important;
    gap:12px !important;
    min-height:82px !important;
    padding:calc(10px + env(safe-area-inset-top)) 16px 10px !important;
    overflow:visible !important;
    background:rgba(3,8,18,.98) !important;
    border-bottom:1px solid rgba(255,255,255,.10) !important;
    backdrop-filter:blur(18px) !important;
  }
  .brand-village{grid-column:1 !important;display:flex !important;align-items:center !important;min-width:0 !important;max-width:100% !important;overflow:hidden !important;gap:10px !important;}
  .brand-crest{width:46px !important;height:56px !important;flex:0 0 46px !important;}
  .brand-text{min-width:0 !important;overflow:hidden !important;}
  .brand-text strong{font-size:clamp(16px,5.2vw,22px) !important;letter-spacing:.12em !important;white-space:nowrap !important;overflow:hidden !important;text-overflow:ellipsis !important;}
  .nav-toggle{
    display:grid !important;
    grid-column:2 !important;
    place-items:center !important;
    width:56px !important;
    height:56px !important;
    margin:0 !important;
    padding:0 !important;
    border-radius:18px !important;
    border:1px solid rgba(255,255,255,.20) !important;
    background:rgba(255,255,255,.06) !important;
    z-index:1005 !important;
    cursor:pointer !important;
  }
  .nav-toggle span{display:block !important;width:25px !important;height:2px !important;margin:4px 0 !important;border-radius:999px !important;background:#fff !important;transition:transform .18s ease,opacity .18s ease !important;}
  .nav-state:checked + .nav-toggle span:nth-child(1),body.nav-open .nav-toggle span:nth-child(1){transform:translateY(10px) rotate(45deg) !important;}
  .nav-state:checked + .nav-toggle span:nth-child(2),body.nav-open .nav-toggle span:nth-child(2){opacity:0 !important;}
  .nav-state:checked + .nav-toggle span:nth-child(3),body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-10px) rotate(-45deg) !important;}
  .nav-panel{
    display:none !important;
    position:fixed !important;
    left:12px !important;
    right:12px !important;
    top:calc(88px + env(safe-area-inset-top)) !important;
    z-index:1004 !important;
    max-height:calc(100dvh - 104px - env(safe-area-inset-top) - env(safe-area-inset-bottom)) !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:14px !important;
    padding:16px !important;
    border:1px solid rgba(255,255,255,.15) !important;
    border-radius:22px !important;
    background:radial-gradient(circle at top right, rgba(56,215,47,.20), transparent 44%),linear-gradient(180deg,rgba(8,15,31,.99),rgba(2,7,17,.99)) !important;
    box-shadow:0 32px 90px rgba(0,0,0,.72) !important;
    backdrop-filter:blur(20px) !important;
  }
  .nav-state:checked ~ .nav-panel,body.nav-open .nav-panel,.nav-panel.is-open{display:flex !important;}
  .nav-backdrop{display:none !important;position:fixed !important;inset:0 !important;z-index:1003 !important;background:rgba(0,0,0,.58) !important;border:0 !important;cursor:pointer !important;}
  .nav-state:checked ~ .nav-backdrop,body.nav-open .nav-backdrop,.nav-backdrop.is-open{display:block !important;}
  .primary-nav,.user-nav{display:flex !important;flex-direction:column !important;align-items:stretch !important;gap:8px !important;width:100% !important;padding:0 !important;border:0 !important;}
  .primary-nav{padding-bottom:14px !important;border-bottom:1px solid rgba(255,255,255,.10) !important;}
  .primary-nav a,.user-nav a,.user-nav .btn{
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    width:100% !important;
    min-width:0 !important;
    min-height:50px !important;
    padding:13px 14px !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.065) !important;
    color:#fff !important;
    font-size:16px !important;
    line-height:1.2 !important;
    text-align:left !important;
    white-space:normal !important;
    box-shadow:none !important;
  }
  .user-nav .btn-green,.user-nav a.btn-green{justify-content:center !important;background:linear-gradient(135deg,#3be02f,#159e16) !important;color:#fff !important;box-shadow:0 16px 45px rgba(56,215,47,.22) !important;}
  .primary-nav a:after,.primary-nav a.active:after,.primary-nav a:hover:after{display:none !important;content:none !important;}
  main.container{padding-top:22px !important;}
  .jt-hero{padding-top:32px !important;}
}

@media (max-width:430px){
  .topbar,.topbar-home{grid-template-columns:minmax(0,1fr) 52px !important;min-height:78px !important;padding-left:14px !important;padding-right:14px !important;}
  .brand-crest{width:42px !important;height:52px !important;flex-basis:42px !important;}
  .brand-text strong{font-size:17px !important;letter-spacing:.105em !important;}
  .nav-toggle{width:52px !important;height:52px !important;border-radius:16px !important;}
  .nav-panel{left:10px !important;right:10px !important;top:calc(84px + env(safe-area-inset-top)) !important;}
}

/* V11.15.1 — bannière installation au-dessus du contenu, sans bloquer le menu */
.jtv-install-banner{z-index:1500 !important;}
body.nav-open .jtv-install-banner{display:none !important;}

/* Prediction form — score fields toggle */
[hidden]{display:none !important;}
.score-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.score-fields label{margin-bottom:0;}
#predForm label small.muted{display:block;margin-top:4px;font-size:12px;}
.match-card{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.match-card>div{flex:1;min-width:0;}
.match-card .btn,.match-card .btn.ghost{flex-shrink:0;white-space:nowrap;}

/* ========================================================================== 
   V11.15.3 — correctif final menu mobile + aide installation iPhone simple
   Objectifs : menu connecté complet, panneau scrollable, déconnexion visible,
   bannière iPhone claire sans masquer le menu.
   ========================================================================== */
.jtv-install-nav-help{
  display:none;
  width:100%;
  border:1px solid rgba(56,215,47,.28);
  background:rgba(56,215,47,.09);
  color:#fff;
  border-radius:16px;
  padding:13px 14px;
  text-align:left;
  font-weight:900;
  cursor:pointer;
}
.jtv-install-nav-help span{display:block;margin-top:4px;color:rgba(255,255,255,.72);font-size:12px;font-weight:700;}
@media (max-width:1180px){
  body.nav-open{overflow:hidden !important;position:relative !important;}
  .topbar,.topbar-home{z-index:3000 !important;}
  .nav-toggle{z-index:3010 !important;}
  .nav-backdrop,.nav-backdrop.is-open,body.nav-open .nav-backdrop,.nav-state:checked ~ .nav-backdrop{z-index:3001 !important;}
  .nav-panel{
    z-index:3002 !important;
    display:none !important;
    position:fixed !important;
    left:10px !important;
    right:10px !important;
    top:calc(82px + env(safe-area-inset-top)) !important;
    max-height:calc(100dvh - 98px - env(safe-area-inset-top) - env(safe-area-inset-bottom)) !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch !important;
    padding:16px 16px calc(18px + env(safe-area-inset-bottom)) !important;
    gap:12px !important;
    flex-direction:column !important;
    align-items:stretch !important;
  }
  .nav-panel.is-open,body.nav-open .nav-panel,.nav-state:checked ~ .nav-panel{display:flex !important;}
  body:not(.nav-open) .nav-panel:not(.is-open){display:none !important;}
  .primary-nav,.user-nav{display:flex !important;flex-direction:column !important;align-items:stretch !important;width:100% !important;gap:8px !important;}
  .primary-nav{padding-bottom:12px !important;margin-bottom:2px !important;border-bottom:1px solid rgba(255,255,255,.10) !important;}
  .user-nav{padding-bottom:4px !important;}
  .primary-nav a,.user-nav a,.user-nav .btn,.jtv-install-nav-help{
    min-height:50px !important;
    width:100% !important;
    justify-content:flex-start !important;
    white-space:normal !important;
    box-sizing:border-box !important;
  }
  .user-nav a.btn-green,.user-nav .btn-green{justify-content:center !important;margin-top:4px !important;}
  .jtv-install-nav-help{display:block !important;}
  body.nav-open .jtv-install-banner{display:none !important;}
}
@media (max-width:430px){
  .nav-panel,.nav-panel.is-open,body.nav-open .nav-panel,.nav-state:checked ~ .nav-panel{
    top:calc(78px + env(safe-area-inset-top)) !important;
    max-height:calc(100dvh - 92px - env(safe-area-inset-top) - env(safe-area-inset-bottom)) !important;
    left:8px !important;
    right:8px !important;
    padding:14px 14px calc(18px + env(safe-area-inset-bottom)) !important;
  }
}
.jtv-install-banner{
  z-index:2500 !important;
  left:max(12px, env(safe-area-inset-left)) !important;
  right:max(12px, env(safe-area-inset-right)) !important;
  bottom:calc(12px + env(safe-area-inset-bottom)) !important;
  border:1px solid rgba(56,215,47,.26) !important;
  background:linear-gradient(180deg,rgba(9,18,34,.98),rgba(3,8,18,.98)) !important;
}
