@charset "UTF-8";
/*******************************************************************************
 * Variables used throughout the theme.
 * To adjust anything, simply edit the variables below and rebuild the theme.
 ******************************************************************************/
/*******************************************************************************
 * Themes
 ******************************************************************************/
:root {
  --global-bg-color: #ffffff;
  --global-text-color: #000000;
  --global-theme-color: #5555b6;
  --global-hover-color: rgb(102.8395061728, 102.8395061728, 189.6604938272);
  --global-footer-bg-color: rgb(66.25, 66.25, 66.25);
  --global-footer-text-color: #e8e8e8;
  --global-footer-link-color: #ffffff;
  --global-icon-color: rgb(66.25, 66.25, 66.25);
}
:root .fa-sun {
  display: none;
}
:root .fa-moon {
  padding-left: 10px;
  padding-top: 12px;
  display: block;
}

html[data-theme=dark] {
  --global-bg-color: rgb(66.25, 66.25, 66.25);
  --global-text-color: #e8e8e8;
  --global-theme-color: #2698ba;
  --global-hover-color: rgb(123.3883928571, 204.0535714286, 228.1116071429);
  --global-footer-bg-color: #e8e8e8;
  --global-footer-text-color: rgb(66.25, 66.25, 66.25);
  --global-footer-link-color: #000000;
  --global-icon-color: navajowhite;
}
html[data-theme=dark] .fa-sun {
  padding-left: 10px;
  padding-top: 12px;
  display: block;
}
html[data-theme=dark] .fa-moon {
  display: none;
}

/******************************************************************************
 * Content
 ******************************************************************************/
body {
  padding-bottom: 70px;
  color: var(--global-text-color);
  background-color: var(--global-bg-color);
}

body.fixed-top-nav {
  padding-top: 56px;
}

body.sticky-bottom-footer {
  padding-bottom: 0;
}

.container {
  max-width: 950px;
}

.profile img {
  width: 100%;
}

/******************************************************************************
 * Publications
 ******************************************************************************/
/*****************************************************************************
* Projects
*****************************************************************************/
/*******************************************************************************
 * Styles for the base elements of the theme.
 ******************************************************************************/
p,
h1,
h2,
h3,
h4,
h5,
h6,
em,
div,
span,
strong {
  color: var(--global-text-color);
}

a,
table.table a {
  color: var(--global-theme-color);
}
a:hover,
table.table a:hover {
  color: var(--global-theme-color);
  text-decoration: underline;
}
a:hover:after,
table.table a:hover:after {
  width: 100%;
}

.equation {
  margin-bottom: 1rem;
  text-align: center;
}

.caption {
  font-size: 0.875rem;
  margin-top: 0.75rem;
  margin-bottom: 1.5rem;
  text-align: center;
}

.profile {
  margin-left: 1rem;
  width: 100%;
}
.profile .address {
  margin-bottom: 5px;
  margin-top: 5px;
  font-family: monospace;
  font-size: 1.2rem;
}
.profile .address p {
  display: inline-block;
  margin: 0;
}

@media (min-width: 576px) {
  .profile {
    width: 30%;
  }
  .profile .address p {
    display: block;
  }
}
.post-description {
  margin-bottom: 2rem;
  font-size: 0.875rem;
}
.post-description a {
  color: inherit;
}
.post-description a:hover {
  color: var(--global-theme-color);
  text-decoration: none;
}

.navbar {
  box-shadow: none;
  border-bottom: 1px solid #e8e8e8;
  opacity: 0.95;
  background-color: var(--global-bg-color);
}

.navbar.navbar-light a:hover {
  text-decoration: none;
}
.navbar.navbar-light .navbar-brand {
  color: var(--global-text-color);
}
.navbar.navbar-light .navbar-nav .nav-item .nav-link {
  color: var(--global-text-color);
}
.navbar.navbar-light .navbar-nav .nav-item .nav-link:hover {
  color: var(--global-hover-color);
}
.navbar.navbar-light .navbar-nav .nav-item.active > .nav-link {
  background-color: inherit;
  font-weight: bolder;
  color: var(--global-theme-color);
}
.navbar.navbar-light .navbar-nav .nav-item.active > .nav-link:hover {
  color: var(--global-hover-color);
}
.navbar.navbar-light .contact-icon {
  font-size: 2rem;
}
.navbar.navbar-light .contact-icon a:hover {
  color: var(--global-hover-color);
}

