/* src/style.css - Light/Dark Theme with CSS Variables */

/* --- Define COLOR Variables --- */
:root {
  /* === DEFAULT (LIGHT) THEME - CONTRAST ADJUSTED === */
  --color-bg-primary: #ffffff; /* White */
  --color-bg-secondary: #cedae4; /* Very Light Grey (Cards, Inputs) */
  --color-bg-tertiary: #e9ecef; /* Light Grey (Table Headers, Footers) */
  --color-bg-topnav: #ffffff; /* White */
  --color-bg-sidebar: #f8f9fa; /* Very Light Grey */
  --color-bg-footer: #e9ecef; /* Light Grey */
  --color-bg-input: #ffffff; /* White */
  --color-bg-table-row-alt: #f1f3f5; /* Slightly different light grey for rows */
  --color-bg-card: #ffffff; /* White */
  --color-bg-table-header: #e9ecef; /* Light Grey */
  --color-bg-hover-medium: #e9ecef; /* Light Grey hover */
  --color-bg-row-hover: #dee2e6; /* Darker Grey Row hover */

  --color-text-primary: #212529; /* Dark Grey/Near Black - Good */
  --color-text-secondary: #495057; /* Medium Dark Grey - Good */
  --color-text-muted: #5a6268; /* Darker Muted Grey - Increased Contrast */
  --color-text-subtle: #6c757d; /* Medium Grey - Increased Contrast */
  --color-text-light: #f8f9fa; /* Very Light Grey (Keep for dark button text maybe?) */
  --color-text-dark: #000000; /* Pure Black - Good */
  --color-text-heading: #005596; /* UWindsor Blue - Good */
  --color-text-link: #005596; /* UWindsor Blue - Good */
  --color-text-link-hover: #003865; /* Darker UWindsor Blue - Good */
  --color-text-button-primary: #212529; /* Dark Text on Yellow - Good */
  --color-text-input: #212529; /* Dark Text in inputs - Good */
  --color-text-footer: #495057; /* Darker Footer Text */

  --color-accent-primary: #ffce00; /* UWindsor Yellow/Gold */
  --color-accent-hover: #e6b800; /* Darker Yellow */
  --color-accent-focus-shadow: rgba(255, 206, 0, 0.4); /* Yellow focus glow */

  --color-border-medium: #ced4da; /* Darker Grey Border - Increased Contrast */
  --color-border-dark: #adb5bd; /* Even Darker Grey Border - Increased Contrast */
  --color-border-light: #dee2e6; /* Light Grey for subtle lines */
  --color-border-accent: var(--color-accent-primary); /* Yellow */
  --color-border-input: #ced4da; /* Darker Grey Input Border */

  /* Action/Button Colors (Light Theme - ADJUSTED) */
  --color-button-primary-bg: var(--color-accent-primary);
  --color-button-primary-hover-bg: var(--color-accent-hover);
  --color-button-secondary-bg: #6c757d; /* Grey */
  --color-button-secondary-hover-bg: #5a6268;
  --color-button-secondary-text: #ffffff; /* CHANGED to White for contrast on grey */

  --color-action-view-bg: #17a2b8; /* Info Blue */
  --color-action-view-text: #ffffff; /* White text */
  --color-action-edit-bg: #ffc107; /* Yellow */
  --color-action-edit-text: #212529; /* Dark text */
  --color-action-delete-bg: #dc3545; /* Red */
  --color-action-delete-text: #ffffff; /* White text */
  --color-action-add-bg: #28a745; /* Green */
  --color-action-add-hover-bg: #218838;
  --color-action-add-text: #ffffff; /* White text */

  /* Message Colors (Light Theme - Minor tweaks for consistency) */
  --color-msg-success-bg: #d1e7dd;
  --color-msg-success-text: #0f5132;
  --color-msg-success-border: #badbcc;
  --color-msg-error-bg: #f8d7da;
  --color-msg-error-text: #842029;
  --color-msg-error-border: #f5c2c7;
  --color-msg-warning-bg: #fff3cd;
  --color-msg-warning-text: #664d03;
  --color-msg-warning-border: #ffecb5;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.07); /* Slightly softer shadow */
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.12),
    0 2px 4px -1px rgba(0, 0, 0, 0.08);
}

