
@import url("https://fonts.googleapis.com/css2?family=Allura&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap");
@charset "UTF-8";
:root {
  --app-height: 100%;
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  outline: 0;
}
html {
  overscroll-behavior-y: contain;
}
body {
  -webkit-overflow-scrolling: touch;
}
html,
body {
  font-family: "Noto Sans JP", "Allura", "Shippori Mincho", "Noto Serif JP", Playfair Display, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #000000;
  font-variant-east-asian: proportional-width;
  font-feature-settings: "palt" 1, "pkna" 1;
  font-kerning: normal;
  scroll-behavior: smooth;
}
body.modal-open {
  padding-right: 0 !important;
}
img {
  width: 100%;
  height: 100%;
  vertical-align: middle;
  -o-object-fit: cover;
     object-fit: cover;
}
a {
  text-decoration: none;
}
a:hover {
  text-decoration: none;
}
p {
  margin-bottom: 0;
}
button {
  outline: 0;
  border: 0;
  color: black;
  font-family: "Noto Sans JP", sans-serif;
}
ol,
ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
input:-webkit-autofill {
  box-shadow: 0 0 0px 1000px #fff6e1 inset !important;
  -webkit-text-fill-color: #000 !important;
}
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin-bottom: 0;
  font-weight: 400;
}
section {
  scroll-margin-top: 64px;
}
@media screen and (min-width: 768px) {
  section {
    scroll-margin-top: 85.33px;
  }
}
@supports (-webkit-touch-callout: none) {
  section {
    scroll-margin-top: calc(64px + env(safe-area-inset-top));
  }
  @media screen and (min-width: 768px) {
    section {
      scroll-margin-top: calc(85.33px + env(safe-area-inset-top));
    }
  }
}
textarea::-moz-placeholder {
  white-space: pre-line;
}
textarea::placeholder {
  white-space: pre-line;
}
.mr-p-20-important {
  padding: 20px !important;
}
.min-height-100 {
  min-height: 100%;
}
.mr-d-none {
  display: none;
}
.mr-heading-2 {
  font-family: "Libre Baskerville", serif;
}
@media screen and (max-width: 374px) {
  .mr-heading-2 {
    font-size: 25px;
  }
  .mr-heading-2::first-letter {
    font-size: 60px;
  }
  .mr-ul {
    list-style: none;
    padding: 0;
  }
  .mr-ul li {
    padding: 0 50px;
    text-align: left;
    font-size: 13px;
  }
  .mr-ul li:before {
    content: "※";
    display: inline-block;
    margin-left: -1.3em;
    width: 1.3em;
  }
}
.container {
  max-width: 375px;
  padding: 0;
  margin: 0 auto;
}
.mr-heading-2 {
  font-size: 25px;
}
.mr-heading-2::first-letter {
  font-size: 60px;
}
.mr-ul {
  list-style: none;
  padding: 0;
}
.mr-ul li {
  padding: 0 50px;
  text-align: left;
  font-size: 13px;
}
.mr-ul li:before {
  content: "※";
  display: inline-block;
  margin-left: -1.3em;
  width: 1.3em;
}
.mr-color-red {
  color: #ff0000;
}
.mr-bgc-light-pink {
  background-color: #ffb6c1;
}
.mr-bgc-bricks {
  background-color: #d58b6e;
}
.mr-height-m-70vh {
  min-height: 70vh;
}
.mr-full-height-minus-70px {
  min-height: calc(100vh - 70px);
}
.mr-d-none {
  display: none;
}
.mr-d-block {
  display: block;
}
.img-mix-hl {
  mix-blend-mode: hard-light;
}
.img-mix-normal {
  mix-blend-mode: normal;
}
.full-width {
  width: 100% !important;
}
.w-fit {
  width: -moz-fit-content;
  width: fit-content;
}
.mr-w-100 {
  width: 100px;
}
.fs-10 {
  font-size: 10px;
}
.fs-11 {
  font-size: 11px;
}
.fs-12 {
  font-size: 12px;
}
.fs-13 {
  font-size: 13px;
}
.fs-14 {
  font-size: 14px;
}
.fs-15 {
  font-size: 15px;
}
.fs-16 {
  font-size: 16px;
}
.fs-17 {
  font-size: 17px;
}
.fs-18 {
  font-size: 18px;
}
.fs-21 {
  font-size: 21px;
}
.fs-22 {
  font-size: 22px;
}
.fs-34 {
  font-size: 34px;
}
.fs-42 {
  font-size: 42px;
}
.fw-300 {
  font-weight: 300;
}
.fw-500 {
  font-weight: 500;
}
.fw-700 {
  font-weight: 700;
}
.mr-h-47 {
  height: 47px;
}
.mr-h-105 {
  height: 105px;
}
.mr-h-305 {
  height: 305px;
}
.mr-pr-30 {
  padding-right: 30px;
}
.mr-pt-36 {
  padding-top: 36px;
}
.mr-pt-45 {
  padding-top: 45px;
}
.mr-pt-60 {
  padding-top: 60px;
}
.mr-pt-100 {
  padding-top: 100px;
}
.mr-pb-15 {
  padding-bottom: 15px;
}
.mr-pb-40 {
  padding-bottom: 40px;
}
.mr-pb-60 {
  padding-bottom: 60px;
}
.mr-pb-100 {
  padding-bottom: 100px;
}
.mr-p-0 {
  padding: 0;
}
.mr-px-0 {
  padding-left: 0px;
  padding-right: 0px;
}
.mr-px-6 {
  padding-left: 6px;
  padding-right: 6px;
}
.mr-px-8 {
  padding-left: 8px;
  padding-right: 8px;
}
.mr-px-10 {
  padding-left: 10px;
  padding-right: 10px;
}
.mr-px-15 {
  padding-left: 15px;
  padding-right: 15px;
}
.mr-px-18 {
  padding-left: 18px;
  padding-right: 18px;
}
.mr-px-20 {
  padding-left: 20px;
  padding-right: 20px;
}
.mr-px-22 {
  padding-left: 22px;
  padding-right: 22px;
}
.mr-px-24 {
  padding-left: 24px;
  padding-right: 24px;
}
.mr-px-35 {
  padding-left: 35px;
  padding-right: 35px;
}
.mr-px-38 {
  padding-left: 38px;
  padding-right: 38px;
}
.mr-px-40 {
  padding-left: 40px;
  padding-right: 40px;
}
.mr-px-50 {
  padding-left: 50px;
  padding-right: 50px;
}
.mr-px-56 {
  padding-left: 56px;
  padding-right: 56px;
}
.mr-mb-0 {
  margin-bottom: 0px;
}
.mr-mb-6 {
  margin-bottom: 6px;
}
.mr-mb-8 {
  margin-bottom: 8px;
}
.mr-mb-10 {
  margin-bottom: 10px;
}
.mr-mb-12 {
  margin-bottom: 12px;
}
.mr-mb-15 {
  margin-bottom: 15px;
}
.mr-mb-18 {
  margin-bottom: 18px;
}
.mr-mb-20 {
  margin-bottom: 20px;
}
.mr-mb-22 {
  margin-bottom: 22px;
}
.mr-mb-24 {
  margin-bottom: 24px;
}
.mr-mb-35 {
  margin-bottom: 35px;
}
.mr-mb-38 {
  margin-bottom: 38px;
}
.mr-mb-40 {
  margin-bottom: 40px;
}
.mr-mb-56 {
  margin-bottom: 56px;
}
.mr-mb-100 {
  margin-bottom: 100px;
}
.mr-mt-2 {
  margin-top: 2px;
}
.mr-mt-3 {
  margin-top: 3px;
}
.mr-mt-6 {
  margin-top: 6px;
}
.mr-mt-8 {
  margin-top: 8px;
}
.mr-mt-9 {
  margin-top: 9px;
}
.mr-mt-10 {
  margin-top: 10px;
}
.mr-mt-12 {
  margin-top: 12px;
}
.mr-mt-15 {
  margin-top: 15px;
}
.mr-mt-20 {
  margin-top: 20px;
}
.mr-mt-23 {
  margin-top: 23px;
}
.mr-mt-25 {
  margin-top: 25px;
}
.mr-mt-27 {
  margin-top: 27px;
}
.mr-mt-30 {
  margin-top: 30px;
}
.mr-mt-38 {
  margin-top: 38px;
}
.mr-mt-40 {
  margin-top: 40px;
}
.mr-mt-50 {
  margin-top: 50px;
}
.mr-mt-70 {
  margin-top: 70px;
}
.mr-mr-10 {
  margin-right: 10px;
}
.mr-mr-20 {
  margin-right: 20px;
}
.mr-ml-10 {
  margin-left: 10px;
}
.mr-ml-20 {
  margin-left: 20px;
}
.mr-mlr-20 {
  margin-left: 20px;
  margin-right: 20px;
}
.mr-mlr-16 {
  margin-left: 16px;
  margin-right: 16px;
}
.mr-ml-5 {
  margin-left: -5px;
}
.mr-mtb-10 {
  margin-top: 10px;
  margin-bottom: 10px;
}
.mr-mlr-26 {
  padding-left: 26px;
  padding-right: 26px;
}
.mr-mtb-30 {
  margin-top: 30px;
  margin-bottom: 30px;
}
.mr-line-height-11 {
  line-height: 11px;
}
.mr-line-height-17 {
  line-height: 17px;
}
.mr-line-height-20 {
  line-height: 20px;
}
.mr-shadow-lightPink {
  box-shadow: inset 0 0 0 6px #ebded6, inset 0 0 0 7px black;
}
.mr-shadow-lightGreen {
  box-shadow: inset 0 0 0 6px #cbd3cb, inset 0 0 0 7px black;
}
.mr-shadow-crimson {
  box-shadow: inset 0 0 0 6px #bf826b, inset 0 0 0 7px black;
}
.mr-shadow-grey {
  box-shadow: inset 0 0 0 6px #959595, inset 0 0 0 7px black;
}
.mr-pt-34-important {
  padding-top: 34px !important;
}
.mr-pt-90-important {
  padding-top: 90px !important;
}
.mr-mt-12-important {
  margin-top: 12px !important;
}
.mr-mb-7-important {
  margin-bottom: 7px !important;
}
.mr-mb-13-important {
  margin-bottom: 13px !important;
}
.mr-mt-35-important {
  margin-top: 35px !important;
}
.mr-h-47-important {
  height: 47px !important;
}
.mr-pl-15 {
  padding-left: 15px;
}
.mr-pr-15 {
  padding-right: 15px;
}
.mr-ph-15 {
  padding-left: 15px;
  padding-right: 15px;
}
.mr-overflow-hidden {
  overflow: hidden;
}
.mr-ec-required-custom .ec-required {
  display: inline-block;
  margin-left: 0.8em;
  vertical-align: 2px;
  color: #de5d50;
  font-size: 12px;
  background-color: #fff;
  font-weight: 500;
  padding: 0 5px;
  border-radius: 5px;
}
.mr-ec-required-custom .ec-label {
  font-size: 12px;
  line-height: 17px;
  color: #fff;
  font-weight: 700;
}
.mr-ec-required-custom .ec-errorMessage {
  margin-bottom: 25px;
  font-size: 12px;
  font-weight: bold;
  color: #de5d50;
}
button {
  cursor: pointer;
}
.btn-radius {
  margin: 0 auto;
  display: block;
  font-size: 15px;
  line-height: 17px;
  font-weight: 700;
  text-align: center;
  height: 45px;
  width: 279px;
  color: #fff;
  border-radius: 999px;
}
.btn-radius-red {
  border: 1px solid #de5d50;
  background-color: #de5d50;
}
.btn-radius-gray {
  border: 1px solid #525263;
  background-color: #525263;
}
::-moz-placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: rgba(0, 0, 0, 0.3) !important;
}
::placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: rgba(0, 0, 0, 0.3) !important;
}
:-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: rgba(0, 0, 0, 0.3) !important;
}
::-ms-input-placeholder {
  /* Microsoft Edge */
  color: rgba(0, 0, 0, 0.3) !important;
}
.mr-pt-0-im {
  padding-top: 0 !important;
}
.mr-overflow-hidden {
  overflow: hidden;
}
.mr-overflow-y-hidden {
  overflow-y: hidden !important;
}
.form-control.is-invalid {
  border-color: unset !important;
}
@media screen and (min-width: 411px) {
  .container {
    max-width: 411px;
  }
  .mr-mt-12 {
    margin-top: 12px;
  }
}
@media screen and (min-width: 414px) {
  .container {
    max-width: 414px;
  }
}
.grid-product {
  padding: 10px 30px;
  text-align: center;
  color: #707070;
}
.grid-product__item {
  padding: 10px;
}
.grid-product__item a {
  display: flex;
  flex-wrap: wrap;
  text-align: center;
}
.grid-product__item a img {
  width: 155px;
  height: 155px;
}
@media screen and (max-width: 410px) {
  .grid-product__item a img {
    width: 132px;
    height: 132px;
  }
}
@media screen and (max-width: 360px) {
  .grid-product__item a img {
    width: 125px;
    max-height: 125px;
    height: auto;
  }
}
.grid-product__item a p {
  color: #707070;
  margin: 0 14px;
}
.font-playfair {
  font-family: "Playfair Display", serif !important;
}
.font-notoSeri {
  font-family: "Noto Serif JP", serif !important;
  word-break: keep-all;
}
.font-jp {
  font-family: "Shippori Mincho", serif !important;
  word-break: keep-all;
}
.font-en {
  font-family: "Libre Baskerville", serif !important;
}
.font-btn {
  font-family: "Noto Sans JP", sans-serif !important;
}
.font-ph3 {
  font-family: "Noto Sans JP", sans-serif !important;
}
/* Loading */
.hidden {
  visibility: hidden;
}
#loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  background: rgba(0, 0, 0, 0.5019607843);
  z-index: 99999;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
