/*@charset "UTF-8";*/
.eventCont {
  padding-top: 40px;
  padding-bottom: 40px;
}

@media (max-width: 769px) {
  .eventCont {
    padding-top: 20px;
    padding-bottom: 20px;
  }
}

.eventCont a:hover {
  opacity: 0.8;
}

/* --------------------------------------------------------------------
contentTitle
-------------------------------------------------------------------- */
.contentTitle {
  max-width: 720px;
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
}

.contentTitle h2 {
  letter-spacing: 0.1rem;
  font-size: 2rem;
  font-family: "Noto Serif JP", serif !important;
  text-align: center;
}

.contentTitle h3 {
  letter-spacing: 0.1rem;
  font-size: 1.8rem;
  font-family: "Noto Serif JP", serif !important;
  text-align: center;
}

.contentTitle h4 {
  letter-spacing: 0.1rem;
  font-size: 1.6rem;
  font-family: "Noto Serif JP", serif !important;
  text-align: center;
}

.contentTitle p {
  text-align: center;
}

@media (max-width: 768.98px) {
  .contentTitle {
    margin-top: 10px;
  }

  .contentTitle h2 {
    font-size: 1.4rem;
    letter-spacing: 0.05rem;
  }

  .contentTitle h3 {
    font-size: 1.2rem;
    letter-spacing: 0.05rem;
  }

  .contentTitle h4 {
    letter-spacing: 0.1rem;
    font-size: 1.4rem;
    text-align: center;
  }
}

/* --------------------------------------------------------------------
contentText
-------------------------------------------------------------------- */
.contentText {
  padding: 30px 0;
  margin: 0 auto;
  max-width: 720px;
}

@media (max-width: 768.98px) {
  .contentText {
    padding: 30px 0;
  }
}

.contentText h3 {
  font-weight: 600;
}

.contentText h4 {
  font-weight: 600;
}

.contentText p {
  line-height: 1.7;
  /* text-align: center; */
}

@media (max-width: 768.98px) {
  .contentText p {
    text-align: left;
  }
}

/* 斜体の場合、文字を小さくする */
.contentText p em {
  font-style: normal;
  font-size: 0.875em;
}

/* 取り消し線の場合、改行する */
@media (min-width: 769px) {
  .contentText p s::before {
    content: "\A";
    /* 改行を追加 */
    white-space: pre;
    /* 改行を有効にする */
    text-decoration: unset;
  }
}

.contentText p s {
  text-decoration: unset;
}

/* --------------------------------------------------------------------
common
-------------------------------------------------------------------- */
.limitContainer {
  padding-right: 0;
  padding-left: 0;
}

/* global.css */
.experience-component .mx-n2 {
  margin-left: unset !important;
  margin-right: unset !important;
}

/* titleAndRichtextAndButtons.css */
@media (min-width: 544px) {
  .title-and-richtext-and-buttons-component-container .content {
    padding-top: 0;
  }
}

.title-and-richtext-and-buttons-component-container .content .button p a {
  color: #fff !important;
  width: 100%;
  background-color: #2c2c2c;
  padding: 1rem;
}

/* productTile.css */
@media (min-width: 769px) {
  .product-tile-pd .product-tile-body {
    padding: 0.625em 0;
  }
}

@media (max-width: 768.98px) {
  .product-tile-pd .product-tile-body {
    font-size: 0.75em;
    padding: 0.3125em 0;
  }
}

/* carousel.css */
@media (min-width: 769px) {
  .carousel.indicators-md {
    padding-bottom: 2.375rem;
  }
}

@media (min-width: 544px) and (max-width: 768.98px) {
  .carousel.indicators-sm {
    padding-bottom: 2.375rem;
  }
}

@media (max-width: 543.98px) {
  .carousel.indicators-xs {
    padding-bottom: 2.375rem;
  }
}

.mainbanner-with-text-position-container .image-heading-text {
  line-height: 1.7;
}

@media (min-width: 544px) {
  .title-and-richtext-and-buttons-component-container .content {
    padding-top: 0;
  }
}