/* --- DARK THEME OVERRIDES --- */
body.dark {
  /* Keep the dark theme variables as they were, they had better contrast */
  --color-bg-primary: #002b51;
  --color-bg-secondary: #001f3a;
  --color-bg-tertiary: #003a6a;
  --color-bg-topnav: var(--color-bg-secondary);
  --color-bg-sidebar: var(--color-bg-secondary);
  --color-bg-footer: black;
  --color-bg-input: #003a6a;
  --color-bg-table-row-alt: #004a80;
  --color-bg-card: var(--color-bg-tertiary);
  --color-bg-table-header: #001f3a;
  --color-bg-hover-medium: #005596;
  --color-bg-row-hover: #006fc2;

  --color-text-primary: #f0f0f0;
  --color-text-secondary: #e0e0e0;
  --color-text-muted: #ccc;
  --color-text-subtle: #bbb;
  --color-text-light: white;
  --color-text-dark: #002b51;
  --color-text-heading: #ffce00;
  --color-text-link: #ffce00;
  --color-text-link-hover: #ffd940;
  --color-text-button-primary: var(--color-text-dark);
  --color-text-input: var(--color-text-light);
  --color-text-footer: #aaa;

  --color-border-medium: #005596;
  --color-border-dark: #003a6a;
  --color-border-light: #005596;
  --color-border-accent: var(--color-accent-primary);
  --color-border-input: var(--color-border-medium);

  --color-button-secondary-text: var(--color-text-light);
  --color-action-view-bg: var(--color-accent-primary);
  --color-action-view-text: var(--color-text-dark);
  --color-action-edit-bg: #ff9800; /* Orange */
  --color-action-edit-text: var(--color-text-dark);
  --color-action-delete-text: var(--color-text-light);
  --color-action-add-bg: #005596; /* Use UWindsor Blue for Add in Dark */
  --color-action-add-hover-bg: #006fc2;
  --color-action-add-text: var(--color-text-light);

  --color-msg-success-bg: #0f5132;
  --color-msg-success-text: #d1e7dd;
  --color-msg-success-border: #badbcc;
  --color-msg-error-bg: #842029;
  --color-msg-error-text: #f8d7da;
  --color-msg-error-border: #f5c2c7;
  --color-msg-warning-bg: #664d03;
  --color-msg-warning-text: #fff3cd;
  --color-msg-warning-border: #ffecb5;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.25);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3),
    0 2px 4px -1px rgba(0, 0, 0, 0.2);
}

/* --- Base Styles --- */
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica,
    Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  margin: 0;
  padding: 0;
  line-height: 1.5;
  background-color: var(--color-bg-primary);
  color: var(--color-text-primary);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  transition: background-color 0.3s ease, color 0.3s ease; /* Smooth transition */
}
* {
  box-sizing: border-box;
}
a {
  color: var(--color-text-link);
  text-decoration: none;
}
a:hover {
  color: var(--color-text-link-hover);
  text-decoration: underline;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--color-text-heading);
  margin-top: 0;
  margin-bottom: 0.75em;
  font-weight: 500;
}
h1 {
  font-size: 1.8em;
  border-bottom: 1px solid var(--color-border-medium);
  padding-bottom: 0.3em;
  margin-bottom: 1em;
}
h2 {
  font-size: 1.5em;
}
h3 {
  font-size: 1.25em;
}
h4 {
  font-size: 1.1em;
}
hr {
  border: none;
  border-top: 1px solid var(--color-border-medium);
  margin: 10px 0;
}
img {
  max-width: 100%;
  height: auto;
}

/* --- Layout Styles --- */
/* Top Navigation Bar */
.top-navbar {
  background-color: var(--color-bg-topnav);
  padding: 25px;
  border-bottom: 2px solid var(--color-border-accent);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}
