/*共通項目にてフォントファミリー編集済み 矢野*/
/* 白ボタン */
.white-btn a {
  border: 1px solid #fff;
  /* color: #fff; */
  background-color: #fff;
  max-width: 220px;
}
.white-btn:hover a {
  border: 1px solid #000;
  color: #fff;
}
/* 角丸スライド ボタンのスタイル */
.r-corners-btn {
  cursor: pointer;
  transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
  background: #000;
  border: 1px solid #000;
  border-radius: 60px;
  color: #fff;
  display: block;
  /* font-size: 11px; */
  font-size: var(--font-body);
  font-weight: 600;
  max-width: 300px;
  padding: 10px 20px;
  text-align: center;
  transform: var(--scaleX);
  letter-spacing: 0.02em;
  line-height: 1.54;
  display: inline-block;
}
.r-corners-btn:hover {
  background: #fff;
  color: #000;
}
/******************************/
/* SLIDER */
/******************************/

.p-main-slider .bx-wrapper .bx-viewport {
  border: 0;
  box-shadow: none;
  left: 0;
}
.p-main-slider .bx-wrapper img {
  margin: 0 auto;
  width: 100%;
}
.p-main-slider .bx-wrapper .bx-pager {
  padding-top: 0;
  bottom: -40px;
}
@media screen and (max-width: 767px) {
  .p-main-slider .bx-wrapper .bx-pager {
    bottom: -25px;
  }
}
.p-main-slider .bx-wrapper .bx-pager.bx-default-pager a {
  margin-left: 10px;
  margin-right: 10px;
  background: #dddddd;
}

/******************************/
/* NEWS */
/******************************/
.p-line-informaiton {
  margin-top: 90px;
  margin-bottom: 90px;
}
@media screen and (max-width: 1023px) {
  .p-line-informaiton {
    margin-top: 90px;
    margin-bottom: 50px;
  }
}
@media screen and (max-width: 767px) {
  .p-line-informaiton {
    margin-top: 45px;
    margin-bottom: 45px;
  }
}

.p-line-informaiton-list__item {
  display: flex;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .p-line-informaiton-list__item {
    display: block;
    margin-bottom: 15px;
  }
}

.p-line-informaiton-list__date {
  width: 120px;
}

.p-line-informaiton-list__ttl {
  flex: 1;
}

/******************************/
/* グループバナー */
/******************************/
.p-group-bnr {
  margin-top: 90px;
  margin-bottom: 90px;
}
@media screen and (max-width: 1023px) {
  .p-group-bnr {
    margin-top: 50px;
    margin-bottom: 60px;
  }
}
@media screen and (max-width: 1023px) {
  .p-group-bnr .c-slider-thema .slick-next {
    right: -10px;
  }
}
@media screen and (max-width: 767px) {
  .p-group-bnr .c-slider-thema .slick-next {
    right: -3px;
  }
}
@media screen and (max-width: 1023px) {
  .p-group-bnr .c-slider-thema .slick-prev {
    left: -10px;
  }
}
@media screen and (max-width: 767px) {
  .p-group-bnr .c-slider-thema .slick-prev {
    left: -3px;
  }
}

.p-group-bnr-list {
  margin-left: -25px;
  margin-right: -25px;
}
@media screen and (max-width: 1070px) {
  .p-group-bnr-list {
    margin-left: 0px;
    margin-right: 0px;
  }
}

.p-group-bnr-list__item {
  margin-left: 25px;
  margin-right: 25px;
  word-break: break-all;
}
@media screen and (max-width: 1023px) {
  .p-group-bnr-list__item {
    margin-left: 12px;
    margin-right: 12px;
  }
}
.p-group-bnr-list__item img {
  width: 100%;
}

.p-group-bnr-list__ttl {
  margin-top: 15px;
}

