:root{
  --bg1:#2a0a5e;
  --bg2:#0b1026;
  --card:rgba(255,255,255,.08);
  --card2:rgba(255,255,255,.06);
  --text:#f4f6ff;
  --muted:rgba(244,246,255,.75);
  --stroke:rgba(255,255,255,.14);
  --accent:#8a5cff;
  --accent2:#ff4fd8;
  --shadow: 0 20px 60px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 12% 10%, rgba(138,92,255,.35), transparent 55%),
    radial-gradient(1000px 500px at 90% 0%, rgba(255,79,216,.22), transparent 55%),
    radial-gradient(900px 600px at 80% 95%, rgba(88,214,255,.12), transparent 60%),
    linear-gradient(160deg, var(--bg1), var(--bg2));
  min-height:100%;
}
a{color:inherit}
.container{max-width:1100px;margin:0 auto;padding:24px}
.nav{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:16px;
  padding:14px 18px;
  border:1px solid var(--stroke);
  border-radius:18px;
  background:linear-gradient(180deg,var(--card),var(--card2));
  box-shadow:var(--shadow);
  backdrop-filter: blur(10px);
}
.brand{display:flex;align-items:flex-start;gap:12px;min-width:260px}
.brand img{width:44px;height:44px;border-radius:14px;object-fit:cover;border:1px solid var(--stroke);background:rgba(255,255,255,.06)}
.brand .title{font-weight:800;letter-spacing:.4px}
.brand .subtitle{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.45}
.pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.pill{
  display:flex;align-items:center;gap:8px;
  border:1px solid var(--stroke);
  background:rgba(0,0,0,.18);
  padding:10px 12px;
  border-radius:999px;
  font-size:14px;
}
select,input{
  background:rgba(0,0,0,.22);
  border:1px solid var(--stroke);
  color:var(--text);
  padding:10px 12px;
  border-radius:12px;
  outline:none;
}
input{width:100%}
.grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:16px;
}
@media (max-width: 900px){
  .grid{grid-template-columns:1fr}
  .brand{min-width:auto}
}
.card{
  border:1px solid var(--stroke);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
  border-radius:22px;
  padding:18px;
  box-shadow:var(--shadow);
}
.card h2{margin:0 0 10px;font-size:18px}
.muted{color:var(--muted)}
.program{
  display:flex;gap:14px;flex-wrap:wrap;
  align-items:stretch;
  margin-top:10px;
}
.game{
  flex:1 1 260px;
  border:1px solid var(--stroke);
  border-radius:18px;
  background:rgba(0,0,0,.18);
  overflow:hidden;
}
.game .imgwrap{height:120px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.03)}
.game img{max-height:100px;max-width:86%;object-fit:contain;filter: drop-shadow(0 10px 18px rgba(0,0,0,.35))}
.game .meta{padding:12px}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(138,92,255,.16);
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  margin-top:10px;
}
.exerciseRow{margin-top:14px;display:flex;gap:12px;flex-wrap:wrap}
.exercise{
  flex:1 1 260px;
  border:1px solid var(--stroke);
  border-radius:18px;
  background:rgba(0,0,0,.18);
  padding:12px;
}
.exerciseHeader{display:flex;align-items:center;justify-content:space-between;gap:12px}
.exerciseHeader .name{font-weight:800}
.exerciseHeader .lvl{font-size:12px;color:var(--muted)}
.exercise img{width:100%;max-height:160px;object-fit:contain;margin-top:10px;filter: drop-shadow(0 10px 18px rgba(0,0,0,.35))}
.kpi{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.kpi .chip{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  padding:10px 12px;border-radius:16px;
  font-size:13px;color:var(--muted)
}
.sep{width:100%;margin:8px 0 2px;border-top:1px dashed rgba(255,255,255,.18)}
.btn{
  cursor:pointer;
  border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(180deg, rgba(138,92,255,.35), rgba(138,92,255,.15));
  padding:10px 12px;border-radius:14px;
  color:var(--text);
  font-weight:700;
  text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
}
.btn:hover{filter:brightness(1.05)}
.btn.secondary{background:rgba(255,255,255,.06)}
.footer{
  margin-top:18px;
  border:1px solid var(--stroke);
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.05));
  border-radius:22px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.tabs{display:flex;gap:8px;flex-wrap:wrap;padding:14px}