@media (max-width: 1024px) {
  .top-navbar {
    flex-direction: column;
  }
}
.top-navbar .navbar-brand a {
  color: var(--color-text-heading);
  font-weight: bold;
  font-size: 1.4em;
  text-decoration: none;
}
.top-navbar .navbar-brand a:hover {
  color: var(--color-text-link-hover);
}
.top-navbar .navbar-links {
  display: flex;
  gap: 5px 10px;
  flex-wrap: wrap;
}
.top-navbar .navbar-links a {
  color: var(--color-text-secondary);
  font-weight: bold;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.top-navbar .navbar-links a:hover,
.top-navbar .navbar-links a.active {
  color: var(--color-text-link);
  border-bottom-color: var(--color-accent-primary);
  text-decoration: none;
}
/* Add to src/style.css */
.top-navbar .navbar-links a.theme-toggle {
  border-bottom: none; /* Remove underline effect */
  /* Add other specific styles if needed */
  margin-left: 15px;
}
.top-navbar .navbar-links a.theme-toggle:hover {
  border-bottom: none;
  background-color: var(--color-bg-hover-medium); /* Example hover */
}
/* --- Add to src/style.css --- */
/* Container for Sidebar and Main Content */
.main-body-container {
  display: flex;
  flex: 1;
  overflow: hidden;
}
@media (max-width: 1024px) {
  .main-body-container {
    flex-direction: column;
  }
}
.context-sidebar {
  flex-basis: 25%;
  background-color: var(--color-bg-sidebar);
  border-right: 1px solid var(--color-border-medium);
  padding: 20px;
  box-sizing: border-box;
  color: var(--color-text-sidebar);
  flex-shrink: 0;
  overflow-y: auto;
}
.app-content {
  flex-basis: 75%;
  flex-grow: 1;
  padding: 25px;
  box-sizing: border-box;
  overflow-y: auto;
}

/* --- Components (Use var() extensively) --- */
/* Filters */
.context-sidebar .content-filters {
  background-color: transparent;
  padding: 0;
  margin-top: 20px;
  border: none;
  border-top: 2px solid var(--color-border-medium);
  padding-top: 20px;
  border-radius: 0;
  box-shadow: none;
}
.content-filters {
  /* Applies when filters are in main content area too */
  background-color: var(--color-bg-secondary);
  padding: 15px 20px;
  margin-bottom: 25px;
  border: 1px solid var(--color-border-medium);
  border-radius: 4px;
  box-shadow: var(--shadow-sm);
}
.content-filters h4 {
  margin-top: 0;
  margin-bottom: 20px;
  color: var(--color-text-heading);
  border-bottom: 1px solid var(--color-border-medium);
  padding-bottom: 8px;
  font-size: 1.1em;
}
.filter-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 15px 20px;
  align-items: end;
}
.context-sidebar .filter-form-grid {
  grid-template-columns: 1fr;
  gap: 15px;
} /* Override for sidebar */
.filter-group {
  padding: 0;
}
.content-filters label {
  display: block;
  margin-bottom: 5px;
  font-size: 0.9em;
  font-weight: bold;
  color: var(--color-text-secondary);
}
.content-filters input[type="text"],
.content-filters input[type="number"],
.content-filters select {
  width: 100%;
  padding: 8px;
  border: 1px solid var(--color-border-input);
  border-radius: 3px;
  box-sizing: border-box;
  font-size: 0.95em;
  background-color: var(--color-bg-input);
  color: var(--color-text-input);
  height: 37px;
}
.content-filters input:focus,
.content-filters select:focus {
  outline: none;
  border-color: var(--color-border-accent);
  box-shadow: 0 0 0 2px var(--color-accent-focus-shadow);
}
.filter-group.person-id-filter input[type="number"] {
  max-width: 100px;
}
.context-sidebar .filter-group.person-id-filter input[type="number"] {
  max-width: none;
} /* Allow full width in sidebar */
.filter-group.filter-actions {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}
.content-filters button,
.content-filters a.button {
  padding: 8px 10px;
  font-size: 0.9em;
  border-radius: 3px;
  cursor: pointer;
  font-weight: bold;
  height: 37px;
  box-sizing: border-box;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-grow: 1;
  border: none;
}
.content-filters button[type="submit"] {
  background-color: var(--color-button-primary-bg);
  color: var(--color-text-button-primary);
  transition: background-color 0.2s ease;
}
.content-filters button[type="submit"]:hover {
  background-color: var(--color-button-primary-hover-bg);
}
.content-filters a.button.clear {
  background-color: var(--color-button-secondary-bg);
  color: var(--color-button-secondary-text);
  margin-left: 0;
}
.content-filters a.button.clear:hover {
  background-color: var(--color-button-secondary-hover-bg);
  text-decoration: none;
}

