/*@charset "UTF-8";*/
.eventCont {
  padding-top: 60px;
  padding-bottom: 60px;
  /* line-height: 1.8; */
}

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

.eventCont a:hover {
  opacity: 0.8;
  transition: opacity 0.3s ease-out;
}

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

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

.contentTitle h2 em {
  font-size: 16px;
  font-weight: 400;
  font-family: "Noto Serif JP", serif !important;
  font-style: unset;
  vertical-align: top;
}

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

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

.contentTitle p {
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 1.8;
}

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

  .contentTitle h2 {
    font-size: 1.8rem;
    /* letter-spacing: 0.05rem; */
  }

  .contentTitle h3 {
    font-size: 1.4rem;
    /* letter-spacing: 0.05rem; */
  }

  .contentTitle h4 {
    font-size: 1.1rem;
    /* letter-spacing: 0.05rem; */
  }
}

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

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

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

/* contentTitle.sub 左寄せ線ありデザイン
-------------------------------------------------------------------- */
.contentTitle.sub {
  /* display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 15px;
  margin-bottom: 30px;
  text-align: left;
  letter-spacing: 0.1em; */
}

@media (max-width: 768.98px) {
  .contentTitle.sub {
    /* margin-bottom: 30px; */
  }
}

.contentTitle.sub::after {
  /* content: "";
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  height: 1px;
  background: #E2E2E2; */
}

.contentTitle.sub h3 {
  /* margin-bottom: 0; */
}

/* contentTitle.sub 左寄せ線ありデザイン 調整
-------------------------------------------------------------------- */
.contentTitle.sub>.row>.col-12 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 15px;
  /* margin-bottom: 30px; */
  text-align: left;
  letter-spacing: 0.1em;
}

@media (max-width: 768px) {
  .contentTitle.sub>.row>.col-12 {
    margin-bottom: 15px;
  }

  .contentTitle.sub>.row>.col-12>p {
    order: 3;
    width: 100%;
    text-align: left;
  }
}

.contentTitle.sub>.row>.col-12::after {
  content: "";
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  height: 1px;
  background: #E2E2E2;
}

.contentTitle.sub h3 {
  margin-bottom: 0;
}

.contentTitle.sub p {
  font-size: 1.2rem;
  font-family: "Noto Serif JP", serif !important;
}

@media (max-width: 768px) {
  .contentTitle.sub p {
    font-size: 1.0rem;
  }
}

/* --------------------------------------------------------------------
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;
}

.textbox 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;
}

/* sub.contentText 左寄せデザイン
-------------------------------------------------------------------- */
.sub.contentText {
  max-width: unset;
  margin-bottom: 30px;
  padding: 0;
}

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


/* --------------------------------------------------------------------
products
-------------------------------------------------------------------- */
.products {
  margin-top: 40px;
  /* margin-bottom: 40px; */
}

@media (max-width: 768px) {
  .products {
    margin-top: 0;
  }
}

.graduation {
  display: none;
}

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

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

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

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

.imageWithText.product .ITC-text-underneath p strong {
  display: block;
  margin-top: 1rem;
}

/* --------------------------------------------------------------------
more
-------------------------------------------------------------------- */
.more .titleRichtextButtons .content .button p {
  margin-top: 0;
  margin-bottom: 0;
}

.more .titleRichtextButtons .content .button p a {
  padding: 0.75rem 0.75rem;
}

@media (max-width: 768.98px) {
  .more {
    display: flex;
    flex-wrap: nowrap;
  }

  .more>.col-12 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
    padding-right: 10px;
    padding-left: 10px;
  }

  .more .titleRichtextButtons .button p a {
    font-size: inherit;
  }
}


/* --------------------------------------------------------------------
other common
-------------------------------------------------------------------- */
.limitContainer {
  padding-right: 0;
  padding-left: 0;
  /* max-width: 1280px; */
}

/* 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;
  max-width: 500px;
}

@media (max-width: 768.98px) {
  .title-and-richtext-and-buttons-component-container .content .button p a {
    font-size: 1.0em;
  }
}

/* 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;
  }
}

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

/* 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;
  }
}

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

.fullscreen-banner .mainBannerWithTextPosition a {
  pointer-events: none
}

.fullscreen-banner .row.slickCarousel {
  margin-right: 0;
  margin-left: 0;
  /* display: none; */
}

