/* ============================================================
   BUTTONS.CSS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .01em;
  padding: .625rem 1.25rem;
  border-radius: var(--radius);
  border: 2px solid transparent;
  transition: all var(--transition);
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  line-height: 1.4;
}

/* PRIMARY */
.btn-primary {
  background: var(--cl-blue);
  color: var(--white);
  border-color: var(--cl-blue);
}
.btn-primary:hover {
  background: var(--cl-blue-dark);
  border-color: var(--cl-blue-dark);
  color: var(--white);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(24,95,165,.35);
}

/* TEAL */
.btn-teal {
  background: var(--cl-teal);
  color: var(--white);
  border-color: var(--cl-teal);
}
.btn-teal:hover {
  background: var(--cl-teal-dark);
  border-color: var(--cl-teal-dark);
  color: var(--white);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(14,165,164,.35);
}

/* OUTLINE */
.btn-outline {
  background: transparent;
  color: var(--cl-blue);
  border-color: var(--cl-blue);
}
.btn-outline:hover {
  background: var(--cl-blue);
  color: var(--white);
  transform: translateY(-1px);
}

/* GHOST */
.btn-ghost {
  background: transparent;
  color: var(--gray-700);
  border-color: var(--border-strong);
}
.btn-ghost:hover {
  background: var(--gray-100);
  color: var(--gray-900);
}

/* WHITE */
.btn-white {
  background: var(--white);
  color: var(--cl-blue);
  border-color: var(--white);
}
.btn-white:hover {
  background: var(--gray-100);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

/* SIZES */
.btn-sm { font-size: .8125rem; padding: .4rem .875rem; }
.btn-lg { font-size: 1rem; padding: .875rem 1.75rem; }
.btn-xl { font-size: 1.05rem; padding: 1rem 2rem; border-radius: var(--radius-lg); }

/* ICON */
.btn-icon { width: 40px; height: 40px; padding: 0; border-radius: var(--radius); }
.btn-icon-sm { width: 32px; height: 32px; }

/* LOADING STATE */
.btn.loading { pointer-events: none; opacity: .7; }