/* --------------------------------------------------------------------
fullscreen-banner
-------------------------------------------------------------------- */

/* video
-------------------------------------------------------------------- */
.fullscreen-banner .video {
  /* margin-bottom: -5px; */
  margin-bottom: 30px;
  /* display: none; */
}

@media (max-width: 768.98px) {
  .fullscreen-banner .video {
    margin-bottom: 15px;
  }
}

/* mainBannerWithTextPosition
-------------------------------------------------------------------- */
.fullscreen-banner .mainBannerWithTextPosition>.row {
  margin-right: 0;
  margin-left: 0;
}

.fullscreen-banner .mainBannerWithTextPosition>.row>.col-12 {
  padding-right: 0;
  padding-left: 0;
}

/* リンク無効化 */
.fullscreen-banner .mainBannerWithTextPosition a {
  pointer-events: none;
}

/* ボタン非表示 */
.fullscreen-banner .mainBannerWithTextPosition .mainbanner-sub-text {
  display: none;
}

/* mainImage padding 削除*/
.fullscreen-banner>.row:first-child>.col-12:first-child {
  padding-right: 0;
  padding-left: 0;
}

/* catchCopy */
.fullscreen-banner .mainBannerWithTextPosition .image-heading-container {
  position: absolute;
  top: 50%;
  left: 10%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}

.fullscreen-banner .mainBannerWithTextPosition h1 {
  font-size: 2.0rem;
  font-family: Noto Serif, Noto Serif Japanese !important;
  /* letter-spacing: 0.1rem; */
  line-height: 1.4;
  color: #fff;
  text-align: left;
}

.fullscreen-banner .mainBannerWithTextPosition h2 {
  font-size: 1.4rem;
  font-family: Noto Serif, Noto Serif Japanese !important;
  letter-spacing: 0.1rem;
  line-height: 1.4;
  color: #fff;
  text-align: left;
}

@media (max-width: 768.98px) {
  .fullscreen-banner .mainBannerWithTextPosition .image-heading-container {
    /* position: absolute;
    top: 20% !important;
    left: 10% !important;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%); */
    position: absolute;
    top: 20% !important;
    /* 上からの位置 */
    left: 50% !important;
    /* 左からの位置 */
    transform: translate(-50%, -50%);
    /* 中央揃えのために両方向を調整 */
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
  }

  .fullscreen-banner .mainBannerWithTextPosition .image-heading-container {
    position: absolute;
    top: unset !important;
    bottom: 0 !important;
    right: 0 !important;
    left: unset !important;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }

  .fullscreen-banner .mainBannerWithTextPosition h1 {
    text-align: right;
    font-size: 1rem;
    margin-bottom: 0;
  }
}


/* --------------------------------------------------------------------
pickup
-------------------------------------------------------------------- */
.pickup {
  display: none;
}

/* pickupTitle
-------------------------------------------------------------------- */
.pickupTitle h2 {
  letter-spacing: inherit !important;
  color: #b3608c;
}

.pickupTitle h2 em {
  font-weight: 600;
  font-style: inherit;
  font-size: 1.5rem;
}

.pickupTitle p {
  margin-top: 0 !important;
}

.pickupTitle {
  background-color: #fbfaf5;
}

@media (max-width: 768.98px) {
  .pickupTitle h2 {
    font-size: 1.4rem !important;
  }

  .pickupTitle p {
    text-align: left !important;
  }
}

/* 3rd content pickUP fullscreenBanner 
-------------------------------------------------------------------- */
/* title */
.pickup .mainbanner-with-text-position-container .image-heading-container {
  position: absolute;
  top: 50% !important;
  left: 50% !important;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  width: 40% !important;
}

.pickup .mainbanner-with-text-position-container h3 {
  font-size: 1.4rem;
  font-family: Noto Serif, Noto Serif Japanese !important;
  letter-spacing: 2px;
  color: #fff;
  text-align: left !important;
}

