/* ============================================
   Reusable Components
   ============================================ */

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: 12px 24px; font-size: var(--font-size-base); font-weight: var(--font-weight-semibold);
  border-radius: var(--radius-md); transition: all var(--transition-base);
  cursor: pointer; border: none; white-space: nowrap; text-align: center;
}
.btn--primary { background: var(--color-primary); color: var(--text-on-primary); }
.btn--primary:hover { background: var(--color-primary-dark); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--accent { background: var(--color-accent); color: var(--text-on-accent); }
.btn--accent:hover { background: var(--color-accent-dark); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--outline { background: transparent; color: var(--color-primary); border: 2px solid var(--color-primary); }
.btn--outline:hover { background: var(--color-primary); color: var(--text-on-primary); }
.btn--white { background: var(--color-white); color: var(--color-primary); }
.btn--white:hover { background: var(--color-gray-100); transform: translateY(-1px); }
.btn--pill { border-radius: var(--radius-full); }
.btn--sm { padding: 8px 16px; font-size: var(--font-size-sm); }
.btn--lg { padding: 14px 28px; font-size: var(--font-size-md); }
.btn--full { width: 100%; }
.btn--icon { width: 44px; height: 44px; padding: 0; border-radius: var(--radius-full); }

/* ---- Cards ---- */
.card {
  background: var(--surface-card); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); overflow: hidden; transition: all var(--transition-base);
}
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.card__image { width: 100%; height: 180px; object-fit: cover; }
.card__body { padding: var(--space-4); }
.card__title { font-size: var(--font-size-md); font-weight: var(--font-weight-semibold); margin-bottom: var(--space-1); }
.card__text { font-size: var(--font-size-sm); color: var(--text-secondary); line-height: var(--line-height-relaxed); }
.card--bordered { box-shadow: none; border: 1px solid var(--color-gray-200); }
.card--flat { box-shadow: none; }

/* ---- Badges ---- */
.badge {
  display: inline-flex; align-items: center; padding: 4px 10px;
  font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold);
  border-radius: var(--radius-full); letter-spacing: 0.02em;
}
.badge--primary { background: var(--color-primary-bg); color: var(--color-primary); }
.badge--accent { background: var(--color-accent-bg); color: var(--color-accent); }
.badge--success { background: #DCFCE7; color: #16A34A; }

/* ---- Stat Card ---- */
.stat-card {
  text-align: center; padding: var(--space-4);
  background: var(--surface-card); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
}
.stat-card__number { font-size: var(--font-size-2xl); font-weight: var(--font-weight-extrabold); color: var(--color-primary); }
.stat-card__label { font-size: var(--font-size-xs); color: var(--text-secondary); margin-top: var(--space-1); }

/* ---- Testimonial Card ---- */
.testimonial-card {
  background: var(--surface-card); border-radius: var(--radius-lg);
  padding: var(--space-6); box-shadow: var(--shadow-sm); border: 1px solid var(--color-gray-100);
}
.testimonial-card__header { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-4); }
.testimonial-card__avatar { width: 48px; height: 48px; border-radius: var(--radius-full); object-fit: cover; }
.testimonial-card__name { font-weight: var(--font-weight-semibold); font-size: var(--font-size-base); }
.testimonial-card__role { font-size: var(--font-size-xs); color: var(--text-secondary); }
.testimonial-card__stars { display: flex; gap: 2px; color: var(--color-warning); margin-bottom: var(--space-3); }
.testimonial-card__quote { font-size: var(--font-size-sm); color: var(--text-secondary); line-height: var(--line-height-relaxed); font-style: italic; }

/* ---- Benefit Row ---- */
.benefit-row {
  display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-3) 0;
}
.benefit-row__icon {
  width: 36px; height: 36px; min-width: 36px; border-radius: var(--radius-full);
  background: var(--color-primary-bg); color: var(--color-primary);
  display: flex; align-items: center; justify-content: center; font-size: 16px;
}
.benefit-row__content { flex: 1; }
.benefit-row__title { font-weight: var(--font-weight-semibold); font-size: var(--font-size-base); margin-bottom: 2px; }
.benefit-row__text { font-size: var(--font-size-sm); color: var(--text-secondary); }

/* ---- Filter Pills ---- */
.filter-pills {
  display: flex; gap: var(--space-2); overflow-x: auto; padding-bottom: var(--space-2);
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.filter-pills::-webkit-scrollbar { display: none; }
.filter-pill {
  padding: 8px 18px; font-size: var(--font-size-sm); font-weight: var(--font-weight-medium);
  border-radius: var(--radius-full); border: 1.5px solid var(--color-gray-200);
  background: var(--color-white); color: var(--text-secondary); white-space: nowrap;
  cursor: pointer; transition: all var(--transition-fast);
}
.filter-pill:hover { border-color: var(--color-primary); color: var(--color-primary); }
.filter-pill.active { background: var(--color-primary); color: var(--text-on-primary); border-color: var(--color-primary); }

/* ---- Accordion ---- */
.accordion-item { border-bottom: 1px solid var(--color-gray-200); }
.accordion-trigger {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-4) 0; font-size: var(--font-size-base); font-weight: var(--font-weight-medium);
  text-align: left; cursor: pointer; transition: color var(--transition-fast);
}
.accordion-trigger:hover { color: var(--color-primary); }
.accordion-trigger__icon { transition: transform var(--transition-base); font-size: 18px; }
.accordion-item.open .accordion-trigger__icon { transform: rotate(180deg); }
.accordion-content {
  max-height: 0; overflow: hidden; transition: max-height var(--transition-base);
}
.accordion-item.open .accordion-content { max-height: 500px; }
.accordion-content__inner { padding-bottom: var(--space-4); font-size: var(--font-size-sm); color: var(--text-secondary); line-height: var(--line-height-relaxed); }

/* ---- Media Logo Bar ---- */
.media-logos {
  display: flex; gap: var(--space-4); align-items: center; justify-content: center;
  flex-wrap: wrap; opacity: 0.7;
}
.media-logos img { height: 24px; object-fit: contain; filter: grayscale(100%); transition: filter var(--transition-base); }
.media-logos img:hover { filter: grayscale(0%); }

/* ---- Icon Circle ---- */
.icon-circle {
  width: 56px; height: 56px; border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
}
.icon-circle--primary { background: var(--color-primary-bg); color: var(--color-primary); }
.icon-circle--accent { background: var(--color-accent-bg); color: var(--color-accent); }

/* ---- Form Inputs ---- */
.form-group { margin-bottom: var(--space-4); }
.form-label { display: block; font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); margin-bottom: var(--space-2); color: var(--text-primary); }
.form-input {
  width: 100%; padding: 12px 16px; font-size: var(--font-size-base); border: 1.5px solid var(--color-gray-200);
  border-radius: var(--radius-md); background: var(--color-white); transition: border-color var(--transition-fast);
}
.form-input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(26,158,143,0.1); }
.form-input--textarea { min-height: 120px; resize: vertical; }
.form-input.error { border-color: var(--color-error); }
.form-error { font-size: var(--font-size-xs); color: var(--color-error); margin-top: var(--space-1); }
