*, ::before, ::after {box-sizing: border-box;border-style: solid;border-width: 0;}html {line-height: 1.15;-webkit-text-size-adjust: 100%;-webkit-tap-highlight-color: transparent;}body {margin: 0;}main {display: block;}p, table, blockquote, address, pre, iframe, form, figure, dl {margin: 0;}h1, h2, h3, h4, h5, h6 {font-size: inherit;font-weight: inherit;margin: 0;}ul, ol {margin: 0;padding: 0;list-style: none;}dt {font-weight: bold;}dd {margin-left: 0;}hr {box-sizing: content-box;height: 0;overflow: visible;border-top-width: 1px;margin: 0;clear: both;color: inherit;}pre {font-family: monospace, monospace;font-size: inherit;}address {font-style: inherit;}a {background-color: transparent;text-decoration: none;color: inherit;}abbr[title] {text-decoration: underline dotted;}b, strong {font-weight: bolder;}code, kbd, samp {font-family: monospace, monospace;font-size: inherit;}small {font-size: 80%;}sub, sup {font-size: 75%;line-height: 0;position: relative;vertical-align: baseline;}sub {bottom: -0.25em;}sup {top: -0.5em;}svg, img, embed, object, iframe {vertical-align: bottom;}button, input, optgroup, select, textarea {-webkit-appearance: none;appearance: none;vertical-align: middle;color: inherit;font: inherit;background: transparent;padding: 0;margin: 0;border-radius: 0;text-align: inherit;text-transform: inherit;}[type="checkbox"] {-webkit-appearance: checkbox;appearance: checkbox;}[type="radio"] {-webkit-appearance: radio;appearance: radio;}button, [type="button"], [type="reset"], [type="submit"] {cursor: pointer;}button:disabled, [type="button"]:disabled, [type="reset"]:disabled, [type="submit"]:disabled {cursor: default;}:-moz-focusring {outline: auto;}select:disabled {opacity: inherit;}option {padding: 0;}fieldset {margin: 0;padding: 0;min-width: 0;}legend {padding: 0;}progress {vertical-align: baseline;}textarea {overflow: auto;}[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button {height: auto;}[type="search"] {outline-offset: -2px;}[type="search"]::-webkit-search-decoration {-webkit-appearance: none;}::-webkit-file-upload-button {-webkit-appearance: button;font: inherit;}label[for] {cursor: pointer;}details {display: block;}summary {display: list-item;}[contenteditable]:focus {outline: auto;}table {border-color: inherit;border-collapse: collapse;}caption {text-align: left;}td, th {vertical-align: top;padding: 0;}th {text-align: left;font-weight: bold;}

*:focus { outline: none; }
a { -webkit-tap-highlight-color: rgba(0 0 0 / 0); cursor: pointer; }

/* variable
------------------------------------------*/
:root {
  --maxWidth: 1680px;

  --marginPc: 60px;
  --margin1200: 52px;
  --marginTb: 44px;
  --marginSp: 36px;

  --paddingPc: 48px;
  --padding1200: 26px;
  --paddingTb: 22px;
  --paddingSp: 18px;

  --imageGapHorPc: 22px;
  --imageGapHorTb: 16px;
  --imageGapHorSp: 10px;

  --margin: calc(var(--marginPc) * var(--sectionSpacing));
  --padding: calc(var(--paddingPc) * var(--sectionSpacing));
  --imageGapVer: calc(var(--paddingPc) * 0.7);
  --imageGapHor: calc(var(--imageGapHorPc) * var(--sectionSpacing) * var(--imageSpacing));

  @media screen and (max-width: 1200px) {
    --margin: calc(var(--margin1200) * var(--sectionSpacing));
    --padding: calc(var(--padding1200) * var(--sectionSpacing));
    --imageGapVer: calc(var(--padding1200) * var(--sectionSpacing));
    --imageGapHor: calc(var(--imageGapHorPc) * var(--sectionSpacing) * var(--imageSpacing));
  }
  @media screen and (max-width: 992px) {
    --margin: calc(var(--marginTb) * var(--sectionSpacing));
    --padding: calc(var(--paddingTb) * var(--sectionSpacing));
    --imageGapVer: calc(var(--paddingTb) * var(--sectionSpacing));
    --imageGapHor: calc(var(--imageGapHorTb) * var(--sectionSpacing) * var(--imageSpacing));
  }
  @media screen and (max-width: 768px) {
    --margin: calc(var(--marginSp) * var(--sectionSpacing));
    --padding: calc(var(--paddingSp) * var(--sectionSpacing));
    --imageGapVer: calc(var(--paddingSp) * var(--sectionSpacing));
    --imageGapHor: calc(var(--imageGapHorSp) * var(--sectionSpacing) * var(--imageSpacing));
  }

  --plusLineHeight: calc((var(--bodyLineHeight) - 1.6) * 0.25);

  .head-font-size-s {
    --headFontSize: 2.6rem;
    --headFontSize1200: 2.5rem;
    --headFontSizeTb: 2.4rem;
    --headFontSizeSp: 2.2rem;
    --headLineHeight: calc(1.30 + var(--plusLineHeight));
    --headLineHeightTb: calc(1.28 + var(--plusLineHeight));
    --headLineHeightSp: calc(1.26 + var(--plusLineHeight));
  }
  .head-font-size-m {
    --headFontSize: 3.2rem;
    --headFontSize1200: 3.0rem;
    --headFontSizeTb: 2.8rem;
    --headFontSizeSp: 2.3rem;
    --headLineHeight: calc(1.28 + var(--plusLineHeight));
    --headLineHeightTb: calc(1.26 + var(--plusLineHeight));
    --headLineHeightSp: calc(1.24 + var(--plusLineHeight));
  }
  .head-font-size-l {
    --headFontSize: 3.8rem;
    --headFontSize1200: 3.5rem;
    --headFontSizeTb: 3.2rem;
    --headFontSizeSp: 2.4rem;
    --headLineHeight: calc(1.26 + var(--plusLineHeight));
    --headLineHeightTb: calc(1.24 + var(--plusLineHeight));
    --headLineHeightSp: calc(1.22 + var(--plusLineHeight));
  }

  .head-font-size-s,
  .head-font-size-m,
  .head-font-size-l {
    @media screen and (max-width: 1200px) {
      --headFontSize: var(--headFontSize1200);
    }
    @media screen and (max-width: 992px) {
      --headFontSize: var(--headFontSizeTb);
      --headLineHeight: var(--headLineHeightTb);
    }
    @media screen and (max-width: 768px) {
      --headFontSize: var(--headFontSizeSp);
      --headLineHeight: var(--headLineHeightSp);
    }

    --pageTitleSize: calc(var(--headFontSize) * 1.4);
    --subPageTitleSize: calc(var(--headFontSize) * 1.1);
    --headFontSizeS: calc(var(--headFontSize) * 0.8);

    @media screen and (max-width: 992px) {
      --headFontSizeS: calc(var(--headFontSize) * 0.9);
    }
    @media screen and (max-width: 768px) {
      --headFontSizeS: calc(var(--headFontSize) * 1.0);
    }
    @media screen and (max-width: 600px) {
      --pageTitleSize: calc(var(--headFontSize) * 1.1);
    }
  }

  --pageTitleMargin: calc(var(--margin) * 1);

  --inputBorderRadius: 4px;

  --itemNum: 4;
  --imageMargin: 20px;
  --imageTitleHeight: 420px;
  --itemListTextAlign: start;

  @media screen and (max-width: 1200px) {
    --itemNum: 3;
    --imageMargin: 18px;
    --imageTitleHeight: 400px;
  }

  @media screen and (max-width: 992px) {
    --itemNum: 3;
    --imageMargin: 16px;
    --imageTitleHeight: 380px;
  }

  @media screen and (max-width: 768px) {
    --itemNum: 3;
    --imageTitleHeight: 360px;
  }

  @media screen and (max-width: 600px) {
    --itemNum: 2;
    --imageTitleHeight: 200px;
  }
}

html {
  font-size: var(--bodyFontSize);
  scroll-padding-top: var(--headerGroupHeight);
}

/* base
------------------------------------------*/
body {
  min-height: 100vh;
  color: var(--textColor);
  font-size: 1.4rem;
  font-family: var(--bodyFontEn), var(--bodyFontJa), sans-serif;
  font-weight: var(--bodyFontWeightNormal);
  line-height: var(--bodyLineHeight);
  letter-spacing: var(--bodyLetterSpacing);
  word-break: break-word;
  overflow-wrap: anywhere;
  line-break: anywhere;

  &.use-themebg {
    background: var(--bgColor);
  }
}

h1,
h2,
.logo,
.split-text span:nth-child(1),
.mv2 .text .title,
.looptext ul li p,
.concept .text h3,
.item-detail .price .default:not(.related-items .text .price .default),
.item-detail .price .current,
.appsItemDetailCustomTag_heading,
.about-main h3,
.about-main h4,
.communityMain .communityItemHeader,
.communityMain .communityUrlHeader,
.membership .guide .content .heading,
.membership .guide .register .heading,
.membership .login .heading,
.membership .mypage .heading,

.item-list-title h1,
.image-title h2,
.page-title,
.contact h2,
#privacy h2,
#law h2 {
  font-size: var(--headFontSize);
  font-weight: var(--headFontWeight) !important;
  font-family: var(--headFontEn), var(--headFontJa), sans-serif !important;
  line-height: var(--headLineHeight) !important;
  letter-spacing: var(--headLetterSpacing);
}
a {
  color: var(--textColor);
  transition: all 0.3s ease;
}
img:where(:not(.bnplBanner img)):where(:not(.bnplBannerModal img)):where(:not(.x_purchaseButtonModal img)):where(:not(.communityBox img)) {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}
label[for] {
  cursor: default;
}

.scrollbar,
.header-category-dropdown > ul {
  overflow-x: hidden;
  overflow-y: auto;
/*  scrollbar-width: thin;*/

  @media (hover: hover) {
    &::-webkit-scrollbar {
      width: 4px;
    }
    &::-webkit-scrollbar-track {
      width: 100%;
      background: var(--bgColor);
      border-radius: 1px;
    }
    &::-webkit-scrollbar-thumb {
      width: 100%;
      background: var(--textColor12);
      border-radius: 1px;
    }
  }
}

.content-wrap {
  overflow-x: clip;
}
.content {
  position: relative;
  margin: 0 auto var(--margin) auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
}
.home .content {
  margin: 0 auto;
  padding: 0;
  max-width: 100%;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  cursor: pointer;
  font-family: var(--bodyFontEn), var(--bodyFontJa), sans-serif !important;
  font-weight: var(--bodyFontWeightNormal);
  line-height: var(--bodyLineHeight);
  letter-spacing: var(--bodyLetterSpacing);
}

.header-search input,
.drawer-search input,
.sidebar-search input,
.inquirySection dl dd input,
.inquirySection dl dd textarea,
input.x_mailMagazineSubscribe_input,
input.itemOption__input,
select.x_i18nSelectBox,
select#valiationSelect,
select.itemOption__select,
select.amountSelect {
  outline: none !important;
  display: block;
  margin: 0 !important;
  padding: 10px !important;
  width: 100% !important;
  min-width: auto !important;
  color: var(--textColor) !important;
  font-size: 1.3rem !important;
  font-family: var(--bodyFontEn), var(--bodyFontJa), sans-serif !important;
  line-height: inherit !important;
  letter-spacing: inherit !important;
  background: transparent !important;
  border: var(--textColor12) 1px solid !important;
  border-radius: var(--inputBorderRadius) !important;
  box-shadow: none !important;
  transition: all 0.3s ease !important;
  appearance: none !important;
}

select.x_i18nSelectBox,
select#valiationSelect,
select.itemOption__select,
select.amountSelect {
  padding: 8px 24px 8px 10px !important;
  background:
    linear-gradient(45deg, transparent 50%, var(--bgColor) 50%) no-repeat top calc(50% - 1.5px) right 18px / 6px 6px,
    linear-gradient(-45deg, transparent 50%, var(--bgColor) 50%) no-repeat top calc(50% - 1.5px) right 12px / 6px 6px,
    linear-gradient(45deg, transparent 50%, var(--textColor) 50%) no-repeat top 50% right 18px / 6px 6px,
    linear-gradient(-45deg, transparent 50%, var(--textColor) 50%) no-repeat top 50% right 12px / 6px 6px !important;
  background-color: var(--bgColor) !important;
}

.header-search input::placeholder,
.drawer-search input::placeholder,
.sidebar-search input::placeholder,
input.x_mailMagazineSubscribe_input::placeholder,
input.itemOption__input::placeholder {
  opacity: 0.3 !important;
  color: var(--textColor);
}

a:focus,
button:focus,
input:focus,
textarea:focus,
input[type="checkbox"]:focus,
input[type="radio"]:focus,
select:focus,
select.x_i18nSelectBox:focus,
select#valiationSelect:focus,
select.itemOption__select:focus,
select.amountSelect:focus {
  outline: none !important;
  box-shadow: none !important;
}

.is-keyboard {
  a:focus-visible,
  button:focus-visible,
  input:focus-visible,
  textarea:focus-visible,
  input[type="checkbox"]:focus-visible,
  input[type="radio"]:focus-visible,
  select:focus-visible,
  select.x_i18nSelectBox:focus-visible,
  select#valiationSelect:focus-visible,
  select.itemOption__select:focus-visible,
  select.amountSelect:focus-visible,
  summary:focus-visible,
  .x_reviewLabel:focus-visible,
  .review01__trigger:focus-visible {
    outline: #fff 1px solid !important;
    outline-offset: 2px !important;
    box-shadow: 0 0 0 2px rgb(0 123 255 / 0.5) !important;
    border-radius: 4px;
  }

  .swiper-button-prev,
  .swiper-button-next,
  .swiper-pagination-bullet {
    &:focus {
      outline: #fff 1px solid !important;
      outline-offset: 2px !important;
      box-shadow: 0 0 0 2px rgb(0 123 255 / 0.5) !important;
      border-radius: 4px;
    }
  }
}

#i18 {
  display: flex;
  align-items: center;
  gap: 18px;

  .subheader & {
    --textColor: var(--subheaderTextColor);
  }

  .select {
    position: relative;
    transition: all 0.3s ease;

    &:after {
      content: '';
      position: absolute;
      inset: 50% 0 auto auto;
      width: 16px;
      height: 16px;
      mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.5%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-down%22%3E%3Cpolyline%20points%3D%226%209%2012%2015%2018%209%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 16px;
      -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.5%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-down%22%3E%3Cpolyline%20points%3D%226%209%2012%2015%2018%209%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 16px;
      background-color: var(--textColor);
      translate: 0 -50%;
    }

    @media (hover: hover) {
      &:hover {
        opacity: 0.7;
      }
    }

    select {
      position: relative;
      padding: 0 18px 0 0 !important;
      min-width: 12px !important;
      height: 30px !important;
      color: var(--textColor) !important;
      letter-spacing: normal !important;
      background: none !important;
      border: none !important;
      z-index: 1;
    }
  }

  .gtranslate_wrapper {
    display: flex;
    gap: 8px;
    position: relative;
    padding: 0 18px 0 0;

    &:after {
      content: '';
      position: absolute;
      inset: 50% 0 auto auto;
      width: 1px;
      height: 12px;
      background: currentColor;
      translate: 0 -50%;
    }

    a {
      opacity: 0.5;

      &.gt-current-lang {
        opacity: 1;
        font-weight: var(--bodyFontWeightNormal);
      }
    }
  }
}

.fancybox-bg {
  background: #000;
}
.fancybox-is-open .fancybox-bg {
  opacity: 0.8;
}

/* base overwrite
------------------------------------------*/
.msg_messenger__shopName {
  line-height: 44px !important;
}
.msg_postBox__control__submit {
  text-align: center;
}
.purchaseButtonModal__title {
  padding: 15px 35px !important;
  line-height: 1.4 !important;
}
.purchaseButtonModal__input,
.purchaseButtonModal__inputArea,
.purchaseButtonModal__ageVerificationWarningText,
.communityModal,
.communityModal h1,
.communityModal a,
.msg_postBox__control__input,
#salesPeriodModal .salesPeriodModal__input {
  color: #222 !important;
}
.communityModal {
  overflow: auto;
  max-height: 90%;
}
.telnumValid__txt {
  color: var(--textColor) !important;
  background: var(--subBgColor) !important;
}
.centeringFixForPostageInfo {
  position: fixed !important;
}
#takeoutModal .takeoutModal__title {
  padding: 18px 30px !important;
  line-height: 1.3 !important;
}
.shippingModal .shippingInfo__tabChild {
  text-align: center;
}

.informationBanner {
  opacity: 0;
  transition: all 0.6s ease;
}
.loaded .informationBanner {
  opacity: 1;
}
.informationBannerIcon i {
  font-size: 18px !important;
}
.informationBannerText strong {
  font-size: 13px !important;
  font-weight: var(--bodyFontWeightBold) !important;
}
.informationBannerArrow {
  font-size: 14px !important;
}

.flash-message,
.flashMessage {
  opacity: 0;
  position: fixed !important;
  top: 20px !important;
  left: auto !important;
  right: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 340px;
  transform: translateX(20px);
  transition: all 0.6s ease;
  z-index: 9999;
}
.loaded .flash-message,
.loaded .flashMessage {
  opacity: 1;
  transform: translateX(0);
}
.flash-message.close,
.flashMessage.close {
  opacity: 0 !important;
  transform: translateX(20px) !important;
}
.flash-message .contents,
.flashMessage .message {
  margin: 0 0 10px 0 !important;
  padding: 20px !important;
  width: 100% !important;
  max-width: auto !important;
  font-size: 1.2rem !important;
  color: var(--textColor) !important;
  background: var(--bgColor) !important;
  box-shadow: 0 10px 10px -5px rgba(0 0 0 / 0.1);
  border-radius: 4px;
}
.flashMessage.error .contents,
.flashMessage #orderErrorMessage {
  color: var(--noticeColor) !important;
}
@media screen and (max-width: 768px) {
  .flash-message,
  .flashMessage {
    width: calc(100% - 40px);
  }
}