/******************************/
/* INFORMATION */
/******************************/
.p-information {
  margin-top: 90px;
  margin-bottom: 90px;
  padding: 60px 90px;
  background: url(https://img.shop-pro.jp/tmpl_img/87/bg-grid.png) repeat;
  color: #2d2d2d;
}
@media screen and (max-width: 1023px) {
  .p-information {
    margin-top: 60px;
    margin-bottom: 45px;
    margin-left: 25px;
    margin-right: 25px;
    padding: 45px 45px;
  }
}
@media screen and (max-width: 767px) {
  .p-information {
    margin-left: 0;
    margin-right: 0;
    padding: 35px 25px;
  }
}
/******************************/
/* RECOMMEND ITEMS */
/******************************/
.c-ttl-bg.is-recommend:before {
  background: url(https://img21.shop-pro.jp/PA01490/435/etc/soba-background.jpg?cmsp_timestamp=20221027142016) center center no-repeat;
  background-size: cover;
}
.p-recommend {
  overflow: hidden;
  padding-bottom: 90px;
}
@media screen and (max-width: 1023px) {
  .p-recommend {
    padding-bottom: 60px;
  }
}
@media screen and (max-width: 767px) {
  .p-recommend {
    padding-bottom: 30px;
  }
}

@media screen and (max-width: 1023px) {
  .p-recommend-list {
    margin-left: 25px;
    margin-right: 25px;
  }
}
@media screen and (max-width: 767px) {
  .p-recommend-list {
    margin-left: 0;
    margin-right: 0;
  }
}

/******************************/
/* TOP PICK UP ITEMS */
/******************************/
.p-pickup {
  padding-top: 120px;
  padding-bottom: 120px;
  background: #fafafa;
}
@media screen and (max-width: 1023px) {
  .p-pickup {
    padding-top: 90px;
    padding-bottom: 90px;
  }
}
@media screen and (max-width: 767px) {
  .p-pickup {
    padding-top: 45px;
    padding-bottom: 60px;
  }
}

.p-pickup-list {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .p-pickup-list {
    margin-top: 0;
    margin-left: -25px;
    margin-right: -25px;
  }
}

.p-pickup-list__item {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 75px;
  word-break: break-all;
}
@media screen and (max-width: 1023px) {
  .p-pickup-list__item {
    margin-bottom: 60px;
  }
}
@media screen and (max-width: 767px) {
  .p-pickup-list__item {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 45px;
    max-width: 600px;
  }
}
.p-pickup-list__item:last-child {
  margin-bottom: 0;
}
.p-pickup-list__item:nth-child(even) .p-pickup-list__txt {
  order: -1;
}
@media screen and (max-width: 1023px) {
  .p-pickup-list__item:nth-child(even) .p-pickup-list__txt {
    padding-left: 25px;
    padding-right: 60px;
  }
}

.p-pickup-list__img {
  overflow: hidden;
  position: relative;
  width: 53%;
  height: 28vw;
  opacity: 1;
  transform: translate(0, 0);
}
@media screen and (min-width: 1270px) {
  .p-pickup-list__img {
    max-height: 365px;
  }
}
@media screen and (max-width: 1023px) {
  .p-pickup-list__img {
    width: 53%;
    height: 28vw;
  }
}
@media screen and (max-width: 767px) {
  .p-pickup-list__img {
    width: auto;
    height: 55vw;
  }
}
.p-pickup-list__img:before, .p-pickup-list__img:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.p-pickup-list__img .p-pickup-list__img-bg {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: 100%;
  height: 100%;
  transition: all 0.4s 0.6s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  background: #fff;
}
.p-pickup-list__img:after {
  transition: all 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  background: #fff;
}
.p-pickup-list__img:before {
  transition: all 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  background: #fff;
}
.p-pickup-list__img.faded .p-pickup-list__img-bg, .p-pickup-list__img.faded:after {
  width: 0;
}
.p-pickup-list__img img {
  position: relative;
  top: 50%;
  transform: translate(0, -50%);
  width: 100%;
}

.p-pickup-list__txt {
  box-sizing: border-box;
  flex: 1;
  padding-left: 70px;
  padding-right: 70px;
}
@media screen and (max-width: 1023px) {
  .p-pickup-list__txt {
    padding-left: 60px;
    padding-right: 25px;
    width: 47%;
  }
}
@media screen and (max-width: 767px) {
  .p-pickup-list__txt {
    margin-top: 20px;
    padding-left: 25px;
    padding-right: 25px;
    width: auto;
  }
}

.p-pickup-list__ttl {
  margin-top: 0;
  margin-bottom: 15px;
  line-height: 1.4;
  font-size: 24px;
  font-weight: normal;
}
@media screen and (max-width: 767px) {
  .p-pickup-list__ttl {
    margin-bottom: 10px;
    font-size: 17px;
  }
}
.p-pickup-list__ttl img {
  display: none !important;
}

.p-pickup-list__btn {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .p-pickup-list__btn {
    margin-top: 20px;
  }
}

/******************************/
/* TOP RANKING */
/******************************/
@media screen and (max-width: 1023px) {
  .c-ttl-bg.is-ranking {
    margin-bottom: 25px;
  }
}
@media screen and (max-width: 767px) {
  .c-ttl-bg.is-ranking {
    margin-bottom: 35px;
  }
}
.c-ttl-bg.is-ranking:before {
  background: url(https://img21.shop-pro.jp/PA01490/435/etc/soba-background.jpg?cmsp_timestamp=20221027142016) center center no-repeat;
  background-size: cover;
}

.p-ranking {
  padding-top: 30px;
}
@media screen and (max-width: 1023px) {
  .p-ranking {
    padding-top: 90px;
  }
}
@media screen and (max-width: 767px) {
  .p-ranking {
    padding-top: 60px;
  }
}

.p-ranking-list {
  margin-bottom: 30px;
}
@media screen and (max-width: 1050px) {
  .p-ranking-list {
    margin-left: 20px;
    margin-right: 20px;
  }
}
@media screen and (max-width: 1023px) {
  .p-ranking-list {
    margin-left: 0;
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-ranking-list {
    margin-left: -12px;
    margin-right: -12px;
  }
}
.p-ranking-list .slick-prev {
  left: -5px;
  margin-top: -43px;
}
@media screen and (max-width: 1023px) {
  .p-ranking-list .slick-prev {
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-ranking-list .slick-prev {
    margin-top: -30px;
  }
}
.p-ranking-list .slick-next {
  right: -5px;
  margin-top: -43px;
}
@media screen and (max-width: 1023px) {
  .p-ranking-list .slick-next {
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-ranking-list .slick-next {
    margin-top: -30px;
  }
}
.p-ranking-list .slick-dotted.slick-slider {
  margin-bottom: 60px;
}
.p-ranking-list .slick-dots {
  bottom: -45px;
}
.p-ranking-list .slick-dots li {
  margin: 0 2px;
}

.p-ranking-list__item {
  position: relative;
  box-sizing: border-box;
  margin-right: 10px;
  margin-left: 10px;
  padding-bottom: 25px;
  word-break: break-all;
}
@media screen and (max-width: 1023px) {
  .p-ranking-list__item {
    margin-right: 20px;
    margin-left: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-ranking-list__item {
    margin-right: 12px;
    margin-left: 12px;
  }
}
.p-ranking-list__item.slick-active .p-ranking-list__num {
  opacity: 1;
  animation: rankingfadein 0.2s 0s;
}

.p-ranking-list__img {
  margin-bottom: 20px;
  background: #ffffff;
}
@media screen and (max-width: 767px) {
  .p-ranking-list__img {
    margin-bottom: 10px;
    text-align: center;
  }
}

.p-ranking-list__num {
  box-sizing: border-box;
  position: absolute;
  top: 0px;
  right: 0px;
  padding-top: 3px;
  min-width: 30px;
  line-height: 27px;
  font-size: 16px;
  font-weight: bold;
  background: #ffffff;
  color: #2d2d2d;
  text-align: center;
  opacity: 0;
  transition: all ease 0.1s;
}
.p-ranking-list__num.is-1 {
  background: #c5b597;
  color: #ffffff;
}
.p-ranking-list__num.is-2 {
  background: #b1b9bb;
  color: #ffffff;
}
.p-ranking-list__num.is-3 {
  background: #714d3b;
  color: #ffffff;
}

@keyframes rankingfadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.p-ranking-list__ttl {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-ranking-list__ttl {
    font-size: 13px;
  }
}
.p-ranking-list__ttl img {
  vertical-align: middle;
}

.p-ranking-list__price {
  margin-top: 15px;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .p-ranking-list__price {
    margin-top: 5px;
    font-size: 13px;
  }
}
.p-ranking-list__price.is-default {
  margin-top: 0;
}

.p-ranking-list__btn {
  position: absolute;
  bottom: 0;
  right: 0;
}

/******************************/
/* TOP SHOP */
/******************************/
.p-shop {
  padding-top: 90px;
}
@media screen and (max-width: 1023px) {
  .p-shop {
    padding-top: 60px;
  }
}
@media screen and (max-width: 767px) {
  .p-shop {
    padding-top: 30px;
  }
}

.p-shop-wrap {
  position: relative;
  overflow: hidden;
  padding-top: 45px;
  padding-bottom: 45px;
}
@media screen and (max-width: 767px) {
  .p-shop-wrap {
    padding-top: 0;
    padding-bottom: 0;
  }
}
.p-shop-wrap:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
}
@media screen and (max-width: 767px) {
  .p-shop-wrap:before {
    content: none;
  }
}

.p-shop__bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-shop__bg {
    position: static;
    width: auto;
    height: auto;
  }
}
.p-shop__bg img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .p-shop__bg img {
    max-width: 100%;
  }
}
@media screen and (max-width: 1023px) {
  .p-shop__bg .simpleParallax {
    overflow: visible !important;
  }
}
@media screen and (max-width: 767px) {
  .p-shop__bg .simpleParallax {
    overflow: hidden !important;
  }
}

.p-shop-contents {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 360px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-shop-contents {
    min-height: inherit;
  }
}

.p-shop-box {
  position: relative;
  z-index: 100;
  width: 660px;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .p-shop-box {
    margin-top: 15px;
    width: auto;
    color: #2d2d2d;
  }
}

.p-shop-box__ttl {
  margin-bottom: 15px;
  line-height: 1.4;
  font-size: 24px;
}
@media screen and (max-width: 767px) {
  .p-shop-box__ttl {
    font-size: 17px;
  }
}

.p-shop-box__body {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .p-shop-box__body {
    margin-top: 0;
  }
}

.p-shop-box__url {
  margin-top: 15px;
}
.p-shop-box__url a {
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .p-shop-box__url a {
    color: #2d2d2d;
  }
}

.p-shop-box__btn {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .p-shop-box__btn {
    margin-top: 20px;
  }
}

/******************************/
/* 矢野 CSS追加 */
/******************************/
/*フォントファミリー変更*/
body{
    /* font-family: "Yu Mincho","YuMincho","MS Mincho","Spartan", "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo", "sans-serif"; */
    font-family:  "YuMincho", "Hiragino Mincho ProN","Times New Roman", "Yu Mincho", "MS PMincho", serif;
}

/*コンテンツ最大幅の設定*/

body {
    min-width: 375px;
}



/*ヘッダーアイコンを中央寄せにするため*/
h1 {
  margin: 0;
}
.l-header-main {
    margin-left: 0;
    margin-right: 0;
}
/* メインヒーロー */
.l-main.is-top {
  position: relative;
  top: -60px;
  left: 0;
}
.hero {
  position: relative;
  width: 100%;
  margin: 0 auto;
  background-image: url(https://ideasanta01b.xbiz.jp/zenkai/images/hero-sp-3.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  margin-bottom: 0px;
  height: 100vh;
  height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 1024px) {
  .hero {
    background-image: url(https://ideasanta01b.xbiz.jp/zenkai/images/hero-pc-3.jpg);
    margin-bottom: 100px;
  }
}
/* ロゴとサブタイトル上段寄せ */
.hero-logo {
display: flex;
flex-direction: row;
flex-wrap: nowrap;
align-items: flex-start;
justify-content: center
}
.hero h1 {
width: 30%;
margin-left: 1.6em;
}

p.p-main-ttl-sub {
  color: #fff;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  line-height: 1.37;
  font-size: 14px;
  letter-spacing: 0.12em;
  margin-bottom: 0;
  margin-left: 0.714em;
  font-feature-settings: "palt" 1;
}
.hero-btn {
  position: absolute;
  bottom: 50px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}
.hero-btn .c-btn {
  color: #fff;
  background-color: rgba(255 ,255 ,255 ,0.3);
  border: 1px solid #fff;
}

@media screen and (min-width: 601px){
  .hero {
    margin-bottom: 50px;
}
}

@media screen and (min-width: 768px) {
  .l-main.is-top {
    top: -90px;
}
.hero h1 {
  width: 50%;
  margin-left: 1.8em;
}
.p-main-ttl-sub {
  font-size: 16px;
  margin-left: 0.4em;
}
}

@media screen and (min-width: 1024px) {
  .hero h1 {
    margin-left: 1.9em;
  }
  .l-main.is-top {
    top: -120px;
}
p.p-main-ttl-sub {
  font-size: 16px;
}
}

/* 北海道の味 */
section#taste {
  padding-top: 0;
  padding-bottom: 54px;
}
.taste-img-flex {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: flex-end;
}

/* 上段のそばとロゴ */
.taste-img-top-item:first-child {
  flex-basis: 27%;
    margin-right: 2%;
    margin-bottom: 30px;
}

.taste-img-top-item:last-child {
  flex-basis: 34%;
    margin: 0 0 0 10%;
}

.taste-decoration01 {
  width: 13%;
  position: absolute;
  top: 27px;
  left: 0;
}

.taste-decoration02 {
  width: 14%;
  position: absolute;
  bottom: 84px;
  right: 116px;
}

.taste-img-top {
  padding-top: 5.231em;
  position: relative;
}

/* 中段のそば */
.taste-img-middle-item:first-child {
  width: 94.334%;
    margin: 0 0 11% auto;
  z-index: 3;
  position: relative;
}

.taste-img-middle {
  position: relative;
}

.taste-img-middle-item:last-child {
  width: 32%;
  position: absolute;
  top: 4px;
  left: 17px;
}

.taste-ttl h2 {
  font-size: var(--font-ttl);
  margin-top: 2px;
  margin-bottom: 11px;
  letter-spacing: .044em;
  font-feature-settings: "palt" 1;
}
.taste-text {
  margin-left: -2%;
}
.taste-text p {
  font-size: var(--font-body);
  margin-bottom: 37px;
  letter-spacing: 0.12em;
  line-height: 1.58;
  font-weight: 700;
  font-feature-settings: "palt" 1;
  transform: var(--scaleX);
}

.taste-img-bottom {
  width: 100%;
  background-image: url('https://img21.shop-pro.jp/PA01490/435/etc_base64/c25vdw.png?cmsp_timestamp=20240403210722');
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 100% center;
  position: relative;
  top: -170px;
  margin-bottom: -170px;
}
.taste-img-bottom-wrapper {
  /* width: 58.67%; */
  width: calc(100% - 40px);
  margin: 0 auto;
  padding: 133px 0 86px;
}
.taste-btn {
  text-align: center;
  max-width: 211px;
  margin: 0 auto;
}
@media screen and (min-width: 601px) {
  .taste-grid { 
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
    grid-column-gap: 0px;
    grid-row-gap: 0px;
  }

.taste-img-middle {
    top: 0;
    margin-top: 0px;
    margin-bottom: 0;
    /* grid-area: 2 / 1 / 3 / 2; */
}
.taste-img-middle-item:first-child {
  margin: 0 auto;
}
.taste-img-bottom {
    width: 100%;
    top: 0;
    margin-bottom: 0;
    background-position-x: 0%;
}

.taste-img-top {
    grid-area: 1 / 1 / 2 / 2;
}

.taste-img-bottom {
    grid-area: 1 / 2 / 3 / 3;
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex-wrap: nowrap;
}
.taste-text {
  margin-left: 0;
}
}
@media screen and (min-width: 768px){
  .taste-img-bottom-wrapper {
    width: 58.67%;
  }
  .taste-btn {
    margin: 0;
  }
}
@media screen and (min-width: 980px) {
  .taste-grid {
    max-width: 1000px;
    margin: 0 auto;
}
}

@media screen and (min-width: 1024px) {
  section#taste {
    padding-bottom: 80px;
  }
}
/* RECOMMENDED ITEMS */
/* .recommend {
  margin-bottom: 50px;
} */
.recommend-container {
  /* width: 59%; */
  width: calc(100% - 40px);
  margin: 0 auto;
}
.recommend-ttl {
  margin-bottom: 27px;
}
.recommend-ttl h2 span.main-ttl {
  display: block;
  font-size: var(--font-ttl);
  font-family: Big Caslon;
  line-height: 1;
  letter-spacing: normal;
  font-weight: 600;
  margin-bottom: 8px;
}
.recommend-ttl h2 span.sub-ttl {
  display: block;
  font-weight: 600;
  font-size: var(--font-ttl-sub);
  line-height: 1.41;

}
@media screen and (min-width: 768px) {
  /* .recommend-container {
    width: 41.67%;
} */
}
@media screen and (min-width: 980px) {

.recommend-container {
    width: 100%;
}

.recommend-ttl h2 span.main-ttl {
    text-align: center;
}

.recommend-ttl h2 span.sub-ttl {
    text-align: center;
}
}
@media screen and (min-width: 1024px) {
  .recommend {
    margin-bottom: 32px;
  }
}
/* Soba products */
.product-category {
  width: calc(100% - 32px);
  margin: 0 auto;
}
.product-category-ttl {
  width: 100%;
  margin: 0 auto;
}
.product-category-ttl h2 {
  /* font-size: 17px; */
  font-size: var(--font-ttl-middle);
  font-family: Big Caslon;
  font-weight: 600;
  margin-bottom: 10px;
}
.product-category-item {
text-align: right;
}
.product-category-item a {
  width: 100%;
  border-bottom: 1px solid #c8c8c8;
  display: inline-block;
  font-size: 14px;
  font-feature-settings: "palt" 1;
  padding: 14px 0;
}
.product-category-item .fa-solid.fa-arrow-right-long {
  font-size: 12px;
  margin-right: 7%;
}

.product-category-item a:hover .fa-arrow-right-long {
  transform: translateX(11px);
  transition: transform 0.35s ease;
}

.product-category-item a:first-child {
  border-top: 1px solid #c8c8c8;
}
.product-category-item a:last-child {
  border-bottom: none;
}
@media screen and (min-width: 768px) {
  .product-category {
      width: 41.67%;
      max-width: 700px;
      margin-bottom: 50px;
  }
  .product-category-ttl {
    width: 38.5%;
}
.product-category-ttl h2 {
    font-size: 19px;
    margin-bottom: 16px;
    text-align: center;
}
.product-category-item a {
  font-size: 16px;
  padding: 16px 0;
}
.product-category-item .fa-solid.fa-arrow-right-long {
  margin-left: 3%;
}
}

@media screen and (min-width: 1024px) {
  .product-category-ttl h2 {
    font-size: 21px;
    margin-top: 0;
  }
  /* .product-category-item a {
    font-size: 18px;
  } */
}

/* 十割蕎麦を楽しみたい方へ */
/* .towari {
  padding: 60px 0;
} */
.towari-top {
  width: calc(100% - 40px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: flex-start;
  position: relative;
  z-index: 2;
}
.towari-top-ttl {
  width: 100%;
}
.towari-top-ttl h2 {
  /* font-size: var(--font-ttl-middle); */
  font-size: var(--font-ttl);
  font-weight: bold;
  font-feature-settings: "palt" 1;
  line-height: 1.4861;
  /* letter-spacing: 0.044em; */
  letter-spacing: 0.084em;
  margin-top: 0;
}
.towari-top-text {
  width: 81%;
  margin-left: -2%;
}
.towari-top-text p {
  font-size: var(--font-body);
  font-weight: 700;
  line-height: 1.916;
  font-feature-settings: "palt" 1;
  letter-spacing: 0.12em;
  transform: var(--scaleX);
}
.towari-bottom {
  width: 100%;
  background-image: url(https://img21.shop-pro.jp/PA01490/435/etc_base64/dG93YXJpLWJhY2s.png?cmsp_timestamp=20240405103311);
  background-size: 105%;
  background-repeat: no-repeat;
  background-position: center;
  padding-bottom: 50px;
  position: relative;
  top: -65px;
  margin-bottom: -65px;
}
.towari-bottom-flex {
  width: 80%;
  display: block;
  /* display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: flex-end; */
}
.towari-bottom-emphasis {
  margin-top: -6px;
  margin-bottom: 36px;
}
.towari-bottom-emphasis p {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #fff;
  font-size: 129px;
  line-height: 1;
  letter-spacing: -0.15em;
  margin-bottom: 0;
  margin-left: auto;
}
.towari-bottom-text {
  width: 100%;
  margin: 0 auto 22px 4.5%;
}
.towari-bottom-text p {
  color: #fff;
  font-size: var(--font-body);
  font-weight: 700;
  line-height: 1.58;
  letter-spacing: 0.12em;
  font-feature-settings: "palt" 1;
  transform: var(--scaleX);
}
.towari-btn {
  width: 75%;
  text-align: left;
  margin-left: auto;
}
.towari-copy {
  position: absolute;
  bottom: -9px;
  right: 35px;
  font-size: 11px;
  color: #1c4f34;
}

@media screen and (min-width: 405px) {
  .towari-bottom {
    background-size: 103%;
}
.towari-copy {
  right: 2%;
}
}
@media screen and (min-width: 450px) {
  .towari-bottom {
    background-size: 100%;
}
  .towari-bottom-emphasis p {
    margin-left: auto;
    margin-right: clamp(54px, 39%, 240px);;
}
}
@media screen and (min-width: 470px) {
  .towari-bottom {
    background-size: 91%;
    background-position-x: 0%;
  }
  .towari-copy {
    right: 8%;
}
}

@media screen and (min-width: 601px) {
  .towari-flex {
    display: flex;
    flex-direction: row-reverse;
}

.towari-copy {
    right: 7%;
}

.towari-top {
    width: 35%;
    align-items: flex-start;
}

.towari-bottom {
    background-size: 100%;
    width: 62%;
}

.towari-top-ttl {
    width: 100%;
}
.towari-bottom-text {
  width: 100%;
  margin: 0 auto 12px;
}

.white-btn.towari-btn {
  margin: 0;
}

.towari-bottom-emphasis p {
  margin: 0;
}

.towari-bottom-flex {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  margin: 0 auto;
}
}
@media screen and (min-width: 681px) {
  .towari-copy {
    right: 1%;
  }
}
@media screen and (min-width: 768px) {
  .towari-top {
      width: 43%;
      margin-left: 30px;
      margin-right: auto;
  }
  .towari-top-text {
    margin-left: 0;
  }
  .towari-bottom-flex {
    width: 86%;
  }
  .towari-bottom {
    width: 50%;
    padding-bottom: 38px;
}
  .towari-bottom-text {
    width: 81.8%;
    margin: 0 0 12px 0;
}
.towari-copy {
  right: 12%;
  bottom: -11px;
}
}

@media screen and (min-width: 803px) {
  .towari-copy {
    right: 4%;
  }
}

@media screen and (min-width: 980px) {
  .towari-flex {
    max-width: 1000px;
    margin: 0 auto;
}
.towari-copy {
  right: 1%;
}
}

/* 蕎麦の特徴 */
.feature {
  padding: 96px 0 22px;
}
.feature-flex:nth-child(2),
.feature-flex:nth-child(3) {
  display: flex;
  flex-direction: column-reverse;
  flex-wrap: nowrap;
}
.feature-flavor {
  margin-bottom: 50px;
}

.feature-flex:nth-child(2) .feature-flavor{
  margin-bottom: 14px;
}

.feature-flex:nth-child(3) .feature-flavor {
  margin-bottom: 24px;
}

.feature-flavor-ttl,
.feature-flavor-text {
  width: calc(100% - 40px);
  margin: 0 auto;
}
.feature-flavor-ttl h2 {
  /* font-size: var(--font-ttl-middle); */
  font-size: var(--font-ttl);
  font-weight: bold;
  font-feature-settings: "palt" 1;
  line-height: 1.4861;
  /* letter-spacing: 0.044em; */
  letter-spacing: 0.084em;
  margin-top: 0;
}
.feature-flex:nth-child(2) .feature-flavor-ttl h2,
.feature-flex:nth-child(3) .feature-flavor-ttl h2 {
  margin-bottom: 13px;
}

.feature-flavor-text {
  margin: 0 auto 0 3.5%;
}
.feature-flavor-text p {
  font-size: var(--font-body);
  font-weight: 700;
  line-height: 1.916;
  font-feature-settings: "palt" 1;
  letter-spacing: 0.12em;
  transform: var(--scaleX);
}
.feature-flex:nth-child(2) .feature-flavor-text,
.feature-flex:nth-child(3) .feature-flavor-text {
  width: 70%;
  margin: 0 auto 0 4%;
}
.feature-flavor-img {
  position: relative;
  margin-bottom: 50px;
}
.feature-flex:nth-child(2) .feature-flavor-img,
.feature-flex:nth-child(3) .feature-flavor-img {
  margin-bottom: 21px;
}
.flavor-img-item:first-child {
  width: 64%;
  position: relative;
  z-index: 2;
}
.flavor-img-item:last-child {
  width: 53.34%;
  position: relative;
  top: -65px;
  left: 144px;
  margin-bottom: -65px;
}

@media screen and (min-width: 601px) {
  .feature-flex:first-child {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-evenly;
    align-items: flex-start;
}
.feature-flavor-img {
    width: 55%;
}

.feature-flex:first-child .feature-flavor-ttl, .feature-flex:first-child .feature-flavor-text {
    width: 100%;
    margin: 0;
}
.feature-flex:nth-child(2) .feature-flavor-img, .feature-flex:nth-child(3) .feature-flavor-img {
  width: 100%;
}
.flavor-img-item:last-child {
  left: 104px;
}
}

@media screen and (min-width: 768px) {
  .feature-flex:first-child {
    justify-content: flex-end;
}
  .feature-flavor-ttl, .feature-flavor-text {
    width: 100%;
    margin: 0;
}
.feature-flavor-img {
  width: 44.43%;
  margin-bottom: 10px;
}
.flavor-img-item:first-child {
    width: 66%;
  }
.flavor-img-item:last-child {
  width: 53%;
  top: -70px;
  left: 160px;
}
.feature-flex:nth-child(2), .feature-flex:nth-child(3) {
    width: 90%;
    flex-direction: row;
}
.feature-flex:nth-child(2) {
    flex-direction: row-reverse;
    margin-bottom: 50px;
}
.feature-flavor-ttl, .feature-flavor-text {
    width: 100%;
    margin: 0;
}

.feature-flex:first-child .feature-flavor {
  margin-right: 30px;
  width: 37.76%;
}
.feature-flex:nth-child(2) .feature-flavor, .feature-flex:nth-child(3) .feature-flavor {
    width: 85%;
    margin: 0 30px 0 30px;
}
.feature-flex:nth-child(2) {
    margin-right: auto;
    margin-bottom: 71px;
} 
.feature-flex:nth-child(3) {
    margin-left: auto;
    margin-bottom: 71px;
}
.feature-flex:nth-child(2) .feature-flavor-img,
.feature-flex:nth-child(3) .feature-flavor-img {
  margin-bottom: 0px;
}
.feature-flex:nth-child(2) .feature-flavor-text,
.feature-flex:nth-child(3) .feature-flavor-text {
  margin: 0;
}
}
@media screen and (min-width: 980px) {
  .feature {
    max-width: 1000px;
    margin: 0 auto;
  }
  .flavor-img-item:last-child {
    left: auto;
    margin-left: auto;
  }
}
@media screen and (min-width: 1024px) {
  .feature-flex {
    margin-bottom: 85px;
}
.feature-flex:nth-child(2) {
  margin-bottom: 100px;
}
.feature-flex:nth-child(3) {
  margin-bottom: 65px;
}
}

/* 食べ方 */
.how-to {
  background-color: #f3f4ef;
  padding: 60px 0 48px;
}
.how-to-ttl,
.how-to-text {
  /* width: 58%; */
  width: calc(100% - 40px);
  margin: 0 auto;
}
.how-to-ttl h2 {
  /* font-size: var(--font-ttl-middle); */
  font-size: var(--font-ttl);
  font-weight: bold;
  font-feature-settings: "palt" 1;
  line-height: 1.4861;
  /* letter-spacing: 0.044em; */
  letter-spacing: 0.084em;
  margin-top: 0;
  margin-bottom: 0;
}
.how-to-text {
  margin: 0 auto 0 3%;
}
.how-to-text p {
  font-size: var(--font-body);
  font-weight: 700;
  line-height: 1.916;
  font-feature-settings: "palt" 1;
  letter-spacing: 0.12em;
  transform: var(--scaleX);
  margin-bottom: 18px;
}
.how-to-img {
  width: 92%;
    margin: 0 auto 35px;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.how-to-img-item {
  display: flex; 
  flex-direction: column; 
  justify-content: space-between; 
  align-items: center; 
  height: 85px; 
}
.how-to-img-item figure {
  margin: 0;
}
.how-to-img-item p {
  /* font-size: 10px; */
  font-size: var(--font-ttl-sub);
  text-align: center;
  margin: 0;
}
.how-to-img-item:first-child {
  width: 23.7%;
}
.how-to-img-item:first-child > figure {
  margin-top: 0;
  margin-bottom: 10px;
}
.how-to-img-item:nth-child(2) {
  width: 23.7%;
}
.how-to-img-item:nth-child(2) > figure {
  width: 100%;
  margin: 0 auto 10px;
}
.how-to-img-item:nth-child(3) {
  width: 23.7%;
}
.how-to-img-item:nth-child(3) > figure {
  width: 100%;
  margin: 0 auto 10px;
}
.how-to-img-item:nth-child(4) {
  width: 23.7%;
}
.how-to-img-item:nth-child(4) > figure {
  margin-top: 0;
  margin-bottom: 10px;
}
.how-to-img-item:last-child {
  width: 23.7%;
}
.how-to-img-item:last-child > figure {
  margin-top: 0;
  margin-bottom: 10px;
}
.how-to-btn {
  text-align: center;
  margin-bottom: 50px;
}
.how-to-btn a {
  border: 1px solid #000;
}
.making-img {
  margin-bottom: 25px;
}
.making-ttl {
  margin-bottom: 14px;
}
.making-ttl h2 {
  width: calc(100% - 40px);
  margin: 0 auto;
  /* font-size: var(--font-ttl-middle); */
  font-size: var(--font-ttl);
  font-weight: bold;
  font-feature-settings: "palt" 1;
  line-height: 1.4861;
  /* letter-spacing: 0.044em; */
  letter-spacing: 0.084em;
  margin-top: 0;
}
.making-text {
      width: calc(100% - 40px);
    margin: 0 auto 22px 3.5%;
}
.making-text p{
  font-size: var(--font-body);
  font-weight: 700;
  line-height: 1.916;
  font-feature-settings: "palt" 1;
  letter-spacing: 0.12em;
  transform: var(--scaleX);
}
.making-img-md {
  width: calc(100% - 80px);
  margin: 0 auto 30px;
}
.making-btn {
  text-align: center;
}
.making-btn a {
  border: 1px solid #000;
}

@media screen and (min-width: 451px) {
  .how-to-img-item {
    height: 160px;
  }
}
@media screen and (min-width: 768px) {
  .how-to {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .how-to-ttl h2 {
    text-align: center;
}
.how-to-img-item {
  height: 140px;
}
.how-to-text p {
    text-align: center;
    margin-bottom: 22px;
}
.how-to-img-item p {
  font-size: 14px;
}
.how-to-img-item:first-child > figure {
  max-width: 100px;
}

.how-to-img-item:nth-child(2) > figure {
  max-width: 100px;
}

.how-to-img-item:nth-child(3) > figure {
  max-width: 100px;
}
.how-to-img-item:nth-child(4) > figure {
  max-width: 100px;
}
.how-to-img-item:last-child > figure {
  max-width: 100px;
}
.making-ttl h2 {
  width: 78.4%;
  margin: 0 auto;
}
.making-text {
  width: 78.4%;
  margin: 0 auto 25px;
}
.making-img {
  margin-bottom: 50px;
}
.making-img-md {
  margin-bottom: 25px;
}
}

@media screen and (min-width: 980px) {
.how-to-ttl, .how-to-text {
    width: 100%;
    margin: 0;
}
.making-img {
    width: 100%;
}
.making-img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  max-height: 400px;
}
}

@media screen and (min-width: 1024px) {
  .how-to {
    padding: 100px 0;
    max-width: none;
  }
  .how-to-text p {
    margin-bottom: 50px;
  }
  .how-to-img {
    max-width: 760px;
    margin-bottom: 50px;
  }
  .how-to-btn {
    margin-bottom: 100px;
  }
  .making-img img {
    max-height: 520px;
}
.making-ttl h2 {
  max-width: 1000px;
}
.making-text {
  max-width: 1000px;
  margin: 0 auto 25px;
}
.making-img-md {
  max-width: 1000px;
  margin-bottom: 50px;
}
}

/****************
CSS アニメーション
****************/
/* ぼかしから出現 */
.blur.on{
  animation-name:blurAnime;
  animation-duration:1s;
  animation-fill-mode:forwards;
  opacity: 0;
}

@keyframes blurAnime{
  from {
  filter: blur(10px);
  /* transform: scale(1.02); */
  opacity: 0;
  }

  to {
  filter: blur(0);
  /* transform: scale(1); */
  opacity: 1;
  }
}

.fade.on{
  animation-name:fadeInAnime;
  animation-duration:2s;
  animation-fill-mode:forwards;
  opacity:0;
  }

  @keyframes fadeInAnime{
    from {
      opacity: 0;
    }
  
    to {
      opacity: 1;
    }
  }

  /* ヒーロー部分のアニメーション */
  .fade {
    opacity: 0;
  }
  .hero-logo.fade.on {
    animation-delay: 1s;
  }
  .l-header.fade.on,
  .hero-btn.fade.on {
  animation-delay: 2s;
  }

  /* テキストアニメーション */
  .slide-in {
    overflow: hidden;
      display: inline-block;
  }
  
  .slide-in_inner {
    display: inline-block;
  
  }
  
  /*左右のアニメーション*/
  .rightAnime{
      opacity: 0;/*事前に透過0にして消しておく*/
  }
  
  .slideAnimeLeftRight {
    animation-name:slideTextX100;
    animation-duration:0.8s;
    animation-fill-mode:forwards;
      opacity: 0;
  }
  
  @keyframes slideTextX100 {
    from {
    transform: translateX(-100%); /*要素を左の枠外に移動*/
          opacity: 0;
    }
  
    to {
    transform: translateX(0);/*要素を元の位置に移動*/
      opacity: 1;
    }
  }
  
  .slideAnimeRightLeft {
    animation-name:slideTextX-100;
    animation-duration:0.8s;
    animation-fill-mode:forwards;
      opacity: 0;
  }
  
  
  @keyframes slideTextX-100 {
    from {
    transform: translateX(100%);/*要素を右の枠外に移動*/
      opacity: 0;
    }
  
    to {
    transform: translateX(0);/*要素を元の位置に移動*/
      opacity: 1;
    }
  }

  /* テキストアニメーション 個別調整 */
  /* .taste-ttl .slideAnimeRightLeft {
    animation-delay: 2s;
    animation-duration: 2.8s;
  } */