:root {
  --brand-color: #ff29a9;

  --font-family-sans-serif:
    "Lato",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    "Helvetica Neue",
    Arial,
    "Noto Sans",
    sans-serif,
    "Apple Color Emoji",
    "Segoe UI Emoji",
    "Segoe UI Symbol",
    "Noto Color Emoji";

  --font-family-display:
    "Estado Headline",
    Georgia,
    Cambria,
    "Times New Roman",
    Times,
    serif;

  --base-background-color: #ffe6ba;
  --base-foreground-color: #605245;
  --base-font-family: var(--font-family-sans-serif);
  --base-font-size: 1.6rem;
  --base-line-height: 1.5;

  --brandbar-height: 6.4rem;
  --brandbar-margin-bottom: 0;
  /* --brandbar-margin-bottom: 3.2rem; */

  --cover-max-width: 24rem;

  --headings-font-family: var(--font-family-display);

  --kicker-foreground-color: var(--brand-color);
  --kicker-font-size: 1.2rem;
  --kicker-line-height: 1.6rem;

  --headline-font-size: 2.8rem;
  --headline-line-height: 3.2rem;

  /* --headline-font-size: 4.2rem;
  --headline-line-height: 4.8rem; */

  /* --lead-font-size: 2rem;
  --lead-line-height: 2.4rem; */

  --lead-font-size: 1.6rem;
  --lead-line-height: 2.4rem;
  --lead-margin-bottom: 2.4rem;

  --swiper-theme-color: var(--brand-color);
}

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

html {
  font-family: var(--font-family-sans-serif);
  font-size: 62.5%;
}

body {
  margin: 0;
  background-color: var(--base-background-color);
  color: var(--base-foreground-color);
  font-size: var(--base-font-size);
  line-height: var(--base-line-height);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-family: var(--headings-font-family);
  font-weight: 900;
}

p {
  margin: 0 1em;
}

b,
strong {
  font-weight: 900;
}

a {
  color: var(--brand-color);
}

.oesp {
  display: inline-block;
  position: relative;
  font-family: "OESP";
  font-size: inherit;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  line-height: 1;
}

.oesp-estadao:before {
  content: '\f000';
}

.canvas {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100vh;
}

.app {
  position: absolute;
  top: 0;
  padding: 0 1.6rem 9.6rem;
  width: 100%;
}

.app__header,
.section__header {
  /* display: flex; */
  /* flex-direction: column; */
  /* justify-content: space-between; */
  /* position: relative; */
  margin: 0 auto 3.2rem;
  max-width: 64rem;
  /* height: 100vh; */
  text-align: center;
}

/* .cover-wrapper {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
} */

/* .cover {
  display: flex;
  display: none;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: var(--brandbar-height);
  left: 0;
  z-index: -1;
  margin: 0;
  width: 100%;
  height: calc(100% - 12.8rem);
} */

/* .cover::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--base-background-color);
  opacity: 0.6;
} */

.brandbar {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: var(--brandbar-margin-bottom);
  height: var(--brandbar-height);
}

.brand {
  color: inherit;
  font-size: 3.2rem;
  line-height: 1;
}

.brand:hover,
.brand:focus {
  filter: brightness(1.25);
}

.kicker,
.credits h3.kicker {
  margin-bottom: 1.6rem;
  color: var(--kicker-foreground-color);
  font-size: var(--kicker-font-size);
  font-weight: 900;
  line-height: var(--kicker-line-height);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-family: 'Lato';
}

.headline {
  margin-bottom: 2.4rem;
  font-size: var(--headline-font-size);
  line-height: var(--headline-line-height);
}

.lead {
  margin-bottom: var(--lead-margin-bottom);
  font-size: var(--lead-font-size);
  line-height: var(--lead-line-height);
}

.byline {
  list-style: none;
  /* display: flex;
  flex-direction: column;
  flex-wrap: wrap; */
  margin: 0;
  padding: 0;
  font-size: var(--kicker-font-size);
  line-height: var(--kicker-line-height);
  text-align: left;
}

.byline__role,
.byline__name {
  /* display: inline-block; */
}

.byline__role {
  color: var(--brand-color);
  font-weight: 900;
}

.byline__role::after {
  content: ":";
}

.byline__name {
  flex: 1;
  margin: 0;
}