/* Tables */
.table-container {
  overflow-x: auto;
  /* margin-bottom: 20px; */
  border: 1px solid var(--color-border-medium);
  border-radius: 4px;
}
table {
  border-collapse: collapse;
  width: 100%;
  background-color: var(--color-bg-card);
  border: none; /* Border now on container */
  color: var(--color-text-primary);
}
th,
td {
  border: none;
  border-bottom: 1px solid var(--color-border-medium);
  padding: 8px 10px;
  text-align: left;
  vertical-align: top;
  white-space: nowrap;
}
thead tr:first-child th {
  border-top: none;
}
tbody tr:last-child td {
  border-bottom: none;
}
th {
  background-color: var(--color-bg-table-header);
  color: var(--color-text-heading);
  font-weight: bold;
  position: sticky;
  top: 0;
}
td:first-child {
  font-weight: 500;
}
tbody tr:nth-child(odd) {
  background-color: var(--color-bg-table-row-alt);
}
tbody tr:hover {
  background-color: var(--color-bg-row-hover);
  color: var(--color-text-secondary);
}
td small {
  color: var(--color-text-subtle);
  display: block;
  line-height: 1.2;
}

/* Action Buttons */
.button,
.actions a,
.action-add,
button.action-delete {
  display: inline-block;
  padding: 6px 12px;
  font-size: 0.9em;
  font-weight: bold;
  border-radius: 3px;
  text-decoration: none;
  cursor: pointer;
  border: none;
  text-align: center;
  transition: opacity 0.2s ease, background-color 0.2s ease;
  line-height: 1.3;
}
.button:hover,
.actions a:hover,
.action-add:hover,
button.action-delete:hover {
  opacity: 0.9;
  text-decoration: none;
}
.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
} /* Arrange actions */
.action-view {
  background-color: var(--color-action-view-bg);
  color: var(--color-action-view-text);
  &:hover {
    background-color: var(--color-action-view-bg);
    color: var(--color-action-view-text);
  }
}
.action-edit {
  background-color: var(--color-action-edit-bg);
  color: var(--color-action-edit-text);
  &:hover {
    background-color: var(--color-action-edit-bg);
    color: var(--color-action-edit-text);
  }
}
.action-delete {
  background-color: var(--color-action-delete-bg);
  color: var(--color-action-delete-text);
  &:hover {
    background-color: var(--color-action-delete-bg);
    color: var(--color-action-delete-text);
  }
} /* For link version */
button.action-delete {
  background-color: var(--color-action-delete-bg);
  color: var(--color-action-delete-text);
  &:hover {
    background-color: var(--color-action-delete-bg);
    color: var(--color-action-delete-text);
  }
} /* For button version */
.action-add {
  background-color: var(--color-action-add-bg);
  color: var(--color-action-add-text);
  &:hover {
    background-color: var(--color-action-add-bg);
    color: var(--color-action-add-text);
  }
  margin-bottom: 15px;
}
.button.cancel {
  background-color: var(--color-button-secondary-bg);
  color: var(--color-button-secondary-text);
  &:hover {
    background-color: var(--color-action-cancel-bg);
    color: var(--color-action-cancel-text);
  }
}
.button.disabled {
  background-color: var(--color-text-muted);
  color: var(--color-bg-primary);
  cursor: not-allowed;
  opacity: 0.7;
}
td .actions {
  flex-direction: row; /* Keep actions horizontal in table */
}
td .actions form {
  display: inline;
} /* Make delete form inline */

/* Cards */
.people-card-list,
.application-card-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 20px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.person-card,
.application-card {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border-medium);
  border-radius: 5px;
  padding: 15px;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}
