.firsthero {
  padding: 0.9375rem 0;
}
.firsthero__wrap {
  display: flex;
  align-items: center;
  background-color: #fbf0f0;
}
.firsthero__content, .firsthero__slider {
  flex: 1 1 50%;
}
.firsthero__content {
  height: 100%;
}
.firsthero__text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.firsthero__text {
  line-height: 1.3;
}
.firsthero__title {
  font-weight: 700;
}
.firsthero__subtitle {
  font-weight: 700;
}
.firsthero__subtitle {
  border-bottom: 0.0625rem solid #212121;
}
.firsthero__description p:not(:last-child) {
  margin-bottom: 0.625rem;
}
.firsthero__description ul, .firsthero__description ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.firsthero__description ul li, .firsthero__description ol li {
  position: relative;
  padding-left: 0.9375rem;
  margin-bottom: 0.625rem;
}
.firsthero__description ul li:before, .firsthero__description ol li:before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  width: 0.25rem;
  height: 0.25rem;
  background-color: #dc0f0f;
}
.firsthero__description a {
  color: #dc0f0f;
  transition: all 0.3s;
}
.firsthero__description a:hover {
  color: #485400;
}
.firsthero__link {
  padding: 0.625rem 1.3125rem;
  background-color: #dc0f0f;
  color: #fff;
  transition: all 0.3s;
}
.firsthero__link:hover {
  background-color: #485400;
}
.firsthero__slider {
  background-color: #dc0f0f;
  height: 100%;
  position: relative;
}
.firsthero__slider--button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2.5rem;
  height: 2.5rem;
  background-color: #dc0f0f;
  color: #fff;
  font-size: 1.375rem;
  transition: all 0.3s;
}
.firsthero__slider--button.firsthero__slider--button-prev {
  left: 0;
}
.firsthero__slider--button.firsthero__slider--button-next {
  right: 0;
}
.firsthero__slider--button.swiper-button-disabled {
  background-color: #666;
}
.firsthero__slider--button.swiper-button-disabled:hover {
  background-color: #666;
}
.firsthero__slider--button span {
  display: flex;
  align-items: center;
  justify-content: center;
}
.firsthero__slider--button:hover {
  background-color: #485400;
}

.firsthero-slide {
  position: relative;
}
.firsthero-slide__image {
  width: 100%;
  height: 100%;
  overflow: hidden;
  aspect-ratio: 3/3;
}
.firsthero-slide__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.firsthero-slide__content {
  position: absolute;
  bottom: 0.9375rem;
  left: 0.9375rem;
  right: 0.9375rem;
  width: calc(100% - 1.875rem);
  z-index: 9;
  padding: 0.9375rem;
  background-color: rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(0.4375rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.9375rem;
  line-height: 1.3;
}
.firsthero-slide__title {
  font-weight: 500;
}
.firsthero-slide__link {
  padding: 0.4375rem 2.1875rem;
  text-align: center;
  background-color: #dc0f0f;
  color: #fff;
  transition: all 0.3s;
  display: inline-block;
  font-size: 0.875rem;
}
.firsthero-slide__link:hover {
  background-color: #485400;
}
@media (max-width: 61.99875em) {
  .firsthero__wrap {
    flex-wrap: wrap;
  }
  .firsthero__content, .firsthero__slider {
    flex: 1 1 100%;
  }
  .firsthero-slide__image {
    aspect-ratio: 4/3;
  }
}
@media (max-width: 20em) {
  .firsthero__text {
    gap: 1.25rem;
  }
  .firsthero__text {
    padding-top: 1.875rem;
  }
  .firsthero__text {
    padding-bottom: 1.875rem;
  }
  .firsthero__text {
    padding-left: 1.875rem;
  }
  .firsthero__text {
    padding-right: 1.875rem;
  }
  .firsthero__title {
    font-size: 1.5625rem;
  }
  .firsthero__subtitle {
    font-size: 1.125rem;
  }
  .firsthero__subtitle {
    padding-bottom: 1.25rem;
  }
  .firsthero-slide__title {
    font-size: 1rem;
  }
}
@media (min-width: 20em) and (max-width: 87.5em) {
  .firsthero__text {
    gap: clamp( 1.25rem , 1.0648148148125rem  +  0.9259259259vw , 1.875rem );
  }
  .firsthero__text {
    padding-top: clamp( 1.875rem , 1.50462962963125rem  +  1.8518518519vw , 3.125rem );
  }
  .firsthero__text {
    padding-bottom: clamp( 1.875rem , 1.50462962963125rem  +  1.8518518519vw , 3.125rem );
  }
  .firsthero__text {
    padding-left: clamp( 1.875rem , 1.50462962963125rem  +  1.8518518519vw , 3.125rem );
  }
  .firsthero__text {
    padding-right: clamp( 1.875rem , 1.50462962963125rem  +  1.8518518519vw , 3.125rem );
  }
  .firsthero__title {
    font-size: clamp( 1.5625rem , 1.284722222225rem  +  1.3888888889vw , 2.5rem );
  }
  .firsthero__subtitle {
    font-size: clamp( 1.125rem , 1.0879629629625rem  +  0.1851851852vw , 1.25rem );
  }
  .firsthero__subtitle {
    padding-bottom: clamp( 1.25rem , 1.0648148148125rem  +  0.9259259259vw , 1.875rem );
  }
  .firsthero-slide__title {
    font-size: clamp( 1rem , 0.83333333333125rem  +  0.8333333333vw , 1.5625rem );
  }
}
@media (min-width: 87.5em) {
  .firsthero__text {
    gap: 1.875rem;
  }
  .firsthero__text {
    padding-top: 3.125rem;
  }
  .firsthero__text {
    padding-bottom: 3.125rem;
  }
  .firsthero__text {
    padding-left: 3.125rem;
  }
  .firsthero__text {
    padding-right: 3.125rem;
  }
  .firsthero__title {
    font-size: 2.5rem;
  }
  .firsthero__subtitle {
    font-size: 1.25rem;
  }
  .firsthero__subtitle {
    padding-bottom: 1.875rem;
  }
  .firsthero-slide__title {
    font-size: 1.5625rem;
  }
}