/* mainBannerWithTextPosition.css */
.fullscreen-banner .mainbanner-with-text-position-container .mainbanner-sub-text {
  margin-top: 0;
}

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

/* noButton
-------------------------------------------------------------------- */
.fullscreen-banner .noButton a.link-large.btn.btn-dark {
  display: none;
}


/* animation
-------------------------------------------------------------------- */
.fullscreen-banner>.row>.col-12 {
  aspect-ratio: 2 / 1;
  overflow: hidden;
  position: relative;
}

@media (max-width: 768.98px) {
  .fullscreen-banner>.row>.col-12 {
    aspect-ratio: 1 / 1;
  }
}

/* JavaScript で制御する場合 ここから */
.fullscreen-banner>.row>.col-12 .experience-commerce_assets-mainBannerWithTextPosition {
  position: absolute;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1s ease, transform 1s ease;
  transition: opacity 2s ease-in-out, transform 2s ease-in-out;
  /* 2秒で滑らかに変化 */
  transition: opacity 1s ease, transform 5s ease;
  /* 徐々に拡大させるために時間を延ばす */
  transform: scale(1);
  pointer-events: none;
  z-index: 0;
}

.fullscreen-banner>.row>.col-12 .experience-commerce_assets-mainBannerWithTextPosition.active {
  opacity: 1;
  transform: scale(1.02);
  pointer-events: auto;
  z-index: 1;
}

/* JavaScript で制御する場合 ここまで */

.fullscreen-banner {
  position: relative;
}

.fullscreen-banner::before {
  content: "";
  position: absolute;
  top: 50px;
  left: 50px;
  width: 150px;
  height: 39px;
  background-image: url(/on/demandware.static/-/Library-Sites-WBJapanSharedLibrary/ja_JP/images/top/main/logo_wb_w.svg);
  /* ロゴ画像 */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: 3;
  /* ロゴは常に最前面 */
  pointer-events: none;
}

@media (max-width: 768.98px) {
  .fullscreen-banner::before {
    top: unset;
    bottom: 25px;
    left: 25px;
    width: 9.57em
      /* ロゴの幅 */
    ;
    height: 2.49em;
  }
}


/* --------------------------------------------------------------------
subBanner
-------------------------------------------------------------------- */
.subBanner {
  display: none;
  padding-top: 10px;
}

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

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

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

/* animation
-------------------------------------------------------------------- */
.subBanner>.row>.col-12 {
  aspect-ratio: 2 / 1;
  overflow: hidden;
  position: relative;
}

.subBanner>.row>.col-12 .experience-commerce_assets-mainBannerWithTextPosition {
  position: absolute;
  width: 100%;
  height: 100%;
  opacity: 0;
  animation: anime 15s 0s infinite;
  z-index: 0 !important;
}

/* 2枚目の画像のアニメーション開始を遅延 */
.subBanner>.row>.col-12 .experience-commerce_assets-mainBannerWithTextPosition:nth-of-type(2) {
  animation-delay: 7.5s;
}

@keyframes anime {
  0% {
    opacity: 1;
  }

  50% {
    opacity: 1;
  }

  60% {
    opacity: 0;
    transform: scale(1.1);
    z-index: 10;
  }

  100% {
    opacity: 0;
    transform: scale(1.1);
  }
}

@media (max-width: 768.98px) {
  .subBanner>.row>.col-12 {
    aspect-ratio: 1 / 1;
  }
}


/* --------------------------------------------------------------------
promoBanner
-------------------------------------------------------------------- */
.promoBanner {
  /* display: none; */
  padding-top: 0;
  /* padding-bottom: 0; */
}

.promoBanner .textbox h4 {
  text-align: center;
  margin-bottom: 15px;
  font-family: "Noto Serif JP", serif !important;
}

.promoBanner .mainBannerWithTextPosition {
  margin: auto;
  max-width: 940px;
  margin-bottom: 15px;
}

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

/* --------------------------------------------------------------------
mainText
-------------------------------------------------------------------- */
.mainText {
  /* padding-top: 30px;
  padding-bottom: 0; */
}

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

.mainText .contentTitle.textbox {
  margin-bottom: 20px;
}

.mainText .contentTitle.textbox h1 {
  font-size: 2.2rem;
  font-family: "Noto Serif JP", serif !important;
  text-align: center;
  letter-spacing: 0.1em;
}

