/* adapted from https://pawelgrzybek.com/the-css-reset-again/ */
@layer reset {
  *,
  *::before,
  *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }
  html {
    color-scheme: light dark;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
    hanging-punctuation: first allow-end last;
  }
  html.translated-rtl {
    direction: rtl;
  }
  input, textarea {
    hanging-punctuation: none;
  }
  h1, h2, h3, h4, h5, h6 {
    text-wrap: balance;
  }
}
body {
  background-color: #fff;
  color: #222;
  font-family: "Mulish", sans-serif;
  font-weight: 300;
  line-height: 1.4;
  text-align: center;
}

h1, h2, h3, h4, h5, h6 {
  color: #2622b2;
  cursor: default;
  font-family: "Hanuman", serif;
  line-height: 1.25;
}
h1 em, h2 em, h3 em, h4 em, h5 em, h6 em {
  color: #cc004a;
  font-style: normal;
  white-space: pre;
}

h1 {
  font-size: 3em;
}

h2 {
  font-size: 2.25em;
  margin-bottom: 16px;
}

h3 {
  font-size: 1.5em;
  font-weight: 400;
  margin-bottom: 4px;
}

h4 {
  font-size: 1.125em;
  font-weight: 500;
  margin-bottom: 4px;
}

p:not(:last-child) {
  margin-bottom: 12px;
}

ul {
  margin-left: 1em;
}
ul li em {
  font-style: normal;
  font-weight: bold;
}
ul li::marker {
  color: #2622b2;
  font-size: 0.875em;
}
ul li:nth-child(even)::marker {
  color: #cc004a;
}
ul li:not(:last-child) {
  margin-bottom: 4px;
}

.button {
  align-items: center;
  background: #2622b2;
  border: #2622b2 2px solid;
  border-radius: 3px;
  color: #fff;
  display: inline-flex;
  font-weight: 600;
  margin: 6px;
  padding: 10px 16px;
  text-decoration: none;
  transition: all 0.12s;
}
.button:first-of-type {
  margin-left: 0;
}
.button:last-of-type {
  margin-right: 0;
}
.button .icon {
  font-variation-settings: "opsz" 20;
  margin-left: 2px;
}
.button:hover, .button:focus {
  background: #4541e5;
  border-color: #4541e5;
}
.button.outlined {
  background: #fff;
  color: #2622b2;
}
.button.outlined:hover, .button.outlined:focus {
  border-color: #4541e5;
  color: #4541e5;
}

.image-placeholder {
  background: #fff;
  flex: 0 0 auto;
  overflow: hidden;
  position: relative;
}
.image-placeholder::after {
  align-items: center;
  border: 1px #bbb dotted;
  bottom: 0;
  content: "image\a coming\asoon";
  color: #bbb;
  display: flex;
  font-weight: 100;
  justify-content: center;
  left: 0;
  line-height: 1.25;
  position: absolute;
  right: 0;
  text-align: center;
  top: 0;
  white-space: pre-wrap;
}
.image-placeholder.lg {
  font-size: 4em;
  height: 500px;
  width: 500px;
}
.image-placeholder.md {
  font-size: 1.5em;
  height: 300px;
  width: 300px;
}
.image-placeholder.sm {
  font-size: 1em;
  height: 150px;
  width: 150px;
}

section {
  align-items: center;
  display: flex;
  justify-content: center;
  min-height: 100px;
  padding: 48px 32px;
  width: 100%;
}
section:nth-child(even) {
  background: #f6f5fb;
}
section:nth-child(odd) .card {
  background: #f6f5fb;
}
section:last-of-type {
  padding-bottom: 96px;
}
section .subsection:not(:last-child) {
  margin-bottom: 48px;
}

.content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 1000px;
  text-align: left;
}

.img-with-text {
  display: flex;
}
.img-with-text .text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.card {
  background: #fff;
  border-radius: 4px;
  box-shadow: 0 2px rgba(38, 34, 178, 0.07);
  padding: 20px;
}

#top {
  padding-top: 24px;
}
#top .logo-section {
  margin-bottom: 24px;
  max-width: 1000px;
  width: 100%;
}
#top .mri-logo {
  margin-bottom: 10px;
  max-width: calc(100vw - 32px);
  width: 300px;
}
#top .content {
  align-items: center;
  max-width: 1280px;
  min-width: 900px;
}
#top .img-with-text {
  padding: 0 0 48px 0;
}
#top .img-with-text .button {
  margin: 12px 12px 0 0;
}
#top .top-img {
  height: 450px;
  width: 500px;
}
#top .text {
  padding: 0 0 0 12px;
}
#top .subhead {
  font-size: 1.125em;
  margin-bottom: 6px;
  text-wrap: balance;
}
#top .logo-img {
  height: 150px;
  width: 150px;
}

