@charset "UTF-8";
/* -----------------------------------------------
setting
Scssの変数等を定義
-------------------------------------------------- */
/* -----------------------------------------------
hs-top
トップページ　
-------------------------------------------------- */
.hs-top__archive {
  margin-top: 100px;
}
@media (max-width: 767px) {
  .hs-top__archive {
    margin-top: 16vw;
  }
}

/* -----------------------------------------------
hs-top-mainvisual
メインビジュアル
-------------------------------------------------- */
.hs-top-mainvisual {
  background: center/cover url(/recipe/asset/img/top/bg1.jpg);
}

.hs-top-mainvisual__container {
  max-width: 1100px;
  padding: 0 20px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .hs-top-mainvisual__container {
    padding: 0 5.3333333333vw;
  }
}

.hs-top-mainvisual__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 340px;
}
@media (max-width: 767px) {
  .hs-top-mainvisual__wrapper {
    height: 56vw;
  }
}

.hs-top-mainvisual__heading {
  color: #fff;
  font-size: 40px;
  font-weight: 600;
  line-height: 1;
}
@media (max-width: 767px) {
  .hs-top-mainvisual__heading {
    font-size: 7.2vw;
  }
}

.hs-top-mainvisual__subheading {
  color: #fff;
  font-size: 16px;
  line-height: 1.8125;
  margin-top: 30px;
}
.hs-top-mainvisual__subheading:before, .hs-top-mainvisual__subheading:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-mainvisual__subheading:before {
  margin-top: calc((1 - 1.8125) * 0.5em);
}
.hs-top-mainvisual__subheading:after {
  margin-bottom: calc((1 - 1.8125) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-mainvisual__subheading {
    font-size: 3.7333333333vw;
    margin-top: 5.3333333333vw;
  }
}

/* -----------------------------------------------
hs-top-about
アバウト
-------------------------------------------------- */
.hs-top-about {
  margin: 60px 0 100px;
}
@media (max-width: 767px) {
  .hs-top-about {
    margin: 10.6666666667vw 0 16vw;
  }
}

.hs-top-about__container {
  max-width: 1100px;
  padding: 0 20px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .hs-top-about__container {
    padding: 0 5.3333333333vw;
  }
}

.hs-top-about__heading {
  font-size: 30px;
  font-weight: 600;
  line-height: 1.67;
}
.hs-top-about__heading:before, .hs-top-about__heading:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-about__heading:before {
  margin-top: calc((1 - 1.67) * 0.5em);
}
.hs-top-about__heading:after {
  margin-bottom: calc((1 - 1.67) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-about__heading {
    font-size: 6.4vw;
  }
}

.hs-top-about__text {
  font-size: 16px;
  line-height: 1.8125;
  margin-top: 40px;
}
.hs-top-about__text:before, .hs-top-about__text:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-about__text:before {
  margin-top: calc((1 - 1.8125) * 0.5em);
}
.hs-top-about__text:after {
  margin-bottom: calc((1 - 1.8125) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-about__text {
    font-size: 3.7333333333vw;
    margin-top: 8vw;
  }
}

.hs-top-about__image {
  padding: 0 40px;
  margin-top: 60px;
}
.hs-top-about__image img {
  width: 100%;
}
@media (max-width: 767px) {
  .hs-top-about__image {
    padding: 0;
    margin-top: 10.6666666667vw;
  }
}

/* -----------------------------------------------
hs-top-feature
特長
-------------------------------------------------- */
.hs-top-feature__background {
  background: center/cover url(/recipe/asset/img/top/bg2.jpg);
  padding: 80px 0 100px;
}
@media (max-width: 767px) {
  .hs-top-feature__background {
    padding: 13.3333333333vw 0 0;
  }
}

.hs-top-feature__container {
  max-width: 1100px;
  padding: 0 20px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .hs-top-feature__container {
    padding: 0 5.3333333333vw;
  }
}

@media (max-width: 767px) {
  .hs-top-feature__header {
    position: relative;
  }
}

.hs-top-feature__header-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .hs-top-feature__header-wrapper {
    width: 100%;
  }
}

.hs-top-feature__header-image {
  width: 176px;
}
.hs-top-feature__header-image img {
  width: 100%;
}
@media (max-width: 767px) {
  .hs-top-feature__header-image {
    width: 21.3333333333vw;
    position: absolute;
    top: -2.6666666667vw;
    left: 0;
  }
}

.hs-top-feature__header-content {
  width: calc(100% - 176px);
  padding-left: 55px;
}
@media (max-width: 767px) {
  .hs-top-feature__header-content {
    width: 100%;
    padding-left: 0;
  }
}

.hs-top-feature__heading {
  color: #CC0022;
  font-size: 54px;
  font-weight: 600;
  line-height: 1.2;
}
.hs-top-feature__heading:before, .hs-top-feature__heading:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-feature__heading:before {
  margin-top: calc((1 - 1.2) * 0.5em);
}
.hs-top-feature__heading:after {
  margin-bottom: calc((1 - 1.2) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-feature__heading {
    font-size: 8.5333333333vw;
    padding-left: 26.6666666667vw;
  }
}

.hs-top-feature__header-text {
  color: #fff;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.68;
  margin-top: 20px;
}
.hs-top-feature__header-text:before, .hs-top-feature__header-text:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-feature__header-text:before {
  margin-top: calc((1 - 1.68) * 0.5em);
}
.hs-top-feature__header-text:after {
  margin-bottom: calc((1 - 1.68) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-feature__header-text {
    font-size: 4.8vw;
    margin-top: 8vw;
  }
}

.hs-top-feature__box {
  background: rgba(0, 0, 0, 0.3);
  padding: 75px 40px;
  margin-top: 50px;
}
@media (max-width: 1099px) {
  .hs-top-feature__box {
    padding: 75px 20px;
    margin: 50px -20px 0;
  }
}
@media (max-width: 767px) {
  .hs-top-feature__box {
    padding: 10.6666666667vw 5.3333333333vw 16vw;
    margin: 10.6666666667vw -5.3333333333vw 0;
  }
}

.hs-top-feature__item:not(:first-of-type) {
  margin-top: 100px;
}
@media (max-width: 767px) {
  .hs-top-feature__item:not(:first-of-type) {
    margin-top: 16vw;
  }
}

@media (max-width: 767px) {
  .hs-top-feature__item--1 .hs-top-feature__image {
    top: -1.6vw;
  }
}

.hs-top-feature__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
@media (max-width: 767px) {
  .hs-top-feature__wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-top: 18.6666666667vw;
  }
}

.hs-top-feature__number {
  position: absolute;
  top: 0;
  left: 0;
}
@media (max-width: 767px) {
  .hs-top-feature__number {
    height: 13.3333333333vw;
    padding-left: 20vw;
  }
  .hs-top-feature__number img {
    height: 100%;
  }
}

.hs-top-feature__content {
  width: calc(100% - 205px);
  padding-right: 50px;
  padding-left: 180px;
}
@media (max-width: 1099px) {
  .hs-top-feature__content {
    width: calc(100% - 160px);
    padding-right: 20px;
  }
}
@media (max-width: 767px) {
  .hs-top-feature__content {
    width: 100%;
    padding: 0;
  }
}

.hs-top-feature__heading_secondary {
  color: #CC0022;
  font-size: 44px;
  font-weight: 600;
  line-height: 1.2;
}
.hs-top-feature__heading_secondary:before, .hs-top-feature__heading_secondary:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-feature__heading_secondary:before {
  margin-top: calc((1 - 1.2) * 0.5em);
}
.hs-top-feature__heading_secondary:after {
  margin-bottom: calc((1 - 1.2) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-feature__heading_secondary {
    font-size: 6.4vw;
  }
}

.hs-top-feature__text {
  color: #fff;
  font-size: 22px;
  line-height: 1.68;
  margin-top: 25px;
}
.hs-top-feature__text:before, .hs-top-feature__text:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-feature__text:before {
  margin-top: calc((1 - 1.68) * 0.5em);
}
.hs-top-feature__text:after {
  margin-bottom: calc((1 - 1.68) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-feature__text {
    font-size: 4.8vw;
    margin-top: 4vw;
  }
}

.hs-top-feature__image {
  width: 205px;
}
.hs-top-feature__image img {
  width: 100%;
}
@media (max-width: 1099px) {
  .hs-top-feature__image {
    width: 160px;
  }
}
@media (max-width: 767px) {
  .hs-top-feature__image {
    width: 16vw;
    position: absolute;
    top: 0;
    left: 0;
  }
}

.hs-top-feature__button {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background: #333;
  min-width: 400px;
  color: #fff !important;
  font-size: 18px;
  line-height: 1;
  padding: 20px 40px 20px 20px;
  margin: 40px auto 0;
  position: relative;
}
.hs-top-feature__button:after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 16px;
  background: center/contain no-repeat url(/r23res/image/common/icon_arrow_white.svg);
  right: 12px;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media (hover: hover) {
  .hs-top-feature__button {
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
  }
  .hs-top-feature__button:hover {
    opacity: 0.7;
  }
}
@media (max-width: 767px) {
  .hs-top-feature__button {
    min-width: 100%;
    font-size: 3.4666666667vw;
    padding: 5.3333333333vw 10.6666666667vw 5.3333333333vw 5.3333333333vw;
    margin: 5.3333333333vw auto 0;
  }
  .hs-top-feature__button:after {
    width: 2.1333333333vw;
    height: 4.2666666667vw;
    right: 3.2vw;
  }
}

/* -----------------------------------------------
hs-top-cta
CTA パターン1
-------------------------------------------------- */
.hs-top-cta {
  margin-top: 100px;
}
@media (max-width: 767px) {
  .hs-top-cta {
    margin-top: 16vw;
  }
}

.hs-top-cta__container {
  max-width: 1100px;
  padding: 0 20px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .hs-top-cta__container {
    padding: 0 5.3333333333vw;
  }
}

.hs-top-cta__wrapper {
  padding: 59px;
  border: 1px solid #E6E6E6;
}
@media (max-width: 767px) {
  .hs-top-cta__wrapper {
    padding: 5.3333333333vw;
  }
}

.hs-top-cta__heading {
  font-size: 30px;
  font-weight: 600;
  line-height: 1.67;
}
.hs-top-cta__heading:before, .hs-top-cta__heading:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-cta__heading:before {
  margin-top: calc((1 - 1.67) * 0.5em);
}
.hs-top-cta__heading:after {
  margin-bottom: calc((1 - 1.67) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-cta__heading {
    font-size: 6.4vw;
  }
}

.hs-top-cta__list {
  margin-top: 42px;
}
@media (max-width: 767px) {
  .hs-top-cta__list {
    margin-top: 7.2vw;
  }
}

.hs-top-cta__item {
  color: #CC0022;
  font-size: 25px;
  font-weight: 600;
  line-height: 1.72;
  padding-left: 44px;
  position: relative;
}
.hs-top-cta__item:before, .hs-top-cta__item:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-cta__item:before {
  margin-top: calc((1 - 1.72) * 0.5em);
}
.hs-top-cta__item:after {
  margin-bottom: calc((1 - 1.72) * 0.5em);
}
.hs-top-cta__item:not(:first-of-type) {
  margin-top: 32px;
}
@media (max-width: 767px) {
  .hs-top-cta__item:not(:first-of-type) {
    margin-top: 4.5333333333vw;
  }
}
@media (max-width: 767px) {
  .hs-top-cta__item {
    font-size: 5.6vw;
    padding-left: 10.6666666667vw;
  }
}

.hs-top-cta__icon {
  width: 28px;
  position: absolute;
  top: 8px;
  left: 0;
}
@media (max-width: 767px) {
  .hs-top-cta__icon {
    width: 6.4vw;
    top: 1.6vw;
  }
}

.hs-top-cta__text {
  font-size: 16px;
  line-height: 1.8125;
  margin-top: 36px;
}
.hs-top-cta__text:before, .hs-top-cta__text:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-cta__text:before {
  margin-top: calc((1 - 1.8125) * 0.5em);
}
.hs-top-cta__text:after {
  margin-bottom: calc((1 - 1.8125) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-cta__text {
    font-size: 3.7333333333vw;
    margin-top: 5.6vw;
  }
}

.hs-top-cta__buttons {
  margin-top: 35px;
}

@media (hover: hover) {
  .hs-top-cta__button {
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
  }
  .hs-top-cta__button:hover {
    opacity: 0.7;
  }
}
@media (max-width: 767px) {
  .hs-top-cta__button {
    width: 100%;
  }
}

/* -----------------------------------------------
hs-top-cta2
CTA パターン2
-------------------------------------------------- */
.hs-top-cta2 {
  margin-top: 80px;
}
@media (max-width: 767px) {
  .hs-top-cta2 {
    margin-top: 13.3333333333vw;
  }
}

.hs-top-cta2__container {
  max-width: 1100px;
  padding: 0 20px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .hs-top-cta2__container {
    padding: 0 5.3333333333vw;
  }
}

.hs-top-cta2__wrapper {
  background: #E5E5E5;
  padding: 60px;
}
@media (max-width: 767px) {
  .hs-top-cta2__wrapper {
    padding: 5.3333333333vw;
  }
}

.hs-top-cta2__heading {
  font-size: 25px;
  font-weight: 600;
  line-height: 1.4;
}
.hs-top-cta2__heading:before, .hs-top-cta2__heading:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-cta2__heading:before {
  margin-top: calc((1 - 1.4) * 0.5em);
}
.hs-top-cta2__heading:after {
  margin-bottom: calc((1 - 1.4) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-cta2__heading {
    font-size: 5.6vw;
  }
}

.hs-top-cta2__buttons {
  margin-top: 35px;
}

@media (max-width: 767px) {
  .hs-top-cta2__button {
    width: 100%;
  }
}

/* -----------------------------------------------
hs-top-relation
関連情報
-------------------------------------------------- */
.hs-top-relation {
  margin-top: 100px;
}
@media (max-width: 767px) {
  .hs-top-relation {
    margin-top: 16vw;
  }
}

.hs-top-relation__container {
  max-width: 1100px;
  padding: 0 20px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .hs-top-relation__container {
    padding: 0 5.3333333333vw;
  }
}

.hs-top-relation__heading {
  font-size: 24px;
  font-weight: 600;
  line-height: 1.625;
  padding-bottom: 29px;
  border-bottom: 1px solid #DDD;
  margin-bottom: 40px;
}
.hs-top-relation__heading:before, .hs-top-relation__heading:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.hs-top-relation__heading:before {
  margin-top: calc((1 - 1.625) * 0.5em);
}
.hs-top-relation__heading:after {
  margin-bottom: calc((1 - 1.625) * 0.5em);
}
@media (max-width: 767px) {
  .hs-top-relation__heading {
    font-size: 6.4vw;
    padding-bottom: 7.7333333333vw;
    border-width: 0.2666666667vw;
    margin-bottom: 10.6666666667vw !important;
  }
}

.hs-top-relation__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
@media (max-width: 767px) {
  .hs-top-relation__list {
    grid-template-columns: none;
  }
}

@media (hover: hover) {
  .hs-top-relation__item a {
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
  }
  .hs-top-relation__item a:hover {
    opacity: 0.7;
  }
}

.hs-top-relation__image {
  aspect-ratio: 332/140;
  position: relative;
}
.hs-top-relation__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.hs-top-relation__image--contain img {
  -o-object-fit: contain;
     object-fit: contain;
}

.hs-top-relation__content {
  background: #333;
  padding: 12px 15px;
  position: relative;
}
.hs-top-relation__content:after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 16px;
  background: center/contain no-repeat url(/recipe/asset/img/common/icon_link.svg);
  right: 12px;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media (max-width: 767px) {
  .hs-top-relation__content {
    padding: 3.2vw 4vw;
  }
}

.s-top-relation__title {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.8125;
}
.s-top-relation__title:before, .s-top-relation__title:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.s-top-relation__title:before {
  margin-top: calc((1 - 1.8125) * 0.5em);
}
.s-top-relation__title:after {
  margin-bottom: calc((1 - 1.8125) * 0.5em);
}
@media (max-width: 767px) {
  .s-top-relation__title {
    font-size: 3.7333333333vw;
  }
}