h1,
h2,
h3,
p,
li {
  color: black;
  font-family: Jost, sans-serif;
  text-wrap: wrap;
}

h1,
h2,
h3 {
  line-height: 1.1;
  letter-spacing: calc(-2 * 0.01em);
}

h1 {
  font-size: clamp(2.3783rem, 1.6391vw + 2.0505rem, 3.0996rem);
  font-weight: 700;
  margin: 1.4em 0 0.5em;
}

h2 {
  font-size: clamp(1.6818rem, 0.8745vw + 1.5069rem, 2.0665rem);
  font-weight: 600;
  margin: 1.4em 0 0.5em;
}

p,
ul {
  font-size: clamp(1rem, 0.2841vw + 0.9432rem, 1.125rem);
  line-height: 1.6;
  letter-spacing: calc(2 * 0.01em);
  max-width: 80ch;
  margin-bottom: 1em;
}

a {
  color: #00538b;
  text-decoration: underline;
  transition: color 0.2s ease-in-out;
  text-decoration-color: #00afe9;
  font-weight: 500;
}

a:hover,
a:active {
  text-decoration-color: #00779b;
}

ul {
  list-style-type: square;
  padding-left: 1.5rem;
  margin-top: 1em;
}

li {
  margin-bottom: 1em;
}

li::marker {
  color: #00b48d; /* Replace with your preferred green hex code */
}

body {
  padding: 1rem;
}

.container {
  max-width: 80rem;
  margin: 3em auto 0 auto;
}

header,
main,
footer {
  max-width: 50rem;
  width: 100%;
  position: relative;
}

section {
  margin-bottom: 5em;
}

iframe {
  max-width: 50rem;
  background: transparent;
  padding: 0;
}

.logo {
  max-width: 7rem;
}

#card-sort {
  background: rgb(0, 83, 139);
  color: white;
  font-size: 1.125rem;
  line-height: 1.4em;
  font-weight: 500;
  transition: transform 0.2s, background 0.2s;
  -webkit-appearance: button;
  -moz-appearance: button;
  padding: 0.375em 1rem;
  border-radius: 6px;
  text-decoration: none;
}

#card-sort:hover {
  transform: scale(1.05);
  background: rgb(0, 101, 170);
}

#airtable-embed {
  margin-left: -48px;
  margin-top: -48px;
  margin-bottom: -48px;
}

#airtable-container {
  position: relative;
  min-height: 500px;
}

@media (width >= 48rem) {
  body {
    padding: 1rem 3rem;
  }
}
