.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 46px;
  padding: 0 26px;
  border-radius: var(--r-pill);
  font-size: 14.5px;
  font-weight: 600;
  transition: var(--t);
  white-space: nowrap;
  cursor: pointer;
  border: none;
}
.btn-primary {
  background: var(--teal);
  color: #fff;
  box-shadow: var(--sh-teal);
}
.btn-primary:hover {
  background: var(--teal-dk);
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(13,158,117,.32);
}
.btn-outline {
  background: transparent;
  border: 2px solid var(--teal);
  color: var(--teal);
}
.btn-outline:hover { background: var(--teal); color: #fff; transform: translateY(-2px); }
.btn-dark   { background: var(--ink); color: #fff; }
.btn-dark:hover { background: var(--ink-2); transform: translateY(-2px); }
.btn-dark-o { background: transparent; border: 1.5px solid rgba(255,255,255,.28); color: #fff; }
.btn-dark-o:hover { background: rgba(255,255,255,.1); transform: translateY(-2px); }
.btn-ghost  { background: var(--bg-2); color: var(--ink); }
.btn-ghost:hover { background: var(--bg-3); }
.btn-gold   { background: var(--gold); color: #fff; }
.btn-sm     { height: 36px; padding: 0 18px; font-size: 13px; }
.btn-lg     { height: 54px; padding: 0 36px; font-size: 15.5px; }
