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

@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-bottom: 40px;
}

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

/* 左寄せ */
.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%); */
  }

  /* 左寄せ */
  .fullscreen-banner .mainBannerWithTextPosition .image-heading-container {
    position: absolute;
    top: 20% !important;
    left: 10% !important;
    transform: translateY(-50%);
  }
}

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

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

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

/* ボタン非表示 */
.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 .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;
}

/* --------------------------------------------------------------------
fathersday
-------------------------------------------------------------------- */
.fathersday {

}

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


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

.mothersday .contentTitle {
  margin-bottom: 50px;
}

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

.mothersday .contentTitle .text-center {
  text-align: center !important;
}

.mothersday .contentTitle h2 {
  position: relative;
  display: inline-block;
  /* or inline-flex, depending on layout */
  transition: 0.2s;
}

.mothersday .contentTitle h2::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -50%;
  transform: translateX(-50%);
  width: 20%;
  height: 3px;
  background-color: #980017;
}

@media (max-width: 768.98px) {
  .mothersday .contentTitle h2 {
    font-size: 1.4rem;
  }
  .mothersday .contentTitle h2::after {
    height: 2px;
  }
}

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

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

.mothersday .contentText {
  padding: 30px 0;
}

.mothersday .textbox p {
  text-align: center;
}

.mothersday .products.glass,
.mothersday .products.mug {
  margin-bottom: 0;
}


/* --------------------------------------------------------------------
point
-------------------------------------------------------------------- */
.point {
  /* padding-top: 20px;
  padding-bottom: 20px; */
}

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

@media (max-width: 543.98px) {

  .point .col-sm-4:first-child,
  .point .col-sm-4:nth-child(2) {
    /* -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
    padding-left: 10px;
    padding-right: 10px; */
  }

  .point .col-sm-4:nth-child(3) {
    /* -webkit-box-flex: 0;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    padding-left: 10px;
    padding-right: 10px; */
  }
}

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

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



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

@media (max-width: 768.98px) {
  .menu {
    /* padding-top: 0;
    padding-bottom: 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;
}

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

.scene-menu>.row>.col-12 {
  padding-right: 0;
  padding-left: 0;
}

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

.scene-menu .pageAnchor {
  background-color: #C7B994;
  margin-bottom: 20px;
}

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

.scene-menu .pageAnchor ul.menuWrap li.menuBg:first-child {
  border-image: linear-gradient(to top, transparent 0%, transparent 100%);
}

.scene-menu .pageAnchor ul.menuWrap li.menuBg {
  border-left: solid 1px transparent;
  border-image-width: 0 0 0 1px;
  border-image: linear-gradient(to top, transparent 30%, rgba(255, 255, 255, 0.7) 30%, rgba(255, 255, 255, 0.7) 70%, transparent 70%);
  border-image-slice: 1;
  transition: 0.2s;
}

.scene-menu .pageAnchor ul.menuWrap li.menuBg a {
  display: block;
  padding: 25px;
  font-size: 16px;
  color: #fff !important;
  text-align: center;
}

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

  .scene-menu .pageAnchor ul.menuWrap li.menuBg:nth-child(3),
  .scene-menu .pageAnchor ul.menuWrap li.menuBg:nth-child(5) {
    border-image: linear-gradient(to top, transparent 0%, transparent 100%);
  }

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


/* --------------------------------------------------------------------
scene
-------------------------------------------------------------------- */
.scene {
  padding-top: 0;
}


/* --------------------------------------------------------------------
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;
  /* border: 1px solid; */
  padding: 5px 10px;
  display: inline-block;
  margin-bottom: 1.0rem;
  /* background-color: #d0b67d; */
  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 a {
  pointer-events: none;
}

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

.options .etching .etching-ex .contentTitle h4 {
  margin-bottom: 1rem;
}

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

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

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

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

}

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

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

/* 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 {
  display: none;
}

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

@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;
  /* border-radius: 1rem; */
  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 .textbox p {
  text-align: right;
  font-size: 0.8125em;
  display: none;
}

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

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

/* ボタン非表示 */
.for-business .mainBannerWithTextPosition .mainbanner-sub-text {
  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;
  }
}

/* --------------------------------------------------------------------
manners
-------------------------------------------------------------------- */
.manners {
  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%;
  }
}

