/**
 * HoplaCollect — Milestones (Paliers) Public Section
 * Professional milestone timeline with progress bar
 * Theme-proof with !important and high specificity
 */

/* ===== Reset ===== */
.hc-ms *,
.hc-ms *::before,
.hc-ms *::after {
  box-sizing: border-box !important;
}

/* ===== Container ===== */
.hc-ms {
  position: relative !important;
  margin: 2rem 0 !important;
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
  box-shadow: none !important;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  color: #374151 !important;
  line-height: 1.6 !important;
  -webkit-font-smoothing: antialiased !important;
}

/* ===== Header ===== */
.hc-ms .hc-ms-header {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  padding: 0 0 1.25rem !important;
  background: none !important;
  border-bottom: none !important;
}

.hc-ms .hc-ms-header-left {
  display: flex !important;
  align-items: flex-start !important;
  gap: 1rem !important;
  flex: 1 !important;
  min-width: 0 !important;
}

.hc-ms .hc-ms-header-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 10px !important;
  background: #fef3c7 !important;
  color: #d97706 !important;
  flex-shrink: 0 !important;
}

.hc-ms .hc-ms-header-icon svg {
  width: 20px !important;
  height: 20px !important;
  stroke: #d97706 !important;
  fill: none !important;
}

.hc-ms .hc-ms-header-text {
  flex: 1 !important;
  min-width: 0 !important;
}

.hc-ms .hc-ms-header-text h3 {
  font-size: 1.125rem !important;
  font-weight: 700 !important;
  color: #1f2937 !important;
  margin: 0 0 0.25rem !important;
  padding: 0 !important;
  line-height: 1.3 !important;
  border: none !important;
  background: none !important;
  letter-spacing: -0.01em !important;
}

.hc-ms .hc-ms-header-text p {
  font-size: 0.8125rem !important;
  color: #9ca3af !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.5 !important;
  font-weight: 400 !important;
}

/* ===== Global Progress Bar ===== */
.hc-ms .hc-ms-progress {
  padding: 1.25rem 1.5rem 1rem !important;
  margin: 0 !important;
}

.hc-ms .hc-ms-progress-track {
  position: relative !important;
  height: 10px !important;
  background: #f3f4f6 !important;
  border-radius: 999px !important;
  overflow: visible !important;
  margin-bottom: 1.75rem !important;
}

.hc-ms .hc-ms-progress-fill {
  height: 100% !important;
  border-radius: 999px !important;
  background: #3b82f6 !important;
  transition: width 1.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative !important;
  z-index: 1 !important;
}

/* Shine animation on progress fill */
.hc-ms .hc-ms-progress-fill::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent) !important;
  border-radius: inherit !important;
  animation: hc-ms-shine 2s ease-in-out infinite !important;
}

@keyframes hc-ms-shine {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(200%); }
}

/* Markers on the progress bar */
.hc-ms .hc-ms-marker {
  position: absolute !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  z-index: 2 !important;
}

