/* ===== Mastery Path ===== */

.mp-page {
  max-width: 800px;
  margin: 0 auto;
}

/* Next recommended card */
.mp-next-card {
  margin-bottom: var(--space-xl);
  border-left: 4px solid var(--color-secondary);
}

/* Path card */
.mp-path-card {
  margin-bottom: var(--space-xl);
}

.mp-path-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-md);
}

.mp-path-stats {
  text-align: right;
  flex-shrink: 0;
}

.mp-path-pct {
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--color-primary);
  font-family: var(--font-display);
}

/* Progress bar */
.mp-progress-bar {
  height: 10px;
  background: var(--color-border);
  border-radius: var(--radius-full);
  overflow: hidden;
  margin-bottom: var(--space-lg);
}

.mp-progress-fill {
  height: 100%;
  background: var(--gradient-pink);
  border-radius: var(--radius-full);
  transition: width 0.5s ease;
}

/* Gate list */
.mp-gates {
  position: relative;
}

.mp-gate {
  display: flex;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  position: relative;
}

.mp-gate-content {
  flex: 1;
  padding: var(--space-md);
  background: var(--color-bg-alt);
  border-radius: var(--radius-md);
  border: 2px solid var(--color-border);
  transition: all var(--transition-fast);
}

.mp-gate-completed .mp-gate-content {
  border-color: var(--color-success-light);
  background: var(--color-success-light);
}

.mp-gate-unlocked .mp-gate-content {
  border-color: var(--color-secondary-light);
}

.mp-gate-locked .mp-gate-content {
  opacity: 0.7;
}

.mp-gate-header {
  margin-bottom: var(--space-xs);
}

.mp-gate-icon {
  font-size: 1.2rem;
}

.mp-gate-title {
  font-weight: 700;
  font-size: var(--text-sm);
}

.mp-gate-badge {
  font-size: 10px;
  padding: 1px 8px;
  border-radius: var(--radius-full);
  font-weight: 700;
}

.mp-badge-completed {
  background: var(--color-success-light);
  color: var(--color-success-dark);
}

.mp-badge-unlocked {
  background: var(--color-secondary-light);
  color: var(--color-secondary-dark);
}

.mp-badge-locked {
  background: var(--color-border);
  color: var(--color-text-muted);
}

/* Gate details */
.mp-gate-details {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: center;
}

.mp-gate-mastery {
  flex: 1;
  min-width: 150px;
}

.mp-gate-mastery span {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  display: block;
  margin-bottom: 2px;
}

.mp-gate-bar {
  height: 6px;
  background: var(--color-border);
  border-radius: var(--radius-full);
  overflow: hidden;
  max-width: 200px;
}

.mp-gate-fill {
  height: 100%;
  border-radius: var(--radius-full);
  transition: width 0.5s ease;
}

/* Connector lines between gates */
.mp-gate-connector {
  position: absolute;
  left: 18px;
  top: 100%;
  width: 2px;
  height: calc(100% - 20px);
  z-index: 0;
}

.mp-connector-completed {
  background: var(--color-success);
}

.mp-connector-unlocked {
  background: var(--color-secondary);
}

.mp-connector-locked {
  background: var(--color-border);
}

/* Responsive */
@media (max-width: 768px) {
  .mp-path-header {
    flex-direction: column;
  }

  .mp-path-stats {
    text-align: left;
    margin-top: var(--space-sm);
  }

  .mp-gate-details {
    flex-direction: column;
    align-items: flex-start;
  }

  .mp-gate-bar {
    max-width: 100%;
  }
}