.pickup .mainbanner-with-text-position-container p {
  margin-top: 10px;
  text-align: left;
}

.pickup .mainbanner-with-text-position-container a.btn {
  border-color: #fff !important;
}

@media (max-width: 768.98px) {
  .pickup .mainbanner-with-text-position-container .image-heading-container {
    top: 120% !important;
    left: 50% !important;
    transform: translate(-50%, -50%);
    width: 90% !important;
    padding: 30px;
    background: rgba(0, 0, 0, .9);
    box-shadow: 1px 2px 3px rgb(0 0 0 / 10%);
  }

  .pickup .mainbanner-with-text-position-container .image-component {
    margin-bottom: 360px;
  }

  .pickup .mainbanner-with-text-position-container .image-heading-text .subtitle {
    margin-right: 0;
  }

  .pickup .experience-commerce_assets-editorialRichText {
    padding: 30px 0 50px;
  }

  .pickup .mainbanner-with-text-position-container h3 {
    font-size: 1.2rem;
  }

  .pickup .mainbanner-with-text-position-container a.btn {
    margin: 0;
  }
}

/* pickupImg
-------------------------------------------------------------------- */
.pickupImg .mainbanner-sub-text {
  text-align: left !important;
}

.beaujolaisNouveau {
  /* display: none; */
}

/* --------------------------------------------------------------------
product
-------------------------------------------------------------------- */
.product {
  /* display: none; */
}

.product .mobile-3r-1c>.row {
  display: flex;
}

.product .mobile-3r-1c>.row>.col-12 {
  display: flex;
  flex-direction: column;
}

.product .imageWithText {
  margin-bottom: 15px;
}

.product .imageWithText figcaption {
  margin-top: 15px;
}

.product .imageWithText h4 {
  font-weight: 400;
  font-family: "Noto Serif JP", serif !important;
  /* text-align: left; */
}

.product .imageWithText h4:first-child {
  font-size: 1.2rem;
}

.product .imageWithText p:nth-child(n+5) {
  text-align: left;
}

.product .experience-commerce_assets-titleAndRichtextAndButtons {
  margin-top: auto;
  padding-right: 15px;
  padding-left: 15px;
}


/* --------------------------------------------------------------------
xmas
-------------------------------------------------------------------- */
.xmas {
  display: none;
}

/* バナー リンク無効化 */
.xmas .mainBannerWithTextPosition>.row>.col-12>.mainbanner-figure>a {
  pointer-events: none;
}

.xmas .mainBannerWithTextPosition img {
  filter: brightness(70%) !important;
}

.xmas .mainBannerWithTextPosition .image-heading-container .image-heading-text .title h4 {
  color: #fff !important;
  font-family: "Noto Serif JP", serif !important;
}

/* ボタン margin 調整 */
.xmas .mainBannerWithTextPosition .image-heading-container .mainbanner-sub-text {
  margin-right: 0;
  margin-left: 0;
}

.xmas .mainBannerWithTextPosition .image-heading-container .mainbanner-sub-text a.btn {
  color: #212529 !important;
  width: 100%;
  padding: 1rem;
  margin: auto;
}

@media (max-width: 768.98px) {
  .xmas .mainBannerWithTextPosition .image-heading-container .image-heading-text .title h4 {
    font-size: 1.2rem;
  }

  .xmas .mainBannerWithTextPosition .image-heading-container .mainbanner-sub-text a.btn {
    width: fit-content;
  }
}


/* テキスト位置調整
----------------------------------------- */
/* 中央寄せ */
.xmas .mainBannerWithTextPosition .image-heading-container {
  position: absolute;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%);
}

/* 左寄せ */
.xmas .mainBannerWithTextPosition .image-heading-container {
  /* position: absolute;
  top: 50%;
  left: 10%;
  transform: translateY(-50%);
  width: fit-content; */
}