#loading .loading-spin {
  border: 5px solid rgba(243, 243, 243, 0.3411764706);
  border-radius: 50%;
  border-top: 5px solid #ffffff;
  width: 60px;
  height: 60px;
  animation: spin 0.8s linear infinite;
}
/* Safari */
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* End Loading */
.section-block {
  padding: 24px 20px 30px;
  background: white;
  border-radius: 4px;
}
.bg-gradient {
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%) !important;
}
.bg-secondary {
  background: #490000;
}
.bg-yellow-2 {
  background: #fff8f3;
}
.break-anywhere {
  overflow-wrap: break-word;
  word-break: break-word;
}
.custom-scrollbar::-webkit-scrollbar {
  display: block;
  height: 8px;
  width: 8px;
}
.sm-custom-scrollbar::-webkit-scrollbar {
  display: block;
  height: 4px;
  width: 4px;
}
.custom-scrollbar::-webkit-scrollbar-track,
.sm-custom-scrollbar::-webkit-scrollbar-track {
  background-color: transparent;
}
.custom-scrollbar::-webkit-scrollbar-thumb,
.sm-custom-scrollbar::-webkit-scrollbar-thumb {
  border-radius: 9px;
  background-color: #bfbfbf;
}
.scrollbar-hide {
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
}
.scrollbar-hide::-webkit-scrollbar {
  display: none;
}
.section-container {
  padding: 60px 20px;
}
.perfect-scrollbar {
  position: relative;
  overflow: hidden;
  max-height: 100%;
  max-width: 100%;
}
@media (max-width: 767px) {
  .perfect-scrollbar {
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
  }
  .perfect-scrollbar::-webkit-scrollbar {
    width: 8px;
    height: 8px;
  }
  .perfect-scrollbar::-webkit-scrollbar-track {
    background: transparent;
  }
  .perfect-scrollbar::-webkit-scrollbar-thumb {
    background: #bfbfbf;
    border-radius: 4px;
  }
  .perfect-scrollbar::-webkit-scrollbar-thumb:hover {
    background: #a0a0a0;
  }
}
.perfect-scrollbar .ps__rail-x, .perfect-scrollbar .ps__rail-y {
  background: transparent;
  opacity: 0.6;
  transition: background 0.2s linear, opacity 0.2s linear;
  border-radius: 4px;
  z-index: 15;
}
@media (max-width: 767px) {
  .perfect-scrollbar .ps__rail-x, .perfect-scrollbar .ps__rail-y {
    display: none;
  }
}
.perfect-scrollbar .ps__thumb-x, .perfect-scrollbar .ps__thumb-y {
  background: #bfbfbf;
  border-radius: 4px;
  transition: background 0.2s linear;
  z-index: 16;
}
@media (max-width: 767px) {
  .perfect-scrollbar .ps__thumb-x, .perfect-scrollbar .ps__thumb-y {
    display: none;
  }
}
.perfect-scrollbar:hover .ps__rail-x, .perfect-scrollbar:hover .ps__rail-y {
  background: transparent;
  opacity: 1;
  width: 8px;
}
.perfect-scrollbar:hover .ps__thumb-x, .perfect-scrollbar:hover .ps__thumb-y {
  background: #a0a0a0;
  width: 8px;
}
.mr-cart-layout {
  padding: 24px 20px 100px;
}
.btn:active, .btn:focus,
.btn :focus-visible,
.btn-link:active,
.btn-link:focus,
.btn-link :focus-visible {
  outline: none !important;
  border-color: transparent !important;
}
.btn-link {
  text-decoration: none;
}
.btn-link:hover {
  text-decoration: underline;
}
.mr-btn__primary {
  width: 260px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  white-space: nowrap;
  border-radius: 60px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  background-color: #bd6856;
  border-color: #bd6856;
  color: #ffffff;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease-in-out;
}
.mr-btn__primary img {
  width: auto;
  height: auto;
}
.mr-btn__primary:focus, .mr-btn__primary.focus, .mr-btn__primary:active:focus, .mr-btn__primary:active.focus, .mr-btn__primary.active:focus, .mr-btn__primary.active.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(189, 104, 86, 0.5);
}
.mr-btn__primary:hover, .mr-btn__primary:focus, .mr-btn__primary.focus {
  color: #ffffff;
  text-decoration: none;
}
.mr-btn__primary:active, .mr-btn__primary.active, .mr-btn__primary:focus-visible {
  outline: 0;
  background-image: none;
  color: #ffffff !important;
  background-color: rgb(170.2585106383, 84.6255319149, 66.4914893617) !important;
  border-color: rgb(161.0893617021, 80.0680851064, 62.9106382979) !important;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__primary.disabled, .mr-btn__primary[disabled], fieldset[disabled] .mr-btn__primary {
  cursor: not-allowed;
  opacity: 0.65;
  box-shadow: none;
}
.mr-btn__primary:hover {
  background-color: rgb(170.2585106383, 84.6255319149, 66.4914893617);
  border-color: rgb(161.0893617021, 80.0680851064, 62.9106382979);
  color: #ffffff;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__secondary {
  width: 260px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  white-space: nowrap;
  border-radius: 60px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  background-color: #bd6856;
  border-color: #995748;
  color: #ffffff;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease-in-out;
}
.mr-btn__secondary img {
  width: auto;
  height: auto;
}
.mr-btn__secondary:focus, .mr-btn__secondary.focus, .mr-btn__secondary:active:focus, .mr-btn__secondary:active.focus, .mr-btn__secondary.active:focus, .mr-btn__secondary.active.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(189, 104, 86, 0.5);
}
.mr-btn__secondary:hover, .mr-btn__secondary:focus, .mr-btn__secondary.focus {
  color: #ffffff;
  text-decoration: none;
}
.mr-btn__secondary:active, .mr-btn__secondary.active, .mr-btn__secondary:focus-visible {
  outline: 0;
  background-image: none;
  color: #ffffff !important;
  background-color: rgb(170.2585106383, 84.6255319149, 66.4914893617) !important;
  border-color: rgb(118.32, 67.28, 55.68) !important;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__secondary.disabled, .mr-btn__secondary[disabled], fieldset[disabled] .mr-btn__secondary {
  cursor: not-allowed;
  opacity: 0.65;
  box-shadow: none;
}
.mr-btn__secondary:hover {
  background-color: rgb(170.2585106383, 84.6255319149, 66.4914893617);
  border-color: rgb(118.32, 67.28, 55.68);
  color: #ffffff;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__teal {
  width: 260px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  white-space: nowrap;
  border-radius: 60px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  background-color: #618a91;
  border-color: #618a91;
  color: #ffffff;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease-in-out;
}
.mr-btn__teal img {
  width: auto;
  height: auto;
}
.mr-btn__teal:focus, .mr-btn__teal.focus, .mr-btn__teal:active:focus, .mr-btn__teal:active.focus, .mr-btn__teal.active:focus, .mr-btn__teal.active.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(97, 138, 145, 0.5);
}
.mr-btn__teal:hover, .mr-btn__teal:focus, .mr-btn__teal.focus {
  color: #ffffff;
  text-decoration: none;
}
.mr-btn__teal:active, .mr-btn__teal.active, .mr-btn__teal:focus-visible {
  outline: 0;
  background-image: none;
  color: #ffffff !important;
  background-color: rgb(81.6683884298, 116.1880165289, 122.0816115702) !important;
  border-color: rgb(76.5578512397, 108.9173553719, 114.4421487603) !important;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__teal.disabled, .mr-btn__teal[disabled], fieldset[disabled] .mr-btn__teal {
  cursor: not-allowed;
  opacity: 0.65;
  box-shadow: none;
}
.mr-btn__teal:hover {
  background-color: rgb(81.6683884298, 116.1880165289, 122.0816115702);
  border-color: rgb(76.5578512397, 108.9173553719, 114.4421487603);
  color: #ffffff;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__coral {
  width: 260px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  white-space: nowrap;
  border-radius: 60px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  background-color: #ed7560;
  border-color: #ed7560;
  color: #ffffff;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease-in-out;
}
.mr-btn__coral img {
  width: auto;
  height: auto;
}
.mr-btn__coral:focus, .mr-btn__coral.focus, .mr-btn__coral:active:focus, .mr-btn__coral:active.focus, .mr-btn__coral.active:focus, .mr-btn__coral.active.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(237, 117, 96, 0.5);
}
.mr-btn__coral:hover, .mr-btn__coral:focus, .mr-btn__coral.focus {
  color: #ffffff;
  text-decoration: none;
}
.mr-btn__coral:active, .mr-btn__coral.active, .mr-btn__coral:focus-visible {
  outline: 0;
  background-image: none;
  color: #ffffff !important;
  background-color: rgb(233.1101694915, 87.1779661017, 61.6398305085) !important;
  border-color: rgb(231.813559322, 77.2372881356, 50.186440678) !important;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__coral.disabled, .mr-btn__coral[disabled], fieldset[disabled] .mr-btn__coral {
  cursor: not-allowed;
  opacity: 0.65;
  box-shadow: none;
}
.mr-btn__coral:hover {
  background-color: rgb(233.1101694915, 87.1779661017, 61.6398305085);
  border-color: rgb(231.813559322, 77.2372881356, 50.186440678);
  color: #ffffff;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__outline {
  width: 260px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  white-space: nowrap;
  border-radius: 60px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  background-color: #ebdcd9;
  border-color: #bd6856;
  color: #bd6856;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease-in-out;
}
.mr-btn__outline img {
  width: auto;
  height: auto;
}
.mr-btn__outline:focus, .mr-btn__outline.focus, .mr-btn__outline:active:focus, .mr-btn__outline:active.focus, .mr-btn__outline.active:focus, .mr-btn__outline.active.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(235, 220, 217, 0.5);
}
.mr-btn__outline:hover, .mr-btn__outline:focus, .mr-btn__outline.focus {
  color: #bd6856;
  text-decoration: none;
}
.mr-btn__outline:active, .mr-btn__outline.active, .mr-btn__outline:focus-visible {
  outline: 0;
  background-image: none;
  color: #bd6856 !important;
  background-color: rgb(221.8103448276, 196.9181034483, 191.9396551724) !important;
  border-color: rgb(161.0893617021, 80.0680851064, 62.9106382979) !important;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__outline.disabled, .mr-btn__outline[disabled], fieldset[disabled] .mr-btn__outline {
  cursor: not-allowed;
  opacity: 0.65;
  box-shadow: none;
}
.mr-btn__outline:hover {
  background-color: rgb(221.8103448276, 196.9181034483, 191.9396551724);
  border-color: rgb(161.0893617021, 80.0680851064, 62.9106382979);
  color: #bd6856;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__outline-black {
  width: 260px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  white-space: nowrap;
  border-radius: 60px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  background-color: #ffffff;
  border-color: #000000;
  color: #000000;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease-in-out;
}
.mr-btn__outline-black img {
  width: auto;
  height: auto;
}
.mr-btn__outline-black:focus, .mr-btn__outline-black.focus, .mr-btn__outline-black:active:focus, .mr-btn__outline-black:active.focus, .mr-btn__outline-black.active:focus, .mr-btn__outline-black.active.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.5);
}
.mr-btn__outline-black:hover, .mr-btn__outline-black:focus, .mr-btn__outline-black.focus {
  color: #000000;
  text-decoration: none;
}
.mr-btn__outline-black:active, .mr-btn__outline-black.active, .mr-btn__outline-black:focus-visible {
  outline: 0;
  background-image: none;
  color: #000000 !important;
  background-color: rgb(235.875, 235.875, 235.875) !important;
  border-color: black !important;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__outline-black.disabled, .mr-btn__outline-black[disabled], fieldset[disabled] .mr-btn__outline-black {
  cursor: not-allowed;
  opacity: 0.65;
  box-shadow: none;
}
.mr-btn__outline-black:hover {
  background-color: rgb(235.875, 235.875, 235.875);
  border-color: black;
  color: #000000;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__outline-primary {
  width: 260px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  white-space: nowrap;
  border-radius: 60px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  background-color: #ffffff;
  border-color: #bd6856;
  color: #bd6856;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  transition: all 0.3s ease-in-out;
}
.mr-btn__outline-primary img {
  width: auto;
  height: auto;
}
.mr-btn__outline-primary:focus, .mr-btn__outline-primary.focus, .mr-btn__outline-primary:active:focus, .mr-btn__outline-primary:active.focus, .mr-btn__outline-primary.active:focus, .mr-btn__outline-primary.active.focus {
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.5);
}
.mr-btn__outline-primary:hover, .mr-btn__outline-primary:focus, .mr-btn__outline-primary.focus {
  color: #bd6856;
  text-decoration: none;
}
.mr-btn__outline-primary:active, .mr-btn__outline-primary.active, .mr-btn__outline-primary:focus-visible {
  outline: 0;
  background-image: none;
  color: #bd6856 !important;
  background-color: rgb(235.875, 235.875, 235.875) !important;
  border-color: rgb(161.0893617021, 80.0680851064, 62.9106382979) !important;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.mr-btn__outline-primary.disabled, .mr-btn__outline-primary[disabled], fieldset[disabled] .mr-btn__outline-primary {
  cursor: not-allowed;
  opacity: 0.65;
  box-shadow: none;
}
.mr-btn__outline-primary:hover {
  background-color: rgb(235.875, 235.875, 235.875);
  border-color: rgb(161.0893617021, 80.0680851064, 62.9106382979);
  color: #bd6856;
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.form-input-group, .mr-select-box {
  width: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
}
.form-input-group .form-input-wrapper, .mr-select-box .form-input-wrapper {
  position: relative;
  width: 100%;
}
.form-input-group .form-input-wrapper.has-icon .form-input, .form-input-group .form-input-wrapper.has-icon .mr-select-box select, .mr-select-box .form-input-wrapper.has-icon .form-input, .mr-select-box .form-input-wrapper.has-icon select {
  padding-left: 35px;
}
.form-input-group .form-input-wrapper.has-autocomplete input, .mr-select-box .form-input-wrapper.has-autocomplete input {
  background-color: #fff6e1 !important;
}
.form-input-group .form-input-wrapper .form-input-icon, .mr-select-box .form-input-wrapper .form-input-icon {
  color: #000000;
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 1;
}
.form-input-group .form-input-wrapper .form-input-icon-right, .mr-select-box .form-input-wrapper .form-input-icon-right {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 1;
}
.form-input-group .half-input, .mr-select-box .half-input {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 8px;
}
.form-input-group .half-input .form-input, .form-input-group .half-input .mr-select-box select, .mr-select-box .half-input .form-input, .mr-select-box .half-input select {
  width: calc(50% - 4px) !important;
}
.form-input-group:has(.form-input:disabled, .mr-select-box select:disabled) .form-input-icon, .mr-select-box:has(.form-input:disabled, .mr-select-box select:disabled) .form-input-icon,
.form-input-group:has(.form-input:disabled, .mr-select-box select:disabled) .form-input-icon-right,
.mr-select-box:has(.form-input:disabled, .mr-select-box select:disabled) .form-input-icon-right {
  color: #b3b3b3;
}
.form-input-group .form-label, .mr-select-box .form-label {
  font-size: 14px;
  line-height: 17px;
  color: #000000;
  margin-bottom: 8px;
  width: -moz-fit-content;
  width: fit-content;
}
.form-input-group .form-label-extends, .mr-select-box .form-label-extends {
  font-size: 11px;
}
.form-input-group .form-input, .mr-select-box .form-input, .mr-select-box select {
  height: 36px !important;
  width: 100%;
  height: auto;
  padding: 7px 9px 10px;
  font-size: 14px;
  line-height: 1;
  color: #000000;
  background-color: #ffffff;
  border: 1px solid #d9d9d9;
  border-radius: 4px;
  transition: all 0.2s ease-in-out;
  background-image: none !important;
  caret-color: #bd6856;
}
.form-input-group .form-input::-moz-placeholder, .mr-select-box .form-input::-moz-placeholder, .mr-select-box select::-moz-placeholder {
  color: #b3b3b3;
  opacity: 1;
}
.form-input-group .form-input::placeholder, .mr-select-box .form-input::placeholder, .mr-select-box select::placeholder {
  color: #b3b3b3;
  opacity: 1;
}
.form-input-group .form-input:focus, .mr-select-box .form-input:focus, .mr-select-box select:focus {
  outline: none;
  border-color: #ebdcd9;
  box-shadow: 0 0 0 0.2rem rgba(235, 220, 217, 0.8);
}
.form-input-group .form-input:disabled, .mr-select-box .form-input:disabled, .mr-select-box select:disabled {
  background-color: #e9e9e9;
  color: #d9d9d9;
  cursor: not-allowed;
}
.form-input-group .form-input[type=password], .mr-select-box .form-input[type=password], .mr-select-box select[type=password] {
  letter-spacing: 0.64px !important;
}
.form-input-group .form-input.form-control:focus, .mr-select-box .form-input.form-control:focus, .mr-select-box select.form-control:focus {
  border-color: #ebdcd9;
  box-shadow: 0 0 0 0.2rem rgba(235, 220, 217, 0.25);
}
.form-input-group .is-invalid.form-input, .mr-select-box .is-invalid.form-input, .mr-select-box select.is-invalid, .form-input-group .is-invalid.form-control, .mr-select-box .is-invalid.form-control {
  border-color: #ed7560 !important;
  background-image: none !important;
}
.form-input-group .is-invalid.form-input:focus, .mr-select-box .is-invalid.form-input:focus, .mr-select-box select.is-invalid:focus, .form-input-group .is-invalid.form-control:focus, .mr-select-box .is-invalid.form-control:focus {
  border-color: #ed7560;
  box-shadow: 0 0 0 0.2rem rgba(237, 117, 96, 0.25);
}
.form-check {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 0;
  opacity: 1;
  transition: opacity 0.2s ease-in-out;
}
.form-check.disabled {
  opacity: 0.3;
  cursor: not-allowed !important;
}
.form-check.disabled .form-check-label {
  cursor: not-allowed !important;
}
.form-check .form-check-input {
  width: 20px;
  height: 20px;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
  background-color: transparent;
  position: relative;
  cursor: pointer;
  transition: all 0.2s ease-in-out;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
.form-check .form-check-input:checked {
  --bs-form-check-bg-image: none;
}
.form-check .form-check-input:checked {
  background-color: #ed7560;
  border-color: #ed7560;
}
.form-check .form-check-input:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 4px;
  width: 11px;
  height: 7px;
  border: 2px solid #ffffff;
  border-top: none;
  border-right: none;
  transform: rotate(-45deg);
}
.form-check .form-check-input:focus {
  outline: none;
  box-shadow: 0 0 0 0.2rem rgba(237, 117, 96, 0.25);
}
.form-check .form-check-input:disabled {
  opacity: 0.3;
  border-color: #d9d9d9;
}
.form-check .form-check-label {
  cursor: pointer;
  font-size: 14px;
  line-height: 20px;
  margin: 0;
}
.checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 20px;
  border: 1px solid #d9d9d9;
  border-radius: 4px;
  width: 100%;
}
.mr-select-box select option:first-child:not([value]),
.mr-select-box select option:first-child[value=""] {
  color: #b3b3b3;
}
.mr-select-box select:not(:focus):invalid, .mr-select-box select:not(:focus):has(option:first-child:checked) {
  color: #b3b3b3;
}
.mr-select-box select:not(:has(option:first-child:checked)) {
  color: #000000;
}
.mr-select-box select:disabled {
  background: rgba(133, 179, 174, 0.1490196078);
  text-align: center;
}
.mr-select-box:has(select:disabled) .mr-icon-select {
  display: none;
}
.mr-select-box .mr-icon-select {
  position: absolute;
  display: inline-block;
  top: 1px;
  bottom: 1px;
  width: 25px;
  right: 1px;
  z-index: 3;
  pointer-events: none;
}
.mr-select-box .mr-icon-select::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 6px solid black;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.error-message, .info-message, .info-message .invalid-feedback .form-error-message, .error-message .invalid-feedback .form-error-message {
  margin-top: 2px;
  font-size: 12px;
  line-height: 14px;
  color: #ed7560;
  display: flex;
  align-items: center;
}
.error-message + .error-message, .info-message + .error-message, .info-message .invalid-feedback .form-error-message + .error-message, .error-message + .info-message, .info-message + .info-message, .info-message .invalid-feedback .form-error-message + .info-message, .info-message .invalid-feedback .error-message + .form-error-message, .info-message .invalid-feedback .info-message + .form-error-message, .info-message .invalid-feedback .form-error-message + .form-error-message, .error-message .invalid-feedback .form-error-message + .error-message, .info-message .invalid-feedback .form-error-message .invalid-feedback .form-error-message + .error-message, .error-message .invalid-feedback .form-error-message + .info-message, .info-message .invalid-feedback .form-error-message .invalid-feedback .form-error-message + .info-message, .info-message .invalid-feedback .form-error-message .invalid-feedback .form-error-message + .form-error-message, .error-message .invalid-feedback .error-message + .form-error-message, .error-message .invalid-feedback .info-message + .form-error-message, .error-message .invalid-feedback .form-error-message + .form-error-message {
  margin-top: 0;
}
.error-message .invalid-feedback, .info-message .invalid-feedback, .info-message .invalid-feedback .form-error-message .invalid-feedback, .error-message .invalid-feedback .form-error-message .invalid-feedback {
  display: inline !important;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 0;
}
.error-message .invalid-feedback .form-error-icon, .info-message .invalid-feedback .form-error-icon {
  display: none !important;
  padding: 0 !important;
}
.error-message .invalid-feedback .form-error-message, .info-message .invalid-feedback .form-error-message {
  margin-top: 0;
}
.info-message {
  color: #000000;
}
.error-label {
  font-size: 12px;
  color: #ed7560;
  padding: 10px;
  border: 1px solid #ed7560;
  background-color: #fff0ed;
  border-radius: 2px;
}
.c-step {
  width: 100%;
  background-color: white;
  border-radius: 4px;
  padding: 12px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.c-step__circle {
  flex-shrink: 0;
  width: 58px;
  height: 58px;
}
.c-step__circle svg {
  width: 100%;
  height: 100%;
}
.c-step__content {
  font-weight: 700;
}
.c-step__title {
  font-size: 18px;
  font-weight: 700;
  line-height: 22px;
  color: #000000;
  margin: 0;
  font-weight: 700;
}
.c-step__message {
  font-size: 12px;
  line-height: 16px;
  color: #b3b3b3;
  margin-top: 4px;
  white-space: pre-line;
}
.package--out .js-form-select {
  opacity: 0.3;
  border-color: #d9d9d9;
}
.js-form-select {
  width: 100%;
  position: relative;
  gap: 10px;
  padding: 12px 10px;
  background-color: #ffffff;
  border-radius: 4px;
  cursor: pointer;
  outline: 1px solid #d9d9d9;
  outline-offset: -1px;
}
.js-form-select .c-form-select__recommend {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #ed7560;
  border-radius: 2px;
  height: 23px;
}
.js-form-select .c-form-select__recommend-text {
  font-weight: 700;
  font-size: 13px;
  line-height: 1;
  color: #ffffff;
}
.js-form-select .c-form-select__content {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  width: 100%;
  margin: 10px 0;
}
.js-form-select .c-form-select__left {
  display: flex;
  gap: 10px;
}
.js-form-select .c-form-select__radio {
  width: 26px;
  height: 26px;
}
.js-form-select .c-form-select__radio input[type=radio] {
  position: absolute;
  opacity: 0;
}
.js-form-select .c-form-select__radio-circle {
  display: block;
  width: 26px;
  height: 26px;
  border: 1px solid #d9d9d9;
  border-radius: 50%;
  background-color: #ffffff;
  position: relative;
  transition: all 0.3s ease-in-out;
}
.js-form-select .c-form-select__title {
  font-weight: 400;
  font-size: 18px;
  line-height: 26px;
}
.js-form-select .c-form-select__title--wrap {
  flex: 1;
  overflow-wrap: anywhere;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}
.js-form-select .c-form-select__right {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}
.js-form-select .c-form-select__price {
  font-size: 18px;
  line-height: 26px;
}
.js-form-select .c-form-select__price-text {
  font-size: 14px;
  line-height: 16px;
}
.js-form-select .c-form-select__period {
  font-size: 11px;
  line-height: 16px;
  color: #b3b3b3;
}
.js-form-select .c-form-select__features {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.js-form-select .c-form-select__feature {
  font-size: 12px;
  line-height: 18px;
  display: flex;
}
.js-form-select .c-form-select__feature-dot {
  display: inline-block;
}
.js-form-select .c-form-select__feature-note {
  font-size: 10px;
  line-height: 14px;
}
.js-form-select .c-form-select:has(input[type=radio]:disabled) {
  opacity: 0.3;
  cursor: not-allowed;
  border-color: #d9d9d9;
}
.js-form-select:has(input[type=radio]:checked) {
  outline: 2px solid #ed7560;
  outline-offset: -2px;
}
.js-form-select:has(input[type=radio]:checked) .c-form-select__radio-circle {
  border: none;
  background-image: url("../img/checked.png");
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: center;
}
.form-message {
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: #272f31;
  border-radius: 2px;
  color: white;
}
.form-message__title {
  font-size: 18px;
  line-height: 22px;
  font-weight: 700;
}
.form-message__message {
  font-size: 12px;
  line-height: 14px;
}
.pulldown-container {
  position: relative;
  width: 100%;
}
.pulldown-trigger {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.pulldown-input {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-left: 10px;
  height: 36px;
  background: white;
  border: 1px solid #d9d9d9;
  border-radius: 4px;
  transition: border-color 0.3s ease;
}
.pulldown-container[data-open] .pulldown-input {
  border-color: #ed7560;
}
.pulldown-placeholder {
  font-size: 14px;
  line-height: 1.45;
  color: #b3b3b3;
  flex: 1;
}
.pulldown-placeholder.selected {
  color: #000000;
}
.pulldown-arrow {
  width: 26px;
  height: 35px;
  background: #ed7560;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  transition: transform 0.3s ease;
  border-radius: 0 4px 4px 0;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
.pulldown-container[data-open] .pulldown-arrow svg {
  transform: rotate(180deg);
}
.pulldown-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: white;
  border: 1px solid #d9d9d9;
  border-top: none;
  border-radius: 0 0 4px 4px;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-10px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1000;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  will-change: transform, opacity, max-height;
  backface-visibility: hidden;
}
.pulldown-container[data-open] .pulldown-dropdown {
  max-height: 410px;
  opacity: 1;
  transform: translateY(0);
}
.pulldown-options {
  padding: 8px 0;
}
.pulldown-option {
  padding: 8px 12px;
  font-size: 14px;
  line-height: 1.45;
  color: #000000;
  cursor: pointer;
  transition: background-color 0.2s ease;
  will-change: background-color;
  transform: translate3d(0, 0, 0);
}
.pulldown-option:hover {
  background-color: #e9e9e9;
}
.pulldown-option.selected {
  background-color: #ed7560;
  color: white;
}
.pulldown-select {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  height: 0;
  width: 0;
}
/* Animation for smooth slide up effect */
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translate3d(0, -10px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
.pulldown-container[data-open] .pulldown-dropdown {
  animation: slideUp 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.custom-carousel .owl-stage {
  padding-bottom: 16px;
}
.custom-carousel .owl-item {
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  border-radius: 4px;
  overflow: hidden;
}
.custom-carousel .js-carousel__item {
  background-color: white;
  width: 270px;
  height: 200px;
  overflow: hidden;
}
.custom-carousel .carousel__button {
  display: flex;
  gap: 10px;
}
.custom-carousel .carousel__button-prev, .custom-carousel .carousel__button-next {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 13px;
  background-color: white;
  color: #ed7560;
  transition: all 0.3s ease;
}
.custom-carousel .carousel__button-prev:hover, .custom-carousel .carousel__button-next:hover {
  background-color: #e9e9e9;
}
.custom-carousel .carousel__button-prev img, .custom-carousel .carousel__button-next img {
  width: 5px;
  height: 10px;
}
.custom-carousel .carousel__button-next {
  transform: rotate(180deg);
}
.modal {
  background-color: rgba(0, 0, 0, 0.5);
}
.modal .modal-dialog {
  padding: 20px 20px 0;
}
.mr-modal.modal {
  padding-right: 0 !important;
  color: white !important;
  width: 100%;
  margin: 0 auto;
  position: fixed;
  top: 0;
  bottom: 0;
  z-index: 1000;
}
.mr-modal.modal.fade .modal-dialog {
  transition: none !important;
  transform: none !important;
}
.mr-modal .modal-close__button {
  position: absolute;
  top: -26px;
  right: 0;
}
.mr-modal .modal-close__button button {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 6px;
}
.mr-modal .modal-close__button-text {
  font-size: 14px;
  font-weight: 700;
  color: #ffffff;
  line-height: 20px;
}
.mr-modal .modal-close__button img {
  width: 17px;
  height: 17px;
}
.mr-modal .modal-dialog {
  margin: 0 auto;
  padding: 20px 20px 0;
  height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
}
.mr-modal .modal-content {
  margin-top: 46px !important;
  border-radius: 4px;
  margin: 0;
  border: 0;
  width: 100%;
  max-height: calc(100vh - 46px);
  display: flex;
  flex-direction: column;
  position: relative;
}
.mr-modal .modal-header {
  display: flex;
  justify-content: flex-end;
  padding: 20px 20px 0;
  border: none;
  background: transparent;
  flex-shrink: 0;
}
.mr-modal .modal-header__close-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  cursor: pointer;
}
.mr-modal .modal-header__close-buttons {
  display: flex;
  gap: 0;
}
.mr-modal .modal-header__close-button {
  width: 17px;
  height: 17px;
  background: #ffffff;
  border-radius: 50%;
}
.mr-modal .modal-header__close-text {
  font-weight: 700;
  font-size: 14px;
  line-height: 1.45;
  letter-spacing: 1.12px;
  color: #ffffff;
}
.mr-modal .modal-title {
  font-size: 14px;
  font-weight: 700;
}
.mr-modal .modal-body {
  background: transparent;
  padding: 30px 20px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
.mr-modal .modal-footer {
  position: absolute;
  display: flex;
  justify-content: center;
  bottom: 0vh;
  left: 50%;
  transform: translate(-50%);
  border: none;
  border-top: none;
}
.modal.mr-modal-full .modal-dialog {
  max-width: 375px;
  margin: auto;
}
.modal-backdrop {
  background-color: rgba(0, 0, 0, 0.7) !important;
  z-index: 1 !important;
}
.apero-modal {
  overflow: hidden;
}
.apero-modal .modal-content {
  min-height: 600px;
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
.apero-modal .modal-body .section-header {
  margin-bottom: 0;
}
.apero-modal .modal-body__description {
  margin-top: 24px;
  font-family: "Shippori Mincho", serif;
  color: white;
  font-size: 14px;
  line-height: 23px;
  margin-bottom: 24px;
  white-space: nowrap;
  letter-spacing: -1.3px;
  text-align: center;
}
.apero-modal .modal-body__image {
  width: 100%;
  aspect-ratio: 335/188.44;
  border-radius: 4px;
  overflow: hidden;
}
.apero-modal .modal-body__description-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin: 24px 0;
  color: white;
  font-size: 14px;
  line-height: 23px;
  font-weight: 500;
}
.apero-modal .modal-body__apero-types {
  background: white;
  border-radius: 4px;
  padding: 15px 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.apero-modal .modal-body__apero-type {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.apero-modal .modal-body__apero-type-number {
  width: 24px;
  height: 24px;
  background: #bd6856;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.apero-modal .modal-body__apero-type-number-text {
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 17px;
  line-height: 1.65;
  color: white;
}
.apero-modal .modal-body__apero-type-description {
  font-weight: 500;
  font-size: 14px;
  line-height: 22px;
  color: #bd6856;
}
.apero-modal .modal-body__footer {
  margin-top: 24px;
  display: flex;
  justify-content: center;
}
.apero-modal .modal-body__footer-content {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 8.5px;
}
.apero-modal .modal-body__footer-icon {
  width: 22px;
  height: 25px;
}
.apero-modal .modal-body__footer-text {
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 18px;
  line-height: 28px;
  color: white;
}
.mr-accordion {
  font-family: "Shippori Mincho", serif;
  background: white;
  border-radius: 4px;
  padding: 20px 20px 20px 19px;
}
.mr-accordion .accordion-item {
  overflow: hidden;
  border: none;
  border-bottom: 1px solid black;
  border-radius: 0px !important;
}
.mr-accordion .accordion-header {
  border: none;
  padding: 0;
}
.mr-accordion__header {
  text-align: center;
  margin-bottom: 30px;
}
.mr-accordion__title {
  font-weight: 700;
  font-size: 32px;
  line-height: 46px;
  color: #bd6856;
}
.mr-accordion__subtitle {
  font-weight: 500;
  font-size: 18px;
  line-height: 26px;
}
.mr-accordion__action {
  border-top: 1px solid black;
}
.mr-accordion__action-content {
  display: flex;
  align-items: center;
  gap: 5px;
}
.mr-accordion .accordion-button {
  width: 100%;
  background: transparent !important;
  border: none !important;
  padding: 12px 0 15px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  transition: all 0.3s ease;
  box-shadow: none !important;
}
.mr-accordion .accordion-button:focus {
  box-shadow: none !important;
  outline: none;
}
.mr-accordion .accordion-button::after {
  display: none;
}
.mr-accordion .accordion-button svg {
  transition: all 0.3s ease;
}
.mr-accordion__action-icon {
  display: flex;
  align-items: center;
  gap: 5px;
}
.mr-accordion__action-text {
  font-weight: 700;
  font-size: 16px;
  line-height: 23px;
}
.mr-accordion__body {
  height: 0;
  overflow: hidden;
  white-space: nowrap;
  transition: all 0.3s ease;
  border-bottom: 1px solid black;
}
.mr-accordion__content {
  display: flex;
  justify-content: center;
  gap: 4px;
  padding: 20px 14px 32px;
}
.mr-accordion__paragraph {
  font-weight: 400;
  font-size: 14px;
  line-height: 14px;
  color: black;
  width: 20px;
  writing-mode: vertical-rl;
  text-orientation: upright;
}
.mr-accordion__paragraph--empty {
  width: 10px;
}
.mr-accordion .active .mr-accordion__action-content {
  color: #bd6856;
}
.mr-accordion .active .mr-accordion__action-icon svg {
  transform: rotate(180deg);
}
.mr-accordion .active .mr-accordion__action-icon svg rect {
  fill: #bd6856;
  stroke: #bd6856;
}
.mr-accordion .active .mr-accordion__action-icon svg path {
  stroke: white;
}
.section-header {
  text-align: center;
  margin-bottom: 36px;
}
.section-header.type-default .section-title {
  margin-bottom: 10px;
  font-family: "Allura", serif;
  font-size: 24px;
  line-height: 30px;
}
.section-header.type-default .section-subtitle {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  gap: 2px;
  margin: 0 auto;
}
.section-header.type-default .section-subtitle__main {
  font-family: "Shippori Mincho", serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 32px;
}
.section-header.type-default .section-subtitle__lines {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
}
.section-header.type-default .section-subtitle__lines .line {
  width: 100%;
  height: 1px;
  background-color: #bd6856;
}
.section-header.type-about {
  color: white;
}
.section-header.type-about .section-title {
  font-family: "Allura", serif;
  height: 23px;
  color: inherit;
  line-height: 23px;
  font-weight: 400;
}
.section-header.type-about .section-subtitle {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.section-header.type-about .section-subtitle__main, .section-header.type-about .section-subtitle__description {
  font-family: "Shippori Mincho", serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 32px;
  color: inherit;
  text-align: center;
}
.section-header.type-about .section-subtitle svg {
  color: inherit;
  width: 62px;
  height: 15px;
}
.chapter {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.chapter-title {
  writing-mode: vertical-lr;
  font-size: 20px;
  line-height: 22px;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 1.5px;
  text-align: justify;
  font-weight: 700;
  white-space: nowrap;
}
.chapter .rotate-group {
  transform-origin: 39.5px 39.5px;
  animation: spin 7s linear infinite;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.date-badge {
  width: 100%;
}
.date-content {
  padding: 10px 0;
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 4px;
  background: #bd6856;
  border-radius: 4px;
  color: white;
  font-family: "Shippori Mincho", serif;
}
.date-content .year {
  display: inline-block;
  width: 76px;
  height: 38px;
  border: 1px solid white;
  font-size: 24px;
  line-height: 35px;
  text-align: center;
  padding-bottom: 3px;
}
.date-content .month {
  display: inline-block;
  width: 48px;
  height: 38px;
  background-color: white;
  font-size: 24px;
  line-height: 35px;
  color: #bd6856;
  text-align: center;
  border: 1px solid #bd6856;
}
.selection-item {
  max-width: 100%;
  min-height: 50px;
  outline: 2px solid #d9d9d9;
  cursor: pointer;
}
.selection-item .selection-item__content {
  display: flex;
  align-items: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
  cursor: pointer;
}
.selection-item .selection-item__content .selection-item__icon {
  width: 26px;
  height: 26px;
}
.selection-item .selection-item__content .selection-item__image {
  width: 100%;
  height: 100%;
}
.selection-item .selection-item__content .selection-item__text {
  font-size: 14px;
  line-height: 100%;
}
.form-radio {
  outline: 1px solid #d9d9d9;
}
.form-radio .c-form-select {
  width: 100%;
  cursor: pointer;
}
.form-radio .c-form-select__top {
  display: flex;
  align-items: center;
  gap: 10px;
}
.form-radio .c-form-select__title {
  font-size: 14px;
  line-height: 20px;
}
.form-radio .c-form-select__image {
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 10px;
  flex-shrink: 0;
}
.form-radio .c-form-select__image img {
  display: flex;
  width: 74.65px;
  height: 98.38px;
}
.form-radio:has(input[type=radio]:disabled),
.form-radio .c-form-select:has(input[type=radio]:disabled) {
  opacity: 0.3;
  border-color: #d9d9d9;
}
.form-radio:has(input[type=radio]:checked:disabled),
.form-radio .c-form-select:has(input[type=radio]:checked:disabled) {
  opacity: 1 !important;
  outline: none;
  color: black;
}
.form-radio:has(input[type=radio]:checked:disabled) {
  background: rgba(133, 179, 174, 0.1490196078) !important;
}
.form-radio:has(input[type=radio]:checked:disabled) .c-form-select__radio-circle {
  background-image: url(../img/checked_bg_teal.png);
}
.layout-wrapper {
  background: url("../img/bg_back_pc.png") no-repeat center center;
  background-size: cover;
  width: auto;
  position: relative;
}
.layout-wrapper:before {
  content: "";
  position: fixed;
  inset: 0; /* shorthand cho top:0; right:0; bottom:0; left:0 */
  z-index: 1;
  background-image: url("../img/bg_front_pc.png");
  background-repeat: repeat-x;
  background-size: cover;
  animation: scroll-bg 60s linear infinite;
}
@media screen and (min-width: 768px) {
  .layout-wrapper:before {
    background-size: 110% 100%;
  }
}
@media screen and (min-width: 768px) {
  .layout-wrapper {
    min-width: 100vw;
    width: -moz-max-content;
    width: max-content;
  }
}
.layout-wrapper__decorate-topright {
  position: fixed;
  top: 0;
  right: 0;
  width: 147px;
  height: 242px;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .layout-wrapper__decorate-topright {
    position: absolute;
  }
}
.layout-wrapper__decorate-bottomleft {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 325px;
  height: 274px;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .layout-wrapper__decorate-bottomleft {
    position: absolute;
    z-index: 1;
  }
}
.layout-container {
  position: relative;
  margin: 0 auto;
  display: flex;
  gap: 54px;
}
@media screen and (min-width: 768px) {
  .layout-container {
    min-width: 1280px;
    flex-direction: row;
    justify-content: center;
  }
}
.layout-aside {
  position: relative;
  z-index: 1;
  display: none;
  visibility: hidden;
  margin-top: 80px;
  gap: 50px;
}
@media screen and (min-width: 768px) {
  .layout-aside {
    display: flex;
    visibility: visible;
  }
}
.layout-aside__nav {
  width: 300px;
}
.layout-aside__logo {
  display: block;
  width: 190px;
  height: 65.7px;
}
.layout-aside__social {
  display: flex;
  gap: 17px;
  margin: 30px 0;
}
.layout-aside__social-link {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background-color: black;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}
.layout-aside__social-link:hover {
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
}
.layout-aside__text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  line-height: 22px;
  font-weight: 500;
  writing-mode: vertical-lr;
  width: 100%;
  letter-spacing: 4.1px;
}
.layout-aside__text p {
  width: 18px;
}
.layout-content {
  margin: 0 auto;
  position: relative;
  z-index: 10;
  overflow: hidden;
  width: 100%;
}
@media screen and (min-width: 414px) {
  .layout-content {
    width: unset;
  }
}
@media screen and (min-width: 768px) {
  .layout-content {
    margin: 0;
    height: calc(100vh - 15px);
    overflow: unset;
    border-left: 5px solid black;
    border-right: 5px solid black;
    width: 500px;
  }
}
@media screen and (min-width: 1280px) {
  .layout-content {
    height: 100vh;
  }
}
.layout-content .header-section {
  width: 100%;
  position: relative;
  z-index: 10;
}
.layout-content__container {
  max-width: 414px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 414px) {
  .layout-content__container {
    width: 414px;
  }
}
@media screen and (min-width: 768px) {
  .layout-content__container {
    max-width: unset;
    width: 100%;
  }
}
.layout-content__container .main {
  flex: 1;
  background: white;
  margin-top: 64px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .layout-content__container .main {
    margin-top: 85px;
  }
}
.layout-content__decorate {
  position: absolute;
  bottom: 69px;
  right: -117px;
  transform: rotate(90deg);
  font-family: "Allura", serif;
  font-size: 36px;
  line-height: 60px;
  animation: translateY 1s linear infinite;
  will-change: transform;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.layout-content__decorate svg {
  transform: rotate(-90deg);
}
@keyframes translateY {
  0% {
    transform: translate3d(0, 0, 0) rotate(90deg) translateX(0);
  }
  100% {
    transform: translate3d(0, 0, 0) rotate(90deg) translateX(6px);
  }
}
@keyframes scroll-bg {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 101% 0;
  }
}
.header {
  height: 64px;
  background-color: white;
  top: 0;
  width: 100%;
  position: fixed;
  top: 0;
  z-index: 10;
}
@media screen and (min-width: 414px) {
  .header {
    max-width: 414px;
  }
}
@media screen and (min-width: 768px) {
  .header {
    height: 85.33px;
    max-width: 500px;
  }
}
.header__container {
  height: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 15px;
}
@media screen and (min-width: 768px) {
  .header__container {
    padding: 13px 20px;
  }
}
.header__logo {
  width: 127px;
  height: 44px;
}
@media screen and (min-width: 768px) {
  .header__logo {
    width: 169.33px;
    height: 60px;
  }
}
.header__actions {
  display: flex;
  align-items: center;
  gap: 10px;
}
.header__actions-login {
  width: 88px;
  height: 34px;
  padding: 3px;
  gap: 3.5px;
  font-size: 12px;
  justify-content: left;
  box-shadow: none !important;
}
@media screen and (min-width: 768px) {
  .header__actions-login {
    width: 117.33px;
    height: 45.33px;
    padding: 3.67px;
    gap: 4.67px;
    font-size: 16px;
  }
  .header__actions-login img {
    width: 36px;
    height: 36px;
  }
}
.header__actions-mypage {
  width: 99px;
  height: 34px;
  padding: 3px;
  gap: 3.5px;
  font-size: 12px;
  justify-content: left;
  box-shadow: none !important;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .header__actions-mypage {
    width: 132px;
    height: 45.33px;
    padding: 3.67px;
    gap: 4.67px;
    font-size: 16px;
  }
  .header__actions-mypage img {
    width: 36px;
    height: 36px;
  }
}
.header__actions--menu {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background: transparent;
  color: #bd6856;
  font-family: "Shippori Mincho", serif;
}
@media screen and (min-width: 768px) {
  .header__actions--menu {
    display: none;
  }
}
.header__actions--menu-text {
  font-size: 10px;
  line-height: 14px;
  font-weight: 700;
}
.header__actions--menu.menu-active .header__actions--menu-text {
  margin-top: -12px;
  margin-bottom: 2px;
}
.header__actions--menu.menu-active .hamburger-line {
  border-radius: 0;
}
.header__actions--menu.menu-active .hamburger-line:nth-child(1) {
  margin-top: 6px;
  transform: rotate(135deg) translate3d(0, 0, 0);
}
.header__actions--menu.menu-active .hamburger-line:nth-child(2) {
  opacity: 0;
}
.header__actions--menu.menu-active .hamburger-line:nth-child(3) {
  margin-top: -16px;
  transform: rotate(-135deg) translate3d(0, 0, 0);
}
.header__actions--hamburger-icon {
  width: 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
}
.header__actions--hamburger-icon .hamburger-line {
  height: 6px;
  background-color: #bd6856;
  border-radius: 0px 2px 2px 0px;
  transition: all 0.3s ease-in-out;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  will-change: transform, opacity;
}
.header__menu-overlay {
  position: absolute;
  top: 64px;
  left: 0;
  height: calc(100vh - 64px);
  overflow: hidden;
  width: 100%;
  visibility: hidden;
}
.header__menu-overlay:has(.js-header__menu.active) {
  visibility: visible;
}
.js-header__menu {
  padding: 24px;
  background: #f3edd8;
  position: absolute;
  width: 100%;
  left: calc(-100% - 5px);
  transition: all 0.3s ease-in-out;
  z-index: 99;
  overflow-x: hidden;
  overflow-y: auto;
  height: 100%;
}
@media screen and (min-width: 768px) {
  .js-header__menu {
    display: none;
  }
}
.js-header__menu.active {
  left: 0;
}
.js-header__menu .sidebar__nav {
  width: auto;
}
.unread-news {
  position: absolute;
  width: 15px;
  height: 15px;
  background: #f00;
  border-radius: 50px;
  font-size: 14px;
  text-align: center;
  top: 20px;
  right: 15px;
}
.unread-news {
  position: absolute;
  width: 15px;
  height: 15px;
  background: #f00;
  border-radius: 50px;
  font-size: 14px;
  text-align: center;
  top: 20px;
  right: 15px;
}
.news-noti {
  display: none;
  position: fixed;
  max-height: 80vh;
  top: 70px;
  color: #000;
  border-radius: 5px;
  font-weight: normal;
}
.news-noti .news-wrap {
  position: absolute;
  width: 70%;
  right: 30px;
  box-shadow: 0 5px 9px 1px rgba(0, 0, 0, 0.0117647059);
  border: 1px solid rgba(112, 112, 112, 0.0784313725);
}
.news-noti .news-list {
  overflow-y: scroll;
  max-height: calc(80vh - 50px);
  width: 100%;
  right: 30px;
  background: #490000;
}
.news-noti .news-item {
  width: 100%;
  border-bottom: 1px solid rgba(112, 112, 112, 0.0784313725);
  padding: 20px 20px 20px 30px;
}
.news-noti .news-content {
  text-align: left;
}
.news-noti .news-content .title {
  font-size: 17px;
  display: flex;
}
.news-noti .news-content .detail {
  display: none;
  margin-top: 20px;
  font-size: 10px;
}
.news-noti .news-noti-bottom {
  right: 30px;
  height: 50px;
  font-size: 15px;
  width: 100%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.news-noti .news-noti-bottom u {
  cursor: pointer;
}
.news-noti .news-noti-bottom u:hover {
  color: blue;
}
.triangle-bell {
  display: none;
}
.triangle-bell::after, .triangle-bell::before {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
}
.triangle-bell:before {
  margin-top: -8px;
  margin-left: 6px;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-bottom: 20px solid rgba(112, 112, 112, 0.0784313725);
}
.triangle-bell:after {
  margin-top: -7px;
  margin-left: 7px;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 20px solid #fff;
}
.mr-bell,
#js-news-noti {
  visibility: hidden;
}
/* ===== Footer Section ===== */
.footer-section {
  background-color: #272f31;
  color: #ffffff;
  position: relative;
  overflow: hidden;
  z-index: 0;
}
.footer-section .footer-inner__top {
  margin-top: 30px;
}
.footer-section .footer-inner__top-image {
  width: 100%;
  height: 100%;
}
.footer-section .footer-inner__bottom {
  margin: 18px 21px 27px;
  display: flex;
  justify-content: space-between;
}
.footer-section .footer-inner .mr-policies {
  margin: 0;
}
.footer-section .footer-inner .mr-policies__item {
  position: relative;
  margin-bottom: 4px;
  padding-left: 10px;
  height: 19px;
}
.footer-section .footer-inner .mr-policies__item:last-child {
  margin-bottom: 0;
}
.footer-section .footer-inner .mr-policies__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 4px;
  height: 4px;
  background-color: #ffffff;
  border-radius: 50%;
}
.footer-section .footer-inner .mr-policies__link {
  display: block;
  color: #ffffff;
  font-size: 13px;
  line-height: 19px;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}
.footer-section .footer-inner .mr-policies__link:hover {
  opacity: 0.8;
  text-decoration: underline;
}
.footer-section .footer-inner .footer-social {
  display: flex;
  gap: 12px;
}
.footer-section .footer-inner .footer-social__item {
  width: 36px;
  height: 36px;
  background-color: #56674e;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease-in-out;
}
.footer-section .footer-inner .footer-social__item:hover {
  background-color: rgb(61.7679558011, 73.9779005525, 56.0220994475);
}
.footer-section .footer-inner {
  /* ===== Footer Registration Info ===== */
}
.footer-section .footer-inner .footer-registration {
  margin-top: 50px;
  text-align: center;
}
.footer-section .footer-inner .footer-registration__text {
  font-size: 12px;
  font-weight: 400;
  line-height: 17px;
}
.footer-section .footer-inner .footer-logo {
  margin: 0 auto;
  width: 150px;
  height: 51.82px;
}
.footer-section .footer-inner .footer-logo__link {
  display: block;
  width: 100%;
  height: 100%;
}
.footer-section .footer-inner .footer-logo__image {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.footer-section .footer-inner {
  /* ===== Footer Copyright ===== */
}
.footer-section .footer-inner .footer-copyright {
  margin-top: 50px;
  height: 24px;
  background: #000000;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  line-height: 14px;
}
.sidebar__container {
  width: 100%;
}
.sidebar__nav {
  width: 300px;
  margin: auto;
}
@media screen and (min-width: 768px) {
  .sidebar__nav {
    width: auto;
  }
}
.sidebar__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
  font-family: "Shippori Mincho", serif;
  letter-spacing: -0.5px;
}
@media screen and (min-width: 768px) {
  .sidebar__menu {
    gap: 12px;
  }
}
.sidebar__menu-item {
  width: 100%;
  padding-bottom: 9px;
  border-bottom: 1px solid #d19a8e;
}
@media screen and (min-width: 768px) {
  .sidebar__menu-item {
    padding-bottom: 12px;
  }
}
.sidebar__menu-item--has-submenu__menu-item--has-submenu {
  margin-bottom: 20px;
}
.sidebar__menu-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 5px;
  text-decoration: none;
  color: #000000;
  width: 100%;
  transition: all 0.3s ease-in-out;
}
.sidebar__menu-link:hover {
  color: #bd6856;
}
.sidebar__menu-text {
  font-weight: 800;
  font-size: 17px;
  line-height: 25px;
}
@media screen and (min-width: 768px) {
  .sidebar__menu-text {
    font-size: 18px;
    line-height: 26px;
  }
}
.sidebar__menu-icon {
  width: 6px;
  height: 12px;
}
.sidebar__submenu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px 16px;
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .sidebar__submenu {
    gap: 16px;
  }
}
.sidebar__submenu-item {
  position: relative;
  width: calc(50% - 8px);
}
.sidebar__submenu-item:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background-color: #e1a779;
  border-radius: 50%;
}
.sidebar__submenu-link {
  text-decoration: none;
  color: #000000;
  margin-left: 11px;
  display: block;
  height: 20px;
}
.sidebar__submenu-link:hover {
  color: #bd6856;
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .sidebar__submenu-link {
    height: 16px;
  }
}
.sidebar__submenu-text {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
  height: 20px;
  transition: all 0.3s ease-in-out;
  letter-spacing: -1.5px;
  display: block;
}
@media screen and (min-width: 768px) {
  .sidebar__submenu-text {
    font-size: 16px;
    line-height: 16px;
    height: 16px;
  }
}
.sidebar__submenu-text:hover {
  color: #bd6856;
  text-decoration: underline;
}
.sidebar__actions {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin: 24px auto 0;
  width: 260px;
}
@media screen and (min-width: 768px) {
  .sidebar__actions {
    margin-top: 27px;
  }
}
.sidebar__actions__store-code {
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  font-family: "Shippori Mincho", serif;
}
#voices .voices-inner {
  padding: 10px 20px;
}
#voices .voices-inner .enjoy-text {
  margin-bottom: -10px;
}
#voices .message {
  position: relative;
  height: 335px;
  margin: 0 -10px;
}
#voices .message-item {
  position: absolute;
  padding: 15px;
  border-radius: 16px;
  background-color: #FFF;
  font-weight: normal;
  font-size: 10px;
  color: #3B3B3B;
  letter-spacing: 0;
  box-shadow: 0px 5px 6px rgba(0, 0, 0, 0.1882352941);
}
#voices .message-item:before {
  content: "";
  position: absolute;
  right: 30px;
  top: 89%;
  width: 0;
  height: 0;
  border-top: 35px solid #ffffff;
  border-right: 21px solid rgba(255, 0, 0, 0);
  transform: rotate(13deg);
}
#voices .message-item-1 {
  top: 12px;
  right: 28px;
  z-index: 3;
  width: 52%;
}
#voices .message-item-2 {
  top: 57px;
  z-index: 2;
  width: 58%;
}
#voices .message-item-2:before {
  left: 35px;
  transform: rotate(-44deg);
  top: 81%;
}
#voices .message-item-3 {
  top: 124px;
  right: 0;
  z-index: 1;
  width: 62%;
  padding-left: 15px;
}
#voices .message-item-4 {
  top: 225px;
  z-index: 1;
  width: 80%;
}
#voices .message-item-4:before {
  left: 35px;
  transform: rotate(-44deg);
  top: 76%;
}
#voices .twitter {
  padding: 0 0 15px 0;
}
#voices .twitter img {
  padding-right: 10px;
}
#voices .twitter p {
  font-size: 14px;
  padding-top: 5px;
  color: #3B3B3B;
  font-weight: bold;
}
.banner-top__section {
  padding-bottom: 50px;
}
.banner-top__inner {
  min-height: 650px;
  position: relative;
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
@media screen and (min-width: 768px) {
  .banner-top__inner {
    min-height: 825px;
  }
}
.banner-top__text {
  padding: 40px 0 0 40px;
  writing-mode: vertical-lr;
  font-size: 20px;
  line-height: 23px;
  font-weight: 500;
  color: white;
  font-family: "Shippori Mincho", serif;
  position: relative;
  z-index: 9;
  letter-spacing: 3px;
  animation: blur 2s linear;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .banner-top__text {
    font-size: 26.67px;
    line-height: 30.67px;
    padding: 53.33px 0 0 53.33px;
  }
}
.banner-top__text p {
  width: 20px;
}
@media screen and (min-width: 768px) {
  .banner-top__text p {
    width: 26.67px;
  }
}
.banner-top__text p:nth-child(2) {
  margin: 0 20px 0 22px;
}
@media screen and (min-width: 768px) {
  .banner-top__text p:nth-child(2) {
    margin: 0 26.67px 0 29.33px;
  }
}
.banner-top__text p:nth-child(3) {
  letter-spacing: 8px;
}
.banner-top__text-highlight {
  font-size: 27px;
  line-height: 28.4px;
  filter: drop-shadow(0 0 10px rgb(255, 255, 255));
  animation: blur 1.5s linear 1s;
}
@media screen and (min-width: 768px) {
  .banner-top__text-highlight {
    font-size: 36px;
    line-height: 37.87px;
  }
}
.banner-top__text-line {
  width: 0.9px;
  height: 44px;
  background-color: white;
  margin: -10px 0 3px 0;
  display: inline-block;
}
@media screen and (min-width: 414px) {
  .banner-top__text-line {
    height: 30px;
    margin: -4px 0 3px 0;
  }
}
@media screen and (min-width: 768px) {
  .banner-top__text-line {
    height: 72px;
    margin: -10px 0 3px 0;
  }
}
.banner-top__img-center {
  position: absolute;
  top: 189.6px;
  left: 24.416%;
  z-index: 9;
  filter: drop-shadow(0 60px 19px rgba(0, 0, 0, 0.2));
  animation: spin-center 2s linear;
  will-change: transform, filter;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
@media screen and (min-width: 768px) {
  .banner-top__img-center {
    top: 252.8px;
    left: 122px;
    width: 258px;
    aspect-ratio: 1/1;
  }
}
.banner-top__img-left {
  position: absolute;
  width: 106px;
  height: 173px;
  top: 335px;
  left: 0;
  animation: blur 2s linear;
}
@media screen and (min-width: 768px) {
  .banner-top__img-left {
    width: 141.33px;
    height: 229.33px;
    top: 446.67px;
  }
}
.banner-top__img-right {
  position: absolute;
  width: 109px;
  height: 183px;
  top: 129px;
  right: 0;
  animation: blur 2s linear;
}
@media screen and (min-width: 768px) {
  .banner-top__img-right {
    width: 145.33px;
    height: 244px;
    top: 172px;
  }
}
.banner-top__img-bottom {
  position: absolute;
  bottom: -45px;
  left: 0;
  right: 0;
  height: 101px;
}
.banner-top__welcome {
  position: absolute;
  bottom: 45px;
  left: 50%;
  transform: translateX(-50%);
  width: 280px;
  height: 137px;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 6px;
  color: white;
}
.banner-top__welcome.welcome-user {
  height: 107px;
}
.banner-top__welcome.welcome-user .banner-top__welcome-icon {
  top: 10px;
}
.banner-top__welcome .text-username,
.banner-top__welcome .text-welcome {
  font-size: 18px;
  line-height: 26px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
  font-weight: 800;
  letter-spacing: 0.64px;
}
.banner-top__welcome .text-welcome {
  letter-spacing: 3.2px;
}
.banner-top__welcome-logo {
  width: 161px;
  height: 56px;
}
.banner-top__welcome-icon {
  position: absolute;
  top: 45px;
  left: 0;
  width: 282px;
  height: 92px;
}
@keyframes blur {
  0% {
    opacity: 0;
    filter: blur(12px);
  }
  50% {
    opacity: 0;
    filter: blur(8px);
  }
  100% {
    opacity: 1;
    filter: blur(0);
  }
}
@keyframes spin-center {
  from {
    filter: drop-shadow(0 60px 40px rgba(0, 0, 0, 0.2));
    transform: translate3d(0, -489.6px, 0) rotate(0deg);
  }
  to {
    filter: drop-shadow(0 60px 19px rgba(0, 0, 0, 0.2));
    transform: translate3d(0, 0, 0) rotate(360deg);
  }
}
@media screen and (min-width: 768px) {
  @keyframes spin-center {
    from {
      filter: drop-shadow(0 60px 40px rgba(0, 0, 0, 0.2));
      transform: translate3d(0, -552.8px, 0) rotate(0deg);
    }
    to {
      filter: drop-shadow(0 60px 19px rgba(0, 0, 0, 0.2));
      transform: translate3d(0, 0, 0) rotate(360deg);
    }
  }
}
.hero__section {
  padding-bottom: 50px;
  height: 225px;
}
@media screen and (min-width: 768px) {
  .hero__section {
    height: 246px;
  }
}
.hero__inner {
  position: relative;
  margin: 0 auto;
  padding-bottom: 50px;
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
.hero__content {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
  text-align: center;
}
.hero__title {
  padding-top: 46px;
  font-size: 24px;
  line-height: 30px;
  color: white;
  font-family: "Allura", serif;
}
.hero__subtitle {
  margin: 10px 0 3px;
  font-size: 22px;
  font-weight: 700;
  line-height: 32px;
  color: white;
  font-family: "Shippori Mincho", serif;
}
.hero__lines {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
}
.hero__lines .line {
  width: 100%;
  height: 1px;
  background-color: white;
}
.hero__section--product.hero__section {
  height: 236px;
}
@media screen and (min-width: 768px) {
  .hero__section--product.hero__section {
    height: 257px;
  }
}
.hero__section--product.hero__section .hero__title {
  font-size: 42px;
  line-height: 61px;
  padding-top: 16px;
  font-family: "Shippori Mincho", serif;
  margin-bottom: 1px;
}
.hero__section--product.hero__section .hero__subtitle {
  font-size: 20px;
  line-height: 29px;
  margin: 0;
  letter-spacing: 0.64px;
}
.hero__section--product.hero__section .hero__description {
  position: relative;
  font-size: 15px;
  line-height: 19px;
  font-family: "Allura", serif;
  color: white;
  letter-spacing: 1.6px;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
.hero__section--product.hero__section .hero__description:before {
  content: "";
  position: absolute;
  top: 9px;
  left: -19px;
  width: 16px;
  height: 1px;
  background-color: white;
  transform: rotate(44deg);
}
.hero__section--product.hero__section .hero__description:after {
  content: "";
  position: absolute;
  top: 9px;
  right: -19px;
  width: 16px;
  height: 1px;
  background-color: white;
  transform: rotate(135deg);
}
.hero__img-bottom {
  position: absolute;
  left: 0;
  width: 100%;
  height: 101px;
}
.news__list {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 25px;
}
.new__item {
  width: calc(50% - 12.5px);
}
.new__item.active .new-card__description {
  color: #bd6856;
  text-decoration: underline;
}
.new__item.active svg {
  transform: rotate(180deg);
}
.new__item.active svg rect {
  fill: #bd6856;
  stroke: #bd6856;
}
.new__item.active svg path {
  stroke: white;
}
.new-card {
  cursor: pointer;
  transition: all 0.3s ease;
}
.new-card:hover {
  opacity: 0.9;
}
.new-card:hover .new-card__img img {
  transform: scale(1.05);
}
.new-card__content {
  display: none;
  margin-top: 20px;
  padding: 20px;
  border: 1px solid #bd6856;
  border-radius: 4px;
  font-size: 12px;
  line-height: 14px;
  font-family: "Shippori Mincho", serif;
  background: white;
}
.new-card__img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  overflow: hidden;
}
.new-card__img img {
  transition: all 0.3s ease;
}
.new-card__title {
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  line-height: 26px;
  margin: 6px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.new-card__description {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
}
.new-card__icon {
  transition: all 0.3s ease;
}
.year-section {
  padding: 16px 0;
  position: relative;
}
.year-section .year-selector {
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
  position: relative;
  scrollbar-width: none;
  -ms-overflow-style: none;
  cursor: grab;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.year-section .year-selector::-webkit-scrollbar {
  display: none;
}
.year-section .year-selector.dragging {
  cursor: grabbing;
  scroll-behavior: auto;
}
.year-section .year-selector__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  height: 28px;
  width: 52px;
  flex-shrink: 0;
  border-radius: 100px;
  font-weight: 700;
  font-size: 12px;
  line-height: 16px;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s ease-in-out;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  border: 1px solid #e9e9e9;
  color: #333333;
  background-color: transparent;
}
.year-section .year-selector__item:first-child {
  margin-left: 20px;
}
.year-section .year-selector__item:last-child {
  margin-right: 40px;
}
.year-section .year-selector__item:hover {
  background-color: rgb(243.525, 243.525, 243.525);
}
.year-section .year-selector__item.active {
  background-color: #525252;
  color: #ffffff;
}
.year-section .year-selector__item.active:hover {
  background-color: rgb(62.875, 62.875, 62.875);
}
@media screen and (min-width: 414px) {
  .year-section .year-selector__item {
    width: 60px;
  }
}
@media screen and (min-width: 768px) {
  .year-section .year-selector__item {
    width: 72px;
  }
}
.year-section .year-selector__gradient-overlay {
  position: absolute;
  right: 0;
  top: 0;
  width: 40px;
  height: 60px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #ffffff 50%, #ffffff 100%);
  pointer-events: none;
  z-index: 1;
}
.mr-progress-delivery {
  margin-left: -5px;
  margin-right: -5px;
}
.mr-progress-delivery ol {
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.mr-progress-delivery ol i {
  font-size: 11px;
  vertical-align: bottom;
  color: #9d4d39;
}
.mr-progress-delivery ol li {
  width: 15px;
  height: 15px;
  background-color: #d3b7ac;
  border-radius: 50%;
  text-align: center;
  line-height: 15px;
}
.mr-progress-delivery li:not(:first-child)::after {
  content: "";
  position: absolute;
  width: 50%;
  height: 3px;
  background-color: #d3b7ac;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
}
.mr-progress-delivery ol .step-2::after {
  left: 15px;
  width: 20%;
}
.mr-progress-delivery ol .step-3::after {
  left: calc(20% + 30px);
  width: calc(20% + 1px);
}
.mr-progress-delivery ol .step-4::after {
  width: 20%;
  left: 52%;
}
.mr-progress-delivery ol .step-5::after {
  width: 20%;
  left: unset;
  right: 15px;
}
.mr-progress-delivery ol li.current-step,
.mr-progress-delivery ol li.current-step::after,
.mr-progress-delivery ol li.done,
.mr-progress-delivery ol .step-2.done::after,
.mr-progress-delivery ol .step-3.done::after,
.mr-progress-delivery ol .step-4.done::after {
  background-color: #490000;
}
.mr-progress-delivery ol li.current-step i {
  display: none;
}
.mr-progress-delivery ol li.current-step ~ li i {
  display: none;
}
.mr-progress-text {
  display: flex;
  justify-content: space-between;
  color: #d3b7ac;
  margin-top: 13px;
  margin-left: -15px;
  margin-right: -15px;
}
.mr-progress-text span {
  display: inline-block;
  width: 80px;
  text-align: center;
  font-size: 12px;
  font-weight: 500;
  font-family: "YuGothic";
  color: #fff;
}
.mr-progress-text .done,
.mr-progress-text .current-step {
  color: #490000;
}
.mr-progress-delivery-2.mr-progress-delivery {
  padding-left: 30px;
  padding-right: 30px;
}
.mr-progress-delivery-2.mr-progress-delivery .step-2::after {
  left: 15px;
  width: 26%;
}
.mr-progress-delivery-2.mr-progress-delivery .step-3::after {
  left: calc(25% + 33px);
  width: calc(26% + 1px);
}
.mr-progress-delivery-2.mr-progress-delivery .step-4::after {
  width: 26%;
  left: unset;
  right: 15px;
}
.mr-progress-delivery-2.mr-progress-delivery .mr-progress-text {
  margin-left: -30px;
  margin-right: -30px;
}
.bg-cart {
  background-image: url("../img/bg-cart.png");
  background-size: cover;
}
.bg-cart .mr-input {
  color: #7b7b7b !important;
}
.cart-inner {
  padding-left: 15px;
  padding-right: 15px;
}
.cart-pagination {
  font-size: 13px;
  font-weight: 700;
}
.cart-pagination .cart-btn-back {
  color: #490000;
  margin-left: 25px;
  padding: 5px;
}
.cart-pagination .cart-btn-back i {
  margin-right: 13px;
}
.cart .cart-icon-wrap {
  display: flex;
  justify-content: flex-end;
  padding-top: 14px;
}
.cart-icon {
  display: inline-block;
  position: relative;
}
.cart-icon-count {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 5px;
  line-height: 26px;
  font-weight: 700;
  color: #bd6856;
}
.mr-title, .sln_card_payment_container .ec-pageHeader h1 {
  font-size: 16px;
  line-height: 26px;
  text-align: center;
  font-weight: 500;
  color: #490000;
}
.mr-input {
  width: 100%;
  height: 46px;
  line-height: 46px;
  font-size: 12px;
  font-weight: 500;
  padding: 0 8px;
  border: 0;
  outline: 0;
  background-color: #f7e9e3;
  border-radius: 0;
}
@media screen and (min-width: 375px) {
  .form-control.mr-input::-moz-placeholder {
    color: #7b7b7b !important;
  }
  .form-control.mr-input::placeholder {
    color: #7b7b7b !important;
  }
}
.mr-form-row {
  margin-bottom: 12px;
}
.mr-form-row label {
  font-size: 12px;
  line-height: 17px;
  color: #490000;
  font-weight: 700;
}
.has-two-input {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.btn-cart, .thank-you .btn-thank, .btn-cart-black, .sln_card_payment_container #add_card_form #top_box__footer #top_box__button_menu p .ec-blockBtn--cancel, .btn-cart-red, .sln_card_payment_container #add_card_form #top_box__footer #top_box__button_menu p .ec-blockBtn--action {
  margin: 0 auto;
  display: block;
  font-size: 15px;
  line-height: 17px;
  font-weight: 700;
  text-align: center;
  height: 45px;
  width: 279px;
  color: #490000;
  border-radius: 999px;
  border: 1px solid #490000;
}
.btn-cart-red, .sln_card_payment_container #add_card_form #top_box__footer #top_box__button_menu p .ec-blockBtn--action {
  background-color: #c33d3d;
}
.btn-cart-black, .sln_card_payment_container #add_card_form #top_box__footer #top_box__button_menu p .ec-blockBtn--cancel {
  background-color: #bd6856;
}
.mr-btn-outline-white {
  border-color: #490000;
  background-color: transparent;
  color: #490000;
  border-radius: 0;
  width: 192px;
  height: 32px;
  line-height: 32px;
  padding: 0;
  font-size: 14px;
  display: block;
  margin: 0 auto;
}
.choose-package {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
}
.package {
  background-color: #f8e9e3;
  border-radius: 20px;
  border: 5px solid #f8e9e3;
  text-align: center;
  padding: 20px 0;
  cursor: pointer;
  position: relative;
}
.package span {
  display: block;
}
.package.package--active {
  border-color: #ff0000;
}
.package.package--active .package-schedule,
.package.package--active .package-price {
  color: #ff0000;
}
.package .btn-card-plan {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0;
  z-index: 9;
}
#page_cart_2 .modal-backdrop {
  z-index: -1;
}
#priceTableCart2 .modal-content {
  padding-top: 40px;
  border: 0;
  margin-left: 5px;
  margin-right: 5px;
  border-radius: 0;
}
#priceTableCart2 .btn {
  position: absolute;
  top: 16px;
  right: 18px;
  border: 0;
  background-color: transparent;
  color: #707070;
  font-size: 40px;
  padding: 0;
  display: flex;
}
#priceTableCart2 .has-balloon span {
  top: -35px;
}
.mr-package-table {
  display: grid;
  /*repeat based on count items in BE, will style inline on template*/
  grid-template-columns: 75px repeat(4, 1fr);
  grid-auto-flow: column;
  grid-auto-rows: 1fr;
}
.mr-package-table .item {
  border-bottom: 1px solid #b15858;
  border-right: 1px solid #b15858;
  word-break: break-word;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  line-height: 1.2;
  padding: 15px 5px;
}
.mr-package-table .item.item--last {
  border-right: 0;
}
.mr-package-table .title {
  grid-column-start: 1;
  grid-column-end: 2;
  font-size: 14px;
  color: #bd6856;
  font-weight: 700;
}
.mr-package-table .title-1 {
  grid-row-start: 1;
  grid-row-end: 2;
}
.mr-package-table .title-2 {
  grid-row-start: 2;
  grid-row-end: 3;
}
.mr-package-table .title-3 {
  grid-row-start: 3;
  grid-row-end: 4;
}
.mr-package-table .title-4 {
  grid-row-start: 4;
  grid-row-end: 5;
}
.mr-package-table .title-5 {
  grid-row-start: 5;
  grid-row-end: 6;
}
.mr-package-table .title-6 {
  grid-row-start: 6;
  grid-row-end: 7;
}
.mr-package-future {
  background-color: #bf826b;
  color: #490000;
  position: absolute;
  bottom: 115px;
  left: 95px;
  padding: 8px 30px 8px 14px;
  font-size: 14px;
}
.mr-package-note {
  margin-top: 15px;
  padding-left: 67px;
  letter-spacing: -2px;
}
.mr-letter-1-negative {
  letter-spacing: -1px;
}
.cart-ticket .order-table .order-item {
  grid-template-columns: 4fr 6fr;
}
.cart-ticket .order-table .order-item .order-item-text {
  padding: 0;
}
.order-table {
  background-color: #f6e8e2;
  padding: 10px;
}
.order-item-balloon .order-item-img {
  position: relative;
}
.order-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 6px 0;
  border-bottom: 1px solid #707070;
}
.order-item-img {
  width: 110px;
  height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  justify-self: flex-end;
}
.order-item-img .label {
  width: 55px;
  height: 55px;
  border-radius: 50%;
  border: 1px solid #707070;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  position: absolute;
  padding: 5px;
  overflow: hidden;
  background-color: #490000;
  transform: translate(-50%, -24%);
}
.order-item-text {
  font-size: 9px;
  font-weight: 500;
  color: #8e1111;
  text-align: center;
  padding-left: 19px;
  justify-self: flex-start;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.order-item-text .order-item-price {
  font-size: 17px;
  margin-bottom: 0;
}
.order-item-text .order-item-price span {
  font-size: 9px;
}
.order-item-text .order-item-discount {
  line-height: 17px;
  font-size: 11px;
  text-decoration: line-through;
  margin-bottom: 0;
}
.order-item-text .order-item-discount span {
  font-size: 8px;
}
.order-item-text .order-discount-description {
  line-height: 14px;
}
.order-item-amount {
  background-color: #490000;
  border-radius: 16px;
  width: 54px;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid #707070;
  margin: 7px auto 0 auto;
}
.order-item-amount input {
  background-color: #490000;
  outline: 0;
  border: 0;
  font-size: 16px;
  font-weight: 500;
  max-width: 100%;
  height: 25px;
  text-align: center;
  padding: 0 17px;
  vertical-align: sub;
}
.order-item-amount button {
  display: inline-block;
  width: 10px;
  height: 17px;
  background-color: #c3c3c3;
  color: #490000;
  font-size: 5px;
  text-align: center;
  padding: 3px;
  border: 0;
  border-radius: 0;
  outline: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.order-item-amount .order-item-minus {
  left: 5px;
}
.order-item-amount .order-item-plus {
  right: 5px;
}
.mr-error-package {
  display: flex !important;
}
.order-table .order-item:last-child {
  border-bottom: 0;
}
.payment {
  color: #490000;
}
.payment-list .line {
  margin: 20px 0;
  background-color: #490000;
}
.payment-item {
  display: flex;
  justify-content: space-between;
  font-size: 15px;
  line-height: 26px;
}
.payment-price.total-money {
  font-size: 18px;
  font-weight: 500;
}
.payment-price.total-money strong {
  font-size: 33px;
  font-weight: bold;
}
.thank-you {
  text-align: center;
  color: #490000;
  padding-top: 56px;
}
.thank-you h2 {
  font-size: 60px;
  margin-bottom: 57px;
  font-weight: 400;
}
.thank-you .btn-thank {
  background-color: #dcb6a8;
}
.thank-you-img {
  width: 155px;
  height: 118px;
  margin: 0 auto 40px auto;
}
.thank-you-text {
  font-size: 14px;
  line-height: 19px;
  margin-bottom: 62px;
}
.thank-you .suggest {
  font-size: 14px;
  line-height: 24px;
}
.mr-cart-quantity {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 1;
}
.mr-pt-41 {
  padding-top: 41px;
}
.mr-mt-27 {
  margin-top: 27px;
}
.mr-pl-30 {
  padding-left: 30px;
}
.custom-control-label {
  color: #fafafa;
}
.custom-control-input:checked ~ .custom-control-label::before {
  border: 3px solid #8b4513 !important;
  background-color: #8b4513 !important;
  box-shadow: 0 0 0 4px #fdfdfd inset;
}
.custom-control-label::before {
  width: 32px;
  height: 32px;
  border: 3px solid #8b4513 !important;
  background-color: #fff !important;
  box-shadow: 0 0 0 3px #fdfdfd inset;
}
.custom-control-label::after {
  width: 32px;
  height: 32px;
  background-image: none;
}
.custom-radio .custom-control-input:checked ~ .custom-control-label::after {
  width: 32px;
  height: 32px;
  background-image: none;
}
.mr-text-black {
  color: #bd6856;
}
#sln_regular_type_0 {
  display: none;
}
.sln_card_payment_container > .row {
  margin: 0 32px !important;
}
.sln_card_payment_container > .row .alert.alert-warning {
  font-size: 15px;
}
.sln_card_payment_container .cards__brand {
  width: 230px;
  margin-bottom: 16px;
  margin: 30px auto;
}
.sln_card_payment_container .error-label {
  margin-bottom: 30px;
}
.sln_card_payment_container .detail_wrap #card_CardExp,
.sln_card_payment_container .detail_wrap #card_SecCd {
  width: 80px;
}
.sln_card_payment_container #detail_wrap #pay_status .col-md-offset-1 {
  display: flex;
  justify-content: center;
  font-size: 15px;
  flex: 0 0 100%;
  max-width: none;
  margin-top: 40px;
}
.sln_card_payment_container #detail_wrap .form-help-text {
  margin-top: 2px;
  font-size: 12px;
  line-height: 17px;
  color: #b3b3b3;
}
.sln_card_payment_container .ec-pageHeader h1 {
  border-top: none;
  margin: 0 32px 20px;
}
.sln_card_payment_container span.ec-required {
  display: none;
  font-size: 14px;
  color: #0066cc;
  border-radius: 4px;
}
.sln_card_payment_container #detail_box__name dd {
  padding-bottom: 0;
}
.sln_card_payment_container #detail_box__name dd .ec-birth,
.sln_card_payment_container #detail_box__name dd p.errormsg {
  font-size: 12px;
  line-height: 17px;
  color: #fff;
  font-weight: 700;
}
.sln_card_payment_container #add_card_form #detail_box__name label {
  font-size: 12px;
  line-height: 17px;
  color: #fff;
  font-weight: 700;
  margin: 0 16px;
}
.sln_card_payment_container #add_card_form #top_box__footer #top_box__button_menu {
  width: 100% !important;
  max-width: 100% !important;
  flex: none;
}
.sln_card_payment_container #add_card_form #top_box__footer #top_box__button_menu p .ec-blockBtn--action {
  display: flex;
  align-items: center !important;
  justify-content: center;
  margin-bottom: 10px;
  margin-top: 20px;
}
.sln_card_payment_container #add_card_form #top_box__footer #top_box__button_menu p .ec-blockBtn--cancel {
  display: none;
  justify-content: center;
  align-items: center !important;
}
.sln_card_payment_container .form-input-expiration-date .form-input-wrapper {
  display: flex;
  gap: 8px;
}
.sln_card_payment_container .form-input-expiration-date input {
  width: 80px;
}
.sln_card_payment_container .form-input-name .form-input-wrapper {
  display: flex;
  gap: 8px;
}
.sln_card_payment_container .form-input-name .form-input-wrapper input:first-child {
  width: 40%;
}
.sln_card_payment_container .form-input-name .form-input-wrapper input:last-child {
  flex: 1;
}
.sln_card_payment_container .ec-errorMessage {
  font-size: 12px;
  color: #dc3545;
}
.sln_card_payment_container .pay_status .col-md-offset-1 {
  color: #fff;
  font-size: 12px;
}
/* START ---- Custom css sln_card_payment */
#detail_box__body p.ec-errorMessage {
  font-size: 15px !important;
  margin: 10px 0 0 0 !important;
  background-color: transparent;
  /* display: table; */
  padding: 0 5px;
}
#detail_box__body .errormsg.text-danger {
  font-size: 15px !important;
  padding: 0 5px;
  background-color: transparent;
  /*     display: table; */
  margin: 10px 0 !important;
}
#detail_box__body .ec-birth {
  font-size: 15px;
}
#detail_box__body dt label {
  font-size: 15px !important;
}
#detail_box__body span.ec-required {
  background: #fff;
  color: #f00 !important;
  font-size: 12px !important;
  border-radius: 5px !important;
  padding: 2px 6px;
}
/* END ---- Custom css sln_card_payment */
/* START ---- Custom css cart */
.mr-cart-1 .mr-progress-delivery {
  padding-top: 45px;
  padding-bottom: 31px;
}
.mr-cart-2 .mr-progress-delivery {
  padding-top: 45px;
  padding-bottom: 31px;
}
.mr-cart-3 .mr-progress-delivery {
  padding-top: 45px;
  padding-bottom: 55px;
}
.mr-cart-3.bg-cart {
  min-height: unset;
}
.mr-cart-3 .cart-pagination {
  margin-top: 15px;
}
.mr-cart-4 .mr-progress-delivery {
  padding-top: 45px;
  padding-bottom: 8px;
}
.mr-cart-fix.bg-cart {
  min-height: unset;
}
.mr-cart-fix .cart-pagination {
  margin-top: 15px;
}
.mr-cart-password .confirm-password-wrapper {
  margin-top: 12px;
}
.mr-cart-password .submit-button {
  margin-top: 30px;
}
.mr-cart-shopping .orders {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.mr-cart-shopping .orders__confirm-button {
  margin-top: 30px;
}
.mr-cart-shopping__cart_4_3 .c-form-select__title--wrap {
  word-break: keep-all;
}
.mr-cart-package .form-message {
  margin-bottom: 30px;
}
.mr-cart-package__cards {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 30px;
}
.mr-cart-package .js-error-package.mr-error-package {
  margin-bottom: 30px;
}
.mr-cart-package__note {
  margin-bottom: 30px;
}
.mr-cart-package__note-item {
  display: flex;
  gap: 4px;
  font-size: 12px;
  line-height: 17px;
  font-family: "Shippori Mincho", serif;
}
.mr-cart-package__actions {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.mr-cart-package__actions .help-agreement {
  font-size: 10px;
  line-height: 12px;
  color: #618a91;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  text-decoration: underline;
}
.mr-cart-complete {
  padding: 24px 20px 60px;
  background-color: #f3edd8;
}
.mr-cart-complete .c-step {
  margin-bottom: 24px;
}
.mr-cart-complete .section-header {
  color: black;
}
/* END ---- Custom css cart */
/* START --- FIX SCREEN < 375px */
@media screen and (max-width: 374px) {
  .container.bg-cart {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
}
@media screen and (min-width: 375px) {
  .intro-section {
    background-repeat: round;
    background-attachment: fixed;
    background-size: cover;
    padding-bottom: 42px;
  }
  .intro-section img {
    height: unset;
    width: unset;
  }
  .intro-section-inner .owl-nav.disabled + .owl-dots {
    position: relative;
  }
  .intro-section-inner .owl-dots .owl-dot span {
    margin: 3px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 1px solid #bd6856;
    background-color: transparent;
  }
  .intro-section-inner .owl-dots .owl-dot.active span {
    background-color: #bd6856;
  }
  .intro-section .intro-title {
    font-size: 25px;
    margin: 40px 15px 40px;
    position: relative;
  }
  .intro-section .intro-title::first-letter {
    font-size: 87px;
    float: left;
    margin-top: -20px;
  }
  .intro-section .intro-text::before {
    content: "";
    display: table;
    clear: both;
  }
  .intro-section .intro-text {
    font-size: 14px;
    line-height: 1.8;
    margin: 0 40px 30px;
  }
  .intro-section .intro-text p {
    margin-bottom: 2px;
  }
  .intro-section .intro-img {
    text-align: center;
  }
  .intro-section .intro-img img {
    max-width: 200px;
    display: initial;
    width: auto;
  }
  .intro-section .intro-direct {
    text-align: center;
    margin: 20px 0 0 0;
    outline: none;
  }
  .intro-section .intro-direct a {
    padding: 15px;
  }
  .intro-section .intro-direct a:hover {
    text-decoration: none;
    color: #490000;
  }
  .intro-section .intro-pagination {
    height: 5vh;
  }
}
@media screen and (max-width: 374px) {
  .intro-section .intro-title:first-child {
    margin: 40px 8px 40px !important;
  }
}
#what-is-chapter .chapter-inner {
  padding-top: 40px;
  margin: 0 auto;
}
#what-is-chapter .chapter-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 36px;
}
#what-is-chapter .question-section {
  position: relative;
  height: 74.55px;
  width: 255px;
  text-align: center;
}
#what-is-chapter .question-text .question-intro {
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 26px;
  margin-bottom: 4px;
}
#what-is-chapter .question-text .question-main {
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 32px;
  letter-spacing: -2.4px;
}
#what-is-chapter .question-text .question-main span {
  font-size: 24px;
  color: #bd6856;
}
#what-is-chapter .question-decoration {
  position: absolute;
  left: 23.54px;
  bottom: 2px;
  width: 89.52px;
  height: 10.99px;
  display: flex;
  align-items: center;
  gap: 1.37px;
}
#what-is-chapter .encounters-section .encounters-header {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
#what-is-chapter .encounters-section .encounters-header .encounters-icon {
  width: 28px;
  height: 56px;
  flex-shrink: 0;
}
#what-is-chapter .encounters-section .encounters-header .encounters-title .encounters-subtitle {
  font-family: "Shippori Mincho", serif;
  font-size: 15px;
  font-weight: 700;
  line-height: 22px;
}
#what-is-chapter .encounters-section .encounters-header .encounters-title .encounters-main {
  color: #bd6856;
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 35px;
  letter-spacing: -2px;
  text-align: center;
}
#what-is-chapter .encounters-section .encounters-header .encounters-title .encounters-main span {
  font-size: 30px;
}
#what-is-chapter .encounters-section .encounter-items {
  display: flex;
  align-items: center;
  gap: 15px;
  width: 100%;
}
#what-is-chapter .encounters-section .encounter-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 150px;
}
#what-is-chapter .encounters-section .encounter-content {
  padding: 0 17.6px;
  margin: auto;
}
#what-is-chapter .encounters-section .encounter-header {
  display: flex;
  gap: 5px;
  width: 100%;
}
#what-is-chapter .encounters-section .encounter-number {
  position: relative;
  font-family: "Shippori Mincho", serif;
  font-size: 30px;
  line-height: 43.5px;
  height: 43.5px;
  width: 25.67px;
}
#what-is-chapter .encounters-section .encounter-number:before {
  content: "";
  position: absolute;
  bottom: 0;
  right: 6px;
  width: 26px;
  height: 1px;
  background-color: black;
  transform: rotate(135deg) translate(-12px);
}
#what-is-chapter .encounters-section .encounter-title {
  margin-top: 14px;
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  color: #bd6856;
}
#what-is-chapter .encounters-section .encounter-image {
  width: 96px;
  height: 120px;
  margin: 5px auto 10px;
}
#what-is-chapter .encounters-section .encounter-description p {
  font-family: "Shippori Mincho", serif;
  font-size: 13px;
  line-height: 20px;
  color: #bd6856;
}
#what-is-chapter .middle-text {
  text-align: center;
  max-width: 231px;
  letter-spacing: -1.5px;
}
#what-is-chapter .middle-text p {
  font-family: "Shippori Mincho", serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 32px;
}
#what-is-chapter .middle-text p span {
  font-weight: 800;
  color: #bd6856;
}
#what-is-chapter .final-image-section {
  max-width: 281.79px;
  margin-bottom: 50.91px;
}
.news-section {
  background: #fff8f3;
}
.news-section__more {
  width: 100%;
  text-align: center;
  margin-top: 36px;
}
.user-data {
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
.user-data .user-data__inner .section-header {
  color: white !important;
}
.user-data .user-data__inner .line {
  background-color: white;
}
.user-data .user-data__content {
  margin-right: -20px;
}
.user-data .user-data__card {
  position: relative;
  padding: 7px 20px 17px;
}
.user-data .user-data__card:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 64px;
  background: url(../img/speechbubble2.png) no-repeat center center;
  background-size: cover;
}
.user-data .user-data__card-title {
  position: relative;
  z-index: 1;
  font-size: 16px;
  line-height: 23px;
  font-weight: 700;
  text-align: center;
  color: white;
}
.user-data .user-data__card-content {
  margin-top: 20px;
}
.user-data .user-data__card-content img {
  height: 70px;
  -o-object-fit: contain;
     object-fit: contain;
}
.user-data .user-data__card-content p {
  margin-top: 3px;
  font-size: 13px;
  line-height: 20px;
}
.start-chapters {
  padding: 20px 20px 23px;
  background-color: #ebdcd9;
  position: relative;
  z-index: 1;
}
.start-chapters:before {
  content: "";
  position: absolute;
  bottom: -9px;
  left: 0;
  width: 100%;
  height: 10.44px;
  background: url(../img/wave.png) repeat center center;
  background-size: contain;
  z-index: 1;
}
.start-chapters__inner {
  background-color: white;
  padding: 30px;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.start-chapters__inner-header {
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  line-height: 26px;
  font-weight: 700;
  text-align: center;
  letter-spacing: -0.36px;
  position: relative;
}
.start-chapters__inner-header:before {
  content: "";
  position: absolute;
  top: 10px;
  left: -25px;
  width: 25px;
  height: 1px;
  background-color: black;
  transform: rotate(56deg);
}
.start-chapters__inner-header:after {
  content: "";
  position: absolute;
  bottom: 14px;
  right: -26px;
  width: 25px;
  height: 1px;
  background-color: black;
  transform: rotate(124deg);
}
.start-chapters__inner-btn-text {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.start-chapters__inner-btn-text .btn-text-primary {
  letter-spacing: 0.64px;
  line-height: 14px;
}
.start-chapters__inner-btn-text .btn-text-secondary {
  font-size: 11px;
  line-height: 14px;
  letter-spacing: 0.72px;
}
.books {
  position: relative;
  background: #fff8f3;
}
.books.section-container {
  padding: 69px 20px 60px;
}
.books::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 0;
  width: 100px;
  height: 184px;
  background: url(../img/book_left.png) no-repeat center center;
  background-size: cover;
}
.books::after {
  content: "";
  position: absolute;
  top: 9px;
  right: 0;
  width: 100px;
  height: 184px;
  background: url(../img/book_right.png) no-repeat center center;
  background-size: cover;
}
.books .section-subtitle__main span {
  font-size: 36px;
  color: #bd6856;
}
.books__description {
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
  margin-bottom: 36px;
}
.books__description-item + .books__description-item {
  margin-top: 10px;
}
.books .date-badge {
  margin-bottom: 22px;
}
.books__theme-section {
  text-align: center;
}
.books__theme-section h4 {
  font-size: 16px;
  line-height: 19px;
  font-weight: 700;
  margin-bottom: 6px;
}
.books__theme-section h3 {
  font-size: 20px;
  font-weight: 600;
  line-height: 29px;
  padding: 8px 0;
  border-bottom: 1px solid black;
  border-top: 1px solid black;
  margin-bottom: 22px;
  font-family: "Shippori Mincho", serif;
}
.books__theme-section .cta-section {
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.books__theme-section .cta-section p {
  font-size: 18px;
  line-height: 23px;
  font-weight: 600;
  color: #bd6856;
  font-family: "Shippori Mincho", serif;
}
.books__theme-section .cta-section .arrow-icon {
  width: 12px;
  height: 18px;
  animation: arrow-icon 1s infinite;
  display: flex;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
.books__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 21px 22px;
  margin-bottom: 36px;
}
.books .book__item {
  overflow: hidden;
  width: calc(50% - 11px);
  aspect-ratio: 1/1;
  cursor: pointer;
  border: 1px solid #bd6856;
  position: relative;
  transition: all 0.3s ease;
  will-change: transform, box-shadow;
  transform: translate3d(0, 0, 0);
}
.books .book__item:hover {
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
  transform: translateY(-2px);
  opacity: 0.9;
}
.books .book__item:hover .book__image {
  transform: scale(1.05);
}
.books .book__content {
  width: 100%;
  height: 100%;
}
.books .book__image {
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.3s ease;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
.books .book__icon {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 26px;
  height: 26px;
}
.books__description-box {
  background: white;
  border: 1px solid #bd6856;
  border-radius: 4px;
  padding: 20px;
  font-size: 13px;
  line-height: 22px;
  text-align: center;
}
.books__description-box P + p {
  padding-top: 24px;
}
.how-to-enjoy {
  background: #f3edd8;
}
.how-to-enjoy__description {
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
  margin-bottom: 36px;
}
.how-to-enjoy .chapter__item {
  display: flex;
  position: relative;
  justify-content: space-between;
  align-items: start;
}
.how-to-enjoy .chapter__item + .chapter__item {
  margin-top: 30px;
}
.how-to-enjoy .chapter__item:nth-child(1) .chapter {
  color: #490000;
}
.how-to-enjoy .chapter__item:nth-child(1) .chapter__img {
  width: 196px;
  height: 157.48px;
}
.how-to-enjoy .chapter__item:nth-child(1) .chapter__icon {
  left: 17px;
  bottom: -10px;
}
.how-to-enjoy .chapter__item:nth-child(2) {
  flex-direction: row-reverse;
}
.how-to-enjoy .chapter__item:nth-child(2) .chapter {
  color: #56674e;
}
.how-to-enjoy .chapter__item:nth-child(2) .chapter__img {
  width: 186px;
  height: 160px;
}
.how-to-enjoy .chapter__item:nth-child(2) .chapter__icon {
  right: 20.93px;
  bottom: -10px;
}
.how-to-enjoy .chapter__item:nth-child(3) .chapter {
  color: #cc8751;
}
.how-to-enjoy .chapter__item:nth-child(3) .chapter__img {
  width: 200.59px;
  height: 150.96px;
}
.how-to-enjoy .chapter__item:nth-child(3) .chapter__icon {
  left: 17px;
  bottom: -10px;
}
.how-to-enjoy .chapter__item:nth-child(4) {
  flex-direction: row-reverse;
}
.how-to-enjoy .chapter__item:nth-child(4) .chapter {
  color: #618a91;
}
.how-to-enjoy .chapter__item:nth-child(4) .chapter__img {
  width: 178px;
  height: 161.38px;
}
.how-to-enjoy .chapter__item:nth-child(4) .chapter__icon {
  right: 20.93px;
  bottom: 17px;
}
.how-to-enjoy .chapter__item:nth-child(5) .chapter {
  color: #ed7560;
}
.how-to-enjoy .chapter__item:nth-child(5) .chapter__img {
  width: 197.77px;
  height: 145.66px;
}
.how-to-enjoy .chapter__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.how-to-enjoy .chapter__description {
  padding-left: 10.25px;
  font-size: 14px;
  line-height: 28px;
  font-weight: 500;
}
.how-to-enjoy .chapter__description p {
  border-bottom: 1px dashed #bd6856;
}
.how-to-enjoy .chapter__description p:first-child {
  border-top: 1px dashed #bd6856;
}
.how-to-enjoy .chapter__description span {
  font-weight: 800;
  color: #ed7560;
}
.how-to-enjoy .chapter__icon {
  position: absolute;
  width: auto;
  height: auto;
}
.how-to-enjoy__bottom {
  margin-top: 36px;
  font-size: 12px;
  line-height: 17px;
}
.how-to-enjoy__bottom p {
  display: flex;
  gap: 6px;
}
.how-to-enjoy__bottom p + p {
  margin-top: 6px;
}
.user-voice {
  background: #f3edd8;
}
.user-voice .js-carousel__user-voice {
  margin-right: -20px;
}
.user-voice .js-carousel__user-voice .js-carousel__item {
  height: 240px;
}
.user-voice__card {
  width: 100%;
  height: 100%;
}
.user-voice__card-image {
  overflow: hidden;
  margin: 5px 5px 0;
  width: 260px !important;
  height: 146px;
  border-radius: 2px;
}
.user-voice__card:hover img {
  transform: scale(1.05);
}
.user-voice__card img {
  transition: all 0.3s ease;
}
.user-voice__card p {
  padding: 10px 15px;
  font-size: 13px;
  line-height: 23px;
  font-weight: 500;
  color: black;
}
.user-voice__action {
  margin-top: 50px;
}
.user-voice__action .btn {
  width: 100%;
  padding: 5px 0 11px;
  height: 38px;
  font-size: 18px;
}
.user-voice .arrow-icon {
  margin: 14px auto;
  width: 12px;
  height: 18px;
  animation: arrow-icon 1s infinite;
  display: flex;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
.user-voice__blog {
  overflow: hidden;
  border-radius: 4px;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}
.user-voice__blog-content {
  aspect-ratio: 335/111;
  width: 100%;
  display: flex;
  justify-content: end;
  align-items: end;
  padding: 9.5px 10px;
  background: url(../img/user_voice_blog.png) no-repeat center center;
  background-size: cover;
}
.user-voice__read-more {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: "Allura", serif;
  font-size: 22px;
  line-height: 28px;
  color: white;
  transition: all 0.3s ease;
}
.user-voice__read-more:hover {
  text-decoration: underline;
}
.service {
  background: #f3edd8;
}
.service.section-container {
  padding: 24px 20px 100px;
}
.service__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
}
.service__item-description {
  font-size: 12px;
  line-height: 14px;
  font-weight: 500;
  margin-bottom: 4px;
  text-align: center;
}
.service__item-title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  margin-bottom: 12px;
  transition: all 0.3s ease;
  color: #bd6856;
}
.service__item-title:hover {
  text-decoration: underline;
  opacity: 0.9;
}
.service__item-title svg {
  animation: translateX-arrow-icon 1s infinite;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
@keyframes translateX-arrow-icon {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(2px);
  }
}
.service__item-name {
  font-size: 18px;
  line-height: 26px;
  font-weight: 800;
  font-family: "Shippori Mincho", serif;
}
.service__item-image {
  width: 100%;
  aspect-ratio: 335/180;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}
.service__item-image img {
  transition: all 0.3s ease;
}
.service__item-image:hover img {
  transform: scale(1.05);
}
.past-section {
  background: url(../img/bg_sensho.png) no-repeat center center;
  background-size: cover;
  position: relative;
}
.past__decoration {
  position: absolute;
  top: -1px;
  left: 0;
  width: 66px;
  height: 55px;
}
.past__inner {
  padding: 49.52px 20px 42.56px;
  margin: 0 auto;
}
.past__header {
  width: 170px;
  height: 167px;
  padding-top: 50.56px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: auto;
  background: url(../img/bg_header_past_section.png) no-repeat center center;
  background-size: cover;
  color: white;
  font-family: "Shippori Mincho", serif;
}
.past__header-title {
  font-size: 32px;
  line-height: 49px;
  font-weight: 700;
}
.past__header-description {
  font-size: 22px;
  line-height: 34px;
  font-weight: 700;
}
.past__description {
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
  margin: 30px auto;
  letter-spacing: 1.4px;
  color: white;
}
.past__description p + p {
  margin-top: 10px;
}
.past__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.past__content-item {
  display: flex;
  align-items: center;
  gap: 27px;
  -o-object-fit: cover;
     object-fit: cover;
}
.past__content-item:nth-child(even) {
  flex-direction: row-reverse;
}
.past__content-image {
  width: 140px;
  aspect-ratio: 1/1;
}
.past__content-flip {
  position: relative;
  width: 100px;
  height: 140px;
  transform-style: preserve-3d;
  transition: transform 0.1s ease-out;
}
.past__content-flip img {
  backface-visibility: hidden;
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  top: 0;
  left: 0;
}
.past__content-flip .flip-front {
  z-index: 2;
  transform: rotateY(0deg);
}
.past__content-flip .flip-back {
  z-index: 1;
  transform: rotateY(180deg);
}
.past__footer {
  text-align: center;
  margin-top: 36px;
}
.past__footer .btn {
  height: 47px;
}
.pickup {
  background: #ffffff;
}
.pickup .section-header {
  color: black;
}
.pickup__content {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 36px;
}
.pickup__creator {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  width: 100%;
}
.pickup__creator:not(:last-child) {
  padding-bottom: 36px;
  border-bottom: 1px solid #bd6856;
}
.pickup__creator-avatar {
  width: 120px;
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  flex-shrink: 0;
  overflow: hidden;
  background: url(../img/bg_circle_creater.png) no-repeat center center;
  background-size: cover;
}
.pickup__creator-avatar img {
  width: 112px;
  height: 112px;
  border-radius: 50%;
  -o-object-fit: cover;
     object-fit: cover;
}
.pickup__creator-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pickup__creator-name {
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  line-height: 26px;
  font-weight: 800;
}
.pickup__creator-sns {
  display: flex;
  align-items: center;
  gap: 12px;
}
.pickup__sns-link {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease-in-out;
}
.pickup__sns-link:hover {
  opacity: 0.8;
}
.pickup__sns-link svg {
  width: 36px;
  height: 36px;
}
.pickup__creator-description {
  font-size: 12px;
  line-height: 14px;
}
.back-number-section {
  background: url(../img/bg_sensho2.png) no-repeat center center;
  background-size: cover;
  position: relative;
  padding: 50px 20px 63px;
}
.back-number-section .back-number__decoration {
  position: absolute;
  top: 0;
  left: 0;
  width: 66px;
  height: 55px;
}
.back-number-section .back-number .section-header {
  color: white;
}
.back-number-section .back-number__inner {
  margin: 0 auto;
}
.back-number-section .back-number__header {
  width: 170px;
  height: 167px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto 30px;
  background: url(../img/bg_header_past_section.png) no-repeat center center;
  background-size: cover;
  color: white;
}
.back-number-section .back-number__header-title {
  font-size: 20px;
  line-height: 29px;
  font-weight: 700;
  font-family: "Shippori Mincho", serif;
}
.back-number-section .back-number__header-description {
  font-size: 22px;
  line-height: 28px;
  margin-top: 48.48px;
  font-family: "Allura", serif;
  margin-bottom: 2px;
}
.back-number-section .back-number__description {
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
  color: white;
  margin-bottom: 30px;
}
.back-number-section .back-number__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 7.5px;
}
.back-number-section .back-number__content-title {
  font-size: 18px;
  line-height: 23px;
  font-weight: 600;
  font-family: "Shippori Mincho", serif;
  margin-bottom: 10px;
  color: white;
}
.back-number-section .back-number__content .arrow-icon {
  width: 12px;
  height: 18px;
  animation: arrow-icon 1s infinite;
  display: flex;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
.back-number-section .back-number__content-list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  gap: 10px;
  margin-top: 20px;
}
.back-number-section .back-number__item {
  width: calc(50% - 5px);
}
.back-number-section .back-number__item .btn {
  width: 100%;
  height: 47px;
}
.back-number-section .back-number__content-more {
  margin-top: 30px;
  width: 100%;
}
.back-number-section .back-number__content-more .btn {
  width: 100%;
}
.fixed-button {
  display: flex;
  gap: 10px;
  position: fixed;
  bottom: 19px;
  left: 50%;
  transform: translateX(-50%);
  width: -moz-max-content;
  width: max-content;
  z-index: 10;
  opacity: 0;
}
.fixed-button .btn {
  height: 47px;
  width: 162.5px;
}
@keyframes arrow-icon {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(6px);
  }
}
.product-detail {
  background-color: #f3edd8;
}
.product-detail .hero__title span {
  font-size: 22px;
}
.product-detail__info-top {
  padding: 20px 20px 40px;
}
.product-detail__theme-info {
  margin-top: 10px;
  padding: 24px 20px;
  background: white;
}
.product-detail__theme-info:has(.product-detail__theme-description.active) .product-detail__theme-overlay {
  height: 0;
}
.product-detail__theme-info:has(.product-detail__theme-description.active) .product-detail__theme-read-more svg {
  transform: rotate(180deg);
}
.product-detail__theme-header {
  margin-bottom: 20px;
}
.product-detail__theme-subtitle {
  margin-bottom: 6px;
  font-size: 16px;
  line-height: 19px;
  font-weight: 700;
  text-align: center;
}
.product-detail__theme-title {
  font-size: 20px;
  line-height: 29px;
  font-weight: 600;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.64px;
  padding: 8px 0;
  border-bottom: 1px solid black;
  border-top: 1px solid black;
  text-align: center;
}
.product-detail__theme-description {
  margin-bottom: 20px;
  position: relative;
  height: 112px;
  overflow: hidden;
  font-size: 14px;
  line-height: 22px;
  transition: all 0.3s ease-in-out;
  text-align: center;
  will-change: height, opacity;
  transform: translate3d(0, 0, 0);
}
.product-detail__theme-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 22px;
  width: 100%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #ffffff 100%);
  transition: all 0.3s ease;
  will-change: opacity;
  transform: translate3d(0, 0, 0);
}
.product-detail__theme-read-more {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  line-height: 20px;
  font-weight: 700;
  width: -moz-fit-content;
  width: fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  background: transparent;
}
.product-detail__theme-read-more svg {
  transition: all 0.3s ease;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}
