@charset "utf-8";

:root {
  --colorgreen: #1a4a17;
  --fontA1: "A1 Gothic M";
}

.mothersday_san {
  color: var(--colorgreen);
  line-height: 1;
  letter-spacing: 0.07em;
  margin-left: auto;
  margin-right: auto;
  max-width: 1170px;
  margin-bottom: 40px;
  position: relative;
}

.mothersday_san * {
  list-style: none;
  margin-bottom: 0;
}

.mothersday_san img {
  height: auto;
  max-width: 100%;
}

.mothersday-header_san {
  background-image: url(../images/mainimage.webp);
  background-size: cover;
  background-repeat: no-repeat;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 662px;
  margin: 0 calc(50% - 50vw);
  overflow: hidden;
  padding-right: 0.9375rem;
  padding-left: 0.9375rem;
  width: 100vw;
}

.mothersday-title_san {
  max-width: 1064px;
}

.mothersday-ctns_san {
  background-image: url(../images/welcome_bg.webp);
  background-size: auto;
  margin: 0 calc(50% - 50vw);
  padding-bottom: 280px;
  padding-right: 0.9375rem;
  padding-left: 0.9375rem;
  padding-top: 160px;
  position: relative;
  width: 100vw;
}

.mothersday-ctns_san::after {
  background-image: url(../images/market_wk.png);
  background-size: auto;
  background-repeat: repeat-x;
  content: "";
  height: 42px;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}

.mothersday-ctn__wk_san {
  max-width: 1090px;
  padding-top: 13.027522935%;
  position: relative;
  width: 100%;
}

