.loader {
  position: fixed;
  width: 100%;
  height: 100%;
  background-color: #fff;
  z-index: 555;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.loader .txt {
  font-size: 45px;
  font-weight: bold;
  color: #333;
  display: none;
}
@media screen and (max-width: 767px) {
  .loader .txt {
  font-size: 20px;
  }
}
.loader .spinner{
  display: none;
}

.spinner {
  margin: 100px auto;
  width: 50px;
  height: 40px;
  text-align: center;
  font-size: 10px;
}

.spinner > div {
  background-color: #333;
  height: 100%;
  width: 6px;
  display: inline-block;
  
  -webkit-animation: sk-stretchdelay 1.2s infinite ease-in-out;
  animation: sk-stretchdelay 1.2s infinite ease-in-out;
}

.spinner .rect2 {
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}

.spinner .rect3 {
  -webkit-animation-delay: -1.0s;
  animation-delay: -1.0s;
}

.spinner .rect4 {
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}

.spinner .rect5 {
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
}

@-webkit-keyframes sk-stretchdelay {
  0%, 40%, 100% { -webkit-transform: scaleY(0.4) }  
  20% { -webkit-transform: scaleY(1.0) }
}

@keyframes sk-stretchdelay {
  0%, 40%, 100% { 
    transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% { 
    transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}

/*
.dis{
height:140px;
}
.c-item-list__ttl,.p-ranking-list__ttl{
height:80px;
}
@media screen and (max-width: 1400px) and (min-width: 1101px){
    .dis{
height:200px;
}
  .c-item-list__ttl,.p-ranking-list__ttl{
height:150px;
}
}
@media screen and (max-width: 1100px) and (min-width: 501px) {
.dis{
height:170px;
}
.c-item-list__ttl,.p-ranking-list__ttl{
height:120px;
}
}*/
@media screen and (max-width: 767px){
  .dis{
    border:none!important;
    padding:1vw!important;
  }
}/*
@media screen and (max-width: 500px){
    .dis{
height:200px;
}
  .c-item-list__ttl,.p-ranking-list__ttl{
height:150px;
}
}*/
@media screen and (max-width: 767px){
.c-item-list__txt,.p-ranking-list__txt{
  border-bottom:solid 1px #333;
}
}
.p-checked .priceyose{
  font-size: 14px;
}
@media screen and (max-width: 500px) {
  .p-checked .priceyose{
  font-size: 12px;
}
}
/* ヘッダー用余白 */
.main__section--top{
  margin-top:-165px;
}
@media screen and (max-width: 1110px) {
  .main__section--top{
  margin-top:0;
}
}
@media screen and (max-width: 767px) {
  .main__section--top{
  margin-top:80px;
}
}
/* ヘッダー用余白 */

/* スライド */
#slidecon .slider { 
  grid-area: 2 / 2 / 3 / 6;
}

#slidecon {
  padding:0 3vw 1vw 3vw;
  display: grid;
grid-template-columns: 2fr 9.5fr;
grid-template-rows: auto;
grid-column-gap: 100px;
}

@media screen and (max-width: 1110px) {
  #slidecon{
    display:initial;
  }
}

#slider > div {
  display: none;
}

.bx-viewport #slider > div {
  display: block;
}

.bx-viewport{
  height:35vw!important;
}

@media screen and (max-width: 1110px) {
  .bx-viewport{
  height:50vw!important;
}
}

.bx-wrapper {
  z-index: 0;
}

.bx-wrapper img {
  min-width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}

@media screen and (min-width: 1111px) {
.bx-wrapper img:hover{
  transform: scale(1.1);
}
}

.bx-wrapper .bx-viewport {
  box-shadow: none !important;
  border: 0 !important;
  left: 0 !important;
}

.slider div {
  width: 100%!important;
  border-radius: 60px;
}

@media screen and (max-width: 1110px) {
  .slider div {
  border-radius: 0;
}
}
/* スライド */