.small{font-size:12px;color:rgba(244,246,255,.65)}
.alert{
  border:1px solid rgba(255,79,216,.35);
  background:rgba(255,79,216,.10);
  padding:10px 12px;border-radius:16px;
  color:var(--text);
  margin:10px 0;
}

/* games selector */
.gridIcons{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:12px;
  margin-top:12px;
}
@media (max-width: 900px){
  .gridIcons{grid-template-columns: repeat(2, minmax(0, 1fr));}
}
.iconCard{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
  border-radius:18px;
  overflow:hidden;
  cursor:pointer;
}
.iconCard.selected{
  outline: 2px solid rgba(138,92,255,.85);
  box-shadow: 0 0 0 6px rgba(138,92,255,.18);
}
.iconCard .imgwrap{height:92px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.03)}
.iconCard img{max-height:70px;max-width:86%;object-fit:contain;filter: drop-shadow(0 10px 18px rgba(0,0,0,.35))}
.iconCard .meta{padding:10px}
.iconCard .meta .name{font-weight:800;font-size:13px}
.iconCard .meta .sub{font-size:12px;color:var(--muted);margin-top:4px}

/* Modal */
.modal-backdrop{position:fixed; inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;padding:18px;z-index:50;}
.modal-backdrop.show{display:flex}
.modal{width:min(880px, 100%);border:1px solid var(--stroke);background:linear-gradient(180deg, rgba(20,10,45,.92), rgba(10,12,30,.88));border-radius:22px;box-shadow:var(--shadow);overflow:hidden;}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.12);}
.modal-title{font-weight:900}
.modal-close{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);color:var(--text);border-radius:14px;padding:8px 10px;cursor:pointer;}
.modal-body{padding:14px 16px;color:var(--muted);line-height:1.55}
.linksRow{display:flex;gap:10px;flex-wrap:wrap}
.linkChip{border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.18);border-radius:999px;padding:10px 12px;cursor:pointer;font-size:13px;color:var(--muted);}
.linkChip:hover{filter:brightness(1.06)}
.footer .legal{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;align-items:center;}


@media (max-width: 520px){
  .container{padding:14px}
  .nav{flex-direction:column; align-items:flex-start; gap:12px}
  .pills{width:100%; justify-content:flex-start; flex-wrap:wrap}
  .brand img{width:44px;height:44px}
  .title{font-size:18px}
  .card{padding:16px}
  .btn{padding:10px 12px; font-size:14px}
  .kpi{gap:8px}
  .chip{font-size:12px}
  .game-row{gap:10px}
  .game-card img{width:64px;height:64px}
  .exercise-card img{width:84px;height:84px}
  .modal .modal-card{padding:16px; margin:14px}
}

@media (max-width: 380px){
  .btn{width:100%; justify-content:center}
  .pills .btn{width:auto}
}


.legal-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.legal-icon:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.16);
}
.legal-icon img{
  width:20px;
  height:20px;
  display:block;
}


/* Modal (Mentions légales / CGV / Politique) */
.modal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display: none;
  align-items:center;
  justify-content:center;
  padding: 18px;
  z-index: 9999;
}
.modal-backdrop.show{ display:flex; }
.modal-card{
  width: 100%;
  max-width: 760px;
  max-height: 85vh;
  overflow:auto;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  backdrop-filter: blur(14px);
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
  padding: 18px;
}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.modal-title{font-weight:800}
.modal-body{color: rgba(255,255,255,.88); line-height:1.5}


/* Modal legal (JS) */
.gg-modal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9999;
}
.gg-modal-backdrop.show{ display:flex; }
.gg-modal-card{
  width: 100%;
  max-width: 760px;
  max-height: 85vh;
  overflow:auto;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  backdrop-filter: blur(14px);
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
  padding: 18px;
}
.gg-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.gg-modal-title{font-weight:800}
.gg-modal-body{color: rgba(255,255,255,.88); line-height:1.5}
.gg-modal-body h3{margin:14px 0 8px}
.gg-modal-body p{margin:0 0 10px}

/* Premium training days selector */
.daysForm{margin-top:8px}
.daysGrid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  margin-top: 10px;
}
@media (min-width: 720px){
  .daysGrid{grid-template-columns: repeat(3, minmax(0,1fr));}
}
.dayPill{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  cursor: pointer;
  user-select: none;
}
.dayPill input{width:16px; height:16px}
.dayPill span{font-weight:700}