.mothersday-ctn__wk_san::before {
  background-image: url(../images/ctn_wk_01.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 100%;
  max-height: 142px;
  max-width: 1090px;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
}

.mothersday-ctn_san {
  margin-left: auto;
  margin-right: auto;
  max-width: 1090px;
  padding-bottom: 100px;
  position: relative;
  z-index: 1;
}

.mothersday-ctn_san::before {
  background-image: url(../images/ctn_bg_01.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 100%;
  max-height: 1104px;
  max-width: 914px;
  position: absolute;
  right: -340px;
  top: -160px;
  width: 100%;
  z-index: 1;
}

.mothersday-ctn_san::after {
  background-image: url(../images/ctn_bg_02.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 100%;
  max-height: 1080px;
  max-width: 818px;
  position: absolute;
  bottom: -360px;
  left: -330px;
  width: 100%;
}

.mothersday-ctn__waku_san {
  background-color: #fff;
  background-image: url(../images/ctn_wk_02.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: center bottom;
  padding-bottom: 110px;
  position: relative;
}

.mothersday-ctn__waku_san::before,
.mothersday-ctn__waku_san::after {
  background-image: url(../images/ctn_line_01.svg);
  background-size: 100%;
  background-repeat: repeat-y;
  content: "";
  height: 98.7%;
  position: absolute;
  top: 0;
  width: 20px;
}

.mothersday-ctn__waku_san::before {
  left: 0;
}

.mothersday-ctn__waku_san::after {
  right: 0;
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg);
}

.mothersday-welcome_san {
  margin-bottom: 80px;
  padding-bottom: 70px;
  position: relative;
}

.mothersday-welcome_san::before {
  background-image: url(../images/welcome_bg.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 100%;
  max-height: 224px;
  max-width: 244px;
  position: absolute;
  left: 40px;
  top: 0;
  width: 100%;
}

.mothersday-welcome_san::after {
  border-bottom: 2px dotted #356232;
  content: "";
  height: 2px;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 84.95412844%;
}

.mothersday-welcome__picts_san {
  margin-left: auto;
  margin-right: auto;
  margin-top: 55px;
  width: 72.935779816%;
}

.mothersday-recommend_san {
  position: relative;
}

.mothersday-recommend_san::before {
  background-image: url(../images/recommend_bg.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 100%;
  max-height: 224px;
  max-width: 244px;
  position: absolute;
  right: -10px;
  top: -50px;
  width: 100%;
  z-index: 1;
}

.mothersday-recommend__kanjyuku_san {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  margin-left: auto;
  margin-right: auto;
  max-width: 926px;
  width: 84.95412844%;
}

.mothersday-recommend__picts_san {
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
  width: 51.295896328%;
}

.mothersday-recommend__captions_san {
  width: 42.116630669%;
}

.mothersday-recommend__caption_san {
  margin-bottom: 30px;
  margin-left: auto;
  margin-right: auto;
  max-width: 290px;
}

.mothersday-recommend_san .section-comment_san {
  text-align: justify;
}

.mothersday-btn_san {
  margin-left: auto;
  margin-right: auto;
  margin-top: 65px;
  max-width: 382px;
}

.mothersday-btn__link_san {
  border: 1px solid var(--colorgreen);
  border-radius: 41px;
  color: var(--colorgreen);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-family: var(--fontA1);
  font-size: 25px;
  height: 84px;
  position: relative;
}

.mothersday-btn__link_san::after {
  background-image: url(../images/arrow.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 20px;
  position: absolute;
  right: 35px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  transition: all 0.2s ease;
  width: 24px;
}

.mothersday-btn__link_san:hover::after {
  right: 30px;
}

.mothersday-btn__link_san:hover {
  color: var(--colorgreen);
  text-decoration: none;
}

.mothersday-market_san {
  background-color: #c5e6f2;
  background-image: url(../images/market_bg.png);
  background-size: 100%;
  background-position: center;
  background-repeat: no-repeat;
  margin: 0 calc(50% - 50vw);
  padding-bottom: 400px;
  padding-top: 110px;
  position: relative;
  width: 100vw;
}

.mothersday-market_san::after {
  background-image: url(../images/market_wk.svg);
  background-size: auto;
  background-repeat: repeat-x;
  content: "";
  height: 42px;
  position: absolute;
  left: 0;
  width: 100%;
}

.mothersday-market_san::after {
  bottom: -42px;
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg);
}

.mothersday-market__items_san {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 40px;
  margin-left: auto;
  margin-right: auto;
  max-width: 1065px;
}

.mothersday-market__item_san {
  position: relative;
  width: 44.788732394%;
}

.mothersday-market__item_san:nth-child(even) {
  top: 200px;
}

.mothersday-market__link_san {
  display: block;
  -webkit-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  transition: all 0.2s ease;
}

.mothersday-market__link_san:hover {
  opacity: 0.6;
  text-decoration: none;
}

.mothersday-market__picts_san {
  margin-top: -25px;
}

.mothersday-market__caption_san {
  color: var(--colorgreen);
  font-family: var(--fontA1);
  font-size: 20px;
  line-height: 1.4;
  margin-top: 15px;
  text-align: center;
}

.mothersday-lineup_san {
  margin-top: 150px;
}

.section-title_san {
  margin-left: auto;
  margin-right: auto;
  max-width: 345px;
}

.section-subtitle_san {
  font-family: var(--fontA1);
  font-size: 30px;
  line-height: 1.4;
  margin-bottom: 45px;
  margin-top: 45px;
  text-align: center;
}

.section-comment_san {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}

@media not all and (min-width: 768px) {
  .mothersday-header_san {
    background-image: url(../images/mainimage_sp.webp);
    height: 229px;
    padding-right: 0;
    padding-left: 0;
  }

  .mothersday-title_san {
    width: 90.933333333%;
  }

  .mothersday-ctns_san {
    background-size: 100%;
    padding-bottom: 60px;
    padding-right: 0;
    padding-left: 0;
    padding-top: 40px;
  }

  .mothersday-ctns_san::after {
    height: 12px;
  }

  .mothersday-ctn__wk_san::before {
    background-image: url(../images/ctn_wk_01_sp.svg);
  }

  .mothersday-ctn_san {
    padding-bottom: 0px;
    width: 90.266666666%;
  }

  .mothersday-ctn_san::before {
    max-width: 240px;
    right: -60px;
    top: -42px;
  }

  .mothersday-ctn_san::after {
    max-height: 300px;
    max-width: 225px;
    bottom: -100px;
    left: -75px;
  }

  .mothersday-ctn__waku_san {
    background-image: url(../images/ctn_wk_02_sp.svg);
    padding-bottom: 45px;
  }

  .mothersday-ctn__waku_san::before,
  .mothersday-ctn__waku_san::after {
    background-image: url(../images/ctn_line_01_sp.svg);
    height: 99.6%;
    width: 6px;
    width: 1.772525849%;
  }

  .mothersday-welcome_san {
    margin-bottom: 40px;
    padding-bottom: 40px;
  }

  .mothersday-welcome_san::before {
    max-width: 65px;
    left: 15px;
  }

  .mothersday-welcome_san::after {
    width: 88.330871491%;
  }

  .mothersday-welcome__picts_san {
    margin-top: 30px;
    width: 87.887740029%;
  }

  .mothersday-recommend_san::before {
    max-width: 85px;
    right: -5px;
    top: -23px;
  }

  .mothersday-recommend__kanjyuku_san {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-top: 32.5%;
    position: relative;
    width: 84.194977843%;
  }

  .mothersday-recommend__picts_san {
    width: 100%;
  }

  .mothersday-recommend__captions_san {
    margin-bottom: 20px;
    width: 100%;
  }

  .mothersday-recommend__caption_san {
    position: absolute;
    left: 50%;
    top: 0;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 52.631578947%;
  }

  .mothersday-btn_san {
    margin-top: 23px;
    width: 45.790251107%;
  }

  .mothersday-btn__link_san {
    border-radius: 18px;
    font-size: 10px;
    height: 35px;
  }

  .mothersday-btn__link_san::after {
    height: 9px;
    right: 15px;
    width: 12px;
  }

  .mothersday-btn__link_san:hover::after {
    right: 10px;
  }

  .mothersday-market_san {
    background-image: url(../images/market_bg_sp.png);
    padding-bottom: 180px;
    padding-top: 40px;
  }

  .mothersday-market_san::after {
    height: 12px;
  }

  .mothersday-market_san::after {
    bottom: -12px;
  }

  .mothersday-market__items_san {
    gap: 40px 0;
    width: 90.666666666%;
  }

  .mothersday-market__item_san {
    width: 50%;
  }

  .mothersday-market__item_san:nth-child(even) {
    top: 135px;
  }

  .mothersday-market__choice_san {
    margin-left: 20px;
    width: 30px;
  }

  .mothersday-market__picts_san {
    margin-top: -5px;
  }

  .mothersday-market__caption_san {
    font-size: 11px;
    margin-top: 10px;
  }

  .mothersday-lineup_san {
    margin-top: 40px;
  }

  .section-title_san {
    max-width: 140px;
  }

  .section-subtitle_san {
    font-size: 15px;
    margin-bottom: 15px;
    margin-top: 15px;
  }

  .section-comment_san {
    font-size: 12px;
  }
}