@media (max-width: 768.98px) {
  .mainText .contentTitle.textbox h1 {
    font-size: 1.6rem;
  }
  .mainText .contentTitle.textbox h1:first-child {
    font-size: 1.2rem;
  }
}

.mainText .textbox p {
  font-family: "Noto Serif JP", serif !important;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 2.0em;
}

@media (max-width: 768.98px) {
  .mainText .textbox p {
    letter-spacing: 0.025em;
  }
}

.mainText .textbox p em {
  font-style: normal;
}

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

  .mainText .textbox p:nth-child(3) {
    /* text-align: left; */
  }
}

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

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

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


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

.point .textbox {
  background-color: #fff;
  padding: 1rem;
  -webkit-box-shadow: 0 1px 3px rgba(49, 49, 49, 0.3);
  box-shadow: 0 1px 3px rgba(49, 49, 49, 0.3);
}

@media (max-width: 768.98px) {
  .point .textbox {
    padding: 0.5rem;
  }
}

.point .contentTitle p {
  margin-bottom: 0.5rem;

}

@media (max-width: 768.98px) {
  .point .contentTitle p {
    font-size: 0.875em;
  }
}

.point .textbox .text-lg-left {
  text-align: center !important;
}

@media (max-width: 768.98px) {
  .point .textbox p {
    font-size: 0.875em;
  }
}

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

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

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

.menu .pageAnchor ul.menuWrap li.menuBg {
  /* background-color: #d0b67d; */
  background-color: #C7B994;
  width: calc(96.75% / 4);
  margin-bottom: 10px;
  text-align: center;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  line-height: 1.5;
}

.menu .pageAnchor ul.menuWrap li.menuBg:nth-child(4) {
  /* display: none; */
}

.menu .pageAnchor ul.menuWrap li.menuBg.single-line a {
  padding: 10px 0 40px;
}


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

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

  .menu .pageAnchor ul.menuWrap li.menuBg.single-line a {
    padding: 10px 0 20px;
  }

  .menu .pageAnchor ul.menuWrap li.menuBg a {
    font-size: 0.825em;
  }
}

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

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

.menu .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;
}

/* シンプルデザイン
-------------------------------------------------------------------- */
.menu .pageAnchor ul.menuWrap li.menuBg {
  background: none;
  width: calc(90.75% / 4);
}

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

/* border-color */
.menu .pageAnchor ul.menuWrap li.menuBg {
  border-bottom: 3px solid #ccc;
}

.menu .pageAnchor ul.menuWrap li.menuBg:hover {
  border-bottom: 3px solid #212529;
}

/* triangle-color */
.menu .pageAnchor ul.menuWrap li.menuBg a.arrow::after {
  border-top: 2px solid #ccc;
  border-right: 2px solid #ccc;
}

.menu .pageAnchor ul.menuWrap li.menuBg:hover a.arrow::after {
  border-top: 2px solid #212529;
  border-right: 2px solid #212529;
}

/* font-color */
.menu .pageAnchor ul.menuWrap li.menuBg a.arrow {
  color: #a0a0a0 !important;
}

.menu .pageAnchor ul.menuWrap li.menuBg:hover a.arrow {
  color: #212529 !important;
}

.menu .pageAnchor ul.menuWrap li.menuBg a.arrow:hover {
  opacity: 1;
}



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

.glass-main>.col-12:first-child {
  padding-right: 0;
  padding-left: 0;
}

@media (max-width: 768.98px) {
  .glass-main>.col-12 {
    padding-right: 0;
    padding-left: 0;
  }
}

.glass-main .imageWithText>.row>.col-12 {
  padding-right: 0;
  padding-left: 0;
}