.msg_smsAuth__formArea .x_address {
  margin: 0 !important;
  padding: 10px !important;
  border: none !important;
}
.c-messageItemBox__link__itemBoxInfo {
  width: calc(100% - 70px);
}

#IllegalReportTitle {
  appearance: auto;
  -webkit-appearance: auto;
}
#x_illegalReportMessage {
  max-width: 100%;
}

/* btn
------------------------------------------*/
.btn-arrow {
  position: relative;
  margin-block-start: 3rem;

  a {
    display: inline-flex;
    position: relative;
    margin-inline: 0;
    padding: 0 32px 0 0;
    font-size: 1.2rem;

    &:before {
      content: '';
      position: absolute;
      inset: 50% 0 auto auto;
      width: 22px;
      height: 22px;
      border: var(--textColor) 1px solid;
      border-radius: 50%;
      translate: 0 -50%;
      transition: all 0.2s ease;
    }

    &:after {
      content: '';
      position: absolute;
      inset: 50% 3px auto auto;
      width: 16px;
      height: 16px;
      mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 16px;
      -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 16px;
      background-color: var(--textColor);
      translate: 0 -50%;
      transition: all 0.3s ease;
    }

    @media (hover: hover) {
      &:hover {
        &:before {
          inset: 50% -2px auto auto;
          width: 26px;
          height: 26px;
        }
      }
    }
  }
}

.btn-image {
  position: relative;
  margin-block-start: 3rem;
  margin-inline: auto;
  z-index: 1;

  a {
    overflow: hidden;
    display: flex;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    position: relative;
    padding: 12px 20px 12px 24px;
    min-width: 180px;
    color: var(--subheaderTextColor);
    font-size: 1.2rem;
    border-radius: 100px;
    transition: all 0.3s ease;

    &:before {
      content: '';
      opacity: 1;
      position: absolute;
      inset: 0;
      background: var(--subheaderBgColor);
      border-radius: 100px;
      box-shadow: rgb(0 0 0 / 0.12) 0px 20px 25px -5px, rgb(0 0 0 / 0.04) 0px 10px 10px -5px;
      transition: all 0.3s ease;
      z-index: -1;
    }

    &:after {
      content: '';
      width: 18px;
      height: 18px;
      mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 18px;
      -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 18px;
      background-color: var(--subheaderTextColor);
      transition: all 0.2s ease;
    }

    @media (hover: hover) {
      &:hover {
        &:before {
          opacity: 0.7;
        }
        &:after {
          translate: 5px 0;
        }
      }
    }

    @media screen and (max-width: 768px) {
      gap: 4px;
      padding: 10px 16px 10px 20px;
      min-width: 140px;

      &:after {
        translate: 3px 0;
      }
    }
  }
}

.btn-normal {
  position: relative;
  margin-block-start: 3rem;
  text-align: center;
  z-index: 1;
}

.btn-normal a,
.btn-normal span,
.contact .control-panel,
.membership .login .link,
.membership .guide .register .link,
.membership .guide .mypage-link .link,
.membership .mypage .content .definition-description .edit,
.membership .mypage .content .definition-edit-button .edit {
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  position: relative;
  margin: 0 auto !important;
  padding: 12px 5px !important;
  min-width: 180px !important;
  width: auto !important;
  color: var(--textColor) !important;
  font-size: 1.2rem !important;
  text-align: center !important;
  line-height: var(--bodyLineHeight) !important;
  background: none !important;
  border: var(--textColor) 1px solid !important;
  border-radius: 100px !important;
  transition: all 0.3s ease !important;

  @media (hover: hover) {
    &:hover {
      opacity: 0.7;
    }
  }
}
.contact .control-panel {
  padding: 0 !important;
}
.contact .control-panel input[type="submit"] {
  display: block;
  padding: 10px 5px;
}



/* popup-banner
------------------------------------------*/
.popup-banner-bg {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  background: var(--textColor);
  transition: all 0.3s ease;
  z-index: 10010;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 0.6;
  }

  &.type-2 {
    display: none;
  }
}

.popup-banner {
  opacity: 0;
  visibility: hidden;
  display: grid;
  place-items: center;
  position: fixed;
  inset: 0;
  translate: 0 20px;
  transition: all 0.6s ease;
  z-index: 10011;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 1;
    translate: 0;
  }

  .popup-banner-image {
    position: relative;
    margin: 0 auto;
    max-width: 780px;
    text-align: center;
    box-shadow: rgb(0 0 0 / 0.12) 0px 20px 25px -5px, rgb(0 0 0 / 0.04) 0px 10px 10px -5px;

    @media screen and (max-width: 992px) {
      max-width: 85%;
    }

    a {
      overflow: hidden;
      display: block;
      border-radius: var(--imageBorderRadius);

      img {
        margin: 0 auto;
        max-height: 75vh;
      }
    }
  }

  &.type-2 {
    display: block;
    inset: auto 40px 40px auto;
    width: auto;
    height: auto;
    z-index: 9999;

    .x_message_view & {
      inset: auto 40px 100px auto;
    }

    .popup-banner-image {
      margin: 0 0 0 auto;
      max-width: 300px;

      @media screen and (max-width: 992px) {
        max-width: 70%;
      }
    }
  }

  .popup-banner-close {
    opacity: 0;
    position: absolute;
    top: -20px;
    right: -20px;
    scale: 0;
    transition: all 0.3s ease;
    z-index: 1;

    a {
      display: block;
      width: 33px;
      height: 33px;
      background: var(--bgColor);
      box-shadow: rgb(0 0 0 / 0.12) 0px 20px 25px -5px, rgb(0 0 0 / 0.04) 0px 10px 10px -5px;
      border-radius: 50%;

      &:after {
        content: '';
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
        -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
        background-color: var(--textColor);
      }
    }

    .popup-banner[aria-hidden='false'] & {
      opacity: 1;
      scale: 1;
      transition: all 0.3s 0.3s ease;
    }
  }
}

/* drawer
------------------------------------------*/
.drawer-bg {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  background: rgb(0 0 0 / 0.3);
  transition: all 0.3s ease;
  z-index: 10002;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 1;
  }
}
.drawer {
  visibility: hidden;
  display: flex;
  flex-direction: column;
  position: fixed;
  inset: 0;
  width: 90%;
  max-width: 440px;
  height: 100dvh;
  background: var(--bgColor);
  border-radius: 0 20px 20px 0;
  box-shadow: rgb(0 0 0 / 0.06) 0px 20px 25px -5px, rgb(0 0 0 / 0.02) 0px 10px 10px -5px;
  translate: -100% 0;
  transition: all 0.3s ease, height 0s;
  z-index: 10003;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 1;
    translate: 0;
  }

  .drawer-close {
    display: flex;
    align-items: center;
    padding: 0 24px;
    height: 70px;

    a {
      display: block;
      position: relative;
      width: 100%;
      height: 44px;

      &:after {
        content: '';
        position: absolute;
        inset: 0 auto 0 -2px;
        width: 100%;
        height: 100%;
        mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat left center / 22px;
        -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat left center / 22px;
        background-color: var(--textColor);
      }
    }
  }

  .drawer-main {
    position: relative;
    height: calc(100% - 70px);

    &:has(+ .drawer-bottom .drawer-sns),
    &:has(+ .drawer-bottom #i18) {
      height: calc(100% - 140px);
    }

    .drawer-menu {
      overflow: hidden;
      position: absolute;
      inset: 0 0 auto 0;
      padding: 0 24px 32px 24px;
      transition: all 0.2s ease, height 0s;

      &[aria-hidden='false'] {
        visibility: visible;
        opacity: 1;
        translate: 0 0;
      }

      &[aria-hidden='true'] {
        visibility: hidden;
        opacity: 0;
        translate: 50px 0;
        height: 0 !important;
        transition: none;
      }

      .drawer-back {
        a {
          display: block;
          position: relative;
          padding: 16px 0 16px 32px;

          span {
            position: absolute;
            inset: 50% auto 0 -16px;
            width: 44px;
            height: 44px;
            translate: 0 -50%;

            &:after {
              content: '';
              position: absolute;
              inset: 0;
              width: 100%;
              height: 100%;
              mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-left%22%3E%3Cpolyline%20points%3D%2215%2018%209%2012%2015%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-left%22%3E%3Cpolyline%20points%3D%2215%2018%209%2012%2015%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              background-color: var(--textColor);
            }
          }
        }
      }

      .menu {

        li {
          position: relative;
          border-block-end: var(--textColor12) 1px solid;

          a:first-child {
            display: block;
            padding-block: 16px;
            line-height: 1.3;
            transition: all 0.2s ease;

            &:has(+ a.arrow) {
              padding-inline-end: 44px;
            }
          }

          a.arrow {
            position: absolute;
            inset: 50% -12px 0 auto;
            width: 44px;
            height: 44px;
            translate: 0 -50%;

            &:after {
              content: '';
              position: absolute;
              inset: 0;
              width: 100%;
              height: 100%;
              mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              background-color: var(--textColor);
              transition: all 0.2s ease;
            }
          }
        }
      }

      .submenu {
        margin-block-start: 32px;
        font-size: 1.2rem;

        a,
        span {
          display: block;
          padding-block: 5px;
        }

        ul {
          position: relative;
          margin-block: 12px;
          padding-inline-start: 20px;
          font-size: 1.2rem;
          border-inline-start: var(--textColor12) 1px solid;

          a {
            padding-block: 3px;
          }
        }
      }

      .drawer-search {
        display: flex;
        position: relative;
        margin-block-start: 24px;
        padding-inline: 3px;
        border: var(--textColor12) 1px solid;
        border-radius: 100px;

        input {
          display: block !important;
          padding: 12px !important;
          margin: 0 !important;
          width: calc(100% - 44px) !important;
          height: auto !important;
          color: var(--textColor) !important;
          font-size: 1.4rem !important;
          line-height: 1 !important;
          background: none !important;
          border: none !important;
        }

        button {
          position: relative;
          width: 44px;
          height: 44px;

          &:after {
            content: '';
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-search%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2216.65%22%20y2%3D%2216.65%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
            -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-search%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2216.65%22%20y2%3D%2216.65%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
            background-color: var(--textColor);
          }
        }
      }
    }
  }

  .drawer-bottom {
    display: none;
    margin-block-start: auto;

    &:has(*) {
      display: flex;
      align-items: center;
      position: relative;
      padding: 0 24px;
      height: 70px;

      &:before {
        content: '';
        opacity: 0.1;
        position: absolute;
        inset: 0 0 auto 0;
        width: 100%;
        height: 1px;
        background: var(--textColor);
      }
    }

    .drawer-sns {
      display: flex;
      align-items: center;
      gap: 10px;

      @media screen and (max-width: 768px) {
        overflow-x: auto;
        width: 60%;
        mask-image: linear-gradient(to right, black 80%, transparent 100%);
        scrollbar-width: none;
      }

      @media screen and (max-width: 600px) {
        width: 50%;
      }

      div {
        width: 18px;

        a {
          display: block;
          width: 18px;

          @media (hover: hover) {
            &:hover {
              opacity: 0.7;
            }
          }

          .twitter & {
            background: #000;
            border-radius: 3px;
          }

          img {
            width: 18px;
            height: 18px;

            .twitter & {
              padding: 3px;
              filter: brightness(0) invert(1);
            }
          }
        }
      }
    }

    #i18 {
      margin-inline-start: auto;
    }
  }
}

/* guidedrawer
------------------------------------------*/
.guidedrawer-bg {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  background: rgb(0 0 0 / 0.3);
  transition: all 0.3s ease;
  z-index: 10002;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 1;
  }
}
.guidedrawer {
  visibility: hidden;
  display: flex;
  flex-direction: column;
  position: fixed;
  inset: 0 0 0 auto;
  width: 90%;
  max-width: 440px;
  height: 100dvh;
  background: var(--bgColor);
  border-radius: 20px 0 0 20px;
  box-shadow: rgb(0 0 0 / 0.06) 0px 20px 25px -5px, rgb(0 0 0 / 0.02) 0px 10px 10px -5px;
  translate: 100% 0;
  transition: all 0.3s ease, height 0s;
  z-index: 10003;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 1;
    translate: 0;
  }

  .guidedrawer-close {
    display: flex;
    align-items: center;
    padding: 0 24px;
    height: 70px;

    a {
      display: block;
      position: relative;
      width: 100%;
      height: 44px;

      &:after {
        content: '';
        position: absolute;
        inset: 0 auto 0 -2px;
        width: 100%;
        height: 100%;
        mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat left center / 22px;
        -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat left center / 22px;
        background-color: var(--textColor);
      }
    }
  }

  .guidedrawer-main {
    position: relative;
    height: calc(100% - 70px);

    .guidedrawer-menu {
      overflow: hidden;
      position: absolute;
      inset: 0 0 auto 0;
      padding: 0 24px 32px 24px;
      transition: all 0.2s ease, height 0s;

      &[aria-hidden='false'] {
        visibility: visible;
        opacity: 1;
        translate: 0 0;
      }

      &[aria-hidden='true'] {
        visibility: hidden;
        opacity: 0;
        translate: 50px 0;
        height: 0 !important;
        transition: none;
      }

      .guidedrawer-back {
        a {
          display: block;
          position: relative;
          padding: 16px 0 16px 32px;

          span {
            position: absolute;
            inset: 50% auto 0 -16px;
            width: 44px;
            height: 44px;
            translate: 0 -50%;

            &:after {
              content: '';
              position: absolute;
              inset: 0;
              width: 100%;
              height: 100%;
              mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-left%22%3E%3Cpolyline%20points%3D%2215%2018%209%2012%2015%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-left%22%3E%3Cpolyline%20points%3D%2215%2018%209%2012%2015%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              background-color: var(--textColor);
            }
          }
        }

        &.guidedrawer-back-bottom {
          margin: 22px 0 0 0;

          a {
            display: block;
            position: relative;
            margin-inline: auto;
            width: 44px;
            height: 44px;
            border-radius: 50%;
            border: var(--textColor) 1px solid;

            &:before {
              content: '';
              position: absolute;
              inset: 0;
              width: 100%;
              height: 100%;
              mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-arrow-left%22%3E%3Cline%20x1%3D%2219%22%20y1%3D%2212%22%20x2%3D%225%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cpolyline%20points%3D%2212%2019%205%2012%2012%205%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-arrow-left%22%3E%3Cline%20x1%3D%2219%22%20y1%3D%2212%22%20x2%3D%225%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cpolyline%20points%3D%2212%2019%205%2012%2012%205%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              background-color: var(--textColor);
            }
          }
        }
      }

      .guidedrawer-text {
        padding-block: 16px;
        font-size: 1.3rem;
      }

      .menu {

        li {
          position: relative;

          a {
            display: block;
            padding: 16px 44px 16px 0;
            border-block-end: var(--textColor12) 1px solid;

            &:after {
              content: '';
              position: absolute;
              inset: 50% -12px 0 auto;
              width: 44px;
              height: 44px;
              mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
              background-color: var(--textColor);
              translate: 0 -50%;
            }
          }
        }
      }

      .submenu {
        margin-block-start: 32px;
        font-size: 1.2rem;

        a {
          display: block;
          padding-block: 5px;
        }
      }

      .bottom {
        margin-block-start: 32px;
        padding: 22px;
        color: var(--subTextColor);
        font-size: 1.2rem;
        white-space: pre-line;
        background: var(--subBgColor);
        border-radius: 4px;
      }
    }
  }
}

.markdown {
  & > * {
    margin-block-end: 2rem;

    &:last-child {
      margin-block-end: 0;
    }
  }

  h1, h2, h3, h4, h5, h6 {
    margin-block-start: 3rem;
    font-size: 1.6rem;
    font-weight: var(--bodyFontWeightBold);

    &:first-child {
      margin-block-start: 0;
    }
  }

  h3 {
    font-size: 1.5rem;
  }

  h4, h5, h6 {
    font-size: 1.4rem;
  }

  h5, h6 {
    opacity: 0.5;
  }

  a {
    text-decoration: underline;
  }

  strong {
    font-weight: var(--bodyFontWeightBold);
  }

  hr {
    color: var(--textColor12);
  }

  ul {
    list-style: inside;

    li {
      padding: 2px 0;
    }
  }

  ol {
    list-style: inside decimal;

    li {
      padding: 2px 0;
    }
  }

  table {
    margin-block-start: -6px;
    width: 100%;
    table-layout: fixed;

    th {
      padding: 8px 2px;
      text-align: center;
      font-size: 1.2rem;
      font-weight: var(--bodyFontWeightBold);
      background: var(--subBgColor);
      border: var(--textColor12) 1px solid;
    }

    td {
      padding: 8px 2px;
      font-size: 1.2rem;
      text-align: center;
      border: var(--textColor12) 1px solid;
    }
  }

  img {
    border-radius: var(--imageBorderRadius);
  }
}