/* --------------------------------------------------------------------
mug
-------------------------------------------------------------------- */
.mug .textbox {
  margin: 0 auto;
  max-width: 720px;
  margin-bottom: 30px;
}

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

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

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

.mug .textbox p s {
  text-decoration: unset;
}

.mug .imageWithText .ITC-text-underneath {
  padding-right: 0;
  padding-left: 0;
}

.mug .imageWithText .ITC-text-underneath h4 {
  text-align: left;
  margin-top: 5px;
  font-size: 1.6rem;
  display: none;
}

@media (max-width: 768.98px) {
  .mug .imageWithText .ITC-text-underneath h4 {
    font-size: 1.1rem;
  }
}

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


/* ---------------------------------------------------------------------------------------------------
以下、非表示
--------------------------------------------------------------------------------------------------- */

/* --------------------------------------------------------------------
noticeDetail
-------------------------------------------------------------------- */
.noticeDetail {
  display: none;
  max-width: 940px;
}

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

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

.pickup .contentTitle p s {
  text-decoration: none;
}

/* mainImage
-------------------------------------------------------------------- */
.pickup .mainBannerWithTextPosition>.row {
  margin-right: 0;
  margin-left: 0;
}

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

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

.pickup .mainBannerWithTextPosition .image-heading-container .image-heading-text {
  padding: 15px 15px 0;
  width: fit-content;
  background: #f1f1f1;
}

.pickup .mainBannerWithTextPosition .image-heading-container .image-heading-text h3 {
  font-size: 1.8rem;
  font-family: "Noto Serif JP", serif !important;
  text-align: center;
  color: initial;
  text-align: center !important;
}

@media (max-width: 768.98px) {
  .pickup .mainBannerWithTextPosition .image-heading-container .image-heading-text {
    padding: 10px 10px 0;
  }

  .pickup .mainBannerWithTextPosition .image-heading-container .image-heading-text h3 {
    font-size: 1.2rem;
  }
}

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

/* 左寄せ */
.pickup .mainBannerWithTextPosition .image-heading-container {
  position: absolute;
  top: 50%;
  /* 上から50%の位置 */
  left: 10%;
  /* 左から10%の位置 */
  transform: translateY(-50%);
  /* その位置から縦方向に50%だけ移動 */
  width: fit-content;
}

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

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

  /* 左寄せ */
  .pickup .mainBannerWithTextPosition .image-heading-container {
    position: absolute;
    top: 15% !important;
    /* 上から15%の位置 */
    left: 5% !important;
    /* 左から5%の位置 */
    transform: translateY(-50%);
    /* その位置から縦方向に50%だけ移動 */
  }
}

/* awards
-------------------------------------------------------------------- */
.pickup .awards {
  padding-top: 20px;
}

.pickup .awards .imageTile {
  max-width: 940px;
  margin: auto;
  padding-right: 40px;
  padding-left: 40px;
}

@media (max-width: 768.98px) {
  .pickup .awards .imageTile {
    padding-right: 0;
    padding-left: 0;
  }
}

/* detail
-------------------------------------------------------------------- */
.pickup .detail .experience-commerce_layouts-mobileGrid2r1c:nth-child(2) {
  padding-top: 20px;
}

@media (max-width: 543.98px) {
  .pickup .detail .mobile-2r-1c .col-sm-6 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
    padding-right: 5px;
    padding-left: 5px;
  }
}

.pickup .detail .mobile-2r-1c .col-sm-6 {
  margin-bottom: 0;
}

.pickup .detail .textbox {
  position: absolute;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}

.pickup .detail .textbox p {
  font-size: 1.4rem;
  font-family: "Noto Serif JP", serif !important;
  text-align: center;
}

@media (max-width: 768.98px) {
  .pickup .detail .textbox p {
    font-size: 1.0rem;
  }
}

/* craftsman
-------------------------------------------------------------------- */
.pickup .craftsman {
  max-width: 940px;
  margin: auto;
  padding: 40px;
  background-color: #f2f2f2;
  margin-top: 20px;
  margin-bottom: 20px;
}

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

.pickup .craftsman .textbox h4 {
  font-size: 1.6rem;
  font-family: "Noto Serif JP", serif !important;
  text-align: left;
}

.pickup .craftsman .textbox em {
  font-size: 1.0rem;
  font-style: unset;
}

.pickup .craftsman .textbox p {
  text-align: left;
}


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