/* ============================================================
 * components.css — ボタン、カード等の再利用パーツ
 * ============================================================ */

/* ---- Buttons ---- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 14px 28px;
  font-size: var(--fs-base);
  font-weight: 600;
  border-radius: var(--radius-sm);
  transition: background var(--transition-base), color var(--transition-base), border-color var(--transition-base);
  border: 1px solid transparent;
  min-height: 48px;
}

.btn--primary {
  background: var(--color-brand-primary);
  color: #fff;
}
.btn--primary:hover {
  background: #0077d6;
}

.btn--outline {
  background: transparent;
  color: var(--color-text-on-dark);
  border-color: rgba(255, 255, 255, 0.5);
}
.btn--outline:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: #fff;
}

.btn--outline-dark {
  background: transparent;
  color: var(--color-brand-deep);
  border-color: var(--color-brand-deep);
}
.btn--outline-dark:hover {
  background: var(--color-brand-deep);
  color: #fff;
}

/* ---- Card ---- */
.card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.card--dark {
  background: var(--color-brand-deep-2);
  color: var(--color-text-on-dark);
  border-color: rgba(255, 255, 255, 0.08);
}

.card__number {
  display: inline-block;
  font-family: var(--font-sans-en);
  font-size: var(--fs-sm);
  color: var(--color-brand-primary);
  font-weight: 700;
  letter-spacing: 0.12em;
  margin-bottom: var(--space-3);
}

.card__title {
  font-size: var(--fs-lg);
  margin-bottom: var(--space-3);
  color: inherit;
}

.card__body {
  color: var(--color-text-secondary);
  font-size: var(--fs-sm);
  line-height: var(--lh-base);
}

.card--dark .card__body {
  color: rgba(255, 255, 255, 0.75);
}

.card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-5);
  color: var(--color-brand-primary);
  font-size: var(--fs-sm);
  font-weight: 600;
}
.card__link::after {
  content: "→";
}