.published {
  display: block;
  margin-bottom: 7.2rem;
  opacity: 0.6;
  font-size: var(--kicker-font-size);
  line-height: var(--kicker-line-height);
  /* text-align: left; */
}

/* .section + .section {
  margin-top: 16rem;
} */

hr {
  margin: 9.6rem auto;
  border: 1px solid var(--base-foreground-color);
  /* max-width: 64rem; */
  opacity: 0.1;
}

.section__header {
  margin-bottom: 7.2rem;
}

.section .kicker {
  font-size: 1.2rem;
}

.section__title {
  margin-bottom: 0;
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 3.2rem;
}

.app__main {
  margin: 0 auto;
  width: 100%;
  max-width: 120rem;
}

.section > p {
  margin: 0 auto 1em;
  max-width: 64rem;
}

.blob {
  padding-top: 100%;
  width: 100%;
  /* max-width: 48rem; */
}

.explanation {
  margin: 0 auto;
  border-left: 0.4rem solid var(--brand-color);
  padding: 0 1.6rem 0 1.2rem;
  max-width: 67.2rem;
}

.explanation b {
  color: var(--brand-color);
}

.scrolly {
  position: relative;
}

.cover,
.example {
  margin: 0 auto;
  max-width: var(--cover-max-width);
}

.examples {
  display: flex;
  justify-content: space-around;
  margin: 0 auto;
  max-width: 72rem;
}

.example {
  width: 50%;
}

.scrolly__steps {
  position: relative;
}

.scrolly__step {
  margin: 0 auto;
  padding: 1.6rem;
  max-width: 48rem;
  background-color: rgba(255, 255, 255, 0.2);
}

.small-multiples {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 -1.6rem;
}

.small-multiple {
  margin: 0 0 6rem;
  width: 50%;
  line-height: 1.25;
  text-align: center;
}

.small-multiple__caption__title,
.small-multiple__caption__artist {
  display: block;
}

.small-multiple__caption__year {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 1rem;
  border-radius: 1.5rem;
  width: 6rem;
  height: 3rem;
  background-color: rgba(255, 41, 169, 0.1);
  color: var(--brand-color);
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1;
  text-transform: uppercase;
}

.small-multiple__caption__title {
  font-weight: 900;
}

@media (min-width: 400px) {
  :root {
    --cover-max-width: 32rem;
  }
}

@media (min-width: 640px) {
  :root {
    --cover-max-width: 40rem;

    --kicker-font-size: 1.4rem;

    --headline-font-size: 4.2rem;
    --headline-line-height: 4.8rem;

    --lead-font-size: 2rem;
    --lead-line-height: 2.4rem;
  }

  /* .app__header {
    display: block;
    height: auto;
  } */

  .small-multiple {
    width: 25%;
  }
}

@media (min-width: 960px) {
  .small-multiple {
    width: 20%;
  }
}

@media (min-width: 1200px) {
  .small-multiples {
    margin: 0;
  }
}

.placeholder {
  position: relative;
  overflow: hidden;
}

.placeholder::before {
  content: '';
  display: block;
}

.placeholder[data-aspect-ratio="1:1"]::before {
  padding-top: 100%;
}

.swiper-container {
  /* margin: 0 -1.6rem; */
  /* width: calc(100% + 3.2rem); */
  width: 100%;
  /* max-width: 64rem; */
  /* height: 300px; */
}

.swiper-slide {
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
  user-select: none;
}

.swiper-slide .small-multiple {
  width: 100%;
  max-width: 40rem;
}

.swiper-slide .small-multiple__caption__year {
  width: 9.6rem;
}

.bet-description {
  margin: 0 auto 4.8rem;
  max-width: 48rem;
}

.spotify-embed {
  display: block;
  margin: 0 auto;
}

.small {
  font-size: var(--kicker-font-size);
  line-height: var(--kicker-line-height);
  opacity: 0.6;
  text-align: center;
}

.avatar {
  margin: 9.6rem auto 4.8rem;
  max-width: 48rem;
  text-align: center;
}

.avatar__photo {
  width: 100%;
}

.avatar__caption {
  font-size: var(--kicker-font-size);
  line-height: var(--kicker-line-height);
  opacity: 0.6;
}

.credits { 
  font-size: 1.2rem;
  /* max-width: 690px; */
  display: flex;
  flex-direction: column;
  align-items: center;
}
