/* ═══════════════════════════════════════════════
   ONBOARDING
   ═══════════════════════════════════════════════ */

.ob {
  --ob-bg: #0e0b20;
  --ob-surface: #13112d;
  --ob-surface-2: #1a1740;
  --ob-border: rgba(145, 70, 255, .15);
  --ob-purple: #9146ff;
  --ob-purple-dim: rgba(145, 70, 255, .12);
  --ob-gold: #f4c942;
  --ob-gold-dim: rgba(244, 201, 66, .1);
  --ob-teal: #1abc9c;
  --ob-teal-dim: rgba(26, 188, 156, .1);
  --ob-champion: #e74c3c;
  --ob-text: #e4e2f0;
  --ob-muted: #8a87a0;
  --ob-radius: 18px;
  --ob-ease: cubic-bezier(.22, 1, .36, 1);
}

/* ── Overlay ── */
.ob {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
}
.ob.ob--visible {
  opacity: 1;
  visibility: visible;
}

.ob-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 2, 12, .85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* ── Modal ── */
.ob-modal {
  position: relative;
  width: 100%;
  max-width: 460px;
  max-height: calc(100vh - 32px);
  max-height: calc(100dvh - 32px);
  display: flex;
  flex-direction: column;
  background: var(--ob-surface);
  border: 1px solid var(--ob-border);
  border-radius: var(--ob-radius);
  box-shadow:
    0 32px 80px rgba(0, 0, 0, .6),
    0 0 0 1px rgba(145, 70, 255, .05),
    inset 0 1px 0 rgba(255, 255, 255, .04);
  overflow: hidden;
  transform: translateY(20px) scale(.96);
  transition: transform .45s var(--ob-ease);
}
.ob.ob--visible .ob-modal {
  transform: translateY(0) scale(1);
}

/* ── Progress bar ── */
.ob-progress {
  height: 3px;
  background: rgba(255, 255, 255, .04);
  flex-shrink: 0;
}
.ob-progress-bar {
  height: 100%;
  width: 20%;
  background: linear-gradient(90deg, var(--ob-purple), var(--ob-gold));
  border-radius: 0 3px 3px 0;
  transition: width .4s var(--ob-ease);
}

/* ── Close ── */
.ob-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 5;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .07);
  border-radius: 50%;
  color: var(--ob-muted);
  cursor: pointer;
  transition: background .2s, color .2s, transform .15s;
}
.ob-close:hover {
  background: rgba(255, 255, 255, .1);
  color: #fff;
  transform: scale(1.1);
}

/* ═══ STEPS ═══ */
.ob-steps {
  position: relative;
  overflow: hidden;
  flex: 1 1 auto;
  min-height: 320px;
}

.ob-step {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 28px 28px 20px;
  opacity: 0;
  transform: translateX(50px);
  transition: opacity .4s var(--ob-ease), transform .4s var(--ob-ease);
  pointer-events: none;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: rgba(145,70,255,.25) transparent;
}
.ob-step.ob-step--active {
  position: relative;
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}
.ob-step.ob-step--exit-left {
  transform: translateX(-50px);
  opacity: 0;
}