.card-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px dashed var(--color-border-dark);
  padding-bottom: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
  gap: 10px;
}
.card-header h4 {
  margin: 0;
  font-size: 1.15em;
  color: var(--color-text-heading);
}
.card-header h4 a {
  color: inherit;
}
.person-card .card-header h3 small {
  font-size: 0.8em;
  color: var(--color-text-secondary);
  margin-left: 5px;
}
.person-card .app-count,
.application-card .app-count {
  font-size: 0.9em;
  font-weight: bold;
  color: var(--color-text-secondary);
  background-color: var(--color-bg-secondary);
  padding: 2px 6px;
  border-radius: 3px;
}
.application-card .application-name {
  display: flex;
  font-size: 1em;
  font-weight: bold;
  color: var(--color-text-secondary);
}
.application-card .application-name a {
  color: inherit;
}
.card-content p {
  margin: 0;
  font-size: 0.95em;
  display: flex;
  justify-content: space-between;
  line-height: 1.4;
  /* padding-bottom: 4px; */
  border-bottom: 1px dotted var(--color-border-dark);
}
.card-content p:last-child {
  border-bottom: none;
  margin-bottom: 0;
}
.card-content strong {
  color: var(--color-text-secondary);
  min-width: 80px;
  margin-right: 8px;
  flex-shrink: 0;
}
.card-content span {
  text-align: right;
  word-break: break-word;
}
.card-content span.school-list,
.card-content span.email-list {
  display: block;
  font-size: 0.9em;
  line-height: 1.3;
  color: var(--color-text-subtle);
}
.card-content span.email-list small {
  display: block;
}
.card-actions {
  margin-top: auto;
  padding-top: 10px;
  /* border-top: 1px solid var(--color-border-dark); */
  text-align: right;
}

/* 
.filter-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 15px 20px;
  align-items: end;
}
.context-sidebar .filter-form-grid {
  grid-template-columns: 1fr;
  gap: 15px;
} Override for sidebar */
/* Detail Sections */
.details {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: 15px 20px;
  align-items: start;
}
@media (max-width: 767px) {
  .details {
    grid-template-columns: 100%;
  }
}
.detail-section {
  grid-template-columns: 1fr;
  margin-bottom: 25px;
  padding: 20px;
  border: 1px solid var(--color-border-medium);
  border-radius: 4px;
  background-color: var(--color-bg-card);
  box-shadow: var(--shadow-sm);
}
.detail-section h3 {
  margin-top: 0;
  border-bottom: 1px solid var(--color-border-light);
  padding-bottom: 8px;
  color: var(--color-text-heading);
}
.detail-section p {
  margin: 8px 0;
  line-height: 1.6;
}
.detail-section strong {
  display: inline-block;
  min-width: 160px;
  color: var(--color-text-muted);
  margin-right: 5px;
  font-weight: 500;
}
.detail-section ul {
  padding-left: 20px;
}

/* Messages */
.message {
  padding: 12px 15px;
  margin-bottom: 20px;
  border: 1px solid transparent;
  border-radius: 4px;
}
.message.success {
  color: var(--color-msg-success-text);
  background-color: var(--color-msg-success-bg);
  border-color: var(--color-msg-success-border);
}
.message.error {
  color: var(--color-msg-error-text);
  background-color: var(--color-msg-error-bg);
  border-color: var(--color-msg-error-border);
}
.message.warning {
  color: var(--color-msg-warning-text);
  background-color: var(--color-msg-warning-bg);
  border-color: var(--color-msg-warning-border);
}
.message ul {
  margin-top: 8px;
  margin-bottom: 0;
  padding-left: 20px;
  font-size: 0.9em;
}

