/**
 * @file
 * Styling for Majors, Degrees and Programs view
 * Design: Clean & Minimal
 */

/* ==========================================================================
   View Wrapper
   ========================================================================== */

.majors-degrees-programs-view-wrapper {
  max-width: 1400px;
  margin: 0 auto;
  padding: 40px 20px 60px;
}

/* ==========================================================================
   View Title
   ========================================================================== */

.majors-degrees-title {
  font-size: 2.5rem;
  font-weight: 600;
  color: #18453B;
  margin-bottom: 30px;
  padding-bottom: 15px;
  border-bottom: 2px solid #e0e0e0;
}

@media (max-width: 768px) {
  .majors-degrees-title {
    font-size: 2rem;
    margin-bottom: 20px;
  }
}

/* ==========================================================================
   Filters Section
   ========================================================================== */

.majors-degrees-filters {
  background: #ffffff;
  border: 1px solid #e0e0e0;
  border-radius: 0;
  padding: 30px;
  margin-bottom: 40px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.filters-header {
  margin-bottom: 15px;
}

.filters-title {
  font-size: 1.25rem;
  font-weight: 600;
  color: #333;
  margin: 0;
}

/* Better Exposed Filters Styling */
.majors-degrees-filters .bef-exposed-form {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: flex-end;
}

/* Remove collapsible/accordion behavior */
.majors-degrees-filters details,
.majors-degrees-filters .bef-collapsible-wrapper,
.majors-degrees-filters .fieldset-wrapper {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

.majors-degrees-filters details {
  display: block !important;
}

.majors-degrees-filters details > summary {
  display: none !important;
}

.majors-degrees-filters details[open] {
  display: block !important;
}

/* Ensure all filter items are visible */
.majors-degrees-filters .bef-filter-wrapper,
.majors-degrees-filters .form-item-wrapper {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  height: auto !important;
  overflow: visible !important;
}

.majors-degrees-filters .form-item {
  flex: 1 1 250px;
  margin: 0;
  display: block !important;
  visibility: visible !important;
}

.majors-degrees-filters label {
  display: block;
  font-weight: 600;
  font-size: 0.95rem;
  color: #555;
  margin-bottom: 8px;
}

/* Enhanced Select Dropdowns */
.majors-degrees-filters select {
  width: 100%;
  padding: 12px 16px;
  font-size: 1rem;
  color: #333;
  background-color: #fff;
  border: 1px solid #d0d0d0;
  border-radius: 0;
  transition: all 0.2s ease;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M10.293 3.293L6 7.586 1.707 3.293A1 1 0 00.293 4.707l5 5a1 1 0 001.414 0l5-5a1 1 0 10-1.414-1.414z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px;
  padding-right: 40px;
  cursor: pointer;
}

.majors-degrees-filters select:hover {
  border-color: #18453B;
}

.majors-degrees-filters select:focus {
  outline: none;
  border-color: #18453B;
  box-shadow: 0 0 0 3px rgba(24, 69, 59, 0.1);
}

/* Buttons */
.majors-degrees-filters .form-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 10px;
  width: 100%;
}

.majors-degrees-filters .form-actions .button,
.majors-degrees-filters .form-actions input[type="submit"],
.majors-degrees-filters .form-actions button {
  padding: 10px 24px;
  font-size: 1rem;
  font-weight: 500;
  border-radius: 0;
  cursor: pointer;
  transition: all 0.2s ease;
  border: 1px solid transparent;
}

/* Apply Button */
.majors-degrees-filters .form-actions input[type="submit"],
.majors-degrees-filters .form-actions .button--primary {
  background-color: #18453B;
  color: #ffffff;
  border-color: #18453B;
}

.majors-degrees-filters .form-actions input[type="submit"]:hover,
.majors-degrees-filters .form-actions .button--primary:hover {
  background-color: #113d34;
  border-color: #113d34;
}

/* Reset Button */
.majors-degrees-filters .form-actions .button--secondary,
.majors-degrees-filters .form-actions input[type="reset"] {
  background-color: #ffffff;
  color: #555;
  border-color: #d0d0d0;
}

.majors-degrees-filters .form-actions .button--secondary:hover,
.majors-degrees-filters .form-actions input[type="reset"]:hover {
  background-color: #f8f9fa;
  border-color: #999;
  color: #333;
}

/* Clear All Filters Button */
.clear-all-filters {
  background-color: #ffffff;
  color: #d32f2f;
  border-color: #d32f2f;
}

.clear-all-filters:hover {
  background-color: #d32f2f;
  color: #ffffff;
  border-color: #d32f2f;
}

/* Ensure filters display in a clean row */
.majors-degrees-filters .form--inline,
.majors-degrees-filters .views-exposed-form {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: flex-end;
}

.majors-degrees-filters fieldset {
  border: none;
  padding: 0;
  margin: 0;
  min-width: 0;
  flex: 1 1 250px;
}

.majors-degrees-filters fieldset legend {
  display: block;
  font-weight: 600;
  font-size: 0.95rem;
  color: #555;
  margin-bottom: 8px;
  padding: 0;
  float: none;
  width: 100%;
}

/* Hide any collapse/expand indicators */
.majors-degrees-filters .fieldset-legend:after,
.majors-degrees-filters .collapse-indicator,
.majors-degrees-filters summary::-webkit-details-marker,
.majors-degrees-filters summary::marker {
  display: none !important;
  content: none !important;
}

/* Mobile Filters */
@media (max-width: 768px) {
  .majors-degrees-filters {
    padding: 20px;
  }

  .majors-degrees-filters .bef-exposed-form,
  .majors-degrees-filters .form--inline,
  .majors-degrees-filters .views-exposed-form {
    flex-direction: column;
    gap: 15px;
  }

  .majors-degrees-filters .form-item,
  .majors-degrees-filters fieldset {
    flex: 1 1 100%;
    width: 100%;
  }

  .majors-degrees-filters .form-actions {
    flex-direction: column;
    gap: 10px;
  }

  .majors-degrees-filters .form-actions .button,
  .majors-degrees-filters .form-actions input[type="submit"],
  .majors-degrees-filters .form-actions button {
    width: 100%;
  }
}

/* ==========================================================================
   Results Info Section
   ========================================================================== */

.view-results-info {
  margin-bottom: 30px;
  padding: 18px 24px;
  background: #f8f9fa;
  border-radius: 0;
  border-left: 4px solid #18453B;
}

.results-count {
  margin: 0;
  font-size: 1rem;
  color: #555;
  font-weight: 500;
}

.results-text {
  color: #333;
}

/* ==========================================================================
   Table Styling
   ========================================================================== */

.majors-degrees-results {
  margin-bottom: 50px;
}

.results-table-wrapper {
  background: #ffffff;
  border: 1px solid #e0e0e0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.majors-degrees-table-wrapper {
  width: 100%;
  overflow-x: auto;
}

.majors-degrees-table {
  width: 100%;
  margin: 0;
  border-collapse: collapse;
  background: #ffffff;
}

/* Table Header */
.majors-degrees-table thead,
.table thead,
table.table thead {
  background-color: #18453B !important;
  border-bottom: 2px solid #18453B;
}

.majors-degrees-table thead th,
.table thead th,
table.table thead th {
  padding: 24px 24px !important;
  text-align: left;
  font-weight: 600;
  font-size: 0.95rem;
  color: #ffffff !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

/* Make all column headers bold and styled with green background */
.majors-degrees-table thead th#view-title-table-column,
.majors-degrees-table thead th.views-field-title,
.majors-degrees-table thead th#view-field-mdp-program-level-table-column,
.majors-degrees-table thead th.views-field-field-mdp-program-level,
.majors-degrees-table thead th#view-field-mdp-format-table-column,
.majors-degrees-table thead th.views-field-field-mdp-format,
.majors-degrees-table thead th#view-field-mdp-academic-department-table-column,
.majors-degrees-table thead th.views-field-field-mdp-academic-department,
.table thead th#view-title-table-column,
.table thead th.views-field-title,
.table thead th#view-field-mdp-program-level-table-column,
.table thead th.views-field-field-mdp-program-level,
.table thead th#view-field-mdp-format-table-column,
.table thead th.views-field-field-mdp-format,
.table thead th#view-field-mdp-academic-department-table-column,
.table thead th.views-field-field-mdp-academic-department,
table.table thead th#view-title-table-column,
table.table thead th.views-field-title,
table.table thead th#view-field-mdp-program-level-table-column,
table.table thead th.views-field-field-mdp-program-level,
table.table thead th#view-field-mdp-format-table-column,
table.table thead th.views-field-field-mdp-format,
table.table thead th#view-field-mdp-academic-department-table-column,
table.table thead th.views-field-field-mdp-academic-department,
table.table thead th.views-field.views-field-title {
  font-weight: 700 !important;
  font-size: 1rem !important;
  color: #ffffff !important;
  background-color: #18453B !important;
  padding-top: 24px !important;
  padding-bottom: 24px !important;
}

.majors-degrees-table thead th#view-title-table-column a,
.majors-degrees-table thead th.views-field-title a,
.majors-degrees-table thead th#view-field-mdp-program-level-table-column a,
.majors-degrees-table thead th.views-field-field-mdp-program-level a,
.majors-degrees-table thead th#view-field-mdp-format-table-column a,
.majors-degrees-table thead th.views-field-field-mdp-format a,
.majors-degrees-table thead th#view-field-mdp-academic-department-table-column a,
.majors-degrees-table thead th.views-field-field-mdp-academic-department a,
.table thead th#view-title-table-column a,
.table thead th.views-field-title a,
.table thead th#view-field-mdp-program-level-table-column a,
.table thead th.views-field-field-mdp-program-level a,
.table thead th#view-field-mdp-format-table-column a,
.table thead th.views-field-field-mdp-format a,
.table thead th#view-field-mdp-academic-department-table-column a,
.table thead th.views-field-field-mdp-academic-department a,
table.table thead th#view-title-table-column a,
table.table thead th.views-field-title a,
table.table thead th#view-field-mdp-program-level-table-column a,
table.table thead th.views-field-field-mdp-program-level a,
table.table thead th#view-field-mdp-format-table-column a,
table.table thead th.views-field-field-mdp-format a,
table.table thead th#view-field-mdp-academic-department-table-column a,
table.table thead th.views-field-field-mdp-academic-department a {
  color: #ffffff !important;
  font-weight: 700 !important;
}

/* Sortable Headers */
.majors-degrees-table thead th.is-active,
.table thead th.is-active,
table.table thead th.is-active {
  background-color: #113d34 !important;
  color: #ffffff !important;
}

.majors-degrees-table thead th a,
.table thead th a,
table.table thead th a {
  color: #ffffff !important;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color 0.2s ease;
}

.majors-degrees-table thead th a:hover,
.table thead th a:hover,
table.table thead th a:hover {
  color: #63b3a2 !important;
}

/* Sort Indicators - Hide default Drupal sort icons */
.majors-degrees-table thead th .tablesort,
.table thead th .tablesort,
table.table thead th .tablesort {
  display: none !important;
}

/* Add custom white arrow sort icons using ::after pseudo-element */
.majors-degrees-table thead th a::after,
.table thead th a::after,
table.table thead th a::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-left: 8px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 5v14'/%3E%3Cpath d='m19 12-7 7-7-7'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 0.6;
  transition: opacity 0.2s ease;
  flex-shrink: 0;
}

.majors-degrees-table thead th a:hover::after,
.table thead th a:hover::after,
table.table thead th a:hover::after {
  opacity: 1;
}

/* Active/sorted column - ascending (up arrow) */
.majors-degrees-table thead th.is-active a::after,
.table thead th.is-active a::after,
table.table thead th.is-active a::after {
  opacity: 1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 19V5'/%3E%3Cpath d='m5 12 7-7 7 7'/%3E%3C/svg%3E");
}

/* Active/sorted column - descending (down arrow) */
.majors-degrees-table thead th.is-active[aria-sort="descending"] a::after,
.table thead th.is-active[aria-sort="descending"] a::after,
table.table thead th.is-active[aria-sort="descending"] a::after,
.majors-degrees-table thead th[aria-sort="descending"] a::after,
.table thead th[aria-sort="descending"] a::after,
table.table thead th[aria-sort="descending"] a::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 5v14'/%3E%3Cpath d='m19 12-7 7-7-7'/%3E%3C/svg%3E");
}