/* スライド上セリフ */
.serif{
  background-color:#333;
  position: absolute;
  color:#fff;
  font-size:2vw;
  z-index:5;
  clip-path: inset(0 100% 0 0);
    display: inline-block;
  padding:5px 15px;
}
.ue{
    margin-top: 18vw;
    margin-left: -150px;
  animation: textanimation 0.7s 0.7s  forwards;
}
  .first-load .ue{
  animation-delay:5.5s;
}
.shi{
      margin-top: 24vw;
    margin-left: -210px;
  animation: textanimation 1s 1s forwards;
}
  .first-load .shi{
  animation-delay:6.5s;
}

@media screen and (max-width: 1110px) {
  .serif{
    font-size:3vw;
  }
  
  .ue{
    margin-top: 5vw;
    margin-left: 3vw;
}
  
  .shi{
      margin-top: 13vw;
    margin-left: 3vw;
}
}

@keyframes textanimation {
    0% {
        clip-path: inset(0 100% 0 0);
    }

    100% {
        clip-path: inset(0);
    }
}
/* スライド上セリフ */

/* 社長・農園メッセージ */
#message{
  display: grid;
grid-template-columns: 1fr 2fr;
grid-template-rows: 30vw;
  padding-right: 2vw;
}

#message .shacho{ 
  grid-area: 1 / 1 / 2 / 2; 
}
#message .kotoba{
  grid-area: 1 / 2 / 2 / 3;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  margin:2vw auto 0 5vw;
  font-size:1.3vw;
   line-height: 2.5;
}
#message　.vertical {
  -webkit-text-combine: horizontal;
  -ms-text-combine-horizontal: all;
  text-combine-upright: all;
}
@media screen and (max-width: 1110px) {
  #message{
    grid-template-columns: auto;
  }
  #message .kotoba{
    margin: 2vw auto 0 1em;
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 767px) {
  #message{
    display: block;
    padding:0;
  }
  #message .kotoba{
    margin:auto;
        font-size: 2.7vw;
    line-height: 2.3;
  }
}
.shacho{
 margin-top:-75px;
}
.shacho img{
height: 37vw;
    position: relative;
}
@media screen and (max-width: 767px) {
  .shacho img{
height: 52vw;
}
}
/* 社長・農園メッセージ */

/* 日付・出荷カレンダー */
#tdsk{
  margin-top: 6vw;
    margin-left: 44vw;
  text-align:center;
  position:relative;
}
@media screen and (max-width: 767px) {
  #tdsk{
    margin-left: 49vw;
  }
}
.date_t{
  font-size: 55px;
    font-weight: bold;
  margin-top: 3px;
}
.week_t{
  font-size: 30px;
    font-weight: bold;
    margin-top: -15px;
}
.todayimg {
  width: 180px;
  display:flex;
  position: relative;
    z-index: 5;
  margin-bottom:-10px;
  margin-left:14px;
}
.maru_t{
  width:200px;
   height:200px;
   border-radius:50%;
   background:#ac1212;
  display:flex;
   align-items:center;
   justify-content:center;
  box-shadow: rgba(0, 0, 0, 0.3) 0px 5px 10px;
  transition: .3s;
  position: relative;
  flex-flow: column;
  color:#fff;
  border: 5px solid #fff;
}
@media screen and (max-width: 1110px) {
  .maru_t{
  width:15vw;
   height:15vw;
    border: 3px solid #fff;
}
  .todayimg {
  width: 13vw;
 margin-left: 1.3vw;
  }
  .date_t{
  font-size: 3.5vw;
  }
  .week_t{
  font-size: 2vw;
    margin-top: -5px;
  }
}
  @media screen and (max-width: 767px) {
    .maru_t{
  width:18vw;
   height:18vw;
      border: 2px solid #fff;
}
    .todayimg {
      width: 16vw;
    }
    .date_t{
  font-size: 4vw;
}
    .week_t{
      font-size: 3vw;
    }
}
#calendar{
  display: grid;