.glass-main .col-sm-6:nth-child(2),
.glass-ice-crack .col-sm-6:nth-child(2) {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

@media (min-width: 544px) {

  .glass-main .col-sm-6:first-child,
  .glass-ice-crack .col-sm-6:first-child {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 55%;
    flex: 0 0 55%;
    max-width: 55%;
  }

  .glass-main .col-sm-6:nth-child(2),
  .glass-ice-crack .col-sm-6:nth-child(2) {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45%;
    flex: 0 0 45%;
    max-width: 45%;
  }

  .glass-main .col-sm-6:nth-child(2)>.experience-component,
  .glass-ice-crack .col-sm-6:nth-child(2)>.experience-component {
    width: 80%;
  }
}

@media (min-width: 544px) {
  .glass .contentDesc {
    padding: 20px;
  }
}

.glass h2,
.glass h4 {
  margin-bottom: 1.5rem;
}

.glass h2 {
  margin-bottom: 1.5rem;
}

@media (max-width: 768.98px) {
  .glass h2 {
    font-size: 1.6rem;
  }
}


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

.glass .imageWithText.glass-category p {
  text-align: left;
}

/* --------------------------------------------------------------------
mug
-------------------------------------------------------------------- */
.mug-main>.col-12:first-child {
  padding-right: 0;
  padding-left: 0;
}

@media (max-width: 768.98px) {
  .mug-main>.col-12 {
    padding-right: 0;
    padding-left: 0;
  }
}

.mug-main .imageWithText>.row>.col-12 {
  padding-right: 0;
  padding-left: 0;
}

.mug-main .col-sm-6:nth-child(2) {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

@media (min-width: 544px) {
  .mug-main .col-sm-6:first-child {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 55%;
    flex: 0 0 55%;
    max-width: 55%;
  }

  .mug-main .col-sm-6:nth-child(2) {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45%;
    flex: 0 0 45%;
    max-width: 45%;
  }

  .mug-main .col-sm-6:nth-child(2)>.experience-component {
    width: 80%;
  }
}

@media (min-width: 544px) {
  .mug .contentDesc {
    padding: 20px;
  }
}


.mug h2 {
  margin-bottom: 1.5rem;
}


/* carousel
-------------------------------------------------------------------- */
.mug .experience-commerce_layouts-carousel .carousel-control-prev {
  left: 0;
}

.mug .experience-commerce_layouts-carousel .carousel-control-next {
  right: 0;
}

.mug .carousel .carousel-inner {
  width: 100%;
  margin-right: unset;
  margin-left: unset;
}

@media (max-width: 768.98px) {
  .mug .carousel .carousel-inner {
    width: 120%;
  }
}

.mug .carousel .carousel-inner .carousel-item {
  padding-right: 5px;
  padding-left: 5px;
  height: 100% !important;
}

/* --------------------------------------------------------------------
pair-gift
-------------------------------------------------------------------- */
@media (max-width: 543.98px) {
  .pair-gift .mobile-2r-2c .col-6 {
    padding-right: 10px;
    padding-left: 10px;
  }
}

@media (min-width: 544px) {
  .pair-gift .mobile-2r-2c .col-sm-3 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 33.333333%;
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
  }
}

.pair-gift .imageWithText figcaption .ITC-text-underneath {
  padding-right: 0;
  padding-left: 0;
  padding-top: 5px;
}

@media (max-width: 543.98px) {
  .pair-gift .imageWithText figcaption .ITC-text-underneath p {
    font-size: 0.875em;
  }
}

/* --------------------------------------------------------------------
budget
-------------------------------------------------------------------- */
.budget .mobile-3r-2c>.row>.region {
  margin-bottom: 0;
}

.budget .titleRichtextButtons .content .button p {
  margin-top: 0;
}

.budget .titleRichtextButtons .content .button p a {
  border: none;
  /* background-color: #d0b67d !important; */
  /* background-color: #C7B994 !important; */
  background-color: #fff !important;
  -webkit-box-shadow: 0 1px 3px rgba(49, 49, 49, 0.3);
  box-shadow: 0 1px 3px rgba(49, 49, 49, 0.3);
  color: #212529 !important;
}

@media (max-width: 768.98px) {
  .budget .titleRichtextButtons .content {
    padding-right: 10px;
    padding-left: 10px;
  }
}

/* --------------------------------------------------------------------
options
-------------------------------------------------------------------- */

/* message-kibako
-------------------------------------------------------------------- */
.options .message-kibako {
  margin-bottom: 40px;
  display: none;
}

.options .message-kibako .textbox .text-center {
  text-align: left !important;
}

.options .message-kibako .textbox h4 {
  font-size: 1.0rem;
  padding: 5px 10px;
  display: inline-block;
  margin-bottom: 1.0rem;
  background-color: #C7B994;
  color: #fff;
}

.options .message-kibako .textbox p strong {
  display: inline-block;
  min-width: 60px;
}

/* etching
-------------------------------------------------------------------- */
.options .etching {
  margin-bottom: 40px;
}

/* etching-ex
------------------------------------- */
.options .etching .etching-ex {
  background: #f0f0f0;
  /* padding: 10px 15px; */
}

@media (max-width: 768.98px) {
  .options .etching .etching-ex {
    /* padding: 15px 10px 0; */
  }
}

.options .etching .etching-ex .contentTitle {
  margin-bottom: 0;
}

.options .etching .etching-ex .contentTitle h4 {
  font-size: 1.2rem;
  margin-bottom: 0;
}

.options .etching .carousel {
  background: #f0f0f0;
  /* padding: 10px 15px; */
}

@media (max-width: 768.98px) {
  .options .etching .carousel {
    /* padding: 15px 10px 0; */
  }
}

.options .etching .carousel .carousel-inner {
  width: 100%;
  margin-right: unset;
  margin-left: unset;
}

.options .etching .carousel .carousel-inner .carousel-item {
  height: 100% !important;
}

@media (max-width: 768.98px) {
  .options .etching .carousel .carousel-inner .carousel-item {
    margin-right: -100%;
  }
}

/* リンク無効化 */
.options .etching .carousel .imageWithText a {
  pointer-events: none;
}

.options .etching .carousel .imageWithText .ITC-text-underneath {
  padding: 0.625em 0;
}

.options .etching .carousel .imageWithText .ITC-text-underneath span {
  text-align: left;
}

.options .etching .carousel .textbox {
  background: #fff;
  padding: 5px;
}

@media (max-width: 768.98px) {
  .options .etching .carousel .textbox {
    margin-bottom: 20px;
  }
}

.options .etching .carousel .textbox .text-center {
  text-align: left !important;
}

.options .etching .carousel .textbox p {
  font-size: 0.875em;
}

.options .etching .carousel .textbox p s {
  visibility: hidden;
}

/* gift-service 
-------------------------------------------------------------------- */
.options .gift-service .contentTitle.sub {
  margin-top: 40px;
}

.options .gift-service .titleRichtextButtons .content .button p a {
  background-color: #C7B994 !important;
  padding: 1rem 2rem;
  border: none;
}

.options .gift-service .banner {
  margin: auto;
  max-width: 600px;
}


/* --------------------------------------------------------------------
ranking
-------------------------------------------------------------------- */
.ranking .experience-commerce_layouts-carousel .carousel-control-prev {
  left: 0;
}

.ranking .experience-commerce_layouts-carousel .carousel-control-next {
  right: 0;
}

.ranking .carousel .carousel-inner {
  width: 100%;
  margin-right: unset;
  margin-left: unset;
}

@media (max-width: 768.98px) {
  .ranking .carousel .carousel-inner {
    width: 120%;
  }
}

.ranking .carousel .carousel-inner .carousel-item {
  padding-right: 5px;
  padding-left: 5px;
  /* max-height: 450px !important; */
  height: 100% !important;
}

@media (max-width: 768.98px) {
  .ranking .carousel .carousel-inner .carousel-item {
    /* max-height: 250px !important; */
  }
}

.ranking .carousel .carousel-inner .carousel-item::before {
  position: absolute;
  top: 0;
  left: 5px;
  content: attr(data-position);
  display: block;
  width: 30px;
  height: 30px;
  background: #6e6e6e;
  color: #fff;
  font-size: 20px;
  line-height: 30px;
  font-weight: bold;
  text-align: center;
  z-index: 3;
}

.ranking .carousel .carousel-inner .carousel-item[data-position="0"]::before {
  content: attr(number)"1";
  background: #D0BD8B;
}

.ranking .carousel .carousel-inner .carousel-item[data-position="1"]::before {
  content: attr(number)"2";
  background: #B4B4B4;
}

.ranking .carousel .carousel-inner .carousel-item[data-position="2"]::before {
  content: attr(number)"3";
  background: #D8A585;
}

.ranking .carousel .carousel-inner .carousel-item[data-position="3"]::before {
  content: attr(number)"4";
}

.ranking .carousel .carousel-inner .carousel-item[data-position="4"]::before {
  content: attr(number)"5";
}

.ranking .carousel .carousel-inner .carousel-item[data-position="5"]::before {
  content: attr(number)"6";
}

.ranking .carousel .carousel-inner .carousel-item[data-position="6"]::before {
  content: attr(number)"7";
}

.ranking .carousel .carousel-inner .carousel-item[data-position="7"]::before {
  content: attr(number)"8";
}

.ranking .carousel .carousel-inner .carousel-item[data-position="8"]::before {
  content: attr(number)"9";
}

/* 手動更新の場合はこちらを利用 */
.ranking .experience-commerce_layouts-carousel {
  display: none;
}

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

@media (max-width: 543.98px) {
  .topics .mobile-2r-2c .col-6 {
    padding-right: 10px;
    padding-left: 10px;
  }
}

.topics .imageWithText figcaption .ITC-text-underneath {
  padding-right: 0;
  padding-left: 0;
  padding-top: 5px;
}

@media (max-width: 543.98px) {
  .topics .imageWithText figcaption .ITC-text-underneath p {
    font-size: 0.875em;
  }
}


/* ---------------------------------------------------------------------------------------------------
以下、非表示
--------------------------------------------------------------------------------------------------- */
/* --------------------------------------------------------------------
campaign
-------------------------------------------------------------------- */
.campaign {
  position: relative;
  background-image: url("../images/retirement/for-business_noshi.jpg?$staticlink$");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: none;
}

.campaign::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
}

