/* ════════════════════════════════════
   components.css  —  Reusable UI parts
   ════════════════════════════════════ */

/* ── BUTTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.8rem 1.8rem;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: var(--weight-medium);
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: transform var(--duration-base) var(--ease-spring),
              opacity   var(--duration-fast);
  white-space: nowrap;
}
.btn:hover  { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: var(--color-accent);
  color: #fff;
}
.btn--primary:hover { opacity: 0.9; }

.btn--ghost {
  background: transparent;
  color: var(--color-text);
  border: 1px solid var(--color-border-2);
}
.btn--ghost:hover { border-color: var(--color-accent); background: rgba(124,106,255,0.06); }

.btn--outline {
  background: transparent;
  color: var(--color-accent-2);
  border: 1px solid rgba(124,106,255,0.35);
}
.btn--outline:hover { background: rgba(124,106,255,0.1); }

.btn--teal {
  background: transparent;
  color: var(--color-accent-3);
  border: 1px solid rgba(56,189,248,0.35);
}
.btn--teal:hover { background: rgba(56,189,248,0.08); }

.btn--edit {
  background: rgba(124,106,255,0.15);
  color: var(--color-accent-2);
  border: 1px solid rgba(124,106,255,0.35);
  font-size: var(--text-sm);
  padding: 0.45rem 1rem;
}
.btn--edit:hover { background: rgba(124,106,255,0.25); }

/* Small size modifier */
.btn--sm {
  padding: 0.5rem 1.1rem;
  font-size: var(--text-sm);
  border-radius: var(--radius-pill);
}

/* ── NAV CTA ── */
.nav__cta {
  background: var(--color-accent) !important;
  color: #fff !important;
  padding: 0.45rem 1.2rem;
  border-radius: var(--radius-pill);
  font-size: var(--text-sm) !important;
  transition: opacity var(--duration-fast) !important;
}
.nav__cta:hover { opacity: 0.85; }

/* ── BADGE DOT ── */
.badge-dot {
  width: 6px;
  height: 6px;
  background: var(--color-green);
  border-radius: 50%;
  flex-shrink: 0;
}