grid-template-columns: 1fr 2.5fr;
grid-template-rows: 1fr;
grid-row-gap: 0px;
}
#calendar .img{
  width: 41vw;
    position: relative;
  margin-left: -28vw!important;
    margin-top: -24vw;
}
#calendar .yasai{
    margin-left: -100px;
    width: 50vw;
  grid-area: 1 / 1 / 2 / 2;
}
#calendar .yasai img{
  width:100%;
  filter: drop-shadow(8px 17px 15px rgba(0,0,0,0.4));
}
#calendar .date{
  margin-top: -6vw;
    margin-left: -10vw;
  grid-area: 1 / 2 / 2 / 3;
  position:relative;
  width:120%;
}
@media screen and (max-width: 1110px) {
  #calendar .date{
  margin-top: -1.5vw;
  }
}
  @media screen and (max-width: 767px) {
    #calendar{
      grid-column-gap: 30px;
    }
    #calendar .yasai{
    margin-left: -25vw;
     position:absolute;
    }
    #calendar .date{
  margin-top: -2vw;
  }
}
/* 日付・出荷カレンダー */

/* お知らせ */
.p-line-informaiton {
  display: flex;
  flex-wrap: wrap;
  margin-top: 50px;
}
@media screen and (min-width: 1111px) {
  .p-line-informaiton {
 width: 800px;
  }
}
@media screen and (max-width: 767px) {
  .p-line-informaiton {
    display: block;
    width: 90%;
    margin: 4vw auto 0 auto;
  }
}
.p-line-informaiton ul {
  flex: 1;
  font-size: 19px;
  list-style:none;
}
@media screen and (max-width: 1110px) {
  .p-line-informaiton ul {
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 767px) {
  .p-line-informaiton ul {
    font-size: 2.3vw;
  }
}
.p-line-informaiton li {
  margin-bottom: 1vw;
}
@media screen and (max-width: 767px) {
  .p-line-informaiton li {
margin-left: 3vw;
  }
}
.p-line-informaiton__ttl {
  position: relative;
  margin: 0 40px 0 0;
  font-size: 20px;
  font-weight: bold;
}
@media screen and (max-width: 1100px) {
  .p-line-informaiton__ttl {
    font-size: 1.9vw;
  }
}
@media screen and (max-width: 767px) {
  .p-line-informaiton__ttl {
    margin: 0;
    font-size:2.5vw;
    background-color: #333;
        color: #fff;
        text-align: center;
        margin-bottom: 10px;
        padding: 5px 0;
        border-radius: 5px;
  }
}
.p-line-informaiton__ttl:before {
  content: "";
  position: absolute;
  top: 6px;
  right: -20px;
  width: 1px;
  height: 20px;
  background: #d2d2d2;
}
@media screen and (max-width: 767px) {
  .p-line-informaiton__ttl:before {
    content: none;
  }
}
/* お知らせ */

/* 見出し */
.midashi{
  display:flex;
  justify-content: space-between;
  margin-top:6vw;
  padding:10px 9vw;
  align-items: flex-end;
}
@media screen and (max-width: 767px) {
.midashi{
padding: 10px 9vw 10px 5vw!important;
  margin-top:20vw;
}
}
.midashi img{
  height:7vw;
}
.japa{
  font-size:2.5vw;
}
@media screen and (max-width: 767px) {
  .japa{
  font-size:4.5vw;
}
  .midashi img{
  height:9vw
}
}
@media screen and (min-width: 768px) {
.midashi{
  margin-right:1vw;
  }
}
/* 見出し */

/* 商品名・価格装飾 */
.dis{
  border-left:2px solid #777;
  padding:1vw 1em;
  margin-top:2vw;
}
/* 商品名・価格装飾 */

/* ランキング */
.ranknum{
    margin-top: 1vw;
}
.p-ranking-list .slick-track {
  margin-left: 0;
  margin-right: 0;
}
.p-ranking-list .slick-prev, .p-ranking-list .slick-next {
  top: 240px;
  width: 30px;
  height: 30px;
  transition: all 0.4s ease;
  z-index: 1;
  background: rgba(255,255,255,0.4);
}
@media screen and (max-width: 767px) {
  .p-ranking-list .slick-prev, .p-ranking-list .slick-next {
    top: 110px;
    width: 45px;
    height: 45px;
  }
}
.p-ranking-list .slick-prev:before, .p-ranking-list .slick-next:before {
  content: "";
  position: absolute;
  top: 7px;
  left: 10px;
  width: 15px;
  height: 15px;
  border-left: 1px solid #000000;
  border-top: 1px solid #000000;
  transition: all 0.4s ease;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-ranking-list .slick-prev:before, .p-ranking-list .slick-next:before {
    top: 15px;
  }
}

@media screen and (max-width: 767px) {
  .p-ranking-list .slick-prev {
    left: 0px;
  }
}
.p-ranking-list .slick-prev:before {
  transform: rotate(-45deg);
}
@media screen and (max-width: 767px) {
  .p-ranking-list .slick-prev:before {
    left: 17px;
  }
}

@media screen and (max-width: 767px) {
  .p-ranking-list .slick-next {
    right: 0px;
  }
}
.p-ranking-list .slick-next:before {
  left: 4px;
  transform: rotate(135deg);
}
@media screen and (max-width: 767px) {
  .p-ranking-list .slick-next:before {
    left: 13px;
  }
}
.p-ranking-list__item {
  position: relative;
  box-sizing: border-box;
  margin-right: 20px;
  margin-left: 20px;
  padding-bottom: 25px;
  word-break: break-all;
}
@media screen and (max-width: 1110px) {
  .p-ranking-list__item {
    margin-right: 5px;
    margin-left: 5px;
  }
}
.p-ranking-list__img {
  position: relative;
  text-align: center;
  border-radius: 7px;
    margin: 0 1em 1em 0;
}
@media screen and (max-width: 767px) {
  .p-ranking-list__img {
    text-align: center;
  }
}
.p-ranking-list__img:before {
  content: "";
  display: block;
  padding-top: 100%;
}
.p-ranking-list__img a {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-ranking-list__img img {
  display: inline-block !important;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
.p-ranking-list__num {
      position: absolute;
    top: 0;
    font-size: 3vw;
    font-weight: bold;
    color: #fff;
    z-index: 2;
    /*background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(10px);
    border-radius: 50%;*/
    height: 6vw;
    width: 50px;
    text-align:center;
  background-color:#333;
  margin-left:2vw;
	&:before{
		content: '';
		position: absolute;
		z-index: 2;
		left: 0;
		bottom: -24px;
		border-left: 25px solid #333;
    border-right: 25px solid #333;
    border-bottom: 25px solid transparent;
	}
}
.p-ranking-list__num span{
   font-size:27px;
    margin-left:5px;
}
@media screen and (max-width: 1110px) {
   .p-ranking-list__num {
  font-size: 3.5vw;
    height: 7vw;
}
}
@media screen and (max-width: 767px) {
  .p-ranking-list__num {
  font-size: 6vw;
        height: 11vw;
    width: 30px;
    &:before{
		bottom: -14px;
		border-left: 15px solid #333;
    border-right: 15px solid #333;
    border-bottom: 15px solid transparent;
	}
}
.p-ranking-list__num span{
   font-size:15px;
}
}
.p-ranking-list__ttl img {
  vertical-align: middle;
}
.p-ranking-list__price {
  color: #909090;
  margin-top: 20px;
  text-align:right;
}
.p-ranking-list__btn {
  display: block;
  position: absolute;
  right: 0px;
  bottom: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: #d8d8d8;
  cursor: pointer;
  text-align: center;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.p-ranking-list__btn.is-added {
  color: #000000;
}
.p-ranking-list__btn svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}
/* ランキング */

/* カテゴリー */
#category{
  z-index:1;
  position:relative;
  display: grid;
grid-template-columns: repeat(3, 1fr);
grid-template-rows: 2fr 0.1fr;
grid-column-gap: 50px;
  width:80%;
    margin:50px auto 75px;
}
@media screen and (max-width: 1110px) {
  #category{
    grid-column-gap: 1em;
    width:90%;
  }
}
@media screen and (max-width: 767px) {
  #category{
    display:initial;
    width:50%
  }
}
.ct1 { grid-area: 1 / 1 / 2 / 2; }
.ct2 { grid-area: 2 / 1 / 3 / 2; }
.ct3 { grid-area: 1 / 2 / 2 / 3; }
.ct4 { grid-area: 2 / 2 / 3 / 3; }
.ct5 { grid-area: 1 / 3 / 2 / 4; }
.ct6 { grid-area: 2 / 3 / 3 / 4; }