/* subheader
------------------------------------------*/
.subheader {
  opacity: 0;
  color: var(--subheaderTextColor);
  font-size: 1.2rem;
  background: var(--subheaderBgColor);
  transition: opacity 0.6s ease;

  --subheaderHeight: 48px;

  @media screen and (max-width: 1200px) {
    --subheaderHeight: 44px;
  }
  @media screen and (max-width: 992px) {
    --subheaderHeight: 40px;
  }

  .loaded & {
    opacity: 1;
  }

  .subheader-inner {
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;
    gap: 20px;
    margin-inline: auto;
    padding-inline: var(--padding);
    max-width: var(--maxWidth);
    height: var(--subheaderHeight);

    @media screen and (max-width: 992px) {
      grid-template-columns: 1fr;
    }

    .subheader-left {
      display: flex;
      align-items: center;

      @media screen and (max-width: 992px) {
        display: none;
      }

      & > * {
        display: none;
      }

      &.sns {
        .sns {
          overflow-x: auto;
          display: flex;
          align-items: center;
          gap: 18px;
          width: 100%;
          mask-image: linear-gradient(to right, black 80%, transparent 100%);
          scrollbar-width: none;

          a {
            display: block;
            width: 18px;
            transition: opacity 0.3s ease;

            @media (hover: hover) {
              &:hover {
                opacity: 0.7;
              }
            }

            .twitter & {
              background: #000;
              border-radius: 3px;
            }

            img {
              width: 18px;
              height: 18px;

              .twitter & {
                padding: 3px;
                filter: brightness(0) invert(1);
              }
            }
          }
        }
      }
    }

    .subheader-center {
      display: flex;

      & > * {
        display: none;
      }

      &.free {
        overflow: hidden;
        width: 100%;
        height: var(--subheaderHeight);

        .free {
          display: flex;
          width: 100%;

          @media screen and (max-width: 992px) {
            margin: 0 -10px;
            width: calc(100% + 20px);
          }

          .swiper-slide {
            visibility: hidden;
            display: flex;
            justify-content: center;
            align-items: center;
            height: var(--subheaderHeight);

            &.swiper-slide-active {
              visibility: visible;
            }
          }

          p {
            opacity: 0;
            padding: 0 44px;
            width: 100%;
            text-align: center;
            line-height: 1.3;
            translate: 0 10px;
            transition: all 0.6s ease;

            .swiper-slide-active & {
              opacity: 1;
              translate: 0;
              transition: all 0.6s 0.2s ease;
            }
          }

          a {
            color: var(--subheaderTextColor);

            @media (hover: hover) {
              &:hover {
                opacity: 0.7;
              }
            }
          }

          .swiper-button-prev,
          .swiper-button-next {
            left: 0;
            color: var(--subheaderTextColor);
            transition: all 0.2s ease;

            &.swiper-button-next {
              left: auto;
              right: 0;
            }

            &:after {
              font-size: 0.5lh;
            }

            @media (hover: hover) {
              &:hover {
                scale: 1.2;
              }
            }
          }
        }
      }
    }

    .subheader-right {
      display: flex;
      justify-content: flex-end;
      align-items: center;

      @media screen and (max-width: 992px) {
        display: none;
      }

      & > * {
        display: none;
      }

      &.lang {
        .translate {
          display: block;

          select {
            font-size: 1.2rem !important;
          }
        }
      }

      &.menu {
        ul.menu {
          display: flex;
          align-items: center;
          gap: 18px;

          li {
            display: flex;

            a {
              position: relative;
              color: var(--subheaderTextColor);

              &:before {
                content: '';
                position: absolute;
                inset: auto 0 0 0;
                width: 100%;
                height: 1px;
                background: var(--subheaderTextColor);
                scale: 0 1;
                transform-origin: right top;
                transition: scale 0.3s ease;
              }

              @media (hover: hover) {
                &:hover:before {
                  scale: 1 1;
                  transform-origin: left top;
                }
              }
            }
          }
        }
      }
    }
  }
}

/* header-search
------------------------------------------*/
.header-search-bg {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  background: rgb(0 0 0 / 0.3);
  transition: all 0.3s ease;
  z-index: 10002;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 1;
  }
}
.header-search-modal {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  inset: 0 0 auto 0;
  padding: var(--padding);
  width: 100%;
  background: var(--bgColor);
  box-shadow: rgb(0 0 0 / 0.06) 0px 20px 25px -5px, rgb(0 0 0 / 0.02) 0px 10px 10px -5px;
  translate: 0 -100%;
  transition: all 0.3s ease;
  z-index: 10003;

  &[aria-hidden='false'] {
    visibility: visible;
    opacity: 1;
    translate: 0 0;
  }

  .header-search-wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-inline: auto;
    width: min(80%, 600px);

    .header-search {
      display: flex;
      justify-content: space-between;
      padding: 3px 3px 3px 15px;
      width: 100%;
      border: var(--textColor) 1px solid;
      border-radius: 100px;
      transition: all 0.3s ease;

      input {
        display: block !important;
        padding: 12px !important;
        margin: 0 !important;
        width: calc(100% - 44px) !important;
        height: auto !important;
        color: var(--textColor) !important;
        font-size: 1.4rem !important;
        line-height: 1 !important;
        background: none !important;
        border: none !important;
      }

      button {
        position: relative;
        width: 44px;
        height: 44px;

        &:after {
          content: '';
          position: absolute;
        inset: 0;
          width: 100%;
          height: 100%;
          mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-search%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2216.65%22%20y2%3D%2216.65%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
          -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-search%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2216.65%22%20y2%3D%2216.65%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
          background-color: var(--textColor);
        }

        @media (hover: hover) {
          &:hover {
            opacity: 0.7;
          }
        }
      }
    }

    .close {
      a {
        cursor: pointer;
        display: block;
        position: relative;
        margin: 0 0 0 10px;
        width: 44px;
        height: 44px;

        &:after {
          content: '';
          position: absolute;
          inset: 0;
          width: 100%;
          height: 100%;
          mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 28px;
          -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 28px;
          background-color: var(--textColor);
        }

        @media (hover: hover) {
          &:hover {
            opacity: 0.7;
          }
        }
      }
    }
  }
}

/* header
------------------------------------------*/
.mega-bg {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  background: var(--textColor30);
  transition: all 0.3s ease;
  z-index: 99;

  &.open {
    visibility: visible;
    opacity: 1;
  }
}

.header {
  opacity: 0;
  position: relative;
  transition: all 0.5s ease, top 0.3s ease, height 0.3s ease;
  will-change: top, height;
  backface-visibility: hidden;
  z-index: 100;

  .loaded & {
    opacity: 1;
  }

  &.height-s {
    --headerHeight: 70px;

    @media screen and (max-width: 992px) {
      --headerHeight: 62px;
    }
    @media screen and (max-width: 768px) {
      --headerHeight: 54px;
    }
  }
  &.height-m {
    --headerHeight: 90px;

    @media screen and (max-width: 992px) {
      --headerHeight: 80px;
    }
    @media screen and (max-width: 768px) {
      --headerHeight: 70px;
    }
  }
  &.height-l {
    --headerHeight: 110px;

    @media screen and (max-width: 992px) {
      --headerHeight: 95px;
    }
    @media screen and (max-width: 768px) {
      --headerHeight: 80px;
    }
  }

  .header-bg {
    opacity: 0;
    position: absolute;
    inset: 0 0 auto 0;
    width: 100%;
    height: 100%;
    background: var(--bgColor);
    transition: all 0.4s ease;
    will-change: opacity, box-shadow;
    backface-visibility: hidden;
    transform: translateZ(0);
    z-index: -1;

    &:after {
      content: '';
      opacity: 0;
      position: absolute;
      inset: auto 0 0 0;
      width: 100%;
      height: 1px;
      background: var(--textColor);
      transition: all 0.5s ease;
      z-index: -1;
    }

    .background & {
      opacity: 1;
    }

    .blur & {
      opacity: 1;
      background: var(--bgColor75);
      backdrop-filter: blur(12px);
    }
  }

  &.mega-open {
    .header-bg {
      opacity: 1;
      border-radius: 0 0 20px 20px;

      .blur & {
        background: var(--bgColor);
      }

      .shadow & {
        box-shadow: rgb(0 0 0 / 0.06) 0px 20px 25px -5px, rgb(0 0 0 / 0.02) 0px 10px 10px -5px;
      }
    }
  }

  &.is-header-sticky {
    &.sticky-always {
      position: sticky;
      inset: 0 0 auto 0;
    }

    &.sticky-scroll {
      position: sticky;

      &.is-header-sticky {
        top: 0;
      }
      &.is-header-hidden {
        top: calc(var(--headerHeight) * -1);
      }
    }

    &.border {
      .header-bg:after {
        opacity: 0.12;
      }
    }

    &.shadow {
      .header-bg {
        box-shadow: rgb(0 0 0 / 0.06) 0px 20px 25px -5px, rgb(0 0 0 / 0.02) 0px 10px 10px -5px;
      }
    }
  }

  .header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-inline: auto;
    padding-inline: var(--padding);
    max-width: var(--maxWidth);
    height: var(--headerHeight);
    transition: all 0.3s ease, height 0.2s ease;

    .is-header-sticky & {
      height: calc(var(--headerHeight) * 0.85);

      .logo {
        scale: 0.95;
      }
    }

    .drawer-open {
      margin-inline-start: -0.5lh;
      width: 60px;

      .menu-none & {
        width: 240px;
      }

      @media screen and (max-width: 992px) {
        width: 60px !important;
      }

      a {
        position: relative;
        display: block;
        width: 44px;
        height: 44px;

        &:after {
          content: '';
          position: absolute;
          inset: 0;
          width: 100%;
          height: 100%;
          mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-menu%22%3E%3Cline%20x1%3D%223%22%20y1%3D%2212%22%20x2%3D%2221%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cline%20x1%3D%223%22%20y1%3D%226%22%20x2%3D%2221%22%20y2%3D%226%22%3E%3C%2Fline%3E%3Cline%20x1%3D%223%22%20y1%3D%2218%22%20x2%3D%2221%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
          -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-menu%22%3E%3Cline%20x1%3D%223%22%20y1%3D%2212%22%20x2%3D%2221%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cline%20x1%3D%223%22%20y1%3D%226%22%20x2%3D%2221%22%20y2%3D%226%22%3E%3C%2Fline%3E%3Cline%20x1%3D%223%22%20y1%3D%2218%22%20x2%3D%2221%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
          background-color: currentColor;
          transition: all 0.3s ease;
        }

        @media (hover: hover) {
          &:hover {
            opacity: 0.7;
          }
        }
      }
    }

    .logo {
      display: flex;
      margin-inline-end: auto;
      width: 180px;
      font-size: 2.4rem;
      line-height: 1.3;
      transition: all 0.2s ease;

      .menu-none & {
        flex: 1;
        justify-content: center;
        text-align: center;
      }

      @media screen and (max-width: 992px) {
        flex: 1;
        justify-content: center;
        text-align: center;
      }

      a {
        display: block;

        img {
          width: auto;
          height: var(--headerLogoHeight);

          @media screen and (max-width: 992px) {
            height: calc(var(--headerLogoHeight) * 0.9);
          }
          @media screen and (max-width: 768px) {
            height: var(--headerLogoHeightSp);
          }
        }

        span {
          overflow: hidden;
          display: -webkit-box;
          text-overflow: ellipsis;
          -webkit-box-orient: vertical;
          -webkit-line-clamp: 2;
        }
      }
    }

    .header-menu {
      flex: 1;
      display: flex;
      align-self: stretch;
      justify-content: center;
      font-size: 1.3rem;

      .menu-none & {
        display: none;
      }

      @media screen and (max-width: 992px) {
        display: none;
      }

      & > li {
        display: flex;
        align-items: center;
        padding-inline: 16px;

        & > a {
          position: relative;

          &:before {
            content: '';
            position: absolute;
            inset: auto 0 0 0;
            width: 100%;
            height: 1px;
            background: var(--textColor);
            scale: 0 1;
            transform-origin: right top;
            transition: scale 0.3s ease;
          }

          @media (hover: hover) {
            &[aria-expanded='true']:before,
            &:hover:before {
              scale: 1 1;
              transform-origin: left top;
            }
          }

          .header-category & {
            padding-inline-end: 20px;

            &:after {
              content: '';
              position: absolute;
              inset: 50% -3px auto auto;
              width: 16px;
              height: 16px;
              mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-down%22%3E%3Cpolyline%20points%3D%226%209%2012%2015%2018%209%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 16px;
              -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-down%22%3E%3Cpolyline%20points%3D%226%209%2012%2015%2018%209%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat right center / 16px;
              background-color: var(--textColor);
              translate: 0 -50%;
              transition: all 0.3s ease;
            }

            &[aria-expanded='true']:after {
              rotate: 180deg;
            }
          }
        }

        .dropdown:not(.mega) & {
          position: relative;

          .header-category-dropdown {
            visibility: hidden;
            opacity: 0;
            position: absolute;
            inset: 100% auto auto 50%;
            width: 240px;
            translate: -50% 0;
            transition: all 0.3s ease;

            &[aria-hidden='false'] {
              visibility: visible;
              opacity: 1;
            }

            & > ul {
              padding: 24px;
              width: 100%;
              max-height: 50vh;
              background: var(--bgColor);
              border-radius: 4px;
              box-shadow: rgb(0 0 0 / 0.06) 0px 20px 25px -5px, rgb(0 0 0 / 0.02) 0px 10px 10px -5px;

              & > li {
                opacity: 0;
                translate: 0 10px;
                transition: all 0.3s ease;

                [aria-hidden='false'] & {
                  opacity: 1;
                  translate: 0;
                }
              }

              a {
                display: block;
                padding-block: 2px;
              }

              ul {
                position: relative;
                margin-block: 12px;
                padding-inline-start: 20px;
                font-size: 1.2rem;
                border-inline-start: var(--textColor12) 1px solid;
              }
            }

            .promo-block {
              display: none;
            }
          }
        }

        .mega & {
          .header-category-dropdown {
            visibility: hidden;
            opacity: 0;
            display: flex;
            gap: calc(var(--padding) * 0.8);
            position: absolute;
            inset: 100% 0 auto 0;
            margin-inline: auto;
            padding: calc(var(--padding) * 0.5) var(--padding) var(--padding) var(--padding);
            max-width: var(--maxWidth);
            max-height: calc(100vh - var(--headerGroupHeight) - 20px);
            width: 100%;
            transition: all 0.3s ease;

            &[aria-hidden='false'] {
              visibility: visible;
              opacity: 1;
            }

            & > ul {
              opacity: 0;
              flex: 2;
              display: grid;
              grid-template-columns: repeat(6, 1fr);
              gap: 32px 16px;
              translate: 0 -10px;
              transition: opacity 0.3s ease, translate 0.6s ease;

              [aria-hidden='false'] & {
                opacity: 1;
                translate: 0;
                transition: opacity 0.3s 0.1s ease, translate 0.6s 0.1s ease;
              }

              @media screen and (max-width: 1200px) {
                grid-template-columns: repeat(5, 1fr);
              }

              &:has(+ .promo-block) {
                grid-template-columns: repeat(4, 1fr);

                @media screen and (max-width: 1200px) {
                  grid-template-columns: repeat(3, 1fr);
                }
              }

              a {
                display: block;
                padding-block: 4px;

                @media (hover: hover) {
                  &:hover {
                    opacity: 0.7;
                  }
                }
              }

              & > li > a {
                opacity: 0.5;

                @media (hover: hover) {
                  &:hover {
                    opacity: 1;
                  }
                }
              }

              ul {
                margin: 8px 0 0 0;
                font-size: 1.2rem;
              }
            }

            .promo-block {
              overflow: hidden;
              opacity: 0;
              flex: 1;
              display: flex;
              position: relative;
              color: var(--promoblockTextColor);
              border-radius: var(--imageBorderRadius);
              translate: 0 -10px;
              transition: opacity 0.3s ease, translate 1s ease;

              [aria-hidden='false'] & {
                opacity: 1;
                translate: 0;
                transition: opacity 0.3s 0.2s ease, translate 1s 0.2s ease;
              }

              a {
                display: block;
                color: var(--promoblockTextColor);

                @media (hover: hover) {
                  &:hover,
                  .is-keyboard &:focus-visible {
                    img {
                      scale: 1.05;
                    }
                  }
                }
              }

              img {
                object-fit: cover;
                position: absolute;
                inset: 0;
                width: 100%;
                height: 100%;
                transition: all 0.3s ease;
              }

              .text {
                display: grid;
                place-items: end start;
                position: absolute;
                inset: 0;
                padding: 24px 28px;
                width: 100%;
                height: 100%;

                p {
                  span {
                    opacity: 0.8;
                    color: var(--promoblockTextColor);

                    &:nth-child(1) {
                      opacity: 1;
                      color: var(--promoblockTextColor);
                      font-size: 1.6rem;
                    }
                  }
                }
              }
            }
          }
        }
      }
    }

    .header-btn {
      display: flex;
      justify-content: flex-end;
      gap: 8px;
      margin-inline-end: -0.5lh;
      width: 240px;

      @media screen and (max-width: 992px) {
        width: 60px;

        .search {
          display: none;
        }
      }

      .cart,
      .search {
        position: relative;

        a {
          display: block;
          position: relative;
          width: 44px;
          height: 44px;
          transition: all 0.3s ease;

          &:after {
            content: '';
            position: absolute;
            top: 0;
            right: 0;
            width: 100%;
            height: 100%;
            mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-shopping-bag%22%3E%3Cpath%20d%3D%22M6%202L3%206v14a2%202%200%200%200%202%202h14a2%202%200%200%200%202-2V6l-3-4z%22%3E%3C%2Fpath%3E%3Cline%20x1%3D%223%22%20y1%3D%226%22%20x2%3D%2221%22%20y2%3D%226%22%3E%3C%2Fline%3E%3Cpath%20d%3D%22M16%2010a4%204%200%200%201-8%200%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
            -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-shopping-bag%22%3E%3Cpath%20d%3D%22M6%202L3%206v14a2%202%200%200%200%202%202h14a2%202%200%200%200%202-2V6l-3-4z%22%3E%3C%2Fpath%3E%3Cline%20x1%3D%223%22%20y1%3D%226%22%20x2%3D%2221%22%20y2%3D%226%22%3E%3C%2Fline%3E%3Cpath%20d%3D%22M16%2010a4%204%200%200%201-8%200%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
            background-color: var(--textColor);
            transition: all 0.3s ease;
          }

          .search &:after {
            mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-search%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2216.65%22%20y2%3D%2216.65%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
             -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-search%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%2211%22%20r%3D%228%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2221%22%20y1%3D%2221%22%20x2%3D%2216.65%22%20y2%3D%2216.65%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
          }

          @media (hover: hover) {
            &:hover {
              opacity: 0.7;
            }
          }
        }

        .cart-badge {
          display: block !important;

          .cart-qty {
            position: absolute;
            inset: 3px 1px auto auto;
            width: 18px;
            height: 18px;
            color: var(--bgColor);
            font-size: 10px;
            text-align: center;
            line-height: 18px;
            background: var(--textColor);
            border-radius: 10px;
          }
        }
      }
    }
  }
}

