.fx-mono {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 0.875rem;
}

.fx-text-success { color: var(--fx-success) !important; }
.fx-text-danger { color: var(--fx-danger) !important; }

.fx-card {
  background: var(--fx-bg-glass);
  border: 1px solid var(--fx-border-silver);
  border-radius: var(--fx-radius-lg);
  backdrop-filter: blur(12px);
  overflow: hidden;
}

.fx-card-header {
  padding: 1rem 1.15rem;
  border-bottom: 1px solid var(--fx-border-silver);
}

.fx-card-body {
  padding: 1.15rem;
}

.fx-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}

.fx-page-title {
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  font-weight: 700;
  margin: 0;
}

.fx-page-subtitle {
  margin: 0.35rem 0 0;
  color: var(--fx-text-secondary);
}

.fx-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.fx-stat-card {
  display: flex;
  gap: 0.9rem;
  align-items: flex-start;
  padding: 1rem;
  border-radius: var(--fx-radius-lg);
  background: var(--fx-bg-glass);
  border: 1px solid var(--fx-border-silver);
  height: 100%;
}

.fx-stat-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 102, 255, 0.15);
  color: var(--fx-cyan-bright);
  flex-shrink: 0;
}

.fx-stat-label {
  display: block;
  color: var(--fx-text-secondary);
  font-size: 0.85rem;
}

.fx-stat-value {
  display: block;
  font-size: 1.35rem;
  font-family: 'JetBrains Mono', monospace;
  margin-top: 0.15rem;
}

.fx-stat-trend {
  display: block;
  color: var(--fx-success);
  margin-top: 0.25rem;
}

.fx-stat-green .fx-stat-icon { background: rgba(0, 200, 150, 0.15); color: var(--fx-success); }
.fx-stat-blue .fx-stat-icon { background: rgba(0, 102, 255, 0.15); color: var(--fx-blue-mid); }
.fx-stat-orange .fx-stat-icon { background: rgba(255, 176, 32, 0.15); color: var(--fx-warning); }
.fx-stat-purple .fx-stat-icon { background: rgba(147, 112, 255, 0.15); color: #9370ff; }
.fx-stat-red .fx-stat-icon { background: rgba(255, 77, 106, 0.15); color: var(--fx-danger); }
.fx-stat-cyan .fx-stat-icon { background: rgba(0, 212, 255, 0.15); color: var(--fx-cyan-bright); }

.fx-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}

.fx-badge-success { background: rgba(0, 200, 150, 0.15); color: var(--fx-success); }
.fx-badge-warning { background: rgba(255, 176, 32, 0.15); color: var(--fx-warning); }
.fx-badge-danger { background: rgba(255, 77, 106, 0.15); color: var(--fx-danger); }
.fx-badge-info { background: rgba(0, 212, 255, 0.15); color: var(--fx-cyan-bright); }
.fx-badge-primary { background: rgba(0, 102, 255, 0.15); color: var(--fx-blue-mid); }
.fx-badge-secondary { background: rgba(160, 160, 176, 0.15); color: var(--fx-silver-light); }

.fx-passbook-scroll {
  overflow-x: auto;
}

.fx-passbook-table,
.fx-data-table {
  color: var(--fx-text-primary);
  margin-bottom: 0;
}

.fx-passbook-table thead th,
.fx-data-table thead th {
  background: var(--fx-bg-elevated);
  border-color: var(--fx-border-silver);
  color: var(--fx-silver-light);
  white-space: nowrap;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.fx-passbook-table tbody td,
.fx-data-table tbody td {
  border-color: var(--fx-border-silver);
  vertical-align: middle;
}

.fx-passbook-table tbody tr:hover,
.fx-data-table tbody tr:hover {
  background: rgba(0, 102, 255, 0.05);
}

.fx-empty-state {
  text-align: center;
  padding: 2.5rem 1rem;
  color: var(--fx-text-secondary);
}

.fx-empty-state i {
  font-size: 2rem;
  display: block;
  margin-bottom: 0.75rem;
  color: var(--fx-text-muted);
}

.fx-alert {
  border-radius: 12px;
  border: 1px solid var(--fx-border-silver);
}

.fx-btn-danger {
  background: var(--fx-danger);
  border: none;
  color: #fff !important;
  font-weight: 600;
  border-radius: 999px;
}

.fx-dropdown {
  background: var(--fx-bg-elevated);
  border: 1px solid var(--fx-border-silver);
}

.fx-dropdown .dropdown-item {
  color: var(--fx-text-primary);
}

.fx-dropdown .dropdown-item:hover {
  background: rgba(0, 102, 255, 0.08);
  color: var(--fx-cyan-bright);
}

.fx-pagination .page-link {
  background: var(--fx-bg-elevated);
  border-color: var(--fx-border-silver);
  color: var(--fx-text-primary);
}

.fx-pagination .page-item.active .page-link {
  background: var(--fx-gradient-brand);
  border-color: transparent;
}

.form-check-input.fx-theme-switch {
  cursor: pointer;
}

.form-check-input:checked {
  background-color: var(--fx-blue-mid);
  border-color: var(--fx-blue-mid);
}

/* Shared panel form controls (user + admin) */
.form-label {
  color: var(--fx-text-secondary);
  font-weight: 500;
  margin-bottom: 0.35rem;
}

.fx-input,
.form-select.fx-input,
.form-control.fx-input {
  background: var(--fx-bg-elevated);
  border: 1px solid var(--fx-border-silver);
  color: var(--fx-text-primary);
  border-radius: 10px;
}

.fx-input:focus,
.form-select.fx-input:focus,
.form-control.fx-input:focus {
  background: var(--fx-bg-elevated);
  border-color: var(--fx-blue-mid);
  color: var(--fx-text-primary);
  box-shadow: 0 0 0 0.2rem rgba(0, 153, 255, 0.15);
}

.fx-btn-primary {
  background: var(--fx-gradient-brand);
  border: none;
  color: #fff !important;
  font-weight: 600;
  border-radius: 999px;
  padding: 0.55rem 1.15rem;
}

.fx-btn-primary:hover,
.fx-btn-primary:focus {
  opacity: 0.92;
  color: #fff !important;
}

.fx-btn-outline {
  background: transparent;
  border: 1px solid var(--fx-border-silver);
  color: var(--fx-text-primary) !important;
  font-weight: 600;
  border-radius: 999px;
  padding: 0.55rem 1.15rem;
}

.fx-btn-outline:hover,
.fx-btn-outline:focus {
  border-color: var(--fx-cyan-bright);
  color: var(--fx-cyan-bright) !important;
  background: rgba(0, 212, 255, 0.06);
}

[data-theme='light'] .fx-card,
[data-theme='light'] .fx-stat-card {
  background: #fff;
}

[data-theme='light'] .fx-passbook-table thead th,
[data-theme='light'] .fx-data-table thead th {
  background: #f4f6fa;
}