/* Table Body */
.majors-degrees-table tbody tr {
  border-bottom: 1px solid #e0e0e0;
  transition: background-color 0.2s ease;
}

.majors-degrees-table tbody tr:hover {
  background-color: #f8f9fa;
}

.majors-degrees-table tbody tr:last-child {
  border-bottom: none;
}

.majors-degrees-table tbody td,
.table tbody td,
table.table tbody td {
  padding: 24px 24px !important;
  font-size: 1rem;
  color: #000 !important;
  vertical-align: middle;
}

/* Program Title (first column) */
.majors-degrees-table tbody td.views-field-title,
.table tbody td.views-field-title,
table.table tbody td.views-field-title {
  font-weight: 700;
  color: #000;
  padding-top: 24px !important;
  padding-bottom: 24px !important;
}

.majors-degrees-table tbody td.views-field-title a,
.table tbody td.views-field-title a,
table.table tbody td.views-field-title a,
.majors-degrees-table tbody td.views-field.views-field-title a,
.table tbody td.views-field.views-field-title a {
  color: #000 !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px;
  transition: color 0.2s ease;
}

.majors-degrees-table tbody td.views-field-title a:hover,
.table tbody td.views-field-title a:hover,
table.table tbody td.views-field-title a:hover,
.majors-degrees-table tbody td.views-field.views-field-title a:hover,
.table tbody td.views-field.views-field-title a:hover {
  color: #18453B !important;
  text-decoration: underline !important;
}