.ct2,.ct4,.ct6{
  font-size:2.1vw;
  padding: 5px 1vw 2vw;
}
.ct2 span, .ct4 span,.ct6 span{
  font-size:1.3vw;
}
@media screen and (max-width: 767px) {
  .ct2,.ct4,.ct6{
  font-size:3.5vw;
}
.ct2 span, .ct4 span,.ct6 span{
  font-size:2.4vw;
}
}
.cthv {
  text-decoration: none; 
  background-image: linear-gradient(90deg, #333, #333); 
  background-repeat: no-repeat;
  background-position: left bottom; 
  background-size: 150px 1px; 
  transition: background-size 0.4s; 
}
@media screen and (max-width: 767px) {
  .cthv{
    width: 70%;
    margin: 5vw auto;
  }
}
@media screen and (min-width: 1111px) {
.cthv:hover {
  background-size: 100% 1px;
}
}
/* カテゴリー */

/* SPカテゴリ背景 */
.backcolor{
  background-color: #efe6d1;
}
/* SPカテゴリ背景 */

/* 姉妹店紹介 */
#shimai{
  margin-top:20vw;
}
.shimap{
  font-size:2.5vw;
  padding-bottom: 7px;
  border-bottom: 1px solid #777;
    width: 70%;
    margin: auto;
    text-align: center;
}
@media screen and (max-width: 767px) {
  .shimap{
  font-size:3vw;
  }
}
#os{
  width:65%;
  margin:auto;
}
#os .slider div{
  scrollbar-width: none; 
}
#os .scroll-hint-icon {
  top:initial;
  bottom: 1.5vw;
}
@media screen and (min-width: 768px) {
  #os .shopp{
    padding: 20px 0;
  }
  #os .shopp ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }

  #os .shopp li {
    list-style: none;
    width:24%;
  }

  #os .shopp li:nth-child(2) {
    margin: 0 10px;
  }
}
@media screen and (max-width: 1110px) {
  #os{
  width:95%;
}
}
@media screen and (max-width: 767px) {
#os .slider  ul {
  width: 100%;
  height: 32vw;
  overflow-x: scroll;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  columns: 1;
  text-align: center;
  -ms-overflow-style: none;
}
#os .slider  ul::-webkit-scrollbar{
  display: none;
}
#os .slider li {
  list-style-type: none;
  display: inline-block;
  width: calc(100% / 3.5);
}