.navbar-toggler .icon-bar {
  display: block;
  width: 22px;
  height: 2px;
  background-color: rgb(66.25, 66.25, 66.25);
  border-radius: 1px;
  margin-bottom: 4px;
  transition: all 0.2s;
}
.navbar-toggler .top-bar {
  transform: rotate(45deg);
  transform-origin: 10% 10%;
}
.navbar-toggler .middle-bar {
  opacity: 0;
}
.navbar-toggler .bottom-bar {
  transform: rotate(-45deg);
  transform-origin: 10% 90%;
}

.navbar-toggler.collapsed .top-bar {
  transform: rotate(0);
}
.navbar-toggler.collapsed .middle-bar {
  opacity: 1;
}
.navbar-toggler.collapsed .bottom-bar {
  transform: rotate(0);
}

.news table td {
  font-size: 1rem;
  color: var(--global-text-color);
}

.news table th {
  color: var(--global-text-color);
}

.social {
  text-align: center;
}
.social .contact-icon {
  font-size: 4rem;
}
.social .contact-icon a {
  color: var(--global-icon-color);
}
.social .contact-icon a:hover {
  color: var(--global-theme-color);
}
.social .contact-note {
  font-size: 0.8rem;
}

footer.fixed-bottom {
  background-color: var(--global-footer-bg-color);
  font-size: 0.75rem;
}
footer.fixed-bottom .container {
  color: var(--global-footer-text-color);
  padding-top: 9px;
  padding-bottom: 8px;
}
footer.fixed-bottom a {
  color: var(--global-footer-link-color);
}
footer.fixed-bottom a:hover {
  color: pink;
  text-decoration: none;
}

footer.sticky-bottom {
  border-top: 1px solid #e8e8e8;
  padding-top: 40px;
  padding-bottom: 40px;
  font-size: 0.9rem;
}

.header-bar {
  border-bottom: 1px solid #e8e8e8;
  text-align: center;
  padding-top: 2rem;
  padding-bottom: 5rem;
}
.header-bar h1 {
  color: var(--global-theme-color);
  font-size: 5rem;
}

.post-list {
  margin: 0;
  margin-bottom: 40px;
  padding: 0;
}
.post-list li {
  border-bottom: 1px solid #e8e8e8;
  list-style: none;
  padding-top: 2rem;
  padding-bottom: 2rem;
}
.post-list li .post-meta {
  color: #828282;
  font-size: 0.875rem;
  margin-bottom: 0;
}
.post-list li a {
  color: var(--global-text-color);
  text-decoration: none;
}
.post-list li a:hover {
  color: var(--global-theme-color);
}

.pagination .page-item .page-link {
  color: var(--global-text-color);
}
.pagination .page-item .page-link:hover {
  color: #000000;
}
.pagination .page-item.active .page-link {
  background-color: var(--global-theme-color);
}
.pagination .page-item.active .page-link:hover {
  background-color: var(--global-theme-color);
}

.distill a:hover {
  border-bottom-color: var(--global-theme-color);
  text-decoration: none;
}

