/* Components styles */

/*
 * IMPORTANT FOR LLMS: 
 * Always use CSS variables from variables.css instead of hardcoded colors.
 * Use var(--variable-name) syntax for colors, spacing, fonts, etc.
 * If a variable doesn't exist, add it to variables.css first.
 * This ensures theme consistency and maintainability.
 */

/* Card styling */
.card {
    box-shadow: var(--card-shadow);
    border-radius: var(--border-radius);
    border: var(--card-border);
    margin-bottom: var(--spacing-lg);
    background-color: var(--card-bg);
    color: var(--text-color);
    transition: all var(--transition-speed) var(--transition-timing);
    /* position: relative; */ /* Avoid general relative positioning on all cards unless necessary */
  }
  
  .card:hover {
    /* transform: translateY(-3px); */ /* Temporarily remove to test stacking context issue */
    box-shadow: 0 15px 25px rgba(0,0,0,.1);
  }
  
  .card-header {
    border-radius: var(--border-radius) var(--border-radius) 0 0 !important;
    font-weight: var(--font-weight-bold);
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--card-header-bg);
    border-bottom: 1px solid rgba(var(--primary-color-rgb), .1);
    color: var(--text-color);
  }
  
  .card-body {
    padding: var(--spacing-lg);
    overflow: visible;
  }
  
  .card-footer {
    border-radius: 0 0 var(--border-radius) var(--border-radius) !important;
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--card-footer-bg);
    border-top: 1px solid rgba(var(--primary-color-rgb), .08);
    color: var(--text-color);
  }
  
  /* Colored card variations */
  .card.primary-card {
    border-top: 4px solid var(--primary-color);
  }
  .card.success-card {
    border-top: 4px solid var(--success-color);
  }
  .card.danger-card {
    border-top: 4px solid var(--danger-color);
  }
  .card.warning-card {
    border-top: 4px solid var(--warning-color);
  }
  .card.info-card {
    border-top: 4px solid var(--info-color);
  }
  
  /* Model card specific styling */
  .model-card {
    transition: all var(--transition-speed) var(--transition-timing);
    height: 100%;
    border-radius: var(--border-radius);
    border: none;
  }
  
  /* Model Icon Theme Switching */
  .model-icon .model-icon-dark {
    display: none;
  }
  .model-icon .model-icon-light {
    display: inline-block;
  }
  html.dark-theme .model-icon .model-icon-dark,
  html.auto-dark-theme .model-icon .model-icon-dark {
    display: inline-block;
  }
  html.auto-dark-theme .model-icon .model-icon-light,
    html.dark-theme .model-icon .model-icon-light {
      display: none;
  }
  
  .model-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(0,0,0,.15);
  }
  
  .model-card .card-img-top {
    height: 160px;
    object-fit: cover;
    background-color: rgba(var(--primary-color-rgb), .1);
  }
  
  .context-length {
    font-size: var(--font-size-sm);
    color: var(--secondary-color);
    display: inline-block;
    padding: .25rem .5rem;
    background-color: rgba(var(--secondary-color-rgb), .1);
    border-radius: 4px;
  }
  
  .model-description {
    height: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    line-height: 1.5;
    color: var(--secondary-color);
  }
  
  /* Button styling */
  .btn {
    padding: .5rem 1.25rem;
    border-radius: var(--border-radius-sm);
    font-weight: var(--font-weight-bold);
    transition: all var(--transition-speed) var(--transition-timing);
    text-transform: none;
    letter-spacing: .2px;
    position: relative;
    overflow: hidden;
    border: none;
  }
  .btn:active {
    transform: translateY(1px);
    box-shadow: none;
  }
  .btn-lg {
    padding: .75rem 1.5rem;
    font-size: 1.1rem;
  }
  .btn-sm {
    padding: .25rem .75rem;
    font-size: .85rem;
  }
  
  /* Button variants */
  .btn-primary {
    background-color: var(--primary-color);
    color: var(--text-on-primary);
    box-shadow: 0 4px 6px rgba(var(--primary-color-rgb), .25);
  }
  .btn-primary:hover, .btn-primary:focus {
    background-color: rgba(var(--primary-color-rgb), .85);
    color: var(--text-on-primary);
    transform: translateY(-2px);
  }
  
  .btn-secondary {
    background-color: var(--button-secondary-bg);
    color: var(--button-secondary-text);
    border-color: var(--button-secondary-border);
    box-shadow: 0 4px 6px rgba(var(--secondary-color-rgb), .25);
  }
  .btn-secondary:hover, .btn-secondary:focus {
    background-color: var(--button-secondary-hover-bg, var(--button-secondary-bg));
    color: var(--button-secondary-hover-text, var(--button-secondary-text));
    border-color: var(--button-secondary-hover-border, var(--button-secondary-border));
    transform: translateY(-2px);
    box-shadow: 0 4px 6px rgba(var(--secondary-color-rgb), .25);
  }
  .dark-theme .btn-secondary,
  :root.auto-dark-theme .btn-secondary {
    background-color: var(--button-secondary-bg);
    color: var(--button-secondary-text);
    border-color: var(--button-secondary-border);
    box-shadow: none;
  }
  .dark-theme .btn-secondary:hover,
  :root.auto-dark-theme .btn-secondary:hover,
  .dark-theme .btn-secondary:focus,
  :root.auto-dark-theme .btn-secondary:focus {
    background-color: var(--button-secondary-hover-bg, var(--button-secondary-bg));
    color: var(--button-secondary-hover-text, var(--button-secondary-text));
    border-color: var(--button-secondary-hover-border, var(--button-secondary-border));
  }
  
  /* Success, Danger, Warning, Info buttons all follow the same pattern */
  .btn-success {
    background-color: var(--success-color);
    color: var(--text-on-success);
    box-shadow: 0 4px 6px rgba(var(--success-color-rgb), .25);
  }
  .btn-success:hover, .btn-success:focus {
    background-color: rgba(var(--success-color-rgb), .85);
    color: var(--text-on-success);
    transform: translateY(-2px);
  }
  
  .btn-danger {
    background-color: var(--danger-color);
    color: var(--text-on-danger);
    box-shadow: 0 4px 6px rgba(var(--danger-color-rgb), .25);
  }
  .btn-danger:hover, .btn-danger:focus {
    background-color: rgba(var(--danger-color-rgb), .85);
    color: var(--text-on-danger);
    transform: translateY(-2px);
  }
  
  .btn-warning {
    background-color: var(--warning-color);
    color: var(--text-on-warning);
    box-shadow: 0 4px 6px rgba(var(--warning-color-rgb), .25);
  }
  .btn-warning:hover, .btn-warning:focus {
    background-color: rgba(var(--warning-color-rgb), .85);
    color: var(--text-on-warning);
    transform: translateY(-2px);
  }
  
  .btn-info {
    background-color: var(--info-color);
    color: var(--text-on-info);
    box-shadow: 0 4px 6px rgba(var(--info-color-rgb), .25);
  }
  .btn-info:hover, .btn-info:focus {
    background-color: rgba(var(--info-color-rgb), .85);
    color: var(--text-on-info);
    transform: translateY(-2px);
  }
  
  /* Light button */
  .btn-light {
    background-color: var(--button-light-bg);
    color: var(--button-light-text);
    border-color: var(--button-light-border);
    box-shadow: 0 4px 6px rgba(var(--secondary-color-rgb), .25);
  }
  .btn-light:hover, .btn-light:focus {
    background-color: var(--button-light-hover-bg, var(--button-light-bg));
    color: var(--button-light-hover-text, var(--button-light-text));
    border-color: var(--button-light-hover-border, var(--button-light-border));
    transform: translateY(-2px);
  }
  .dark-theme .btn-light,
  :root.auto-dark-theme .btn-light {
    background-color: var(--button-light-bg);
    color: var(--button-light-text);
    border-color: var(--button-light-border);
    box-shadow: 0 4px 6px rgba(var(--secondary-color-rgb), .25);
  }
  .dark-theme .btn-light:hover,
  :root.auto-dark-theme .btn-light:hover,
  .dark-theme .btn-light:focus,
  :root.auto-dark-theme .btn-light:focus {
    background-color: var(--button-light-hover-bg, var(--button-light-bg));
    color: var(--button-light-hover-text, var(--button-light-text));
    border-color: var(--button-light-hover-border, var(--button-light-border));
    transform: translateY(-2px);
  }
  
  /* Outline buttons */
  .btn-outline-primary {
    border: 2px solid var(--primary-color);
    color: var(--primary-color);
    background-color: transparent;
  }
  .btn-outline-primary:hover {
    background-color: var(--primary-color);
    color: var(--text-on-primary);
    transform: translateY(-2px);
  }
  
  /* Common outline button pattern for all variants */
  .btn-outline-secondary {
    border: 2px solid var(--secondary-color);
    color: var(--secondary-color);
    background-color: transparent;
  }
  .btn-outline-secondary:hover {
    background-color: var(--secondary-color);
    color: var(--text-on-secondary);
    transform: translateY(-2px);
  }
  
  .btn-outline-success, .btn-outline-danger, .btn-outline-warning, .btn-outline-info {
    border: 2px solid;
    background-color: transparent;
  }
  .btn-outline-success {
    border-color: var(--success-color);
    color: var(--success-color);
  }
  .btn-outline-danger {
    border-color: var(--danger-color);
    color: var(--danger-color);
  }
  .btn-outline-warning {
    border-color: var(--warning-color);
    color: var(--warning-color);
  }
  .btn-outline-info {
    border-color: var(--info-color);
    color: var(--info-color);
  }
  .btn-outline-success:hover, .btn-outline-danger:hover, .btn-outline-warning:hover, .btn-outline-info:hover {
    transform: translateY(-2px);
  }
  .btn-outline-success:hover {
    background-color: var(--success-color);
    color: var(--text-on-success);
  }
  .btn-outline-danger:hover {
    background-color: var(--danger-color);
    color: var(--text-on-danger);
  }
  .btn-outline-warning:hover {
    background-color: var(--warning-color);
    color: var(--text-on-warning);
  }
  .btn-outline-info:hover {
    background-color: var(--info-color);
    color: var(--text-on-info);
  }
  
  /* Outline light button (for LIGHT backgrounds) */
  .btn-outline-light {
    --bs-btn-color: var(--dark-color);
    --bs-btn-border-color: var(--dark-color);
    --bs-btn-hover-color: var(--text-on-dark);
    --bs-btn-hover-bg: var(--dark-color);
    --bs-btn-hover-border-color: var(--dark-color);
    --bs-btn-active-color: var(--text-on-dark);
    --bs-btn-active-bg: var(--dark-color);
    --bs-btn-active-border-color: var(--dark-color);
    --bs-btn-disabled-color: var(--secondary-color);
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: var(--secondary-color);
  }
  .dark-theme .btn-outline-light,
  :root.auto-dark-theme .btn-outline-light {
    color: var(--light-color);
    border-color: var(--light-color);
  }
  .dark-theme .btn-outline-light:hover,
  :root.auto-dark-theme .btn-outline-light:hover {
    color: var(--dark-color);
    background-color: var(--light-color);
    border-color: var(--light-color);
  }
  
  .dark-theme .btn[title="Notifications"],
  html.auto-dark-theme .btn[title="Notifications"] {
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
  }
  .dark-theme .btn[title="Notifications"]:hover,
  html.auto-dark-theme .btn[title="Notifications"]:hover {
    background-color: var(--subtle-bg-color);
    border-color: var(--border-color);
    color: var(--light-color);
  }
  
  /* Badge styling */
  .badge {
    font-weight: 500;
    text-transform: uppercase;
    font-size: .75rem;
    letter-spacing: .5px;
  }
  
  .badge-group, .badge-author, .badge-modality {
    color: white;
  }
  .badge-group { background-color: var(--badge-group-bg); }
  .badge-author { background-color: var(--badge-author-bg); }
  .badge-modality { background-color: var(--badge-modality-bg); }
  .badge-modality-output { 
    background-color: var(--badge-modality-output-bg); 
    color: white; 
  }
  
  .filter-badge {
    margin-right: .5rem;
    margin-bottom: .5rem;
    cursor: pointer;
    transition: all .2s ease;
    border-radius: 16px;
    padding: .35em .8em;
  }
  
  /* Price Tier Badges */
  .price-badge-0, .price-badge-1, .price-badge-2, 
  .price-badge-3, .price-badge-4, .price-badge-5,
  .price-badge-unknown {
    background-color: var(--price-badge-0-bg);
    color: var(--price-badge-0-text);
  }
  .price-badge-1 { background-color: var(--price-badge-1-bg); color: var(--price-badge-1-text); }
  .price-badge-2 { background-color: var(--price-badge-2-bg); color: var(--price-badge-2-text); }
  .price-badge-3 { background-color: var(--price-badge-3-bg); color: var(--price-badge-3-text); }
  .price-badge-4 { background-color: var(--price-badge-4-bg); color: var(--price-badge-4-text); }
  .price-badge-5 { background-color: var(--price-badge-5-bg); color: var(--price-badge-5-text); }
  .price-badge-unknown { background-color: var(--price-badge-unknown-bg); color: var(--price-badge-unknown-text); }
  
  /* Form controls */
  .form-control, .form-select {
    border-radius: var(--border-radius-sm);
    border: 1px solid var(--input-border-color);
    background-color: var(--subtle-bg-color);
    color: var(--input-color);
    transition: all var(--transition-speed) var(--transition-timing);
    font-size: var(--font-size-base);
  }
  .form-control:focus, .form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 .25rem rgba(var(--primary-color-rgb), .25);
    background-color: var(--input-bg);
    color: var(--input-color);
  }
  .form-control::placeholder, .form-select::placeholder {
    color: var(--input-placeholder-color);
    opacity: 1;
  }
  .dark-theme .form-control,
  .dark-theme .form-select,
  .dark-theme .input-group-text {
    background-color: var(--input-bg);
    color: var(--input-color);
    border-color: var(--input-border-color);
  }
  .dark-theme .form-select,
  :root.auto-dark-theme .form-select {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="none" stroke="%23e2e8f0" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-chevron-down" viewBox="0 0 24 24"><polyline points="6 9 12 15 18 9"/></svg>');
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 1em;
  }
  
  .form-label {
    margin-bottom: var(--spacing-sm);
    font-weight: var(--font-weight-bold);
    color: var(--text-color);
  }
  
  /* Input group styling */
  .input-group-text {
    background-color: var(--input-group-text-bg);
    color: var(--text-muted);
    border-color: var(--border-color);
  }
  .dark-theme .input-group-text,
  :root.auto-dark-theme .input-group-text {
    background-color: var(--input-group-text-bg);
    color: var(--text-muted);
    border-color: var(--border-color);
  }
  
  /* Form checkbox and switch styling for dark theme */
  .dark-theme .form-check-input[type="checkbox"],
  :root.auto-dark-theme .form-check-input[type="checkbox"] {
    background-color: var(--dark-color);
    border-color: var(--light-color);
  }
  .dark-theme .form-check-input[type="checkbox"]:checked,
  :root.auto-dark-theme .form-check-input[type="checkbox"]:checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
  }
  .dark-theme .form-switch .form-check-input,
  :root.auto-dark-theme .form-switch .form-check-input {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23e2e8f0'/%3e%3c/svg%3e"); 
  }
  .dark-theme .form-switch .form-check-input:checked,
  :root.auto-dark-theme .form-switch .form-check-input:checked {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e"); 
  }
  
  .dark-theme .form-switch .form-check-input::-webkit-slider-thumb,
  :root.auto-dark-theme .form-switch .form-check-input::-webkit-slider-thumb,
  .dark-theme .form-switch .form-check-input::-moz-range-thumb,
  :root.auto-dark-theme .form-switch .form-check-input::-moz-range-thumb {
    background-color: var(--light-color);
  }
  
  /* Table Styling */
  .table {
    width: 100%;
    margin-bottom: var(--spacing-lg);
    border-collapse: separate;
    border-spacing: 0;
    border-radius: var(--border-radius);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    color: var(--table-color);
    background-color: var(--table-bg);
    border: 1px solid var(--table-border-color);
    --bs-table-bg: var(--table-bg);
    --bs-table-color: var(--table-color);
    --bs-table-border-color: var(--table-border-color);
    --bs-table-color-state: var(--table-color);
    --bs-table-bg-state: transparent;
    --bs-table-striped-bg: var(--table-striped-bg);
    --bs-table-striped-color: var(--table-striped-color);
    --bs-table-active-bg: var(--table-active-bg);
    --bs-table-active-color: var(--table-active-color);
    --bs-table-hover-bg: var(--table-hover-bg);
    --bs-table-hover-color: var(--table-hover-color);
  }
  
  .table th, .table td {
    padding: var(--spacing-md);
    vertical-align: top;
    border-top: 1px solid var(--table-border-color);
    text-align: left;
    background-color: transparent;
  }
  
  .table thead th {
    vertical-align: bottom;
    border-bottom: 2px solid var(--table-border-color);
    background-color: var(--table-header-bg);
    color: var(--table-header-color);
    font-weight: var(--font-weight-bold);
  }
  
  .table caption {
    padding: var(--spacing-md);
    color: var(--text-muted);
    text-align: left;
    caption-side: bottom;
  }
  
  /* Table borders and radius */
  .table > :not(caption) > tr > td,
  .table > :not(caption) > tr > th {
    border-top: 1px solid var(--table-border-color);
  }
  .table > tbody > tr:first-child > td,
  .table > tbody > tr:first-child > th {
    border-top: none; 
  }
  .table > thead > tr:first-child > th:first-child {
    border-top-left-radius: var(--border-radius);
  }
  .table > thead > tr:first-child > th:last-child {
    border-top-right-radius: var(--border-radius);
  }
  .table > tbody > tr:last-child > td:first-child,
  .table > tfoot > tr:last-child > th:first-child {
    border-bottom-left-radius: var(--border-radius);
  }
  .table > tbody > tr:last-child > td:last-child,
  .table > tfoot > tr:last-child > th:last-child {
    border-bottom-right-radius: var(--border-radius);
  }
  
  /* Striped rows */
  .table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: var(--table-striped-bg);
    color: var(--table-striped-color);
  }
  
  /* Hover effect */
  .table-hover > tbody > tr:hover > * {
    background-color: var(--table-hover-bg);
    color: var(--table-hover-color);
  }
  
  /* Alert styling */
  .alert {
    border-radius: var(--border-radius);
    display: flex;
    align-items: flex-start;
    padding: 1rem 1.25rem;
    margin-bottom: var(--spacing-lg);
    border: none;
    box-shadow: var(--shadow-sm);
  }
  .alert::before {
    font-family: "bootstrap-icons";
    font-size: 1.25rem;
    margin-right: .75rem;
    line-height: inherit;
    flex-shrink: 0;
  }
  .alert .btn-close {
    margin-left: auto;
    align-self: flex-start;
    padding-left: .75rem;
  }
  .dark-theme .btn-close {
    --bs-btn-close-color: var(--light-color);
    --bs-btn-close-bg: var(--btn-close-bg, initial);
    color: var(--light-color) !important;
  }
  
  /* Alert variants */
  .alert-success, .alert-danger, .alert-warning, .alert-info {
    background-color: rgba(var(--success-color-rgb), .1);
    color: var(--success-color);
    border-left: 4px solid;
  }
  .alert-success { border-left-color: var(--success-color); }
  .alert-success::before { content: "\F270"; }
  .alert-danger { 
    background-color: rgba(var(--danger-color-rgb), .1);
    color: var(--danger-color); 
    border-left-color: var(--danger-color);
  }
  .alert-danger::before { content: "\F33A"; }
  .alert-warning { 
    background-color: rgba(var(--warning-color-rgb), .1);
    color: var(--alert-warning-text); 
    border-left-color: var(--warning-color);
  }
  .alert-warning::before { content: "\F33E"; }
  .alert-info { 
    background-color: rgba(var(--info-color-rgb), .1);
    color: var(--info-color); 
    border-left-color: var(--info-color);
  }
  .alert-info::before { content: "\F431"; }
  
  /* Filter components */
  .filter-sidebar {
    background-color: var(--light-color);
    padding: var(--spacing-lg);
    border-radius: var(--border-radius);
  }
  .filter-group { margin-bottom: var(--spacing-lg); }
  .active-filters { margin-bottom: var(--spacing-md); }
  .range-labels {
    display: flex;
    justify-content: space-between;
    margin-top: var(--spacing-xs);
    font-size: var(--font-size-sm);
    color: var(--secondary-color);
  }
  
  /* Ripple effect */
  .ripple {
    position: absolute;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, .5);
    transform: scale(0);
    animation: ripple-animation .6s linear;
    pointer-events: none;
  }
  @keyframes ripple-animation {
    to {
      transform: scale(4);
      opacity: 0;
    }
  }
  
  /* Dark theme validation rule form */
  .dark-theme .validation-rule-form {
    background-color: var(--card-bg);
    border: 1px solid var(--input-border-color);
  }
  .dark-theme .validation-rule-form .input-group-text {
    background-color: var(--input-group-text-bg);
    color: var(--light-color);
    border-color: var(--input-border-color);
  }
  
  /* Responsive Design - Media Queries */
  @media (max-width: 575.98px) {
    .card-body, .filter-sidebar, .model-card, .alert,
    .filter-group, .table td, .table th {
      padding: var(--spacing-sm);
    }
    .filter-sidebar { margin-bottom: var(--spacing-lg); }
    .model-card { margin-bottom: var(--spacing-md); }
    .btn {
      padding: .25rem .5rem;
      font-size: .875rem;
    }
    .filter-group {
      display: block;
      width: 100%;
    }
  }
  
  @media (min-width: 576px) and (max-width: 767.98px) {
    .card-body { padding: var(--spacing-md); }
  }
  
  @media (min-width: 1200px) {
    .card-body { padding: var(--spacing-xl); }
  }
  
  /* Dark theme adjustments for Bootstrap utility classes */
  .dark-theme .bg-primary-subtle { background-color: var(--bg-primary-subtle, rgba(var(--primary-color-rgb), .2)) !important; }
  .dark-theme .bg-secondary-subtle { background-color: var(--bg-secondary-subtle, rgba(var(--secondary-color-rgb), .2)) !important; }
  .dark-theme .bg-success-subtle { background-color: var(--bg-success-subtle, rgba(var(--success-color-rgb), .2)) !important; }
  .dark-theme .bg-danger-subtle { background-color: var(--bg-danger-subtle, rgba(var(--danger-color-rgb), .2)) !important; }
  .dark-theme .bg-warning-subtle { background-color: var(--bg-warning-subtle, rgba(var(--warning-color-rgb), .2)) !important; }
  .dark-theme .bg-info-subtle { background-color: var(--bg-info-subtle, rgba(var(--info-color-rgb), .2)) !important; }
  
  .dark-theme h1, .dark-theme h2, .dark-theme h3, 
  .dark-theme h4, .dark-theme h5, .dark-theme h6 {
    color: var(--light-color);
  }
  
  .dark-theme .border-primary { border-color: var(--primary-color) !important; }
  .dark-theme .text-muted { color: var(--text-muted) !important; }
  .dark-theme .bg-primary, :root.auto-dark-theme .bg-primary { color: var(--text-on-primary) !important; }
  
  /* Model icons and indicators */
  .model-icon-sm { width: 24px; height: 24px; }
  .model-icon-md { width: 48px; height: 48px; }
  
  .performance-indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-block;
    margin-right: var(--spacing-xs);
  }
  .performance-high { background-color: var(--success-color); }
  .performance-medium { background-color: var(--warning-color); }
  .performance-low { background-color: var(--danger-color); }
  
  /* View Chips */
  .benchmark-view-selector {
    display: flex;
    flex-direction: column;
    margin: 20px 0;
  }
  .view-chips {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
  }
  .view-chip {
    display: flex;
    align-items: center;
    padding: 8px 16px;
    border-radius: 20px;
    border: 2px solid var(--border-color);
    background: var(--card-bg);
    font-weight: 500;
    cursor: pointer;
    transition: all .2s ease;
    color: var(--text-muted);
  }
  .view-chip i {
    margin-right: 8px;
    font-size: 16px;
  }
  .view-chip.active {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--text-on-primary);
    box-shadow: 0 3px 10px rgba(var(--primary-color-rgb), .2);
  }
  .view-chip.active i { color: var(--text-on-primary); }
  
  .count-badge {
    margin-left: 8px;
    background: rgba(0,0,0,.1);
    border-radius: 12px;
    padding: 2px 8px;
    font-size: 12px;
    font-weight: bold;
  }
  .view-chip.active .count-badge { background: rgba(255,255,255,.2); }
  
  /* Editable/Sortable table styles */
  .editable-cell { cursor: text; }
  .drag-handle { cursor: grab; }
  .step-row.sortable-ghost {
    background-color: var(--subtle-bg-color);
    opacity: .7;
  }
  .dark-theme .step-row.sortable-ghost,
  :root.auto-dark-theme .step-row.sortable-ghost {
    background-color: var(--subtle-bg-color);
  }
  
  /* Pagination Dark Mode */
  .dark-theme .pagination .page-link,
  html.auto-dark-theme .pagination .page-link {
    background-color: var(--card-bg);
    border-color: var(--border-color);
    color: var(--light-color);
  }
  .dark-theme .pagination .page-item.disabled .page-link,
  html.auto-dark-theme .pagination .page-item.disabled .page-link {
    background-color: var(--dark-color);
    border-color: var(--border-color);
    color: var(--text-muted);
  }
  .dark-theme .pagination .page-item.active .page-link,
  html.auto-dark-theme .pagination .page-item.active .page-link {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--text-on-primary);
  }
  .dark-theme .pagination .page-link:hover,
  html.auto-dark-theme .pagination .page-link:hover {
    background-color: var(--subtle-bg-hover);
    color: var(--primary-color);
    border-color: var(--primary-color);
  }
  
  /* Nav Tabs Dark Theme */
  .dark-theme .nav-tabs,
  :root.auto-dark-theme .nav-tabs { border-bottom-color: var(--border-color); }
  .dark-theme .nav-tabs .nav-link,
  :root.auto-dark-theme .nav-tabs .nav-link {
    color: var(--text-muted);
    border-color: transparent;
  }
  .dark-theme .nav-tabs .nav-link:hover,
  :root.auto-dark-theme .nav-tabs .nav-link:hover {
    color: var(--primary-color);
    background-color: var(--subtle-bg-hover);
  }
  .dark-theme .nav-tabs .nav-link.active,
  :root.auto-dark-theme .nav-tabs .nav-link.active {
    color: var(--primary-color);
    background-color: transparent;
    border-color: var(--border-color) var(--border-color) transparent;
    border-bottom: 2px solid var(--primary-color);
    font-weight: var(--font-weight-bold);
  }
  .dark-theme .nav-tabs .nav-link.disabled,
  :root.auto-dark-theme .nav-tabs .nav-link.disabled { color: var(--secondary-color); }
  
  /* Card header tabs */
  .dark-theme .card-header-tabs,
  :root.auto-dark-theme .card-header-tabs {
    margin-bottom: -.75rem;
    border-bottom: none;
  }
  .dark-theme .card-header-tabs .nav-link.active,
  :root.auto-dark-theme .card-header-tabs .nav-link.active {
    background-color: var(--card-bg);
    border-color: var(--border-color) var(--border-color) var(--card-bg);
    border-bottom: none;
  }
  
  /* User Profile Avatar */
  .profile-avatar-lg {
    width: 100px;
    height: 100px;
    font-size: 48px;
    font-weight: bold;
    line-height: 100px;
    text-align: center;
  }
  
  /* Notification Styling */
  .notification-unread { background-color: var(--subtle-bg-color); }
  .dark-theme .notification-unread,
  :root.auto-dark-theme .notification-unread {
    background-color: var(--notification-unread-bg, rgba(var(--primary-color-rgb), .1));
  }
  
  /* Card backgrounds */
  .card-body-subtle-bg { background-color: var(--subtle-bg-color); }
  
  /* Dropdown styling */
  .dropdown-menu .dropdown-item.disabled {
    color: var(--text-muted) !important;
    background-color: transparent !important;
    opacity: .6;
  }
  
  /* Misc */
  .json-schema-template-select {
    min-width: max-content;
    padding-right: 2.5rem;
  }
  
  /* JSON Schema Viewer */
  .json-schema-viewer {
    background-color: var(--subtle-bg-color);
    color: var(--dark-color);
    white-space: pre-wrap;
  }
  
  /* Attached Files Badges */
  .file-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7em;
    margin-top: 0.5em;
  }
  .file-badge {
    background: var(--file-badge-bg);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 0.4em 1.2em 0.4em 0.8em;
    display: flex;
    align-items: center;
    gap: 0.5em;
    font-size: 1em;
  }
  .file-badge .icon {
    color: var(--primary-color);
    margin-right: 0.5em;
  }
  .file-badge .action {
    color: var(--danger-color);
    cursor: pointer;
    font-size: 1.1em;
    margin-left: 0.5em;
    background: none;
    border: none;
  }
  
  .modal-content {
    background-color: var(--modal-bg) !important;
  }
  
/* Styles for action buttons that need to maintain their content width and prevent wrapping on larger screens */
.btn-action-responsive {
    white-space: nowrap;
    min-width: max-content;
}

/* Badge for execution counts */
.badge-execution-count {
    background-color: var(--light-color);
    color: var(--text-on-light);
}
  
.dark-theme input,
.dark-theme select,
.dark-theme textarea,
.dark-theme .form-control,
.dark-theme .form-select {
    color-scheme: dark;
}

.dark-theme .input-group-text .bi {
    color: var(--light-color);
}
  
/* Beta Badge */
.beta-badge {
    font-size: 0.75rem;
    font-weight: bold;
    padding: 0.2em 0.5em;
    border-radius: 0.25rem;
    background-color: var(--warning-color);
    color: var(--bs-dark);
    vertical-align: middle;
}

/* Dark theme adjustments if needed, assuming var(--bs-warning) and var(--bs-dark) adapt or are overridden */
  
/* Specific card type z-index management */
.validation-rules-card {
    position: relative; /* Creates a stacking context */
    z-index: 1;         /* Ensures it has a stacking context, but not aggressively high */
}
  