.campaign>* {
  position: relative;
  z-index: 1;
  /* テキストや要素を前面に */
}

.campaign .contentTitle h2 {
  color: #fff;
}

.campaign .contentTitle p {
  color: #fff;
}

/* coupon
-------------------------------------------------------------------- */
.coupon .coupon-detail {
  background: #f7f1e0;
  background: #fff;
  padding: 1rem 15px;
  margin: auto;
  max-width: 600px;
}

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

@media (max-width: 768.98px) {
  .coupon .coupon-detail h3 {
    font-size: 1.5em;
  }
}

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

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

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

.coupon .coupon-detail p em {
  font-style: unset;
  font-size: 0.8125em;
}

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

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

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

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

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

.special h2,
.special h3,
.special h4,
.special p {
  color: #ffffff;
}

.special .titleRichtextButtons .content h3 {
  font-family: "Noto Serif JP", serif !important;
  text-align: left;
}

.special .titleRichtextButtons .content h4 {
  font-size: 1.0rem;
  border: 1px solid;
  padding: 5px 10px;
  display: inline-block;
  margin-bottom: 1.0rem;
}

.special .titleRichtextButtons .content .richtext p {
  text-align: left;
}

.special .titleRichtextButtons .content .button p {
  text-align: left;
  margin-top: 0;
}