.projects .grid-item {
  width: 250px;
  margin-bottom: 10px;
}
.projects .grid-item a {
  color: black;
  text-decoration: none;
}
.projects .grid-item a:hover {
  color: var(#5555b6);
}
.projects .card img {
  width: 100%;
}

.publications {
  margin-top: 2rem;
}
.publications h1 {
  color: var(--global-theme-color);
  font-size: 2rem;
  text-align: center;
  margin-top: 1em;
  margin-bottom: 1em;
}
.publications h2 {
  margin-bottom: 1rem;
}
.publications h2 span {
  font-size: 1.5rem;
}
.publications h2.year {
  color: #e8e8e8;
  border-top: 1px solid #e8e8e8;
  padding-top: 1rem;
  margin-top: 2rem;
  margin-bottom: -2rem;
  text-align: right;
}
.publications ol.bibliography {
  list-style: none;
  padding: 0;
  margin-top: 0;
}
.publications ol.bibliography li {
  margin-bottom: 1rem;
}
.publications ol.bibliography li .abbr {
  height: 2rem;
  margin-bottom: 0.5rem;
}
.publications ol.bibliography li .abbr abbr {
  display: inline-block;
  background-color: var(--global-theme-color);
  padding-left: 1rem;
  padding-right: 1rem;
}
.publications ol.bibliography li .abbr abbr a {
  color: white;
}
.publications ol.bibliography li .abbr abbr a:hover {
  text-decoration: none;
}
.publications ol.bibliography li .abbr .award {
  color: var(--global-theme-color) !important;
  border: 1px solid var(--global-theme-color);
}
.publications ol.bibliography li abbr.comment-badge {
  background-color: #f4d35e;
  color: white;
}
.publications ol.bibliography li abbr.comment-badge a {
  color: white;
}
.publications ol.bibliography li abbr.comment-badge a:hover {
  text-decoration: none;
}
.publications ol.bibliography li abbr.langdoc-badge {
  background-color: #073b4c;
  color: white;
}
.publications ol.bibliography li abbr.langdoc-badge a {
  color: white;
}
.publications ol.bibliography li abbr.langdoc-badge a:hover {
  text-decoration: none;
}
.publications ol.bibliography li .title {
  font-weight: bolder;
}
.publications ol.bibliography li .author .author-self {
  color: var(--global-theme-color);
  font-weight: bold;
}
.publications ol.bibliography li .links a.btn {
  color: var(--global-text-color);
  border: 1px solid var(--global-text-color);
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}
.publications ol.bibliography li .links a.btn:hover {
  color: var(--global-theme-color);
  border-color: var(--global-theme-color);
}
.publications ol.bibliography li .hidden {
  font-size: 0.875rem;
  max-height: 0px;
  overflow: hidden;
  text-align: justify;
  -webkit-transition: 0.15s ease;
  -moz-transition: 0.15s ease;
  -ms-transition: 0.15s ease;
  -o-transition: 0.15s ease;
  transition: all 0.15s ease;
}
.publications ol.bibliography li .hidden p {
  line-height: 1.4em;
  margin: 10px;
}
.publications ol.bibliography li .hidden pre {
  font-size: 1em;
  line-height: 1.4em;
  padding: 10px;
}
.publications ol.bibliography li .hidden.open {
  max-height: 100em;
  -webkit-transition: 0.15s ease;
  -moz-transition: 0.15s ease;
  -ms-transition: 0.15s ease;
  -o-transition: 0.15s ease;
  transition: all 0.15s ease;
}
.publications ol.bibliography li div.abstract.hidden {
  border: dashed 1px var(--global-bg-color);
}
.publications ol.bibliography li div.abstract.hidden.open {
  border-color: var(--global-text-color);
}

code {
  color: var(--global-theme-color);
}

html.transition,
html.transition *,
html.transition *:before,
html.transition *:after {
  transition: all 750ms !important;
  transition-delay: 0 !important;
}

/* Custom override for About page description */
.page-header .highlight-blue {
  color: #0076df !important;
  font-weight: bold !important;
}

/* project stuff by chat gpt */
.project-row-small .card {
  margin: 0; /* remove auto margins */
  max-width: 100%; /* cards should stretch to col width */
}

.project-row-small .card-body {
  padding: 10px; /* smaller padding */
  font-size: 0.85rem; /* shrink text */
  line-height: 1.2;
}

.project-row-small .card-text {
  font-size: 0.85rem; /* smaller description */
}

.project-row-small .card-title {
  font-size: 1rem; /* slightly smaller title */
  font-weight: 600; /* optional bold */
  color: #1e90ff; /* default title color */
  transition: color 0.3s; /* smooth hover effect */
}

/* Optional: different colors per category */
#model .card-title {
  color: #b509ac; /* blue for Models */
}

