/* =========================================================
   GMAS V2 - Host (tablette)
========================================================= */
.host-grid{
  display:grid;
  gap: clamp(1rem, 2vw, 1.2rem);
  grid-template-columns: 1fr;
}

.topbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
}

.top-actions{ display:flex; gap:.6rem; flex-wrap:wrap; }

.host-create .codebox{
  margin-top:1rem;
  border-top: 1px dashed rgba(255,255,255,.18);
  padding-top: 1rem;
}

.codebig{
  font-size: clamp(2.2rem, 6vw, 4rem);
  letter-spacing: .18em;
  font-weight: 950;
}

.adv{ margin-top: .9rem; }
.adv summary{
  cursor:pointer;
  color: var(--muted);
  font-weight: 900;
}
.adv summary:hover{ color: var(--text); }

.players{ display:grid; gap:.6rem; }
.playerline{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
  padding:.7rem .9rem;
  border:1px solid rgba(255,255,255,.14);
  border-radius: 1rem;
  background: rgba(0,0,0,.18);
}
.badge{ display:inline-flex; align-items:center; gap:.6rem; }
.dot{
  width: .9rem; height:.9rem; border-radius:50%;
  border: 1px solid rgba(255,255,255,.35);
}
.smallmuted{ color: var(--muted); font-weight: 800; }

.board{ display:grid; gap:.8rem; }

/* Barre progression "voiture" */
.track{
  position:relative;
  border:1px solid rgba(255,255,255,.14);
  border-radius: 1rem;
  background: rgba(0,0,0,.18);
  overflow:hidden;
}
.track .fill{
  height: clamp(3.2rem, 5.5vw, 4rem);
  width: 0%;
  background: rgba(255,255,255,.12);
}
.track .content{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 0 .9rem;
  gap:1rem;
  font-weight:900;
}
.track .left{
  display:flex;
  align-items:center;
  gap:.7rem;
  min-width: 0;
}
.track .name{
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.track .badges{
  display:flex;
  gap:.35rem;
  flex-wrap:wrap;
  align-items:center;
}
.carWrap{
  position:absolute;
  left: 0;
  top: 50%;
  transform: translate(0, -50%);
  width: clamp(42px, 6vw, 70px);
  height: auto;
  pointer-events:none;
  transition: transform .35s ease;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,.35));
}
.carWrap img{ width:100%; height:auto; display:block; }

.log{
  display:grid;
  gap:.5rem;
  max-height: min(55lvh, 560px);
  overflow:auto;
  padding-right:.2rem;
}
.logitem{
  border:1px solid rgba(255,255,255,.14);
  border-radius: 1rem;
  padding:.7rem .9rem;
  background: rgba(0,0,0,.18);
}
.logtime{ color: var(--muted); font-size:.9em; font-weight: 800; }

@media (min-width: 980px){
  .host-grid{ grid-template-columns: 1.15fr .85fr; }
  .host-board{ grid-column: 1 / 2; }
  .host-log{ grid-column: 2 / 3; }
  .host-status{ grid-column: 2 / 3; }
  .host-create{ grid-column: 1 / 2; }
}

/* Overlay orientation tablette */
.rotate-overlay{
  position: fixed;
  inset:0;
  display:none;
  place-items:center;
  padding: min(5rem, 8%);
  background: rgba(0,0,0,.65);
  z-index: 70;
}
.rotate-card{
  width: min(520px, 100%);
  border:1px solid rgba(255,255,255,.16);
  border-radius: calc(var(--r) + .6rem);
  background: rgba(20,25,45,.96);
  padding: clamp(1rem, 2.5vw, 1.4rem);
}
@media (orientation: portrait) and (min-width: 700px){
  .rotate-overlay{ display:grid; }
}


/* QR zone */
.qrwrap{
  display:flex;
  gap: clamp(.8rem, 2vw, 1rem);
  align-items:center;
  flex-wrap:wrap;
  margin-top: 1rem;
}
#qrCanvas{
  width: clamp(160px, 22vw, 220px);
  height: auto;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,.18);
  background: #fff;
}
.qrtext{ display:grid; gap:.4rem; min-width: min(260px, 100%); }

/* boost animation */
.carWrap.is-boost{
  animation: boost .55s ease-out 1;
}
@keyframes boost{
  0%{ filter: drop-shadow(0 6px 14px rgba(0,0,0,.35)); }
  40%{ filter: drop-shadow(0 10px 22px rgba(255,255,255,.25)); transform: translate(var(--tx,0), -50%) scale(1.08); }
  100%{ filter: drop-shadow(0 6px 14px rgba(0,0,0,.35)); }
}
