/*@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 {
  margin-top: 20px;
  margin-bottom: 30px;
}

.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: 60px 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: justify; */
  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
-------------------------------------------------------------------- */
.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: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%); */
}

/* 左寄せ */
.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: 4px;
  line-height: 1.4;
  color: #fff;
}

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

.fullscreen-banner .mainBannerWithTextPosition h4 {
  font-size: 1.2rem;
  color: #fff;
  text-align: left;
}

.fullscreen-banner .mainBannerWithTextPosition .image-heading-text {
  text-shadow: 0px 0px 10px #3d3d3d;
}

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

  .fullscreen-banner .mainBannerWithTextPosition .image-heading-text .title {
    margin-right: 0;
  }

  /* 中央寄せ */
  .fullscreen-banner .mainBannerWithTextPosition .image-heading-container {
    /* position: absolute;
    top: 50% !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: 20% !important;
    left: 10% !important;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }
}


/* --------------------------------------------------------------------
mainText
-------------------------------------------------------------------- */
.mainText {}

.mainText .textBox {
  margin: 0 auto;
  max-width: 720px;
}

.mainText .textBox h1 {
  font-size: 1.8rem;
  font-family: Noto Serif, Noto Serif Japanese !important;
  letter-spacing: 2px;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 20px;
}

.mainText .textBox h2 {
  font-size: 1.6rem;
  font-family: Noto Serif, Noto Serif Japanese !important;
  /* letter-spacing: 2px; */
  text-align: center;
}

.mainText .textBox p {
  font-size: 16px;
  text-align: center;
}

.mainText .imageTile {
  margin: auto;
  max-width: 720px;
}

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

  .mainText .textBox h1 {
    font-size: 1.4rem;
  }

  .mainText .textBox h2 {
    font-size: 1.1rem;
  }
}

/* --------------------------------------------------------------------
menu
-------------------------------------------------------------------- */
.menu {
  padding-top: 0;
  padding-bottom: 0;
}

@media (max-width: 768.98px) {
  .menu {
    padding-top: 0;
    padding-bottom: 0;
  }
}

.pageAnchor .menuWrap {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin-bottom: 0;
}

.pageAnchor ul.menuWrap li.menuBg {
  /* background-color: #d0b67d; */
  /* background-color: #cba258; */
  background-color: #1F2F54;
  width: calc(96.75% / 4);
  margin-bottom: 10px;
  text-align: center;
  border-radius: 0.1875rem;
}

.pageAnchor ul.menuWrap li.menuBg a {
  display: block;
  padding: 10px 0 25px;
  font-size: 16px;
}

@media (max-width: 768.98px) {
  .pageAnchor ul.menuWrap li.menuBg {
    width: calc(96.75% / 2);
  }

  .pageAnchor ul.menuWrap li.menuBg a {
    font-size: unset;
  }
}

.pageAnchor ul.menuWrap li.menuBg a.arrow {
  position: relative;
  vertical-align: middle;
  text-decoration: none !important;
  color: #fff !important;
}

.pageAnchor ul.menuWrap li.menuBg a.arrow::before,
.pageAnchor ul.menuWrap li.menuBg a.arrow::after {
  position: absolute;
  top: auto;
  right: auto;
  bottom: auto;
  left: auto;
  margin: auto;
  vertical-align: middle;
  content: "";
}

.pageAnchor ul.menuWrap li.menuBg a.arrow::after {
  -webkit-transform: translateX(-50%) rotate(135deg);
  transform: translateX(-50%) rotate(135deg);
  bottom: 8px;
  left: 50%;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  width: 8px;
  height: 8px;
}


/* --------------------------------------------------------------------
products
-------------------------------------------------------------------- */
.products {
  padding-bottom: 0;
}

.products .contentTitle.intro {
  margin-top: 0;
  margin-bottom: 0;
}

.products .contentTitle.intro p {
  font-size: 16px;
}

/* detailDesc
-------------------------------------------------------------------- */
.detailDesc {
  background-color: #f6f6f6;
}

.detailDesc .region {
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-bottom: 0;
}

.detailDesc .imageTile .col-12 {
  padding-right: 0;
  padding-left: 0;
}

.detailDesc .imageTile .col-12 .photo-tile-figure {
  margin-bottom: 0;
}

.detailDesc .contentText {
  padding-left: 15px;
  padding-right: 15px;
}

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

.detailDesc .contentText p {
  text-align: left;
}

