/* S59DGO Membership System - Custom styles */

body {
  background-color: #f5f7fa;
}

.navbar-brand {
  font-size: 1.1rem;
  letter-spacing: 0.5px;
}

.card {
  border: none;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}

.card-header {
  font-weight: 600;
  font-size: 0.95rem;
}

/* DataTables overrides */
.dataTables_wrapper .dataTables_filter input {
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  padding: 0.25rem 0.5rem;
  margin-left: 0.25rem;
}

.dataTables_wrapper .dataTables_length select {
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  padding: 0.25rem 0.5rem;
}

/* Call signs */
code {
  font-size: 0.9rem;
  color: #0d6efd;
  background: #e8f0fe;
  padding: 0.1rem 0.35rem;
  border-radius: 0.25rem;
}

/* Breadcrumb */
.breadcrumb {
  font-size: 0.875rem;
}

/* Form labels */
.form-label {
  font-weight: 500;
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
}

/* Status badges */
.badge {
  font-size: 0.78rem;
  font-weight: 500;
}

/* Table action buttons */
.table td .btn-sm {
  padding: 0.15rem 0.4rem;
}

/* Fee table */
#fee-table td:first-child {
  font-weight: 600;
  width: 80px;
}

@media (max-width: 576px) {
  .card-body { padding: 0.75rem; }
  .card-header { padding: 0.5rem 0.75rem; font-size: 0.875rem; }
  .navbar-brand { font-size: 0.95rem; }
  .container-fluid { padding-left: 0.75rem; padding-right: 0.75rem; }
}
