/* UIC Library Directory manual styles */

#uiclib_directory {
  /* Sets the minimum height of the element to 30% of the viewport height */
  min-height: 30vh;
}

:root {
  /* Define custom CSS variables for colors */
  --uic_champions_gold: #ffbf3f;
  --uic_fire_engine_red: #d50032;
  --uic_chicago_blue: #41b6e6;
  --uic_ui_health_teal: #0085ad;
  --uic_navy_pier_blue: #001e62;
  --uic_expo_white: #f2f7eb;
  --uic_steel_gray: #333333;

  --uic_orange: #e66b01;
  --uic_gray_light: #eaeaea;
  --uic_silver: #c0c0c0;
  --uic_gray_accessible: #666666;
  --uic_gray_medium: #888888;
  --uic_gray_medium_light: #a4a4a4;
}

/* Search, filters, and functions elements */
#search,
#filters,
#functions {
  margin-bottom: 1rem;
}

.visually_hidden {
  /* Hides the element visually but keeps it accessible for screen readers */
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* The controls section */
#controls {
  display: inline-flex;
  flex-wrap: wrap;
  width: 100%;
}

/* Filters and functions within the controls section */
#controls #filters,
#controls #functions {
  width: 100%;
  display: inline-flex;
  flex-wrap: wrap;
}

/* Filters within the controls section */
#controls #filters {
  display: inline-flex;
  flex-shrink: 0;
  flex-grow: 1;
  flex-basis: 100%;

  justify-content: space-between;
}

/* Filter selectors within filters */
#controls #filters #filters_selectors {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
}

/* Filter dropdown list items */
#filters_selectors .md_filter_dropdown_list_item label {
  color: var(--uic_gray_medium_light);
}

#filters_selectors .md_filter_dropdown_list_item input {
  color: var(--uic_gray_medium_light);
}

#filters_selectors .md_filter_dropdown_list_item.available label {
  color: black;
}

#filters_selectors .md_filter_dropdown_list_item.available input {
  color: black;
}

/* Controls label */
#controls .controls_label {
  width: 3rem;
  margin-right: 0.5rem;
  text-align: right;
}

/* Filter dropdown */
#controls #filters .md_filter_dropdown {
  position: absolute;
  background-color: white;
  border: 1px solid #ccc;
  z-index: 1;

  /* min-width: 30rem; */

  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.25);
}

/* Select elements */
#controls select {
  font-size: 1em;
}

/* Standard input, button, and low button */
.standard_input,
.standard_button,
.low_button {
  border-radius: 0;
  font-size: 1.125em;
  font-weight: normal;
  padding-left: 1rem;
  padding-right: 1rem;
  background-color: var(--uic_gray_light);
  height: 3rem;
}

.standard_button,
.low_button {
  cursor: pointer;
}

.standard_input {
  box-shadow: inset 0 0.25rem 0.25rem rgba(0, 0, 0, 0.25);
  cursor: text;
}

.standard_button {
  border: 0.125rem solid var(--uic_silver);
}

.select_button {
  border-color: var(--uic_ui_health_teal);
}

.low_button {
  border: 1px solid var(--uic_silver);
  height: 2rem;
}

/* Filters clear button */
#controls #filters #filters_clear button {
  width: 7rem;
}

/* Filter elements */
#controls #filters .md_filter {
  margin: 0 0.5rem 0.5rem 0;
  position: relative;
  display: inline-block;
}

/* Sorter select within functions */
#controls #functions #sorter select {
  margin-right: 0.5rem;
}

/* Filters clear button and last filter element */
#filters_clear {
  margin-left: 2rem;
}

#controls #filters .md_filter:last-of-type button,
#controls #filters #filters_clear button,
#controls #functions #sorter select:last-of-type,
#controls #filters .md_filter:last-of-type {
  margin-right: 0;
}

/* Buttons and select elements */
#controls button {
  cursor: pointer;
}

#controls button:hover,
#controls select:hover {
  background-color: #ddd;
}

#controls button:active,
#controls select:active {
  background-color: ccc;
}

/* Select button states */
#controls button.select_button.open,
#controls button.select_button.hover,
#controls button.select_button.active {
  background: var(--uic_ui_health_teal);
  color: white;
}

#controls button.select_button.selected {
  border-color: orange;
  background-color: white;
  color: var(--uic_navy_pier_blue);
}

/* Search input and button */
#controls #search {
  /* display: flex; */
  flex-basis: 100%;
  position: relative;
  border-top: 0.25rem solid var(--uic_ui_health_teal);
}

#controls #search input {
  background-color: white;
  width: 100%;
  height: 3rem;

  border: 1px solid var(--uic_silver);
  border-top: none;
  border-right: none;
}

#controls #search button {
  /* flex-basis: 7rem; */
  /* border-top-width: 0.25rem; */
  /* display: absolute;
  right: 0; */
  /* border: 1px solid green; */
  /* font-weight: 900; */
  /* font-size: 2.5em; */
  /* padding: 0; */
  /* line-height: 0;
  padding: 1rem;
  color: var(--uic_gray_accessible);
  background: none;
  border: none;
  display: absolute;
  right: 0; */
}

#controls #search button svg {
  /* border: 1px solid red; */
  top: 0;
  right: 0;
  position: absolute;
  padding: 0.25rem;
}