/* Standard Forms */
.standard-form {
  background-color: var(--color-bg-card);
  padding: 20px;
  border-radius: 4px;
  border: 1px solid var(--color-border-medium);
}
.standard-form .form-group {
  margin-bottom: 15px;
}
.standard-form label {
  display: block;
  margin-bottom: 5px;
  font-weight: bold;
  color: var(--color-text-secondary);
}
.standard-form input[type="text"],
.standard-form input[type="email"],
.standard-form input[type="password"],
.standard-form select,
.standard-form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--color-border-input);
  background-color: var(--color-bg-input);
  color: var(--color-text-input);
  border-radius: 3px;
  box-sizing: border-box;
}
.standard-form input:focus,
.standard-form select:focus,
.standard-form textarea:focus {
  outline: none;
  border-color: var(--color-border-accent);
  box-shadow: 0 0 0 2px var(--color-accent-focus-shadow);
}
.standard-form .checkbox-group label {
  display: inline-block;
  margin-left: 5px;
  font-weight: normal;
}
.standard-form .checkbox-group input[type="checkbox"] {
  width: auto;
  vertical-align: middle;
}
.standard-form small {
  color: var(--color-text-subtle);
  font-size: 0.9em;
}
.standard-form .form-actions {
  margin-top: 20px;
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}
.standard-form .form-actions button,
.standard-form .form-actions a.button {
  flex-grow: 0;
} /* Don't let form buttons grow */
.standard-form .form-actions a.button.cancel {
  background-color: var(--color-button-secondary-bg);
  color: var(--color-button-secondary-text);
}
.standard-form .form-actions a.button.cancel:hover {
  background-color: var(--color-button-secondary-hover-bg);
}

/* Footer */
footer {
  flex-shrink: 0;
  padding: 15px;
  text-align: center;
  color: var(--color-text-footer);
  font-size: 0.9em;
  background-color: var(--color-bg-footer);
  border-top: 1px solid var(--color-border-medium);
}

/* Login Page Specific */
.login-container {
  max-width: 400px;
  margin: 50px auto;
  padding: 30px;
  background-color: var(--color-bg-content-alt);
  border: 1px solid var(--color-border-medium);
  border-radius: 5px;
  box-shadow: var(--shadow-md);
  color: var(--color-text-primary);
}
.login-container h2 {
  text-align: center;
  margin-bottom: 20px;
  color: var(--color-text-heading);
}
.login-container form div {
  margin-bottom: 15px;
}
.login-container label {
  display: block;
  margin-bottom: 5px;
  color: var(--color-text-secondary);
  font-weight: bold;
}
.login-container input[type="text"],
.login-container input[type="password"] {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--color-border-input);
  border-radius: 3px;
  background-color: var(--color-bg-input);
  color: var(--color-text-input);
}
.login-container input:focus {
  outline: none;
  border-color: var(--color-border-accent);
  box-shadow: 0 0 0 2px var(--color-accent-focus-shadow);
  color: var(--color-text-input);
}
.login-container button {
  width: 100%;
  padding: 10px 15px;
  background-color: var(--color-button-primary-bg);
  color: var(--color-text-button-primary);
  border: none;
  border-radius: 3px;
  cursor: pointer;
  font-weight: bold;
  font-size: 1.1em;
}
.login-container button:hover {
  background-color: var(--color-button-primary-hover-bg);
}
.login-container .error-message {
  color: var(--color-msg-error-text);
  background-color: var(--color-msg-error-bg);
  border: 1px solid var(--color-msg-error-border);
  padding: 10px;
  margin-bottom: 15px;
  border-radius: 3px;
  text-align: center;
}