/* mv
------------------------------------------*/
.mv-wrap {
  overflow: hidden;
  opacity: 0;
  position: relative;
  margin: 0 auto var(--margin) auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .mv2 {
    .swiper-slide {
      visibility: hidden;
      display: grid;
      place-items: center;
      padding: var(--padding);
      color: var(--mvTextColor);
      text-align: center;

      &.swiper-slide-active {
        visibility: visible;
      }

      .text {
        .title {
          opacity: 0;
          display: flex;
          flex-direction: column;
          translate: 0 20px;
          transition: all 0.6s ease;

          .swiper-slide-active & {
            opacity: 1;
            translate: 0;
            transition: all 0.6s 1s ease;
          }
        }

        p {
          opacity: 0;
          margin-block-start: 1.5rem;
          white-space: pre-line;
          translate: 0 20px;
          transition: all 0.6s ease;

          .swiper-slide-active & {
            opacity: 0.8;
            translate: 0;
            transition: all 0.6s 1.1s ease;
          }
        }

        .btn-image,
        .btn-arrow {
          opacity: 0;
          margin-inline: auto 0;
          translate: 0 20px;
          transition: all 0.6s ease;

          .swiper-slide-active & {
            opacity: 1;
            translate: 0;
            transition: all 0.6s 1.2s ease;
          }
        }
      }
    }
  }

  @media screen and (min-width: 993px) {
    &.height-s {
      height: 500px;
    }

    &.height-m {
      height: 650px;
    }

    &.height-l {
      height: 800px;
    }

    &.height-full {
      padding: 0;
      max-width: 100%;
      height: calc(100svh - var(--headerGroupHeight));
    }

    &.height-image {
      height: auto;
    }

    &.type-left {
      --mvTextColor: var(--textColor);
    }

    &.type-right {
      --mvTextColor: var(--textColor);
      display: flex;
    }

    .mv {
      height: 100%;

      .type-left & {
        margin: 0 0 0 auto;
        width: 70%;
      }

      .type-right & {
        width: 65%;
      }

      .bg {
        overflow: hidden;
        height: 100%;
        border-radius: var(--imageBorderRadius);

        .height-full & {
          border-radius: 0;

          .type-left & {
            border-radius: var(--imageBorderRadius) 0 0 var(--imageBorderRadius);
          }

          .type-right & {
            border-radius: 0 var(--imageBorderRadius) var(--imageBorderRadius) 0;
          }
        }

        img {
          object-fit: cover;
          height: 100%;
          width: 100%;
          scale: 1.1;
          transition: all 2s ease;

          .height-image & {
            scale: 1;
          }

          .swiper-slide-active & {
            scale: 1;
          }

          &.sp {
            display: none;
          }
        }
      }
    }

    .mv2 {
      .type-center & {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        padding: var(--padding);
      }

      .type-bottom & {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        padding: 0 var(--padding);

        .height-full & {
          padding: 0;
        }

        .swiper-slide {
          place-items: end center;
          padding: var(--padding) var(--padding) 60px var(--padding);

          .text {
            display: flex;
            justify-content: space-between;
            align-items: flex-end;
            width: 100%;

            .left {
              width: calc(100% - 320px);
              text-align: left;
            }

            .btn {
              display: flex;
              justify-content: flex-end;
              width: 280px;
            }
          }
        }
      }

      .type-left & {
        position: absolute;
        inset: 0 auto 0 0;
        width: 50%;
        height: 100%;
        padding: var(--padding);

        .swiper-slide {
          place-items: center start;
          padding: 0;
          color: var(--textColor);
          text-align: left;
        }
      }

      .type-right & {
        width: 35%;

        .swiper-slide {
          place-items: end start;
          padding: var(--padding) 0 calc(var(--padding) * 1.5) var(--padding);
          color: var(--textColor);
          text-align: left;
        }
      }
    }
  }

  @media screen and (max-width: 992px) {
    &.height-sp-s {
      --heightTb: 350px;
      --heightSp: 200px;
    }

    &.height-sp-m {
      --heightTb: 500px;
      --heightSp: 350px;
    }

    &.height-sp-l {
      --heightTb: 650px;
      --heightSp: 500px;
    }

    &.height-sp-full {
      --heightTb: calc(100svh - var(--headerGroupHeight));
      --heightSp: calc(100svh - var(--headerGroupHeight));

      padding: 0;
      max-width: 100%;
    }

    &.height-sp-image {
      --heightTb: auto;
      --heightSp: auto;
    }

    height: var(--heightTb);

    @media screen and (max-width: 768px) {
      height: var(--heightSp);
    }

    &.type-sp-bottom {
      --mvTextColor: var(--textColor);

      height: auto;

      .mv {
        height: var(--heightTb);

        @media screen and (max-width: 768px) {
          height: var(--heightSp);
        }
      }
    }

    .mv {
      height: 100%;

      .bg {
        overflow: hidden;
        height: 100%;
        border-radius: var(--imageBorderRadius);

        .height-sp-full & {
          border-radius: 0;
        }

        img {
          object-fit: cover;
          height: 100%;
          width: 100%;
          scale: 1.1;
          transition: all 2s ease;

          .height-sp-image & {
            scale: 1;
          }

          .swiper-slide-active & {
            scale: 1;
          }

          &.pc {
            display: none;
          }
        }
      }
    }

    .mv2 {
      .type-sp-center & {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        padding: var(--padding);
      }

      .type-sp-center2 & {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        padding: var(--padding);

        .text {
          .left {
            p {
              display: none;
            }
          }
        }
      }

      .type-sp-bottom & {

        .swiper-slide {
          place-items: end start;
          color: var(--textColor);
          padding: var(--padding) 0 calc(var(--padding) * 1.5) 0;
          text-align: left;
        }

        .border-bottom & {
          overflow: visible;
          margin: 0 0 var(--margin) 0;

          &:after {
            content: '';
            position: absolute;
            inset: auto 0 calc(var(--margin) * -1) 0;
            margin: 0 calc(50% - var(--vw) * 50);
            width: calc(var(--vw) * 100);
            height: 1px;
            background: var(--textColor12);
          }
        }
      }
    }
  }

  .swiper-pagination {
    inset: auto 0 10px 0;
    line-height: 1;

    @media screen and (min-width: 993px) {
      .type-left & {
        inset: auto auto -10px calc(var(--padding) - 6px);
        text-align: left;

        .height-full & {
          inset: auto auto calc(var(--padding) - 10px) calc(var(--padding) - 6px);
        }
      }

      .type-right & {
        inset: auto -6px -10px auto;
        text-align: right;

        .height-full & {
          inset: auto 0 1rem auto;
          padding-inline-end: 1rem;
        }
      }
    }

    @media screen and (max-width: 992px) {
      .type-sp-bottom & {
        inset: auto -6px -10px auto;
        text-align: right;
      }
    }

    .swiper-pagination-bullet {
      opacity: 1;
      position: relative;
      margin: 0;
      width: 26px;
      height: 30px;
      background: none;
      border: none;

      &:after {
        content: '';
        position: absolute;
        inset: 50% 0 0 50%;
        width: 10px;
        height: 10px;
        background: var(--mvTextColor);
        border: var(--mvTextColor) 1.5px solid;
        border-radius: 50%;
        translate: -50% -50%;
        scale: 0.6;
        transition: all 0.3s ease;
      }

      &.swiper-pagination-bullet-active {
        &:after {
          background: none;
          border: var(--mvTextColor) 1.5px solid;
          scale: 1;
        }
      }
    }
  }
}

/* footer
------------------------------------------*/
.footer {
  opacity: 0;
  font-size: 1.2rem;
  transition: opacity 0.6s ease;

  .loaded & {
    opacity: 1;
  }

  .footer-top {
    color: var(--footerTextColor);
    background: var(--footerBgColor);

    .footer-top-inner {
      display: flex;
      gap: var(--padding);
      margin-inline: auto;
      padding: var(--margin) var(--padding);
      max-width: var(--maxWidth);

      .about {
        width: 60%;

        .logo {
          display: flex;
          margin-block-end: 2.5rem;
          font-size: 2.0rem;
          line-height: 1.3;

          a {

            span {
              color: var(--footerTextColor) !important;
            }

            img {
              width: auto;
              height: var(--headerLogoHeight);

              .logo.white & {
                filter: brightness(0) invert(1);
              }

              @media screen and (max-width: 992px) {
                height: calc(var(--headerLogoHeight) * 0.9);
              }
              @media screen and (max-width: 768px) {
                height: var(--headerLogoHeightSp);
              }
            }
          }
        }

        .text {
          white-space: pre-line;
        }
      }

      .menu,
      .mailmagazine {
        width: 20%;

        .title {
          margin-block: 4rem 1.5rem;
          font-weight: var(--bodyFontWeightBold);

          &:first-child {
            margin-block-start: 0;
          }
        }

        ul {
          li {
            a,
            span {
              display: inline-flex;
              padding-block: 3px;
              color: var(--footerTextColor);
            }
          }

          .mailmagazine &,
          ul {
            position: relative;
            margin-block: 12px;
            padding-inline-start: 20px;
            font-size: 1.2rem;
            border-inline-start: var(--footerTextColor12) 1px solid;

            a {
              padding-block: 4px;
            }
          }
        }

        .mailmagazine-form {
          border-radius: 100px;

          &:has(.x_mailMagazineSubscribe_confirm:empty) {
            border: var(--footerTextColor) 1px solid;
          }

          .x_mailMagazineSubscribe_field {
            display: flex;

            input.x_mailMagazineSubscribe_input {
              margin: 0 !important;
              padding: 10px 0 10px 14px !important;
              width: calc(100% - 50px) !important;
              color: var(--footerTextColor) !important;
              font-size: 1.2rem !important;
              background: none !important;
              border: none !important;
              border-radius: 0 !important;

              &::placeholder {
                color: var(--footerTextColor) !important;
              }
            }

            button {
              display: block;
              position: relative;
              margin: 0 0 0 auto;
              padding: 12px;
              width: 50px;
              height: auto;
              color: var(--footerTextColor);
              font-size: 0;
              transition: all 0.3s ease;

              &:after {
                content: '';
                position: absolute;
                top: 0;
                right: 0;
                width: 100%;
                height: 100%;
                mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2071.42%2057.95%22%3E%3Cg%3E%3Cpolygon%20points%3D%220%2023.41%2017.09%2035.81%2063.63%206.21%2021.23%2038.8%2046.83%2057.36%2071.42%200%200%2023.41%22%2F%3E%3Cpolygon%20points%3D%2216.98%2057.95%2029.47%2048.3%2016.82%2039.61%2016.98%2057.95%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
                -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2071.42%2057.95%22%3E%3Cg%3E%3Cpolygon%20points%3D%220%2023.41%2017.09%2035.81%2063.63%206.21%2021.23%2038.8%2046.83%2057.36%2071.42%200%200%2023.41%22%2F%3E%3Cpolygon%20points%3D%2216.98%2057.95%2029.47%2048.3%2016.82%2039.61%2016.98%2057.95%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
                background-color: var(--footerTextColor);
              }
            }
          }
        }
      }

      @media screen and (max-width: 768px) {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: var(--margin);

        .about {
          width: 100%;
        }

        .menu,
        .mailmagazine {
          width: 100%;

          .title:not(:first-child) {
            margin-block-start: var(--margin);
          }
        }
      }

      .type-2 & {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        max-width: 900px;
        gap: 0;

        .about {
          width: 100%;
          text-align: center;

          .logo {
            justify-content: center;
          }

          &:not(:has(.text)) {
            .logo {
              margin: 0;
            }
          }
        }

        .menu {
          display: none;
        }

        .mailmagazine {
          width: 100%;

          .title {
            margin-block-start: var(--margin);
            font-size: 1.6rem;
            text-align: center;

            &:not(:first-child) {
              display: none;
            }
          }

          ul {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
            gap: 0 12px;
            margin: 3rem 0 0 0;
            padding: 0;
            font-size: 1rem;
            border: none;

            &:before {
              display: none;
            }
          }
        }
      }
    }
  }

  .footer-bottom {
    position: relative;

    .footer-bottom-inner {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: var(--padding);
      margin-inline: auto;
      padding: min(var(--padding), 20px) var(--padding);
      max-width: var(--maxWidth);

      @media screen and (max-width: 768px) {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: calc(var(--padding) * 0.7);
        padding: var(--margin) var(--padding);
      }

      .copyright {
        display: flex;
        align-items: center;
        font-size: 1.1rem;
      }

      .footer-sns {
        display: flex;
        align-items: center;
        gap: 12px;

        a {
          display: block;

          @media (hover: hover) {
            &:hover {
              opacity: 0.7;
            }
          }

          .twitter & {
            background: #000;
            border-radius: 3px;
          }

          img {
            width: 18px;
            height: 18px;

            .twitter & {
              padding: 3px;
              filter: brightness(0) invert(1);
            }
          }
        }

        .cart {
          display: none;
        }
      }
    }
  }
}

.msg_startButton {
  opacity: 0;
  visibility: hidden;
  bottom: 20px !important;
  right: 20px !important;
  width: 52px !important;
  height: 52px !important;
  border-radius: 100px !important;
  box-shadow: rgb(0 0 0 / 0.12) 0px 20px 25px -5px, rgb(0 0 0 / 0.04) 0px 10px 10px -5px !important;
  transform: translateY(20px);
  transition: all 0.6s ease !important;
}
.is-scrolled .msg_startButton {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: all 0.6s 0.2s ease !important;
}
.is-bottom .msg_startButton {
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
}
.msg_startButton:before {
  content: '';
  position: absolute;
  top: 1px;
  left: 0;
  width: 100%;
  height: calc(100% - 1px);
  mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-message-circle%22%3E%3Cpath%20d%3D%22M21%2011.5a8.38%208.38%200%200%201-.9%203.8%208.5%208.5%200%200%201-7.6%204.7%208.38%208.38%200%200%201-3.8-.9L3%2021l1.9-5.7a8.38%208.38%200%200%201-.9-3.8%208.5%208.5%200%200%201%204.7-7.6%208.38%208.38%200%200%201%203.8-.9h.5a8.48%208.48%200%200%201%208%208v.5z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
  -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-message-circle%22%3E%3Cpath%20d%3D%22M21%2011.5a8.38%208.38%200%200%201-.9%203.8%208.5%208.5%200%200%201-7.6%204.7%208.38%208.38%200%200%201-3.8-.9L3%2021l1.9-5.7a8.38%208.38%200%200%201-.9-3.8%208.5%208.5%200%200%201%204.7-7.6%208.38%208.38%200%200%201%203.8-.9h.5a8.48%208.48%200%200%201%208%208v.5z%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
  background: #fff;
}
.msg_startButton .msg_startButton__icon {
  display: none !important;
}
.msg_messenger {
  border-radius: 4px !important;
  box-shadow: rgb(0 0 0 / 0.12) 0px 20px 25px -5px, rgb(0 0 0 / 0.04) 0px 10px 10px -5px !important;

  .msg_postBox__control__submit {
    border-radius: 4px !important;
  }

  .msg_messenger__closeBtn {
    position: relative;

    .appsicon-cross {
      &:before {
        display: none !important;
      }
      &:after {
        content: '';
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
        -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-x%22%3E%3Cline%20x1%3D%2218%22%20y1%3D%226%22%20x2%3D%226%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3Cline%20x1%3D%226%22%20y1%3D%226%22%20x2%3D%2218%22%20y2%3D%2218%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 24px;
        background-color: #fff;
      }
    }
  }
}
@media screen and (max-width: 768px) {
  .msg_startButton {
    left: auto !important;
    bottom: 12px !important;
    right: 12px !important;
    width: 48px !important;
    height: 48px !important;
  }
  .msg_startButton .msg_startButton__text {
    display: none !important;
  }
}

/* index
------------------------------------------*/
.not-shop-pablic {
  margin: 0 0 var(--margin) 0;
  padding: 200px 0;
  width: 100%;
  text-align: center;
}

/* home */
.home .main {
  display: flex;
  flex-direction: column;
}
.home .main > * {
  order: 100;
  width: 100%;
}
.home .main .bm0:last-child {
  margin-bottom: 0;
}
/*.home .main .bm0 + .bm0 {
  margin-top: calc(var(--margin) * -1);
}*/

.sec-title {
  opacity: 0;
  position: relative;
  margin-block-end: min(calc(2.5rem * var(--sectionSpacing)), 3rem);
  transition: all 0.6s ease;

  .viewed & {
    opacity: 1;
  }

  .head-type-center & {
    text-align: center;
    text-indent: var(--headLetterSpacing);
  }

  h2 {
    span {
      &:not(:first-child) {
        display: block;
        font-size: 1.3rem;
        font-weight: var(--bodyFontWeightNormal);
      }

      &:nth-child(2) {
        margin: 4px 0 0 0;
      }
    }
  }
}

.split-text {
  span {
    opacity: 0.75;
    display: block;
    font-size: 1.1rem;

    &:nth-child(1) {
      opacity: 1;
      color: var(--textColor);
      font-size: 1.5rem;
    }

    &:nth-child(2) {
      margin: 1rem 0 0 0;
    }

    &:empty {
      height: 1em;
    }
  }
}

/* banner */
.banner-wrap {
  --bannerPaginationLength: 0;
  --bannerPaginationActive: 1;

  opacity: 0;
  position: relative;
  margin: 0 auto var(--margin) auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .banner {
    overflow: visible;

    .swiper-slide {
      text-align: center;

      img {
        margin: 0 auto;
        max-width: 100%;
        width: var(--bannerWidth);

        .swiper-slide:has(p) & {
          margin: 0 auto 1.8rem auto;
        }
      }

      a {
        display: block;

        @media (hover: hover) {
          &:hover {
            opacity: 0.7;
          }
        }
      }
    }
  }

  .swiper-pagination {
    position: relative;
    inset: auto;
    margin: calc(var(--margin) * 0.8) auto 0 auto;
    width: calc(50px * var(--bannerPaginationLength));
    height: 1px;
    line-height: 1;

    &:before {
      content: '';
      opacity: 0.12;
      position: absolute;
      inset: 0 0 auto 0;
      width: 100%;
      height: 1px;
      background: var(--textColor);
    }

    &:after {
      content: '';
      opacity: 1;
      position: absolute;
      inset: 0 0 auto calc(50px * (var(--bannerPaginationActive) - 1));
      width: 50px;
      height: 1px;
      background: var(--textColor);
      transition: all 0.4s cubic-bezier(0.79,0.14,0.15,0.86);;
    }

    .swiper-pagination-bullet {
      display: none;
    }
  }
}