#data .card-title {
  color: var(--global-theme-color); /* green for Datasets */
}

/* Line below each section */
.project-category {
  clear: both;
  border-bottom: 1px solid #ddd;
  padding-bottom: 8px;
  margin-bottom: 8px;
}

/* Remove line after the last section */
.project-category:last-of-type {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

/* Add line above the first section */
.project-category:first-of-type {
  border-top: 1px solid #ddd;
  padding-top: 8px;
  margin-top: 8px; /* small gap above the line */
}

/* Gray background for the entire code block */
.resources-page pre {
  background-color: #f8f8f8;
  padding: 10px;
  border-radius: 5px;
  overflow-x: auto;
}

/* Font size & line height for readability */
.resources-page pre code {
  font-size: 0.85rem;
  line-height: 1.3;
}

/* Optional: keep Rouge span coloring */
.resources-page pre code .k {
  color: #d14;
} /* keywords like @article */
.resources-page pre code .s {
  color: #5555b6;
} /* strings in braces */
.project-flex-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start; /* left-align, no extra space between */
  gap: 4px; /* minimal gap between boxes — you can reduce this to 2px or 0px */
}

.project-flex-item {
  flex: 0 0 calc(24% - 4px); /* ~22% width instead of 20% */
  max-width: calc(24% - 4px);
  margin: 0;
}

.project-flex-item .card {
  width: 100%; /* fill the flex item completely */
  margin: 0; /* remove any leftover margin */
  box-sizing: border-box;
}

.project-flex-item .card-body {
  padding: 4px; /* small padding inside card */
  font-size: 0.75rem; /* scale down text */
  line-height: 1.1;
}

.project-flex-item .card-title {
  font-size: 0.96rem;
  font-weight: 600;
  margin-bottom: 0.25rem;
}

.project-flex-item .card-text {
  font-size: 0.7rem;
  margin-bottom: 0;
}

/*service page*/
.activity-list {
  margin-top: 0.5rem;
}

.activity-list div {
  display: grid;
  grid-template-columns: max-content 1fr;
  align-items: start;
  column-gap: 2rem; /* ← spacing between badge and text */
  margin-bottom: 0.6rem;
  row-gap: 1.2rem;
}

.activity-list .activity-text {
  line-height: 1.5;
}

/* Base style: inherit from al-folio badges */
.badge-conference,
.badge-workshop,
.badge-journal,
.badge-local {
  color: #fff; /* white text for readability */
}

/* 🎓 Conference badge */
.badge-conference {
  background-color: var(--badge-conference, #ef476f);
}

/* 🧠 Workshop badge */
.badge-workshop {
  background-color: var(--badge-workshop, #118ab2);
}

/* 🏫 Local event badge */
.badge-local {
  background-color: var(--badge-local, #5555b6);
}

.badge-journal {
  background-color: var(--badge-local, #12b589);
}

/* Shrink profile picture */
.profile img {
  width: 180px; /* adjust this to desired size */
  height: auto; /* maintain aspect ratio */
  border-radius: 50%; /* optional: keep it circular */
  display: block; /* remove inline quirks */
  margin-bottom: 1rem; /* optional spacing below image */
}

/* Optional: if container width still restricts image */
@media (min-width: 576px) {
  .profile {
    width: auto; /* let image control its size */
  }
}
.project-category {
  margin: 2em 0;
}

.category {
  margin-bottom: 1em;
  font-size: 1.5rem;
}

.timeline-item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 1.5em;
  gap: 20px;
}

.year-badge {
  background-color: #5555b6; /* accent color */
  color: white;
  font-weight: 600;
  padding: 2px 8px; /* slimmer padding */
  border-radius: 4px; /* subtle rounded corners */
  font-size: 0.9rem; /* smaller text */
  min-width: auto; /* remove fixed width */
  text-align: center;
  flex-shrink: 0;
}

.timeline-content {
  margin: 0;
  padding-left: 0;
  list-style: none;
}

.timeline-content li {
  margin-bottom: 0.7em;
  color: #333;
}

.timeline-content li a i {
  font-style: italic;
}

/*# sourceMappingURL=main.css.map */