  .testimonial {
  margin-top: var(--spacing--default);
}

@media print, screen and (width >= 48.0625em) {
  .testimonial {
    margin-top: var(--spacing--large);
  }
}

@media print, screen and (width <= 48.0613em) {
  .testimonial::before {
    margin: var(--spacing--default) auto var(--spacing--default) auto;
    content: '';
    display: block;
    height: var(--spacing--small);
    background-color: var(--gray--bg);
    width: calc(100% - var(--spacing--default));
  }
}

@media print, screen and (width >= 48.0625em) {
  .testimonial > .grid-container {
    padding-top: var(--spacing--default);
  }
}

@media print, screen and (width >= 48.0625em) and (width >= 48.0625em) {
  .testimonial > .grid-container {
    padding-top: var(--spacing--large);
  }
}

@media print, screen and (width >= 48.0625em) and (width >= 64.0625em) {
  .testimonial > .grid-container {
    padding-top: var(--spacing--xlarge);
  }
}

.testimonial > .grid-container::before {
  color: var(--accent-green);
  font-family: var(--font-awesome);
  font-size: 2.625rem;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
  content: '\f086';
}

@media print, screen and (width >= 48.0625em) {
  .testimonial > .grid-container::before {
    position: absolute;
    top: var(--spacing--xlarge);
    font-size: 3.5rem;
  }
}

@media print, screen and (width >= 48.0625em) {
  .testimonial > .grid-container {
    position: relative;
  }

  .testimonial > .grid-container::after {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 7.5rem;
    display: block;
    border-left: 1px solid var(--gray--line);
    content: '';
    width: 0.0625rem;
    height: 100%;
  }
}

.testimonial .intro-text {
  font-size: 1rem;
  margin-top: var(--spacing--small);
}

.testimonial .intro-text p {
  font-size: 1.125rem;
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__inner {
    padding-left: 10rem;
  }
}

.testimonial figure {
  margin: 0;
  margin-bottom: var(--spacing--small);
  max-width: 28.75rem;
  position: relative;
}

@media print, screen and (width >= 48.0625em) {
  .testimonial figure {
    margin-bottom: var(--spacing--medium);
  }
}

@media print, screen and (width >= 48.0625em) {
  .testimonial figure {
    margin-bottom: 0;
  }
}

.testimonial figure figcaption {
  position: relative;
  z-index: 1;
  background: var(--white);
  font-size: 0.875rem;
  font-style: italic;
  line-height: 1.428;
  padding: var(--spacing--xsmall) var(--spacing--small);
  padding-left: 0;
  margin-top: 0;
}

.testimonial figure figcaption::after {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  background-color: var(--gray--line-alt);
  content: '';
  width: 2.96875rem;
  height: 0.0625rem;
}

.testimonial .testimonial__eyebrow {
  margin-top: var(--spacing--xsmall);
  color: var(--accent-green);
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 0.3125rem;
  letter-spacing: 0.075rem;
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__eyebrow {
    font-size: 1rem;
    margin-top: 0;
  }
}

.testimonial h2 {
  font-size: 1.75rem;
  font-weight: 600;
  margin-top: 0;
}

@media print, screen and (width >= 48.0625em) {
  .testimonial h2 {
    font-size: 4.5rem;
  }
}

.testimonial .testimonial__box {
  margin-top: var(--spacing--medium);
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__box {
    margin-top: var(--spacing--large);
  }
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__box {
    padding-bottom: var(--spacing--large);
    margin-bottom: 0;
    display: flex;
  }
}

@media print, screen and (width >= 48.0625em) and (width >= 64.0625em) {
  .testimonial .testimonial__box {
    padding-bottom: var(--spacing--2xlarge);
  }
}

@media print, screen and (width >= 48.0625em) and (width <= 64.0613em) {
  .testimonial .testimonial__box {
    -ms-flex-align: start;
    align-items: flex-start;
  }
}

.testimonial .testimonial__box blockquote p {
  font-style: normal;
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__box blockquote {
    font-size: 1.5rem;
  }
}

.testimonial .testimonial__box .testimonial__attribution {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0;
  margin-top: 0.625rem;
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__box .testimonial__attribution {
    font-size: 1.125rem;
    margin-bottom: 0.1875rem;
  }
}

.testimonial .testimonial__box .testimonial__pronouns {
  margin-bottom: var(--spacing--small);
  font-size: 0.875rem;
  margin-top: 0;
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__box .testimonial__photo {
    flex: 1 0 46%;
    -ms-flex-preferred-size: 46%;
    -ms-flex-negative: 0;
    -ms-flex-positive: 1;
  }
}

@media print, screen and (width >= 48.0625em) {
  .testimonial .testimonial__box .testimonial__quote {
    display: flex;
    flex-direction: column;
    -ms-flex-pack: center;
    -ms-flex-align: start;
    align-items: start;
    justify-content: center;
    padding-left: var(--spacing--default);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-box-pack: center;
  }
}

.testimonial .testimonial__box blockquote {
  border-left: 0;
  font-size: 1.25rem;
  line-height: 1.666;
  padding: 0;
}
