/* ==========================================================================
   Buttons — unified CTA system.
   Variants: primary (orange), brand (navy), ghost, link.
   Sizes:    sm, md (default), lg.
   ========================================================================== */

.btn-wfs {
  --btn-bg: var(--c-accent);
  --btn-fg: var(--wfs-cream-50);
  --btn-bd: var(--c-accent);
  --btn-bg-h: var(--c-accent-hover);
  --btn-bd-h: var(--c-accent-hover);
  --btn-shadow: var(--shadow-2);

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 22px;
  font-family: var(--font-sans);
  font-size: var(--fs-16);
  font-weight: var(--fw-semibold);
  letter-spacing: -0.005em;
  line-height: 1;
  color: var(--btn-fg);
  background: var(--btn-bg);
  border: 1px solid var(--btn-bd);
  border-radius: var(--r-2);
  cursor: pointer;
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
  box-shadow: var(--btn-shadow);
  white-space: nowrap;
}
.btn-wfs:hover {
  background: var(--btn-bg-h);
  border-color: var(--btn-bd-h);
  color: var(--btn-fg);
  text-decoration: none;
  transform: translateY(-1px);
}
.btn-wfs:active { transform: translateY(0); }
.btn-wfs svg { width: 18px; height: 18px; flex: 0 0 18px; }

.btn-wfs--brand {
  --btn-bg: var(--c-brand);
  --btn-bd: var(--c-brand);
  --btn-bg-h: var(--wfs-navy-600);
  --btn-bd-h: var(--wfs-navy-600);
  --btn-fg: var(--wfs-cream-50);
}
.btn-wfs--ghost {
  --btn-bg: transparent;
  --btn-bd: var(--c-line-strong);
  --btn-fg: var(--c-fg);
  --btn-bg-h: var(--c-bg-soft);
  --btn-bd-h: var(--c-fg);
  --btn-shadow: none;
}
.btn-wfs--ghost-on-ink {
  --btn-bg: transparent;
  --btn-bd: rgba(245, 239, 224, 0.32);
  --btn-fg: var(--c-fg-on-ink);
  --btn-bg-h: rgba(245, 239, 224, 0.08);
  --btn-bd-h: var(--c-fg-on-ink);
  --btn-shadow: none;
}
.btn-wfs--link {
  --btn-bg: transparent;
  --btn-bd: transparent;
  --btn-fg: var(--c-brand);
  --btn-bg-h: transparent;
  --btn-bd-h: transparent;
  --btn-shadow: none;
  padding: 4px 0;
  border-bottom: 1px solid var(--c-line-strong);
  border-radius: 0;
}
.btn-wfs--link:hover {
  color: var(--c-accent);
  border-bottom-color: var(--c-accent);
  transform: none;
}

.btn-wfs--lg { padding: 18px 28px; font-size: var(--fs-17); }
.btn-wfs--sm { padding: 10px 16px; font-size: var(--fs-14); }
.btn-wfs--block { width: 100%; }

/* CTA pair — primary + secondary, gap-aware */
.cta-pair {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  align-items: center;
}

/* Inline arrow link — used heavily in cards and stat blocks */
.arrow-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: var(--fs-15);
  font-weight: var(--fw-semibold);
  letter-spacing: -0.005em;
  color: var(--c-brand);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
  transition: color var(--dur-fast), border-color var(--dur-fast), gap var(--dur-fast);
}
.arrow-link::after {
  content: "→";
  font-family: var(--font-sans);
  transition: transform var(--dur-fast) var(--ease-out);
}
.arrow-link:hover {
  color: var(--c-accent);
  border-bottom-color: var(--c-accent);
  gap: 12px;
}
.arrow-link:hover::after { transform: translateX(2px); }

.arrow-link--on-ink { color: var(--wfs-cream-100); }
.arrow-link--on-ink:hover { color: var(--wfs-orange-300); border-bottom-color: var(--wfs-orange-300); }