.special .titleRichtextButtons .content .button p a {
  width: fit-content;
  background-color: transparent;
  padding: 1rem 2rem;
  border: 1px solid #ffffff;
}

@media (max-width: 768.98px) {
  .special .titleRichtextButtons .content .button p a {
    width: 100%;
  }
}

.special .textbox p {
  font-size: 0.8125em;
}

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

.category .cat>.row>.col-12 {
  padding-right: 5px;
  padding-left: 5px;
}

.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;
  color: #212529 !important;
  /* font-weight: 600; */
}

@media (max-width: 768.98px) {
  .category .cat .mainbanner-sub-text a.link-large.btn.btn-dark {
    font-size: 12px;
  }
}

/* --------------------------------------------------------------------
for-business
-------------------------------------------------------------------- */
.for-business {
  display: none;
}

.for-business .mainBannerWithTextPosition {
  margin: auto;
  max-width: 940px;
}

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

/* --------------------------------------------------------------------
manners
-------------------------------------------------------------------- */
.manners {
  display: none;
  padding-top: 0;
}

.manners .titleRichtextButtons p {
  text-align: left;
}

.manners .titleRichtextButtons p strong {
  font-size: 1rem;
}

.manners .titleRichtextButtons .content .button p {
  text-align: left;
  margin-top: 0;
}

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

/* gift-service
-------------------------------------------------------------------- */
.manners .gift-service {
  margin-bottom: 40px;
}

.manners .gift-service .titleRichtextButtons .content .button p a {
  width: fit-content;
  background-color: #C7B994 !important;
  padding: 1rem 2rem;
  border: none;
}

@media (max-width: 768.98px) {
  .manners .gift-service .titleRichtextButtons .content .button p a {
    width: 100%;
  }
}

/* compensation
-------------------------------------------------------------------- */
.manners .compensation .titleRichtextButtons .content .button p a {
  color: #212529 !important;
  width: fit-content;
  background-color: transparent;
  padding: 1rem 2rem;
}

@media (max-width: 768.98px) {
  .manners .compensation .titleRichtextButtons .content .button p a {
    width: 100%;
  }
}