/**
 * ImpactMojo Tour Theme — Custom Intro.js Overrides
 * Uses site CSS variables for automatic light/dark theme support.
 */

/* Overlay */
.introjs-overlay {
  background: rgba(15, 23, 42, 0.65) !important;
  backdrop-filter: blur(2px);
}

/* Tooltip container */
.introjs-tooltip {
  background: var(--card-bg, #fff) !important;
  color: var(--text-primary, #0F172A) !important;
  border: 1px solid var(--border-color, #E2E8F0) !important;
  border-radius: 16px !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(14, 165, 233, 0.1) !important;
  padding: 0 !important;
  max-width: 380px !important;
  min-width: 300px !important;
  font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
  overflow: hidden;
}

/* Tooltip header area (the text content) */
.introjs-tooltiptext {
  padding: 24px 24px 16px !important;
  font-size: 14.5px !important;
  line-height: 1.65 !important;
  color: var(--text-secondary, #475569) !important;
}

.introjs-tooltiptext strong {
  display: block;
  font-size: 17px;
  font-weight: 700;
  color: var(--text-primary, #0F172A) !important;
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}

/* Progress bar */
.introjs-progressbar {
  background: var(--border-color, #E2E8F0) !important;
  height: 3px !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

.introjs-progress {
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  overflow: hidden;
}

.introjs-progressbar > div,
.introjs-progressbar .introjs-progress {
  background: linear-gradient(90deg, #0EA5E9, #06B6D4) !important;
  height: 3px !important;
  border-radius: 0 !important;
  transition: width 0.4s ease !important;
}

/* Button area */
.introjs-tooltipbuttons {
  padding: 12px 24px 20px !important;
  border-top: none !important;
  display: flex !important;
  justify-content: space-between !important;
  gap: 8px !important;
  background: transparent !important;
}

/* All buttons base */
.introjs-button {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  border-radius: 10px !important;
  padding: 9px 20px !important;
  border: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-shadow: none !important;
  box-shadow: none !important;
  letter-spacing: 0.01em;
  line-height: 1.2 !important;
}

.introjs-button:focus {
  outline: 2px solid #0EA5E9 !important;
  outline-offset: 2px !important;
  box-shadow: none !important;
}

/* Next / Done button — accent */
.introjs-nextbutton,
.introjs-donebutton {
  background: linear-gradient(135deg, #0EA5E9, #0284C7) !important;
  color: #fff !important;
}

.introjs-nextbutton:hover,
.introjs-donebutton:hover {
  background: linear-gradient(135deg, #0284C7, #0369A1) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(14, 165, 233, 0.35) !important;
}

/* Back button — subtle */
.introjs-prevbutton {
  background: var(--hover-bg, #F1F5F9) !important;
  color: var(--text-secondary, #475569) !important;
}

.introjs-prevbutton:hover {
  background: var(--border-color, #E2E8F0) !important;
  color: var(--text-primary, #0F172A) !important;
}

/* Skip button — minimal */
.introjs-skipbutton {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  font-size: 18px !important;
  line-height: 28px !important;
  text-align: center !important;
  color: var(--text-muted, #94A3B8) !important;
  background: transparent !important;
  border-radius: 50% !important;
  opacity: 1 !important;
  transition: all 0.2s ease !important;
}

.introjs-skipbutton:hover {
  background: var(--hover-bg, #F1F5F9) !important;
  color: var(--text-primary, #0F172A) !important;
}

/* Arrow (the tooltip pointer) */
.introjs-arrow {
  border-color: transparent !important;
}

.introjs-arrow.top {
  border-bottom-color: var(--card-bg, #fff) !important;
  top: -10px !important;
}

.introjs-arrow.bottom {
  border-top-color: var(--card-bg, #fff) !important;
  bottom: -10px !important;
}

.introjs-arrow.left {
  border-right-color: var(--card-bg, #fff) !important;
  left: -10px !important;
}

.introjs-arrow.right {
  border-left-color: var(--card-bg, #fff) !important;
  right: -10px !important;
}

/* Highlighted element ring */
.introjs-helperLayer {
  border-radius: 12px !important;
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.3), 0 0 0 5000px rgba(15, 23, 42, 0.65) !important;
  transition: all 0.35s ease !important;
}

/* Step numbers — hidden in favor of progress bar */
.introjs-helperNumberLayer {
  display: none !important;
}

/* Disabled buttons */
.introjs-disabled {
  opacity: 0.4 !important;
  pointer-events: none !important;
}

/* ── Tour dropdown helper ──────────────────────────────────────────
   When the tour highlights an item inside a dropdown menu,
   .tour-dropdown-open is added to the parent <li.has-dropdown>.
   This forces the dropdown visible so Intro.js can target it. */

.tour-dropdown-open > .dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
  pointer-events: auto !important;
  margin-top: 0.25rem !important;
  z-index: 10000001 !important;
}

/* Override any old tour-blocking CSS */
body.introjs-active-tour .tour-dropdown-open > .dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
}

/* Ensure dropdown items targeted by Intro.js stay above the overlay */
.introjs-showElement {
  z-index: 10000000 !important;
}

.introjs-showElement .dropdown-menu {
  z-index: 10000001 !important;
}

/* Mobile adjustments */
@media (max-width: 600px) {
  .introjs-tooltip {
    max-width: 92vw !important;
    min-width: unset !important;
    border-radius: 14px !important;
    margin: 8px !important;
  }

  .introjs-tooltiptext {
    padding: 20px 20px 12px !important;
    font-size: 14px !important;
  }

  .introjs-tooltiptext strong {
    font-size: 16px;
  }

  .introjs-tooltipbuttons {
    padding: 10px 20px 16px !important;
  }

  .introjs-button {
    padding: 10px 16px !important;
    font-size: 13px !important;
  }
}