/* categoryslide */
.categoryslide {
  opacity: 0;
  margin: 0 auto var(--margin) auto;
  padding-inline: var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .btn-arrow {
    .head-type-center & {
      text-align: center;
    }
  }

  .title-area {
    position: relative;

    .btn-arrow {
      position: absolute;
      inset: auto 0 0 auto;
      margin-block-start: 0;
    }
  }

  .slideitem-slide {

  }
}

/* looptext */
.looptext {
  opacity: 0;
  overflow: hidden;
  margin: 0 0 var(--margin) 0;
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  ul {
    overflow: hidden;
    display: flex;
    gap: 50px;

    li {
      display: flex;
      gap: var(--padding);
      flex-shrink: 0;
      white-space: nowrap;
      transform: translate3d(0, 0, 0);

      &:nth-child(odd) {
        animation: looptext var(--looptextDuration) calc((var(--looptextDuration) / 2 ) * -1) linear infinite;
      }
      &:nth-child(even) {
        animation: looptext2 var(--looptextDuration) linear infinite;
      }

      &:has(a:hover) {
        animation-play-state: paused;
      }

      p {
        display: flex;
        gap: max(calc(var(--padding) * 0.5), 20px);

        a {
          transition: all 0.1s ease;

          @media (hover: hover) {
            &:hover {
              scale: 1.05;
            }
          }
        }

        &:nth-child(even) {
          opacity: 0.5;
        }
      }
    }
  }
}

@keyframes looptext {
  from { transform: translateX(100%); }
  to { transform: translateX(-100%); }
}
@keyframes looptext2 {
  from { transform: translateX(0); }
  to { transform: translateX(-200%); }
}

/* fixblog */
.fixblog {
  opacity: 0;
  margin: 0 auto var(--margin) auto;
  padding-inline: var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .fixblog-inner {
    padding: 12px 22px;
    text-align: center;
    background: var(--subBgColor);
    border-radius: 4px;

    a {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 8px;
      position: relative;

      &:before {
        content: '';
        width: 20px;
        min-width: 20px;
        height: 20px;
        mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.8%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-info%22%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%2210%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2212%22%20y1%3D%2216%22%20x2%3D%2212%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cline%20x1%3D%2212%22%20y1%3D%228%22%20x2%3D%2212.01%22%20y2%3D%228%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
        -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.8%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-info%22%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%2210%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2212%22%20y1%3D%2216%22%20x2%3D%2212%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cline%20x1%3D%2212%22%20y1%3D%228%22%20x2%3D%2212.01%22%20y2%3D%228%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
        background-color: var(--textColor);
      }
    }
  }
}

/* concept */
.concept {
  opacity: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--imageGapHor);
  margin: 0 auto var(--margin) auto;
  padding-inline: var(--padding);
  max-width: var(--maxWidth);
  min-height: 50vh;
  transition: opacity 0.6s ease;

  &:has(> :nth-child(2):last-child) {
    grid-template-columns: repeat(2, 1fr);
  }

  &.viewed {
    opacity: 1;
  }

  .image {
    position: relative;

    img {
      object-fit: cover;
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      border-radius: var(--imageBorderRadius);
    }
  }

  .text {
    order: -1;
    display: flex;
    flex-direction: column;
    padding: 0 calc(var(--padding) - var(--imageGapHor)) 0 0;

    .title {
      margin: 0 0 3rem 0;
      font-size: 1.4rem;

      span {
        display: block;
      }
    }

    h3 {
      margin-block-start: auto;
      white-space: pre-line;
    }

    p {
      opacity: 0.8;
      margin-block-start: 1.5rem;
      white-space: pre-line;
    }
  }

  @media screen and (max-width: 992px) {
    grid-template-columns: repeat(2, 1fr);
    height: auto;

    &:has(> :nth-child(2):last-child) {
      grid-template-columns: repeat(1, 1fr);
    }

    .image {
      height: 35vw;
    }

    .text {
      order: 1;
      grid-column: 1 / -1;
      padding: var(--padding) 0 0 0;

      .title {
        margin: 0 0 var(--padding) 0;
      }
    }
  }
}

/* bgimage */
.bgimage {
  overflow: hidden;
  opacity: 0;
  position: relative;
  margin-block-end: var(--margin);
  padding: var(--padding);
  height: 50vh;
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;

    img {
      object-fit: cover;
      width: 100%;
      height: 100%;
    }
  }

  .text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: absolute;
    inset: 0;
    padding: var(--padding);
    color: var(--bgimage01TextColor);
    text-align: center;

    .bgimage02 & {
      color: var(--bgimage02TextColor);
    }

    .title {
      opacity: 0;
      display: flex;
      flex-direction: column;
      text-indent: var(--headLetterSpacing);
      translate: 0 20px;

      .viewed & {
        opacity: 1;
        translate: 0;
        transition: all 0.6s ease;
      }
    }

    p {
      opacity: 0;
      margin-block-start: 1.5rem;
      white-space: pre-line;
      translate: 0 20px;

      .viewed & {
        opacity: 0.8;
        translate: 0;
        transition: all 0.6s 0.1s ease;
      }
    }

    .btn-image {
      opacity: 0;
      translate: 0 20px;

      .viewed & {
        opacity: 1;
        translate: 0;
        transition: all 0.6s 0.2s ease;
      }
    }
  }
}

/* topinfo */
.topinfo {
  opacity: 0;
  position: relative;
  margin: 0 auto var(--margin) auto;
  background: var(--subBgColor);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .topinfo-inner {
    margin-inline: auto;
    padding: var(--margin) var(--padding);
    max-width: var(--maxWidth);
    text-align: center;
    text-indent: var(--headLetterSpacing);

    h2 {
      margin-block-end: calc(2.5rem * var(--sectionSpacing));

      span {
        &:not(:first-child) {
          display: block;
          font-size: 1.3rem;
        }

        &:nth-child(2) {
          margin: 0.5rem 0 0 0;
        }
      }
    }

    p {
      opacity: 0.8;
      white-space: pre-line;
    }
  }
}

/* pickup */
.pickup {
  opacity: 0;
  margin: 0 auto var(--margin) auto;
  padding-inline: var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .pickup-content {
    display: flex;
    gap: var(--padding);

    @media screen and (max-width: 768px) {
      flex-direction: column;
    }
  
    .pickup-slide {
      width: 70%;

      .image {
        overflow: hidden;
        position: absolute;
        inset: 0;
        border-radius: var(--imageBorderRadius);

        img {
          object-fit: cover;
          width: 100%;
          height: 100%;
          scale: 1.1;
          transition: all 2s ease;

          .swiper-slide-active & {
            scale: 1;
          }
        }
      }

      @media screen and (max-width: 768px) {
        width: 100%;
        height: 300px;
      }
    }

    .pickup-items {
      padding: 0 0 calc(var(--padding) * 2) 0;
      width: 30%;

      .swiper-slide-inner {
        opacity: 0;
        position: relative;
        translate: 2rem 0;
        transition: all 0.6s ease;

        .swiper-slide-active & {
          opacity: 1;
          translate: 0 0;
        }

        .image {
          position: relative;
          margin: 0 auto;

          .num {
            display: none;
            place-items: center;
            position: absolute;
            inset: 6px 6px auto auto;
            width: 38px;
            height: 38px;
            color: var(--bgColor);
            font-size: 1.2rem;
            background: var(--textColor);
            border-radius: 4px;
            z-index: 1;

            .ranking & {
              display: grid;
            }
          }

          a {
            overflow: hidden;
            display: block;
            border-radius: var(--imageBorderRadius);

            img {
              aspect-ratio: var(--itemListImageAspect);
              object-fit: cover;
              width: 100%;
              height: 100%;
              transition: all 0.3s ease;
            }

            @media (hover: hover) {
              &:hover {
                img {
                  scale: 1.05;
                }
              }
            }
          }
        }

        .text {
          p {
            margin: 2.5rem 0 0 0;
            font-size: 1.8rem;

            span {
              &:nth-child(1) {
                font-size: 1.8rem;
              }
            }
          }
        }
      }

      @media screen and (max-width: 768px) {
        padding: 0 0 calc(var(--padding) * 1.5 + 4px) 0;
        width: 100%;

        .swiper-slide-inner {
          display: flex;
          align-items: center;
          gap: 12px;

          .image {
            margin: 0;
            width: 150px;

            .num {
              inset: 3px auto auto 3px;
              width: 24px;
              height: 24px;
              font-size: 1rem;
            }
          }

          .text {
            width: calc(100% - 20px);

            p {
              margin: 0;
            }
          }
        }
      }
    }

    .swiper-pagination {
      inset: auto -6px -10px auto;
      line-height: 1;
      text-align: right;

      @media screen and (max-width: 768px) {
        inset: auto auto -10px auto;
        text-align: center;
      }

      .swiper-pagination-bullet {
        opacity: 1;
        position: relative;
        margin: 0;
        width: 26px;
        height: 30px;
        background: none;
        border: none;

        &:after {
          content: '';
          position: absolute;
          inset: 50% 0 0 50%;
          width: 10px;
          height: 10px;
          background: var(--textColor);
          border: var(--textColor) 1.5px solid;
          border-radius: 50%;
          translate: -50% -50%;
          scale: 0.6;
          transition: all 0.3s ease;
        }

        &.swiper-pagination-bullet-active {
          &:after {
            background: none;
            border: var(--textColor) 1.5px solid;
            scale: 1;
          }
        }
      }
    }
  }
}

/* bgyoutube */
.bgyoutube {
  overflow: hidden;
  opacity: 0;
  position: relative;
  margin-block-end: var(--margin);
  padding: var(--padding);
  height: 50vh;
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: absolute;
    inset: 0;
    padding: var(--padding);
    color: var(--bgyoutubeTextColor);
    text-align: center;

    .title {
      opacity: 0;
      display: flex;
      flex-direction: column;
      text-indent: var(--headLetterSpacing);
      translate: 0 20px;

      .viewed & {
        opacity: 1;
        translate: 0;
        transition: all 0.6s ease;
      }
    }

    p {
      opacity: 0;
      margin-block-start: 1.5rem;
      white-space: pre-line;
      translate: 0 20px;

      .viewed & {
        opacity: 0.8;
        translate: 0;
        transition: all 0.6s 0.1s ease;
      }
    }

    .btn-image {
      opacity: 0;
      translate: 0 20px;

      .viewed & {
        opacity: 1;
        translate: 0;
        transition: all 0.6s 0.2s ease;
      }
    }
  }
}

/* slideitem */
.slideitem-wrap {
  opacity: 0;
  margin: var(--margin) 0 0 0;
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .home & {
    margin: 0 auto var(--margin) auto;
    padding: 0 var(--padding);
    max-width: var(--maxWidth);
  }

  .slideitem-slide {
    position: relative;
    max-width: 100%;

    @media screen and (max-width: 992px) {
      .swiper {
        overflow: visible;
      }
    }
  }

  .swiper-button-prev,
  .swiper-button-next {
    inset: 50% auto auto calc(var(--padding) * -1);
    width: var(--padding);
    height: var(--padding);
    color: var(--textColor);
    transition: all 0.2s ease;

    &:after {
      content: '';
      position: absolute;
      inset: 50% auto auto 50%;
      width: 36px;
      height: 36px;
      mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.0%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-left%22%3E%3Cpolyline%20points%3D%2215%2018%209%2012%2015%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
      -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.0%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-left%22%3E%3Cpolyline%20points%3D%2215%2018%209%2012%2015%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
      background-color: var(--textColor);
      translate: -50% -50%;
      transition: all 0.2s ease;
    }

    &.swiper-button-next {
      inset: 50% calc(var(--padding) * -1) auto auto;

      &:after {
        mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.0%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
        -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.0%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
        background-color: var(--textColor);
      }
    }

    @media (hover: hover) {
      &:hover {
        &:after {
          scale: 1.2;
        }
      }
    }

    @media screen and (max-width: 992px) {
      display: none;
    }
  }
}

/* instagram */
.instagram {
  opacity: 0;
  margin: 0 auto var(--margin) auto;
  padding-inline: var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .btn-arrow {
    .head-type-center & {
      text-align: center;
    }
  }

  .title-area {
    position: relative;

    .btn-arrow {
      position: absolute;
      inset: auto 0 0 auto;
      margin-block-start: 0;
    }
  }

  .instagram-content {
    width: 100%;
  }
}

.newblog {
  opacity: 0;
  margin: 0 auto var(--margin) auto;
  padding-inline: var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  .btn-arrow {
    .head-type-center & {
      text-align: center;
    }
  }

  .title-area {
    position: relative;

    .btn-arrow {
      position: absolute;
      inset: auto 0 0 auto;
      margin-block-start: 0;
    }
  }

  .newblog-content {
    width: 100%;

    .newblog-list {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: var(--imageGapVer) var(--imageGapHor);

      @media screen and (max-width: 992px) {
        grid-template-columns: repeat(2, 1fr);
      }

      .newblog-list-item {
        background: var(--newblogItemBgColor);

        .image {
          overflow: hidden;
          margin: 0 0 15px 0;
          border-radius: var(--imageBorderRadius);

          a {
            display: block;

            img {
              aspect-ratio: var(--newblogImageAspect);
              object-fit: cover;
              width: 100%;
              height: 100%;
              transition: all 0.3s ease;
            }

            @media (hover: hover) {
              &:hover {
                img {
                  scale: 1.05;
                }
              }
            }
          }
        }

        .date {
          color: var(--subTextColor);
          font-size: 1.2rem;
        }

        p {
          display: none;
        }
      }

      .blog-type-2 & {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--imageGapHor);

        @media screen and (max-width: 768px) {
          grid-template-columns: repeat(1, 1fr);
        }

        .newblog-list-item {
          display: flex;
          justify-content: space-between;
          align-items: center;

          .image {
            margin: 0;
            width: 120px;
          }

          .text {
            width: calc(100% - 140px);

            .title {
              overflow: hidden;
              display: -webkit-box;
              -webkit-box-orient: vertical;
              -webkit-line-clamp: 2;
            }

            .date {
              margin: 5px 0 0 0;
            }

            p {
              overflow: hidden;
              display: -webkit-box;
              -webkit-box-orient: vertical;
              -webkit-line-clamp: 2;
              margin: 12px 0 0 0;
              font-size: 1.2rem;
            }
          }
        }
      }

      .blog-type-3 & {
        grid-template-columns: repeat(1, 1fr);
        gap: 1.5rem;
        padding: var(--padding);
        background: var(--subBgColor);
        border-radius: var(--imageBorderRadius);

        .newblog-list-item {
          display: flex;

          .image {
            display: none;
          }

          .text {
            display: flex;
            flex-direction: row-reverse;
            align-items: center;
            gap: 30px;
            font-size: 1.2rem;

            @media screen and (max-width: 768px) {
              flex-direction: column-reverse;
              align-items: flex-start;
              gap: 4px;
            }

            a {
              @media (hover: hover) {
                &:hover {
                  opacity: 0.7;
                }
              }
            }
          }
        }
      }
    }
  }
}

/* tguide */
.tguide {
  opacity: 0;
  margin: 0 auto var(--margin) auto;
  padding-inline: var(--padding);
  max-width: var(--maxWidth);
  transition: opacity 0.6s ease;

  &.viewed {
    opacity: 1;
  }

  ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;

    @media screen and (max-width: 768px) {
      grid-template-columns: repeat(2, 1fr);
      gap: 6px;
    }

    li {
      height: 100%;

      a {
        display: block;
        position: relative;
        padding: 16px 22px;
        height: 100%;
        font-size: 1.2rem;
        line-height: 1.3;
        border: var(--textColor12) 1px solid;
        border-radius: 4px;

        @media screen and (max-width: 600px) {
          padding: 12px;
          text-align: center;
        }

        &:before {
          content: '';
          position: absolute;
          inset: 50% 6px auto auto;
          width: 20px;
          height: 20px;
          mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
          -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
          background-color: var(--textColor);
          translate: 0 -50%;
          transition: all 0.2s ease;

          @media screen and (max-width: 600px) {
            display: none;
          }
        }

        @media (hover: hover) {
          &:hover {
            opacity: 0.7;

            &:before {
              inset: 50% 2px auto auto;
            }
          }
        }
      }
    }
  }
}

.item-list-area {
  .home & {
    opacity: 0;
    margin: 0 auto var(--margin) auto;
    padding: 0 var(--padding);
    max-width: var(--maxWidth);
    transition: opacity 0.6s ease;

    &.viewed {
      opacity: 1;
    }

    &.hide {
      display: none;
    }
  }
}

.item-list-child-category,
.saerch-result {
  opacity: 0;
  margin: calc(var(--margin) * 0.6 * -1) 0 var(--margin) 0;
  transition: all 0.6s ease;

  .viewed & {
    opacity: 1;
  }

  ul {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;

    @media screen and (max-width: 992px) {
      justify-content: center;
    }

    li {
      a {
        display: block;
        padding: 5px 10px;
        font-size: 1.1rem;
        background: var(--subBgColor);
        border-radius: 2px;

        @media (hover: hover) {
          &:hover {
            opacity: 0.7;
          }
        }
      }
    }
  }
}

.item-list-wrap {
  opacity: 0;
  margin: 0 0 0 auto;
  max-width: 100%;
  transition: all 0.6s ease;

  .viewed & {
    opacity: 1;
  }

  .item-list {
    display: grid;
    grid-template-columns: repeat(var(--itemNum), 1fr);
    gap: var(--imageGapVer) var(--imageGapHor);
  }
}