.product-detail__selection-title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 14px;
  line-height: 17px;
  font-weight: 700;
}
.product-detail__tabs {
  background: transparent;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
  padding: 0 23.88px;
  margin: 10px 0 15px;
}
@media screen and (min-width: 768px) {
  .product-detail__tabs {
    gap: 8px;
  }
}
.product-detail__tab {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: calc(25% - 4px);
  height: 29px;
  border-radius: 100px;
  font-size: 16px;
  line-height: 23px;
  font-weight: 700;
  background-color: white;
  color: #e2e2e2;
  cursor: default;
}
@media screen and (min-width: 768px) {
  .product-detail__tab {
    width: calc(25% - 8px);
  }
}
.product-detail__tab.active {
  background-color: #ed7560;
  color: white;
}
.product-detail__slider .img-wrapper {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
.product-detail__slider .custom-owl-dots {
  margin-top: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
.product-detail__slider .custom-owl-dots .owl-dot {
  width: 40px;
  height: 40px;
  overflow: hidden;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  cursor: pointer;
}
.product-detail__slider .custom-owl-dots .owl-dot.active {
  box-shadow: none;
  border: 2px solid #ed7560;
  padding: 1px;
}
.product-detail__action {
  margin: 30px 0;
  text-align: center;
}
.product-detail__action .btn {
  height: 47px;
}
.product-detail__details-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6.4px;
  height: 48px;
  width: 100%;
  background: #bd6856;
  position: relative;
}
.product-detail__details-header::before {
  content: "";
  position: absolute;
  z-index: 5;
  bottom: -11.5px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 7.795px solid transparent;
  border-right: 7.795px solid transparent;
  border-top: 13.5px solid #bd6856;
}
.product-detail__details-title {
  font-size: 16px;
  line-height: 23px;
  font-weight: 700;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.64px;
  color: white;
}
.product-detail__details-content-wrapper {
  position: relative;
  overflow: hidden;
}
.product-detail__details-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 33.5px 20px 40px;
  background: white;
  font-size: 14px;
  line-height: 22px;
  font-weight: 500;
  transition: all 1s ease-in-out;
  opacity: 0;
  transform: translate3d(0, 20px, 0);
  will-change: transform, opacity;
  backface-visibility: hidden;
}
.product-detail__details-content.active {
  position: relative;
  opacity: 1;
  transform: translate3d(0, 0, 0);
}
.product-detail .pickup {
  background: #f3edd8;
}
.product-show__container {
  background: #fff8f3;
}
.product-show__hero {
  padding: 26px 20px 20px;
  margin-bottom: 9.44px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 25px;
  background: #f3edd8;
}
@media screen and (min-width: 768px) {
  .product-show__hero {
    padding: 46px 20px 30px;
  }
}
.product-show__hero .chapter {
  color: #490000;
}
.product-show__hero .chapter-title {
  width: 50px;
  display: flex;
  align-items: center;
  border-right: 1px dashed #490000;
  border-left: 1px dashed #490000;
}
.product-show__hero-img {
  max-width: 187.33px;
  aspect-ratio: 187.33/149;
}
@media screen and (min-width: 768px) {
  .product-show__hero-img {
    max-width: 195.33px;
    aspect-ratio: 195.33/157;
  }
}
.product-show__hero::before {
  content: "";
  position: absolute;
  bottom: -9.44px;
  left: 0;
  width: 100%;
  height: 9.44px;
  background: url("../img/wave_beige.png") repeat center center;
  background-size: contain;
}
.product-show__content {
  padding: 30.44px 20px 100px;
  text-align: center;
}
.product-show__info {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  justify-content: center;
  margin-bottom: 36px;
}
.product-show__info-description {
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
}
.product-show__info-title {
  position: relative;
  height: 88px;
  width: 290px;
  text-align: center;
}
.product-show__info-title--decoration {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 69px;
  z-index: 0;
}
.product-show__subtitle {
  position: relative;
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
  color: #bd6856;
  font-weight: 700;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}