.hc-ms .hc-ms-marker-dot {
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  border: 3px solid #d1d5db !important;
  background: #fff !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.hc-ms .hc-ms-marker--completed .hc-ms-marker-dot,
.hc-ms .hc-ms-marker--unlocked .hc-ms-marker-dot {
  background: var(--hc-ms-color, #32bddd) !important;
  border-color: var(--hc-ms-color, #32bddd) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--hc-ms-color, #32bddd) 20%, transparent), 0 1px 3px rgba(0,0,0,0.1) !important;
}

.hc-ms .hc-ms-marker-label {
  position: absolute !important;
  top: calc(100% + 6px) !important;
  white-space: nowrap !important;
  font-size: 0.6875rem !important;
  font-weight: 600 !important;
  color: #9ca3af !important;
  letter-spacing: -0.01em !important;
}

.hc-ms .hc-ms-progress-legend {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  font-size: 0.8125rem !important;
  margin: 0 !important;
  padding: 0 !important;
}

.hc-ms .hc-ms-progress-current {
  font-weight: 700 !important;
  font-size: 0.9375rem !important;
  color: #3b82f6 !important;
}

.hc-ms .hc-ms-progress-max {
  color: #9ca3af !important;
  font-weight: 500 !important;
  font-size: 0.8125rem !important;
}

/* ===== Timeline Rows Container ===== */
.hc-ms .hc-ms-rows {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  padding: 0 !important;
  margin: 0 !important;
  position: relative !important;
}

/* ===== Timeline Connector (spacer + dot + line segments) ===== */
.hc-ms .hc-ms-tl-connector {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding: 0 calc(50% + 0.375rem) 0 0 !important;
  margin: 0 !important;
  position: relative !important;
  z-index: 2 !important;
}

.hc-ms .hc-ms-tl-connector::before,
.hc-ms .hc-ms-tl-connector::after {
  content: '' !important;
  display: block !important;
  width: 2px !important;
  height: 16px !important;
  background: #e5e7eb !important;
}

.hc-ms .hc-ms-tl-dot {
  display: block !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  background: #d1d5db !important;
  border: 2px solid #e5e7eb !important;
  flex-shrink: 0 !important;
}

/* ===== Individual Row (horizontal layout: card + sidebar) ===== */
.hc-ms .hc-ms-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 0.75rem !important;
  margin-bottom: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  background: none !important;
  overflow: visible !important;
  animation: hc-ms-row-in 0.5s ease both !important;
  transition: none !important;
  position: relative !important;
  z-index: 1 !important;
}

/* Vertical timeline line through each milestone row (not goal/tier0) */
.hc-ms .hc-ms-row:not(.hc-ms-row--goal):not(.hc-ms-row--tier0)::before {
  content: '' !important;
  position: absolute !important;
  left: calc((100% - 0.75rem) / 4) !important;
  transform: translateX(-50%) !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 2px !important;
  background: #e5e7eb !important;
  pointer-events: none !important;
  z-index: -1 !important;
}

/* Completed rows: full campaign color line */
.hc-ms .hc-ms-row--completed:not(.hc-ms-row--goal):not(.hc-ms-row--tier0)::before {
  background: var(--hc-ms-color, #32bddd) !important;
}

/* Unlocked row: faded campaign color line */
.hc-ms .hc-ms-row--unlocked:not(.hc-ms-row--goal):not(.hc-ms-row--tier0)::before {
  background: color-mix(in srgb, var(--hc-ms-color, #32bddd) 40%, #e5e7eb) !important;
}
/* Goal row: full-height line connecting top connector to bottom connector */
.hc-ms .hc-ms-row--goal::before {
  content: '' !important;
  position: absolute !important;
  left: calc((100% - 0.75rem) / 4) !important;
  transform: translateX(-50%) !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 2px !important;
  background: #e5e7eb !important;
  pointer-events: none !important;
  z-index: -1 !important;
}

/* Goal row completed: full color */
.hc-ms .hc-ms-row--goal.hc-ms-row--completed::before {
  background: var(--hc-ms-color, #32bddd) !important;
}

/* ===== Timeline connector coloring ===== */

/* --- Connector after completed row --- */
/* ::before (from completed) = full color */
.hc-ms .hc-ms-row--completed + .hc-ms-tl-connector::before {
  background: var(--hc-ms-color, #32bddd) !important;
}
/* dot = full color */
.hc-ms .hc-ms-row--completed + .hc-ms-tl-connector .hc-ms-tl-dot {
  background: var(--hc-ms-color, #32bddd) !important;
  border-color: var(--hc-ms-color, #32bddd) !important;
}
/* ::after = full color ONLY if next row is also completed (or completed goal) */
.hc-ms .hc-ms-row--completed + .hc-ms-tl-connector:has(+ .hc-ms-row--completed)::after {
  background: var(--hc-ms-color, #32bddd) !important;
}

/* --- Connector between unlocked (above) and completed (below) --- */
/* ::before (from unlocked toward dot) = faded */
.hc-ms .hc-ms-row--unlocked + .hc-ms-tl-connector:has(+ .hc-ms-row--completed)::before {
  background: color-mix(in srgb, var(--hc-ms-color, #32bddd) 40%, #e5e7eb) !important;
}
/* dot = campaign color */
.hc-ms .hc-ms-row--unlocked + .hc-ms-tl-connector:has(+ .hc-ms-row--completed) .hc-ms-tl-dot {
  background: var(--hc-ms-color, #32bddd) !important;
  border-color: var(--hc-ms-color, #32bddd) !important;
}
/* ::after (from dot toward completed) = full color */
.hc-ms .hc-ms-row--unlocked + .hc-ms-tl-connector:has(+ .hc-ms-row--completed)::after {
  background: var(--hc-ms-color, #32bddd) !important;
}

/* --- Connector above unlocked (from waiting): stays neutral gray (no override) --- */

/* --- Connector below goal row (completed goal) — all full color --- */
.hc-ms .hc-ms-row--goal.hc-ms-row--completed + .hc-ms-tl-connector::before,
.hc-ms .hc-ms-row--goal.hc-ms-row--completed + .hc-ms-tl-connector::after {
  background: var(--hc-ms-color, #32bddd) !important;
}
.hc-ms .hc-ms-row--goal.hc-ms-row--completed + .hc-ms-tl-connector .hc-ms-tl-dot {
  background: var(--hc-ms-color, #32bddd) !important;
  border-color: var(--hc-ms-color, #32bddd) !important;
}

/* --- Connector below goal row (unlocked / not yet reached) --- */
/* ::after (bottom, below dot): full campaign color */
.hc-ms .hc-ms-row--goal.hc-ms-row--unlocked + .hc-ms-tl-connector::after {
  background: var(--hc-ms-color, #32bddd) !important;
}
/* dot: campaign color */
.hc-ms .hc-ms-row--goal.hc-ms-row--unlocked + .hc-ms-tl-connector .hc-ms-tl-dot {
  background: var(--hc-ms-color, #32bddd) !important;
  border-color: var(--hc-ms-color, #32bddd) !important;
}
/* ::before (top, toward goal box): faded */
.hc-ms .hc-ms-row--goal.hc-ms-row--unlocked + .hc-ms-tl-connector::before {
  background: color-mix(in srgb, var(--hc-ms-color, #32bddd) 40%, #e5e7eb) !important;
}

.hc-ms .hc-ms-row:last-child {
  margin-bottom: 0 !important;
}

@keyframes hc-ms-row-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ===== Row status styles (monochrome: primary for completed + unlocked) ===== */
.hc-ms .hc-ms-row--completed .hc-ms-row-left,
.hc-ms .hc-ms-row--unlocked .hc-ms-row-left {
  border-color: color-mix(in srgb, var(--hc-ms-color, #32bddd) 25%, #fff) !important;
  background: color-mix(in srgb, var(--hc-ms-color, #32bddd) 8%, #fff) !important;
  box-shadow: 0 1px 3px color-mix(in srgb, var(--hc-ms-color, #32bddd) 8%, transparent) !important;
}

.hc-ms .hc-ms-row--waiting .hc-ms-row-left {
  background: #ffffff !important;
  border-color: #e5e7eb !important;
  box-shadow: none !important;
}

.hc-ms .hc-ms-row--waiting .hc-ms-row-amount {
  color: #1f2937 !important;
}

.hc-ms .hc-ms-row--waiting .hc-ms-row-bar-pct {
  color: #6b7280 !important;
}

.hc-ms .hc-ms-row--waiting .hc-ms-row-bar-fill {
  background: var(--hc-ms-waiting-color, #6b7280) !important;
}

.hc-ms .hc-ms-row--waiting .hc-ms-row-desc {
  color: #6b7280 !important;
}

/* ===== Left Section: Progress + Info (the actual card) ===== */
.hc-ms .hc-ms-row-left {
  flex: 1 !important;
  min-width: 0 !important;
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 12px !important;
  padding: 1.25rem !important;
  overflow: hidden !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

/* ===== Row Progress Bar ===== */
.hc-ms .hc-ms-row-bar {
  display: flex !important;
  align-items: center !important;
  gap: 0.625rem !important;
  margin-bottom: 0.875rem !important;
}

.hc-ms .hc-ms-row-bar-track {
  flex: 1 !important;
  height: 8px !important;
  background: #f3f4f6 !important;
  border-radius: 999px !important;
  overflow: hidden !important;
}

.hc-ms .hc-ms-row-bar-fill {
  height: 100% !important;
  border-radius: 999px !important;
  background: var(--hc-ms-color, #32bddd) !important;
  transition: width 1s ease-out !important;
}

.hc-ms .hc-ms-row--completed .hc-ms-row-bar-fill {
  background: var(--hc-ms-color, #32bddd) !important;
}

.hc-ms .hc-ms-row-bar-pct {
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  color: #6b7280 !important;
  min-width: 2.5rem !important;
  text-align: right !important;
  white-space: nowrap !important;
}

.hc-ms .hc-ms-row--completed .hc-ms-row-bar-pct {
  color: var(--hc-ms-color, #32bddd) !important;
}

/* ===== Row Meta (badge + amount) ===== */
.hc-ms .hc-ms-row-meta {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 0.5rem !important;
  flex-wrap: wrap !important;
  gap: 0.5rem !important;
}

.hc-ms .hc-ms-row-amount {
  font-size: 1.125rem !important;
  font-weight: 800 !important;
  color: #1f2937 !important;
  letter-spacing: -0.02em !important;
  line-height: 1 !important;
}

/* ===== Badge group (keeps badges side by side) ===== */
.hc-ms .hc-ms-badges-group {
  display: flex !important;
  align-items: center !important;
  gap: 0.375rem !important;
  flex-wrap: wrap !important;
}

/* ===== Badges ===== */
.hc-ms .hc-ms-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.3125rem !important;
  padding: 0.25rem 0.625rem !important;
  border-radius: 999px !important;
  font-size: 0.6875rem !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  letter-spacing: 0.01em !important;
  text-transform: none !important;
  white-space: nowrap !important;
  border: 1px solid transparent !important;
  background: none !important;
}

.hc-ms .hc-ms-badge-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 12px !important;
  height: 12px !important;
  flex-shrink: 0 !important;
}

.hc-ms .hc-ms-badge-icon svg {
  width: 12px !important;
  height: 12px !important;
  stroke: currentColor !important;
  fill: none !important;
}

.hc-ms .hc-ms-badge--completed,
.hc-ms .hc-ms-badge--unlocked {
  background: color-mix(in srgb, var(--hc-ms-color, #32bddd) 12%, #fff) !important;
  color: var(--hc-ms-color, #32bddd) !important;
  border-color: color-mix(in srgb, var(--hc-ms-color, #32bddd) 30%, #fff) !important;
}

.hc-ms .hc-ms-badge--waiting {
  background: color-mix(in srgb, var(--hc-ms-waiting-color, #6b7280) 10%, #fff) !important;
  color: var(--hc-ms-waiting-color, #6b7280) !important;
  border-color: color-mix(in srgb, var(--hc-ms-waiting-color, #6b7280) 25%, #fff) !important;
}

.hc-ms .hc-ms-badge--surprise {
  background: linear-gradient(135deg, #fef3c7, #fde68a) !important;
  color: #92400e !important;
  border-color: #fbbf24 !important;
  animation: hc-ms-surprise-pulse 2s ease-in-out infinite !important;
}

@keyframes hc-ms-surprise-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(251, 191, 36, 0.3); }
  50% { box-shadow: 0 0 0 4px rgba(251, 191, 36, 0); }
}

/* ===== Row Info (avatar + content side by side) ===== */
.hc-ms .hc-ms-row-info {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.875rem !important;
}

.hc-ms .hc-ms-row-content {
  flex: 1 !important;
  min-width: 0 !important;
}

/* ===== Row Avatar (circular image) ===== */
.hc-ms .hc-ms-row-avatar {
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  overflow: hidden !important;
  background: #f3f4f6 !important;
  flex-shrink: 0 !important;
  border: 2px solid #e5e7eb !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08) !important;
}

.hc-ms .hc-ms-row--completed .hc-ms-row-avatar,
.hc-ms .hc-ms-row--unlocked .hc-ms-row-avatar {
  border-color: color-mix(in srgb, var(--hc-ms-color, #32bddd) 40%, #fff) !important;
}

.hc-ms .hc-ms-row-avatar img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 50% !important;
}

/* ===== Row Title & Description ===== */
.hc-ms .hc-ms-row-title {
  margin: 0 0 0.25rem !important;
  padding: 0 !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #1f2937 !important;
  line-height: 1.35 !important;
  border: none !important;
  background: none !important;
  letter-spacing: -0.01em !important;
}

.hc-ms .hc-ms-row-desc {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0.8125rem !important;
  color: #6b7280 !important;
  line-height: 1.55 !important;
  font-weight: 400 !important;
}

/* ===== Right Section: Details sidebar (Rewards + Evolutions) ===== */
.hc-ms .hc-ms-row-right {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
  min-width: 0 !important;
  border-top: none !important;
}

.hc-ms .hc-ms-row-details {
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.75rem !important;
  overflow: visible !important;
}

/* Empty state */
.hc-ms .hc-ms-row-details--empty {
  justify-content: center !important;
  align-items: center !important;
  gap: 0.5rem !important;
  padding: 1.5rem 1rem !important;
  background: #fafafa !important;
  border: 1px dashed #e5e7eb !important;
  border-radius: 0 !important;
}

.hc-ms .hc-ms-row-details--empty svg {
  stroke: #d1d5db !important;
  fill: none !important;
}

.hc-ms .hc-ms-detail-empty {
  font-size: 0.75rem !important;
  color: #9ca3af !important;
  font-weight: 500 !important;
  font-style: italic !important;
}

/* ===== Evolution Block (theme-proof mirror of hc-rewards.css) ===== */
.hc-ms .hc-product-evo-block {
  margin-top: 0 !important;
  padding: 14px !important;
  background: var(--hc-surface, #ffffff) !important;
  border-radius: 0 !important;
  border: 1px solid hsl(0, 0%, 83%) !important;
  border-top: 3px solid hsl(0, 0%, 55%) !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .04) !important;
}

.hc-ms .hc-product-evo-block-title {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  color: var(--hc-product-evolving, #15803d) !important;
  margin-bottom: 4px !important;
}

.hc-ms .hc-product-evo-block-title svg {
  flex-shrink: 0 !important;
  stroke: var(--hc-product-evolving, #15803d) !important;
}

.hc-ms .hc-product-evo-block-intro {
  font-size: 0.72rem !important;
  color: #6b7280 !important;
  margin: 0 0 10px !important;
  line-height: 1.4 !important;
}

.hc-ms .hc-product-evo-block-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.hc-ms .hc-product-evo-block-item {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  padding: 10px 12px !important;
  border-radius: 0 !important;
  border: 1px solid var(--hc-border, #e5e7eb) !important;
  transition: background .15s ease !important;
}

.hc-ms .hc-product-evo-block-item.hc-evo-done {
  background: color-mix(in srgb, var(--hc-product-evolving, #15803d) 5%, transparent) !important;
}

.hc-ms .hc-product-evo-block-item.hc-evo-pending {
  background: color-mix(in srgb, var(--hc-product-evolving, #15803d) 8%, transparent) !important;
}

.hc-ms .hc-evo-item-line1 {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.hc-ms .hc-evo-item-icon {
  width: 24px !important;
  height: 24px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.hc-ms .hc-evo-done .hc-evo-item-icon {
  background: var(--hc-product-evolving, #15803d) !important;
}

.hc-ms .hc-evo-done .hc-evo-item-icon svg {
  stroke: #fff !important;
}

.hc-ms .hc-evo-pending .hc-evo-item-icon {
  background: color-mix(in srgb, var(--hc-product-evolving, #15803d) 25%, transparent) !important;
}

.hc-ms .hc-evo-pending .hc-evo-item-icon svg {
  stroke: var(--hc-product-evolving, #15803d) !important;
}

.hc-ms .hc-evo-item-text {
  font-size: 0.82rem !important;
  color: #1f2937 !important;
  line-height: 1.35 !important;
}

.hc-ms .hc-evo-item-state-ok {
  color: var(--hc-product-evolving, #15803d) !important;
  font-weight: 600 !important;
}

.hc-ms .hc-evo-item-state-locked {
  color: color-mix(in srgb, var(--hc-product-evolving, #15803d) 60%, #6b7280) !important;
  font-weight: 600 !important;
}

.hc-ms .hc-evo-item-line2 {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 0.78rem !important;
  color: #4b5563 !important;
  line-height: 1.4 !important;
  padding-left: 32px !important;
}

.hc-ms .hc-evo-item-ms-img {
  width: 32px !important;
  height: 32px !important;
  flex-shrink: 0 !important;
  border-radius: 4px !important;
  overflow: hidden !important;
}

.hc-ms .hc-evo-item-ms-img img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
}

.hc-ms .hc-evo-item-line3 {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  padding-left: 32px !important;
  font-size: 0.78rem !important;
  color: #4b5563 !important;
  line-height: 1.45 !important;
}

.hc-ms .hc-evo-item-brings {
  font-weight: 600 !important;
  font-size: 0.72rem !important;
  color: #6b7280 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em !important;
}

.hc-ms .hc-evo-item-desc p {
  margin: 0 !important;
}

.hc-ms .hc-evo-item-price {
  font-weight: 700 !important;
  color: var(--hc-product-evolving, #15803d) !important;
  font-size: 0.78rem !important;
}

.hc-ms .hc-product-evo-ms-link {
  color: inherit !important;
  text-decoration: underline !important;
  text-decoration-style: dotted !important;
  text-underline-offset: 2px !important;
}

.hc-ms .hc-product-evo-ms-link:hover {
  color: var(--hc-primary, #7c3aed) !important;
}

/* ===== Unlock Card (theme-proof mirror of hc-rewards.css) ===== */
.hc-ms .hc-product-unlock-card {
  padding: 14px !important;
  border-radius: 0 !important;
  border: 1px solid var(--hc-border, #e5e7eb) !important;
  border-top: 3px solid !important;
  background: var(--hc-surface, #ffffff) !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .04) !important;
}

.hc-ms .hc-product-unlock-card.hc-unlock-locked,
.hc-ms .hc-product-unlock-card.hc-unlock-reached {
  border-top-color: hsl(0, 0%, 55%) !important;
}

.hc-ms .hc-product-unlock-line1 {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 10px !important;
}

.hc-ms .hc-product-unlock-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.hc-ms .hc-unlock-locked .hc-product-unlock-icon,
.hc-ms .hc-unlock-reached .hc-product-unlock-icon {
  background: rgba(107, 114, 128, .15) !important;
}

.hc-ms .hc-unlock-locked .hc-product-unlock-icon svg,
.hc-ms .hc-unlock-reached .hc-product-unlock-icon svg {
  stroke: #6b7280 !important;
}

.hc-ms .hc-product-unlock-text {
  font-size: 0.85rem !important;
  color: #1f2937 !important;
  line-height: 1.3 !important;
}

.hc-ms .hc-product-unlock-name {
  font-weight: 600 !important;
}

.hc-ms .hc-product-unlock-state {
  font-weight: 400 !important;
}

.hc-ms .hc-unlock-locked .hc-product-unlock-state,
.hc-ms .hc-unlock-reached .hc-product-unlock-state {
  color: #6b7280 !important;
}

.hc-ms .hc-product-unlock-line2-label {
  font-size: 0.78rem !important;
  color: #6b7280 !important;
  line-height: 1.4 !important;
  margin-bottom: 8px !important;
  font-style: italic !important;
}

.hc-ms .hc-product-unlock-line2 {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

/* ===== Grouped unlock list (multiple miniatures in one card) ===== */
.hc-ms .hc-product-unlock-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 2px !important;
}

.hc-ms .hc-product-unlock-list .hc-product-mini {
  max-width: 100% !important;
}

.hc-ms .hc-product-unlock-image {
  width: 40px !important;
  height: 40px !important;
  flex-shrink: 0 !important;
  border-radius: 6px !important;
  overflow: hidden !important;
}

.hc-ms .hc-product-unlock-image img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
}

.hc-ms .hc-product-unlock-msg {
  flex: 1 !important;
  min-width: 0 !important;
}

.hc-ms .hc-product-unlock-ms-name {
  font-weight: 600 !important;
  color: #1f2937 !important;
  text-decoration: underline !important;
  text-decoration-style: dotted !important;
  text-underline-offset: 2px !important;
  cursor: pointer !important;
}

.hc-ms .hc-product-unlock-ms-name:hover {
  color: var(--hc-primary, #7c3aed) !important;
}

/* ===== Gift Card label (theme-proof) ===== */
.hc-ms .hc-product-gift-line2-label {
  font-size: 0.78rem !important;
  color: #6b7280 !important;
  line-height: 1.4 !important;
  margin-bottom: 6px !important;
  margin-top: 10px !important;
  font-style: italic !important;
}
.hc-ms .hc-product-gift-line2-label:first-of-type {
  margin-top: 0 !important;
}
.hc-ms .hc-product-gift-line2--sources {
  flex-direction: column !important;
  align-items: stretch !important;
}

/* ===== Empty State ===== */
.hc-ms .hc-ms-empty {
  text-align: center !important;
  padding: 3rem 1.5rem !important;
}

.hc-ms .hc-ms-empty svg {
  color: #d1d5db !important;
  stroke: #d1d5db !important;
  margin: 0 auto 1rem !important;
  display: block !important;
}

.hc-ms .hc-ms-empty p {
  font-size: 1.0625rem !important;
  font-weight: 600 !important;
  color: #6b7280 !important;
  margin: 0 0 0.375rem !important;
  line-height: 1.4 !important;
}

.hc-ms .hc-ms-empty span {
  font-size: 0.875rem !important;
  color: #9ca3af !important;
  font-weight: 400 !important;
}

/* ===== Confetti Canvas ===== */
.hc-ms .hc-milestones-confetti-canvas {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
  z-index: 10 !important;
}

/* ===== Responsive — Tablet ===== */
@media (max-width: 768px) {
  .hc-ms {
    margin: 1.25rem 0 !important;
    border-radius: 8px !important;
  }

  .hc-ms .hc-ms-header {
    padding: 1.25rem !important;
    gap: 0.75rem !important;
  }

  .hc-ms .hc-ms-header-icon {
    width: 38px !important;
    height: 38px !important;
    border-radius: 8px !important;
  }

  .hc-ms .hc-ms-header-icon svg {
    width: 18px !important;
    height: 18px !important;
  }

  .hc-ms .hc-ms-header-text h3 {
    font-size: 1rem !important;
  }

  .hc-ms .hc-ms-progress {
    padding: 1rem 1.25rem 0.75rem !important;
  }

  /* Stack vertically on tablet */
  .hc-ms .hc-ms-row {
    flex-direction: column !important;
    gap: 0 !important;
  }

  .hc-ms .hc-ms-tl-connector {
    padding-right: 0 !important;
  }

  /* Hide per-row timeline lines on tablet (vertical stacking) */
  .hc-ms .hc-ms-row::before {
    display: none !important;
  }

  .hc-ms .hc-ms-row-left {
    padding: 1rem !important;
    border-radius: 12px 12px 0 0 !important;
  }

  .hc-ms .hc-ms-row-right {
    flex: none !important;
    width: 100% !important;
    border-top: 1px solid #f3f4f6 !important;
  }

  .hc-ms .hc-ms-row-amount {
    font-size: 1rem !important;
  }

  .hc-ms .hc-ms-marker-label {
    font-size: 0.625rem !important;
  }
}

/* ===== Responsive — Mobile ===== */
@media (max-width: 640px) {
  .hc-ms .hc-ms-header {
    padding: 1rem !important;
  }

  .hc-ms .hc-ms-header-left {
    gap: 0.75rem !important;
  }

  .hc-ms .hc-ms-header-icon {
    width: 34px !important;
    height: 34px !important;
  }

  .hc-ms .hc-ms-header-icon svg {
    width: 16px !important;
    height: 16px !important;
  }

  .hc-ms .hc-ms-header-text h3 {
    font-size: 0.9375rem !important;
  }

  .hc-ms .hc-ms-header-text p {
    font-size: 0.75rem !important;
  }

  .hc-ms .hc-ms-progress {
    padding: 0.75rem 1rem 0.5rem !important;
  }

  .hc-ms .hc-ms-progress-track {
    height: 8px !important;
    margin-bottom: 1.5rem !important;
  }

  .hc-ms .hc-ms-marker-dot {
    width: 14px !important;
    height: 14px !important;
    border-width: 2px !important;
  }

  .hc-ms .hc-ms-marker-label {
    font-size: 0.5625rem !important;
  }

  .hc-ms .hc-ms-rows {
    padding: 0 0.75rem 1rem !important;
  }

  .hc-ms .hc-ms-row-left {
    padding: 0.875rem !important;
    border-radius: 8px 8px 0 0 !important;
  }

  .hc-ms .hc-ms-row-details {
    padding: 0.75rem !important;
  }

  .hc-ms .hc-ms-tl-connector::before,
  .hc-ms .hc-ms-tl-connector::after {
    height: 12px !important;
  }

  .hc-ms .hc-ms-tl-dot {
    width: 8px !important;
    height: 8px !important;
  }


  .hc-ms .hc-ms-row-meta {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0.375rem !important;
  }

  .hc-ms .hc-ms-row-amount {
    font-size: 1rem !important;
  }

  .hc-ms .hc-ms-row-title {
    font-size: 0.9375rem !important;
  }

  .hc-ms .hc-ms-row-desc {
    font-size: 0.75rem !important;
  }

  .hc-ms .hc-ms-row-avatar {
    width: 44px !important;
    height: 44px !important;
  }

  .hc-ms .hc-ms-row-info {
    gap: 0.625rem !important;
  }

  .hc-ms .hc-ms-empty {
    padding: 2rem 1rem !important;
  }

  .hc-ms .hc-ms-empty p {
    font-size: 0.9375rem !important;
  }

  .hc-ms .hc-ms-empty span {
    font-size: 0.8125rem !important;
  }
}