@media (max-width: 768.98px) {
  .xmas .mainBannerWithTextPosition .image-heading-text .title {
    margin-right: 0;
  }

  /* 中央寄せ */
  .xmas .mainBannerWithTextPosition .image-heading-container {
    position: absolute;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%);
  }

  /* 左寄せ */
  .xmas .mainBannerWithTextPosition .image-heading-container {
    /* position: absolute;
    top: 15% !important;
    left: 5% !important;
    transform: translateY(-50%); */
  }
}


/* --------------------------------------------------------------------
development
-------------------------------------------------------------------- */
.development .mobile-1r-1c {
  background-color: #e9ecef;
  max-width: 830px;
  margin: 0 auto;
  padding: 100px;
}

@media (max-width: 768.98px) {
  .development .mobile-1r-1c {
    padding: 60px 20px 45px;
  }
}

.development .imageTile {
  max-width: 334px;
  margin: auto;
}

.development .textBox p {
  padding-top: 30px;
  text-align: center;
}


/* --------------------------------------------------------------------
 design
-------------------------------------------------------------------- */
.design {
  /* display: none; */
}

.design .contentTitle {
  margin-bottom: 30px;
}

/* design.mainBannerWithTextPosition
-------------------------------------------------------------------- */
.design.mainBannerWithTextPosition>.row>.col-12 {
  padding-right: 0;
  padding-left: 0;
}

/* リンク無効化 */
.design.mainBannerWithTextPosition a {
  pointer-events: none;
}

/* ボタン非表示 */
.design.mainBannerWithTextPosition .mainbanner-sub-text {
  display: none;
}

/* title */
.design.mainBannerWithTextPosition .image-heading-container {
  position: absolute;
  top: 50% !important;
  left: 10% !important;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}

.design.mainBannerWithTextPosition.stem .image-heading-container {
  position: absolute;
  top: 50% !important;
  right: 10% !important;
  left: unset !important;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}

.design.mainBannerWithTextPosition .image-heading-text .title h3 {
  font-size: 2.0rem !important;
  font-family: "Noto Serif JP", serif !important;
  letter-spacing: 0.1rem;
  color: #fff;
  text-align: left !important;
}

.design.mainBannerWithTextPosition.stem .image-heading-text .title h3 {
  text-align: right !important;
}

/* text */
@media (max-width: 768.98px) {
  .design.mainBannerWithTextPosition .image-heading-container {
    top: 80% !important;
    left: 5% !important;
  }

  .design.mainBannerWithTextPosition.stem .image-heading-container {
    top: 30% !important;
    right: 5% !important;
  }
}

/* --------------------------------------------------------------------
 craftman
-------------------------------------------------------------------- */
.craftman .contentText h3 em {
  font-style: normal;
  font-size: 0.875em;
}

.craftman .imageTile {
  max-width: 830px;
  margin: 0 auto;
}

/* --------------------------------------------------------------------
 recommended
-------------------------------------------------------------------- */
.recommended {
  max-width: 720px;
  margin: 0 auto;
}

.recommended .contentTitle {
  margin-bottom: 30px;
}

.recommended .imageWithText figcaption {
  margin-top: 15px;
}

.recommended .imageWithText h4 {
  font-weight: 400;
  font-family: "Noto Serif JP", serif !important;
  /* text-align: left; */
}

.recommended .imageWithText p {
  text-align: left;
}

.recommended .experience-commerce_assets-titleAndRichtextAndButtons {
  margin-top: auto;
  padding-right: 15px;
  padding-left: 15px;
}


/* --------------------------------------------------------------------
limitedItems
-------------------------------------------------------------------- */
#limitedItems {
  /* display: none; */
}

.limitedItems .contentTitle {
  margin-bottom: 30px;
}

.limitedItems .imageWithText figcaption {
  margin-top: 15px;
}

.limitedItems .imageWithText h4 {
  font-weight: 400;
  font-family: "Noto Serif JP", serif !important;
}

.limitedItems .imageWithText p {
  /* text-align: left; */
}

/* --------------------------------------------------------------------
campaign
-------------------------------------------------------------------- */
.campaign {
  background-color: #f7f1e0;
}

.campaign .mobile-2r-2c>.row {
  justify-content: center;
}