.item-list-item {
  position: relative;

  .label_image {
    position: absolute;
    inset: 0 auto auto 0;
    width: 50px;
    z-index: 2;
  }

  .image {
    position: relative;
    margin: 0 0 1.2rem 0;

    .rate-area {
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      gap: 3px;
      position: absolute;
      inset: 6px 6px auto auto;
      z-index: 1;

      div {
        padding: 5px 6px;
        color: #fff;
        font-size: 1rem;
        line-height: 1;
        background: var(--noticeColor);
        border-radius: 2px;
      }
    }

    a {
      overflow: hidden;
      display: block;
      border-radius: var(--imageBorderRadius);

      img {
        aspect-ratio: var(--itemListImageAspect);
        object-fit: cover;
        width: 100%;
        height: 100%;
        transition: all 0.3s ease;
      }

      @media (hover: hover) {
        &:hover,
        .is-keyboard &:focus-visible {
          img {
            scale: 1.05;
          }
        }
      }
    }
  }

  .text {
    margin: 1.2em 0 0 0;
    text-align: var(--itemListTextAlign);
    line-height: 1.5;

    .name {
      margin: 0 0 4px 0;
    }

    .tags {
      display: flex;
      flex-wrap: wrap;
      justify-content: var(--itemListTextAlign);
      gap: 5px;

      &:has(*) {
        margin: 1em 0 0 0;
      }

      div {
        padding: 5px 6px;
        font-size: 1rem;
        text-align: center;
        line-height: 1;
        border: var(--textColor) 1px solid;
        border-radius: 2px;
      }
    }
  }
}

.item-list-more {
  display: none;
  margin: min(3rem, var(--margin)) auto 0 auto;

  &.show {
    display: block;
  }
}

.item-list-loading {
  display: none;
  justify-content: center;
  gap: 6px;
  position: relative;
  margin: 0 auto;
  padding: 60px 0;
  width: 36px;
  height: 36px;

  &.show {
    display: block;
  }

  &:after {
    content: '';
    opacity: 0.3;
    position: absolute;
    inset: 50% auto auto 50%;
    width: 36px;
    height: 36px;
    mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cstyle%3E.spinner_z9k8%7Btransform-origin%3Acenter%3Banimation%3Aspinner_StKS%20.75s%20infinite%20linear%7D%40keyframes%20spinner_StKS%7B100%25%7Btransform%3Arotate(360deg)%7D%7D%3C%2Fstyle%3E%3Cpath%20d%3D%22M12%2C1A11%2C11%2C0%2C1%2C0%2C23%2C12%2C11%2C11%2C0%2C0%2C0%2C12%2C1Zm0%2C19a8%2C8%2C0%2C1%2C1%2C8-8A8%2C8%2C0%2C0%2C1%2C12%2C20Z%22%20opacity%3D%22.25%22%2F%3E%3Cpath%20d%3D%22M12%2C4a8%2C8%2C0%2C0%2C1%2C7.89%2C6.7A1.53%2C1.53%2C0%2C0%2C0%2C21.38%2C12h0a1.5%2C1.5%2C0%2C0%2C0%2C1.48-1.75%2C11%2C11%2C0%2C0%2C0-21.72%2C0A1.5%2C1.5%2C0%2C0%2C0%2C2.62%2C12h0a1.53%2C1.53%2C0%2C0%2C0%2C1.49-1.3A8%2C8%2C0%2C0%2C1%2C12%2C4Z%22%20class%3D%22spinner_z9k8%22%2F%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
    -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cstyle%3E.spinner_z9k8%7Btransform-origin%3Acenter%3Banimation%3Aspinner_StKS%20.75s%20infinite%20linear%7D%40keyframes%20spinner_StKS%7B100%25%7Btransform%3Arotate(360deg)%7D%7D%3C%2Fstyle%3E%3Cpath%20d%3D%22M12%2C1A11%2C11%2C0%2C1%2C0%2C23%2C12%2C11%2C11%2C0%2C0%2C0%2C12%2C1Zm0%2C19a8%2C8%2C0%2C1%2C1%2C8-8A8%2C8%2C0%2C0%2C1%2C12%2C20Z%22%20opacity%3D%22.25%22%2F%3E%3Cpath%20d%3D%22M12%2C4a8%2C8%2C0%2C0%2C1%2C7.89%2C6.7A1.53%2C1.53%2C0%2C0%2C0%2C21.38%2C12h0a1.5%2C1.5%2C0%2C0%2C0%2C1.48-1.75%2C11%2C11%2C0%2C0%2C0-21.72%2C0A1.5%2C1.5%2C0%2C0%2C0%2C2.62%2C12h0a1.53%2C1.53%2C0%2C0%2C0%2C1.49-1.3A8%2C8%2C0%2C0%2C1%2C12%2C4Z%22%20class%3D%22spinner_z9k8%22%2F%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
    background-color: var(--textColor);
    translate: -50% -50%;
  }
}

/* item
------------------------------------------*/
.item {
  display: flex;
  gap: var(--padding);
  padding-block-start: calc(var(--padding) / 2);

  @media screen and (max-width: 992px) {
    flex-direction: column;
    gap: 0;
    padding-block-start: 0;
  }

  .item-image {
    opacity: 0;
    overflow: clip;
    position: relative;
    width: calc(60% - (var(--padding) / 2));
    transition: opacity 0.6s ease, translate 0.6s ease;

    .viewed & {
      opacity: 1;
    }

    @media screen and (max-width: 992px) {
      margin: 0 0 var(--margin) 0;
      width: 100%;
    }

    @media screen and (max-width: 768px) {
      margin: 0 calc(50% - var(--vw) * 50);
      padding: 0 0 var(--margin) 0;
      width: calc(var(--vw) * 100);

      .item.type-row1 &,
      .item.type-row2 & {
        margin: 0;
        padding: 0 0 var(--margin) 0;
        width: 100%;
      }
    }

    .item-image-inner {
      position: sticky;
      top: var(--padding);

      .header.sticky-always + .content-wrap & {
        top: calc(var(--headerHeight) + 4px);
      }

      .label_image {
        position: absolute;
        inset: 0 auto auto 0;
        width: 50px;
        z-index: 2;
      }

      .item.type-slide & {
        .item-image-list {
          margin: 0 0 10px 0;
          border-radius: var(--imageBorderRadius);

          @media screen and (max-width: 768px) {
            overflow: visible;
            margin: 0;
          }
        }

        .item-image-thumbnail {
          display: grid;
          grid-template-columns: repeat(8, 1fr);
          gap: 5px;

          @media screen and (max-width: 992px) {
            grid-template-columns: repeat(12, 1fr);
          }

          @media screen and (max-width: 768px) {
            display: none;
          }

          div {
            cursor: pointer;
            overflow: hidden;
            position: relative;
            border-radius: var(--imageBorderRadius);

            img {
              object-fit: contain;
              width: 100%;
              height: 100%;
            }

            &:before {
              content: '';
              opacity: 0;
              position: absolute;
              inset: 0;
              width: 100%;
              height: 100%;
              border-radius: var(--imageBorderRadius);
              box-shadow: inset 0 0 0 1px var(--textColor30);
              transition: all 0.3s ease;
            }

            &.active {
              &:before {
                opacity: 1;
              }
            }
          }
        }

        .swiper-pagination {
          display: none;

          @media screen and (max-width: 768px) {
            display: flex;
            justify-content: center;
            position: relative;
            inset: 0;
            margin: 2rem 0 0 0;
            height: 4px;
            line-height: 1;

            .swiper-pagination-bullet {
              opacity: 0.2;
              width: 4px;
              height: 4px;
              background: var(--textColor);

              &.swiper-pagination-bullet-active {
                opacity: 0.8;
                background: var(--textColor);
              }
            }
          }
        }
      }

      .item.type-row1 &,
      .item.type-row2 & {
        border-radius: 0;

        .swiper-wrapper {
          display: grid;
          grid-template-columns: repeat(1, 1fr);
          gap: calc(var(--padding) / 2);

          .item.type-row2 & {
            grid-template-columns: repeat(2, 1fr);

            & .swiper-slide:only-child {
              grid-column: 1 / 3;
            }
          }
        }

        .swiper-slide {
          overflow: hidden;
          border-radius: var(--imageBorderRadius);
        }

        .item-image-thumbnail {
          display: none;
        }
      }
    }
  }

  .item-detail {
    opacity: 0;
    width: calc(40% - (var(--padding) / 2));
    transition: opacity 0.6s ease, translate 0.6s ease;
    z-index: 1;

    .viewed & {
      opacity: 1;
    }

    @media screen and (max-width: 992px) {
      width: 100%;
    }

    .item-detail-inner {
      position: sticky;
      top: var(--padding);

      .header.sticky-always + .content-wrap & {
        top: calc(var(--headerHeight) + 4px);
      }

      .item-detail-main {
        h1 {
          margin: 0 0 1.5rem 0;

          &.font-body {
            font-family: var(--bodyFontEn), var(--bodyFontJa), sans-serif;
            font-weight: var(--bodyFontWeightBold) !important;
            letter-spacing: var(--bodyLetterSpacing) !important;
          }
        }

        .price {
          position: relative;
          margin: 0 0 2rem 0;

          div {
            &:first-child {
              display: flex;
              align-items: center;
              gap: 5px;
            }

            &:nth-child(2) {
              margin-block-start: 8px;
            }
          }

          .rate {
            padding: 5px 6px;
            color: #fff;
            font-size: 1rem;
            line-height: 1;
            background: var(--noticeColor);
            border-radius: 2px;
          }

          .normal {
            opacity: 0.6;
            font-size: 1.2rem;
            text-decoration: line-through;
          }

          .current {
            color: var(--noticeColor);
            font-size: var(--headFontSizeS) !important;

            span {
              margin: 0 0 0 3px;
              font-size: 1.2rem;
            }
          }

          .default {
            font-size: var(--headFontSizeS) !important;

            span {
              opacity: 0.6;
              margin-inline-start: 3px;
              font-size: 1.2rem;
            }
          }
        }

        .bnplBanner {
          margin: 0 0 2rem 0 !important;
          border-radius: var(--inputBorderRadius);
        }

        .soldout {
          margin: 0 0 2rem 0;
          color: var(--noticeColor);
          font-weight: var(--bodyFontWeightBold);
        }

        .item-commontext {
          margin: 0 0 2rem 0;
          font-size: 1.3rem;
          font-weight: var(--bodyFontWeightBold);
          white-space: pre-line;
        }

        #itemAttention {
          color: var(--subTextColor);
          font-size: 1.1rem;
          line-height: calc(var(--bodyLineHeight) + 0.3);

          p {
            a {
              color: var(--subTextColor);
              font-weight: var(--bodyFontWeightNormal);
            }
          }

          .salesPeriod--term,
          .preOrder,
          .lottery,
          .takeout,
          .communityLabel {
            margin: 1rem 0;
            padding: 0;
            color: var(--textColor);
            font-size: 1.3rem;
            font-weight: var(--bodyFontWeightBold);
            line-height: var(--bodyLineHeight);
            background: none;

            .communityLabel__note {
              margin: 0;
              font-size: 1.3rem !important;
              line-height: var(--bodyLineHeight);
            }
          }

          .soldout {
            margin: 0 0 1rem 0;
            color: var(--noticeColor);
            font-size: 1.3rem;
          }
          .coming-soon,
          .preOrder__label,
          .lottery__label,
          .takeout__label,
          .communityLabel__title {
            margin: 0 0 1rem 0;
            padding: 6px 12px;
            width: fit-content;
            font-size: 1.3rem !important;
            border: var(--textColor) 1px solid;
            border-radius: 2px;
          }

          .membershipPoint__amountWrapper {
            margin: 0 0 4px 0;
            color: var(--textColor) !important;
            font-size: 1.3rem !important;
            font-weight: var(--bodyFontWeightBold) !important;

            .membershipPoint__amount {
              margin: 0 3px 0 0 !important;
              font-size: inherit !important;
              font-weight: var(--bodyFontWeightBold) !important;
            }
          }
        }

        .ageVerificationWarning {
          opacity: 0.6;
          margin: 2rem 0;
          color: var(--textColor) !important;
          font-size: calc(var(--headFontSizeS) + 0.1px) !important;
          line-height: var(--headLineHeight) !important;
        }

        #purchase_form {
          margin: 2rem 0;

          .purchaseElement,
          .itemOptionElement {
            margin: 1rem 0;

            label {
              display: block;
              margin: 0 0 4px 0;
              font-size: 1.2rem;
            }

            .itemOption__caption {
              margin: 3px 0 1rem 0;
              font-size: 1rem;
            }

            .itemOption__bottomCaptionBlock {
              display: flex !important;
              justify-content: space-between;
              gap: 10px;
              margin: 3px 0 0 0;

              .itemOption__caption--error {
                color: var(--noticeColor);
                font-size: 1rem;
              }

              .itemOption__count {
                margin: 0 0 0 auto;
                font-size: 1rem;
                text-align: right;
              }
            }
          }

          .purchaseButton {
            button,
            a {
              cursor: pointer;
              display: block;
              margin: 2rem 0 0 0;
              padding: 20px;
              width: 100%;
              color: var(--bgColor);
              font-size: 1.3rem;
              font-weight: var(--bodyFontWeightBold);
              line-height: var(--bodyLineHeight);
              letter-spacing: var(--bodyLetterSpacing);
              text-align: center;
              background: var(--textColor);
              border-radius: var(--inputBorderRadius);
              transition: all 0.3s ease;

              .subheader-color & {
                color: var(--subheaderTextColor);
                background: var(--subheaderBgColor);
              }
            }

            button:disabled,
            .purchaseButton__btn--soldOut,
            .purchaseButton__btn--noItem,
            .purchaseButton__btn--disabled,
            .purchaseButton__btn--endOfSale,
            button:disabled:hover,
            .purchaseButton__btn--soldOut:hover,
            .purchaseButton__btn--noItem:hover,
            .purchaseButton__btn--disabled:hover,
            .purchaseButton__btn--endOfSale:hover {
              cursor: not-allowed;
              pointer-events: none;
              opacity: 0.3;
            }

            @media (hover: hover) {
              button:hover,
              a:hover {
                opacity: 0.7;
              }
            }
          }
        }

        #communityPurchase {
          .communitySignin {
            position: relative;
            margin: 2rem 0 !important;
            padding: 10px;
            background: var(--subBgColor);
            border: none !important;
            border-radius: var(--inputBorderRadius) !important;

            p {
              margin: 0 0 4px 0 !important;
              font-size: 1.1rem !important;
              text-align: center;
            }

            a {
              margin: 4px 0 0 0;
              padding: 10px !important;
              color: #fff !important;
              background-color: #000435 !important;
              border-radius: var(--inputBorderRadius);

              img {
                display: inline-block;
                width: 88px;
              }
            }
          }
        }

        .item-tab {
          display: flex;
          margin-block: 3.5rem 2.5rem;
          border-bottom: var(--textColor12) 1px solid;

          li {
            flex: 1;
            display: flex;
            text-align: center;

            a {
              opacity: 0.3;
              display: block;
              position: relative;
              margin-block-end: -1px;
              padding: 8px 0;
              width: 100%;
              font-size: 1.2rem;
              font-weight: var(--bodyFontWeightBold);

              &:after {
                content: '';
                opacity: 0;
                position: absolute;
                inset: auto 0 0 0;
                width: 100%;
                height: 1px;
                background: var(--textColor);
              }

              &[aria-expanded='true'] {
                opacity: 1;

                &:after {
                  opacity: 1;
                }
              }
            }
          }
        }

        .item-tab-content {
          margin: 0 0 5rem 0;

          &.notab {
            display: flex;
            flex-direction: column;
            gap: 3rem;
          }

          .item-tab-content-item {
            visibility: hidden;
            opacity: 0;
            height: 0;
            font-size: 1.3rem;

            &[aria-hidden='false'],
            .notab & {
              visibility: visible;
              opacity: 1;
              height: auto;
            }

            &.item-description {
              a {
                text-decoration: underline;

                @media (hover: hover) {
                  &:hover {
                    opacity: 0.7;
                  }
                }
              }
            }

            .notab-title {
              margin: 0 0 1.2rem 0;
              font-weight: var(--bodyFontWeightBold);
            }

            &.item-guide {

              .text {
                margin: 0 0 3rem 0;
              }

              .btn {
                margin: 0 0 1rem 0;

                a {
                  position: relative;
                  padding: 0 0 0 26px;
                  font-weight: var(--bodyFontWeightBold);

                  &:before {
                    content: '';
                    position: absolute;
                    inset: 50% auto auto 0;
                    width: 18px;
                    height: 18px;
                    mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.8%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-info%22%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%2210%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2212%22%20y1%3D%2216%22%20x2%3D%2212%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cline%20x1%3D%2212%22%20y1%3D%228%22%20x2%3D%2212.01%22%20y2%3D%228%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat right center / 18px;
                    -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.8%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-info%22%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%2210%22%3E%3C%2Fcircle%3E%3Cline%20x1%3D%2212%22%20y1%3D%2216%22%20x2%3D%2212%22%20y2%3D%2212%22%3E%3C%2Fline%3E%3Cline%20x1%3D%2212%22%20y1%3D%228%22%20x2%3D%2212.01%22%20y2%3D%228%22%3E%3C%2Fline%3E%3C%2Fsvg%3E') no-repeat right center / 18px;
                    background-color: var(--textColor);
                    translate: 0 -50%;
                  }
                }
              }

              ul {
                border-block-start: var(--textColor12) 1px solid;

                li {
                  border-block-end: var(--textColor12) 1px solid;

                  a {
                    display: block;
                    position: relative;
                    padding: 16px 44px 16px 0;
                    font-size: 1.2rem;

                    &:after {
                      content: '';
                      position: absolute;
                      inset: 50% -12px 0 auto;
                      width: 44px;
                      height: 44px;
                      mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
                      -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.2%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22feather%20feather-chevron-right%22%3E%3Cpolyline%20points%3D%229%2018%2015%2012%209%206%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E') no-repeat center center / 20px;
                      background-color: var(--textColor);
                      translate: 0 -50%;
                    }
                  }
                }
              }
            }
          }
        }
      }

      .related-items {
        position: relative;

        .title {
          position: relative;
          margin: 0 0 1.2rem 0;

          h2 {
            font-size: 1.6rem !important;
          }
        }

        .swiper {
          border: var(--textColor12) 1px solid;
          border-radius: 4px;

          .swiper-slide {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 8px;

            .image {
              width: 80px;

              a {
                overflow: hidden;
                display: block;
                border-radius: var(--imageBorderRadius);

                img {
                  aspect-ratio: var(--itemListImageAspect);
                  object-fit: cover;
                  width: 100%;
                  height: 100%;
                  transition: all 0.3s ease;
                }

                @media (hover: hover) {
                  &:hover {
                    img {
                      scale: 1.05;
                    }
                  }
                }
              }
            }

            .text {
              width: calc(100% - 100px);
              font-size: 1.3rem;
            }
          }
        }

        .swiper-button-prev,
        .swiper-button-next {
          inset: 50% -6px auto auto;
          margin: 0;
          width: 24px;
          height: 24px;
          border: var(--textColor12) 1px solid;
          border-radius: 50%;
          translate: 0 -50%;
          transition: all 0.3s ease;

          &:after {
            padding-inline-start: 1px;
            color: var(--textColor);
            font-size: 0.35lh;
            transition: all 0.2s ease;
          }

          &.swiper-button-prev {
            inset: 50% 22px auto auto;

            &:after {
              padding-inline-end: 1px;
              color: var(--textColor);
              font-size: 0.35lh;
            }
          }

          &.swiper-button-disabled {
            opacity: 1;

            &:after {
              opacity: 0.3;
            }
          }
        }
      }

      .item-sns-wrap {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin: 3rem 0 0 0;

        @media screen and (max-width: 992px) {
          margin: 2rem 0 var(--margin) 0;
        }

        .item-sns {
          display: flex;
          align-items: center;
          gap: 16px;
          font-size: 1.2rem;

          div {
            a {
              display: flex;
              align-items: center;

              @media (hover: hover) {
                &:hover {
                  opacity: 0.7;
                }
              }

              img {
                margin: 0 7px 0 0;
                width: 15px;
              }

              .item-sns .twitter & {
                span {
                  margin: 0 7px 0 0;
                  max-width: 15px;
                  max-height: 15px;
                  font-size: 0;
                  background: #000;
                  border-radius: 3px;

                  img {
                    padding: 3px;
                    filter: brightness(0) invert(1);
                  }
                }
              }
            }
          }
        }

        #reportBtn {
          font-size: 1.1rem;
        }
      }
    }
  }
}

