* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
}

body {
  background-color: #f5f4f0;
  font-family: "Open Sans", sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  color: #333333;
}

/* page */

main {
  width: 1120px;
  margin: 8.8rem auto;
}

header {
  display: flex;
  flex-direction: column;
  gap: 4rem;

  & h1 {
    margin-top: 0.8rem;
  }

  & p {
    margin-top: 2.4rem;
    text-align: center;
    font-style: italic;
  }
}

img {
  max-width: 1120px;
  border-radius: 2.8rem;
}

section {
  & div {
    margin-block: 1.6rem;
    & h2 {
      margin-block: 0.2rem 0.8rem;
    }
  }

  & figure {
    & img {
      height: 375px;
      width: 1120px;
      object-fit: cover;
      margin-top: 4.8rem;
    }

    & figcaption {
      margin-top: 2rem;

      & h3 {
        margin-left: 1rem;
      }

      & li {
        margin-left: 2.5rem;

        &::marker {
          color: #333333;
        }
      }
    }
  }
}

footer {
  text-align: center;
}

.divisor {
  width: 100%;
  height: 1px;
  margin: 36px 0;
  background-color: #d9d9d9;
}

/* fonts */

h1,
h2,
h3,
span {
  font-weight: 700;
  color: #1b1b1b;
}

h1 {
  font-size: 3.6rem;
}

h2 {
  font-size: 3.2rem;
}

h3 {
  font-size: 2.8rem;
}

span {
  color: #e1624f;
  text-transform: uppercase;
}