.majors-degrees-table tbody td.views-field-title a:focus,
.table tbody td.views-field-title a:focus,
table.table tbody td.views-field-title a:focus {
  outline: 2px solid #18453B !important;
  outline-offset: 2px !important;
}

/* Empty State */
.view-empty {
  padding: 40px 20px;
  text-align: center;
  color: #777;
  font-size: 1.1rem;
  background: #f8f9fa;
  border-radius: 0;
  border: 1px dashed #d0d0d0;
}

/* ==========================================================================
   Mobile Responsive Table
   ========================================================================== */

@media (max-width: 768px) {
  .majors-degrees-table-wrapper {
    border: none;
    border-radius: 0;
  }

  .majors-degrees-table thead {
    display: none;
  }

  .majors-degrees-table tbody,
  .majors-degrees-table tr,
  .majors-degrees-table td {
    display: block;
  }

  .majors-degrees-table tbody tr {
    margin-bottom: 15px;
    border: 1px solid #e0e0e0;
    border-radius: 0;
    padding: 15px;
    background: #ffffff;
  }

  .majors-degrees-table tbody tr:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }

  .majors-degrees-table tbody td {
    padding: 10px 0;
    border-bottom: 1px solid #f0f0f0;
    display: flex;
    justify-content: space-between;
    align-items: start;
  }

  .majors-degrees-table tbody td:last-child {
    border-bottom: none;
  }

  /* Show label on mobile using data-label attribute */
  .majors-degrees-table tbody td::before {
    content: attr(data-label);
    font-weight: 600;
    color: #777;
    margin-right: 10px;
    flex-shrink: 0;
    min-width: 120px;
  }

  .majors-degrees-table tbody td.views-field-title::before {
    content: "Program: ";
  }
}

