/** Shopify CDN: Minification failed

Line 145:52 "font-wegiht" is not a known CSS property
Line 161:83 Expected ":"
Line 256:108 "font-wegiht" is not a known CSS property
Line 314:100 "marign-bottom" is not a known CSS property
Line 356:119 "font-wegiht" is not a known CSS property
Line 388:101 "font-wegiht" is not a known CSS property
Line 525:8 Expected identifier but found whitespace
Line 525:9 Unexpected "calc("

**/
@charset "utf-8";

body { font-family: 'Noto Sans JP', sans-serif; font-weight: 400;font-size: 1.6rem; }
a { text-decoration: none; color: inherit; }
ul,
ol { list-style: none; padding: 0;  }
img { vertical-align: bottom; }

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

.sp { display: none; }
@media screen and (max-width: 900px) {
  .sp { display: inline; }
}

.page-bottom-margin { margin-bottom: 120px; }
.contents-width { width: 1000px; max-width: 90%; margin: 0 auto; }
.contents-width-l { width: 1200px; max-width: 90%; margin: 0 auto; }
.contents-width-wide { width: calc(100% - 160px); margin: 0 auto; }
.conts-section { padding-top: 80px; }

@media screen and (max-width: 900px) {
  .contents-width-wide { width: 90%;}
}

.header-logo { font-size: 2rem; width: 8em; font-family: 'Figtree', sans-serif; white-space: nowrap;  }
.header-logo img { display: block; }
.header-menu { display: flex; font-size: 1.4rem;  }
.header-menu > li + li { margin-left: 2em; }

.btn-hamburger { display: none; }