/* --- Pagination Styles --- */
.pagination {
  margin-top: 25px;
  margin-bottom: 15px;
  display: flex;
  justify-content: center; /* Center pagination block */
}
.pagination-list {
  display: inline-flex; /* Align items horizontally */
  list-style: none;
  padding: 0;
  margin: 0;
  border-radius: 4px;
  overflow: hidden; /* Clip rounded corners */
  border: 1px solid var(--color-border-dark);
}
.pagination-list li {
  margin: 0;
}
.pagination-list a,
.pagination-list span {
  display: inline-block;
  padding: 8px 12px;
  min-width: 40px; /* Ensure consistent button width */
  text-align: center;
  text-decoration: none;
  color: var(--color-text-secondary);
  background-color: var(--color-bg-card);
  border-left: 1px solid var(--color-border-dark);
  font-size: 0.9em;
  white-space: nowrap;
}
.pagination-list li:first-child a,
.pagination-list li:first-child span {
  border-left: none;
}
.pagination-list a:hover {
  background-color: var(--color-bg-tertiary);
  color: var(--color-text-link-hover);
  text-decoration: none;
}
.pagination-list span.is-current {
  background-color: var(--color-medium-blue);
  color: var(--color-text-light);
  font-weight: bold;
  cursor: default;
}
.pagination-list span.is-disabled {
  color: var(--color-text-subtle);
  cursor: not-allowed;
  background-color: var(--color-bg-secondary);
}
.pagination-ellipsis {
  color: var(--color-text-subtle);
}
.uw-card-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
  width: 100%;
}
.uw-card {
  flex-basis: calc(33% - calc(10px / 2));
  display: flex;
  flex-direction: column;
  background-color: #005596;
}
@media (max-width: 1024px) {
  .uw-card {
    flex-basis: 100%;
  }
}
.uw-card-header {
  display: flex;
  flex-direction: row;
  /* flex-basis: 25%; */
  /* flex-grow: 1; */
  gap: 5px;
  padding: 10px;
  background-color: #004a80;
  align-content: baseline;
  justify-content: start;
  & h4 {
    margin: 0px;
    padding: 0px;
  }
}
.uw-card-body {
  /* flex-basis: 50%; */
  flex-grow: 1;
  display: flex;
  flex-direction: row;
  justify-content: start;
  align-content: baseline;
  padding: 10px;
  gap: 5px;
  flex-wrap: wrap;
}
.uw-card-data {
  background-color: #002b51;
  color: white;
  padding: 2px 10px;
  border-radius: 5px;
}
/* Add to src/style.css */

.content-filters select[multiple] {
  height: auto; /* Override fixed height */
  min-height: 100px; /* Example: Make it taller */
  background-color: var(--color-bg-input); /* Ensure background matches */
  color: var(--color-text-input);
  padding: 8px; /* Adjust padding if needed */
}

.content-filters select[multiple] option {
  padding: 4px 6px; /* Spacing for options */
  color: var(--color-text-input); /* Ensure text color */
  /* Target selected options if needed */
  /* background-color: ... */
}
/* Style the helper text */
.filter-group small {
  display: block;
  font-size: 0.8em;
  color: var(--color-text-subtle);
  margin-top: 4px;
}
.change-log-filters {
  margin-bottom: 10px;
  font-size: 0.9em;
}

.change-log-filters strong {
  padding: 2px 5px;
  background-color: var(--color-bg-secondary);
  color: var(--color-text-secondary);
  border-radius: 3px;
}

.change-type-create {
  color: var(--color-msg-success-text);
  font-weight: bold;
}

.change-type-update {
  color: var(--color-msg-warning-text);
}

.table-container {
  max-width: 100%;
}

ul.change-details {
  padding-left: 0;
  list-style: none;
  margin: 0;
}

ul.change-details li {
  border-bottom: 1px dotted var(--color-border-dark);
  padding: 2px 0;
  margin-bottom: 2px;
  font-size: 0.9em;
}

ul.change-details li:last-child {
  border-bottom: none;
}

ul.change-details strong {
  color: var(--color-text-heading);
  min-width: 100px;
  display: inline-block;
}

.old-value {
  color: var(--color-text-subtle);
  text-decoration: line-through;
  margin-right: 5px;
}

.new-value {
  color: var(--color-msg-success-text);
  background-color: rgba(21, 87, 36, 0.3);
  padding: 0 2px;
  border-radius: 2px;
  margin-left: 5px;
}

body.dark .new-value {
  color: #aaffaa;
}

/* Adjust dark theme new value color */
.button.small {
  font-size: 0.8em;
  padding: 4px 8px;
  height: auto;
}

ul.compact-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

ul.compact-list li {
  font-size: 0.9em;
  margin-bottom: 5px;
  padding-bottom: 5px;
  border-bottom: 1px solid var(--color-border-dark);
}

ul.compact-list li:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

ul.compact-list li small {
  color: var(--color-text-subtle);
}