/* ── Visual / Emoji icon ── */
.ob-visual {
  position: relative;
  width: 76px;
  height: 76px;
  margin: 0 auto 16px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.ob-emoji {
  font-size: 2.2rem;
  line-height: 1;
  position: relative;
  z-index: 2;
}
.ob-emoji--big {
  font-size: 2.8rem;
}

.ob-glow {
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  opacity: .4;
  filter: blur(20px);
  z-index: 1;
}
.ob-glow--purple { background: var(--ob-purple); }
.ob-glow--gold   { background: var(--ob-gold); }
.ob-glow--teal   { background: var(--ob-teal); }

.ob-step.ob-step--active .ob-visual {
  animation: ob-pop .45s .1s var(--ob-ease) both;
}
@keyframes ob-pop {
  0%   { transform: scale(.5); opacity: 0; }
  100% { transform: scale(1);  opacity: 1; }
}

/* ── Typography ── */
.ob-title {
  font-family: 'Antonio', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 12px;
  line-height: 1.25;
  width: 100%;
}

.ob-desc {
  font-family: 'Poppins', sans-serif;
  font-size: .87rem;
  line-height: 1.7;
  color: var(--ob-text);
  margin: 0 0 6px;
  width: 100%;
  max-width: 380px;
}
.ob-desc strong { color: #fff; }

.ob-sub {
  font-family: 'Poppins', sans-serif;
  font-size: .78rem;
  line-height: 1.6;
  color: var(--ob-muted);
  margin: 4px 0 0;
  width: 100%;
  max-width: 360px;
}
.ob-sub strong { color: var(--ob-text); }

/* Highlights */
.ob-hl { font-weight: 600; }
.ob-hl--purple { color: var(--ob-purple); }
.ob-hl--gold   { color: var(--ob-gold); }
.ob-hl--teal   { color: var(--ob-teal); }

/* ── Rarity pills ── */
.ob-rarities {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  margin-top: 14px;
  width: 100%;
}

.ob-pill {
  font-family: 'Poppins', sans-serif;
  font-size: .66rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 4px 11px;
  border-radius: 999px;
  border: 1px solid;
  white-space: nowrap;
}

.ob-pill--commune    { color: #97a3b0; border-color: rgba(151,163,176,.25); background: rgba(151,163,176,.07); }
.ob-pill--rare       { color: #5b9cf5; border-color: rgba(91,156,245,.3);   background: rgba(91,156,245,.07); }
.ob-pill--epique     { color: #b77aff; border-color: rgba(183,122,255,.3);  background: rgba(183,122,255,.07); }
.ob-pill--legendaire { color: #f4c942; border-color: rgba(244,201,66,.3);   background: rgba(244,201,66,.07); }
.ob-pill--champion   { color: #e74c3c; border-color: rgba(231,76,60,.35);   background: rgba(231,76,60,.08); }

/* ── Feature list (step 4) ── */
.ob-features {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
  margin-top: 6px;
}

.ob-feat {
  display: flex;
  align-items: center;
  gap: 12px;
  text-align: left;
  padding: 10px 14px;
  background: var(--ob-surface-2);
  border: 1px solid rgba(255, 255, 255, .04);
  border-radius: 12px;
  transition: border-color .2s;
}
.ob-feat:hover {
  border-color: rgba(145, 70, 255, .2);
}

.ob-feat-icon {
  font-size: 1.15rem;
  flex-shrink: 0;
  width: 24px;
  text-align: center;
}

.ob-feat div {
  min-width: 0;
}

.ob-feat strong {
  font-family: 'Poppins', sans-serif;
  font-size: .8rem;
  font-weight: 600;
  color: #fff;
  display: block;
  margin-bottom: 1px;
}

.ob-feat span {
  font-family: 'Poppins', sans-serif;
  font-size: .72rem;
  color: var(--ob-muted);
  line-height: 1.4;
  display: block;
}

/* ── Quick links (step 5) ── */
.ob-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 16px;
  width: 100%;
}

.ob-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--ob-surface-2);
  border: 1px solid rgba(255, 255, 255, .06);
  border-radius: 10px;
  font-family: 'Poppins', sans-serif;
  font-size: .78rem;
  font-weight: 500;
  color: var(--ob-text);
  text-decoration: none;
  transition: all .2s ease;
}
.ob-link:hover {
  background: rgba(145, 70, 255, .12);
  border-color: rgba(145, 70, 255, .25);
  color: #fff;
  transform: translateY(-1px);
}

.ob-link-icon {
  font-size: .9rem;
  flex-shrink: 0;
}

/* ═══ NAV BAR ═══ */
.ob-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px 16px;
  border-top: 1px solid rgba(255, 255, 255, .04);
  background: rgba(0, 0, 0, .2);
  flex-shrink: 0;
  gap: 16px;
}

/* Dots */
.ob-dots {
  display: flex;
  gap: 7px;
  flex-shrink: 0;
}

.ob-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .1);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all .3s ease;
}
.ob-dot.ob-dot--active {
  background: var(--ob-purple);
  box-shadow: 0 0 8px rgba(145, 70, 255, .5);
  transform: scale(1.3);
}
.ob-dot.ob-dot--done {
  background: rgba(145, 70, 255, .4);
}

/* Buttons */
.ob-btns {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.ob-btn {
  font-family: 'Poppins', sans-serif;
  font-size: .8rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 9px 16px;
  border-radius: 10px;
  border: none;
  cursor: pointer;
  transition: all .2s ease;
  white-space: nowrap;
}
.ob-btn svg { flex-shrink: 0; }

.ob-btn--prev {
  background: rgba(255, 255, 255, .05);
  color: var(--ob-muted);
  border: 1px solid rgba(255, 255, 255, .07);
}
.ob-btn--prev:hover:not(:disabled) {
  background: rgba(255, 255, 255, .09);
  color: #fff;
}
.ob-btn--prev:disabled {
  opacity: .25;
  cursor: not-allowed;
}

.ob-btn--next {
  background: var(--ob-purple);
  color: #fff;
}
.ob-btn--next:hover {
  background: #7c34e0;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(145, 70, 255, .35);
}

.ob-btn--finish {
  background: linear-gradient(135deg, var(--ob-gold) 0%, #e8a820 100%);
  color: #1a1200;
  font-weight: 700;
  padding: 9px 22px;
}
.ob-btn--finish:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 18px rgba(244, 201, 66, .4);
}

/* Skip */
.ob-skip {
  font-family: 'Poppins', sans-serif;
  font-size: .72rem;
  color: var(--ob-muted);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: color .2s, background .2s;
  opacity: .6;
  white-space: nowrap;
  flex-shrink: 0;
}
.ob-skip:hover {
  color: #fff;
  background: rgba(255, 255, 255, .05);
  opacity: 1;
}

/* ═══ HEADER INTEGRATION ═══ */

button.hdr__drop-item[data-open-onboarding] {
  width: 100%;
  text-align: left;
  background: none;
  cursor: pointer;
  border: none;
  padding: 8px 16px;
  color: inherit;
  font: inherit;
}
button.hdr__drop-item[data-open-onboarding]:hover {
  background: rgba(145, 70, 255, .08);
}
button.hdr__drop-item[data-open-onboarding] div {
  pointer-events: none;
}

button.hdr__drawer-link[data-open-onboarding] {
  width: 100%;
  text-align: left;
  background: none;
  cursor: pointer;
  border: none;
  padding: 10px 0;
  color: inherit;
  font: inherit;
  font-size: inherit;
}
button.hdr__drawer-link[data-open-onboarding]:hover {
  color: var(--ob-purple);
}

/* ═══ RESPONSIVE ═══ */

/* ── Tablette / petit desktop ── */
@media (max-width: 560px) {
  .ob {
    padding: 0;
  }

  .ob-modal {
    width: 100%;
    max-width: 100%;
    height: 100%;
    max-height: 100%;
    border-radius: 0;
    border: none;
  }

  .ob-steps {
    min-height: 0;
  }

  .ob-step {
    padding: 24px 20px 16px;
    justify-content: center;
  }

  .ob-visual {
    width: 64px;
    height: 64px;
    margin-bottom: 14px;
  }
  .ob-emoji { font-size: 1.9rem; }
  .ob-emoji--big { font-size: 2.3rem; }

  .ob-title { font-size: 1.15rem; }
  .ob-desc  { font-size: .84rem; }
  .ob-sub   { font-size: .76rem; }

  .ob-nav {
    padding: 12px 16px 14px;
  }

  .ob-skip {
    position: static;
    transform: none;
    margin: 0 auto;
    display: block;
    padding: 8px 16px;
  }

  .ob-links {
    flex-direction: column;
    align-items: stretch;
  }
  .ob-link {
    justify-content: center;
  }
}

/* ── Petit mobile ── */
@media (max-width: 380px) {
  .ob-step {
    padding: 20px 16px 12px;
  }

  .ob-title { font-size: 1.05rem; }
  .ob-desc  { font-size: .8rem; }
  .ob-pill  { font-size: .58rem; padding: 3px 8px; }
  .ob-btn   { font-size: .74rem; padding: 8px 12px; }

  .ob-feat {
    padding: 8px 10px;
    gap: 10px;
  }
  .ob-feat strong { font-size: .76rem; }
  .ob-feat span   { font-size: .68rem; }
}

/* ── Grand écran : modal plus aérée ── */
@media (min-height: 750px) and (min-width: 561px) {
  .ob-steps {
    min-height: 360px;
  }
  .ob-step {
    padding: 36px 32px 24px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ob, .ob-modal, .ob-step, .ob-visual, .ob-dot, .ob-btn {
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
  }
}

button.hdr__drawer-link[data-open-onboarding] {
  width: 100%;
  text-align: left;
  background: none;
  cursor: pointer;
  border: none;
  padding: 10px 0;
  padding-left: 0;
  margin: 0;
  color: inherit;
  font: inherit;
  font-size: inherit;
  line-height: inherit;
  display: block;
}