.item-detail-custom {
  #appsItemDetailCustom {
    overflow: hidden;

    .position-1 & {
      margin: var(--padding) 0 0 0;
    }

    .position-2 & {
      margin: var(--margin) calc(50% - var(--vw) * 50) 0 calc(50% - var(--vw) * 50);
      width: calc(var(--vw) * 100);
      background: var(--subBgColor);
    }

    #appsItemDetailCustomTag {
      margin: 0 auto;

      .position-2 & {
        opacity: 0;
        padding: var(--margin) var(--padding);
        max-width: var(--maxWidth);
        transition: all 0.6s ease;

        .viewed & {
          opacity: 1;
        }
      }

      & > :first-child {
        margin-top: 0 !important;
      }
      & > :last-child {
        margin-bottom: 0 !important;
      }

      .appsItemDetailCustomTag_heading {
        margin: var(--margin) 0 2rem 0;
        font-size: var(--headFontSizeS);

        .position-1 & {
          margin: 4rem 0 2rem 0;
        }
      }

      .appsItemDetailCustomTag_description {
        margin: 2rem 0;
      }

      .appsItemDetailCustomTag_image {
        margin: 3rem 0;
        width: 100%;
        border-radius: var(--imageBorderRadius);
      }

      .appsItemDetailCustomTag_youtube,
      .appsItemDetailCustomTag_vimeo {
        overflow: hidden;
        margin: 3rem 0;
        border-radius: var(--imageBorderRadius);

        iframe {
          aspect-ratio: 16 / 9;
          width: 100%;
          height: auto;
        }
      }

      .appsItemDetailCustomTag_slider {
        position: relative;
        margin: 3rem auto;
        max-width: 60%;

        .position-2 & {
          max-width: 500px;
        }

        @media screen and (max-width: 768px) {
          max-width: 80%;
        }

        .baseCarouselItem {
          position: relative;

          img {
            width: 100%;
            border-radius: var(--imageBorderRadius);
          }

          .baseCarouselCaption {
            margin: 0.5rem 0 0 0;
            width: 100%;
            font-size: 1.2rem;
          }
        }

        .swiper-button-prev,
        .swiper-button-next {
          inset: 50% auto auto -30px;
          width: 30px;
          height: 30px;
          color: var(--textColor);
          transition: all 0.3s ease;

          &.swiper-button-next {
            inset: 50% -30px auto auto;
          }

          &:after {
            font-size: 2.0rem;
            transition: all 0.3s ease;
          }

          @media screen and (max-width: 992px) {
            display: none;
          }
        }
      }
    }
  }
}

.review01 {
  margin: 0 0 0 auto !important;
  max-width: 100% !important;

  .review01__title {
    display: none;
  }

  .review01__tabWrap {
    padding: 0 44px 0 0 !important;
    background: var(--subBgColor) !important;
    border: none !important;
    border-radius: var(--inputBorderRadius);

    ul.review01__tab {
      display: flex;
      gap: 22px;
      padding: 0 0 0 22px;

      &:after {
        bottom: 0 !important;
        border-bottom: none !important;
      }

      li.review01__tabChild {
        opacity: 0.3;
        width: auto;
        height: 44px;

        .review01__tab--all &:nth-child(1) {
          opacity: 1;
        }
        .review01__tab--good &:nth-child(2) {
          opacity: 1;
        }
        .review01__tab--normal &:nth-child(3) {
          opacity: 1;
        }
        .review01__tab--bad &:nth-child(4) {
          opacity: 1;
        }

        .review01__tabIcon {
          width: 18px !important;
          height: 18px !important;
          background-size: 18px !important;
        }

        .review01__radio + label {
          height: 44px !important;
          font-size: 1.2rem !important;
          line-height: 44px !important;
        }

        .review01__radio:checked + label {
          font-weight: var(--bodyFontWeightNormal) !important;
        }
      }
    }

    .review01__trigger {
      width: 44px !important;
      height: 44px !important;

      &:before {
        top: 17px !important;
        width: 8px !important;
        height: 8px !important;
        border-right: var(--textColor) 1px solid !important;
        border-bottom: var(--textColor) 1px solid !important;
      }

      .is-open &:before {
        top: 21px !important;
      }
    }
  }

  .review01__list {
    border: none !important;

    li.review01__listLoading {
      position: relative;
      background: none !important;

      &:after {
        content: '';
        opacity: 0.3;
        position: absolute;
        inset: 50% auto auto 50%;
        width: 36px;
        height: 36px;
        mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cstyle%3E.spinner_z9k8%7Btransform-origin%3Acenter%3Banimation%3Aspinner_StKS%20.75s%20infinite%20linear%7D%40keyframes%20spinner_StKS%7B100%25%7Btransform%3Arotate(360deg)%7D%7D%3C%2Fstyle%3E%3Cpath%20d%3D%22M12%2C1A11%2C11%2C0%2C1%2C0%2C23%2C12%2C11%2C11%2C0%2C0%2C0%2C12%2C1Zm0%2C19a8%2C8%2C0%2C1%2C1%2C8-8A8%2C8%2C0%2C0%2C1%2C12%2C20Z%22%20opacity%3D%22.25%22%2F%3E%3Cpath%20d%3D%22M12%2C4a8%2C8%2C0%2C0%2C1%2C7.89%2C6.7A1.53%2C1.53%2C0%2C0%2C0%2C21.38%2C12h0a1.5%2C1.5%2C0%2C0%2C0%2C1.48-1.75%2C11%2C11%2C0%2C0%2C0-21.72%2C0A1.5%2C1.5%2C0%2C0%2C0%2C2.62%2C12h0a1.53%2C1.53%2C0%2C0%2C0%2C1.49-1.3A8%2C8%2C0%2C0%2C1%2C12%2C4Z%22%20class%3D%22spinner_z9k8%22%2F%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
        -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cstyle%3E.spinner_z9k8%7Btransform-origin%3Acenter%3Banimation%3Aspinner_StKS%20.75s%20infinite%20linear%7D%40keyframes%20spinner_StKS%7B100%25%7Btransform%3Arotate(360deg)%7D%7D%3C%2Fstyle%3E%3Cpath%20d%3D%22M12%2C1A11%2C11%2C0%2C1%2C0%2C23%2C12%2C11%2C11%2C0%2C0%2C0%2C12%2C1Zm0%2C19a8%2C8%2C0%2C1%2C1%2C8-8A8%2C8%2C0%2C0%2C1%2C12%2C20Z%22%20opacity%3D%22.25%22%2F%3E%3Cpath%20d%3D%22M12%2C4a8%2C8%2C0%2C0%2C1%2C7.89%2C6.7A1.53%2C1.53%2C0%2C0%2C0%2C21.38%2C12h0a1.5%2C1.5%2C0%2C0%2C0%2C1.48-1.75%2C11%2C11%2C0%2C0%2C0-21.72%2C0A1.5%2C1.5%2C0%2C0%2C0%2C2.62%2C12h0a1.53%2C1.53%2C0%2C0%2C0%2C1.49-1.3A8%2C8%2C0%2C0%2C1%2C12%2C4Z%22%20class%3D%22spinner_z9k8%22%2F%3E%3C%2Fsvg%3E') no-repeat center center / 36px;
        background-color: var(--textColor);
        translate: -50% -50%;
      }
    }
  }
  .review01__listChild + .review01__listChild {
    border-top: var(--textColor12) 1px solid !important;
  }
  .review01__itemName,
  .review01__comment {
    color: var(--textColor) !important;
  }
  .review01__itemVariation,
  .review01__date {
    color: var(--subTextColor) !important;
  }
  .review01__reply {
    color: var(--subTextColor) !important;
    background: var(--subBgColor) !important;
  }
}

/* common
------------------------------------------*/
.image-title {
  opacity: 0;
  position: relative;
  margin: 0 0 var(--margin) 0;
  height: var(--imageTitleHeight);
  transition: all 0.6s ease;

  .viewed & {
    opacity: 1;
  }

  .image {
    overflow: hidden;
    margin: 0 calc(50% - var(--vw) * 50);
    width: calc(var(--vw) * 100);
    height: 100%;

    img {
      opacity: 0;
      object-fit: cover;
      width: 100%;
      height: 100%;
      scale: 1.05;
      transition: all 0.6s ease;

      .viewed & {
        opacity: 1;
        scale: 1;
      }
    }
  }

  .bg {
    overflow: hidden;
    position: absolute;
    inset: 0;
    margin: 0 calc(50% - var(--vw) * 50);
    width: calc(var(--vw) * 100);
    height: 100%;

    div {
      opacity: 0;
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      scale: 1.05;
      transition: all 0.6s ease;

      .viewed & {
        opacity: 1;
        scale: 1;
      }
    }
  }

  .text,
  h2 {
    position: absolute;
    inset: auto 0 var(--padding) 0;
    width: 100%;
    color: var(--imageTitleTextColor);
    font-size: var(--pageTitleSize);
    text-indent: var(--headLetterSpacing);

    @media screen and (max-width: 992px) {
      inset: 50% 0 auto 0;
      text-align: center;
      translate: 0 -50%;
    }

    h1 {
      font-size: var(--pageTitleSize);
    }
  }
}

.breadcrumb-wrap {
  opacity: 0.8;
  margin: 0 0 12px 0;
  transition: opacity 0.6s 0.1s ease;
  z-index: 10;

  .breadcrumb {
    opacity: 0;
    display: flex;
    flex-wrap: wrap;
    color: var(--imageTitleTextColor);
    font-size: 1rem;
    transition: all 0.6s ease;

    .page-title-breadcrumb & {
      color: var(--textColor);
    }

    .viewed & {
      opacity: 1;
    }

    @media screen and (max-width: 992px) {
      justify-content: center;
    }

    li {
      display: flex;

      a {
        color: var(--imageTitleTextColor);

        .page-title-breadcrumb & {
          color: var(--textColor);
        }
      }

      &:first-child {
        a {
          font-size: 0;

          &:after {
            content: var(--categoryHome);
            font-size: 1rem;
          }
        }
      }

      &:not(:last-child):after {
        content: '/';
        margin-inline: 8px;
      }
    }
  }
}

.page-title {
  opacity: 0;
  padding: var(--pageTitleMargin) 0;
  font-size: var(--pageTitleSize);
  text-align: center;
  text-indent: var(--headLetterSpacing);
  transition: all 0.6s ease;

  .viewed & {
    opacity: 1;
  }
}

.page-title-breadcrumb {
  opacity: 0;
  padding: var(--pageTitleMargin) 0;
  transition: all 0.6s ease;

  .viewed & {
    opacity: 1;
  }

  @media screen and (max-width: 992px) {
    text-align: center;
  }

  h1 {
    font-size: var(--pageTitleSize);
  }
}

/* blog
------------------------------------------*/
.blogListMain {
  opacity: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--imageGapVer) var(--imageGapHor);
  transition: all 0.6s ease;

  .viewed & {
    opacity: 1;
  }

  @media screen and (max-width: 992px) {
    grid-template-columns: repeat(3, 1fr);
  }

  @media screen and (max-width: 768px) {
    grid-template-columns: repeat(2, 1fr);
  }

  .blog_inner {
    display: flex;
    flex-direction: column;
    padding: 0 !important;
    border: none !important;

    .blog_head_image {
      order: 1;
      overflow: hidden;
      margin: 0 0 15px 0;
      border-radius: var(--imageBorderRadius);

      a {
        display: block;

        img {
          aspect-ratio: var(--newblogImageAspect);
          object-fit: cover;
          width: 100%;
          height: 100%;
          transition: all 0.3s ease;
        }

        @media (hover: hover) {
          &:hover img,
          &:focus-visible img {
            scale: 1.05;
          }
        }
      }
    }

    .blog_title {
      order: 2;

      h2 {
        font-size: 1.4rem !important;
        font-family: var(--bodyFontEn), var(--bodyFontJa), sans-serif !important;
        font-weight: var(--bodyFontWeightNormal) !important;
        line-height: var(--bodyLineHeight) !important;
        letter-spacing: var(--bodyLetterSpacing) !important;
      }
    }

    .blog_publish {
      order: 3;
      margin: 3px 0 0 0 !important;
      color: var(--subTextColor);
      font-size: 1.2rem;
    }

    .blog_contents {
      display: none;
    }
  }

  .paginate-wrp {
    display: none;
    grid-column: 1 / -1;
    margin: min(3rem, var(--margin)) auto 0 auto;

    &:has(li) {
      display: block;
    }

    .paginate {
      justify-content: center;
      gap: 5px;

      li,
      li.current {
        margin: 0 !important;
        font-weight: var(--bodyFontWeightBold);
        background: none;
        border: none;

        a,
        a:hover,
        &.current a,
        &.current a:hover {
          display: block;
          padding: 10px 3px;
          min-width: 34px;
          color: var(--textColor);
          font-size: 1.1rem;
          font-weight: var(--bodyFontWeightNormal);
          line-height: 1;
          text-align: center;
          background: none;
          border: var(--textColor12) 1px solid;
          border-radius: var(--inputBorderRadius);
        }

        &.current a,
        &.current a:hover {
          color: var(--bgColor);
          background: var(--textColor);
          border: var(--textColor) 1px solid;
        }

        &.prev,
        &.next {
          a {
            font-size: 0;

            &:after,
            &:after {
              content: '<';
              margin: 0 0 0 -4px;
              font-size: 1.2rem;
            }
          }
        }

        &.next {
          a {
            &:after {
              content: '>';
            }
          }
        }
      }

      @media (hover: hover) {
        li a:hover {
          opacity: 0.7;
        }
      }
    }
  }

  .blog-type-2 & {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--imageGapHor);

    @media screen and (max-width: 1400px) {
      grid-template-columns: repeat(3, 1fr);
    }

    @media screen and (max-width: 1200px) {
      grid-template-columns: repeat(2, 1fr);
    }

    @media screen and (max-width: 768px) {
      grid-template-columns: repeat(1, 1fr);
    }

    .blog_inner {
      justify-content: center;
      padding: 0 0 0 140px !important;
      height: 120px;

      .blog_head_image {
        position: absolute;
        top: 0;
        left: 0;
        width: 120px;
      }

      .blog_title {
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
      }

      .blog_publish {
        margin: 5px 0 0 0;
      }

      .blog_contents {
        order: 4;
        display: block;
        height: auto !important;

        .blog_body {
          .text {
            overflow: hidden;
            display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 2;
            margin: 12px 0 0 0;
            font-size: 1.2rem;
          }
        }

        .read_more {
          display: none;
        }
      }
    }
  }

  .blog-type-3 & {
    grid-template-columns: repeat(1, 1fr);
    gap: 1.5rem;
    margin: 0 auto;
    max-width: 900px;
    padding: var(--padding);
    background: var(--subBgColor);
    border-radius: var(--imageBorderRadius);

    .blog_inner {
      display: flex;
      flex-direction: row-reverse;
      justify-content: flex-end;
      align-items: center;
      gap: 30px;
      font-size: 1.2rem;

      @media screen and (max-width: 768px) {
        flex-direction: column-reverse;
        align-items: flex-start;
        gap: 4px;
      }

      .blog_head_image {
        display: none;
      }
    }
  }
}

.blogDetail {
  opacity: 0;
  margin: 0 auto;
  max-width: 900px;
  transition: all 0.6s ease;
}
.viewed .blogDetail {
  opacity: 1;
}
.blogDetail .blog_inner {
  padding: 0 !important;
  border: none !important;
}
.blogDetail .blog_title h2 {
  margin: 0 0 10px 0 !important;
  padding: 0;
  font-size: var(--headFontSizeS);
}
.blogDetail .blog_publish {
  opacity: 0.6;
  margin: 0 0 25px 0 !important;
  font-size: 1.2rem !important;
}
.blogDetail .blog_publish .publish_date {
  margin: 0 !important;
}
#about .publish_date {
  font-size: inherit !important;
}
.social {
  margin: var(--margin) 0 0 0 !important;

  ul {
    display: flex;

    li {
      a {
        display: block !important;

        img {
          width: 24px;
          height: 24px;
        }

        .tw & {
          background: #000;
          border-radius: 100px;

          img {
            padding: 5px;
            filter: brightness(0) invert(1);
          }
        }
      }
    }
  }
}