/* ==========================================================================
   Pager Styling
   ========================================================================== */

.view-pager {
  margin-top: 40px;
  padding-top: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-top: 1px solid #e0e0e0;
}

.view-pager .pager {
  display: flex;
  gap: 8px;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.view-pager .pager__item {
  margin: 0;
}

.view-pager .pager__item a,
.view-pager .pager__item span {
  display: inline-block;
  padding: 10px 16px;
  border: 1px solid #d0d0d0;
  border-radius: 0;
  background: #ffffff;
  color: #555;
  text-decoration: none;
  transition: all 0.2s ease;
  font-size: 0.95rem;
  min-width: 44px;
  text-align: center;
}

.view-pager .pager__item a:hover {
  background: #18453B;
  color: #ffffff;
  border-color: #18453B;
}

.view-pager .pager__item.is-active span {
  background: #18453B;
  color: #ffffff;
  border-color: #18453B;
  font-weight: 600;
}

/* ==========================================================================
   Loading States
   ========================================================================== */

.majors-degrees-view-loading {
  opacity: 0.6;
  pointer-events: none;
  position: relative;
}

.majors-degrees-view-loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40px;
  height: 40px;
  margin: -20px 0 0 -20px;
  border: 3px solid #f3f3f3;
  border-top: 3px solid #18453B;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* ==========================================================================
   Button Field Styling
   ========================================================================== */

/* Button field container */
.views-field.views-field-field-majors-degree-button,
.sidebar-second .views-field.views-field-field-majors-degree-button {
  margin: 0;
  padding: 0;
}

.views-field.views-field-field-majors-degree-button .field-content,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content {
  margin: 0;
  padding: 0;
}

.views-field.views-field-field-majors-degree-button .field-content .item-list,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list {
  margin: 0;
  padding: 0;
}

/* Remove list styling */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.views-field.views-field-field-majors-degree-button .field-content .item-list ul li,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Button link styling - All links in the button field */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a,
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link {
  display: inline-block !important;
  padding: 10px !important;
  padding-left: 30px !important;
  padding-right: 30px !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  text-align: center;
  text-decoration: none !important;
  white-space: nowrap;
  vertical-align: middle;
  cursor: pointer;
  user-select: none;
  border: 1px solid transparent !important;
  border-radius: 0 !important;
  transition: all 0.3s ease-in-out;

  /* Primary MSU Green Button */
  background-color: #113d34 !important;
  color: #ffffff !important;
  line-height: 1.5 !important;
}

.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:hover,
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:focus,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:hover,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:focus,
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link:hover,
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link:focus,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link:hover,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link:focus {
  background-color: #113d34 !important;
  border-color: transparent !important;
  color: #63b3a2 !important;
  text-decoration: none !important;
}

.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:active,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:active,
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link:active,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.external-link:active {
  background-color: #0d2f28 !important;
  border-color: transparent !important;
  color: #63b3a2 !important;
}

/* Focus state for accessibility */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:focus,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a:focus {
  outline: 3px solid #0d5c2e !important;
  outline-offset: 2px !important;
}

/* Hide the visually-hidden span inside external links from affecting button layout */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a .visually-hidden,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a .visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Secondary button variant (if needed, add class .btn-secondary to the link) */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-secondary,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-secondary {
  background-color: #ffffff !important;
  border-color: #000000 !important;
  color: #000000 !important;
}

.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-secondary:hover,
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-secondary:focus,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-secondary:hover,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-secondary:focus {
  background-color: #000000 !important;
  border-color: #000000 !important;
  color: #ffffff !important;
}

/* Outline button variant (if needed, add class .btn-outline to the link) */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-outline,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-outline {
  background-color: transparent !important;
  border-color: #d0d0d0 !important;
  color: #555 !important;
}

.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-outline:hover,
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-outline:focus,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-outline:hover,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-outline:focus {
  background-color: #f8f9fa !important;
  border-color: #18453B !important;
  color: #18453B !important;
}

/* Small button variant */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-sm,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-sm {
  padding: 8px !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  font-size: 0.875rem !important;
}

/* Large button variant */
.views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-lg,
.sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a.btn-lg {
  padding: 12px !important;
  padding-left: 36px !important;
  padding-right: 36px !important;
  font-size: 1.125rem !important;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .views-field.views-field-field-majors-degree-button .field-content .item-list ul,
  .sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul {
    flex-direction: column;
    gap: 8px;
  }

  .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a,
  .sidebar-second .views-field.views-field-field-majors-degree-button .field-content .item-list ul li a {
    width: 100%;
    text-align: center;
  }
}

/* ==========================================================================
   Accessibility Improvements
   ========================================================================== */

/* Focus styles */
.majors-degrees-table a:focus,
.majors-degrees-filters select:focus,
.majors-degrees-filters button:focus,
.majors-degrees-filters input:focus {
  outline: 3px solid #18453B;
  outline-offset: 2px;
}

/* Skip to results link (for screen readers) */
.skip-to-results {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.skip-to-results:focus {
  position: static;
  width: auto;
  height: auto;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  .majors-degrees-filters,
  .results-table-wrapper {
    border-width: 2px;
  }

  .majors-degrees-table tbody tr {
    border-width: 2px;
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