.product-show__subtitle svg {
  position: absolute;
  bottom: 0;
  right: -12px;
}
.product-show__title {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
  color: #bd6856;
  font-weight: 700;
  position: relative;
  z-index: 1;
}
.product-show__title::before {
  content: "";
  position: absolute;
  bottom: 3px;
  left: 0;
  width: calc(100% - 6px);
  height: 4px;
  background: #f3edd8;
  z-index: -1;
}
.product-show__action .btn {
  height: 47px;
  border: 2px solid #984a3a;
}
.product-show__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px 21px;
}
.product-show__list .book-item {
  width: 100%;
  aspect-ratio: 1/1;
  border: 1px solid #bd6856;
  overflow: hidden;
  transition: all 0.3s ease;
}
.product-show__list .book-item img {
  transition: all 0.3s ease;
}
.product-show__list .book-item:hover {
  box-shadow: 0px 6px 8px 0px rgba(0, 0, 0, 0.3);
  transform: translateY(-2px);
  opacity: 0.9;
}
.product-show__list .book-item:hover img {
  transform: scale(1.05);
}
#news.news {
  background: #fff8f3;
}
#news.news .news__content {
  padding: 40px 20px 100px;
}
#news.news .news__more {
  margin-top: 36px;
  text-align: center;
}
.register-form--step-high {
  height: 465px !important;
}
.register-form.register-form--step8 {
  position: unset;
  transform: unset;
  height: unset;
  margin-left: auto;
  margin-right: auto;
}
.register-form.register-form--step8 .register-form-bottom {
  position: unset;
  transform: unset;
  justify-content: center;
}
.register-form.register-form--step9 {
  height: 480px;
}
#register-isbn {
  background-color: transparent;
  text-decoration: underline;
  padding: 5px;
}
#register-isbn-popup {
  border: 1px solid #000;
  padding: 10px;
  border-radius: 0;
}
#register-isbn-popup #btn-copy {
  font-size: 13px;
  border: 1px solid #000;
  border-radius: 50%;
  background-color: #fff;
  text-decoration: none;
  width: 70px;
  height: 70px;
  margin-top: 15px;
}
.text-ph-ccc::-moz-placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: #ccc;
  opacity: 1; /* Firefox */
}
.text-ph-ccc::placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: #ccc;
  opacity: 1; /* Firefox */
}
.text-ph-ccc::-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: #ccc;
}
.text-ph-ccc::-ms-input-placeholder {
  /* Microsoft Edge */
  color: #ccc;
}
.mr-register {
  background-color: #ebded6;
  background-size: auto;
  width: 100%;
  height: 100%;
}
.mr-register-content {
  height: 95vh;
  margin-top: 70px;
  position: relative;
}
.mr-register-bottom {
  height: 5vh;
}
.register-request-text {
  font-size: 15px;
  padding-top: 48px;
  text-align: center;
  line-height: 26px;
  font-weight: 500;
}
.register-warning {
  font-size: 14px;
  color: #f00;
  margin-top: 50px;
  margin-bottom: 5px;
  text-align: end;
  margin-right: 10%;
}
.register-form {
  background-color: white;
  padding: 5px 36px 36px 36px;
  text-align: center;
  position: absolute;
  height: 434px;
  width: 80%;
  left: 50%;
  top: 174px;
  transform: translate(-50%);
}
.step-num {
  font-size: 72px;
  display: inline-block;
  line-height: 72px;
  font-weight: 400;
}
.steps-total {
  font-weight: 400;
  font-size: 23px;
  margin-left: -3px;
}
.question-title {
  font-size: 14px;
  margin-bottom: 17px;
}
.multi-part-question-title {
  margin-top: 20px;
}
.register-select-box {
  width: 100%;
  font-size: 14px;
  border-radius: 4px;
  height: 36px !important;
  background-color: white;
}
.custom-register-select-box .select2-selection {
  border-radius: 0 !important;
  border: 1px solid black !important;
  display: flex !important;
  text-align: left;
  font-size: 13px;
}
.custom-register-select-box .select2-selection ul {
  margin-bottom: 0;
}
.register-question {
  font-size: 14px;
  margin-top: 35px;
}
.top-register-question {
  margin-top: 40px;
}
.mr-btn-back {
  text-align: left;
  font-size: 13px;
  color: black;
  bottom: 13px;
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: 17px;
  padding: 3px;
}
.return-chevron-left-button {
  vertical-align: middle;
  margin-right: 10px;
}
.date-col {
  display: inline-flex;
  padding: 0 5px;
}
.question-part {
  margin-bottom: 15px;
}
.question-part .question-label {
  font-size: 13px;
  text-align: left;
  margin-bottom: 3px;
  display: block;
  font-weight: 500;
}
.register-input {
  font-weight: 500;
  font-size: 13px;
  width: 100%;
  height: 24px;
  border-radius: 0;
  border: 1px solid black;
}
.register-form-bottom {
  position: absolute;
  bottom: 33px;
  left: 50%;
  transform: translate(-50%);
  display: flex;
}
.register-form-bottom button {
  font-size: 13px;
  border: 1px solid black;
  border-radius: 50%;
  background-color: white;
  text-decoration: none;
  width: 70px;
  height: 70px;
  font-weight: 500;
}
.guide-popup {
  background-image: url(../../img/bg-guide-popup.png);
  background-color: rgba(0, 0, 0, 0.831372549);
  width: 210px;
  height: 260px;
  padding: 12px 24px 33px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  left: 50%;
  color: white;
  font-size: 11px;
  z-index: 99;
}
.guide-popup p {
  word-break: break-all;
  line-height: 20px;
}
.guide-popup .fa-times {
  color: white;
  margin-left: -12px;
  margin-bottom: 25px;
}
.guide-popup .mr-btn,
.guide-popup .btn-next-page {
  width: 100%;
}
.guide-popup .mr-btn button,
.guide-popup .btn-next-page button {
  border: 1px solid white;
  background-color: transparent;
  text-align: center;
  font-size: 11px;
  border-radius: 0;
  padding: 5px;
  width: 100%;
  color: white;
  font-weight: 500;
}
.register-final {
  height: 95vh;
  text-align: center;
  width: 100%;
  margin-top: 70px;
}
.register-final .text {
  font-size: 20px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
.register-select-box.register-select-box--modify {
  padding: 0 0 0 5px;
}
.register-input.register-input--modify {
  padding: 5px;
}
.btn-prev-register {
  font-size: 13px;
  border: 1px solid black;
  border-radius: 50%;
  background-color: white;
  text-decoration: none;
  width: 70px;
  height: 70px;
  display: inline-block;
  color: black;
  font-weight: 500;
  line-height: 70px;
}
.btn-prev-register:hover {
  text-decoration: none;
  color: black;
}
#btn-copy-step-9 {
  font-size: 13px;
  border: 1px solid #000;
  border-radius: 50%;
  background-color: #fff;
  text-decoration: none;
  width: 45px;
  height: 45px;
}
.register-final-btn {
  text-align: center;
  bottom: 20vh;
  position: absolute;
  left: 50%;
  transform: translate(-50%);
}
.register-final-btn a {
  background: black;
  color: white;
  font-weight: 700;
  font-size: 13px;
  padding: 10px 50px;
  border-radius: 23px;
}
.nickname-random-wrap .nickname-recommendation {
  margin-top: 15px;
  margin-bottom: 0;
}
.nickname-random-wrap .nickname-text span {
  text-decoration: underline;
}
.nickname-random-wrap .nickname-text i {
  transform: rotate(-90deg);
  font-size: 20px;
  margin-left: 5px;
  cursor: pointer;
}
.custom-time-selectbox-step2 {
  min-width: 6px;
}
select#customer_register_birth_year {
  min-width: 70px;
}
.rm-inner {
  padding-left: 28px;
  padding-right: 28px;
  background-color: #ebded6;
}
.rm-inner .title-of-step {
  font-size: 15px;
  line-height: 26px;
  font-weight: 500;
  font-family: "YuGothic";
  text-align: center;
  min-height: 173px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.rm-inner .title-of-step p {
  margin-bottom: 0;
}
.rm-inner .question-text {
  margin-bottom: 0;
  font-size: 14px;
  line-height: 26px;
  font-weight: 500;
}
.rm-content {
  min-height: 495px;
  background-image: url("../img/bg-mypage-register.png");
  background-size: cover;
  position: relative;
  padding: 28px 33px 14px 33px;
}
.rm-content .rm-corner-bg-wrap {
  width: 106px;
  height: 80px;
  position: absolute;
  bottom: 0;
  right: 0;
}
.rm-content .rm-corner-bg-wrap img {
  position: absolute;
  bottom: 0;
}
.rm-btn-group {
  display: flex;
  justify-content: center;
}
.rm-btn {
  display: inline-block;
  background-color: #bf826b;
  width: 70px;
  height: 70px;
  line-height: 70px;
  text-align: center;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  font-family: "YuGothic";
  cursor: pointer;
  border-radius: 50%;
}
.rm-label {
  margin-bottom: 3px;
  font-size: 13px;
  font-weight: 500;
  font-family: "YuGothic";
}
.rm-step-1 {
  padding-bottom: 16px;
}
.rm-step-1 .rm-form-group {
  margin-bottom: 22px;
}
.rm-step-1 .rm-form-group.rm-form-group--last {
  margin-bottom: 39px;
}
.rm-step-1 .rm-content {
  padding: 28px 33px 14px 33px;
}
.rm-step-1 .question-part {
  margin-bottom: 40px;
}
.rm-step-1 .rm-btn-back {
  color: #fff;
  font-family: "YuGothic";
  font-size: 13px;
  font-weight: 500;
  line-height: 26px;
  margin-top: 35px;
  margin-left: -11px;
  display: inline-block;
}
.mr-register-step-1 {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.mr-register-step-1__note {
  display: flex;
  gap: 4px;
  font-size: 12px;
  line-height: 17px;
  color: #b3b3b3;
}
.mr-register-step-1__date-of-birth .form-label {
  font-size: 14px;
  line-height: 20px;
  margin-bottom: 8px;
}
.mr-register-step-1__date-of-birth--content {
  display: flex;
  align-items: end;
  gap: 8px;
}
.mr-register-step-1__date-of-birth--content .mr-select-box {
  width: -moz-fit-content;
  width: fit-content;
}
.mr-register-step-1__date-of-birth--content .js-select-zodiac-year {
  width: 64px;
}
.mr-register-step-1__date-of-birth--content .js-select-zodiac-month, .mr-register-step-1__date-of-birth--content .js-select-zodiac-day {
  width: 48px;
}
.mr-register-step-1__date-of-birth--content .time-unit {
  font-size: 14px;
  line-height: 20px;
}
.mr-register-step-1__form {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.mr-register-step-1__sex-description-box {
  display: flex;
  align-items: end;
  justify-content: center;
  font-size: 14px;
  line-height: 20px;
  gap: 8px;
}
.mr-register-step-1__sex-description-box .age-text,
.mr-register-step-1__sex-description-box .sex-text {
  width: 48px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(133, 179, 174, 0.1490196078);
}
.mr-register-step-1__sex, .mr-register-step-1__object-love, .mr-register-step-1__marriage {
  display: flex;
  gap: 14px;
}
.mr-register-step-1__sex {
  flex-direction: row-reverse;
}
.mr-register-step-1__sex .js-form-select:has(input[type=radio]:checked) {
  background: rgba(237, 117, 96, 0.1490196078);
}
.mr-register-step-1__object-love {
  flex-direction: row-reverse;
}
.mr-register-step-1__marriage {
  flex-direction: column;
}
.rm-question-content {
  text-align: center;
}
.rm-question-content .step-number-block {
  font-family: "Bodoni 72";
  font-weight: 350;
}
.rm-question-content .step-number-block .current-step {
  font-size: 72px;
}
.rm-question-content .step-number-block .slash-step {
  font-size: 23px;
}
.rm-question-content .step-number-block .total-step {
  font-size: 23px;
}
.rm-step-2 {
  padding-bottom: 73px;
}
.rm-step-2 .rm-content {
  padding-top: 0;
}
.rm-step-2 h6.question-text {
  margin-bottom: 68px;
  margin-top: 17px;
}
.rm-step-2 .rm-form-group {
  margin-bottom: 105px;
}
.rm-step-3 {
  padding-bottom: 73px;
}
.rm-step-3 .rm-content {
  padding-top: 0;
}
.rm-step-3 .question-text {
  margin-top: 14px;
}
.rm-step-3 .top-register-question {
  margin-top: 26px;
}
.rm-step-3 .so-text {
  margin-bottom: 8px;
  text-align: center;
  display: block;
}
.rm-step-3 .i-read-text {
  margin-top: 10px;
  display: block;
  text-align: center;
  margin-bottom: 44px;
}
.rm-step-4 .preface {
  margin-bottom: 12px;
  padding: 24px 20px;
  background: rgba(237, 117, 96, 0.15);
  border-radius: 2px;
}
.rm-step-4 .preface__text {
  font-size: 12px;
  line-height: 16px;
  font-family: "Noto Sans JP";
}
.rm-step-4 .preface__feature {
  display: flex;
  align-items: center;
  gap: 4px;
  color: #ed7560;
  margin: 12px 0 8px;
}
.rm-step-4 .preface__feature-title {
  font-weight: 700;
  font-size: 14px;
  line-height: 18px;
}
.rm-step-4 .preface__feature-icon {
  width: 20px;
  height: 18px;
}
.rm-step-4 .preface__image {
  width: 100%;
  height: auto;
  margin: 8px 0 12px;
}
.rm-step-4 .book {
  margin-top: 30px;
}
.rm-step-4 .book .has-icon .form-input, .rm-step-4 .book .has-icon .mr-select-box select, .mr-select-box .rm-step-4 .book .has-icon select {
  padding-right: 35px;
}
.rm-step-4 .book .has-icon img {
  position: absolute;
  width: 14px;
  height: 14px;
}
.rm-step-4 .book__order {
  margin-bottom: 12px;
  padding-bottom: 10px;
  font-size: 14px;
  font-weight: 700;
  line-height: 18px;
  color: #b3b3b3;
  border-bottom: 1px solid #b3b3b3;
}
.rm-step-4 .book__isbn {
  margin: 12px 0 2px;
}
.rm-step-4 .book__isbn-note {
  display: flex;
  gap: 4px;
  font-family: "Shippori Mincho";
  font-size: 12px;
  line-height: 17px;
  letter-spacing: -0.8px;
}
.rm-step-4 .book__isbn-note p {
  overflow-wrap: anywhere;
}
.rm-step-4 .book__isbn-icon {
  color: #b3b3b3 !important;
}
.rm-step-4 .book__isbn-icon.is-filled {
  color: #000000 !important;
}
.rm-step-4 .rm-btn-group {
  margin-top: 30px;
}
.rm-step-4 .rm-content {
  padding-top: 0;
}
.rm-step-4 .question-text {
  letter-spacing: -2px;
  margin-top: -14px;
  margin-bottom: 14px;
}
.rm-step-4 .question-part {
  margin-bottom: 3px;
}
.rm-step-4 #register-isbn {
  font-size: 7px;
  font-weight: 500;
  font-family: "YuGothic";
  text-decoration: none;
  border: 1px solid #000;
  width: 59px;
  height: 31px;
  border-radius: 50%;
}
.rm-step-4 .register-isbn-wrap {
  text-align: center;
  margin-top: 17px;
  margin-bottom: 21px;
}
.rm-step-4 #register-isbn-popup {
  width: 202px;
  min-height: 292px;
  padding-top: 9px;
  padding-left: 19px;
  font-weight: 500;
}
.rm-step-4 #register-isbn-popup .isbn-popup-title {
  margin-bottom: 0;
  font-size: 15px;
  font-weight: inherit;
  font-family: "YuGothic";
  line-height: 26px;
  letter-spacing: -1px;
}
.rm-step-4 #register-isbn-popup .isbn-label {
  margin-bottom: 0;
  font-size: 14px;
}
.rm-step-4 #register-isbn-popup .isbn-item {
  display: flex;
  flex-direction: column;
  overflow-wrap: anywhere;
}
.rm-step-4 #register-isbn-popup .book-paragraph {
  min-height: 17px;
  font-size: 12px;
  font-weight: inherit;
}
.rm-step-4 #register-isbn-popup .register-input {
  width: 68%;
}
.rm-step-4 #register-isbn-popup #btn-copy {
  width: 31px;
  height: 31px;
  font-size: 7px;
  font-weight: inherit;
  margin-top: 10px;
}
.rm-step-5 {
  padding-bottom: 73px;
}
.rm-step-5 .rm-content {
  padding: 31px 14px 0 14px;
}
.rm-step-5 #btn-copy-step-9 {
  margin-bottom: 95px;
  width: 33px;
  height: 33px;
  font-size: 7px;
  font-weight: 500;
  font-family: "YuGothic";
}
#nickname-wrap {
  margin-bottom: 21px;
}
#nickname-wrap .register-input {
  height: 40px;
  font-size: 22px;
}
.rm-step-5-note {
  font-size: 10px;
  font-weight: 500;
  font-family: "YuGothic";
  margin-bottom: 38px;
}
.rm-step-6 {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rm-step-6 .rm-item-heading {
  margin-bottom: 4px;
  font-family: "Noto Sans JP";
  font-size: 12px;
  line-height: 18px;
  font-weight: 700;
}
.rm-step-6 .rm-item-book {
  margin-top: 4px;
}
.rm-step-6 .rm-item-book__order {
  display: block;
  font-family: "Noto Sans JP";
  font-size: 12px;
  line-height: 18px;
}
.rm-step-6 .rm-item-book__content {
  font-family: "Noto Sans JP";
  font-size: 12px;
  line-height: 1;
}
.rm-step-6 .rm-item-content {
  font-family: "Noto Sans JP";
  font-size: 12px;
  line-height: 18px;
}
.rm-step-6 .rm-item-warning {
  font-family: "Noto Sans JP";
  font-size: 12px;
  line-height: 1;
  color: #ed7560;
}
.rm-step-6 .zodiac-description-box {
  padding-right: 0;
}
#rm-step-6-form .rm-step-6-group-button {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.rm-step-final .button-section {
  margin-top: 10px;
  padding: 24px 20px 30px;
  width: 100%;
  background-color: white;
  border-radius: 4px;
}
@media screen and (min-width: 375px) and (max-height: 667px) {
  .rm-inner .title-of-step {
    min-height: 100px;
  }
  .rm-step-1 .rm-content {
    padding-top: 10px;
  }
  .rm-step-1 .question-part {
    margin-bottom: 20px;
  }
  .rm-step-1 .zodiac-description-box {
    margin-bottom: 20px;
  }
  .rm-step-1 .rm-form-group {
    margin-bottom: 12px;
  }
  .rm-step-1 .rm-form-group.rm-form-group--last {
    margin-bottom: 12px;
  }
  .rm-step-2 h6.question-text {
    margin-bottom: 20px;
  }
  .rm-step-2 .rm-form-group {
    margin-bottom: 35px;
  }
  .rm-step-3 .question-text {
    margin-top: 0;
  }
  .rm-step-3 .top-register-question {
    margin-top: 10px;
  }
  .rm-step-3 .i-read-text {
    margin-bottom: 20px;
  }
  .rm-step-4 .question-text {
    margin-bottom: 0;
  }
  .rm-step-4 .register-isbn-wrap {
    margin-top: 5px;
    margin-bottom: 5px;
  }
  .rm-step-5 #btn-copy-step-9 {
    margin-bottom: 20px;
  }
}
.mr-profile-layout {
  padding: 36px 0 60px;
  margin: 0 auto;
  max-width: 375px;
}
@media screen and (min-width: 414px) {
  .mr-profile-layout {
    padding: 36px 10px 60px;
    max-width: unset;
  }
}
.mr-profile-content {
  font-family: "Playfair Display", serif;
}
.mr-profile-content img {
  height: revert-layer;
  width: revert-layer;
}
.dp-back-btn {
  width: 75px;
  padding: 5px 10px;
  border: solid 1px black;
  cursor: pointer;
  border-radius: 20px;
}
.dp-back-btn .db-back-text {
  font-family: "Shippori Mincho", serif;
  font-size: 13px;
  font-weight: 500;
  margin-right: 0;
  padding: 0 10px;
}
.dp-back-btn .db-back-mypage {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  color: black;
}
.view-contract {
  padding: 10px 22px 0 22px;
  text-align: center;
  display: flex;
  justify-content: space-between;
  font-size: 13px;
}
.view-contract.view-contract--modify {
  display: inline-block;
  color: #fff !important;
  background-color: #000000;
  border: solid 1px black;
  border-radius: 4px;
  padding: 5px 10px;
  margin-top: 15px;
  align-items: center;
  width: 50%;
  height: 32px;
}
.view-contract .view-contract-edit {
  color: #000;
  border: solid 1px black;
  border-radius: 3px;
  padding: 7px 20px;
  width: 49%;
}
.mr-profile-title-ph3 {
  padding: 0 22px 10px 22px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 600;
}
.mr-profile-title-ph3 .more-info {
  font-weight: lighter;
  color: grey;
  font-size: 12px;
}
.mr-profile-title-ph3 .more-info i {
  padding: 5px;
}
#view-plan-popup .modal-content {
  border-radius: 0;
  border: 0;
}
#view-plan-popup .modal-body {
  font-size: 15px;
  font-weight: 400;
  color: #000;
  padding: 0 25px 10px;
}
#view-plan-popup .modal-footer {
  border: 0;
  display: flex;
  justify-content: center;
}
#view-plan-popup h5 {
  margin-bottom: 16px;
}
#view-plan-popup .contact-note {
  text-align: center;
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 13px;
  font-family: "Yu Gothic";
  font-weight: 500;
}
#view-plan-popup .modal-content {
  margin: auto;
}
.form-control.form-control--reset {
  outline: 0;
}
.form-control.form-control--reset:focus {
  border: 0;
  box-shadow: none;
}
.mr-full-name {
  font-size: 30px;
  font-family: "Libre Baskerville", serif;
  line-height: 1;
  margin: 0 !important;
  padding-left: 22px;
  padding-top: 15px;
  position: relative;
}
.mr-full-name img {
  position: absolute;
  padding-left: 10px;
}
.mr-datetime-join-ph3 {
  font-size: 13px;
  color: grey;
  padding: 0 0 5.5px 22px;
}
.block-info-user-ph3 span {
  display: inline-block;
  border: solid 1px #c9c9c9;
  padding: 5px;
}
.view-detail-profile {
  margin: 15px 22px 0 10px;
  display: inline-block;
  text-align: center;
  color: #000;
  border: solid 1px black;
  border-radius: 4px;
  width: 50%;
  height: 32px;
}
.view-detail-profile:active {
  text-decoration: none;
  color: #000;
}
.view-detail-profile:hover {
  color: #000;
}
.view-detail-profile span {
  font-size: 13px;
}
.mr-view-apero-ph3 {
  display: flex;
  padding-left: 22px;
  padding-right: 22px;
  position: relative;
  font-size: 13px;
  justify-content: space-between;
  height: 40px;
}
.mr-view-apero-ph3 a {
  color: #000;
  border: solid 1px #bf826b;
  border-radius: 20px;
  padding: 10px 13px;
  background-color: white;
  text-align: center;
  width: 49%;
}
.mr-view-apero-ph3 a:hover {
  background-color: #bf826b;
  color: white;
}
.mr-view-apero-ph3 .active {
  background-color: #bf826b !important;
  color: white !important;
}
.mr-view-apero-ph3 .num-count-notify {
  position: absolute;
  right: 22px;
  top: -10px;
  border-radius: 50%;
  width: 22px;
  text-align: center;
  background-color: #ff672e;
  height: 22px;
  font-size: 11px;
  color: white;
  border: 2px white solid;
  font-weight: bold;
}
.close-detail-profile {
  margin-left: 22px;
  display: grid;
}
.close-detail-profile .close {
  align-items: center;
  margin-bottom: 10px;
  font-weight: normal;
  font-size: 14px;
  opacity: 100%;
}
.close-detail-profile .close:not(:disabled):not(.disabled) {
  cursor: pointer;
}
.close-detail-profile span {
  font-size: 14px;
}
.close-detail-profile .close-text {
  float: left;
  width: calc(100% - 100px);
  padding-top: 4px;
}
.close-detail-profile .dp-back-btn {
  float: right;
}
.infomation {
  font-size: 13px;
  margin-top: 50px;
}
.infomation p {
  font-weight: bold;
}
.infomation .icon {
  margin-top: 14px;
  display: flex;
  justify-content: center;
}
.infomation .icon i {
  vertical-align: -webkit-baseline-middle;
}
.infomation .footer {
  display: flex;
  justify-content: flex-end;
}
.infomation .button {
  background: transparent;
  font-size: 13px;
  color: #9b9b9b;
}
.infomation .js-btn-edit {
  display: none;
  cursor: pointer;
}
.infomation .btn-save {
  display: block;
}
.infomation .triangle {
  text-align: initial;
}
.js-mypage-info-bar {
  background: white;
  border: 1px solid rgba(112, 112, 112, 0.0784313725);
  height: 44px;
  margin-top: 9px;
  box-shadow: 0 5px 9px 1px rgba(0, 0, 0, 0.0117647059);
  padding-left: 22px;
  position: relative;
  display: none;
  border-radius: 5px;
}
.js-mypage-info-bar.twitter-bar {
  display: block;
}
.js-mypage-info-bar input {
  outline: none;
  border: none;
  width: 100%;
  height: 41px;
}
.js-mypage-info-bar .while-mask {
  display: none;
  width: 100%;
  height: 100%;
  position: absolute;
  padding: 11px;
}
.js-edit-mypage .js-mypage-info-bar .while-mask {
  display: block;
}
.js-edit-mypage .js-btn-edit {
  display: block;
}
.js-edit-mypage .btn-save {
  display: none;
}
.triangle::after {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
}
.triangle:before {
  display: none;
  margin-top: 2px;
  margin-left: 5px;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid rgba(112, 112, 112, 0.0784313725);
}
.triangle:after {
  top: 45px;
  left: 25px;
  margin-top: 12px;
  margin-left: -7px;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-bottom: 7px solid white;
}
.apero-schedule {
  font-size: 13px;
  padding: 0px 28px;
  margin-top: 15px;
}
.apero-schedule p {
  font-weight: bold;
}
.apero-schedule .schedule-box {
  background: white;
  border: 1px solid rgba(112, 112, 112, 0.0784313725);
  height: -moz-max-content;
  height: max-content;
  margin-top: 12px;
  box-shadow: 0 5px 9px 1px rgba(0, 0, 0, 0.0117647059);
  padding: 20px 0 20px 22px;
  font-weight: normal;
}
.apero-schedule .schedule-box .row {
  padding-left: 22px;
}
.apero-content {
  background-color: #eeeeee;
  margin-top: 20px;
  padding: 30px 22px 0 22px;
}
.box-button-contract {
  padding-left: 22px;
  display: flex;
}
.monthly-apero {
  background: #fff;
  border: 1px solid #9c9c9c;
  position: relative;
  min-height: 206px;
}
.monthly-apero .bg-tab {
  height: 40px;
  background: #f3f3f3;
}
.monthly-apero .chapter-tab {
  width: 50%;
  height: 40px;
  font-size: 14px;
  font-weight: bold;
  padding: 10px 0 0 11px;
  text-align: center;
}
.monthly-apero .chapter-tab img {
  width: 21px;
  height: 21px;
}
.monthly-apero .chapter-tab.active {
  background: #fff;
}
.monthly-apero .person-tab {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  width: 50%;
  height: 40px;
}
.monthly-apero .person-tab img {
  width: 23px;
  height: 23px;
}
.monthly-apero .person-tab p {
  font-size: 13px;
  font-weight: 700;
  width: 100%;
  text-align: center;
}
.monthly-apero .override-tab {
  content: "";
  position: absolute;
  right: 5px;
  transform: skewX(12deg);
  width: 50%;
  height: 39px;
  top: 0;
  background: #f3f3f3;
  border-left: 1px solid #9c9c9c;
  border-bottom: 1px solid #9c9c9c;
}
.monthly-apero .override-tab::before {
  content: "";
  width: 0;
  height: 0;
  border-left: 0px solid transparent;
  border-right: 16px solid transparent;
  border-top: 28px solid #9c9c9c;
  top: 0px;
  position: absolute;
}
.monthly-apero .override-tab::after {
  content: "";
  width: 0;
  height: 0;
  border-left: 0px solid transparent;
  border-right: 16px solid transparent;
  border-top: 28px solid #eeeeee;
  top: -1px;
  position: absolute;
}
.monthly-apero .title {
  font-size: 14px;
  font-weight: bold;
  padding: 10px 0 0 0px;
}
.monthly-apero .title .icon-apero {
  width: 32px;
  height: 33px;
  background: url("../img/icon-apero.png");
  margin-right: 8px;
}
.monthly-apero .count-apero-request .num {
  z-index: 9999;
  position: absolute;
  right: 17px;
  top: 10px;
  border-radius: 50%;
  width: 18px;
  text-align: center;
  background-color: #000000;
  height: 18px;
  font-size: 11px;
  color: white;
  font-weight: bold;
}
.mr-apero-tab {
  padding-left: 22px;
  border: none;
}
.item-box-border-lightPink {
  min-height: 305px;
  width: 100%;
  padding: 14px 20px 25px 20px;
  text-align: center;
  position: relative;
}
.item-box-border-lightPink::before {
  position: absolute;
  content: "";
  width: 111px;
  height: 14px;
  border-top: 1px solid black;
  clip-path: polygon(29% 0, 99% 0, 100% 0%, 98% 66%, 97% 64%, 36% 82%);
  background: #ebded6;
  right: -14px;
  bottom: 11px;
  transform: rotate(-45deg);
}
.item-box-border-lightPink::after {
  border-bottom: 70px solid #fff;
  border-left: 70px solid transparent;
  content: "";
  position: absolute;
  bottom: 0px;
  right: -11px;
}
.item-box-border-lightGreen {
  min-height: 305px;
  width: 100%;
  padding: 14px 20px 25px 20px;
  text-align: center;
  position: relative;
}
.item-box-border-lightGreen::before {
  position: absolute;
  content: "";
  width: 111px;
  height: 14px;
  border-top: 1px solid black;
  clip-path: polygon(29% 0, 99% 0, 100% 0%, 98% 66%, 97% 64%, 36% 82%);
  background: #cbd3cb;
  right: -14px;
  bottom: 11px;
  transform: rotate(-45deg);
}
.item-box-border-lightGreen::after {
  border-bottom: 70px solid #fff;
  border-left: 70px solid transparent;
  content: "";
  position: absolute;
  bottom: 0px;
  right: -11px;
}
.item-box-border-crimson {
  min-height: 305px;
  width: 100%;
  padding: 14px 20px 25px 20px;
  text-align: center;
  position: relative;
}
.item-box-border-crimson::before {
  position: absolute;
  content: "";
  width: 111px;
  height: 14px;
  border-top: 1px solid black;
  clip-path: polygon(29% 0, 99% 0, 100% 0%, 98% 66%, 97% 64%, 36% 82%);
  background: #bf826b;
  right: -14px;
  bottom: 11px;
  transform: rotate(-45deg);
}
.item-box-border-crimson::after {
  border-bottom: 70px solid #fff;
  border-left: 70px solid transparent;
  content: "";
  position: absolute;
  bottom: 0px;
  right: -11px;
}
.apero-item {
  margin-top: 20px;
  padding: 0 17px;
}
.apero-item .btn-disabled-call {
  background: #e5e5e5 !important;
  cursor: no-drop;
}
.apero-item .mr-time {
  font-family: "Playfair Display", serif;
  width: 50px;
}
.apero-item .mr-time .mr-year {
  color: #828282;
  font-size: 16px;
  font-weight: bold;
}
.apero-item .mr-time .mr-month {
  color: black;
  font-size: 40px;
  line-height: 40px;
}
.apero-item .mr-time .mr-day {
  color: black;
  font-size: 18px;
  font-weight: bold;
}
.apero-item .chapter-name {
  font-family: "Playfair Display", serif;
  font-size: 30px;
  margin-top: -100px;
  font-weight: normal;
}
.apero-item .chapter-name::first-letter {
  font-size: 2em;
}
.apero-item .chapter-name strong {
  font-size: 48px;
  font-weight: 400;
  margin-bottom: 20px;
  font-family: "Playfair Display", serif;
}
.apero-item.apero-chapter-1 .chapter-img {
  margin: 15px 0 0 0;
}
.apero-item.apero-chapter-1 .chapter-img img {
  width: 95px;
  height: 84px;
}
.apero-item.apero-chapter-2 .chapter-img {
  margin: 15px 0 0 0;
}
.apero-item.apero-chapter-2 .chapter-img img {
  width: 124px;
  height: 82px;
}
.apero-item.apero-chapter-2 .chapter-des {
  min-height: 40px;
  vertical-align: middle;
  display: flex;
  justify-content: center;
  align-items: center;
}
.apero-item.apero-chapter-3 .chapter-img {
  margin: 0px 0 0 0;
}
.apero-item.apero-chapter-3 .chapter-img img {
  width: 167px;
  height: 111px;
}
.apero-item .btn {
  padding: 0;
}
.apero-item .btn button {
  border-radius: 23px;
  width: 220px;
  background: black;
  color: white;
  font-size: 15px;
  font-weight: bold;
  padding: 7px 0;
}
.apero-item .btn .btn-link {
  border-radius: 23px;
  width: 220px;
  background: black;
  color: white;
  font-size: 15px;
  font-weight: bold;
  padding: 7px 0;
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
}
.apero-item .btn .btn-link:hover {
  color: white;
}
.apero-item .result-noti {
  font-size: 15px;
  font-weight: bold;
}
.apero-item .live-noti {
  margin-top: 20px;
  font-size: 13px;
  line-height: 13px;
  display: inline-block;
}
.apero-item .chapter-closed-info {
  margin-left: 56px;
  text-align: left;
}
.apero-item .item-box-closed {
  width: 100%;
  padding: 14px 20px;
  text-align: center;
  position: relative;
  background: #e5e5e5;
}
.apero-item .item-box-closed::before {
  position: absolute;
  content: "";
  width: 111px;
  height: 14px;
  border-top: 1px solid black;
  clip-path: polygon(29% 0, 99% 0, 100% 0%, 98% 66%, 97% 64%, 36% 82%);
  background: #959595;
  right: -14px;
  bottom: 11px;
  transform: rotate(-45deg);
}
.apero-item .item-box-closed::after {
  border-bottom: 70px solid #fff;
  border-left: 70px solid transparent;
  content: "";
  position: absolute;
  bottom: 0px;
  right: -11px;
}
.apero-item .item-box-closed .mr-time {
  width: 50px;
  color: #8b8b8b;
}
.apero-item .item-box-closed .mr-time .mr-year {
  font-size: 16px;
  font-weight: bold;
}
.apero-item .item-box-closed .mr-time .mr-month {
  font-size: 40px;
  line-height: 40px;
}
.apero-item .item-box-closed .mr-time .mr-day {
  font-size: 18px;
  font-weight: bold;
}
.apero-item .item-box-closed .chapter-name {
  font-size: 30px;
  margin-top: -100px;
  font-weight: normal;
}
.apero-item .item-box-closed .chapter-name::first-letter {
  font-size: 2em;
}
.apero-item .item-box-closed .chapter-name strong {
  font-size: 48px;
  font-weight: 400;
  margin-bottom: 20px;
  font-family: "Playfair Display", serif;
}
.apero-item .item-box-closed .chapter-closed-info {
  margin-left: 56px;
  text-align: left;
  font-weight: normal;
}
.apero-item .item-box-closed .chapter-closed-info span {
  color: #767676;
  font-size: 14px;
}
.my-best-book {
  margin-left: 22px;
  margin-right: 22px;
  margin-top: 11px;
  font-weight: normal;
}
.my-best-book .row {
  margin-right: 0;
}
.my-best-book .best-book-ph3 {
  display: inline-block;
  padding: 10px 5px 0 0;
  width: 33%;
  overflow: hidden;
}
.my-best-book .best-book-ph3 img {
  width: 100%;
  max-width: 105px;
  aspect-ratio: 105/150;
}
@media screen and (min-width: 768px) {
  .my-best-book .best-book-ph3 img {
    max-width: 124px;
    aspect-ratio: 124/177;
  }
}
.my-best-book .best-book-ph3 p {
  font-size: 14px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.reading-habits {
  margin-left: 22px;
  font-size: 14px;
}
.reading-habits div {
  margin-top: 20px;
}
.reading-habits div p.text {
  font-weight: normal;
}
.book-purchase-history {
  margin-left: 20px;
  margin-top: 20px;
  font-size: 14px;
  padding: 0 0 0 0px;
  overflow: hidden;
}
.book-purchase-history .text {
  font-weight: normal;
}
.list-book {
  margin-top: 0;
  margin-left: -8px;
  z-index: unset;
}
.list-book .item {
  height: 140px;
  padding: 8px;
}
.list-book .item-box {
  width: 110px;
  height: 110px;
  border: 1px solid #ccc;
  background: white;
  padding: 4px;
}
.list-book .item-star {
  width: 108px;
  text-align: center;
  margin-top: 6px;
}
.popup-review-book {
  background: #ececec;
  padding: 70px 19px;
  overflow: auto;
  width: -moz-fit-content;
  width: fit-content;
}
.popup-review-book .popup-content {
  background: white;
  width: 336px;
}
.popup-review-book .mr-time {
  padding-top: 10px;
  margin-left: 15px;
  text-align: center;
  width: 50px;
}
.popup-review-book .mr-time .mr-year {
  color: #828282;
  font-size: 16px;
  font-weight: bold;
}
.popup-review-book .mr-time .mr-month {
  color: black;
  font-size: 40px;
  line-height: 40px;
}
.popup-review-book .mr-time .mr-day {
  color: black;
  font-size: 18px;
  font-weight: bold;
}
.popup-review-book .review-text {
  font-size: 13px;
  text-align: center;
  margin-top: -22px;
}
.popup-review-book .ratings_vote {
  display: flex;
  align-items: end;
  height: 27px;
  justify-content: center;
  margin-top: 20px;
}
.popup-review-book .book-img {
  width: 247px;
  height: 247px;
  background: white;
  border: 1px solid black;
  margin-top: 26px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.popup-review-book .book-img img {
  width: 100%;
  height: 100%;
}
.popup-review-book .author {
  font-size: 13px;
  margin-left: 40px;
}
.popup-review-book .author p {
  margin-top: 27px;
}
.popup-review-book .review-btn {
  text-align: center;
  padding: 15px 30px;
}
.popup-review-book .review-btn button {
  color: white;
  font-size: 16px;
  font-weight: bold;
  background: black;
  border-radius: 23px;
  width: 100%;
  height: 45px;
}
.bg-zebra {
  background-image: url("../img/zebra-sub.png"), url("../img/zebra.png");
  background-size: cover;
  margin-top: 70px;
  padding-bottom: 70px;
  font-family: "Playfair Display", serif;
}
.bg-zebra .topic {
  text-align: center;
}
.bg-zebra .topic img {
  width: auto;
  height: auto;
}
.bg-zebra .join-title {
  font-family: "Playfair Display", serif;
  font-size: 40px;
  text-align: center;
}
.bg-zebra .join-description {
  font-size: 14px;
  text-align: center;
}
.bg-zebra .join-description i {
  color: #16c60c;
}
.bg-zebra .join-date {
  text-align: center;
  font-family: "Yu Gothic";
  font-size: 23px;
  font-weight: 700;
  text-decoration: underline;
  margin-bottom: 11px;
  margin-top: 5px;
}
.bg-zebra .join-choose-book {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: 10px;
  margin-bottom: 10px;
}
.bg-zebra .join-book-box {
  width: 248px;
  background: #fff;
  height: 248px;
  padding: 5px;
}
.bg-zebra .join-book-box .book-item {
  padding: 4px;
}
.bg-zebra .join-book-box img {
  width: 100%;
  height: 100%;
}
.bg-zebra .join-select {
  padding: 18px;
}
.bg-zebra .select-book-form {
  padding: 17px;
  background: #fff;
  font-size: 14px;
  margin-top: 10px;
}
.bg-zebra .select-book-form .row {
  padding-left: 15px;
  height: 43px;
}
.bg-zebra .select-book-form .row div {
  padding: 0;
  text-align: left;
}
.bg-zebra .join-btn {
  height: 45px;
  text-align: center;
  margin-top: 10px;
}
.bg-zebra .join-btn button {
  border-radius: 23px;
  width: 220px;
  background: black;
  color: white;
  font-size: 15px;
  font-weight: bold;
  padding: 13px 0;
}
.bg-zebra .denial-btn {
  height: 45px;
  margin-top: 30px;
  display: table;
  width: 100%;
  padding: 0 10px;
}
.bg-zebra .denial-btn div {
  text-align: center;
  padding: 0;
  display: table-cell;
  text-align: center;
}
.bg-zebra .denial-btn button {
  border-radius: 23px;
  width: 150px;
  background: black;
  color: white;
  font-size: 15px;
  font-weight: bold;
  padding: 13px 0;
}
.bg-zebra .denial-btn .btn-1 {
  background: #545050;
}
.bg-zebra .denial-btn .btn-2 {
  background: #635876;
}
.bg-zebra .join-text {
  font-size: 13px;
  padding: 30px;
}
.bg-zebra .join-bottom {
  height: 5vh;
  position: fixed;
  bottom: 0;
}
.bg-zebra .zebra-text {
  font-size: 16px;
  text-align: center;
  margin-top: 50px;
  font-weight: 500;
  font-family: "Shippori Mincho", serif;
  min-height: 454px;
}
.bg-zebra .book-disable {
  opacity: 0.3;
}
.bg-zebra .book-check {
  outline: 3px solid #f00 !important;
}
.bg-zebra .join-select .row {
  display: flex;
  align-items: center;
}
.bg-zebra .join-select .custom-fa-icon input[type=checkbox] {
  position: absolute;
  left: -999px;
}
.bg-zebra .join-select .custom-fa-icon label {
  cursor: pointer;
  display: inline;
}
.bg-zebra .join-select .custom-fa-icon label input[type=checkbox] + span:before {
  font-family: FontAwesome;
  content: "\f096";
  display: inline-block;
  font-weight: 400;
  font-style: normal;
  font-size: 2em;
  text-align: center;
  letter-spacing: 6px;
}
.bg-zebra .join-select .custom-fa-icon label input[type=checkbox]:checked + span:before {
  content: "\f046";
  letter-spacing: 3px;
  color: #16c60c;
}
.bg-message-zebra {
  background-image: url("../img/zebra-sub.png"), url("../img/zebra.png");
  background-size: cover;
  margin-top: 70px;
  padding: 12px;
}
.bg-message-zebra .mr-message-box {
  background: #5c5e5e;
  padding: 12px;
}
.bg-message-zebra .message-box-content {
  border: 1px solid white;
  color: #490000;
  text-align: center;
  padding: 24px 11px;
}
.bg-message-zebra h1 {
  font-size: 40px;
  font-weight: 350;
}
.bg-message-zebra h4 {
  font-size: 14px;
  font-weight: 500;
}
.bg-message-zebra .text-box {
  padding: 22px 0;
  text-align: center;
  font-size: 13px;
  color: #bd6856;
  background: white;
  margin-top: 20px;
}
.bg-message-zebra .email-box {
  padding: 12px 16px;
  margin-top: 10px;
  font-size: 13px;
  color: #bd6856;
  background: white;
  text-align: left;
  display: flex;
  justify-content: left;
  align-items: center;
}
.bg-message-zebra .email-box i {
  text-align: left;
}
.bg-message-zebra .email-box span {
  margin-left: 30px;
}
.bg-message-zebra .message-btn {
  margin-top: 10px;
  font-size: 13px;
}
.bg-message-zebra .message-btn button {
  border: 1px solid white;
  border-radius: 23px;
  padding: 6px 20px;
  background: transparent;
  color: white;
}
.bg-message-zebra .message-time {
  font-weight: 600;
  margin-top: 25px;
}
.bg-message-zebra .message-time .mr-num {
  font-size: 20px;
}
.bg-message-zebra .message-time .mr-text {
  font-size: 14px;
}
.bg-message-zebra .message-note {
  font-size: 13px;
  padding: 0 5px 0 40px;
  text-align: left;
  margin-top: 20px;
  position: relative;
  font-weight: 400;
}
.bg-message-zebra .message-note span::before {
  content: "※";
  font-size: 13px;
  position: absolute;
  left: 20px;
}
.bg-message-zebra .invitation-text {
  font-size: 14px;
  margin-top: 30px;
}
.bg-message-zebra .invitation-text {
  font-size: 17px;
  font-weight: 700;
}
.bg-message-zebra .invitation-btn {
  margin-top: 20px;
}
.bg-message-zebra .invitation-btn button {
  position: relative;
  background: black;
  font-size: 15px;
  font-weight: 700;
  color: white;
  padding: 14px 70px;
  border: 1px solid white;
  border-radius: 23px;
}
.bg-message-zebra .invitation-btn img {
  position: absolute;
  right: 15px;
  bottom: 8px;
}
.mr-profile-content-message {
  background-image: url("../img/bg-book.png");
  background-size: cover;
  width: 100%;
  padding-bottom: 60px;
}
#register_apero_call_schedule {
  background-color: #fff;
  padding: 15px;
}
#register_apero_no_schedule {
  background-color: #fff;
  padding: 15px;
  margin: 0 35px;
}
.bg-zebra {
  padding-bottom: 12px;
}
.bg-zebra .join-bottom {
  position: unset;
  height: unset;
}
.join-bottom .mr-btn-back {
  font-weight: 700;
  position: unset;
  justify-content: left;
}
.mr-thank-you.bg-zebra .zebra-text {
  margin-top: 46px;
}
.position-header-mypage-request {
  border-radius: 22px;
  box-shadow: 0 0 0.25em 0.25em rgba(0, 0, 0, 0.15);
  background: white;
  position: relative;
  top: -22px;
}
.block-notify-apero-request {
  background-color: #bf826b;
  padding: 10px 0;
}
.block-notify-apero-request .no-package {
  margin: 10px 22px;
  padding: 10px;
  background: #fff;
  border-radius: 10px;
  color: red;
  font-size: 12px;
}
.block-notify-apero-request .no-package p {
  overflow-wrap: break-word;
}
.block-notify-apero-request .text-notify-mail {
  display: inline-block;
  color: white;
  font-weight: bold;
  font-size: 14px;
  padding: 0;
}
.block-notify-apero-request .block-item-notify-request {
  background-color: white;
  margin: 10px 22px;
  padding: 5px;
  border-radius: 10px;
  display: flex;
  align-items: center;
}
.block-notify-apero-request .first-character-name {
  width: 28px;
  height: 28px;
  line-height: 1.6em;
  text-align: center;
  border: 1px solid lightgrey;
  border-radius: 50%;
  float: left;
  margin: 9px;
}
.block-notify-apero-request .bg-lover {
  background-color: #f3d6c8;
  color: #bf826b;
}
.block-notify-apero-request .bg-friend {
  background-color: #d4f3c8;
  color: #4a5f4f;
}
.block-notify-apero-request .content-notify-request {
  display: inline-block;
  font-size: 12px;
  margin-right: 25px;
  font-weight: normal;
}
.block-notify-apero-request .button-accept-request {
  display: inline-block;
  float: right;
  padding: 8px;
}
.block-notify-apero-request .button-accept-request a {
  background-color: black;
  color: white;
  border-radius: 25px;
  font-size: 12px;
  width: 46px;
  height: 24px;
  padding: 2px;
}
.block-notify-apero-request {
  /* The switch - the box around the slider */
}
.block-notify-apero-request .switch-receive-notify {
  display: inline-block;
  position: relative;
  width: 60px;
  height: 24px;
  margin: 10px 0 0 0;
  cursor: pointer;
}
.block-notify-apero-request .switch-receive-notify.off .label-off {
  opacity: 1;
}
.block-notify-apero-request .switch-receive-notify.off .label-on {
  opacity: 0;
}
.block-notify-apero-request .switch-receive-notify .label-switch {
  position: absolute;
  top: 1px;
  font-size: 14px;
  font-weight: normal;
  z-index: 1;
  transition: 0.4s;
}
.block-notify-apero-request .switch-receive-notify .label-off {
  opacity: 0;
  right: 8px;
  color: #999;
}
.block-notify-apero-request .switch-receive-notify .label-on {
  opacity: 1;
  left: 10px;
  color: #fff;
}
.block-notify-apero-request .switch-receive-notify {
  /* Hide default HTML checkbox */
}
.block-notify-apero-request .switch-receive-notify Z input {
  opacity: 0;
  width: 0;
  height: 0;
}
.block-notify-apero-request {
  /* The slider */
}
.block-notify-apero-request .slider-receive-notify {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 1px;
  background-color: #fff;
  cursor: pointer;
  transition: 0.4s;
}
.block-notify-apero-request .slider-receive-notify:before {
  content: "";
  position: absolute;
  height: 19px;
  width: 19px;
  left: 2px;
  bottom: 1px;
  background-color: #fff;
  border: 1px solid #bf826b;
  transition: 0.4s;
}
.block-notify-apero-request input:checked + .slider-receive-notify {
  background-color: #bf826b;
}
.block-notify-apero-request input:focus + .slider-receive-notify {
  box-shadow: 0 0 1px #bf826b;
}
.block-notify-apero-request input:checked + .slider-receive-notify:before {
  transform: translateX(35px);
}
.block-notify-apero-request {
  /* Rounded sliders */
}
.block-notify-apero-request .slider-receive-notify.round-receive-notify {
  border-radius: 25px;
  border: 1px solid white;
}
.block-notify-apero-request .slider-receive-notify.round-receive-notify:before {
  border-radius: 50%;
}
.block-apero-lover {
  background-color: #905946;
}
.block-apero-lover .btn-request-apero {
  background-color: #905946;
  color: white;
}
.block-apero-lover .first-character-name {
  color: #905946;
}
.block-apero-lover .border-item-inner i {
  background: #905946;
}
.block-apero-lover .hand-lover {
  background-image: url("../img/hand-lover-left.png");
}
.block-apero-lover .item--apero:nth-child(even) .hand-lover {
  background-image: url("../img/hand-lover-right.png");
}
.block-apero-friend {
  background-color: #4a5f4f;
  padding-bottom: 10px;
}
.block-apero-friend .btn-request-apero {
  background-color: #589365;
  color: white;
}
.block-apero-friend .first-character-name {
  color: #4a5f4f;
}
.block-apero-friend .border-item-inner i {
  background: #4a5f4f;
}
.block-apero-friend .hand-lover {
  background-image: url("../img/hand-friend-left.png");
}
.block-apero-friend .item--apero:nth-child(even) .hand-lover {
  background-image: url("../img/hand-friend-right.png");
}
.title-block-apero {
  padding: 20px 22px 0 20px;
  color: white;
  font-size: 13px;
  font-weight: bold;
}
.content-block-apero {
  font-size: 13px;
}
.content-block-apero .message-empty-suggestion {
  width: 100%;
  color: white;
  padding: 30px 40px 20px 40px;
}
.content-block-apero .apero-suggestion-block {
  padding: 10px 20px 0 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.content-block-apero .apero-suggestion-block .item--apero {
  background-color: white;
  width: 47%;
  height: 190px;
  text-align: center;
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  overflow: hidden;
}
.content-block-apero .apero-suggestion-block .item--apero .border-item-inner i {
  width: 30px;
  height: 30px;
  border-radius: 7px;
}
.content-block-apero .apero-suggestion-block .item--apero .border-item-inner .border-item__top {
  margin-top: -22px;
}
.content-block-apero .apero-suggestion-block .item--apero .border-item-inner .border-item__bottom {
  margin-top: -8px;
  margin-bottom: -22px;
}
.content-block-apero .apero-suggestion-block .item--apero .border-item-inner .border-item__left {
  float: left;
  margin-left: -23px;
}
.content-block-apero .apero-suggestion-block .item--apero .border-item-inner .border-item__right {
  float: right;
  margin-right: -22px;
}
.content-block-apero .apero-suggestion-block .item--apero .time-left-answer {
  color: #a1a1a1;
  font-size: 12px;
}
.content-block-apero .apero-suggestion-block .item--apero .btn-request-disable {
  background-color: #c9c4c3;
  color: white;
}
.content-block-apero .apero-suggestion-block .item--apero .mr-img-apero-request {
  padding-top: 14px;
}
.content-block-apero .apero-suggestion-block .item--apero .hand-close {
  background-image: url("../img/hand-close-left.png");
}
.content-block-apero .apero-suggestion-block .item--apero:nth-child(even) .hand-close {
  background-image: url("../img/hand-close-right.png");
}
.content-block-apero .apero-suggestion-block .nobody-request {
  background-color: gray;
}
.content-block-apero .content-survey-ccc {
  padding: 10px 20px 0 20px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
}
.content-block-apero .content-survey-ccc .survey-ccc {
  background-color: white;
  width: 100%;
  min-height: 190px;
  text-align: center;
  margin-bottom: 20px;
  overflow: hidden;
}
.content-block-apero .content-survey-ccc .survey-ccc .survey-ccc--title {
  font-weight: bold;
  padding-left: 20px;
  padding-bottom: 15px;
  padding-top: 5px;
}
.content-block-apero .content-survey-ccc .survey-ccc .survey-ccc--info {
  font-size: 12px;
  text-decoration: underline;
  padding-top: 5px;
  cursor: pointer;
}
.content-block-apero .content-survey-ccc .survey-ccc .btn-survey-start {
  background: #d7b7d4;
  border-radius: 20px;
  color: black;
  font-weight: bold;
  margin-top: 10px;
  margin-bottom: 5px;
}
.content-block-apero .content-survey-ccc .survey-ccc .btn-survey-disable {
  width: 55%;
  padding: 5px;
  margin-top: 20px;
  background: #c9c4c3;
  border-radius: 20px;
  color: white;
  font-weight: bold;
  cursor: not-allowed;
}
.content-block-apero .content-survey-ccc .survey-ccc .border-item-inner i {
  width: 36px;
  height: 30px;
  border-radius: 20px;
}
.content-block-apero .content-survey-ccc .survey-ccc .border-item-inner .border-item__top {
  margin-top: -20px;
}
.content-block-apero .content-survey-ccc .survey-ccc .border-item-inner .border-item__bottom {
  margin-top: -10px;
  margin-bottom: -20px;
}
.content-block-apero .content-survey-ccc .survey-ccc .border-item-inner .border-item__left {
  float: left;
  margin-left: -20px;
}
.content-block-apero .content-survey-ccc .survey-ccc .border-item-inner .border-item__right {
  float: right;
  margin-right: -20px;
}
#modalSurveyInfo .modal-survey-info--title {
  font-size: 15px;
  font-weight: bold;
}
#modalSurveyInfo .modal-survey-info--description {
  font-size: 15px;
  font-weight: bold;
  padding: 25px 0;
}
#modalSurveyInfo .modal-survey-info--content {
  font-size: 13px;
  font-weight: normal;
}
.btn-request-apero {
  display: inline-block;
  width: 75%;
  margin: 0 auto;
  padding: 2px 0;
  border-radius: 25px;
  font-size: 11px;
}
.nickname-suggest {
  padding: 5px;
  font-size: 14px;
  font-family: "Libre Baskerville", serif;
}
.first-character-name {
  font-size: 45px;
  position: absolute;
  top: 20px;
}
.btn-mr-disable {
  background-color: #e5e5e5 !important;
  color: #fff !important;
  cursor: pointer;
}
.hand-book {
  width: 100%;
  height: 106px;
  background-repeat: no-repeat;
}
.btn-mr {
  border-radius: 23px;
  width: 220px;
  font-size: 15px;
  font-weight: bold;
  padding: 7px 0;
  display: inline-block;
}
.btn-mr-available {
  background: #000;
  color: #fff;
}
@media screen and (min-width: 414px) {
  .hand-close,
  .hand-lover,
  .hand-friend {
    background-position-x: 30%;
  }
  .first-character-name {
    left: 45px;
    right: 50px;
  }
  .item--apero:nth-child(even) .hand-close,
  .item--apero:nth-child(even) .hand-lover,
  .item--apero:nth-child(even) .hand-friend {
    background-position-x: 70%;
  }
  .item--apero:nth-child(even) .first-character-name {
    left: 57px;
    right: 50px;
  }
}
@media screen and (min-width: 375px) {
  .hand-close,
  .hand-lover,
  .hand-friend {
    background-position-x: 30%;
  }
  .first-character-name {
    left: 50px;
    right: 50px;
  }
  .item--apero:nth-child(even) .hand-close,
  .item--apero:nth-child(even) .hand-lover,
  .item--apero:nth-child(even) .hand-friend {
    background-position-x: 70%;
  }
  .item--apero:nth-child(even) .first-character-name {
    left: 55px;
    right: 50px;
  }
}
@media screen and (min-width: 320px) {
  .hand-close,
  .hand-lover,
  .hand-friend {
    background-position-x: 20%;
  }
  .first-character-name {
    left: 50px;
    right: 50px;
  }
  .item--apero:nth-child(even) .hand-close,
  .item--apero:nth-child(even) .hand-lover,
  .item--apero:nth-child(even) .hand-friend {
    background-position-x: 70%;
  }
  .item--apero:nth-child(even) .first-character-name {
    left: 50px;
    right: 50px;
  }
}
.modal-apero-request {
  margin-left: 30px;
  margin-right: 30px;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.75);
  color: white;
  border-radius: 15px;
  padding: 10px;
}
.modal-apero-request .modal-footer {
  border: none;
}
.modal-apero-request .modal-footer .btn {
  color: white;
  text-decoration: none;
  width: 90px;
  border-radius: 25px;
  background-color: #905946;
}
.mr-process-ri-circle {
  position: absolute;
  top: 12px;
  right: 12px;
  background: white;
  border-radius: 50%;
}
.mr-process-ri-circle .percent {
  width: 34px;
  height: 34px;
}
.mr-process-ri-circle .percent svg {
  stroke-linecap: round;
}
.progress-ri-index {
  padding: 10px 22px 0 22px;
}
.progress-ri-index .progress-bar {
  position: relative;
  width: 100%;
  background: rgba(255, 255, 255, 0.1);
}
.progress-ri-index .progress-bar .progress-bar-info {
  border-radius: 5px;
  padding: 5px;
  background: #ce6541;
  color: white;
  width: 2%;
  position: relative;
  transition: width 3.3s ease-in-out;
}
.progress-ri-index .title {
  font-family: "Noto Sans JP", sans-serif;
}
.progress-ri-index .percent-ri-style {
  color: #ce6541;
  font-size: 19px;
  font-weight: bold;
  line-height: 20px;
}
.progress-ri-index .progress {
  height: 10px;
  border-radius: 25px;
  margin-top: 10px;
  margin-bottom: 15px;
}
.margin-top-10 {
  margin-top: 10px;
}
.block-action-apero-request {
  background-color: #bf826b;
  padding-bottom: 10px;
}
.block-action-apero-request .block-title {
  text-align: center;
  border-bottom: 1px #b4b4b4 solid;
  padding: 20px 22px 10px 22px;
  color: white;
}
.block-action-apero-request .block-schedule-candidate {
  padding: 10px 22px;
}
.block-action-apero-request .block-schedule-candidate .title {
  color: white;
  font-size: 13px;
}
.block-action-apero-request .block-schedule-candidate .item-schedule-choose {
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 0 !important;
  min-height: 40px;
}
.block-action-apero-request .block-schedule-candidate .item-schedule {
  background-color: white;
  border-radius: 10px;
  padding: 10px 25px;
  margin-top: 10px;
  font-size: 14px;
  font-weight: bold;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .form-control {
  text-align: center;
  color: #000000;
  border: 1px solid #905946;
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
  padding: 0 0.75rem !important;
  height: 28px;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .form-control:focus {
  box-shadow: 0 0 0 0.2rem rgba(133, 73, 53, 0.25);
}
.block-action-apero-request .block-schedule-candidate .item-schedule label {
  margin: 0;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom {
  opacity: 0;
  position: absolute;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom,
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom-label {
  cursor: pointer;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom-label {
  position: relative;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom + .radio-custom-label:before {
  content: "";
  background: #fff;
  border: 2px solid #905946;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  width: 20px;
  height: 20px;
  padding: 2px;
  margin-right: 10px;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom + .radio-custom-label:before {
  border-radius: 3px;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom:checked + .radio-custom-label:before {
  content: "\f00c";
  font-family: "FontAwesome";
  background-color: #905946;
  color: #ffffff;
}
.block-action-apero-request .block-schedule-candidate .item-schedule .radio-custom:focus + .radio-custom-label {
  outline: 1px solid #ddd;
}
.block-action-apero-request .block-schedule-candidate .btn-accept-apero {
  margin-top: 20px;
  margin-bottom: 10px;
  width: 80%;
  background-color: black;
  color: white;
  border-radius: 25px;
  padding: 10px 0;
}
.block-action-apero-request .block-schedule-candidate .group-btn-denied {
  display: flex;
  flex-direction: row;
  align-content: center;
  justify-content: center;
  align-items: center;
}
.block-action-apero-request .block-schedule-candidate .group-btn-denied button {
  width: 50%;
  margin: 10px;
  border-radius: 25px;
  color: white;
}
.block-action-apero-request .block-schedule-candidate .group-btn-denied .btn-ng {
  background-color: #adadad;
}
.block-action-apero-request .block-schedule-candidate .group-btn-denied .btn-inconvenient {
  background-color: #905946;
}
.block-action-apero-request .block-schedule-candidate .text-description {
  padding-top: 15px;
  font-size: 13px;
}
.btn-yes {
  background-color: #905946 !important;
  color: white !important;
}
.btn-no {
  color: #905946 !important;
  background-color: white !important;
}
.block-info-matching-apero {
  background-color: #bf826b;
  padding: 20px 12px;
}
.space-white-inner {
  background-color: white;
  border-radius: 7px;
}
.padding-content-center {
  padding: 10px;
}
.border-block-outer {
  background-color: #d9c3ba;
  overflow: hidden;
}
.border-block-inner {
  border: 1px solid #bf826b;
}
.border-block-inner i {
  width: 30px;
  height: 30px;
  border: 1px solid #bf826b;
  border-radius: 50%;
  background-color: #fff;
}
.border-block-inner .border__top {
  margin-top: -18px;
}
.border-block-inner .border__bottom {
  margin-top: -12px;
  margin-bottom: -22px;
}
.border-block-inner .border__left {
  float: left;
  margin-left: -17px;
}
.border-block-inner .border__right {
  float: right;
  margin-right: -17px;
}
.info-matching {
  padding: 15px;
  min-height: 80px;
  font-family: "Playfair Display", serif;
}
.info-matching .title {
  font-size: 38px;
  font-weight: bold;
}
.info-matching .message-time {
  font-weight: 600;
  margin-top: 10px;
}
.info-matching .message-time .mr-num {
  font-size: 20px;
}
.info-matching .message-time .mr-text {
  font-size: 14px;
}
.info-matching .group-btn-sns {
  padding: 10px;
}
.info-matching .group-btn-sns i {
  width: 46px;
  height: auto;
  background-color: #c9c4c3;
  color: white;
  border: none;
  padding: 10px;
}
.info-matching .group-btn-sns i.active {
  background: #000 !important;
}
.info-matching .group-btn-sns a {
  position: relative;
  font-size: 26px;
}
.info-matching .group-btn-sns a:nth-child(2) {
  margin-right: 15px;
  margin-left: 15px;
}
.info-matching .btn-start-apero--waiting {
  width: 90%;
  height: 48px;
  border-radius: 25px;
  margin-top: 15px;
  color: white;
  background-color: #cccccc;
}
.info-matching .btn-start-apero--waiting img {
  width: initial;
}
.info-matching .btn-start-apero--ready {
  width: 90%;
  height: 48px;
  border-radius: 25px;
  margin-top: 15px;
  color: white;
  background-color: #000;
}
.info-matching .btn-start-apero--ready img {
  width: initial;
}
.block-ai-suggestion {
  display: flex;
  justify-content: space-evenly;
}
.block-ai-suggestion .suggestion-ai {
  background: url("../img/border_suggestion_ai.png");
  width: 43%;
  background-size: contain;
  background-repeat: round;
  position: relative;
  padding: 14px 0;
}
.block-ai-suggestion .mr-process-ri-circle--ai {
  width: 34px;
  height: 34px;
  background: #b199b0;
  color: white;
  font-family: "Libre Baskerville", serif;
  font-weight: bold;
  line-height: 11px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.ec-blockBtn--action {
  display: inline-block;
  margin-bottom: 0;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  border: 1px solid transparent;
  white-space: nowrap;
  padding: 6px 12px;
  font-size: 14px;
  line-height: 1.42857;
  border-radius: 0px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  color: #fff;
  background-color: #DE5D50;
  border-color: #DE5D50;
  display: block;
  width: 100%;
  height: 56px;
  line-height: 56px;
  padding-top: 0;
  padding-bottom: 0;
}
.ec-blockBtn--action:hover {
  color: #fff;
  background-color: #d33828;
  border-color: #cb3526;
  text-decoration: none;
}
.ec-blockBtn--cancel {
  display: inline-block;
  margin-bottom: 0;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  border: 1px solid transparent;
  white-space: nowrap;
  padding: 6px 12px;
  font-size: 14px;
  line-height: 1.42857;
  border-radius: 0px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  padding: 10px 16px;
  text-decoration: none;
  color: #fff;
  background-color: #525263;
  border-color: #525263;
  display: block;
  width: 100%;
  height: 56px;
  line-height: 56px;
  padding-top: 0;
  padding-bottom: 0;
}
.ec-blockBtn--cancel:hover {
  color: #fff;
  background-color: #3b3b47;
  border-color: #363642;
  text-decoration: none;
}
.ec-pageHeader h1 {
  margin: 0 0 8px;
  border-bottom: 1px dotted #ccc;
  border-top: 1px solid #ccc;
  padding: 8px 0 12px;
  font-size: 16px;
  font-weight: bold;
}
.ec-registerCompleteRole {
  margin: 0 auto;
  box-sizing: border-box;
  font-size: 16px;
  line-height: 1.4;
  color: #fff;
  -webkit-text-size-adjust: 100%;
  width: 100%;
  max-width: 1130px;
}
.ec-reportHeading {
  width: 100%;
  border-top: 1px dotted #ccc;
  margin: 20px 0 30px;
  padding: 0;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}
.ec-reportHeading h1, .ec-reportHeading h2, .ec-reportHeading h3, .ec-reportHeading h4,
.ec-reportHeading h5, .ec-reportHeading h6, .ec-reportHeading p {
  font-weight: bold;
  font-size: 24px;
}
.ec-reportDescription {
  margin-bottom: 32px;
  font-size: 16px;
  line-height: 1.4;
}
.mr-color-eee dd {
  color: #eee;
}
.mr-ec-input .form-control:focus {
  outline: 0;
  background-color: #F7E9E3;
  box-shadow: none;
  border-color: unset;
}
.bg-apero {
  position: relative;
  background-image: url("../img/bg_apero.png");
  background-size: cover;
  width: 100%;
  height: 100vh;
}
.bg-apero .apero-body {
  color: #fff;
}
.bg-apero .apero-body .mr-btn {
  position: absolute;
  bottom: 183px;
  height: 43px;
  width: 100%;
  text-align: center;
}
.bg-apero .apero-body .mr-btn button {
  border: 1px solid #fff;
  border-radius: 22px;
  color: #fff;
  background: #000;
  font-size: 17px;
  text-align: center;
  line-height: 17px;
  padding: 10px 20px;
  height: 43px;
  width: 71%;
}
.bg-call {
  position: relative;
  background: #000;
  width: 100%;
  height: 100vh;
}
.bg-call .apero-body {
  position: absolute;
  width: 100%;
  top: 62px;
  bottom: 9vh;
}
.apero-header {
  position: absolute;
  background: #000;
  height: 62px;
  width: 100%;
  text-align: center;
  padding-top: 10px;
  color: #fff;
}
.apero-header .mr-time {
  font-size: 15px;
}
.apero-header .mr-time-left,
.apero-header .remain-time {
  display: flex;
  align-items: center;
  position: absolute;
  bottom: 0;
  right: 7px;
}
.apero-header .mr-time-left .text,
.apero-header .remain-time .text {
  font-size: 15px;
}
.apero-header .mr-time-left .interval,
.apero-header .remain-time .interval {
  font-size: 31px;
  line-height: 31px;
}
.apero-body .escaping {
  position: absolute;
  top: 17%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
  text-align: center;
}
.apero-body .escaping span {
  color: #000;
  font-size: 17px;
}
.apero-body .apero-logo {
  background: url("../img/black-logo.png");
  position: absolute;
  top: 25%;
  left: 50%;
  width: 220px;
  height: 80px;
  transform: translate(-50%, -50%);
}
.apero-body .mr-btn-descript {
  position: absolute;
  top: 65%;
  width: 100%;
  text-align: center;
}
.apero-body .mr-btn-descript button {
  border: 1px solid #fff;
  border-radius: 17px;
  color: #fff;
  background: #000;
  text-align: center;
  height: 59px;
  margin-top: 5px;
  width: 80%;
}
.apero-body .mr-btn-descript button .mr-answer {
  font-size: 36px;
  line-height: 36px;
}
.apero-body .mr-btn-descript button .mr-descript {
  font-size: 11px;
  line-height: 11px;
}
.apero-body .apero-infomation {
  font-size: 13px;
  padding: 0px 28px;
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
.apero-body .apero-infomation .icon {
  margin-top: 14px;
  display: flex;
  justify-content: center;
}
.apero-body .apero-infomation .icon i {
  vertical-align: -webkit-baseline-middle;
}
.apero-body .mr-text-box-black {
  height: 211px;
  background: #000;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  color: #fff;
  display: table;
}
.apero-body .mr-text-box-black .mr-text {
  display: table-cell;
  vertical-align: center;
  text-align: center;
}
.apero-body .intro-video {
  height: 211px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
.apero-body .intro-text {
  position: absolute;
  text-align: center;
  font-size: 17px;
  top: 70%;
  transform: translateY(-50%);
  width: 100%;
  color: #000;
}
.apero-body .change-chapter-question {
  position: absolute;
  top: 22%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  text-align: center;
  color: #000;
}
.apero-body .change-chapter-question .question-complement {
  font-size: 25px;
  padding: 0 20%;
  font-weight: normal;
  line-height: 30px;
}
.apero-body .change-chapter-question .question-focus {
  font-size: 40px;
  line-height: 47px;
}
.apero-body .change-chapter-question hr {
  width: 50%;
  margin-left: 50%;
  margin-top: 5px;
  transform: translate(-50%);
}
.apero-body .mr-text-box-white {
  position: absolute;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  color: #000;
  padding: 0 28px;
}
.apero-body .mr-text-box-white .mr-box {
  background: #fff;
  padding: 19px 17px;
  border: 1px solid #707070;
  font-size: 12px;
  line-height: 21px;
  font-weight: 700;
}
.apero-body .mr-text-box-white .comment-box {
  background: #fff;
  padding: 19px 17px;
  border: 1px solid #707070;
  font-size: 13px;
  line-height: 21px;
}
.apero-body .mr-text-box-white .comment-box .comment-text-area {
  width: 100%;
  border: none;
}
.apero-body .apero-comment {
  font-size: 13px;
  color: #fff;
}
.apero-body .text-thank-you {
  color: #000;
  font-size: 48px;
  position: absolute;
  top: 25%;
  left: 50%;
  width: 100%;
  transform: translate(-50%);
  text-align: center;
}
.apero-body .mr-time-left .text {
  margin-right: 20px;
}
.apero-body .remain-time .text {
  margin-right: 5px;
}
.apero-body .popup-start-apero {
  position: absolute;
  top: 53%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60%;
  height: 72px;
  background: #fff;
  text-align: center;
  color: #000;
  border-radius: 22px;
  padding-top: 7px;
}
.apero-body .popup-start-apero .mr-title, .apero-body .popup-start-apero .sln_card_payment_container .ec-pageHeader h1, .sln_card_payment_container .ec-pageHeader .apero-body .popup-start-apero h1 {
  font-size: 15px;
  color: #000;
}
.apero-body .popup-start-apero .mr-text {
  font-size: 18px;
}
.apero-body .apero-text-17 {
  position: absolute;
  font-size: 17px;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  text-align: center;
  color: #fff;
  word-wrap: break-word;
}
.apero-body .mr-btn-provide-info {
  position: absolute;
  bottom: 50px;
  height: 43px;
  width: 100%;
  text-align: center;
  bottom: 120px;
}
.apero-body .mr-btn-provide-info button {
  border: 1px solid #fff;
  border-radius: 22px;
  color: #fff;
  background: #000;
  font-size: 17px;
  text-align: center;
  line-height: 17px;
  padding: 10px 20px;
  height: 43px;
  width: 71%;
}
.apero-body .questions-item {
  height: calc(100vh - 62px - 85vh);
  width: 100%;
  display: flex;
  align-items: center;
  margin-left: 20px;
  padding-right: 20px;
}
.apero-body .questions-item .mr-question {
  display: flex;
  align-items: center;
  padding: 0;
}
.apero-body .questions-item .question-title {
  font-size: 25px;
  margin-bottom: 0px;
  margin-right: 5px;
}
.apero-body .questions-item .question-content {
  font-size: 13px;
}
.apero-body .questions-item .btn-next-question {
  padding: 0;
  display: flex;
  align-items: center;
}
.apero-body .questions-item .btn-next-question span {
  margin-right: 5px;
}
.apero-body .mr-rules {
  position: absolute;
  padding: 0 55px;
  font-size: 12px;
  color: #fff;
  text-align: left;
  transform: translate(-50%, -50%);
  top: 33%;
  left: 50%;
  width: 100%;
}
.apero-body .partner-screen {
  position: absolute;
  width: 100%;
  height: 38vh;
  top: 0;
}
.apero-body .user-screen {
  position: absolute;
  width: 100%;
  height: 38vh;
  bottom: 0;
}
.apero-body .call-question {
  position: absolute;
  top: 38vh;
  left: 50%;
  bottom: 38vh;
  transform: translateX(-50%);
  background: #fff;
  width: 100%;
}
.apero-body .call-question .owl-nav {
  display: none;
}
.apero-footer {
  position: absolute;
  background: #000;
  height: 9vh;
  width: 100%;
  bottom: 0;
  display: table;
}
.apero-footer .mr-btn {
  height: 43px;
  width: 100%;
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
.apero-footer .mr-btn button {
  border: 3px solid #fff;
  border-radius: 24px;
  color: #fff;
  background: #000;
  font-size: 17px;
  line-height: 17px;
  padding: 10px 57px;
}
.apero-footer .apero-back,
.apero-footer .apero-chat {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  width: 50%;
}
.apero-footer .apero-back button,
.apero-footer .apero-chat button {
  width: 99%;
  height: 43px;
  border: 3px solid #fff;
  border-radius: 24px;
  background: #000;
  background: #000;
  color: #fff;
}
.mr-pt-80 {
  padding-top: 80px;
}
.mr-t-15 {
  top: 15%;
}
.mr-t-54 {
  top: 54%;
}
.mr-t-48 {
  top: 48%;
}
.mr-t-65 {
  top: 65%;
}
.mr-t-50 {
  top: 50%;
}
.mr-t-25 {
  top: 25%;
}
.mr-t-37 {
  top: 37%;
}
.mr-b-57 {
  bottom: 57%;
}
.mr-about .welcome {
  padding: 40px 20px 60px;
  background-color: #ffffff;
}
.mr-about .welcome__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 36px;
  max-width: 335px;
  margin: 0 auto;
}
.mr-about .welcome__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  width: 100%;
}
.mr-about .welcome__title {
  font-family: "Allura", serif;
  font-size: 18px;
  line-height: 23px;
  color: #bd6856;
  text-align: left;
}
.mr-about .welcome__subtitle {
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-size: 18px;
  line-height: 30px;
  text-align: left;
}
.mr-about .welcome__description p {
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
}
.mr-about .img-section {
  width: 100%;
  aspect-ratio: 375/347;
}
.mr-about .service-concept {
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
.mr-about .service-concept__inner {
  width: 100%;
}
.mr-about .service-concept__description {
  margin-bottom: 20px;
  font-family: "Shippori Mincho", serif;
  font-size: 18px;
  line-height: 28px;
  color: white;
  text-align: center;
}
.mr-about .service-concept__image {
  width: 100%;
  max-width: 274px;
  aspect-ratio: 274/190;
  margin: 0 auto 20px;
}
.mr-about .service-concept__content {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.mr-about .service-concept__item {
  padding: 20px;
  border-radius: 4px;
  background: white;
}
.mr-about .service-concept__item-title {
  display: flex;
  gap: 8px;
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 28px;
  color: #bd6856;
}
.mr-about .service-concept__item-description {
  font-size: 14px;
  line-height: 24px;
  padding: 14px 0 0 30px;
}
.mr-about .service-concept__bottom {
  text-align: center;
}
.mr-about .service-concept__bottom-text {
  font-size: 20px;
  line-height: 32px;
  font-weight: 700;
  font-family: "Shippori Mincho", serif;
  color: white;
}
.mr-about .chapter-about {
  background: #f3edd8;
}
.mr-about .chapter-about .section-header {
  color: black;
}
.mr-about .chapter-about__inner {
  width: 100%;
}
.mr-about .chapter-about__description {
  margin-bottom: 30px;
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
  text-align: center;
}
.mr-about .chapter-about__content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.mr-about .chapter-about__item {
  width: 100%;
}
.mr-about .chapter-about__item #mrAccordion-accordion-2 .mr-accordion__paragraph--empty:nth-child(3) {
  width: 6px;
}
.mr-about .about-book-selection {
  background: #ffffff;
  padding: 60px 20px;
}
.mr-about .about-book-selection__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 36px;
}
.mr-about .about-book-selection .section-header {
  color: black;
  margin-bottom: 0;
}
.mr-about .about-book-selection__description {
  width: 100%;
}
.mr-about .about-book-selection__description-text {
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
  text-align: left;
}
.mr-about .about-book-selection__image {
  width: 100%;
  aspect-ratio: 335/200;
  border-radius: 4px;
  overflow: hidden;
}
.mr-about .about-book-selection__criteria-description {
  width: 100%;
}
.mr-about .about-book-selection__criteria-description p {
  font-size: 14px;
  line-height: 23px;
  text-align: center;
  font-family: "Shippori Mincho", serif;
}
.mr-about .about-book-selection__criteria {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.mr-about .about-book-selection__criteria-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.mr-about .about-book-selection__criteria-icon {
  width: 24px;
  height: 24px;
  display: flex;
}
.mr-about .about-book-selection__criteria-text {
  font-weight: 500;
  font-size: 14px;
  line-height: 22px;
  flex: 1;
  color: #bd6856;
}
.mr-about .about-book-selection__bottom-text {
  width: 100%;
}
.mr-about .about-book-selection__bottom-text p {
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
  margin-bottom: 24px;
}
.mr-about .about-book-selection__bottom-text p:last-child {
  margin-bottom: 0;
}
.mr-about .about-apero {
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
.mr-about .about-apero__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 36px;
}
.mr-about .about-apero .section-header {
  margin-bottom: 0;
}
.mr-about .about-apero__subtitle p {
  font-size: 14px;
  line-height: 23px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
  color: white;
  letter-spacing: -1.2px;
}
.mr-about .about-apero__image {
  width: 100%;
  aspect-ratio: 335/188.44;
  border-radius: 4px;
  overflow: hidden;
}
.mr-about .about-apero__description p {
  font-size: 14px;
  line-height: 23px;
  font-weight: 500;
  color: white;
  line-height: 16px;
}
.mr-about .about-apero__description p + p {
  margin-top: 24px;
}
.mr-about .about-apero__types {
  background: white;
  border-radius: 4px;
  padding: 15px 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.mr-about .about-apero__type {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.mr-about .about-apero__type-number {
  width: 24px;
  height: 24px;
  background: #bd6856;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mr-about .about-apero__type-number-text {
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 17px;
  color: white;
}
.mr-about .about-apero__type-description {
  font-weight: 500;
  font-size: 14px;
  line-height: 22px;
  color: #bd6856;
}
.mr-about .about-apero__footer {
  display: flex;
  justify-content: center;
}
.mr-about .about-apero__footer-content {
  display: flex;
  align-items: center;
  gap: 12px;
}
.mr-about .about-apero__footer-icon {
  width: 22px;
  height: 25px;
}
.mr-about .about-apero__footer-text {
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 18px;
  line-height: 28px;
  color: white;
  letter-spacing: 0.64px;
}
.mr-about .about-invitation-code {
  background: #ffffff;
}
.mr-about .about-invitation-code__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 36px;
}
.mr-about .about-invitation-code .section-header {
  color: black;
  margin-bottom: 0;
}
.mr-about .about-invitation-code__description-text {
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
}
.mr-about .about-invitation-code__image {
  width: 100%;
  aspect-ratio: 335/200;
  border-radius: 4px;
  overflow: hidden;
}
.mr-about .about-invitation-code__content p {
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
  margin-bottom: 24px;
}
.mr-about .about-invitation-code__content p:last-child {
  margin-bottom: 0;
}
.mr-about .about-invitation-code__highlight {
  color: #bd6856;
  font-weight: 700;
}
.mr-about .price-section {
  background-color: #ebdcd9;
}
.mr-about .price-section__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 36px;
}
.mr-about .price-section .section-header {
  color: black;
  margin-bottom: 0;
}
.mr-about .price-section__description {
  text-align: center;
}
.mr-about .price-section__description p {
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
}
.mr-about .price-section__plans {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}
.mr-about .price-section__disclaimers {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
}
.mr-about .price-section__disclaimer {
  display: flex;
  gap: 4px;
  align-items: flex-start;
}
.mr-about .price-section__disclaimer-asterisk {
  font-family: "Shippori Mincho", serif;
  font-size: 12px;
  line-height: 17px;
  flex-shrink: 0;
}
.mr-about .price-section__disclaimer p {
  font-family: "Shippori Mincho", serif;
  font-size: 12px;
  line-height: 17px;
}
.mr-about .mr-plan-card {
  background-color: white;
  border-radius: 4px;
  padding: 10px 10px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mr-about .mr-plan-card--monthly .mr-plan-card__badge {
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background-color: #bd6856;
  color: #ffffff;
  border-radius: 4px;
  font-weight: 700;
  font-size: 20px;
  line-height: 29px;
  letter-spacing: 1.28px;
}
.mr-about .mr-plan-card--monthly .mr-plan-card__content {
  padding: 0 20px;
}
.mr-about .mr-plan-card--monthly .mr-plan-card__option {
  padding: 0 10px;
}
.mr-about .mr-plan-card--monthly .mr-plan-card__price {
  line-height: 49px;
}
.mr-about .mr-plan-card--monthly .mr-plan-card__price-note {
  width: 85px;
}
.mr-about .mr-plan-card--ticket .mr-plan-card__badge {
  height: 31px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background-color: #56674e;
  color: #ffffff;
  border-radius: 4px;
  font-weight: 700;
  font-size: 16px;
  line-height: 23px;
  letter-spacing: 1.28px;
}
.mr-about .mr-plan-card--ticket .mr-plan-card__content {
  padding: 0 18px;
}
.mr-about .mr-plan-card--ticket .mr-plan-card__option {
  padding: 0 44px;
}
.mr-about .mr-plan-card--ticket .mr-plan-card__option-name {
  flex-direction: row;
  align-items: end;
}
.mr-about .mr-plan-card__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 100%;
}
.mr-about .mr-plan-card__header p {
  font-weight: 700;
  font-size: 14px;
  line-height: 20px;
  text-align: center;
}
.mr-about .mr-plan-card__pricing {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mr-about .mr-plan-card__option {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
}
.mr-about .mr-plan-card__option-name {
  display: flex;
  align-items: center;
  flex-direction: column;
  font-weight: 700;
  font-size: 12px;
  line-height: 12px;
  letter-spacing: 0.64px;
  text-align: center;
  padding-bottom: 6px;
}
.mr-about .mr-plan-card__option-name--text {
  display: inline-block;
  font-size: 16px;
  line-height: 16px;
}
.mr-about .mr-plan-card__option-name span {
  flex-shrink: 0;
}
.mr-about .mr-plan-card__option-price {
  display: flex;
  align-items: flex-end;
  gap: 5px;
}
.mr-about .mr-plan-card__price {
  font-weight: 700;
  font-size: 34px;
  line-height: 35px;
  color: #bd6856;
  text-align: center;
  width: 102px;
}
.mr-about .mr-plan-card__price span {
  font-size: 18px;
  line-height: 20px;
}
.mr-about .mr-plan-card__price--ticket {
  font-size: 24px;
  color: #56674e;
  text-align: right;
  width: 80px;
  flex-shrink: 0;
}
.mr-about .mr-plan-card__price-note {
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 2px;
  padding-bottom: 8px;
}
.mr-about .mr-plan-card__price-note-text {
  font-weight: 700;
  font-size: 10px;
  line-height: 14px;
  flex-shrink: 0;
}
.mr-about .mr-plan-card__recommend {
  background-color: #ed7560;
  color: #ffffff;
  border-radius: 30px;
  font-weight: 700;
  font-size: 10px;
  line-height: 14px;
  text-align: center;
  width: 85px;
}
.mr-about .mr-plan-card__divider {
  width: 100%;
  height: 1px;
  border-bottom: 1px dashed black;
}
.mr-about .mr-plan-card__features {
  margin-top: 20px;
  background-color: #f3edd8;
  padding: 15px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.mr-about .mr-plan-card__features h4 {
  font-weight: 700;
  font-size: 14px;
  line-height: 20px;
  margin-bottom: 10px;
}
.mr-about .mr-plan-card__feature-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  width: 165px;
}
.mr-about .mr-plan-card__feature-list li {
  font-size: 12px;
  line-height: 18px;
}
.mr-about .mr-plan-card__feature-list li:nth-child(1) {
  padding-right: 14px;
}
.mr-about .mr-plan-card__feature-list li:nth-child(3) {
  line-height: 14px;
}
.mr-about .mr-plan-card__note {
  margin-top: 20px;
  display: flex;
  gap: 8px;
}
.mr-about .mr-plan-card__note-icon {
  width: 55px;
  height: 34px;
  flex-shrink: 0;
}
.mr-about .mr-plan-card__note p {
  font-size: 12px;
  line-height: 16px;
}
.mr-about .greeting {
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
  padding: 60px 20px;
}
.mr-about .greeting__image {
  width: 100%;
  aspect-ratio: 335/200;
  border-radius: 4px;
  overflow: hidden;
}
.mr-about .greeting__content {
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 100%;
  margin-top: 36px;
}
.mr-about .greeting__message p {
  font-family: "Shippori Mincho", serif;
  font-size: 14px;
  line-height: 23px;
  color: #ffffff;
}
.mr-about .greeting__message p:not(:last-child) {
  margin-bottom: 20px;
}
.mr-about .greeting__message-link {
  color: #fcf6c8;
  text-decoration: underline;
  font-weight: 700;
}
.mr-about .greeting__signature {
  text-align: right;
  font-family: "Shippori Mincho", serif;
  color: #ffffff;
}
.mr-about .greeting__signature-title {
  font-size: 14px;
  line-height: 30px;
}
.mr-about .greeting__signature-name {
  font-size: 24px;
  line-height: 30px;
}
.bg-img-pc, .menu-pc {
  display: none;
}
.lamp-box-fixed {
  display: none;
}
.lamp-box-fixed {
  top: -110px;
  transition: 1s;
}
.lamp-box-fixed.lamp-box-after {
  top: 20px;
  animation: aniLamp 1s 1;
  animation-direction: alternate;
  animation-fill-mode: forwards;
}
@keyframes aniLamp {
  0% {
    top: -110px;
  }
  65% {
    top: 30px;
  }
  100% {
    top: 10px;
  }
}
.login-page {
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
.login-page__container {
  padding: 36px 20px 100px;
}
.login-page .section-header {
  margin-bottom: 24px;
}
.login-page__form .error-label {
  margin-bottom: 30px;
}
.login-page__form .form-check-label {
  font-size: 12px;
  line-height: 17px;
}
.login-page__form-content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.login-page__actions {
  margin-top: 24px;
  text-align: center;
}
.login-page__actions .forgot-password {
  display: inline-block;
  margin: 16px 0 32px;
  font-size: 10px;
  line-height: 14px;
  color: #618a91;
  text-decoration: underline;
}
.login-page__actions .login__bt,
.login-page__actions .register__btn {
  height: 47px;
}
.forgot-page {
  padding: 24px 20px 100px;
  background: linear-gradient(180deg, rgb(157, 145, 165) 32%, rgb(206, 159, 141) 55%, rgb(233, 165, 119) 77%, rgb(200, 95, 66) 100%);
}
.forgot-page .section-block {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.forgot-page__form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.forgot-page__form .btn {
  height: 47px;
}
.forgot-page__description {
  display: flex;
  gap: 4px;
  font-size: 12px;
  line-height: 18px;
  font-family: "Shippori Mincho", serif;
}
.qa-section img {
  height: unset;
  width: unset;
}
.qa-section {
  margin-top: 70px;
  padding-top: 50px;
}
.qa-section .qa-box {
  padding: 10px 30px 0;
}
.qa-section .question-label,
.qa-section .answer-label {
  margin-right: 10px;
}
.qa-section .answer {
  margin-bottom: 30px;
  display: none;
}
#back-number .back-number__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 30px;
  padding: 20px 20px 40px;
  background: #fff8f3;
}
#back-number .back-number__title-section {
  width: 100%;
  padding: 8px 0;
  text-align: center;
  border-bottom: 1px solid black;
  border-top: 1px solid black;
}
#back-number .back-number__title-section .title {
  font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 29px;
  letter-spacing: 0.64px;
}
#back-number .back-number__books-list {
  display: flex;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 40px 21px;
  width: 100%;
}
#back-number .back-number__books-list .book-item {
  width: calc(50% - 10.5px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#back-number .back-number__books-list .book-item .book-content {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 10px;
}
#back-number .back-number__books-list .book-item .book-content .book-image {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
#back-number .back-number__books-list .book-item .book-content .book-image img {
  transition: all 0.3s ease;
}
#back-number .back-number__books-list .book-item .book-content .book-image img:hover {
  transform: scale(1.05);
}
#back-number .back-number__books-list .book-item .book-content .book-title {
  font-weight: 500;
  font-size: 14px;
  line-height: 20px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}
#back-number .back-number__books-list .book-item .book-author {
  margin-top: auto;
  font-size: 14px;
  line-height: 20px;
  color: #99a9b0;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
#back-number .back-number__books-list .book-item .btn {
  margin-top: 16px;
  width: 100%;
  height: 47px;
}
.welcome-page {
  background-color: #f3edd8;
}
.welcome-page .welcome__top {
  text-align: center;
}
.welcome-page .welcome__top .section-header {
  color: black;
}
.welcome-page .welcome__top .section-header .section-subtitle__main span {
  transform: rotate(10deg);
}
.welcome-page .welcome__title {
  font-family: "Shippori Mincho", serif;
  font-size: 22px;
  font-weight: 700;
  line-height: 32px;
  margin-bottom: 24px;
  color: #bd6856;
}
.welcome-page .welcome__btn--create-page {
  width: 258px;
  margin-bottom: 24px;
}
.welcome-page .welcome__btn--apero {
  width: 196px;
  height: 47px;
  margin-bottom: 36px;
}
.welcome-page .welcome__content {
  margin-top: 80px;
  position: relative;
  background-color: white;
  padding: 70px 20px 30px;
  border-radius: 4px;
}
.welcome-page .welcome__content-header {
  display: flex;
  align-items: center;
  gap: 2px;
  justify-content: center;
  margin-bottom: 30px;
}
.welcome-page .welcome__content-title {
  font-size: 16px;
  font-weight: 700;
  line-height: 23px;
}
.welcome-page .welcome__content-icon {
  width: 24px;
  height: 22px;
}
.welcome-page .welcome__profile {
  margin-bottom: 12px;
  padding: 16px 20px;
  background: rgba(237, 117, 96, 0.15);
  border-radius: 2px;
}
.welcome-page .welcome__profile-header {
  position: relative;
  font-size: 13px;
  font-weight: 700;
  line-height: 19px;
  color: #bd6856;
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 6px;
}
.welcome-page .welcome__profile-header:before {
  content: "";
  position: absolute;
  top: 9px;
  left: -22px;
  width: 16px;
  height: 1px;
  background-color: #bd6856;
  transform: rotate(44deg);
}
.welcome-page .welcome__profile-header:after {
  content: "";
  position: absolute;
  top: 9px;
  right: -22px;
  width: 16px;
  height: 1px;
  background-color: #bd6856;
  transform: rotate(135deg);
}
.welcome-page .welcome__profile-text {
  font-size: 12px;
  line-height: 17px;
}
.welcome-page .welcome__profile-feature {
  display: flex;
  align-items: center;
  gap: 4px;
  color: #ed7560;
  margin: 12px 0 8px;
}
.welcome-page .welcome__profile-feature--title {
  font-weight: 700;
  font-size: 14px;
  line-height: 18px;
}
.welcome-page .welcome__profile-feature--icon {
  width: 20px;
  height: 18px;
}
.welcome-page .welcome__profile-image {
  width: 100%;
  aspect-ratio: 255/120;
  margin: 8px 0 12px;
}
.welcome-page .welcome__profile-action .btn {
  height: 47px;
  width: 100%;
}
.welcome-page .welcome__message {
  padding: 16px 20px;
  background: rgba(133, 179, 174, 0.15);
  margin-bottom: 12px;
  border-radius: 2px;
}
.welcome-page .welcome__message-title {
  font-size: 18px;
  font-weight: 700;
  line-height: 22px;
  margin-bottom: 10px;
  color: #85b3ae;
}
.welcome-page .welcome__message .welcome__message-item + .welcome__message-item {
  margin-top: 12px;
}
.welcome-page .welcome__message-item--title {
  font-size: 14px;
  font-weight: 700;
  line-height: 16px;
  color: #85b3ae;
}
.welcome-page .welcome__message-item--text {
  font-size: 12px;
  line-height: 15px;
}
.welcome-page .welcome__book-image {
  position: absolute;
  top: -55px;
  left: 50%;
  transform: translateX(-50%);
  width: 110px;
  height: 110px;
  border-radius: 50%;
  border: 4px solid white;
  overflow: hidden;
}
.welcome-page .welcome__share .btn {
  width: 100%;
}
.welcome-page .welcome__my-page-section {
  padding: 24px 20px 0px;
}
.welcome-page .form-message {
  margin: 12px 0 30px;
}
.welcome-page .mr-accordion {
  text-align: start;
}
.order-detail__item {
  display: flex;
  gap: 2px;
}
.order-detail__item .order-detail__text:last-child {
  flex-shrink: 0;
}
.order-detail .order-detail__text {
  font-size: 14px;
  font-weight: 700;
  line-height: 18px;
  color: black;
}
.order-detail .order-detail__text.inactive {
  color: #b3b3b3;
}
.order-detail__book-name {
  font-weight: 400 !important;
  word-break: break-word;
}
.order-detail__total-price {
  font-size: 22px;
  font-weight: 700;
  line-height: 18px;
  color: #ed7560;
  text-align: right;
  margin-bottom: 6px;
}
.order-detail__account-text {
  font-size: 12px;
  line-height: 18px;
  color: black;
}
.order-detail__account-text--link {
  color: #618a91;
  text-decoration: underline;
  font-size: 10px;
}
@keyframes bubble {
  0% {
    transform: translate3d(0, 0, 0) scale(0.5) translate(-50%, -50%);
    opacity: 1;
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1.5) translate(var(--x), var(--y));
    opacity: 0;
  }
}
@keyframes shake {
  0%, 100% {
    transform: translate3d(0, 0, 0) translateX(0);
  }
  25% {
    transform: translate3d(0, 0, 0) translateX(-5px);
  }
  75% {
    transform: translate3d(0, 0, 0) translateX(5px);
  }
}
.tab-card-info__link:hover {
  color: #fbfbfb;
}
.tab-card-info__one-column .tab-card-info__nickname {
  flex-grow: 1;
  font-size: 17px;
  text-align: center;
}
.tab-card-info__one-column .tab-card-info__text {
  font-size: 12px;
}
.tab-card-info__two-columns .tab-card-info__link:first-child {
  background-color: #bd6856;
  align-items: end;
}
.tab-card-info__two-columns .tab-card-info__link:first-child .tab-card-info__nickname {
  font-size: 15px;
  margin-right: 2px;
}
.tab-card-info__two-columns .tab-card-info__link:first-child .tab-card-info__text {
  font-size: 9px;
}
.tab-card-info__two-columns .tab-card-info__link:last-child {
  background-color: rgba(106, 150, 159, 0.8);
  font-size: 13px !important;
}
#apero-tab {
  position: relative;
}
#apero-tab a {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  padding: 10px 18px;
}
#customer_register_4b_another_favorite {
  white-space: pre-line;
}
#js-intro-menu {
  display: none;
}
#mr_btn_ticket_view_plan {
  cursor: pointer;
}
#partner-tab {
  position: relative;
}
#partner-tab a {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  padding: 10px 18px;
}
#same-book-tab {
  position: relative;
}
#same-book-tab a {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  padding: 10px 18px;
}
.affiliate-btn {
  margin-top: auto;
}
.affiliate-btn-group {
  width: 106px;
  height: 108px;
  display: flex;
  flex-direction: column;
}
.apero-block-apero {
  position: relative;
  background-color: #bbcdb2;
  padding-bottom: 30px;
}
.apero-corner {
  background-color: #905946 !important;
}
.apero-tab-profile-full-name {
  font-size: 30px;
  font-family: "Libre Baskerville", serif;
  line-height: 1;
  margin: 0 !important;
  padding-left: 22px;
  padding-top: 15px;
  display: flex;
  cursor: pointer;
  position: relative;
}
.apero-tab-profile-full-name img {
  position: absolute;
  padding-left: 10px;
  right: 0;
}
.apero-tab-top .question-symbol-bg {
  top: 20px;
  right: 7px;
}
.apero-tab-top {
  position: relative;
}
.apero-title {
  color: #ffffff;
  font-size: 13px;
  font-weight: bold;
  margin-top: 8px;
  margin-left: 15px;
}
.bottom-corner {
  /* margin-top: 31px; */
  margin-top: 5px;
  margin-left: -22px;
  display: flex;
  justify-content: space-between;
}
.bottom-left {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  background: #905946;
}
.bottom-right {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  background: #905946;
  margin-right: -22px;
}
.bubble {
  position: absolute;
  width: 20px;
  height: 20px;
  background-color: blue;
  border-radius: 50%;
  opacity: 0;
  animation: bubble 1s ease forwards;
  z-index: 2;
}
.by-on-amazon-btn {
  padding: 1px 16px;
  font-size: 10px;
  color: #666666;
  border: 1px solid #707070;
  border-radius: 8px;
  text-decoration: none;
}
.cus-character {
  top: 30px;
}
.cus-cover-book {
  background-image: url("/html/template/MR/assets/img/book1.jpeg") !important;
  background-size: contain;
}
.cus-heart-symbol {
  /* font-size: 20px; */
  margin-left: auto;
  margin-right: 5px;
  margin-top: 8px;
  /* text-shadow: 0 1px 0 #fff; */
}
.fill-symbol {
  /* color: #fa5c5c; */
  background-color: #fa5c5c !important;
  border: unset !important;
}
.fill-symbol::before {
  /* color: #fa5c5c; */
  background-color: #fa5c5c !important;
  border: unset !important;
}
.go-top-btn {
  position: fixed;
  right: 2px;
  text-align: end;
  cursor: pointer;
  display: block;
  margin-right: 2px;
  bottom: 0;
  transition: opacity 0.5s, visibility 0.5s;
  opacity: 0;
  visibility: hidden;
  z-index: 20;
}
.go-top-btn.show {
  opacity: 1;
  visibility: visible;
}
.grey-load-more-btn {
  font-size: 12px;
  color: #7e7a7a;
  text-align: center;
  padding: 5px 5px;
  cursor: pointer;
}
.heart-container {
  position: relative;
}
.heart-shape {
  position: relative;
  height: 20px;
  width: 12px;
  /* background-color: #fa5c5c; */
  background-color: #ffffff;
  transform: rotate(45deg);
  border-radius: 50% 42% 0 0;
  border: solid 0.5px #a0a0a0;
}
.heart-shape::before {
  content: "";
  position: absolute;
  top: 4px;
  left: -5px;
  height: 20px;
  width: 12px;
  /* background-color: #fa5c5c; */
  background-color: #ffffff;
  transform: rotate(-90deg);
  border-radius: 50% 62% 0 0;
  border: solid 0.5px #a0a0a0;
  border-right: unset;
  /* border-bottom: unset; */
}
.heart-symbol {
  top: 412px;
  left: 146px;
  width: 22px;
  height: 21px;
  background: #a0a0a0 0% 0% no-repeat padding-box;
  opacity: 1;
}
.heart-tag-white {
  margin-top: 2px;
}
.heart.shake {
  animation: shake 0.3s ease-in-out 1;
}
.hide {
  visibility: hidden;
}
.hide-func-btn {
  border: 1px solid #dddddd;
  font-size: 14px;
  font-weight: bold;
  font-family: "Noto Sans JP", sans-serif !important;
  display: flex;
  align-items: center;
  padding: 0px 8px;
  margin-left: 20px;
  background-color: #ffffff;
}
.js-like-partner {
  cursor: pointer;
}
.mr-30 {
  margin-right: 30px;
}
.notify-mail-block {
  /* padding: 18px 0; */
  display: flex;
  align-items: center;
  justify-content: end;
  -moz-column-gap: 30px;
       column-gap: 30px;
}
.partner-block-apero {
  position: relative;
  background: transparent linear-gradient(180deg, #e1a779 0%, #e2ac81 100%) 0 0 no-repeat padding-box;
  padding-bottom: 30px;
}
.partner-corner {
  background-color: #abc0ac !important;
}
.question-symbol {
  font-size: 13px;
  text-align: center;
  color: #a0a0a0;
}
.question-symbol a {
  color: #a0a0a0;
}
.question-symbol-bg {
  position: absolute;
  top: 16px;
  right: 8px;
  width: 26px;
  height: 21px;
  background: #ffffff;
  border: 1px solid #b2b2b2;
  border-radius: 20px;
  opacity: 1;
  padding: 0 6px;
}
.request-apero-btn-icon {
  margin-left: 2px;
}
.js-like-other,
.js-like-partner,
.js-like-action {
  cursor: pointer;
}
.same-book-block-apero {
  position: relative;
  background-color: #fff8f3;
  padding-bottom: 30px;
}
.same-book-block-apero .content-block-apero .message-empty-suggestion {
  color: #7e7a7a;
}
.same-book-block-apero .switch-option-text {
  color: #686868;
}
.same-book-corner {
  background-color: #a0a0a0 !important;
}
.show {
  display: block;
}
.switch-option-block {
  position: relative;
  padding-top: 20px;
}
.switch-option-row {
  display: flex;
  align-items: center;
  justify-content: center;
}
.switch-option-text {
  color: white;
  font-size: 13px;
}
.tab-banner {
  display: flex;
  align-items: center;
  justify-content: center;
}
.tab-banner-wrap {
  /* width: 357px; */
  margin-top: 33px;
}
.tab-banner__bookmark {
  -moz-column-gap: 8px;
       column-gap: 8px;
}
.tab-banner__bookmark img {
  width: 30px;
}
.tab-banner__bookmark .tab-banner__text {
  color: #7e7a7a;
}
.tab-banner__play-apero {
  -moz-column-gap: 18px;
       column-gap: 18px;
}
.tab-banner__play-apero .tab-banner__text {
  max-width: 200px;
}
.tab-banner__schedule {
  -moz-column-gap: 19px;
       column-gap: 19px;
}
@media screen and (max-width: 766px) {
  .tab-banner__schedule {
    -moz-column-gap: 26px;
         column-gap: 26px;
  }
}
.tab-banner__text {
  font-size: 14px;
  font-weight: bold;
  color: #fbfbfb;
}
.tab-card {
  position: relative;
  /* width: 357px; */
  width: unset;
  display: flex;
  flex-direction: column;
  background: transparent linear-gradient(19deg, #ffffff 0%, #f3edd8 100%) 0 0 no-repeat padding-box;
  box-shadow: -2px -1px 5px rgba(0, 0, 0, 0.4);
  border-radius: 0 0 40px;
}
.tab-card-books {
  display: flex;
  justify-content: space-between;
}
.tab-card-books-item {
  position: relative;
  display: flex;
}
.tab-card-books-item img {
  width: 62px;
  height: 86px;
}
.tab-card-books-item:first-child::after {
  content: "";
  width: 90px;
  height: 106px;
  position: absolute;
  top: -7px;
  left: -25px;
  background: url("../img/hand-book2.png") center no-repeat;
  background-size: contain;
}
.tab-card-books-list {
  padding: 12px 0 0 30px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 11px;
}
.tab-card-content {
  border-radius: 0 0 40px;
  /* overflow: hidden; */
}
.tab-card-corner {
  position: absolute;
  bottom: -15px;
  right: -13px;
}
.tab-card-info__link {
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fbfbfb;
  text-decoration: none;
}
.tab-card-info__one-column {
  padding-right: 36px;
  background-color: #bd6856;
  border-bottom-right-radius: 60px;
}
.tab-card-info__right-btn {
  border-bottom-right-radius: 60px;
}
.tab-card-info__two-columns {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.tab-card-list {
  display: flex;
  flex-direction: column;
  row-gap: 20px;
  padding: 0 9px;
  margin-top: 16px;
}
.tab-card-main {
  flex-grow: 1;
}
.tab-card-tags {
  padding: 0 10px 0 7px;
  text-align: right;
  flex-shrink: 0;
}
.tab-card-tags-item {
  padding: 0 8px;
  font-size: 11px;
  line-height: 1.3;
  height: 14px;
  border-radius: 9px;
}
.tab-card-tags-list .tab-card-tags-item {
  color: #ffffff;
  background-color: #905946;
}
.tab-card-tags-item__city {
  /* margin: 7px 0 3px; */
  margin-bottom: 3px;
  display: inline-block;
  color: #905946;
  height: 16px;
  border: 1px solid #905946;
}
.tab-card-main .self-intro {
  padding: 8px 58px 4px;
  font-size: 10px;
  color: #7e7a7a;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-family: "Noto Sans JP", sans-serif;
}
.tab-card-tags-list {
  display: flex;
  align-items: center;
  -moz-column-gap: 3px;
       column-gap: 3px;
}
.tab-card-tags__bookmark {
  display: flex;
  justify-content: end;
  margin-bottom: 7px;
}
.title-block-group {
  display: flex;
  justify-content: space-between;
  margin: 34px 0 -13px;
  cursor: pointer;
}
.title-block-item {
  padding: 10px 18px;
  width: 149px;
  height: 50px;
  font-size: 13px;
  font-weight: bold;
  text-align: center;
  border-radius: 13px;
}
.title-block-item a {
  color: #ffffff;
}
.title-block-item__center {
  background: #e1a779;
}
.title-block-item__center a {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.title-block-item__center a img {
  margin-left: 6px;
}
.title-block-item__left {
  background-color: #fff8f3;
}
.title-block-item__left a {
  color: #707070;
}
.title-block-item__right {
  background: #bbcdb2;
}
.title-block-item__right .num-count-notify {
  position: absolute;
  right: 0px;
  top: -10px;
  border-radius: 50%;
  width: 22px;
  text-align: center;
  background-color: #ff672e;
  height: 22px;
  font-size: 11px;
  color: white;
  border: 2px white solid;
  font-weight: bold;
}
.toggle-overflow {
  scroll-behavior: smooth;
}
.user-like-style {
  border: solid 2px yellow;
}
.white-load-more-btn {
  font-size: 12px;
  color: #fbfbfb;
  text-align: center;
  padding: 5px 5px;
  cursor: pointer;
}
.switch-option-block .slider-receive-notify:before {
  content: "";
  position: absolute;
  height: 19px;
  width: 19px;
  left: 2px;
  bottom: 1px;
  background-color: #fff;
  border: 1px solid #bf826b;
  transition: 0.4s;
}
.switch-option-block input:checked + .slider-receive-notify:before {
  transform: translateX(55px);
}
.switch-option-block .slider-receive-notify.round-receive-notify:before {
  border-radius: 50%;
}
.switch-option-block .same-book-slider:before {
  border: 1px solid #a0a0a0;
}
.switch-option-block .partner-slider:before {
  border: 1px solid #abc0ac;
}
.switch-option-block .apero-slider:before {
  border: 1px solid #abc0ac;
}
.switch-option-block .no-package {
  margin: 10px 22px;
  padding: 10px;
  background: #fff;
  border-radius: 10px;
  color: red;
}
.switch-option-block .no-package p {
  overflow-wrap: break-word;
}
.switch-option-block .text-notify-mail {
  display: inline-block;
  color: white;
  font-weight: bold;
  font-size: 14px;
  padding: 0;
}
.switch-option-block .block-item-notify-request {
  background-color: white;
  margin: 10px 22px;
  padding: 5px;
  border-radius: 10px;
  display: flex;
}
.switch-option-block .first-character-name {
  width: 28px;
  height: 28px;
  line-height: 1.6em;
  text-align: center;
  border: 1px solid lightgrey;
  border-radius: 50%;
  margin-right: 10px;
}
.switch-option-block .bg-lover {
  background-color: #f3d6c8;
  color: #bf826b;
}
.switch-option-block .bg-friend {
  background-color: #d4f3c8;
  color: #4a5f4f;
}
.switch-option-block .content-notify-request {
  display: inline-block;
  font-size: 12px;
  margin-right: 25px;
  font-weight: normal;
}
.switch-option-block .button-accept-request {
  display: inline-block;
  float: right;
  padding: 8px;
}
.switch-option-block .button-accept-request a {
  background-color: black;
  color: white;
  border-radius: 25px;
  font-size: 12px;
  width: 46px;
  height: 20px;
  display: inline-block;
  text-align: center;
  line-height: 20px;
}
.switch-option-block .switch-option-btn {
  margin: 0 10px;
  display: inline-block;
  position: relative;
  width: 80px;
  height: 24px;
}
.switch-option-block .switch-option-btn.off .label-off {
  opacity: 1;
}
.switch-option-block .switch-option-btn.off .label-on {
  opacity: 0;
}
.switch-option-block .switch-option-btn .label-switch {
  position: absolute;
  top: 1px;
  font-size: 14px;
  font-weight: normal;
  z-index: 1;
}
.switch-option-block .switch-option-btn .label-off {
  opacity: 0;
  right: 8px;
  color: #999;
}
.switch-option-block .switch-option-btn .label-on {
  opacity: 1;
  left: 10px;
  color: #fff;
}
.switch-option-block .switch-option-btn Z input {
  opacity: 0;
  width: 0;
  height: 0;
}
.switch-option-block .slider-receive-notify {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 1px;
  background-color: #fff;
  cursor: pointer;
  transition: 0.4s;
}
.switch-option-block input:checked + .slider-receive-notify {
  background-color: #bf826b;
}
.switch-option-block input:focus + .slider-receive-notify {
  box-shadow: 0 0 1px #bf826b;
}
.switch-option-block .slider-receive-notify.round-receive-notify {
  border-radius: 25px;
  border: 1px solid white;
}
.switch-option-block input:checked + .same-book-slider {
  background-color: #ffffff;
}
.switch-option-block input:checked + .partner-slider {
  background-color: #e1a779;
}
.switch-option-block input:checked + .apero-slider {
  background-color: #bbcdb2;
}
/*# sourceMappingURL=main.css.map */