@charset "UTF-8";
@font-face {
  font-family: "Bevan";
  font-weight: 400;
  font-style: normal;
  src: url("../fonts/Bevan-Regular.woff2") format("woff2");
  font-display: auto;
}
@font-face {
  font-family: "Roboto";
  font-weight: 100 900;
  font-style: normal;
  src: url("../fonts/Roboto-Variable.woff2") format("woff2-variations");
  font-display: auto;
}
@font-face {
  font-family: "Roboto";
  font-weight: 100 900;
  font-style: italic;
  src: url("../fonts/Roboto-Italic-Variable.woff2") format("woff2-variations");
  font-display: auto;
}
html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

html {
  height: 100%;
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100%;
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
  line-height: 1.6;
}

input:focus,
select:focus,
textarea:focus,
button:focus {
  outline: none;
}

a,
area,
button,
[role=button],
input,
label,
select,
summary,
textarea {
  touch-action: manipulation;
}

/* Remove default padding */
ul,
ol {
  margin-block: 0;
  padding-inline: 0;
  padding: 0;
  margin: 0;
}

header,
footer,
section,
article {
  container-type: inline-size;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  text-wrap: balance;
}

p,
li,
figcaption {
  text-wrap: pretty;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
li,
figure,
figcaption,
blockquote,
dl,
dd {
  margin: 0;
}

/* Make images easier to work with, low-res background if available as well */
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  font-style: italic;
  shape-margin: 0.75rem;
  background-repeat: no-repeat;
  background-size: cover;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
:root {
  --primary-serif: "Bevan", Georgia, serif;
  --primary-sans: "Roboto", system-ui, sans-serif;
  --text-color: #000000;
  --site-highlight: #A10000;
  --site-page-bg: #EBE8E8;
  --container-shadow: -2px 2px 10px 0px rgba(0, 0, 0, 0.25);
  --column-padding: 1.625rem;
  --splash-padding: 50vh;
  --gutter: 1rem;
  --content-max: 90rem;
  --main-width: 100%;
  --table-width: 55rem;
  --listing-width: 60rem;
  --search-width: 60rem;
  --text-width: 40rem;
}

:is(b, .bold) {
  font-weight: 700;
}

/* :where(a, a:visited) {
	color: var(--site-highlight);
	transition: text-decoration-color .3s ease-in-out;
	text-decoration: underline;

		&:is(:hover, :focus) {
			text-decoration-color: transparent;
			cursor: pointer;
		}
}
 */
li[data-el=def] {
  list-style-type: none;
}

html[lang=en] {
  /* q[lang*="fr"] {
  	quotes: "«" "»" "‹" "›";
  } */
}
html[lang=en] q {
  quotes: "‘" "’";
}

a:not([href]) {
  color: var(--primary-text-color);
  text-decoration: none;
  cursor: default;
}

#main h2,
#main h1 {
  font-weight: 700;
  font-size: 2rem;
  text-align: center;
  font-family: var(--primary-serif);
  color: var(--primary-text-color);
}

#main > div > h3 {
  font-weight: 700;
  font-size: 2rem;
  text-align: center;
  font-family: var(--primary-serif);
  color: var(--primary-text-color);
  line-height: 1.3;
}
#main > div > h3 + p {
  margin-block-start: 0;
  font-size: 1.25rem;
  font-weight: 500;
  color: #525252;
  text-align: center;
}
#main ul[data-el=stems] {
  margin-block-start: 0;
  padding-inline-start: 0;
}

#main ul[data-el=stems] li:has(h3.caption) {
  list-style-type: none;
}
#main ul[data-el=stems] li :is(h3, h3.caption) {
  text-align: left;
  margin-inline: initial;
}

#main h3 + table,
#main h3.caption + div.hyphTable > table:first-of-type {
  margin-block-start: 0;
}

#main table {
  margin-block-start: 0;
  padding: 1rem;
  background-image: url(../../images/body-bg.png);
  background-repeat: repeat;
  box-shadow: 0px 1px 3px 0px rgba(10, 13, 18, 0.1), 0px 1px 2px -1px rgba(10, 13, 18, 0.1);
  border-radius: 8px;
  font-family: var(--primary-serif);
  font-size: 1rem;
  font-weight: 400;
  color: var(--primary-text-color);
  border-collapse: collapse;
}
#main table td {
  padding-block: 0.75rem;
  padding-inline: 0.75rem;
  border: 1px solid #d8d8d8;
}
#main table td div[data-el=note] {
  margin-inline: 0;
}

#main table.entryTable {
  max-width: var(--table-width);
  margin-inline: auto;
}

#main table thead td h3 {
  margin-block-start: 0;
}

#main table thead td h3 ~ br {
  display: none;
}

#main table thead td h3 ~ span {
  margin-top: 0.5rem;
}

div[data-el=source] {
  font-family: var(--primary-serif);
  font-weight: 600;
  font-size: 1.25rem;
  color: var(--primary-text-color);
}
div[data-el=source] div[data-el=cit] {
  margin-block-start: 0.5rem;
  font-weight: 400;
  font-size: 1rem;
}

#main h3 {
  width: 100%;
  max-width: var(--text-width);
  margin-inline: auto;
  margin-block-start: 1.5rem;
  font-family: var(--primary-serif);
  font-weight: 600;
  font-size: 1.25rem;
  color: var(--primary-text-color);
  text-align: center;
}

#main h3 + * {
  margin-block-start: 0.5rem;
}

#main h3.caption {
  font-size: 1.25rem;
  font-weight: 600;
}

#main h3[data-el=headword] {
  display: inline;
}

#main span.warning {
  margin-top: 0.5rem;
  display: block;
}

#main table ul {
  margin-inline: 0;
  margin-block-start: 0;
  padding-inline-start: 0;
  list-style-type: none;
}

#main h2 + *,
#main h1 + * {
  margin-top: 1.5rem;
}

div[data-el=listBibl] {
  margin-inline: auto;
  margin-block-start: 1.5rem;
  width: 100%;
  max-width: var(--text-width);
}

div[data-el=bibl] {
  margin-inline-start: 1.5rem;
  margin-block-start: 0.5rem;
  display: list-item;
  list-style-type: none;
  text-indent: -1.5rem;
  font-size: 1rem;
  font-family: var(--primary-serif);
  color: var(--primary-text-color);
}
div[data-el=bibl] span.mjTitle {
  font-style: italic;
}

