.bufferDiv {
  height: 2rem;
}

.indexMain {
  display: flex;
  flex-direction: column;
  padding-top: 5vmin;
  justify-content: space-between;
}

.top {
  display: flex;
  flex-direction: row;
}

.bottom {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.bottomContent {
  width: 100%;
}

.profileImage {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 15px;
}

.profileImage img {
  width: 100%;
  border-radius: 0.6rem;
}

.left {
  width: 30%;
}

.right {
  width: 70%;
  padding-left: 1rem;
}

iframe {
  border-style: none;
  width: 100%;
  height: 40vh;
}

.demoEmbed {
  margin-bottom: 3vh;
}

.name {
  font-family: 'Vollkorn';
  font-size: 1.25rem;
  font-weight: 200;
  padding: .05rem 0 1rem 0;
}

.intro {
  padding: 0 1rem;
}

@media only screen and (max-width: 768px) {
  /* For mobile phones: */
  .indexMain {
    gap: 2rem;
  }
  .top {
    flex-direction: column;
    align-items: center;
  }
  .left {
    width: 100%;
    margin-bottom: 2rem;
  }
  .right {
    width: 100%;
    padding: 0;
  }
  img {
    width: 50%;
  }
}

.para {
  width: 100%;
  font-size: var(--fsize);
  font-family: 'Inter';
  font-weight: 300;
  line-height: 1.1rem;
  color: #000;
  line-height: calc(var(--fsize) * 1.3);
}

.header {
  width: 100%;
  display: flex;
  margin-left: 6vw;
  align-items: center;
  font-size: var(--hsize);
  font-family: var(--font-mono);
  font-weight: 600;
  color: #000;
  line-height: calc(var(--hsize) * 3 / 2);
}

.sectionHeaderCon {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: left;
  width: 100%;
  height: 2rem;
}

.sectionHeaderHead {
  width: 0;
  height: 2rem;
  border-top: 1.0rem solid transparent;
  border-bottom: 1.0rem solid transparent;
  border-left: 1rem solid #a00;
  position: relative;
  left: -1rem;
}

.sectionHeader {
  width: fit-content;
  heigth: 2rem;
  display: flex;
  white-space: nowrap;
  padding-left: 2rem;
  padding-right: 1rem;
  align-items: center;
  font-size: var(--hssize);
  font-family: var(--font-thin);
  font-weight: 300;
  color: #fff;
  background-color: #a00;
  height: 2rem;
  position: relative;
  left: -1rem;
}

.sectionHeaderTail {
  width: 0;
  height: 2rem;
  border-top: .8rem solid transparent;
  border-bottom: .8rem solid transparent;
  border-right: 1rem solid #500;
  position: relative;
  top: 1rem;
}

.hbuffer {
  width: 100%;
}

.section {
  width: 100%;
  display: flex;
  flex-direction: row;
}

.div {
  margin-top: 0.3vw;
  margin-bottom: 0.3vw;
  width: 100%;
  height: 0.06rem;
  background: #dadada;
}

.centerCon {
  display: flex;
  justify-content: center;
  align-items: center;
}

.center {
  text-align: center;
}

.shadowCon {
  overflow-y: hidden;
  padding: 0 1rem;
}

.newsCard {
  height: fit-content;
  padding: .5rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  flex-direction: row;
  margin: 0 1rem;
  gap: .2rem;
}

.newsDate {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: .7rem;
  font-family: var(--font-mono);
  font-weight: 300;
  color: var(--col-text);
}

.newsMid {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: .9rem;
  font-family: var(--font-mono);
  font-weight: 300;
  color: var(--col-text);
}

.center {
  text-align: center;
}

.newsTitle {
  width: 100%;
  text-align: left;
  font-size: var(--fsizesmall);
  font-family: "Inter";
  font-weight: 300;
  color: var(--col-text);
}

.newsCon {
  overflow: hidden;
  box-shadow: -1.2rem 0 1.5em -2.2rem #444, 1.2rem 0 1.5em -2.2rem #444;
  padding: .3rem 1rem 1rem 0;
  height: fit-content;
}

.projCard {
  min-height: fit-content;
  display: flex;
  align-items: center;
  text-align: center;
  flex-direction: row;
  margin: .75rem .75rem;
  gap: 1rem;
}

.projText {
}

.projImage {

}

.projTitle {

}

.bibCard {
  min-height: fit-content;
  display: flex;
  align-items: center;
  text-align: center;
  flex-direction: row;
  padding: .75rem .75rem;
  gap: 1rem;
}

.bibCard:hover {
  transform: scale(1.05);
  transition: transform 0.5s;
  background: #f0f0f0;
}

.bibText {
  width: 100%;
  min-height: fit-content;
  display: flex;
  justify-content: space-between;
  align-items: left;
  text-align: left;
  flex-direction: column;
  margin: 0;
  gap: 0.2rem;
}

.bibImage {
  width: 30%;
  max-width: 80vw;
  padding: .0rem;
  border: solid 1px;
  border-radius: 0.3rem;
  aspect-ratio: 4 / 3;
  object-fit: contain;
}

.bibImagePad {
  padding: .5rem;
}

.bibTitle {
  width: 100%;
  display: flex;
  align-items: center;
  text-align: left;
  font-size: 1.1rem;
  font-family: 'Vollkorn', serif;
  font-weight: 700;
  line-height: 1.2rem;
  color: var(--col-text);
}

.bibAuthor {
  font-size: .75rem;
  font-family: var(--font-thin);
  font-weight: 300;
  color: var(--col-text);
}

.bibPublish {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: left;
  font-size: var(--fsizesmall);
  font-family: var(--font-thin);
  font-weight: 300;
  color: var(--col-text);
  gap: 0.3rem;
}

.bibYear {
}

.bibPublisher {
}

.bibCon {
  overflow: hidden;
  box-shadow: -1.2rem 0 1.5em -2.2rem #444, 1.2rem 0 1.5em -2.2rem #444;
  padding: .5rem 1rem 0 1rem;
}

.bibLinkCon {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: left;
  width: 100%;
  padding-top: .5rem;
  gap: .25rem;
}

.bibLink {
  font-size: .85rem;
  font-family: var(--font-thin);
  color: white;
  background: black;
  /* border-radius: 0.2rem; */
  padding: 0.3rem 0.5rem;
  text-decoration: none;
  cursor: pointer;
}

.showMoreCon {
  height: 5vh;
  width: 100%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: .9rem;
  color: var(--col-font);
  background: linear-gradient(0, #fff, transparent);
  top: 0;
}

.showMore {
  border-radius: 1vh;
  height: 3vh;
  width: 3vh;
  display: flex;
  position: relative;
  bottom: -2vh;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  background: white;
}

.socialCon {
  gap: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.contactCon {
  font-family: 'Roboto Mono';
  font-size: 0.7rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.contactCon img {
  height: 1rem;
}

.icon {
  cursor: pointer;
  width: 1.25rem;
  height: 1.25rem;
}

.bibHeader {
  display: flex;
  flex-direction: column;
}

.bibHeaderNote {
  display: flex;
  align-items: center;
  font-family: 'Vollkorn';
  font-size: var(--hssize);
  height: 2rem;
}

.projDesc {
  font-family: 'Inter', sans-serif;
  font-weight: 200;
  font-size: 0.8rem;
  line-height: 1.0rem;
  color: #000;
}

#introBtnCon {
  display: flex;
  flex-direction: row;
  align-content: center;
  justify-content: initial;
  gap: 0.3rem;
  padding-bottom: 1rem;
  font-size: var(--fsize);
  font-family: 'Inter';
  cursor: default;
}

.langBtn {
  cursor: pointer;
}

.langBtn:hover {
  background: #f0f0f0;
}

.langBtn.selected {
  text-decoration: underline;
  font-weight: 600;
}

.paraIntro {
  display: none;
}

.paraIntro.selected {
  display: block;
}

@media only screen and (max-width: 768px) {
  .bibCard {
    flex-direction: column;
  }

  .bibImage {
    width: 80%;
  }

  .bibHeader {
    display: flex;
    flex-direction: column;
  }

  .indexMain {
    /* padding-bottom: 25vh; */
  }

  .icon img {
    width: 8vmin;
    height: 8vmin;
  }

  .icon {
    width: 8vmin;
    height: 8vmin;
  }
}