@media screen and (max-width: 1400px) {
   .header-menu { font-size: 1.3rem; }
}
@media screen and (max-width: 1200px) {
  .header-menu  { position: fixed; top: 0; right: 0; width: 300px; height: 100%; margin: auto; transform: translateX(120%);display: block; background: #FFF; padding-top: 50px; 
  box-shadow: 0 0 5px 0 rgba(0,0,0, .16); font-size: 1.6rem; }
  .header-menu > li + li { margin: 0; }
  .header-menu > li > a { display: block; padding: 1em; border-bottom: 1px solid #CCC; disaplay: block; }

  .header-logo { font-size: 1.5rem;  }

  .btn-hamburger { display: block; background: none; margin-left: 10px; border: none; width: 4rem; height: 4rem; position: relative; 
  white-space: nowrap; overflow: hidden; text-indent: 200%;  }
  .btn-hamburger::before,
  .btn-hamburger::after { content: ''; width: 2rem; display: block; height: 2px; background: #000; position: absolute; inset: 0; margin: auto; transition: transform  .3s;  }

  .btn-hamburger::before { transform: translateY(-6px); box-shadow: 0 6px 0 #000; }
  .btn-hamburger::after{ transform: translateY(6px); }

  .btn-hamburger.open::before { transform:rotate(45deg); box-shadow: none; }
  .btn-hamburger.open::after{ transform: rotate(-45deg); }

  .header.open .header-menu { transform: translateX(0);  transition: transform .3s; }
}


.mt1em { margin-top: 1em; }
.mt2em { margin-top: 2em; }

.btn-round { background: #C6577D; color: #FFF; text-align: center; border-radius: 2em; width: 170px; padding: .7em 0; font-family: 'Figtree', sans-serif; display: block; margin: 0 auto; }

.footer { overflow: hidden; }
.footer .inner { border-top: 1px solid #E6E6E6; width: calc(100% - 160px); margin: 0 auto; padding: 80px 0 13vw; position: relative; }
.footer .inner::before { content: 'CANPAI VINO'; font-family: 'Figtree', sans-serif; font-weight: 600; color: #FBEDEB; font-size: 13.7vw; position: absolute; left: 0; right: 0; bottom: -.1em; margin: auto; line-height: .7; white-space: nowrap; text-align: center; }
.foot-menu { display: flex; margin: 0; font-size: 1.4rem; }
.foot-menu > li:not(:last-child) { margin-right: 2em; margin-bottom: .5em;}

.foot-menu-sub { display: flex; margin: 0; font-size: 1.4rem; margin-top: 1em; }
.foot-menu-sub > li:not(:last-child) { margin-right: 2em; margin-bottom: .5em;}

.foot-bottom { display: flex; justify-content: space-between; margin-top: 60px; align-items: flex-end; }
.foot-copy .en { display: block; font-size: 1.4rem; color: #C6577D; font-family: 'Figtree', sans-serif; font-weight: 600;  }
.foot-copy .ja { font-weight: bold; font-size: 1.7rem; }
.copyright{ font-size: 1.2rem; color: #838383; }

.foot-instagram { padding: 10px; margin-top: 10px; display: block; }

@media screen and (max-width: 900px) {
  .footer .inner{ width: 90%; padding: 50px 0 13vw; text-align: center; }
  .foot-menu { flex-wrap: wrap; display: block; font-size: 1.6rem; justify-content: center;  }
  .foot-menu > li:nth-child(n) { margin: 0 0 1em; }
  .foot-menu-sub { display: block; font-size: 1.6rem; }
  .foot-menu-sub > li:not(:last-child) { margin: 0 0 1em;}
}

@media screen and (max-width: 600px) {
  .foot-bottom { display: block; }
  .copyright{ display: block; text-align: right; font-size: 1.1rem; }
}

.page-title { padding: 60px 0; background: #FCFCFC; text-align: center; position: relative; overflow: hidden; }
.page-title > * { position: relative; z-index: 2; margin: 0; }
.page-title .en { font-size: 3.2rem; font-weight: bold; font-family: 'Figtree', sans-serif; display: block; font-weight: 600; line-height: 1.5; position: relative; z-index: 2; }
.page-title .ja { font-size: 2rem; line-height: 1.5; position: relative; z-index: 2; }

.page-title .ja-main { font-size: 3.2rem; display: block; }
.page-title .en-s { font-size: 2rem; display: block; font-family: 'Figtree', sans-serif; }

@media screen and (max-width: 900px) {
  .page-title { padding: 40px 0; }
  .page-title .en { font-size: 2.4rem;}
  .page-title .ja { font-size: 1.6rem; }
  .page-title .ja-main { font-size: 2rem; }
  .page-title .en-s { font-size: 1.4rem; }
}

.marquee { white-space: nowrap; width: 100%; font-size: 16rem; font-family: 'Figtree', sans-serif;  font-weight: bold; line-height: .7; mix-blend-mode: multiply;}
.marquee .yellow { color: #F8F4EB; }
.marquee .pink { color: #FBEDEB; }

.marquee-content { display: inline-block; white-space: nowrap; }

.marquee .track { display: inline-flex; animation: marquee 60s linear infinite; }

.marquee-wrap { overflow: hidden; }
.page-title .marquee { position: absolute; bottom: -.1em; left: 0;margin: auto; opacity: .5; transform: translateX(-35%); }

/*
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}*/

@media screen and (max-width: 768px) {
  .marquee { font-size: 15vw; }
  .page-title .marquee { font-size: 15vw; }
}

.title-std { margin: 0 0 1em; }
.title-std .en { font-family: 'Figtree', sans-serif; disaplay: block; font-size: 3rem; font-weight: 600; }
.title-std .ja { font-size: 1.6rem; display: block; font-wegiht: 500;  }

@media screen and (max-width: 900px) {
  .title-std .en  { font-size: 2.4rem; }
  .title-std .ja { font-size: 1.3rem;}
}

.breadcrumb { display: flex; flex-wrap: wrap; font-size: 1.4rem; margin: 1em 0 100px; list-style: none; }
.breadcrumb > li + li::before { content: '>'; margin: 0 .5em; }

@media screen and (max-width: 900px) {
  .breadcrumb { margin-bottom: 50px; font-size: 1.3rem; }
}


.loop-slider { overflow: hidden;  width: 100%; display: flex; align-items: center; margin-bottom: 2rem; }
.loop-track { display: flex; gap: 0; animation: loop-scroll 20s linear infinite;　}
.loop-track img { width: 115vw; height: 15vw; object-fit: cover; flex-shrink: 0; }

/* アニメーション（シームレスに左へ流す） */
@keyframes loop-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.mainvisual { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0; overflow: hidden;  height: 100vh;}
.mainvisual img { width: 100%; height: 100%; object-fit: cover; }
.mainvisual .title { color: #FFF; position: absolute; left: 0; right: 0; bottom: -.1em; line-height: .7; margin: auto; font-family: 'Figtree', sans-serif; font-size: 14vw; text-align: center; font-weight: 600; }
.mainvisual .text { display: none; }

@media screen and (max-width: 768px) {
  .mainvisual { grid-template-columns: 1fr; }
  .mainvisual > div { height: 33.33vh; }
  .mainvisual .title { position: absolute; bottom: auto; right: .8em; margin: auto; left: auto;top: 50%; transform-origin: right center; transform: rotate(90deg) translateX(50%); display: block; 
    width: fit-content; white-space: nowrap; font-size: 20vw; line-height: 1; height: 1em;}
  .mainvisual .text { display: block; writing-mode: vertical-rl; white-space: nowrap; position: absolute; left: .7em; top: 20vh; font-size: 7vw; line-height: 1;  }
}

.home-product-swiper .product-card { border: 1px solid #CCC; border-radius: 10px; padding: 40px 20px; box-sizing: border-box; position: relative; height: auto; }
.home-product-swiper .product-card__badge { position: absolute; top: 10px; right: 16px; margin: auto; font-size: 1.2rem; padding: .5rem 1.3rem .6rem;
border-radius: .2rem; line-height: 1; background: #FFF; border: 1px solid #CCC; }
.home-product-swiper .product-card__badge--soldout { background: #000; color: #FFF; }
.home-product-swiper .product-card__image-wrapper { width: 100%; aspect-ratio: 1 /1; }
.home-product-swiper .product-card__image-wrapper img { width: 100%; height: 100%; object-fit: contain; }
.home-product-swiper .product-card__price { font-family: 'Figtree', sans-serif; font-size: 1.4rem; margin-top: 1em;}

.home-product-swiper .product-card__title { margin: 0; font-family: 'Figtree', sans-serif; font-weight: 600; font-size: 2rem; }
.home-product-swiper .product-card__button { color: #FFF;  background: #C6577D; border-radius: 2em; text-align: center; 
width: 90%; border: none; padding: 1em; margin: .5em auto 0;}
.home-product-swiper .product-card__button[disabled] { opacity: .6; }
.home-product-swiper .product-card__price--compare { text-decoration: line-through; }


.home-msg { text-align: center; margin: 140px 0 80px; }
.home-msg .title { font-size: 7.5rem; font-weight: bold; margin: 0; }
.home-msg .en { font-size: 2.8rem; color: #C6577D; font-family: 'Figtree', sans-serif; font-weight: 600; margin: 0; }

@media screen and (max-width: 1000px) {
  .home-msg .title { font-size: 5rem; }
}
@media screen and (max-width: 768px) {
  .home-msg .title { font-size: 3rem; }
  .home-msg .en { font-size: 2rem; }
}
.home-pages { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0; margin-top: 60px; }
.home-pages .thumbnail { height: 620px; display: flex; color: #FFF; align-items: center; justify-content: center; position: relative;  }
.home-pages .thumbnail.wine { background: url(/cdn/shop/files/home-wine.jpg) no-repeat center center / cover; }
.home-pages .thumbnail.brand { background: url(/cdn/shop/files/home-brand.jpg) no-repeat center center / cover; }
.home-pages .thumbnail .title { color: #FFF; text-align: center; margin: 0;  }
.home-pages .thumbnail .title .en { display: block; font-size: 2.5rem; font-family: 'Figtree', sans-serif; }
.home-pages .thumbnail .title .ja { display: block; font-size: 1.5rem; margin-bottom: 1em;}
.home-pages .thumbnail .more { position: absolute; left: 0; right: 0; bottom: 55px; margin: auto; font-family: 'Figtree', sans-serif; width: fit-content; border-bottom: 1px solid; display: block; }
.home-pages .desc { padding: 40px 0; width: 80%; margin: 0 auto; font-size: 1.4rem; }
.home-pages .desc .copy { font-size: 2rem; margin: 0 0  .5em; font-weight: 500; }

@media screen and (max-width: 900px) {
.home-pages { grid-template-columns: 1fr; }
.home-pages .thumbnail { padding: 80px 0 100px; height: auto;  }
.home-pages .thumbnail .more { bottom: 40px; }
.home-pages .desc { width: 85%; }
.home-pages .desc .copy { font-size: 1.8rem; }
}
.home-info__item { display: grid; grid-template-columns: 110px minmax(0, 1fr); border-bottom: 1px solid #E6E6E6; align-items: center; padding: 1em 2em 1em 0; background: url(/cdn/shop/files/right-arrow.svg?v=1760528291) no-repeat right center / 1.5em auto; }
.home-info__date { font-family: 'Figtree', sans-serif; color: #C31D55; font-weight: 500;  }

@media screen and (max-width: 900px) {
.home-info__item { grid-template-columns: 1fr; font-size: 1.5rem; }
.home-info__heading { font-size: 1.5rem; }
.home-info__date  { font-size: 1.4rem; margin-bottom: 0; }
}

.home-blog-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2rem; }
.home-blog-head .title-std { margin-bottom: 0; }

.btn-view-more { border-bottom: 1px solid; font-family: 'Figtree', sans-serif; font-weight: 600; letter-spacing: 0; }
.btn-view-more.-inline { width: fit-content; }

.home-blog__thumb { width: 100%; aspect-ratio: 3 / 2; background: #DDD; display: block; margin-bottom: 1rem; }
.home-blog__thumb img { width: 100%; height: 100%; object-fit: cover; }

.home-blog__date { font-size: 1.6rem; font-weight: 600; color: #C31D55; font-family: 'Figtree', sans-serif; margin: 0;}
.home-blog__heading { font-size: 1.5rem; margin: 0; }


.flash-sale-block { background: url(/cdn/shop/files/bg-sale.jpg?v=1760947275) no-repeat center center / cover; padding: 100px 0; font-family: 'Figtree', sans-serif; }
.flash-sale-block .inner { background: rgba(198, 87, 125, .9); width: 90%; max-width: 485px; margin: 0 auto; text-align: center; padding: 50px 5%; color: #FFF; }
.flash-sale-block .inner .title { font-size: 4.6rem ;font-weight: 600; font-family: 'Figtree', sans-serif; color: #FFF; margin: 0; }
.flash-sale-countdown { display: flex; align-items: center; justify-content: space-between;font-size: 1rem; font-wegiht: bold; font-size: 3rem; margin-bottom: .5em;   }
.flash-sale-countdown .num { width: 6rem; height: 6rem; font-size: 3rem; position: relative;  }
.flash-sale-countdown .num .square { background: #FFF; display: block; border-radius: 10px; text-align: center; padding: 0; font-weight: bold; color: #000;   }
.flash-sale-countdown .num .unit { font-size: 1.2rem; line-height: 1; disaplay: block; position: absolute; left: 0; right: 0; top: calc(100% + .5em); margin: auto;  }
.flash-sale-link { background: #FFF; margin:3em auto 0; border-radius: 2em; display: block; width: fit-content; padding: 1em 3em; color: #000; 
font-size: 1.3rem; font-family: 'Figtree', sans-serif; }


.column-conts { display: flex; justify-content: space-between; }
.column-conts .main-column { width: 70%; }
.column-conts .side-column { width: 25%; }

@media screen and (max-width: 900px) {
.column-conts { flex-wrap: wrap; }
.column-conts .main-column { width: 100%; }
.column-conts .side-column { width: 100%; margin-top: 5rem; }
}

.blog-articles { grid-template-columns: 1fr; }

.blog-articles__article { display: grid; grid-template-columns: 40% minmax(0, 1fr); gap: 3rem; }
.blog-articles__article  + .blog-articles__article  { margin-top: 50px; }
.blog-articles__article .thumbnail { width: 100%; aspect-ratio: 3 / 2; display: block; background: #EFEFEF; }
.blog-articles__article .thumbnail img { width: 100%; height: 100%; object-fit: cover;  }
.blog-articles__article .blog_title { font-size: 2rem; border-bottom: 1px solid; padding-bottom: .5em; margin-bottom: .5em; margin-top: 0; font-weight: 600; }
.blog-articles__article .blog_date { font-size: 1.4rem; font-family: 'Figtree', sans-serif; margin: .5em 0; font-weight: bold; }
.blog-articles__article .more { margin: .5em 0 0 auto; padding: .3em; }

@media screen and (max-width: 900px) {
  .blog-articles__article .blog_title { font-size: 1.6rem; }
}
@media screen and (max-width: 600px) {
  .blog-articles__article { grid-template-columns: 1fr; gap: 1rem; }

}
.article-title { margin: 0; font-size: 3rem; border-bottom: 2px solid #C6577D; margin-bottom: 1em; padding-bottom: .5em;font-weight: bold;  }

.article-date { font-family: 'Figtree', sans-serif; font-size: 1.4rem; font-weight: bold; }
.article-body h2 { border-bottom: 2px solid #C6577D; font-size: 2.2rem; padding-bottom: .5em; margin-bottom: 1em; margin-top: 2em;font-weight: bold;  }
.article-body h3 { border-bottom: 1px solid #C6577D; font-size: 1.8rem; padding-bottom: .5em; margin-bottom: 1em; margin-top: 2em;font-weight: bold;  }
.article-body h4 { font-size: 1.8rem; padding-bottom: .5em; margin-bottom: 1em; margin-top: 2em;font-weight: bold; }
.article-body h5 { font-size: 1.6rem; padding-bottom: .5em; margin-bottom: 1em; margin-top: 2em;font-weight: bold;  }

.article-body ul { list-style: disc;  padding-left: 1.5em; }
.article-body ol { list-style: number; padding-left: 1.5em; }

.blog-tags li { display:inline-block;  margin: 0 7px 7px 0; }
.blog-tags a { display: inline-block; background: #F9F7F3; font-size: 1.3rem; padding: .5em 1em; }
@media screen and (max-width: 900px) {
.article-title { font-size: 2.4rem; }
.article-body h2 { font-size: 2rem; }
.article-body h3 { font-size: 1.8rem; }
.article-body h4 { font-size: 1.6rem; }
.article-body h5 { font-size: 1.5rem; }
}

.article-navigation { display: flex; justify-content: center; margin-top: 5rem; font-size: 1.3rem; }

.side-title { font-size:  2rem; font-weight: bold; border-bottom: 2px solid ; padding-bottom: .5em; marign-bottom: 1em; margin-top: 0; }


.list-faq { margin-bottom: 70px; }
.list-faq > dt { background: #FBFAF8; font-weight: bold; font-size: 1.6rem; padding: 1em 3em; position: relative; margin-top: 10px; cursor: pointer; }
.list-faq > dt::before { content: 'Q'; font-family: 'Figtree', sans-serif; color: #C6577D; font-weight: bold; font-size: 2rem; position: absolute;
left: 1em; top: .7em; margin: auto; }
.list-faq > dt::after { content: '+'; position: absolute; top: .7em; right: 1em; margin: auto; }
.list-faq > dd { margin: 0; display: none; padding: 1em 3em;position: relative; }
.list-faq > dd::before { content: 'A'; font-family: 'Figtree', sans-serif; color: #C6577D; font-weight: bold; font-size: 2rem; position: absolute;
left: 1em; top: .7em; margin: auto; }
@media screen and (max-width: 900px) {
  .list-faq > dt { font-size: 1.5rem; }
}

.field { display: block; margin-bottom: 40px; }
.field::after { display: none; }
.field__label { position: relative; top: auto; left: auto; right: auto; bottom: auto; font-weight: bold; }
.field__input { background: #FBFAF8; border: none; }
.field__input::after { display: none; }
.field .text-area { height: 15em; }
.contact__button { text-align: center; }
.contact__button .button { background: #C6577D; border-radius: 2em; margin: 0 auto; }
.contact__button .button::after { content: ''; width: .5em; height: .5em; display: inline-block; border: none;
border-top: 1px solid #FFF; border-right: 1px solid #FFF; margin-left: .5em; transform: rotate(45deg); 
position: relative; top: auto; left: auto; right: auto; bottom: auto; box-shadow: none!important; }
.field__input:focus, .field__input:not(:placeholder-shown), .field__input:-webkit-autofill, .customer .field input:focus, .customer .field input:not(:placeholder-shown), .customer .field input:-webkit-autofill {
  padding: 1.5rem;
}
@media screen and (max-width: 900px) {
  .field { margin-bottom: 20px; }
  .field__label { font-size: 1.4rem; }
}


.collection .grid__item { border: 1px solid #E6E6E6; padding: 40px 20px; border-radius: 10px; }
.collection .card--card.gradient, 
.collection .card__inner.gradient { background: none; }
.collection .card__media .media img { object-fit: contain; width: 100%; aspect-ratio: 1 / 1; height: auto; }
.card-wrapper { height: auto; }

.collection .card-information .price { font-size: 1.4rem; font-family: 'Figtree', sans-serif; }
.collection .card__information .card__heading { font-size: 2.0rem; font-family: 'Figtree', 'Noto Sans JP', sans-serif; font-wegiht: bold;  }
.collection .quick-add__submit { background: #C6577D; color: #FFF; border: none; border-radius: 2em; }
.collection .quick-add__submit::after { display: none; }

.collection .card__badge {     position: absolute; top: -40px; right: -10px; }


.pagination__list a { border: 1px solid #E8E9EC; border-radius: 5px; color:  #A9AAB0; font-size: 1.3rem; }
.pagination__list .pagination__item--current { background: #C6577D; color: #FFF; opacity: 1; }
.pagination__list .pagination__item--current::after { display: none; }


.price__container { font-family:  'Figtree', sans-serif; }
.product__title h1 { font-size: 3.2rem; font-weight: 600; font-family: 'Figtree', sans-serif;  }


.product__media-wrapper .product-media-container.constrain-height.media-fit-contain { width: 100%; height: auto;  aspect-ratio: 1 / 1; display: block; }
.product__media-wrapper .media>*:not(.zoom):not(.deferred-media__poster-button), 
.product__media-wrapper .media model-viewer { object-fit: contain; }
.product__media-wrapper .thumbnail img { object-fit: contain; }

.product__info-wrapper * { word-break: break-all; }
.product__info-wrapper .product__description { }
.product__info-wrapper .form__label { margin-top: 2em ;font-weight: bold; }

.product__info-wrapper .product-form__input--pill input[type=radio]+label { color: #CCCCCC; border-color: #CCCCCC; }
.product__info-wrapper .product-form__input--pill input[type=radio]:checked+label { color: #222222; border-color: #222222; background: none;}

.product__info-wrapper .quantity__label { display: none; }
.product__info-wrapper .quantity:after { border-radius: 5px; box-shadow:none; border: 1px solid #CCC;  }

.product__info-wrapper .product-form__buttons { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: flex-start; gap: 20px; }
.product__info-wrapper .product-form__submit { border-radius: 2em; background: #C6577D; color: #FFF; font-wegiht: bold; }
.product__info-wrapper .product-form__submit::after { display: none; } 

.product__info-wrapper .detail-block { border: 1px solid #CCCCCC; border-radius: 10px; overflow: hidden;}
.product__info-wrapper .detail-block .title{ font-weight: bold; background: #FAFAFA;margin: 0; padding: .7em;  font-size: 1.5rem; }
.product__info-wrapper .detail-block .conts { padding: 1em ;font-size: 1.4rem;  border-top: 1px solid #CCC; }

.conts-recommend .title-recommend { text-align: center; margin-bottom: 1em; }
.conts-recommend .title-recommend .en { display: block; font-family: 'Figtree', sans-serif; font-weight: 600; font-size: 3rem ; line-height: 1.6; }
.conts-recommend .title-recommend .ja { font-size: 1.6rem; font-weight: 600; }
.conts-recommend .content-block img { width: 100%; }
.conts-recommend .content-block__title{ font-weight: 500; font-size: 2.8rem; margin: 1em 0 .5em; }
.conts-recommend .content-block__body { word-break: break-all; }

.nutri-score { border: 1px solid #CCCCCC; border-radius: 10px; padding: 30px 25px 10px; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); text-align: center; }
.nutri-score > * { position: relative; }
.nutri-score .a::before,
.nutri-score .b::before,
.nutri-score .c::before,
.nutri-score .d::before,
.nutri-score .e::before { content: ''; width: 100%; height: 6px; display: block; margin-bottom: 6px; }
.nutri-score .a::before { background: #C9B076; border-radius: 4px 0 0 4px; }
.nutri-score .b::before { background: #68D6C3; }
.nutri-score .c::before { background: #5EB5F6; }
.nutri-score .d::before { background: #D580D5; }
.nutri-score .e::before { background: #C6577D; border-radius:  0 4px 4px 0;}
.nutri-score.score-A .a::after,
.nutri-score.score-B .b::after,
.nutri-score.score-C .c::after,
.nutri-score.score-D .d::after,
.nutri-score.score-E .e::after { content: ''; width: 14px; height: 12px; display: block; position: absolute; left: 0; right: 0; bottom: 100%; margin: auto;
background: #000; clip-path: polygon(0 0, 100% 0, 50% 100%); margin-bottom: 5px;  } 
.nutri-score.score-A .a,
.nutri-score.score-B .b,
.nutri-score.score-C .c,
.nutri-score.score-D .d,
.nutri-score.score-E .e { font-size: 1.2rem; font-weight: bold; }
.nutri-score:not(.score-A) .a,
.nutri-score:not(.score-B) .b,
.nutri-score:not(.score-C) .c,
.nutri-score:not(.score-D) .d,
.nutri-score:not(.score-E) .e { opacity: .6; }

.nutri-score span { font-size: 1.2rem; line-height: 1.2; }

.goes-well-product > a { display: grid; grid-template-columns: 60px minmax(0, 1fr) 120px; gap: 1rem; align-items: center; }
.goes-well-product__image img { width: 60px; height: 60px; object-fit: contain; }
.goes-well-product__title { margin: 0; font-size: 1.6rem; font-family: 'Figtree', sans-serif; font-weight: 600; }
.goes-well-product__price  { margin: 0; font-size: 1.4rem; font-family: 'Figtree', sans-serif; font-weight: 400; }
.goes-well-product .button { background: #C6577D; border-radius: 2em; padding: 0; width: 120px; padding: .5em; font-size: 1.4rem;  }
.goes-well-product .button::after { display: none; }


.custom-product-info { display: grid; grid-template-columns: 6em minmax(0, 1fr); gap: .5em 1em;}

.product-share { display: flex; align-items: center; }
.product-share__title { margin-right: 1em; font-weight: bold; }
.product__tax { display: none; }

.about-us-lead { position: relative; }
.about-us-lead .img { position: absolute; left: 0; top: 0; bottom: 0; width: 46%; height: 100%; object-fit: cover; }
.about-us-lead .text { width: 50%; margin: 0 0 0 auto; padding-top: 130px;  }
.about-us-lead .copy { font-size: 3rem; font-weight: bold; margin-bottom: .5em; }
.about-us-lead .copy-text { font-size: 1.8rem; }
.about-us-lead .profile { margin-top: 100px; padding-left: 80px; position: relative; }
.about-us-lead .profile img { width: 160px; position: absolute; left: -120px; top: 0;  margin: auto; }
.about-us-lead .profile .title { color: #C6577D; font-size: 1.8rem; font-weight: bold; }
.about-us-lead .profile .name { font-weight: bold; margin: 1em 0; }

.about-sns { display: flex; align-items: center; }
.about-sns a + a { margin-left: 2em; }


.about-why { margin-top: 100px; padding: 170px 0; position: relative; }
.about-why::before { content: ''; width: 100%; height: 45%; display: block; background: url("/cdn/shop/files/about2.jpg") no-repeat center center / cover; position: absolute; top: 0; left: 0; right: 0; margin: auto; } 
.about-why .text { background: #FFF; width: 90%; max-width: 900px; margin: 0 auto; padding-top: 80px; position: relative; z-index: 2; }
.about-why .text .inner { width: 700px; max-width: 90%; margin: 0 auto; }
.about-why .text .title { text-align: center; font-size:2rem; color:  #C6577D; font-weight: bold; margin-top: 0; }

@media screen and (max-width: 900px) {
  .about-us-lead .img { position: relative; width: 100%; height: 80vw; max-height: 700px; }
  .about-us-lead .text { width: 100%; padding-top: 60px; }
  .about-us-lead .copy { font-size: 2.4rem; }
  .about-us-lead .copy-text { font-size: 1.5rem;}

  .about-us-lead .profile { font-size: 1.4rem; padding-left: 0; }
  .about-us-lead .profile img { position: relative; margin: 0 auto; display: block;left: auto; }

  .about-why { padding-bottom: 50px; }
  .about-why .text { padding: 80px 0; }
}

.page-title-brand { text-align: center; color: #FFF; }
.page-title-brand .en { font-family: 'Figtree', sans-serif; font-size: 5rem; font-weight: 500;display: block; }
.page-title-brand .ja { font-size: 1.5rem; font-weight: 500; display: block; }


.page-brand-story { background: url(/cdn/shop/files/bg-brand.jpg) no-repeat center top / cover; color: #FFF; padding: 125px 0 280px; overflow: hidden;  }
.page-brand-story .breadcrumb{ justify-content: center; }
.brand-story-body { background: rgba(0,0,0, .6); width: 870px; max-width: 90%; margin: 0 auto; padding: 125px 8% 80px; line-height: 2.5; position: relative;  }
.brand-story-body .title { color: #FFF; font-size: 4rem; text-align: center; font-weight: 600; margin-bottom: 1em; line-height: 1.8; margin-top: 0;  }

.page-brand-story .img1 { position: absolute; left: 95%; top: 20%; width: 25%; margin: auto; }
.page-brand-story .img2 { position: absolute; right: 5%; top: calc(100% - 60px); width: 20%; margin: auto; }
.page-brand-story .img3 { position: absolute; right: 95%; top: 50%; width: 24%; margin: auto; }

@media screen and (max-width: 900px) {
  .page-title-brand .en { font-size: 3rem; }
  .page-title-brand .ja { font-size: 1.3rem; }

  .page-brand-story { padding: 80px 0; }
  .brand-story-body { padding: 60px 8%; line-height: 2; }
  .brand-story-body .title { font-size: 2.3rem; }

  .page-brand-story .img1 { position: relative; left: auto; top: auto; float: right; margin: 0 -15% 0 1rem;  width: 40%;}
  .page-brand-story .img3 { position: relative; left: auto; right: auto; top: auto; float: left; margin: 0 1em 0 -15%; width: 40%; }
  .page-brand-story .img2 { position: relative; left: auto; right: auto; top: auto; width: 50%; margin: 1em 0 -10rem auto; display: block; }
}


.header:not(.header--top-center) *>.header__search, .header--top-center>.header__search { position: relative; }

.header-search { position: relative; }
.search-modal { width: fit-content; top: 4em; right: 0; left: auto; margin: auto;  background: none; border: none;  }
.search-modal .modal-overlay { display: none!important; }
.search-modal__content { padding: 0; box-shadow: none; }
.search-modal .field { display: flex; margin: 0;  }
.search-modal__form {width: 20em; }
details[open] .header__icon-close { display: none!important; }

.search-modal__close-button { display: none!important; }
.search-modal .field__label { left: calc(var(--inputs-border-width) + 2rem); }
.search-modal .field__label { display: none; }
@media screen and (max-width: 900px) {
  .header__search { display: block!important; }
  .search-modal { right: -6em; }
}
    top: calc(1rem + var(--inputs-border-width));
    margin-bottom: 0;
    pointer-events: none;
    position: absolute;}

    .shopify-policy__container {
      width: 100%; 
      max-width: 100%;
      padding: 0;
    }
    .shopify-policy__title {
      padding: 60px 0;
      background: #FCFCFC;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    .shopify-policy__title h1 {
      font-size: 3.2rem;
      display: block;
      margin: 0;
   }

    .shopify-policy__body {
      width: 860px; max-width: 90%;
      margin: 0 auto; 
      padding: 100px 0; 
    }

@media screen and (max-width: 900px) {
    .shopify-policy__title  { padding: 40px 0; }
    .shopify-policy__title h1 {  font-size: 1.6rem; }
    .shopify-policy__body {
      padding: 50px 0;
    }
}