#main ul.glossary {
  list-style: none;
}
#main ul.glossary h3 {
  text-align: left;
}
#main ul.glossary p[data-el=def] {
  margin-block-start: 0.25rem;
  font-style: italic;
}

div[data-el=note] {
  width: 100%;
  max-width: var(--text-width);
  margin-inline: auto;
  margin-block-start: 0;
  font-family: var(--primary-serif);
}
div[data-el=note] .noteCaption {
  font-family: var(--primary-serif);
  font-weight: 700;
  font-size: 1rem;
  text-align: left;
}

p[data-el=def] + div[data-el=note] {
  margin-block-start: 1.5rem;
}

#main :where(p) {
  font-family: var(--primary-serif);
  font-size: 1rem;
  color: var(--primary-text-color);
  margin-top: 0.5rem;
  margin-inline: auto;
  width: 100%;
  max-width: var(--text-width);
}

#main :where(ul, p) {
  width: 100%;
  max-width: var(--text-width);
  margin-block-start: 1rem;
  margin-inline: auto;
  font-size: 1rem;
  font-family: var(--primary-serif);
  color: var(--primary-text-color);
}

#main :where(ul) {
  padding-inline-start: 1.5rem;
}

.interlin {
  font-variant: small-caps;
}

p[data-el=def] + div#hyph_ {
  margin-block-start: 3rem;
}

#main h2 + div[data-el=eg] h3 {
  font-size: 1.5rem;
  font-weight: 500;
}
#main h2 + div[data-el=eg] p {
  font-size: 1rem;
}

button:focus-visible {
  outline: 2px solid rebeccapurple;
  outline-offset: 4px;
  /* Optional enhancements */
  border-radius: 0.25rem;
  box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.1);
}

.skip-link {
  clip-path: polygon(0 0, 0 0, 0 0, 0 0);
  box-sizing: border-box;
  position: absolute;
  margin: 0;
  padding: 0;
}

.skip-link:focus {
  clip-path: none;
  z-index: 999;
  height: 5rem;
  line-height: 5rem;
  background: white;
  font-size: 1.2rem;
  text-decoration: none;
  color: #1295e6;
  text-align: center;
  width: 100%;
  position: fixed;
}

.visually-hidden {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip-path: inset(50%);
  margin: -1px;
}

body {
  background: var(--site-page-bg);
}
body:has(.nav-panel.open) {
  overflow: hidden;
}

.content-page {
  background-color: #EBE8E8;
}

header .panel-opener {
  z-index: 5;
  position: absolute;
  top: 2rem;
  left: 2rem;
  background-color: transparent;
  border: none;
  width: 80px;
  height: 80px;
}
header .panel-opener img {
  filter: drop-shadow(4px 4px 13px rgba(0, 0, 0, 0.25));
}

@view-transition {
  navigation: auto;
}
button {
  cursor: pointer;
}

.nav-panel {
  position: fixed;
  inset: 0;
  display: none;
  opacity: 0;
  overflow: auto;
  transition-property: opacity, display;
  transition-duration: 200ms, 200ms;
  transition-timing-function: ease-out, ease-out;
  transition-behavior: allow-discrete;
  z-index: 100;
  background-color: #000000;
}

.nav-panel.open {
  display: block;
  opacity: 1;
  background: #000;
}
@starting-style {
  .nav-panel.open {
    opacity: 0;
  }
}

.nav-grid-container {
  margin-block-start: 1.5rem;
  width: calc(100% - 50px);
  margin-inline: 0;
  max-width: 1440px;
  padding-inline-start: 1rem;
  display: grid;
  grid-template-columns: auto;
  grid-template-rows: repeat(3, min-content);
  justify-content: center;
  row-gap: 0;
}
@media only screen and (min-width: 768px) {
  .nav-grid-container {
    margin-inline: auto;
    margin-block-start: 2rem;
    row-gap: 3rem;
  }
}
.nav-grid-container .panel-closer {
  position: fixed;
  top: 1rem;
  right: 1rem;
  justify-self: flex-start;
  appearance: none;
  background: transparent;
  border: none;
  width: 44px;
  height: 44px;
}
.nav-grid-container .panel-closer img {
  background: transparent;
}
@media only screen and (min-width: 768px) {
  .nav-grid-container .panel-closer {
    top: 2rem;
    right: 2rem;
    width: auto;
    height: auto;
  }
}
.nav-grid-container .nav-title {
  width: 90%;
  margin-block-start: 0;
  margin-block-end: 1rem;
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: clamp(1.5rem, 3vw, 3rem);
  color: #ffffff;
  letter-spacing: 2.4px;
  line-height: 1.3;
  text-align: left;
  display: none;
}
@media only screen and (min-width: 768px) {
  .nav-grid-container .nav-title {
    display: block;
    margin-block-start: 1.5rem;
    margin-block-end: 0;
    text-align: left;
  }
}

