@charset "utf-8";
/* -------------------t-fv__slide-------------------- */
.t-fv{
  overflow-x: hidden;
}
/* .t-fv__slide */
.t-fv__slide{
  margin-inline: auto;
}
.t-fv__slide .slick-list{
  overflow: visible;
}
.t-fv__slide .slick-slide{
  margin-inline: var(--slick-gap);
}
.t-fv__item{
  position: relative;
  background: no-repeat center center / cover;
}
.t-fv__item__img img{
  object-fit: cover;
}
.t-fv__item__link{
  position: absolute;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  left: 0;
  z-index: 3;
}
.t-fv__item__link::after{
  content: "";
  display: inline-block;
  --this-mask: var(--data-icon-slide-link) no-repeat center center / 100%;
  mask: var(--this-mask);
  -webkit-mask: var(--this-mask);
  aspect-ratio: 1;
  position: absolute;
}
.t-fv__item__link--white::after{
  background-color: var(--c-white);
}
.t-fv__item__link--black::after{
  background-color: var(--txt-c-base);
}
@media (hover: hover){
  .t-fv__item__link::after{
    transition: .3s;
  }
  .t-fv__item__link:hover::after{
    right: 5px;
  }
}
@media screen and (min-width: 768px){
  .t-fv__slide{
    width: var(--inner-width);
    max-width: calc( var(--pc-maw-sm) + var(--slick-gap) * 2 );
  }
  .t-fv__slide.slick-dotted.slick-slider{
    margin-bottom: var(--spc-50);
  }
  .t-fv__slide{
    --slick-gap: var(--spc-25);
  }
  .t-fv__item__img img,
  .t-fv__item__container{
    aspect-ratio: 2/1;
  }
  .t-fv__item__link::after{
    width: 45px;
    bottom: 26px;
    right: 30px;
  }
  [class*="t-fv__slide__arrow"]{
    top: 40%;
  }
}
@media screen and (max-width: 767px){
  .t-fv__slide{
    width: 80%;
  }
  .t-fv__slide.slick-dotted.slick-slider{
    margin-bottom: 35px;
  }
  .t-fv__slide{
    --slick-gap: 10px;
  }
  .t-fv__item__img img,
  .t-fv__item__container{
    aspect-ratio: 10/15;
  }
  [class*="t-fv__slide__arrow"]{
    top: 40%;
  }
  .t-fv__item__link::after{
    width: 20px;
    bottom: 5px;
    right: 15px;
  }
}
/* t-fv__renewal */
.t-fv__renewal{
  position: relative;
}
.t-fv__renewal__ttl{
  width: 100%;
  text-align: center;
  font-family: var(--ff-caveat);
  color: var(--c-white);
  position: absolute;
  left: 0;
  text-shadow: -2px 1px 13px rgba(0, 0, 0, 0.4);
}
@media screen and (min-width: 768px){
  .t-fv__renewal__ttl{
    font-size: var(--fz-50);
    top: 35%;
  }
}
@media screen and (max-width: 767px){
  .t-fv__renewal__ttl{
    font-size: 25px;
    top: 38%;
  }
}
/* t-fv__blog */
.t-fv__blog__ttl{
  font-weight: 500;
  color: var(--c-white);
  position: absolute;
}
@media screen and (min-width: 768px){
  .t-fv__blog__ttl{
    font-size: var(--fz-45);
    right: 20%;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media screen and (max-width: 767px){
  .t-fv__blog__ttl{
    font-size: 30px;
    top: 40%;
    left: 50%;
    transform: translateX(-50%);
  }
}
/* t-fv__cheeseOfTheMonth */
.t-fv__cheeseOfTheMonth__body{
  position: absolute;
  height: 100%;
}
.t-fv__cheeseOfTheMonth__ttl{
  display: flex;
  flex-direction: column;
  color: var(--c-white);
}
.t-fv__cheeseOfTheMonth__ttl::before{
  content: "";
  display: inline-block;
  background: var(--this-icon) no-repeat center center / 100%;
  aspect-ratio: 1;
  margin-left: auto;
}
.t-fv__cheeseOfTheMonth__ttl small{
  display: block;
  border-bottom: 2px solid var(--c-white);
}
@media screen and (min-width: 768px){
  .t-fv__cheeseOfTheMonth__body{
    width: 50%;
    top: 0;
    right: 0;
    background-image: linear-gradient(90deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.3));
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .t-fv__cheeseOfTheMonth__ttl::before{
    width: 85px;
  }
  .t-fv__cheeseOfTheMonth__ttl small{
    font-size: var(--fz-25);
    padding: var(--spc-10);
  }
  .t-fv__cheeseOfTheMonth__ttl span{
    font-size: var(--fz-45);
  }
}
@media screen and (max-width: 767px){
  .t-fv__cheeseOfTheMonth__body{
    width: 100%;
    bottom: 0;
    left: 0;
    background-image: linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.5));
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .t-fv__cheeseOfTheMonth__ttl{
    align-items: center;
    text-align: center;
  }
  .t-fv__cheeseOfTheMonth__ttl::before{
    width: 50px;
    margin-inline: auto;
  }
  .t-fv__cheeseOfTheMonth__ttl small{
    font-size: 14px;
    padding: 5px;
  }
  .t-fv__cheeseOfTheMonth__ttl span{
    font-size: 25px;
  }
}
/* t-fv__aboutRealStore */
.t-fv__item__container{
  display: grid;
  align-items: center;
}
.t-fv__aboutRealStore__img{
  display: grid;
  grid-template-columns: repeat(2,1fr);
}
.t-fv__aboutRealStore__body{
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.t-fv__aboutRealStore__ttl{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.t-fv__aboutRealStore__ttl small{
  display: block;
  border-bottom: 2px solid var(--txt-c-base);
}
@media screen and (min-width: 768px){
  .t-fv__item__container{
    padding-inline: var(--spc-50);
    grid-template-columns: 40fr 47fr;
  }
  .t-fv__aboutRealStore__img{
    gap: var(--spc-15)
  }
  .t-fv__aboutRealStore__logo{
    width: 175px;
    margin: 0 auto var(--spc-50);
  }
  .t-fv__aboutRealStore__ttl small{
    padding-bottom: 5px;
    font-size: var(--fz-25);
    margin-bottom: 5px;
    letter-spacing: 0.1em;
  }
  .t-fv__aboutRealStore__ttl span{
    font-size: var(--fz-35);
  }
}
@media screen and (max-width: 767px){
  .t-fv__item__container{
    padding-inline: 25px;
    gap: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .t-fv__aboutRealStore__img{
    gap: 10px;
  }
  .t-fv__aboutRealStore__logo{
    width: 80px;
    margin: 0 auto 10px;
  }
  .t-fv__aboutRealStore__ttl small{
    padding-bottom: 3px;
    font-size: 14px;
    margin-bottom: 3px;
    letter-spacing: 0.1em;
  }
  .t-fv__aboutRealStore__ttl span{
    font-size: 20px;
    text-align: center;
  }
}
/* t-fv__cheeseSet__body */
.t-fv__cheeseSet__body{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.t-fv__cheeseSet__name{
  text-align: center;
}
.t-fv__cheeseSet__name span{
  color: var(--theme-c-main);
  display: block;
  text-align: center;
}
@media screen and (min-width: 768px){
  .t-fv__cheeseSet__name{
    font-size: var(--fz-25);
    line-height: 1.8;
  }
  .t-fv__cheeseSet__price{
    font-size: var(--fz-30);
  }
  .t-fv__cheeseSet__price small{
    font-size: var(--fz-20);
  }
  .t-fv__cheeseSet__price span{
    font-size: var(--fz-14);
  }
}
@media screen and (max-width: 767px){
  .t-fv__cheeseSet__name{
    font-size: 14px;
    line-height: 1.6;
  }
  .t-fv__cheeseSet__price{
    font-size: 20px;
  }
  .t-fv__cheeseSet__price small{
    font-size: 14px;
  }
  .t-fv__cheeseSet__price span{
    font-size: 12px;
  }
}
/* t-fv__news */
.t-fv__news{
  background-color: var(--c-white);
}
.t-fv__news__heading::before{
  content: "";
  display: inline-block;
  background: var(--this-icon) no-repeat center center / 100%;
  aspect-ratio: 1;
}
.t-fv__news__heading p{
  font-family: var(--ff-en);
}
.t-fv__news__container{
  overflow-y: auto;
}
.t-fv__news__list{
  display: grid;
}
.t-fv__news__date{
  font-family: var(--ff-en);
  color: var(--theme-c-main);
}
.t-fv__news__ttl{
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  font-weight: 400;
}
@media screen and (min-width: 768px){
  .t-fv__news{
    display: grid;
    padding: var(--spc-35) var(--spc-50);
    align-items: center;
    padding-left: 0;
    grid-template-columns: auto 1fr;
  }
  .t-fv__news__heading{
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-inline: var(--spc-60);
  }
  .t-fv__news__heading::before{
    width: 50px;
  }
  .t-fv__news__heading p{
    font-size: var(--fz-40);
    line-height: 1.6;
  }
  .t-fv__news__heading h2{
    font-size: var(--fz-16);
  }
  .t-fv__news__container{
    max-height: 170px;
  }
  .t-fv__news__list{
    gap: var(--spc-30);
  }
  .t-fv__news__date{
    font-size: var(--fz-12);
  }
  .t-fv__news__ttl{
    font-size: var(--fz-14);
    margin-top: 5px;
  }
}
@media screen and (max-width: 767px){
  .t-fv__news{
    padding: 30px 20px;
    max-height: 300px;
    overflow-y: scroll;
  }
  .t-fv__news__heading{
    margin-bottom: 20px;
    width: fit-content;
    margin-inline: auto;
    position: relative;
  }
  .t-fv__news__heading::before{
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(-130%, -50%);
    width: 35px;
  }
  .t-fv__news__heading p{
    font-size: 25px;
    line-height: 1.4;
  }
  .t-fv__news__heading h2{
    font-size: 12px;
  }

  .t-fv__news__list{
    gap: 20px;
  }
  .t-fv__news__date{
    font-size: 12px;
  }
  .t-fv__news__ttl{
    font-size: 12px;
    margin-top: 3px;
  }
}
/* -------------------t-blog-------------------- */
/* t-blog */
.t-blog{
  background: var(--bg-c-beige) var(--this-bg) no-repeat bottom center / 100%;
}
.t-blog__list{
  --grid-cols-pc: 3;
  --grid-gap-pc: var(--spc-20);
  --grid-cols-sp: 1;
  --grid-gap-sp: 15px;
}
.t-blog__item__thumb img{
  aspect-ratio: 1/1;
  object-fit: cover;
}
.t-blog__item__date{
  display: block;
  font-family: var(--ff-en);
  font-weight: 100;
}
.t-blog__item__excerpt{
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  font-weight: 400;
}
@media (hover: hover){
  .t-blog__item a:hover,
  .t-blog__item a:hover img{
    opacity: 1 !important;
  }
  .t-blog__item__thumb{
    overflow: hidden;
  }
  .t-blog__item a:hover .t-blog__item__thumb img{
    transform: scale(1.1);
  }
  .t-blog__item__thumb img{
    transition: .3s;
  }
}
@media screen and (min-width: 768px){
  .t-blog__item__date{
    margin-block: 10px 5px;
  }
  .t-blog__item__ttl{
    font-size: var(--fz-20);
  }
  .t-blog__item__excerpt{
    font-size: var(--fz-14);
    margin-top: var(--spc-10);
  }
}
@media screen and (max-width: 767px){
  .t-blog__item a{
    display: grid;
    grid-template: auto 1fr / repeat(2,1fr);
    gap: 2px 15px;
  }
  .t-blog__item__thumb{
    grid-row: span 2;
  }
  .t-blog__item__date{
    font-size: 12px;
  }
  .t-blog__item__ttl{
    font-size: 16px;
  }
  .t-blog__item__excerpt{
    display: none;
  }
}
/* -------------------t-about-------------------- */
.t-about__photo{
  --grid-cols-pc: 2;
  --grid-cols-sp: 2;
}
.t-about__intro{
  font-weight: 400;
}
.t-about__shopInfo__businessDay{
  border-bottom: 1px solid var(--c-white);
}
.t-about__shopInfo__businessDay dt{
  font-family: var(--ff-en);
  color: var(--theme-c-main);
}
.t-about__shopInfo__access dt{
  font-family: var(--ff-en);
  color: var(--theme-c-main);
}
.t-about__shopInfo__map iframe{
  width: 100%;
}
@media screen and (min-width: 768px){
  .t-about__body{
    margin-block: var(--spc-30);
    position: relative;
  }
  .t-about__intro{
    line-height: 2;
  }
  .t-about__sns{
    position: absolute;
    bottom: 0;
    right: 0;
  }
  .t-about__sns{
    gap: var(--spc-30);
  }
  .t-about__sns li a{
    width: 28px;
  }
  .t-about__shopInfo{
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: var(--spc-35);
  }
  .t-about__shopInfo__detail{
    padding: var(--spc-25);
  }
  .t-about__shopInfo__businessDay{
    padding-bottom: var(--spc-30);
    margin-bottom: var(--spc-30);
  }
  .t-about__shopInfo__businessDay dt{
    font-size: var(--fz-20);
    margin-bottom: var(--spc-10);
  }
  .t-about__shopInfo__businessDay dd{
    font-size: var(--fz-16);
  }
  .t-about__shopInfo__access dt{
    font-size: var(--fz-20);
    margin-bottom: var(--spc-10);
  }
  .t-about__shopInfo__access dd{
    font-size: var(--fz-14);
  }
  .t-about__shopInfo__map iframe{
    height: 100%;
  }
}
@media screen and (max-width: 767px){
  .t-about__body{
    margin-block: 20px;
  }
  .t-about__intro{
    font-size: 14px;
    line-height: 2;
  }
  .t-about__sns{
    justify-content: center;
    gap: 20px;
    margin-top: 15px;
  }
  .t-about__sns li a{
    width: 24px;
  }
  .t-about__shopInfo{
    margin-top: 25px;
  }
  .t-about__shopInfo__detail{
    margin-bottom: 20px;
    padding: 20px;
  }
  .t-about__shopInfo__businessDay{
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
  .t-about__shopInfo__businessDay dt{
    font-size: 16px;
    margin-bottom: 8px;
  }
  .t-about__shopInfo__businessDay dd{
    font-size: 14px;
  }
  .t-about__shopInfo__access dt{
    font-size: 16px;
    margin-bottom: 8px;
  }
  .t-about__shopInfo__access dd{
    font-size: 12px;
  }
  .t-about__shopInfo__map iframe{
    height: 200px;
  }
}
/* -------------------カレンダー-------------------- */
.tbl_calendar {
  border: none !important;
  border-collapse: collapse !important;
  border-spacing: 0 !important;
}
.tbl_calendar th, .tbl_calendar td {
  padding: 4px !important;
  text-align: center !important;
  border-bottom: 1px solid #ccc !important;
  font-weight: 400;
  font-size: 12px;
}
.side_cal{
  display: grid;
  font-weight: 400;
  align-items: flex-start;
  gap: var(--spc-30);
}
.side_holiday{
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 5px;
  font-weight: 500;
}
.side_holiday span{
  display: inline-block;
  aspect-ratio: 1/1;
  background-color: #DB5656;
  width: 12px;
}
.side_cal_memo{
  font-weight: 500;
}
@media screen and (min-width: 768px){
  .side_cal{
    grid-template-columns: repeat(2,1fr);
  }
  .side_holiday{
    font-size: var(--fz-14);
    margin-top: var(--spc-10);
  }
  .side_cal_memo{
    margin-top: var(--spc-15);
    font-size: var(--fz-14);
  }
}
@media screen and (max-width: 767px){
  .side_holiday{
    font-size: 12px;
    margin-top: 10px;
  }
  .side_cal_memo{
    margin-top: 10px;
    font-size: 12px;
  }
}

/* -------------------インスタ-------------------- */
@media screen and (min-width: 768px){
  .gallery__container {
    overflow: hidden;
    animation-duration: 90s;
  }
  .gallery__wrapper {
    display: flex;
    width: max-content;
    z-index: 1;
    animation: scroll 90s linear infinite;
  }
  .gallery__wrapper:hover {
    animation-play-state: paused;
  }
  .gallery__list {
    display: flex;
    margin: 0;
    list-style: none;
  }
  .gallery__list li{
    min-width: var(--this-width);
    max-width: var(--this-width);
    --this-width: clamp(150px, 20vw, 250px);
    margin-inline: var(--spc-10);
  }
  @keyframes scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
  }
}
@media screen and (max-width: 767px){
  .gallery__list{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 10px;
  }
}
