/* latin-ext */
@font-face {
  font-family: 'Lato';
  font-style: italic;
  font-weight: 400;
  src: local('Lato Italic'), local('Lato-Italic'), url(https://fonts.gstatic.com/s/lato/v15/S6u8w4BMUTPHjxsAUi-qNiXg7eU0.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Lato';
  font-style: italic;
  font-weight: 400;
  src: local('Lato Italic'), local('Lato-Italic'), url(https://fonts.gstatic.com/s/lato/v15/S6u8w4BMUTPHjxsAXC-qNiXg7Q.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Lato';
  font-style: italic;
  font-weight: 700;
  src: local('Lato Bold Italic'), local('Lato-BoldItalic'), url(https://fonts.gstatic.com/s/lato/v15/S6u_w4BMUTPHjxsI5wq_FQftx9897sxZ.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Lato';
  font-style: italic;
  font-weight: 700;
  src: local('Lato Bold Italic'), local('Lato-BoldItalic'), url(https://fonts.gstatic.com/s/lato/v15/S6u_w4BMUTPHjxsI5wq_Gwftx9897g.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 400;
  src: local('Lato Regular'), local('Lato-Regular'), url(https://fonts.gstatic.com/s/lato/v15/S6uyw4BMUTPHjxAwXiWtFCfQ7A.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 400;
  src: local('Lato Regular'), local('Lato-Regular'), url(https://fonts.gstatic.com/s/lato/v15/S6uyw4BMUTPHjx4wXiWtFCc.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 700;
  src: local('Lato Bold'), local('Lato-Bold'), url(https://fonts.gstatic.com/s/lato/v15/S6u9w4BMUTPHh6UVSwaPGQ3q5d0N7w.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 700;
  src: local('Lato Bold'), local('Lato-Bold'), url(https://fonts.gstatic.com/s/lato/v15/S6u9w4BMUTPHh6UVSwiPGQ3q5d0.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

a {
  color: #0b63b6;
  text-decoration: none;
  transition: color .15s ease, background-color .15s ease, border-color .15s ease;
}

a:focus,
a:hover {
  color: #b85f00;
  text-decoration: none;
}

body {
  margin: 0;
  min-height: 100vh;
  color: #253141;
  background:
    linear-gradient(180deg, #f7f9fc 0%, #eef3f7 100%);
  line-height: 1.55;
}

body,
td,
th,
tr,
p,
a {
  font-family: 'Lato', Verdana, Helvetica, sans-serif;
  font-size: 16px;
}

strong {
  font-family: 'Lato', Verdana, Helvetica, sans-serif;
  font-size: 16px;
}

h2 {
  margin: 0;
  padding-bottom: 8px;
  color: #172033;
  border-bottom: 1px solid #e6edf5;
  font-weight: 700;
  font-family: 'Lato', Verdana, Helvetica, sans-serif;
  font-size: 23px;
}

.page-table {
  width: 100%;
  max-width: 920px;
  border: 0px;
  border-spacing: 0px;
  border-collapse: separate;
  margin: 32px auto;
  background: rgba(255, 255, 255, .96);
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  box-shadow: 0 18px 50px rgba(42, 58, 84, .10);
  overflow: hidden;
}

.content-table {
  width: 100%;
  border: 0px;
  border-spacing: 0px;
  border-collapse: separate;
  margin-right: auto;
  margin-left: auto;
}

.no-padding {
  padding: 0px;
}

.page-table > tbody > tr > .no-padding {
  padding: 0 22px 22px;
}

.no-padding-row {
  padding: 0px;
}

.text-center {
  text-align: center;
}

.text-justify {
  text-align: justify;
}

.intro-email {
  margin-top: 8px;
  margin-bottom: 10px;
  color: #526070;
}

.section-cell {
  padding: 26px 20px 18px;
  width: 100%;
  vertical-align: middle;
}

.section-cell p {
  margin-bottom: 0;
}

.news-section {
  padding-top: 30px;
  padding-bottom: 8px;
}

.news-list {
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
}

.news-list li {
  display: flex;
  gap: 12px;
  margin: 7px 0;
  line-height: 1.45;
}

.news-date {
  flex: 0 0 82px;
  color: #64748b;
  font-variant-numeric: tabular-nums;
}

.news-text {
  display: block;
  flex: 1 1 auto;
  min-width: 0;
}

.section-heading-cell {
  padding: 38px 20px 10px;
}

.section-title-table {
  width: 100%;
  border: 0px;
  border-spacing: 0px;
  border-collapse: separate;
  margin-right: auto;
  margin-left: auto;
}

.profile-image-cell {
  padding: 24px 20px 20px;
  width: 35%;
  max-width: 35%;
  vertical-align: top;
}

.profile-photo {
  width: 100%;
  max-width: 100%;
  object-fit: cover;
  border: 1px solid #d8e0ea;
  border-radius: 18px;
  box-shadow: 0 16px 32px rgba(38, 52, 73, .16);
}

.bio {
  padding: 24px 20px 18px;
  width: 65%;
  vertical-align: middle;
}

.bio p {
  margin-top: 0;
}

#contact-links-desktop p,
#contact-links-mobile p {
  margin: 18px 0 0;
  color: #8a97a8;
}

#contact-links-desktop a,
#contact-links-mobile a {
  display: inline-block;
  margin: 3px 0;
  padding: 2px 4px;
  border-radius: 5px;
  font-weight: 400;
}

#contact-links-desktop a:hover,
#contact-links-mobile a:hover {
  background: #eef6ff;
}

@media (max-width: 768px) {
  .bio {
    padding: 16px 14px 6px;
  }
}

@media (max-width: 768px) {
  .desktoponly {
    display: none;
  }
}

@media (min-width: 768px) {
  .mobileonly {
    display: none;
  }
}

.paperimage {
  padding: 20px 18px;
  width: 34%;
  vertical-align: top;
}

.paperdetails {
  padding: 20px 18px;
  width: 66%;
  vertical-align: middle;
}

.paper-hover {
  transition: background-color .15s ease, transform .15s ease;
}

.paper-hover > td {
  border-top: 1px solid #edf2f7;
}

.section-title-table + .content-table .paper-hover:first-child > td {
  border-top: 0;
}

.paper-hover:hover {
  background-color: #f7fbff;
}

.paper {
  margin-top: 8px;
  color: #253141;
}

.paper a {
  font-weight: 700;
}

.venue {
  display: inline-block;
  margin-top: 7px;
}

.institution {
  display: inline-block;
  margin-top: 7px;
}

.education-logo-cell {
  padding: 20px;
  width: 25%;
  vertical-align: middle;
  text-align: center;
}

.education-table {
  width: 100%;
  border: 0px;
  border-spacing: 0px;
  border-collapse: separate;
  margin-right: auto;
  margin-left: auto;
}

.education-table tr + tr > td {
  border-top: 1px solid #edf2f7;
}

.education-detail-cell {
  padding: 18px 0;
  width: 50%;
  vertical-align: middle;
}

.education-date-cell {
  padding: 18px 0;
  width: 25%;
  color: #64748b;
  vertical-align: middle;
  text-align: right;
}

.education-spacer-row {
  height: 20px;
}

.cmu-logo {
  max-width: 70%;
  filter: saturate(.95);
}

.uoft-logo {
  max-width: 90%;
  filter: saturate(.95);
}

@media (max-width: 768px) {
  .paperimage {
    width: 50%;
  }
}

.papertitle {
  color: #102a43;
  font-family: 'Lato', Verdana, Helvetica, sans-serif;
  font-size: 16px;
  font-weight: 700;
}

a:hover .papertitle {
  color: #b85f00;
}

.name {
  padding-top: 36px;
  margin: 0;
  color: #111827;
  font-family: 'Lato', Verdana, Helvetica, sans-serif;
  font-size: 36px;
  font-weight: 700;
}

.one {
  width: 100%;
  position: relative;
  border-radius: 12px;
}

.one img {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  border: 1px solid #dbe3ed;
  border-radius: 12px;
  box-sizing: border-box;
  object-fit: cover;
  box-shadow: 0 10px 24px rgba(38, 52, 73, .10);
  transition: opacity .2s ease-in-out;
  -moz-transition: opacity .2s ease-in-out;
  -webkit-transition: opacity .2s ease-in-out;
}

.two {
  width: 100%;
  opacity: 0;
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(38, 52, 73, .10);
  transition: opacity .2s ease-in-out;
  -moz-transition: opacity .2s ease-in-out;
  -webkit-transition: opacity .2s ease-in-out;
}

.autoplay-preview .two {
  opacity: 1;
}

.autoplay-preview .one img {
  display: none;
}

.one.text-center .two {
  margin-right: auto;
  margin-left: auto;
  width: 97%;
}

.one.text-center img {
  left: 50%;
  width: 97%;
  transform: translateX(-50%);
}

.paper-hover.is-hovering .one img {
  opacity: 0;
}

.two video {
  display: block;
  width: 100%;
  border: 1px solid #dbe3ed;
  border-radius: 12px;
  box-sizing: border-box;
}

.project-image img {
  display: block;
  border: 1px solid #dbe3ed;
  border-radius: 12px;
  box-sizing: border-box;
  box-shadow: 0 10px 24px rgba(38, 52, 73, .10);
}

.project-thumbnail {
  border-radius: 12px;
}

.fade {
  transition: opacity .2s ease-in-out;
  -moz-transition: opacity .2s ease-in-out;
  -webkit-transition: opacity .2s ease-in-out;
}

span.highlight {
  padding: 0 3px;
  background-color: #fff2a8;
  border-radius: 4px;
}

.award {
  color: #b42318;
}

.highlighted-publication {
  background-color: #fff9df;
}

.highlighted-publication:hover {
  background-color: #fff9df;
}

@media (max-width: 768px) {
  td,
  th,
  tr,
  p,
  a,
  strong {
    font-size: 14px;
  }

  body {
    background: #ffffff;
  }

  .page-table {
    margin: 0;
    max-width: none;
    border: 0;
    border-radius: 0;
    box-shadow: none;
  }

  .page-table > tbody > tr > .no-padding {
    padding: 0 12px 18px;
  }

  .text-justify {
    text-align: left;
  }

  .name {
    padding-top: 24px;
    font-size: 31px;
  }

  .papertitle {
    font-size: 15px;
  }

  .intro-row {
    display: flex;
    flex-direction: column;
  }

  .bio {
    display: block;
    order: 2;
    padding: 6px 10px 6px;
    width: auto;
    vertical-align: middle;
  }

  .profile-image-cell {
    display: block;
    order: 1;
    max-width: 240px;
    margin: 0 auto;
    padding: 10px 14px 6px;
    width: auto;
    vertical-align: top;
  }

  #contact-links-mobile p {
    font-size: 12px;
    line-height: 1.25;
    margin-top: 10px;
    white-space: nowrap;
  }

  #contact-links-mobile a {
    margin: 0;
    padding-left: 1px;
    padding-right: 1px;
    padding-top: 0;
    padding-bottom: 0;
  }

  .section-cell {
    padding: 26px 10px 12px;
  }

  .news-section {
    padding-top: 24px;
  }

  .news-list li {
    display: block;
    margin: 9px 0;
  }

  .news-date {
    display: inline-block;
    margin-right: 5px;
  }

  .section-heading-cell {
    padding: 32px 10px 8px;
  }

  .paper-hover {
    display: block;
    padding: 14px 0;
    border-top: 1px solid #edf2f7;
  }

  .paper-hover > td {
    display: block;
    border-top: 0;
  }

  .section-title-table + .content-table .paper-hover:first-child {
    border-top: 0;
  }

  .paperimage,
  .paperdetails {
    width: auto;
  }

  .paperimage {
    padding: 6px 10px 10px;
  }

  .paperdetails {
    padding: 4px 10px 8px;
  }

  .education-logo-cell {
    padding: 16px 10px;
  }

  .education-date-cell {
    padding-right: 4px;
  }
}