#os .slider ul::column {
  scroll-snap-align: center;
}
#os .slider ul::scroll-button(*) {
  border: 0;
  font-size: 4.5vw;
  background: none;
  color: rgb(51 0 0 / 0.7);
  cursor: pointer;
}

#os .slider ul::scroll-button(*):hover,
#os .slider ul::scroll-button(*):focus {
  color: rgb(51 0 0 / 1);
}

#os .slider ul::scroll-button(*):active {
  translate: 1px 1px;
}

#os .slider ul::scroll-button(*):disabled {
  color: rgb(51 0 0 / 0.2);
  cursor: unset;
}

#os .slider ul::scroll-button(left) {
  content: "\025c0";
}

#os .slider ul::scroll-button(right) {
  content: "\025b6";
}

#os .slider ul {
  anchor-name: --myCarousel;
}

#os .slider ul::scroll-button(*) {
  position: absolute;
  position-anchor: --myCarousel;
}

#os .slider ul::scroll-button(left) {
  right: calc(anchor(left) - 6vw);
        bottom: calc(anchor(bottom) - -3vw);
}

#os .slider ul::scroll-button(right) {
          left: calc(anchor(right) - 6vw);
        bottom: calc(anchor(bottom) - -3vw);
}

#os .slider ul {
  scroll-marker-group: after;
  }}
#os .item{
  padding:20px 0;
}
@media screen and (min-width: 600px){
#os .hov {
  cursor: pointer;
  max-width: 500px;
  width: 100%;
}
#os .hov img {
  height: auto;
  transition: transform .6s ease;/* ゆっくり変化させる */
  width: 100%;
}
#os .hov:hover img {
  transform: scale(1.1);/* 拡大 */
}
}

/* 姉妹店紹介 */