@media (max-width: 768.98px) {
  .campaign .mobile-2r-2c>.row {
    justify-content: flex-start;
  }
}

.campaign .mobile-2r-2c>.row>.col-6:nth-child(4) {
  display: none;
}

.campaign h4 {
  text-align: center;
}

.campaign p {
  text-align: center;
}


/* accordion
-------------------------------------------------------------------- */
.services-container {
  /* display: flex;
  flex-wrap: wrap;
  justify-content: center; */
  /* margin: 20px auto; */
  max-width: 600px;
  margin: auto;
}

.service-image {
  align-self: flex-start;
  width: 100%;
}

.service-image img {
  width: 100%;
}

.services-right-text,
.services-left-text {
  align-self: center;
  width: 100%;
  text-align: left;
}

@media screen and (min-width: 768px) {
  .service-image {
    /* width: 50%; */
    order: unset;
  }

  .services-right-text {
    width: 50%;
    text-align: left;
    padding: 30px;
  }

  .services-left-text {
    width: 50%;
    margin: 42px 0;
    text-align: left;
    padding: 0 70px 0 0;
  }
}

@media screen and (max-width: 768px) {

  .services-right-text,
  .services-left-text {
    margin-top: 20px;
  }

  .services-right-text h3,
  .services-left-text h3 {
    font-size: 1.8em;
  }
}

.expander {
  width: 100%;
  max-width: 500px;
  background: #151515;
  /* color: rgba(255, 255, 255, 0.8); */
  padding: 1em;
  cursor: pointer;
  position: relative;
  /* background: #ccc; */
  background: #858585;
  margin: auto;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .expander {
    max-width: 350px;
  }
}

h2.expander {
  font-size: 14px;
  transition: 0.5s;
  margin-bottom: 0;
}

.expander:hover {
  /* color: rgba(255, 255, 255, 1);
  background: #2d2d2d;
  transition: 0.5s; */
}

.expander.changecolor {
  /* color: #000; */
  /* background: #0f1315; */
  transition: 0.5s;
  background: #ccc;
  background: #b3b3b3;
}

.active .arrow-down {
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

.arrow-down {
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 8px solid rgba(255, 255, 255, 0.8);
  position: absolute;
  right: 1.5em;
  top: 1.5em;
}

/* the magic */
.wrapper2 {
  width: 100%;
  max-width: 500px;
  overflow: hidden;
  margin-bottom: 2em;
  order: 0;
  background: #f8f8f8;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .wrapper2 {
    max-width: 350px;
  }
}

.content2 {
  /* margin-top: -133%; */
  margin-top: -213%;
  transition: 0.35s;
}

.wrapper2.open .content2 {
  margin-top: 0;
  transition: 0.17s;
}

@media (max-width: 768px) {
  .wrapper2 {
    width: 100%;
    overflow: hidden;
    /* margin-bottom: 2em; */
    order: -1;
  }
}

.parent {
  display: flex;
  flex-wrap: wrap;
  transition: 1s;
  flex-direction: column;
}

/* howToUse
-------------------------------------------------------------------- */
.howToUse.hidden {
  display: none;
}

.howToUse {
  /* width: fit-content;
  margin: 1rem auto;
  background: #f8f8f8; */
  padding: 15px 15px 0;
  padding: 1rem 1rem 0;
  /* max-width: 540px; */
  /* font-size: 0.8rem; */
  font-size: 0.8125em;
}

.howToUse p {
  text-align: left !important;
}

.howToUse .text-center {
  text-align: left !important;
}

.howToUse ol {
  padding-left: 15px;
}

.howToUse ul {
  padding-left: 20px;
}

/* img
--------------------------------------------- */
.howToUse .img {
  text-align: center !important;
  margin-bottom: 1rem;
}

.howToUse .img img {
  max-width: 300px;
}





/* --------------------------------------------------------------------
 gallery
-------------------------------------------------------------------- */
.gallery .contentTitle {
  margin-bottom: 30px;
}