/* ------------------------------------------------------
   components.css — Design System: Baseline UI Components
   ------------------------------------------------------
   Loaded globally AFTER theme.css, BEFORE site.css.
   Provides reusable class-based components that reference
   design tokens from theme.css.

   Keep classes neutral and composable.
*/

/* ================================================
   BUTTONS
   ================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-family: inherit;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  line-height: var(--leading-normal);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background-color var(--transition-fast),
              border-color var(--transition-fast),
              color var(--transition-fast);
  text-decoration: none;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Primary */
.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.btn-primary:hover:not(:disabled) {
  background-color: var(--color-primary-hover);
}

/* Secondary */
.btn-secondary {
  background-color: var(--color-white);
  color: var(--color-gray-700);
  border-color: var(--color-gray-300);
}

.btn-secondary:hover:not(:disabled) {
  background-color: var(--color-gray-50);
  border-color: var(--color-gray-400);
}

/* Danger */
.btn-danger {
  background-color: var(--color-danger);
  color: var(--color-white);
}

.btn-danger:hover:not(:disabled) {
  background-color: var(--color-danger-hover);
}

/* Small variant */
.btn-sm {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
}

/* Large variant */
.btn-lg {
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-base);
}


/* ================================================
   CARDS
   ================================================ */

.card {
  background-color: var(--color-white);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.card-header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-color);
  font-weight: var(--font-semibold);
  font-size: var(--text-base);
}

.card-body {
  padding: var(--space-4) var(--space-5);
}

.card-footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--border-color);
  background-color: var(--color-gray-50);
}


/* ================================================
   FORMS
   ================================================ */

.form-label {
  display: block;
  margin-bottom: var(--space-1);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-gray-700);
}

.form-input,
.form-select {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-family: inherit;
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--color-gray-900);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast),
              box-shadow var(--transition-fast);
}

.form-input:focus,
.form-select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(11, 95, 255, 0.15);
}

.form-input:disabled,
.form-select:disabled {
  background-color: var(--color-gray-100);
  cursor: not-allowed;
}

.form-select {
  appearance: auto;
}

.form-help {
  display: block;
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-gray-500);
}

.form-error {
  display: block;
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-danger);
  font-weight: var(--font-medium);
}

/* Form group — wraps label + input + help/error */
.form-group {
  margin-bottom: var(--space-4);
}


/* ================================================
   TABLES
   ================================================ */

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.table th,
.table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--border-color);
}

.table th {
  font-weight: var(--font-semibold);
  color: var(--color-gray-600);
  background-color: var(--color-gray-50);
}

.table tbody tr:hover {
  background-color: var(--color-gray-50);
}


/* ================================================
   BADGES / PILLS
   ================================================ */

.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.125rem var(--space-2);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  line-height: var(--leading-normal);
  border-radius: var(--radius-full);
  background-color: var(--color-gray-100);
  color: var(--color-gray-700);
}

.badge-primary {
  background-color: rgba(11, 95, 255, 0.1);
  color: var(--color-primary);
}

.badge-success {
  background-color: rgba(22, 163, 74, 0.1);
  color: var(--color-success);
}

.badge-danger {
  background-color: rgba(220, 38, 38, 0.1);
  color: var(--color-danger);
}

.badge-warning {
  background-color: rgba(217, 119, 6, 0.1);
  color: var(--color-warning);
}


/* ================================================
   ALERTS
   ================================================ */

.alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  border: 1px solid transparent;
}

.alert-info {
  background-color: rgba(2, 132, 199, 0.08);
  color: var(--color-info);
  border-color: rgba(2, 132, 199, 0.2);
}

.alert-success {
  background-color: rgba(22, 163, 74, 0.08);
  color: var(--color-success);
  border-color: rgba(22, 163, 74, 0.2);
}

.alert-warning {
  background-color: rgba(217, 119, 6, 0.08);
  color: var(--color-warning);
  border-color: rgba(217, 119, 6, 0.2);
}

.alert-danger {
  background-color: rgba(220, 38, 38, 0.08);
  color: var(--color-danger);
  border-color: rgba(220, 38, 38, 0.2);
}