#controls #search button svg path {
  fill: var(--uic_silver);
}

#controls #search button:hover svg path {
  fill: var(--uic_gray_accessible);
}

/* Filter dropdown header and body */
#controls #filters .md_filter_dropdown_header {
  display: flex;
  justify-content: flex-end;
  padding: 0.5rem;
  border-bottom: 1px solid #eee;
}

#controls #filters .md_filter_dropdown_body {
  padding: 0.5rem;
}

/* Filter dropdown list */
#controls #filters .md_filter_dropdown ul.md_filter_dropdown_list {
  list-style-type: none;
  padding: 0;
  margin: 0;

  overflow-y: auto;
  min-width: 15rem;
}

#controls #filters .md_filter_dropdown ul.md_filter_dropdown_list.cols_2 {
  column-count: 2;
  column-gap: 1rem;
  min-width: 30rem;
}

/* Filter dropdown list items */
#controls #filters .md_filter_dropdown li.md_filter_dropdown_list_item {
  display: inline-flex;
  width: 100%;
  /* min-width: 15rem; */
}

#controls #filters .md_filter_dropdown li.md_filter_dropdown_list_item input {
  margin-left: 0;
  flex-grow: 0;
  flex-shrink: 0;
  align-self: first baseline;

  cursor: pointer;
}

#controls #filters .md_filter_dropdown li.md_filter_dropdown_list_item label {
  padding-left: 0.25rem;
  cursor: pointer;
  padding-bottom: 0.5rem;
}

/* Functions within controls */
#controls #functions {
  display: inline-flex;
  justify-content: space-between;

  align-items: stretch;

  flex-shrink: 1;
  flex-grow: 1;
  flex-basis: 100%;
  margin-bottom: 2rem;
}

/* Status within functions */
#controls #functions #status {
  flex-basis: 100%;
  padding: 0.5rem 0 0.5rem 3.5rem;
}

#controls #functions #status p.warning {
  color: var(--uic_orange);
}

/* Sorter within functions */
#controls #functions #sorter {
  display: inline-flex;

  align-items: baseline;
  flex-wrap: nowrap;
}

/* Profiles list */
#profiles ul {
  list-style-type: none;
  padding: 0;
}

/* Profile elements */
#profiles .profile {
  position: relative;

  padding: 2rem 0 2rem;
  border-top: 1px solid var(--uic_silver);
}

/* Profile header */
#profiles .profile .profile_header {
  display: flex;
  flex-wrap: wrap;

  width: 100%;
  margin-bottom: 1rem;
  align-items: first baseline;
}

#profiles .profile .profile_header h3 {
  text-wrap: nowrap;
  height: 100%;
  margin-right: 1rem;
  margin-top: 0;
  font-size: 1.5em;
}

#profiles .profile .profile_header .profile_title {
  line-height: 1.5em;
  font-size: 1.25em;
  flex: 1;
  padding-left: 1rem;
  border-left: 2px solid #ddd;
}

/* Profile body */
#profiles .profile .profile_body {
  display: flex;
}

#profiles .profile .profile_body .profile_body_sidebar {
  flex: 1 1 5rem;
  margin-left: 1rem;
  order: 2;
  text-align: center;
  line-height: 1.5em;
}

#profiles .profile .profile_body .profile_body_sidebar a {
  /* font-weight: 500; */
  /* font-size: 1.0625em; */
  text-wrap: nowrap;
  overflow: ellipsis;
}

#profiles .profile .profile_body .profile_body_sidebar img.profile_photo {
  width: 6rem;
  border-radius: 50%;
  object-fit: cover;
  object-position: center;

  margin-bottom: 0.5rem;
}

#profiles .profile .profile_body .profile_body_sidebar .profile_cv {
  margin-top: 1rem;
  font-size: 1.25em;
}

#profiles .profile .profile_body .profile_body_main {
  flex: 1 0 75%;
  order: 1;
}

#profiles .profile .profile_body .profile_body_main .profile_md_line {
  margin-bottom: 0.5rem;
  display: inline-flex;
  width: 100%;
}

#profiles
  .profile
  .profile_body
  .profile_body_main
  .profile_md_line
  .profile_key {
  font-weight: bold;
  margin-right: 0.5rem;
  flex-basis: 8rem;
  flex-grow: 0;
  flex-shrink: 0;
  text-align: right;
}

#profiles
  .profile
  .profile_body
  .profile_body_main
  .profile_md_line
  ul.profile_val {
  display: inline-block;
  flex: 1;
}

#profiles
  .profile
  .profile_body
  .profile_body_main
  .profile_md_line
  ul.profile_val
  li {
  display: inline-block;
  margin-right: 0.5rem;
}

#profiles
  .profile
  .profile_body
  .profile_body_main
  .profile_md_line
  ul.profile_val
  li:not(:last-child)::after {
  content: ",";
}

/* Media queries for responsive design */
@media (max-width: 768px) {
  #profiles .profile .profile_md_line {
    width: calc(100% - 5rem);
  }

  #profiles img.profile_photo {
    width: 5rem;
    height: 5rem;
  }
}

@media (min-width: 769px) {
  /* Add specific styles for larger screens if needed */
}