.partners {
  text-align: center;
  max-width: 900px;
  width: 80%;
  z-index: 1;
}
.partners .partners-header {
  color: #2622b2;
  cursor: default;
  font-family: "Hanuman", serif;
  font-size: 1.5em;
  font-weight: 400;
  margin: 0 auto;
  max-width: 90vw;
}
.partners .partners-grid {
  display: flex;
  gap: 0 32px;
  justify-content: center;
  margin: 24px 0 30px;
}
.partners .partners-grid .partner {
  align-items: center;
  display: flex;
  flex: 0 0 25%;
  flex-direction: column;
}
.partners .partners-grid .partner span {
  color: #2622b2;
  font-size: 1.125em;
  margin-top: 6px;
}

.building-grid, .pedagogy-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: 1fr 1fr 1fr;
}

.building-item a.button {
  margin-top: 12px;
  padding: 6px 16px;
}

.capabilities-grid {
  display: grid;
  gap: 16px;
  grid-template: 1fr 1fr/1fr 1fr;
}
.capabilities-grid h3 {
  margin-right: 24px;
}
.capabilities-grid ul {
  margin: 0 16px 16px 16px;
}
.capabilities-grid .different h3 {
  position: relative;
}
.capabilities-grid .different h3 span {
  position: relative;
  z-index: 1;
}
.capabilities-grid .different h3::after {
  background: url("img/burst-cut.svg") no-repeat;
  content: "";
  height: 32px;
  left: -17px;
  position: absolute;
  top: -15px;
  width: 32px;
}
.capabilities-grid .different div {
  font-size: 1.125em;
}

#approach .wrap {
  display: block;
}
#approach .wrap.left .image-placeholder, #approach .wrap.left img {
  float: left;
  margin: 0 24px 16px 0;
}
#approach .wrap.right .image-placeholder, #approach .wrap.right img {
  float: right;
  margin: 0 0 16px 16px;
  max-width: 40vw;
}
#approach .wrap .text {
  display: inline;
}
#approach h3 {
  margin-bottom: 12px;
}
#approach .pedagogy-grid {
  margin-top: 20px;
}
#approach .working-grid {
  display: grid;
  gap: 16px;
  grid-template: min-content min-content/1fr 1fr;
  margin-bottom: 20px;
}

#platform .platform-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr 1fr;
  margin: 24px 0;
}
#platform .status em {
  font-style: normal;
  font-weight: bold;
}

#contact ul {
  margin: 0 16px;
}
#contact .contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
#contact em {
  font-style: normal;
  font-weight: bold;
}
#contact .contact-info div {
  margin-top: 12px;
}

@media (max-width: 65rem) {
  .image-placeholder.md {
    max-width: 50vw;
  }
  .image-placeholder.lg, .top-img {
    max-width: 50vw;
  }
  #top .content {
    min-width: 0;
    position: relative;
  }
  #top .content .img-with-text {
    padding: 0;
    margin-bottom: 24px;
  }
  #top .content .text {
    padding: 24px;
    position: relative;
    z-index: 1;
  }
  #top .content .image-placeholder.lg, #top .content .top-img {
    height: auto;
    width: auto;
  }
}
@media (max-width: 60rem) {
  #top .content .img-with-text {
    position: relative;
  }
  #top .content .text {
    flex: 0 0 100%;
    text-align: center;
  }
  #top .content .image-placeholder.lg, #top .content .top-img {
    left: 50%;
    max-height: calc(100% - 24px);
    max-width: 90vw;
    opacity: 0.25;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  #top .content .image-placeholder.sm, #top .content .logo-img {
    height: 100px;
    width: 120px;
  }
}
@media (max-width: 50rem) {
  #top .content .image-placeholder.lg, #top .content .top-img {
    top: 24px;
    transform: translateX(-50%);
    height: calc(100% - 24px);
  }
  .partners .partners-grid {
    display: grid;
    gap: 16px 32px;
    grid-template: min-content min-content/1fr 1fr;
    margin: 24px auto;
    width: 60%;
  }
  .partners .partners-grid .partner span {
    font-size: 1em;
  }
  .building-grid {
    grid-template: min-content min-content min-content/none;
  }
}
@media (max-width: 40rem) {
  #top .content .image-placeholder.lg, #top .content .top-img {
    height: auto;
    top: 0;
    width: 100%;
  }
  section {
    padding: 32px 16px;
  }
  h1 {
    font-size: 2.25em;
  }
  h2 {
    font-size: 2em;
  }
  h3, .partners .partners-header {
    font-size: 1.375em;
    font-weight: 500;
  }
  .capabilities-grid {
    grid-template: min-content min-content min-content min-content/none;
  }
  .capabilities-grid .different h3::after {
    background-size: 26px 26px;
    height: 26px;
    left: -13px;
    top: -11px;
    width: 26px;
  }
  .pedagogy-grid {
    grid-template: min-content min-content min-content/none;
  }
  #platform .platform-grid {
    grid-template: min-content min-content/none;
  }
  #approach .working-grid {
    grid-template: min-content min-content min-content min-content/none;
  }
  #contact .contact-grid {
    gap: 16px;
    grid-template: min-content min-content/none;
  }
}

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