.blog_body h3 {
  margin: 1.2rem 0;
}
.blog_body .youtube,
.blog_body .vimeo {
  aspect-ratio: 16 / 9;
  width: 100%;
  height: auto;
}
.blog_body img {
  border-radius: var(--imageBorderRadius) !important;
}

@media screen and (max-width: 768px) {
  .paginate-wrp {
    grid-column: 1 / 3;
  }
}

/* privacy, law, contact
------------------------------------------*/
#privacy,
#law,
.contact {
  opacity: 0;
  margin: 0 auto calc(var(--margin) * 2) auto;
  max-width: 900px;
  transition: all 0.6s ease;
}
.viewed #privacy,
.viewed #law,
.contact.viewed {
  opacity: 1;
}

.contact h1 {
  display: none;
}
#privacy h2,
#law h2,
.contact h2 {
  margin: var(--pageTitleMargin) 0;
  font-size: var(--subPageTitleSize);
  text-align: center;
}
#law h3 {
  margin: 3rem 0 1.5rem 0;
  font-size: min(var(--headFontSizeS), 2.6rem);
  font-weight: var(--bodyFontWeightBold);
}
#law h3:nth-child(2) {
  margin: 0 0 1.5rem 0;
}
#privacy a,
#law a {
  font-weight: var(--bodyFontWeightNormal);
  text-decoration: underline;
}
#privacy p.privacy_intro {
  margin: 0 0 3rem 0;
}
#privacy dl dt,
#law dl dt {
  margin: 0 0 1.5rem 0;
  font-size: min(var(--headFontSizeS), 2.6rem);
}
#privacy dl dd,
#law dl dd {
  margin: 0 0 3rem 0;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  #privacy h2,
  #law h2 {
    font-size: min(var(--subPageTitleSize), 2.4rem);
  }
  #law h3 {
    font-size: min(var(--headFontSizeS), 2.0rem);
  }
}

#ShopInquiryInquiryForm {
  text-align: center;

  & > * {
    text-align: start;
  }
}

.contact p {
  margin: 0 0 30px 0;
}
.contact dl dt {
  display: flex;
  align-items: center;
  margin: 3rem 0 1rem 0;
}
.contact dl dt:first-child {
  margin: 0 0 1rem 0;
}
.contact dl dt span {
  margin: 0 0 0 5px;
  font-size: 1.2rem;
  font-weight: var(--bodyFontWeightNormal);
}
.contact dl dd.error {
  margin: 5px 0 0 0;
  color: var(--noticeColor);
  font-size: 1.2rem;
}
.contact dl dd input,
.contact dl dd textarea {
  padding: 12px !important;
  background: none !important;
  border: var(--textColor12) 1px solid !important;
}
.contact dl dd textarea {
  height: 200px !important;
}
.contact .control-panel {
  margin: var(--padding) auto 0 auto !important;
}
#inquiryCompleteSection {
  text-align: center;
}
#inquiryCompleteSection a {
  text-decoration: underline;
}

/* about
------------------------------------------*/
.about-main {
  opacity: 0;
  margin: 0 auto;
  max-width: 900px;
  transition: all 0.6s ease;
}
.viewed .about-main {
  opacity: 1;
}
.about-main :first-child {
  margin-top: 0 !important;
}
.about-main :last-child {
  margin-bottom: 0 !important;
}
.about-main h3,
.about-main h4 {
  margin: var(--margin) 0 2rem 0;
  font-size: var(--headFontSizeS);
  white-space: pre-line;
}
.about-main .text {
  margin: 2rem 0;
  white-space: pre-line;
}
.about-main .text.shop-info {
  white-space: normal;
}
.about-main .text.shop-info a {
  text-decoration: underline;
}
.about-main .image {
  margin: 3rem 0;
}
.about-main .image img {
  border-radius: var(--imageBorderRadius);
}
.about-main .googlemap {
  margin: 3rem 0;
}
.about-main .googlemap iframe {
  margin: 0 0 0 auto;
  width: 100% !important;
  height: 400px;
  border-radius: var(--imageBorderRadius);
}

/* membership
------------------------------------------*/
.membership .draft .message {
  margin: 0 !important;
  padding: 200px 0;
  width: 100%;
  text-align: center;
  line-height: 1 !important;
}
#membership {
  --white: var(--bgColor) !important;
  --black: var(--textColor) !important;
  --black-light: var(--subBgColor) !important;
  --checked-color: var(--textColor) !important;
  padding: 0 !important;
}

.membership .guide,
.membership .content,
.membership .about-point,
.membership .mypage-link,
.membership .register,
.membership .login,
.membership .heading-wrapper,
.membership .info,
.membership .leave-wrapper {
  opacity: 0;
  margin: 0;
  padding: 0;
  max-width: 100%;
  transition: all 0.6s ease;
}
.viewed .membership .guide,
.viewed .membership .content,
.viewed .membership .about-point,
.viewed .membership .mypage-link,
.viewed .membership .register,
.viewed .membership .login,
.viewed .membership .heading-wrapper,
.viewed .membership .info,
.viewed .membership .leave-wrapper {
  opacity: 1;
}
.membership .guide .content .heading,
.membership .guide .about-point .heading-point {
  margin: 0 0 2.5rem 0 !important;
  font-size: var(--headFontSizeS) !important;
  line-height: inherit !important;
}
.membership .guide .content .description {
  margin: 0 !important;
}
.membership .guide .content .description > p {
  font-size: 1.4rem !important;
  font-weight: var(--bodyFontWeightNormal) !important;
  line-height: 2.0 !important;
}
.membership .guide .about-point {
  margin: 50px 0 0 0 !important;
}
.membership .guide .about-point .description {
  margin: 0 !important;
  line-height: 2.0 !important;
}
.membership .guide .about-point .description .description-details {
  font-size: inherit !important;
  line-height: inherit !important;
}
.membership .guide .reward-list .bar {
  background: var(--textColor12) !important;
}
.membership .guide .reward-list .reward-card-list .reward-card .reward-detail-wrapper .exchange-point-wrapper .exchange-point-icon path {
  fill: var(--textColor) !important;
}
.membership .guide .register {
  margin: min(var(--margin), 80px) 0 0 0 !important;
  padding: var(--padding) !important;
  background: var(--subBgColor) !important;
  border-radius: var(--imageBorderRadius) !important;
}
.membership .guide .register .box {
  color: var(--textColor) !important;
  background: var(--bgColor) !important;
}
.membership .guide .register .box:before {
  color: var(--bgColor) !important;
  background: var(--textColor) !important;
}
.membership .guide .register .mail-magazine .mail-magazine-wrapper .checkbox:after {
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20512%20512%22%3E%3Cg%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%22440.469%2C73.413%20218.357%2C295.525%2071.531%2C148.709%200%2C220.229%20146.826%2C367.055%20218.357%2C438.587%20289.878%2C367.055%20512%2C144.945%22%3E%3C%2Fpolygon%3E%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat center center / 14px;
  -webkit-mask: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20512%20512%22%3E%3Cg%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%22440.469%2C73.413%20218.357%2C295.525%2071.531%2C148.709%200%2C220.229%20146.826%2C367.055%20218.357%2C438.587%20289.878%2C367.055%20512%2C144.945%22%3E%3C%2Fpolygon%3E%3C%2Fg%3E%3C%2Fsvg%3E') no-repeat center center / 14px;
  background: var(--subBgColor) !important;
}
.membership .login .heading,
.membership .guide .register .heading {
  font-size: var(--headFontSizeS) !important;
  line-height: 1.8 !important;
}
.membership .guide .register .description-wrapper {
  margin: 20px 0;
}
.membership .guide .register .description-link,
.membership .guide .register .login-link,
.membership .login .register-link {
  color: var(--textColor) !important;
}
.membership .guide .register .mail-magazine .mail-magazine-wrapper .label {
  color: var(--textColor) !important;
}
.membership .guide .mypage-link {
  margin: var(--margin) 0 0 0 !important;
}
.membership .guide .img-wrapper {
  margin: 0 0 4rem 0 !important;

  img {
    max-height: 300px !important;
    border-radius: var(--imageBorderRadius);
  }
}
.membership .mypage .img-wrapper {
  margin: 4rem 0 !important;
}
.membership .mypage .img-wrapper img {
  width: 100% !important;
  height: auto !important;
  max-height: 300px !important;
  border-radius: var(--imageBorderRadius);
}
.membership .mypage .heading-wrapper {
  margin: 0 0 2.5rem 0 !important;
  padding: 0 0 1rem 0;
  text-align: center !important;
  border-bottom: var(--textColor12) 1px solid;
}
.membership .mypage .heading {
  font-size: var(--headFontSizeS) !important;
}
.membership .mypage .logout {
  color: var(--textColor) !important;
  background: none !important;
}
.membership .mypage .info {
  gap: var(--padding) !important;
}
.membership .mypage .content .customer-info {
  margin: 0 !important;
}
.membership .mypage .card {
  margin: 0 !important;
  color: var(--textColor) !important;
  background: var(--subBgColor) !important;
  border: var(--subBgColor) 1px solid !important;
  border-radius: var(--imageBorderRadius) !important;
}
.membership .mypage .card .logo-image {
  margin: 0 0 15px 0 !important;
}
.membership .mypage .content .bar {
  height: 0 !important;
  background: none !important;
}
.membership .mypage .content .definition-description .mail-address,
.membership .mypage .content .definition-description .point-amount {
  padding: 12px !important;
  color: var(--textColor) !important;
  background: var(--subBgColor) !important;
  border-radius: var(--inputBorderRadius) !important;
}
.membership .mypage .content .customer-info-wrapper {
  margin: 0 0 2.5rem 0 !important;
  padding: 0 0 1rem 0;
  border-bottom: var(--textColor12) 1px solid;
}
.membership .mypage .content .customer-info-wrapper .edit-wrapper .edit,
.membership .draft .logout,
.membership .draft .content .point-info-login-link {
  color: inherit !important;
}
.membership .mypage .content .definition-description {
  gap: 20px !important;
  padding: 0 !important;
  background: none !important;
}
.membership .mypage .content .definition-description .mail-address {
  padding: 12px 18px !important;
  background: var(--subBgColor) !important;
}
.membership .mypage .content .definition-description .edit {
  color: var(--textColor) !important;
  font-weight: var(--bodyFontWeightNormal) !important;
  background: none !important;
  border: var(--textColor) 1px solid !important;
}
.membership .mypage .content .definition-description .point-expiry-date,
.membership .mypage .content .definition-description .point-history .link,
.membership .mypage .content .about-wrapper .about,
.membership .point-history .content .point-history-summary .point-name,
.membership .point-history .content .point-history-summary .description {
  color: var(--textColor) !important;
}
.membership .mypage .leave-wrapper {
  margin: var(--margin) 0 0 0 !important;
}
.membership .mypage .leave-wrapper .leave {
  color: var(--textColor) !important;
  background: none !important;
}
.membership .mypage .leave-modal-wrapper .leave-overlay {
  z-index: 9999 !important;
}
.membership .mypage .leave-modal-wrapper .leave-modal {
  z-index: 10000 !important;
}
.membership .mypage .leave-modal-wrapper .leave-modal-new {
  --white: #fff !important;
  --black: #252525 !important;
  --black-light: #6a6f76 !important;
  --checked-color: var(--black) !important;
}
.membership .point-history .content .point-history-summary {
  margin: 0 0 2.5rem 0 !important;
  padding: 0 0 1rem 0;
  border-bottom: var(--textColor12) 1px solid;
}
.membership .point-history .content .point-history-empty-text {
  padding: 0 !important;
  border: none !important;
}

@media screen and (max-width: 768px) {
  .membership .mypage .card {
    max-width: 100% !important;
  }
  .membership .mypage .content .customer-info {
    margin: 0 0 12px 0 !important;
  }
}

/* community
------------------------------------------*/
.communityMain {
  opacity: 0;
  padding: 0 !important;
  width: 100% !important;
  transition: all 0.6s ease;
}
.viewed .communityMain {
  opacity: 1;
}
.communityMain h1.communityTitle {
  margin: 0 0 2.5rem 0 !important;
  font-size: var(--headFontSizeS) !important;
  line-height: inherit !important;
  text-align: left !important;
}
.communityMain .communityContent {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}
.communityMain .communityNav {
  flex: 1;
  margin: 0 0 0 var(--padding) !important;
  padding: 20px;
  width: 100% !important;
  border: var(--textColor12) 1px solid;
  border-radius: var(--imageBorderRadius);
}
.communityMain .communityTerm a {
  color: var(--textColor) !important;
}
.communityMain .communityOverviewWrap {
  flex: 2;
}
.communityMain .communityOverviewWrap .communityOverview {
  width: 100% !important;
  font-size: inherit !important;
  line-height: var(--bodyLineHeight) !important;
  white-space: pre-line;
}
.communityMain .communitySignin {
  padding: 16px 0 0 0 !important;
  border: none !important;
  border-top: var(--textColor12) 1px solid !important;
}
.communityMain #limitedItem,
.communityMain #limitedUrl {
  width: 100% !important;
}
.communityMain .communityItemHeader,
.communityMain .communityUrlHeader {
  position: relative !important;
  margin: var(--margin) 0 2.5rem 0 !important;
  padding: 0 !important;
  color: var(--textColor) !important;
  font-size: var(--headFontSizeS) !important;
  text-align: left !important;
}
.communityMain .communityItems {
  display: grid !important;
  grid-template-columns: repeat(var(--itemNum), 1fr);
  gap: var(--imageGapVer) var(--imageGapHor);
}
.communityMain .communityItems .communityItem {
  margin: 0 !important;
}
.communityMain .communityItems .communityItem .communityImageContainer {
  overflow: hidden;
  display: block !important;
  margin: 0 0 1.2rem 0;
  width: 100% !important;
  height: auto !important;
  border-radius: var(--imageBorderRadius);
}
.communityMain .communityItems .communityItem a .communityImageContainer img {
  aspect-ratio: var(--itemListImageAspect);
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: all 0.3s ease;
}
@media (hover: hover) {
  .communityMain .communityItems .communityItem a:hover .communityImageContainer img {
    transform: scale(1.05);
  }
}
.communityMain .communityItems .communityItem .communityLabelImage {
  top: 0 !important;
  left: 0 !important;
  width: 50px !important;
  height: auto !important;
}
.communityMain .communityItems .communityItem .communityItemTitle {
  margin: 0 !important;
  width: auto !important;
  max-height: none !important;
  text-align: var(--itemListTextAlign) !important;
}
.communityMain .communityItems .communityItem .communityItemPrice {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: var(--itemListTextAlign) !important;
  align-items: center !important;
  gap: 5px !important;
  margin: 0 !important;
  font-size: 1.4rem !important;
}
.communityMain .communityItems .communityItem .communityItemPrice.discount {
  color: var(--noticeColor) !important;
}
.communityMain .communityItems .communityItem .communityItemPrice.discount .discount {
  margin: 3px 0 !important;
  padding: 5px 6px !important;
  color: #fff !important;
  font-size: 1rem !important;
  font-weight: var(--bodyFontWeightNormal) !important;
  line-height: 1 !important;
  background: var(--noticeColor) !important;
  border: none !important;
  border-radius: 2px !important;
}
.communityMain .communityItems .communityItem .communityItemMeta {
  text-align: center;
}
.communityMain .communityItems .communityItem .communityItemMetaSub {
  margin: 0 !important;
  text-align: center !important;
}
.communityMain .communityItems .communityItem .communityItemLabel,
.communityMain .communityItems .communityItem .communityItemLabelBlock {
  display: block !important;
  margin: 0 auto !important;
  color: var(--noticeColor) !important;
  font-size: 1.2rem !important;
  font-weight: var(--bodyFontWeightNormal) !important;
  text-align: var(--itemListTextAlign) !important;
  border: none !important;
  border-radius: 2px !important;
}
.communityMain .communityItems .communityItem .communityItemLabelBlock.community {
  color: #fff !important;
  background: var(--communityColor) !important;
  border: none !important;
}
.communityMain section.limited p {
  margin: 0 !important;
}
.communityMain #productsLimitedUrl {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--imageGapVer) var(--imageGapHor);
}
.communityMain #productsLimitedUrl .urlBox {
  overflow: hidden !important;
  margin: 0 !important;
  padding: 15px !important;
  width: 100% !important;
  border: none !important;
  background: none !important;
  border: var(--textColor) 1px solid !important;
  border-radius: var(--inputBorderRadius) !important;
}
.communityMain #productsLimitedUrl .urlBox .url {
  margin: 5px 0 0 0 !important;
}
.communityMain .communityModalTextNotice {
  margin: var(--margin) 0 0 0 !important;
  font-size: 1.4rem !important;
  text-align: center !important;
}
.communityMain .communityModalTextNotice.openLeaveModal {
  margin: 30px 0 0 0 !important;
  color: var(--textColor) !important;
  font-size: 1.4rem !important;
}
.communityModal .communityModalTextNotice {
  margin: 0 !important;
  text-align: left !important;
}
.communityMain .communityModalTextNotice a {
  text-decoration: underline;
}
.communityMain .openLeaveModal {
  margin: 3rem 0 0 0 !important;
  color: var(--textColor) !important;
}
.communityMain .communityModalButton {
  color: #fff !important;
}

@media screen and (max-width: 992px) {
  .communityMain .communityContent {
    display: block !important;
  }
  .communityMain .communityNav {
    margin: var(--padding) 0 0 0 !important;
    width: 100% !important;
  }
  .communityMain .communityOverviewWrap {
    width: 100% !important;
  }
  .communityMain #productsLimitedUrl {
    grid-template-columns: repeat(1, 1fr);
    gap: var(--imageGapHor);
  }
}