/* --------------------------------------------------------------------
color
-------------------------------------------------------------------- */
.color {
  padding-top: 0;
  padding-bottom: 0;
}

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

@media (max-width: 768.98px) {
  .product.imageWithText p {
    /* font-size: 0.85em; */
  }
}

.product.imageWithText .ITC-text-underneath {
  padding: 0.625em 0;
}

.product.imageWithText .ITC-text-underneath p:first-child {
  font-size: 12px;
}

.product.imageWithText .ITC-text-underneath p:nth-child(3) {
  margin-top: 0.5rem;
}

.product.imageWithText .ITC-text-underneath p:nth-child(3) em {
  font-size: 0.8125em;
  font-style: normal;
  font-weight: initial;
}

.product.imageWithText ul {
  list-style: none;
  padding: 0.5rem;
  margin-top: 0.5rem;
  margin-bottom: 0;
  background-color: #f6f6f6;
  font-size: 12px;
}

@media (max-width: 768.98px) {
  .product.imageWithText ul {
    font-size: 12px;
    text-align: left;
  }
}

/* --------------------------------------------------------------------
pairset
-------------------------------------------------------------------- */
.pairset .mobile-2r-2c .col-6,
.pairset .mobile-3r-2c .col-6 {
  /* padding-right: 5px;
  padding-left: 5px;
  display: flex;
  flex-direction: column; */
}


/* --------------------------------------------------------------------
craftsman
-------------------------------------------------------------------- */

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

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

/* --------------------------------------------------------------------
keirou
-------------------------------------------------------------------- */
.keirou {
  padding-bottom: 0;
}

.keirou .contentText {
  padding: 0;
}

.keirou .contentText p {
  text-align: left;
}

.keirou .contentText ul {
  text-align: left;
  padding-left: 25px;
}

.keirou .contentText p:first-child {
  font-size: 16px;
}


/* --------------------------------------------------------------------
messageKibako
-------------------------------------------------------------------- */
.messageKibako {
  padding-bottom: 40px;
  margin-bottom: 40px;
}

@media (max-width: 768.98px) {
  .messageKibako {
    padding-bottom: 20px;
  }
}

.messageKibako .limitContainer {
  padding-right: 0;
  padding-left: 0;
}

.messageKibako .contentTitle h2,
.messageKibako .contentTitle h3 {
  text-align: center;
}

.messageKibako .imageTile {
  /* max-width: 940px; */
  margin: auto;
}

.messageKibako .imageTile img {
  border: 10px solid #fff;
  box-shadow: 0 0 1px #ccc, 1px 1px 2px rgba(50, 50, 50, 0.2);
  position: relative;
}

/* desc
-------------------------------------------------------------------- */
.messageKibako .desc {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  background: #fff;
  padding: 1rem;
}

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

@media (max-width: 768.98px) {
  .messageKibako .desc p {
    font-size: 12px;
  }
}

/* --------------------------------------------------------------------
giftset
-------------------------------------------------------------------- */


/* --------------------------------------------------------------------
scene
-------------------------------------------------------------------- */

/* scene productList
-------------------------------------------------------------------- */
.scene .productList {
  /* padding-left: 0;
  padding-right: 0; */
}

/* コメント下揃え */
.scene .productList .region {
  /* display: flex;
  flex-direction: column; */
}

.scene .productList .experience-commerce_assets-editorialRichText {
  /* flex-wrap: wrap;
  justify-content: space-between;
  margin-top: auto; */
}

.scene .productList .productTextBox {
  /* display: none; */
  /* background-color: #f5f5f5;
  background-color: #fff;
  padding: 0.625em 1em;
  font-size: 0.8em; */
}

.scene .productList .productTextBox .text-center {
  /* text-align: left !important; */
}

@media (max-width: 768.98px) {
  .scene .productList .productTextBox {
    /* font-size: 0.75em;
    padding: 0.3125em 0.5em; */
  }

  .scene .productList .productTextBox .text-center {
    /* text-align: left !important; */
  }
}


/* --------------------------------------------------------------------
coupon
-------------------------------------------------------------------- */
.member {
  display: none;
}

.hayawari {
  display: none;
}

.chokuzenwari {
  display: none;
}

.coupon .couponImg {
  text-align: center;
}

.coupon .couponImg img {
  max-width: max-content;
}

.coupon .contentTitle u {
  font-size: 0.8em;
  text-decoration: none;
}