.navigation__list {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 0.5rem;
  justify-content: flex-start;
  margin-inline: 0;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .navigation__list {
    grid-template-columns: repeat(2, minmax(min(200px, 100%), max-content));
    grid-template-rows: repeat(4, min-content);
    grid-auto-flow: column;
    column-gap: 5rem;
    row-gap: 1.5rem;
    justify-content: center;
    margin-inline: auto;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .navigation__list {
    grid-template-columns: repeat(3, minmax(min(200px, 100%), max-content));
    grid-template-rows: repeat(4, min-content);
    grid-auto-flow: column;
    column-gap: 5rem;
    row-gap: 1.5rem;
  }
}
.navigation__list .navigation__item {
  width: 100%;
  max-width: 23rem;
  display: block;
}
.navigation__list .navigation__link {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  gap: 1rem;
  font-family: var(--primary-sans);
  font-weight: 300;
  font-size: 1.25rem;
  color: white;
  text-decoration-color: transparent;
  transition: all 0.3s ease-in-out;
}
.navigation__list .navigation__link:is(:focus, :hover) {
  text-decoration-color: #ffffff;
}
.navigation__list .navigation__link img {
  width: 50px;
  height: 50px;
  aspect-ratio: 1/1;
}
@media only screen and (min-width: 768px) {
  .navigation__list .navigation__link img {
    width: 100px;
    height: 100px;
  }
}
.navigation__list .misc-container {
  grid-row: auto;
  margin-block-start: 1.5rem;
}
@media only screen and (min-width: 768px) {
  .navigation__list .misc-container {
    margin-block-start: 0;
    grid-row: 1/3;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .navigation__list .misc-container {
    grid-row: 1/4;
  }
}

.nav-misc {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}
.nav-misc .thankyou {
  margin-block-start: 1.5rem;
  width: 100%;
  max-width: 20rem;
}
.nav-misc .thankyou span {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: #ffffff;
  letter-spacing: 1.6px;
  line-height: 1.3;
}
.nav-misc .thankyou .sshrc {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 1.5rem;
}

.nav-contact :is(li) {
  font-family: var(--primary-sans);
  font-size: 1rem;
  color: #ffffff;
  list-style: none;
}
.nav-contact :is(a) {
  list-style: none;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: #ffffff;
  letter-spacing: 1.6px;
  text-decoration: none;
}
.nav-contact :is(a:focus, a:hover) {
  text-decoration: underline;
}

.page-content-wrapper {
  width: 100%;
  margin-inline: auto;
}

.parallax {
  contain: paint;
  position: relative;
  z-index: 0;
  display: grid;
  grid-template-areas: "stack";
  width: 100%;
  margin-inline: auto;
  padding-block-start: var(--splash-padding);
  background-color: #fff;
}

.hero {
  --parallax-speed: 35;
  animation: parallax-hero;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 3.56rem;
  padding-inline: 2rem;
  justify-self: center;
  align-self: flex-start;
  margin-top: calc(clamp(11.75rem, 5vw, 21.875rem) - var(--splash-padding));
  z-index: 4;
  width: 100%;
  max-width: 950px;
}
@media only screen and (min-width: 1024px) and (max-height: 500px) {
  .hero {
    gap: 5.125rem;
  }
}
.hero h1 {
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: clamp(2rem, 4vw, 4rem);
  color: var(--text-color);
  line-height: 1.3;
  text-align: center;
}
.hero h2 {
  font-family: var(--primary-sans);
  font-weight: 800;
  font-size: clamp(1rem, 2vw, 2rem);
  color: var(--text-color);
  text-align: center;
}
.hero h2 .pox-red {
  color: var(--site-highlight);
}

.hero__text-wrapper {
  background-color: #000000;
  padding-block-end: clamp(3.8rem, 4vw, 5.5rem);
  z-index: 15;
}

.hero__text {
  background-color: #000000;
  display: grid;
  margin-inline: auto;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .hero__text {
    grid-template-rows: 90px 1fr 90px;
    grid-template-columns: 90px 1fr 90px;
    width: 80%;
    max-width: 1850px;
  }
}
.hero__text .contents {
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
  grid-row: 2/3;
  grid-column: 2/3;
  padding-inline: 1.625rem;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .hero__text .contents {
    padding-inline: 5.5rem;
  }
}
.hero__text :is(.top-border-brush, .right-border-brush, .bottom-border-brush, .left-border-brush) {
  display: none;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .hero__text :is(.top-border-brush, .right-border-brush, .bottom-border-brush, .left-border-brush) {
    display: block;
  }
}
.hero__text .top-border-brush {
  grid-column: 1/-1;
  grid-row: 1/2;
  background-image: url(../images/top-red-border.png);
  background-size: 100% 7px;
  background-repeat: no-repeat;
  background-position: center center;
}
.hero__text .left-border-brush {
  grid-column: 1/2;
  grid-row: 1/-1;
  background-image: url(../images/left-red-border.png);
  background-size: 13px 100%;
  background-repeat: no-repeat;
  background-position: top right;
}
.hero__text .right-border-brush {
  grid-column: 3/4;
  grid-row: 1/-1;
  background-image: url(../images/right-red-border.png);
  background-size: 13px 100%;
  background-repeat: no-repeat;
}
.hero__text .bottom-border-brush {
  grid-column: 1/-1;
  grid-row: 3/4;
  background-image: url(../images/bottom-red-border.png);
  background-size: 100% 7px;
  background-repeat: no-repeat;
  background-position: center center;
}

.hero__text-description {
  font-family: var(--primary-sans);
  font-weight: 800;
  font-size: 1.25rem;
  color: #ffffff;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .hero__text-description {
    font-size: 1.5rem;
  }
}

.scroll-down-link {
  transition: transform 0.3s ease-in-out;
  transform: scale(1) translateY(0);
}
.scroll-down-link img {
  transition: transform 0.3s ease-in-out;
}
.scroll-down-link:is(:focus, :hover) img {
  transform: scale(1.3) translateY(1rem);
  transition: all 0.3s ease-in-out;
}

@keyframes down-arrow {
  0% {
    transform: scale(1);
  }
  66% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
.parallax > * {
  grid-area: stack;
  animation: parallax linear;
  animation-timeline: scroll(root);
}

.parallax > img {
  width: 100%;
  max-width: 100%;
}

:is(.parallax__people, .parallax__mist, .parallax__mountain-1, .parallax__mountain-2, .parallax__mountain-3) {
  pointer-events: none;
}

.parallax__people {
  --parallax-speed: 1;
  z-index: 9;
  mix-blend-mode: darken;
}

.parallax__mist {
  --parallax-speed: 5;
  z-index: 8;
  mix-blend-mode: darken;
}

.parallax__mountain-1 {
  --parallax-speed: 6;
  z-index: 7;
  mix-blend-mode: darken;
}

.parallax__mountain-2 {
  --parallax-speed: 8;
  z-index: 6;
  mix-blend-mode: darken;
}

.parallax__mountain-3 {
  --parallax-speed: 10;
  z-index: 5;
  mix-blend-mode: darken;
}

.parallax > .parallax__virus {
  z-index: 3;
  mix-blend-mode: multiply;
  animation: none;
  width: 85%;
  position: absolute;
  top: calc(var(--splash-padding) * -1);
  right: 0;
  animation: virus forwards 5s ease-in-out;
  width: 85%;
  max-width: 1872px;
  opacity: 0.5;
}

@keyframes parallax {
  to {
    transform: translateY(calc(var(--parallax-speed) * 50px));
  }
}
@keyframes virus {
  0% {
    top: -25%;
    right: -25%;
    transform: translateY(calc(var(--splash-padding) * -1)) scale(0.3);
    opacity: 0;
  }
  100% {
    top: calc(var(--splash-padding) * -1);
    right: 0;
    transform: scale(1);
    opacity: 0.5;
  }
}
.main-content {
  position: relative;
  padding-block: 6rem;
  min-height: 0;
}
.main-content.internal {
  padding-block-start: 3rem;
  padding-block-end: 6rem;
}
.main-content .content-column {
  margin-inline: auto;
  width: 100%;
  max-width: 61.875rem;
  /* display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center; */
  padding-inline: 1.625rem;
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .main-content .content-column {
    max-width: 80rem;
  }
}
.main-content .content-column.breakout {
  padding-inline: 0;
  max-width: 150rem;
}
.main-content p {
  width: 100%;
  max-width: 60rem;
  margin-block-start: 1.5rem;
}
.main-content p.center {
  text-align: center;
  margin-inline: auto;
}
.main-content p.red {
  color: var(--site-highlight);
}

.content-link {
  color: var(--site-highlight);
  text-decoration: underline;
  transition: all 0.3s ease-in-out;
}
.content-link:is(:focus-visible, :hover) {
  text-decoration-color: transparent;
}

.header-wrapper {
  margin-block-start: 4rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0;
}
@media only screen and (min-width: 1024px) {
  .header-wrapper {
    margin-block-start: 1.5rem;
  }
}
.header-wrapper .page-header {
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: 3rem;
  color: var(--text-color);
  text-align: center;
}

.content-column.breakout {
  margin-block-start: 3rem;
}
.content-column.breakout .tip {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--text-color);
  text-align: center;
  letter-spacing: 1.6px;
  padding-inline: var(--column-padding);
}

@media only screen and (min-width: 1024px) {
  .timeline-wrapper {
    padding: var(--column-padding);
  }
}

.timeline-container {
  margin-block-start: 2rem;
}
.timeline-container > * {
  opacity: 0;
  transform: translateY(2rem);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.timeline-container > *.fade-in {
  opacity: 1;
  transform: translateY(0);
}
.timeline-container > *.visible-no-fade {
  opacity: 1;
  transform: none;
  transition: none;
}
@media only screen and (min-width: 1024px) {
  .timeline-container {
    margin-block-start: 1.4rem;
    position: relative;
    margin-inline: auto;
    display: grid;
    grid-template-rows: 311.5px 364.7px 445.2px 542.5px;
    width: 100%;
    max-width: 69rem;
  }
}
@media only screen and (min-width: 1440px) {
  .timeline-container {
    grid-template-rows: 445px 521px 636px 775px;
    max-width: 86rem;
    margin-block-start: 2rem;
  }
}
.timeline-container .timeline-date-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-block-start: 1rem;
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-date-container {
    margin-block-start: 0.7rem;
  }
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-date-container {
    margin-block-start: 1rem;
  }
}
.timeline-container .timeline-date-container .timeline-date {
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: 8rem;
  color: var(--text-color);
  line-height: 1;
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-date-container .timeline-date {
    font-size: 5.6rem;
  }
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-date-container .timeline-date {
    font-size: 8rem;
  }
}
.timeline-container .timeline-date-container .timeline-location {
  margin-block-start: 0.5rem;
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: 2rem;
  color: var(--text-color);
  line-height: 1.2;
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-date-container .timeline-location {
    font-size: 1.4rem;
  }
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-date-container .timeline-location {
    font-size: 2rem;
  }
}
.timeline-container .timeline-date-container .timeline-readmore {
  margin-block-start: 2rem;
}
.timeline-container .timeline-date-container .timeline-readmore a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding-block: 0.625rem;
  padding-inline: 1.375rem;
  background-color: var(--site-highlight);
  font-family: var(--primary-sans);
  font-weight: 900;
  font-size: 1.5rem;
  color: #ffffff;
  letter-spacing: 2.4px;
  text-decoration: none;
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-date-container .timeline-readmore a {
    gap: 7px;
    padding-block: 0.4375rem;
    padding-inline: 0.9625rem;
    font-size: 1.05rem;
    letter-spacing: 1.68px;
  }
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-date-container .timeline-readmore a {
    gap: 10px;
    padding-block: 0.625rem;
    padding-inline: 1.375rem;
    font-size: 1.5rem;
    letter-spacing: 2.4px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-date-container .timeline-readmore {
    margin-block-start: 1.4rem;
  }
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-date-container .timeline-readmore {
    margin-block-start: 2rem;
  }
}
.timeline-container .timeline-track {
  margin-block-start: 4rem;
  position: relative;
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track {
    display: none;
  }
}
.timeline-container .timeline-track.poxed-right::before {
  content: "";
  width: 150px;
  height: 150px;
  position: absolute;
  top: -75px;
  right: -75px;
  background-size: cover;
  background-image: url(../images/timeline-bg.webp);
  transform: rotate(45deg);
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track.poxed-right::before {
    top: 975px;
    left: 1061px;
  }
}
.timeline-container .timeline-track.poxed-left::before {
  content: "";
  width: 150px;
  height: 150px;
  position: absolute;
  top: -75px;
  left: -75px;
  background-size: cover;
  background-image: url(../images/timeline-bg.webp);
  transform: rotate(180deg);
}
.timeline-container .timeline-track img {
  margin-inline: auto;
  display: block;
}
.timeline-container .end-timeline {
  display: block;
  margin-inline: auto;
  margin-block-start: 1.5rem;
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: 3rem;
  color: var(--text-color);
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .timeline-container .end-timeline {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    margin-block-start: 1.05rem;
    font-size: 2.1rem;
  }
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .end-timeline {
    margin-block-start: 1.5rem;
    font-size: 3rem;
  }
}
.timeline-container > :is([class*=timeline-track-desktop-]) {
  display: none;
}
@media only screen and (min-width: 1024px) {
  .timeline-container > :is([class*=y1]) {
    position: absolute;
  }
  .timeline-container > :is([class*=timeline-track-desktop-]) {
    display: block;
  }
  .timeline-container > :is([class*=desktop-]) {
    position: absolute;
  }
  .timeline-container .y1770 {
    top: 0%;
    left: 0%;
  }
  .timeline-container .timeline-track-desktop-1 {
    top: 3.113%;
    left: 23.91%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-1 {
    width: 79.8px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-1 {
    width: 114px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1775 {
    top: 2.945%;
    left: 34.64%;
  }
  .timeline-container .timeline-track-desktop-2 {
    top: 5.636%;
    left: 58.7%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-2 {
    width: 79.8px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-2 {
    width: 114px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1782 {
    top: 4.418%;
    left: 68.55%;
  }
  .timeline-container .timeline-track-desktop-3 {
    top: 9.171%;
    left: 76.59%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-3 {
    width: 170.1px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-3 {
    width: 243px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1835 {
    top: 25.23%;
    left: 51.45%;
  }
  .timeline-container .timeline-track-desktop-4 {
    top: 33.86%;
    left: 41.88%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-4 {
    width: 74.9px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-4 {
    width: 107px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1845 {
    top: 28.23%;
    left: 17.39%;
  }
  .timeline-container .timeline-track-desktop-5 {
    top: 34.7%;
    left: 0.94%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-5 {
    width: 132.3px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-5 {
    width: 189px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1853 {
    top: 48.05%;
    left: 0%;
  }
  .timeline-container .timeline-track-desktop-6 {
    top: 51.34%;
    left: 24.35%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-6 {
    width: 74.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-6 {
    width: 106px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1860 {
    top: 50.26%;
    left: 33.7%;
  }
  .timeline-container .timeline-track-desktop-7 {
    top: 53.93%;
    left: 57.97%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-7 {
    width: 74.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-7 {
    width: 106px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1862 {
    top: 53.21%;
    left: 67.83%;
  }
  .timeline-container .timeline-track-desktop-8 {
    top: 62.81%;
    left: 77.1%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-8 {
    width: 130.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-8 {
    width: 186px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1868 {
    top: 71.53%;
    left: 51.09%;
  }
  .timeline-container .timeline-track-desktop-9 {
    top: 74.84%;
    left: 41.09%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-9 {
    width: 74.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-9 {
    width: 106px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .y1894 {
    top: 74.2%;
    left: 16.88%;
  }
  .timeline-container .timeline-track-desktop-10 {
    top: 82.37%;
    left: 14.13%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-10 {
    width: 130.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-10 {
    width: 186px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-1 {
    top: 3.113%;
    right: 52.68%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-1 {
    width: 79.8px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-1 {
    width: 114px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-2 {
    top: 5.636%;
    right: 17.89%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-2 {
    width: 79.8px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-2 {
    width: 114px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-3 {
    top: 9.171%;
    right: 0;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-3 {
    width: 170.1px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-3 {
    width: 243px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-4 {
    top: 33.86%;
    right: 34.71%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-4 {
    width: 74.9px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-4 {
    width: 107px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-5 {
    top: 34.7%;
    right: 75.65%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-5 {
    width: 132.3px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-5 {
    width: 189px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-6 {
    top: 51.34%;
    right: 52.24%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-6 {
    width: 74.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-6 {
    width: 106px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-7 {
    top: 53.93%;
    right: 18.62%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-7 {
    width: 74.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-7 {
    width: 106px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-8 {
    top: 62.81%;
    left: 77.1%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-8 {
    width: 130.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-8 {
    width: 186px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-9 {
    top: 74.84%;
    right: 35.5%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-9 {
    width: 74.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-9 {
    width: 106px;
  }
}
@media only screen and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-10 {
    top: 82.37%;
    right: 62.46%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .timeline-container .timeline-track-desktop-10 {
    width: 130.2px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .timeline-container .timeline-track-desktop-10 {
    width: 186px;
  }
}

.poxed-1 {
  display: none;
}
@media only screen and (min-width: 1024px) {
  .poxed-1 {
    display: block;
    position: absolute;
    top: 41.02%;
    left: 76.88%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .poxed-1 img {
    width: 210px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .poxed-1 img {
    width: 300px;
  }
}

.poxed-2 {
  display: none;
}
@media only screen and (min-width: 1024px) {
  .poxed-2 {
    display: block;
    position: absolute;
    top: 73.21%;
    left: 0%;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1024px) {
  .poxed-2 img {
    width: 140px;
  }
}
@media only screen and (min-width: 1024px) and (min-width: 1440px) and (min-height: 500px) {
  .poxed-2 img {
    width: 200px;
  }
}

.epidemics-top-grid {
  display: grid;
}
.epidemics-top-grid :is(.para-1, .para-2, .para-3) {
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .epidemics-top-grid {
    grid-template-rows: auto auto;
    grid-template-columns: auto auto;
    column-gap: 2rem;
  }
  .epidemics-top-grid .para-1 {
    margin-inline: auto;
    grid-column: 1/3;
    grid-row: 1/2;
    text-align: left;
  }
  .epidemics-top-grid .video-container {
    grid-column: 1/2;
    grid-row: 2/3;
  }
  .epidemics-top-grid .epidemics-multirow {
    grid-column: 2/3;
    grid-row: 2/3;
    text-align: left;
  }
  .epidemics-top-grid .epidemics-multirow p {
    text-align: left;
  }
}

.endemic {
  margin-block-start: 2.25rem;
  margin-inline: auto;
  padding-inline: 2rem;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--text-color);
  letter-spacing: 0.32px;
  text-align: center;
}

.pox-account {
  display: grid;
  grid-template-rows: 48px 1fr 48px;
  grid-template-columns: 48px 1fr 48px;
  width: 100%;
  max-width: 69rem;
  margin-block-start: 10rem;
  margin-inline: auto;
}
.pox-account .top-border-brush {
  grid-column: 1/-1;
  grid-row: 1/2;
  background-image: url(../images/top-red-border.png);
  background-size: 100% 7px;
  background-repeat: no-repeat;
  background-position: center center;
}
.pox-account .left-border-brush {
  grid-column: 1/2;
  grid-row: 1/-1;
  background-image: url(../images/left-red-border.png);
  background-size: 13px 100%;
  background-repeat: no-repeat;
  background-position: top right;
}
.pox-account .right-border-brush {
  grid-column: 3/4;
  grid-row: 1/-1;
  background-image: url(../images/right-red-border.png);
  background-size: 13px 100%;
  background-repeat: no-repeat;
}
.pox-account .bottom-border-brush {
  grid-column: 1/-1;
  grid-row: 3/4;
  background-image: url(../images/bottom-red-border.png);
  background-size: 100% 7px;
  background-repeat: no-repeat;
  background-position: center center;
}
.pox-account .content {
  display: grid;
  grid-column: 2/3;
  grid-row: 2/3;
  padding-block: 0;
  padding-inline: 2rem;
  margin-block-start: 0;
}
.pox-account .content blockquote {
  margin-block-start: 0;
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1rem;
  color: var(--site-highlight);
}
.pox-account .content blockquote .attribution {
  padding: 0;
  margin-block-start: 1.5rem;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--site-highlight);
  text-align: right;
  background-color: transparent;
}

nav:has(.paging-navigation) {
  width: 100%;
}

.paging-navigation {
  display: grid;
  grid-template-rows: auto auto;
  grid-template-columns: auto auto;
  margin-block-start: 17rem;
  row-gap: 2rem;
}
.paging-navigation li {
  list-style: none;
}
.paging-navigation a {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--text-color);
  text-decoration: none;
  letter-spacing: 1.6px;
}
.paging-navigation .home {
  grid-column: 1/3;
}
.paging-navigation .home a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
}
.paging-navigation .next {
  grid-row: 2/3;
  grid-column: 2/3;
  margin-inline-start: auto;
}
.paging-navigation .next a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  text-align: right;
  gap: 0.5rem;
}
.paging-navigation .previous {
  grid-row: 2/3;
  grid-column: 1/2;
  margin-inline-end: auto;
}
.paging-navigation .previous a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  text-align: right;
  gap: 0.5rem;
}

.circle-nav {
  display: grid;
  gap: 2rem;
  width: 100%;
  max-width: 304px;
  align-items: flex-start;
  list-style: none;
  margin-inline: auto;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav {
    grid-template-columns: 36.16% 28.28% 31.55%;
    grid-template-rows: 26.63% 29.7% 43.67%;
    max-width: 1092px;
    gap: 0rem;
    aspect-ratio: 1092/815;
  }
}
.circle-nav li {
  display: flex;
  transform: scale(1);
  transition: transform 0.3s ease-in-out;
}
.circle-nav li:has(a:focus, a:hover) {
  transform: scale(1.1);
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav li {
    position: relative;
  }
}
.circle-nav a {
  display: flex;
  flex-direction: row-reverse;
  justify-self: flex-start;
  align-items: center;
  gap: 1.5rem;
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--text-color);
  text-decoration: none;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav a {
    flex-direction: row;
    align-items: center;
    gap: 1.25rem;
    position: absolute;
  }
}
.circle-nav a img {
  width: 90px;
  height: 90px;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav a img {
    width: 150px;
    height: 150px;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .bottom a {
    flex-direction: column-reverse;
    text-align: center;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .right a {
    flex-direction: row-reverse;
  }
}
.circle-nav .header {
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--text-color);
  text-align: center;
  line-height: 1.3;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .header {
    grid-column: 2/3;
    grid-row: 2/3;
    /* 50px of 242px ≈ 20.66% */
    top: 20.66%;
    left: 0%;
    font-size: 1.5rem;
  }
}
@media only screen and (min-width: 1280px) and (min-height: 500px) {
  .circle-nav .header {
    font-size: 1.75rem;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav :is(.epidemics, .bibliography) {
    grid-column: 1/-1;
    grid-row: 1/2;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .vaccinations {
    grid-column: 1/2;
    grid-row: 2/3;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .research {
    grid-column: 1/2;
    grid-row: 3/4;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .publications {
    grid-column: 2/3;
    grid-row: 3/4;
    margin-top: auto;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .curriculum {
    grid-column: 3/4;
    grid-row: 3/4;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .team {
    grid-column: 3/4;
    grid-row: 2/3;
  }
}
.circle-nav .epidemics a {
  /* 197px of (395+309+345=1049px) ≈ 18.78% */
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .epidemics a {
    left: 18.78%;
    top: 0%;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .bibliography a {
    /* original left: 602px ⇒ 602/1049 ≈ 57.39% */
    left: 57.39%;
    top: 0%;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .vaccinations a {
    left: 0%;
    top: 0%;
    text-align: right;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .research a {
    /* 105px of 395px ≈ 26.58% */
    left: 26.58%;
    /* 30px of 356px ≈ 8.43% */
    top: 8.43%;
    text-align: right;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .publications a {
    /* 70px of 309px ≈ 22.65% */
    left: 22.65%;
    bottom: 0%;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .curriculum a {
    /* 5px of 345px ≈ 1.45% */
    left: 1.45%;
    /* 20px of 356px ≈ 5.62% */
    top: 5.62%;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .team a {
    /* 73px of 345px ≈ 21.16% */
    left: 21.16%;
    top: 0%;
  }
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .circle-nav .bibliography a {
    /* 130px of 1049px ≈ 12.39% */
    right: 12.39%;
    top: 0%;
  }
}

.mini-head {
  margin-block-start: 4.5rem;
  margin-inline: auto;
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1.25rem;
  font-style: italic;
  color: var(--text-color);
  text-align: center;
}

.mini-head + .section-head {
  margin-block-start: 2.625rem;
}

.section-head {
  margin-block-start: 3rem;
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 3rem);
  color: var(--text-color);
  line-height: 1.4;
  text-align: center;
}

.center {
  text-align: center;
}

.red {
  color: var(--site-highlight);
}

.content-column {
  /* & h2+* {
  	margin-block-start: .5rem;
  } */
}
.content-column p {
  margin-block-start: 1.5rem;
  font-family: var(--primary-sans);
  font-size: 1.25rem;
  color: var(--text-color);
}
.content-column .content-image {
  display: grid;
  grid-template-rows: auto auto auto;
  margin-inline: auto;
  width: 100%;
  max-width: 36rem;
  position: relative;
}
@media only screen and (min-width: 1024px) {
  .content-column .content-image {
    margin-block-start: 1.5rem;
    margin-inline: 0;
  }
}
.content-column .content-image .content-image-link-wrapper {
  display: grid;
  grid-template-rows: auto auto auto;
  text-decoration: none;
}
.content-column .content-image .content-image-link-wrapper .flyout-link-wrapper {
  grid-row: 3/4;
}
@media only screen and (min-width: 1024px) {
  .content-column .content-image .content-image-link-wrapper .flyout-link-wrapper {
    grid-row: 1/2;
  }
}
.content-column .content-image .content-image-link-wrapper .pseudo-caption {
  grid-row: 2/3;
  width: 100%;
  padding-inline: 3rem;
  font-family: var(--primary-sans);
  font-weight: 300;
  font-size: 0.875rem;
  color: var(--text-color);
}
@media only screen and (min-width: 1024px) {
  .content-column .content-image .content-image-link-wrapper .pseudo-caption {
    grid-row: 3/4;
  }
}
.content-column .content-image .flyout-link-wrapper {
  width: 100%;
  max-width: 340px;
  background-color: #000000;
  position: static;
  margin-inline: auto;
  margin-block-start: 1.5rem;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  .content-column .content-image .flyout-link-wrapper {
    width: 370px;
    position: absolute;
    top: 25%;
    left: 82%;
    transition: transform 0.3s ease-in-out;
  }
}
.content-column .content-image .flyout-link-wrapper .flyout-text {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding-inline: 1.5rem;
  padding-block: 1rem;
  font-family: var(--primary-sans);
  font-weight: 900;
  font-size: 1.5rem;
  color: #ffffff;
  text-decoration: none;
}
.content-column .content-image .flyout-link-wrapper .flyout-text img {
  width: 150px;
}
@media only screen and (min-width: 1024px) {
  .content-column .content-image:is(:hover, :focus) .flyout-link-wrapper {
    transform: scale(1.2) translateX(-45%);
  }
}
.content-column .content-image + .section-head {
  margin-block-start: 5rem;
}

.reminder {
  margin-block-start: 7rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.reminder .reminder-head {
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 2rem;
  color: var(--text-color);
  letter-spacing: 1.6px;
  text-align: center;
  text-transform: uppercase;
}
.reminder > p {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1.4rem;
  color: var(--text-color);
  text-align: center;
}

.video-container {
  margin-block-start: 1.5rem;
  width: 100%;
  max-width: 39rem;
  margin-inline: auto;
}

.video-container video {
  display: block;
  width: 100%;
  height: auto;
}

.vaccine-grid {
  display: grid;
}
@media only screen and (min-width: 1024px) {
  .vaccine-grid {
    grid-template-columns: auto auto;
    grid-template-rows: auto auto;
    column-gap: 3rem;
    row-gap: 2rem;
  }
}
@media only screen and (min-width: 1024px) {
  .vaccine-grid .red-header {
    grid-column: 1/3;
    grid-row: 1/2;
  }
}
.vaccine-grid p {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--text-color);
}
@media only screen and (min-width: 1024px) {
  .vaccine-grid .content-1 :is(.image-container:first-child, .trigger-wrapper::first-child, p:first-child) {
    margin-block-start: 0;
  }
}
@media only screen and (min-width: 1024px) {
  .vaccine-grid .content-1 {
    grid-column: 1/2;
    grid-row: 2/3;
  }
}
@media only screen and (min-width: 1024px) {
  .vaccine-grid .content-2 :is(.image-container:first-child, .trigger-wrapper::first-child, p:first-child) {
    margin-block-start: 0;
  }
}
@media only screen and (min-width: 1024px) {
  .vaccine-grid .content-2 {
    grid-column: 2/3;
    grid-row: 2/3;
  }
}

.red-header {
  width: 100%;
  margin-block-start: 7rem;
  padding-block-end: 0.75rem;
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 2rem;
  color: var(--site-highlight);
  letter-spacing: 1.6px;
  line-height: 1.3;
  position: relative;
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .red-header {
    text-align: left;
  }
}
.red-header:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 5px;
  background-image: url(../images/red-header-border.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  bottom: 0;
  left: 0;
}

.image-container {
  margin-block-start: 3rem;
  margin-inline: auto;
  display: table;
}
.image-container .caption {
  display: table-caption;
  caption-side: bottom;
  max-width: 100%;
  overflow-wrap: break-word;
  font-family: var(--primary-sans);
  font-weight: 300;
  font-size: 0.875rem;
  color: var(--text-color);
}
.image-container .trigger-wrapper {
  position: relative;
  display: grid;
  grid-template-areas: "stack";
  cursor: pointer;
  z-index: 1;
}
.image-container .trigger-wrapper > * {
  grid-area: stack;
}
.image-container .trigger-wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(8.5px);
  opacity: 1;
  transition: opacity 0.3s ease-in-out;
}
.image-container .trigger-wrapper.triggered::before {
  opacity: 0;
}
.image-container .trigger-wrapper:focus-visible {
  outline: 2px solid #333;
  outline-offset: 4px;
}
.image-container .trigger-wrapper.triggered .trigger-warning {
  display: none;
}
.image-container .trigger-warning {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 2;
}
.image-container .trigger-warning .warning {
  margin-block-start: 1rem;
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1rem;
  color: #ffffff;
  text-align: center;
}
.image-container .trigger-warning .click-to-reveal {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: #ffffff;
  text-align: center;
}

.presentations-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.presentations-grid {
  display: grid;
  gap: 0.5rem;
  padding: 1.25rem;
  margin-block-start: 3rem;
  background: #E3DEDE;
  box-shadow: var(--container-shadow);
}
.presentations-grid .date {
  margin-block-start: 0;
  font-family: var(--primary-sans);
  font-weight: 600;
  font-size: 1.25rem;
  color: var(--text-color);
}
.presentations-grid :is(.org, .title, .location) {
  margin-block-start: 0;
  font-family: var(--primary-sans);
  font-weight: 300;
  font-size: 1.25rem;
  color: var(--text-color);
}
.presentations-grid .title-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0.5rem;
}
.presentations-grid .title-wrapper .presenter {
  margin-block-start: 0;
  font-style: italic;
}

.book-grid {
  margin-block-start: 3rem;
  display: grid;
  row-gap: 1.5rem;
  padding: 1.25rem;
  box-shadow: var(--container-shadow);
  background-color: #E3DEDE;
}
@media only screen and (min-width: 1024px) {
  .book-grid {
    grid-template-rows: auto 1fr;
    grid-template-columns: auto auto;
    align-content: flex-start;
    align-items: start;
    column-gap: 2rem;
  }
}
.book-grid .image-container {
  margin-block-start: 0;
  margin-block-end: 0;
}
@media only screen and (min-width: 1024px) {
  .book-grid .image-container {
    grid-column: 1/2;
    grid-row: 1/2;
  }
}
.book-grid .book-link {
  width: 100%;
  max-width: 205px;
  padding: 0.75rem;
  background-color: var(--site-highlight);
  margin-inline: auto;
  font-family: var(--primary-sans);
  font-weight: 900;
  font-size: 1rem;
  color: #ffffff;
  text-decoration: none;
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .book-grid .book-link {
    grid-column: 1/2;
    grid-row: 2/3;
    align-self: flex-start;
  }
}
@media only screen and (min-width: 1024px) {
  .book-grid .book-info-wrapper {
    grid-column: 2/3;
    grid-row: 1/3;
    align-self: flex-start;
  }
}
.book-grid .book-title {
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--text-color);
  font-style: normal;
}
.book-grid .publication-date {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--site-highlight);
  letter-spacing: 1.6px;
}
.book-grid time {
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-color);
}
.book-grid .publisher-type {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--site-highlight);
  letter-spacing: 1.6px;
}
.book-grid .publisher-title {
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-color);
}
.book-grid .publisher-title cite {
  font-style: normal;
}
.book-grid .citation-header {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--site-highlight);
  letter-spacing: 1.6px;
}
.book-grid .citation {
  margin-block-start: 1.5rem;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--text-color);
  font-style: italic;
}
.book-grid .citation:first-of-type {
  margin-block-start: 0;
}
.book-grid p {
  margin-block-start: 0;
}

.book-info-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0.5rem;
}

a:has(.sshrc-horizontal) {
  display: block;
  margin-block-start: 1.5rem;
  margin-inline: auto;
  text-align: center;
}

.sshrc-horizontal {
  width: 100%;
  max-width: 320px;
}

@media only screen and (min-width: 1024px) {
  .team-section > .red-header {
    text-align: center;
  }
}

.team-members-wrapper {
  display: grid;
}
@media only screen and (min-width: 1440px) and (min-height: 500px) {
  .team-members-wrapper {
    grid-template-columns: auto auto;
    column-gap: 3rem;
  }
}

.team-member {
  width: 100%;
}

.team-member-grid {
  display: grid;
}
@media only screen and (min-width: 1024px) {
  .team-member-grid {
    grid-template-columns: max-content 1fr;
    column-gap: 1.5rem;
  }
}
.team-member-grid .member-info {
  margin-block-start: 1.25rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
@media only screen and (min-width: 1024px) {
  .team-member-grid .member-info {
    align-items: flex-start;
  }
}
.team-member-grid p {
  margin-block-start: 0.625rem;
}
.team-member-grid .member-name {
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--text-color);
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .team-member-grid .member-name {
    text-align: left;
  }
}
.team-member-grid .member-position {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  font-style: italic;
  color: var(--text-color);
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .team-member-grid .member-position {
    text-align: left;
  }
}
.team-member-grid .member-affiliation {
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-color);
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .team-member-grid .member-affiliation {
    text-align: left;
  }
}
.team-member-grid .member-contact a {
  display: block;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: var(--site-highlight);
  text-decoration: underline;
  transition: text-decoration-color 0.3s ease-in-out;
  text-align: center;
}
.team-member-grid .member-contact a .member-contact a:is(:focus-visble, :hover) {
  text-decoration-color: transparent;
}
@media only screen and (min-width: 1024px) {
  .team-member-grid .member-contact a {
    text-align: left;
  }
}

.university-logo-link {
  display: block;
  margin-block-start: 1.5rem;
  margin-inline: auto;
  text-align: center;
}

.student-researcher-list {
  margin-block-start: 1.5rem;
  list-style-type: none;
}
.student-researcher-list li {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1.5rem;
  font-style: italic;
  color: var(--text-color);
  text-align: center;
}

.alpha-list {
  margin-block-start: 3rem;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  list-style: none;
  gap: 1rem;
}
.alpha-list .alpha-link {
  width: 44px;
  height: 44px;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  border: 1px solid var(--site-highlight);
  background-color: transparent;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--site-highlight);
  letter-spacing: 1.2px;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}
.alpha-list .alpha-link:is(:focus-visible, :hover) {
  background-color: var(--site-highlight);
  color: #ffffff;
}

.alpha-letter-wrapper {
  margin-block-start: 3rem;
}
.alpha-letter-wrapper .alpha-header {
  position: sticky;
  top: 30px;
  float: left;
  font-family: var(--primary-sans);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--site-highlight);
  line-height: 1;
}
.alpha-letter-wrapper .bibliography-list {
  margin-inline-start: 4rem;
}
.alpha-letter-wrapper .bibliography-item {
  margin-block-start: 1rem;
  margin-inline-start: 1.5em;
  text-indent: -1.5em;
  list-style: none;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1.125rem;
  color: var(--text-color);
}

footer {
  background-color: #000;
  padding: 3rem;
  margin-block-start: 3.5rem;
}
footer .foot-grid {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  width: 100%;
  max-width: 1440px;
  margin-inline: auto;
  gap: 4.375rem;
}
@media only screen and (min-width: 1024px) {
  footer .foot-grid {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-evenly;
    gap: 0;
  }
}
footer .foot-grid :is(.foot-nav, .foot-contact) {
  width: max-content;
  max-width: 376px;
}
footer .foot-grid :is(.foot-nav ul, .foot-contact ul) {
  margin-inline-end: 0;
}
@media only screen and (min-width: 1024px) {
  footer .foot-grid :is(.foot-nav ul, .foot-contact ul) {
    margin-inline-end: 2rem;
  }
}
footer .foot-grid :is(.foot-nav li, .foot-contact li) {
  font-family: var(--primary-sans);
  font-size: 1rem;
  color: #ffffff;
  list-style: none;
  text-align: center;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  footer .foot-grid :is(.foot-nav li, .foot-contact li) {
    text-align: left;
  }
}
footer .foot-grid :is(.foot-nav a, .foot-contact a) {
  list-style: none;
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: #ffffff;
  letter-spacing: 1.6px;
  text-decoration: none;
}
footer .foot-grid :is(.foot-nav a:focus, .foot-nav a:hover, .foot-contact a:hover, .foot-contact a:focus) {
  text-decoration: underline;
}
footer .foot-grid .foot-logos {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4.3rem;
}
footer .foot-grid .foot-logos .foot-title {
  font-family: var(--primary-serif);
  font-weight: 400;
  font-size: 2rem;
  color: var(--site-highlight);
  line-height: 1.3;
  text-align: center;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  footer .foot-grid .foot-logos .foot-title {
    text-align: left;
  }
}
footer .foot-grid .foot-logos .thankyou {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4.3rem;
  /* @media only screen and (min-width: $tablet-portrait-width)  {
  flex-direction: row;
  gap: 4rem;
  } */
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  footer .foot-grid .foot-logos .thankyou {
    flex-direction: row;
    gap: 1.5rem;
  }
}
footer .foot-grid .foot-logos .thankyou img {
  width: 282px;
  height: 282px;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  footer .foot-grid .foot-logos .thankyou img {
    width: 100%;
    max-width: 205px;
    height: 205px;
  }
}
footer .foot-grid .foot-logos .sshrc {
  max-width: 188px;
}
footer .foot-grid .foot-logos .sshrc img {
  margin-block-start: 1.5rem;
  width: 100%;
  max-width: 188px;
  height: auto;
}
footer .foot-grid .foot-logos .sshrc span {
  font-family: var(--primary-sans);
  font-weight: 400;
  font-size: 1rem;
  color: #ffffff;
  letter-spacing: 1.6px;
  line-height: 1.3;
  text-align: center;
}
@media only screen and (min-width: 1024px) and (min-height: 500px) {
  footer .foot-grid .foot-logos .sshrc span {
    text-align: left;
  }
}

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