/* ==========================================================================
   Buttons
   ========================================================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  border-radius: var(--radius-md);
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
  white-space: nowrap;
  cursor: pointer;
}

.btn--primary {
  background-color: var(--accent);
  color: var(--text-heading);
}

.btn--primary:hover {
  background-color: var(--accent-hover);
}

.btn--outline {
  background-color: transparent;
  color: var(--text-heading);
  border: 1px solid var(--border);
}

.btn--outline:hover {
  border-color: var(--border-light);
  background-color: var(--bg-card);
}

.btn--dark {
  background-color: var(--bg-card);
  color: var(--text-heading);
  border: 1px solid var(--border);
}

.btn--dark:hover {
  background-color: var(--bg-card-hover);
}

.btn--lg {
  padding: var(--space-4) var(--space-8);
  font-size: var(--font-size-base);
}

.btn--sm {
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-xs);
}

.btn--icon {
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: var(--radius-full);
}

/* ==========================================================================
   Cards
   ========================================================================== */

.card {
  background-color: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color var(--transition-base);
}

.card:hover {
  border-color: var(--border-light);
}

.card__image {
  width: 100%;
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-4);
}

.card__image img {
  width: 100%;
  height: 250px;
  object-fit: cover;
}

.card__badge {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--text-heading);
  background-color: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
}

.card__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-2);
}

.card__text {
  font-size: var(--font-size-sm);
  color: var(--text-body);
  margin-bottom: var(--space-4);
}

.card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}

.card__price-label {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
}

.card__price {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-heading);
}

/* ==========================================================================
   Form Inputs
   ========================================================================== */

.form-input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--text-heading);
  background-color: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast);
}

.form-input::placeholder {
  color: var(--text-muted);
}

.form-input:focus {
  border-color: var(--accent);
}

.form-group {
  display: flex;
  gap: var(--space-3);
}

.form-group .form-input {
  flex: 1;
}

/* ==========================================================================
   Section Headings
   ========================================================================== */

.section {
  padding-block: var(--space-16);
}

.section__header {
  margin-bottom: var(--space-10);
}

.section__stars {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-bottom: var(--space-3);
}

.section__star {
  color: var(--star-color);
  font-size: var(--font-size-lg);
}

.section__tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--text-body);
  margin-bottom: var(--space-4);
}

.section__title {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-3);
}

.section__description {
  font-size: var(--font-size-sm);
  color: var(--text-body);
  max-width: 650px;
  line-height: var(--line-height-relaxed);
}

.section__header-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.section__nav {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* ==========================================================================
   Stars Rating
   ========================================================================== */

.stars {
  display: flex;
  gap: 2px;
}

.stars__icon {
  width: 20px;
  height: 20px;
  color: var(--star-color);
}

/* ==========================================================================
   Badge / Tag
   ========================================================================== */

.badge {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--text-heading);
  background-color: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
}