.coupon .contentTitle p:nth-child(2) {
  margin-bottom: 0.5rem;
}

.coupon .detail {
  background: #f7f1e047;
  /* padding: 1rem 0.5rem; */
  margin: auto;
  width: fit-content;
  padding: 1rem 2rem;

}

.coupon .detail h3 {
  text-align: center;
  font-weight: 600;
  font-size: 1.4rem;
}

.coupon .detail h3:nth-child(2) strong {
  font-size: 2.2rem;
  margin-right: 2px;
}

.coupon .detail h4 {
  text-align: center;
  font-size: 1.3rem;
}

.coupon .detail p {
  text-align: center;
}

.coupon .detail p strong:first-child {
  font-size: 1.2rem;
}

/* code
------------------------------------- */
.coupon .detail h4:nth-child(3) {
  margin-top: 1rem;
  margin-bottom: 0.25rem;
  font-size: 1.2rem;
}

.coupon .detail h3:nth-child(4) {
  margin-left: auto;
  margin-right: auto;
  width: fit-content;
  background: #fff;
  padding: 0.25rem 2rem;
}

/* link
------------------------------------- */
.coupon .link p {
  text-align: center;
}

.coupon .link p a {
  text-decoration: underline;
}


/*  -------------------------------------------------  COMMON PARTS  -------------------------------------------------  */

/* --------------------------------------------------------------------
imageTile icon
-------------------------------------------------------------------- */
.imageTile.icon {
  margin: auto;
  max-width: 100px;
}

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

.banner .mainBannerWithTextPosition {
  /* margin: auto;
  max-width: 600px; */
}

/*  -------------------------------------------------  COMMON PARTS END -------------------------------------------------  */

/*  -------------------------------------------------  DISPLAY NONE PARTS  -------------------------------------------------  */

/* --------------------------------------------------------------------
budget 予算から選ぶ
-------------------------------------------------------------------- */
.budget {
  display: none;
}

.budget .region {
  margin-bottom: 0;
}

.budget .region {
  margin-bottom: 0;
}

.budget .col-6 {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 50%;
  flex: 0 0 100%;
  max-width: 100%;
}

@media (min-width: 544px) {
  .budget .col-sm-4 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 33.33333%;
    flex: 0 0 33.33333%;
    max-width: 33.33333%;
  }
}

.budget .button p a {
  width: 100% !important;
  border: none;
  background-color: #d0b67d !important;
  padding: 1rem;
}

.budget .button p {
  margin: 0.5rem auto !important;
}

@media (min-width: 544px) {
  .budget .button p {
    margin: 1rem auto;
  }
}

/* --------------------------------------------------------------------
category カテゴリから選ぶ
-------------------------------------------------------------------- */
.category {
  display: none;
}

.category .cat .image-heading-container {
  top: unset !important;
  bottom: 0;
}

@media (min-width: 769px) {
  .category .cat .image-heading-container {
    width: 100%;
  }
}

.category .cat .mainbanner-sub-text {
  margin-top: 0;
}

@media (max-width: 543.98px) {
  .category .cat .mainbanner-sub-text {
    margin-top: 1rem;
    text-align: right !important;
    margin-right: -15px;
  }
}

.category .cat .mainbanner-sub-text a.link-large.btn.btn-dark {
  width: inherit;
  padding: 0.5rem;
  font-size: 0.9em;
  color: #212529 !important;
}

/* --------------------------------------------------------------------
giftService ギフトサービス
-------------------------------------------------------------------- */
.giftService {
  display: none;
}

.giftService .banner {
  margin: auto;
  max-width: 600px;
}

/* --------------------------------------------------------------------
notice
-------------------------------------------------------------------- */
.notice {
  display: none;
  padding-top: 20px;
  padding-bottom: 10px;
}

.notice h4 {
  font-size: 1.0rem;
  font-weight: 600;
  color: #fff;
}

.notice h4 em {
  font-style: unset;
  color: #fff;
}

.notice h4 u {
  text-decoration: none;
  font-weight: 500;
  font-size: 0.9rem;
  color: #fff;
}

.notice p {
  color: #fff;
}

@media (min-width: 992px) {
  .notice .text-lg-left {
    text-align: center !important;
  }
}

.notice .link p a {
  text-decoration: underline;
  color: #fff !important;
}

/*  -------------------------------------------------  DISPLAY NONE PARTS END  -------------------------------------------------  */