/* setting
------------------------------------------*/
:root {
  scroll-behavior: auto;

  --bodyFontSize: 14px; /* 全体のフォントサイズ */
  --bodyLineHeight: 1.4; /* 全体の行間 */
  --bodyLineHeight2: 1.8; /* 全体の行間（Pタグなど広めの行間） */
  --bodyLetterSpacing: 0.05em; /* 全体の文字間 */

  --bodyFontFamily:  "Noto Sans JP", sans-serif; /* 全体のフォントファミリー */
  --headFontFamily: "Cormorant Garamond", "Noto Serif JP", serif; /* 見出しのフォントファミリー */

  --headFontSize: 24px; /* 見出しのフォントサイズ */
  --headFontSizeSp: 20px; /* 見出しのフォントサイズ(スマホ) */
  --headFontWeight: normal; /* 見出しのフォントウェイト */
  --headLetterSpacing: 0.2em; /* 見出しの文字間 */

  --btnFontSize: 14px; /* ボタンのフォントサイズ */
  --btnFontWeight: normal; /* ボタンのフォントウェイト */
  --btnLetterSpacing: 0.1em; /* ボタンの文字間 */

  --headerLogoHeight: 18px; /* ヘッダーのロゴの高さ 16px ~ 80px */
  --headerLogoHeightSp: 14px; /* ヘッダーのロゴの高さ(スマホ) 12px ~ 60px */

  --itemListImageAspectRatio: 3 / 4; /* 商品一覧の画像の比率 正方形は1 / 1 */

  --themeBgColor: #ffffff; /* 背景カラー */
  --themeTextColor: #262626; /* 文字カラー */
  --themeSubBgColor: #f8f4f0; /* サブ背景カラー */
  --themeSubBgColor2: #f0ece8; /* サブ背景カラー2 */
  --themeNoticeColor: #e44545; /* 注意書きカラー */
  --themeAccentBgColor: #AF9778; /* アクセント背景カラー */
  --themeAccentTextColor: #ffffff; /* アクセント文字カラー */

  --darkThemeBgColor: #1c2535; /* 背景カラー(ダークモード) */
  --darkThemeTextColor: #ffffff; /* 文字カラー(ダークモード) */
  --darkThemeSubBgColor: #2f3e58; /* サブ背景カラー(ダークモード) */
  --darkThemeSubBgColor2: #263650; /* サブ背景カラー2(ダークモード) */
  --darkThemeNoticeColor: #e44545; /* 注意書きカラー(ダークモード) */
  --darkThemeAccentBgColor: #ffffff; /* アクセント背景カラー(ダークモード) */
  --darkThemeAccentTextColor: #1c2535; /* アクセント文字カラー(ダークモード) */
}

/* base
------------------------------------------*/
html {
  scroll-padding-top: 80px;
  --headerHeight: 80px;
  --margin: 150px;
  --padding: 60px;
  --maxWidth: 1480px;
  --titleMargin: 65px;

  --itemNum: 4;
  --itemMarginV: 50px;
  --itemMarginH: 28px;

  --pageTitleHeight: 240px;
  --imageTitleHeight: 320px;

  --inputBorderRadius: 0;

  --headFontSizeL: calc(var(--headFontSize) + 14px);
  --headFontSizeS: calc(var(--headFontSize) - 2px);
  --headFontLsL: min(var(--headFontLs), 0.2em);

  --messagePadding: 80px;
}
@media (max-width: 1200px) {
  html {
    --margin: 100px;
    --padding: 50px;
    --titleMargin: 40px;

    --itemMarginV: 55px;
    --itemMarginH: 24px;

    --imageTitleHeight: 420px;

    --messagePadding: 60px;
  }
}
@media (max-width: 1000px) {
  html {
    --itemNum: 3;
    --messagePadding: 50px;
  }
}
@media (max-width: 768px) {
  html {
    scroll-padding-top: 60px;
    --headerHeight: 60px;
    --margin: 80px;
    --padding: 40px;
    --titleMargin: 30px;

    --itemMarginV: 40px;
    --itemMarginH: 20px;

    --pageTitleHeight: 180px;
    --imageTitleHeight: 320px;

    --headFontSize: var(--headFontSizeSp);
    --headFontSizeL: calc(var(--headFontSizeSp) + 10px);
    --headFontSizeS: calc(var(--headFontSizeSp) - 2px);
    --headFontLsL: min(var(--headFontLs), 0.2em);
  }
}
@media (max-width: 600px) {
  html {
    --margin: 60px;
    --padding: 30px;

    --itemNum: 2;
    --itemMarginV: 30px;
    --itemMarginH: 16px;

    --imageTitleHeight: 180px;
  }
}

body {
  --bgColor: var(--themeBgColor);
  --textColor: var(--themeTextColor);
  --subBgColor: var(--themeSubBgColor);
  --subBgColor2: var(--themeSubBgColor2);
  --noticeColor: var(--themeNoticeColor);
  --accentBgColor: var(--themeAccentBgColor);
  --accentTextColor: var(--themeAccentTextColor);
  --imageBtnBgColor: var(--themeAccentBgColor);
  --imageBtnTextColor: var(--themeAccentTextColor);
  --informationBannerBgColor: var(--themeAccentBgColor);
  --informationBannerTextColor: var(--themeAccentTextColor);
  --headerBgColor: var(--themeBgColor);
  --headerTextColor: var(--themeTextColor);
  --headerCartBgColor: var(--themeAccentBgColor);
  --headerCartTextColor: var(--themeAccentTextColor);
}

body.header-colortype-1 {
  --headerTextColor: var(--themeTextColor);
}
body.front_page.header-colortype-1.header-white-1.obverse {
  --headerTextColor: #fff;
}
body.header-colortype-2 {
  --headerBgColor: var(--themeBgColor);
  --headerTextColor: var(--themeTextColor);
}
body.header-colortype-3 {
  --headerBgColor: var(--themeAccentBgColor);
  --headerTextColor: var(--themeAccentTextColor);
  --headerCartBgColor: var(--themeAccentTextColor);
  --headerCartTextColor: var(--themeAccentBgColor);
  --informationBannerBgColor: var(--themeSubBgColor);
  --informationBannerTextColor: var(--themeAccentBgColor);
}

@media (prefers-color-scheme: dark) {
  body.darkmode-1 {
    --bgColor: var(--darkThemeBgColor);
    --textColor: var(--darkThemeTextColor);
    --subBgColor: var(--darkThemeSubBgColor);
    --subBgColor2: var(--darkThemeSubBgColor2);
    --noticeColor: var(--darkThemeNoticeColor);
    --accentBgColor: var(--darkThemeAccentBgColor);
    --accentTextColor: var(--darkThemeAccentTextColor);
    --imageBtnBgColor: var(--darkThemeAccentBgColor);
    --imageBtnTextColor: var(--darkThemeAccentTextColor);
    --informationBannerBgColor: var(--darkThemeSubBgColor);
    --informationBannerTextColor: var(--darkThemeAccentBgColor);
    --headerBgColor: var(--darkThemeBgColor);
    --headerTextColor: var(--darkThemeTextColor);
    --headerCartBgColor: var(--darkThemeAccentBgColor) !important;
    --headerCartTextColor: var(--darkThemeAccentTextColor) !important;
  }
}

*,
*:before,
*:after {
  outline: none;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html {
  background: var(--bgColor);
}
body {
  color: var(--textColor);
  font-size: var(--bodyFontSize);
  font-family: var(--bodyFontFamily);
  line-height: var(--bodyLineHeight);
  letter-spacing: var(--bodyLetterSpacing);
  word-break: break-word;
  overflow-wrap: break-word;
}
h1,
h2,
h3,
h4,
.mv .text .sub,
.mv .text .title,
.concept .text .sub,
.concept .text .title,
.access .text .title,
.footer-info .text .title,
.footer-guide-once .title {
  font-size: var(--headFontSize);
  font-weight: var(--headFontWeight);
  font-family: var(--headFontFamily);
  line-height: var(--bodyLineHeight);
  letter-spacing: var(--headLetterSpacing);
}
a,
a:hover {
  color: var(--textColor);
  text-decoration: underline;
  transition: all 0.3s ease;
}
@media (hover: hover) {
  a:hover {
    opacity: 0.7;
    color: var(--textColor);
  }
}
img {
  max-width: 100%;
}
::placeholder {
  opacity: 0.4 !important;
}

.ec-layoutRole {
  overflow: clip;
  background: var(--bgColor);
}
.ec-layoutRole .ec-layoutRole__contents {
  opacity: 0;
  margin: 0 auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
  transition: all 1s ease;
}
.ec-layoutRole .ec-layoutRole__contents.viewed {
  opacity: 1;
}
.front_page .ec-layoutRole .ec-layoutRole__contents {
  opacity: 1;
  padding: 0;
  max-width: 100%;
  filter: blur(0);
}
.ec-role {
  margin: 0;
  padding: 0;
  max-width: 100%;
  color: var(--textColor);
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight);
}
.bg-load-overlay{
  opacity: 0.4;
  background: var(--bgColor);
}

/* btn, input
------------------------------------------*/
.ec-inlineBtn--cancel,
.ec-inlineBtn--action,
.ec-inlineBtn,
.ec-blockBtn--cancel,
.ec-blockBtn--action,
.ec-blockBtn,
.btn-image a,
.btn-normal a {
  outline: none !important;
  cursor: pointer;
  display: block;
  margin: 0 auto;
  padding: 14px 5px;
  width: 100%;
  height: auto;
  color: var(--textColor) !important;
  font-size: var(--btnFontSize) !important;
  font-weight: var(--btnFontWeight) !important;
  text-align: center;
  line-height: 1;
  letter-spacing: var(--btnLetterSpacing);
  text-decoration: none;
  background: none !important;
  border: #c9c9c9 1px solid !important;
  border-radius: 0;
  box-shadow: none !important;
  transition: all 0.3s ease;
  appearance: none;
  font-family: var(--headFontFamily);
}
.ec-inlineBtn--cancel,
.ec-inlineBtn--action,
.ec-inlineBtn {
  margin: 0;
  max-width: 200px;
}
.ec-inlineBtn--action,
.ec-blockBtn--action,
.ec-mypageRole .ec-blockBtn--cancel,
.ec-orderDelivery__change .ec-inlineBtn,
.ec-orderDelivery__edit .ec-inlineBtn {
  color: var(--imageBtnTextColor) !important;
  background: var(--imageBtnBgColor) !important;
  border: var(--imageBtnBgColor) 1px solid !important;
}
.btn-image,
.btn-normal {
  margin: 50px 0 0 0;
}
.btn-image a,
.btn-normal a {
  width: 200px;
}
.btn-image a {
  color: var(--imageBtnTextColor) !important;
  background: var(--imageBtnBgColor) !important;
  border: none !important;
}
@media (hover: hover) {
  .ec-inlineBtn--cancel:hover,
  .ec-inlineBtn--action:hover,
  .ec-inlineBtn:hover,
  .ec-blockBtn--cancel:hover,
  .ec-blockBtn--action:hover,
  .ec-blockBtn:hover {
    opacity: 0.7;
  }
}
@media (max-width: 768px) {
  .ec-inlineBtn {
    min-width: auto;
  }
}

.ec-layoutRole__main input[type="text"],
.ec-layoutRole__main input[type="number"],
.ec-layoutRole__main input[type="email"],
.ec-layoutRole__main input[type="password"],
.ec-layoutRole__main input[type="tel"],
.ec-layoutRole__main textarea,
.ec-layoutRole__main select {
  display: block;
  margin: 0 0 8px 0 !important;
  padding: 12px;
  width: 100%;
  height: auto;
  color: var(--textColor);
  font-size: var(--bodyFontSize);
  font-family: var(--bodyFontFamily);
  line-height: var(--bodyLineHeight);
  background: none;
  border: #8c8c8c 1px solid;
  border-radius: var(--inputBorderRadius);
  transition: all 0.3s ease;
  appearance: none;
}
.ec-layoutRole__main input[type="text"]:focus,
.ec-layoutRole__main input[type="number"]:focus,
.ec-layoutRole__main input[type="email"]:focus,
.ec-layoutRole__main input[type="password"]:focus,
.ec-layoutRole__main input[type="tel"]:focus,
.ec-layoutRole__main textarea:focus,
.ec-layoutRole__main select:focus {
  border: var(--accentBgColor) 1px solid;
  box-shadow: none;
}
.ec-layoutRole__main input[type="tel"] {
  display: inline-block;
}
.ec-layoutRole__main textarea {
  height: 200px;
}
.ec-layoutRole__main select,
.ec-layoutRole__main select:focus {
  display: inline-block;
  padding: 12px 24px 12px 12px;
  width: auto;
  height: auto !important;
  max-width: 100% !important;
  min-width: auto !important;
  background: linear-gradient(45deg, transparent 50%, var(--textColor) 50%)
      no-repeat center right 14px/4px 4px,
    linear-gradient(-45deg, transparent 50%, var(--textColor) 50%) no-repeat
      center right 10px/4px 4px;
  background-color: var(--bgColor);
}
.ec-layoutRole__main select:focus {
  border: var(--accentBgColor) 1px solid;
}
.ec-select {
  margin: 0;
}
.ec-selects {
  padding: 0 0 12px 0;
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-halfInput {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 8px;
}
.ec-halfInput input,
.ec-halfInput p {
  width: calc(50% - 4px) !important;
}
.ec-birth span {
  margin: 0 5px;
}

.ec-layoutRole__main .error input,
.ec-layoutRole__main .error select,
.ec-layoutRole__main .error textarea {
  background: var(--bgColor);
  border: var(--noticeColor) 1px solid;
}
.ec-layoutRole__main .error select {
  background: linear-gradient(45deg, transparent 50%, var(--textColor) 50%)
      no-repeat center right 14px/4px 4px,
    linear-gradient(-45deg, transparent 50%, var(--textColor) 50%) no-repeat
      center right 10px/4px 4px;
}
.error.ec-checkbox div,
.error.ec-checkbox input,
.error.ec-checkbox label,
.error.ec-radio div,
.error.ec-radio input,
.error.ec-radio label {
  background: none;
  border: none;
}
.ec-layoutRole__main .ec-errorMessage {
  margin: 0 0 8px 0;
  color: var(--noticeColor);
}

.ec-modal .ec-modal-wrap {
  padding: 30px;
  max-width: 800px;
  background: var(--bgColor);
  border: none;
  border-radius: 3px;
}
.ec-modal .ec-modal-close {
  top: 5px;
  right: 5px;
  height: 30px;
  width: 30px;
}
.ec-modal .ec-modal-close span {
  display: none;
}
.ec-modal .ec-modal-close:before,
.ec-modal .ec-modal-close:after {
  content: "";
  position: absolute;
  top: 14px;
  left: 5px;
  width: 20px;
  height: 2px;
  background: var(--textColor);
  border-radius: 1px;
}
.ec-modal .ec-modal-close:before {
  transform: rotate(45deg);
}
.ec-modal .ec-modal-close:after {
  transform: rotate(-45deg);
}
.ec-modal-header {
  font-size: var(--bodyFontSize);
}
.ec-modal .ec-role {
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 0;
}
.ec-modal .ec-role span,
.ec-modal .ec-role a {
  max-width: 300px;
}

/* drawer
------------------------------------------*/
.drawer-bg {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.7);
  transition: all 0.4s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 10002;
}
.drawer-bg.open {
  opacity: 1;
  visibility: visible;
  transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.drawer {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  width: min(80%, 320px);
  height: 100vh;
  color: var(--textColor);
  background: var(--subBgColor);
  z-index: 10003;
  transform: translateX(-100%);
  transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.drawer.open {
  transform: translateX(0);
  transition: all 0.4s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.drawer-close {
  cursor: pointer;
  position: relative;
  height: 50px;
}
.drawer-close:before,
.drawer-close:after {
  content: "";
  position: absolute;
  top: 25px;
  right: 17px;
  width: 20px;
  height: 1px;
  background: var(--textColor);
  transform: rotate(45deg);
}
.drawer-close:after {
  transform: rotate(-45deg);
}
.drawer-search {
  margin: 25px 25px 30px 25px;
}
.drawer-search form {
  display: flex;
  justify-content: space-between;
  margin: 25px 0 0 0;
  padding: 5px 5px 5px 15px;
  width: 100%;
  border: #8c8c8c 1px solid;
  transition: all 0.3s ease;
}
.drawer-search form input {
  width: calc(100% - 34px);
  color: var(--textColor);
  line-height: 1;
  background: none;
  border: none;
}
.drawer-search form input::placeholder {
  color: inherit;
}
.drawer-search form button {
  width: 32px;
  height: 32px;
  text-align: center;
  background: none;
  border: none;
}
.drawer-search form button svg {
  margin: 0 auto;
  width: 18px;
  fill: var(--textColor);
}

.drawer ul {
  padding: 0;
  list-style: none;
}
.drawer a {
  display: block;
  padding: 8px 30px 8px 0;
  color: var(--textColor);
  text-decoration: none;
}
.drawer-menu {
  margin: 25px;
  font-size: 13px;
}

.drawer-category {
  margin: 25px 25px 35px 25px;
  font-size: 13px;
}
.drawer-category span {
  display: none;
}
.drawer-category > ul > li {
  position: relative;
  padding: 10px 0;
  border-bottom: var(--drawerBorderColor) 1px solid;
}
.drawer-category > ul > li:after {
  content: '';
  opacity: 0.1;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--textColor);
}
.drawer-category > ul > li > span {
  content: "";
  cursor: pointer;
  display: block;
  position: absolute;
  top: 11px;
  right: 0;
  width: 31px;
  height: 31px;
  transition: all 0.3s ease;
  z-index: 1;
}
.drawer-category > ul > li > span:before,
.drawer-category > ul > li > span:after {
  content: "";
  position: absolute;
  top: 15px;
  left: 9px;
  width: 13px;
  height: 1px;
  background: var(--textColor);
  transition: all 0.3s ease;
}
.drawer-category > ul > li > span:after {
  top: 9px;
  left: 15px;
  width: 1px;
  height: 13px;
}
.drawer-category > ul > li > span.open:before {
  opacity: 0;
  transform: rotate(90deg);
}
.drawer-category > ul > li > span.open:after {
  transform: rotate(90deg);
}

.drawer-category > ul > li > ul {
  display: none;
}
.drawer-category > ul > li > ul:before,
.drawer-category > ul > li > ul:after {
  content: "";
  display: block;
  height: 8px;
}
.drawer-category > ul > li > ul > li > a {
  padding: 8px 0 8px 10px;
}
.drawer-category > ul > li > ul > li ul {
  padding: 6px 0 6px 20px;
}
.drawer-category > ul > li > ul > li ul a {
  padding: 6px 0;
}

.drawer-copyright {
  opacity: 0.5;
  padding: 25px;
  font-size: 10px;
  text-align: center;
}

/* header
------------------------------------------*/
.header-search-bg {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.7);
  transition: all 0.4s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 10002;
}
.header-search-bg.open {
  opacity: 1;
  visibility: visible;
  transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.header-search-modal {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: calc(var(--headerHeight) * -1);
  left: 50%;
  padding: var(--padding);
  width: min(100%, 800px);
  height: var(--headerHeight);
  transform: translateX(-50%);
  transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
  z-index: 10003;
}
.header-search-modal.open {
  opacity: 1;
  visibility: visible;
  top: 0;
  transition: all 0.4s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.header-search-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 100%;
  height: 100%;
}
.header-search {
  display: flex;
  justify-content: space-between;
  padding: 6px 6px 6px 18px;
  width: 100%;
  border: #fff 2px solid;
  border-radius: 100px;
  transition: all 0.3s ease;
}
.header-search input {
  display: block;
  padding: 0;
  margin: 0;
  width: calc(100% - 34px);
  height: auto;
  color: #fff;
  font-size: 14px;
  line-height: 1;
  background: none;
  border: none;
}
.header-search input::placeholder {
  color: inherit;
}
.header-search button {
  appearance: none;
  width: 36px;
  height: 36px;
  text-align: center;
  background: none;
  border: none;
}
.header-search button svg {
  margin: 0 auto;
  width: 22px;
  fill: #fff;
}
.header-search-wrap .close {
  cursor: pointer;
  position: relative;
  margin: 0 0 0 10px;
  width: 41px;
  height: 41px;
}
.header-search-wrap .close:before,
.header-search-wrap .close:after {
  content: '';
  position: absolute;
  top: 20px;
  left: 6px;
  width: 25px;
  height: 2px;
  background: #fff;
  transform: rotate(45deg);
}
.header-search-wrap .close:after {
  transform: rotate(-45deg);
}

.information {
  opacity: 0;
  display: grid;
  place-items: center;
  position: relative;
  padding: 0 10px;
  height: 40px;
  color: var(--informationBannerTextColor);
  font-size: 11px;
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
  background: var(--informationBannerBgColor);
  transition: all 1s ease;
}
.loaded .information {
  opacity: 1;
}
.information a {
  color: var(--informationBannerTextColor);
}

.header {
  opacity: 0;
  display: flex;
  align-items: center;
  position: sticky;
  top: 0;
  padding: 0 22px;
  width: 100%;
  height: var(--headerHeight);
  color: var(--headerTextColor);
  background: var(--headerBgColor);
  transition: all 1s ease;
  z-index: 1001;
}
.header-colortype-1 .header {
  background: none;
}
.loaded .header {
  opacity: 1;
}
.drawer-open-wrap{
  font-family: var(--headFontFamily);
}
.header-type-3 .drawer-open-wrap {
  width: 30%;
}
.drawer-open {
  cursor: pointer;
  display: block;
  position: relative;
  width: 36px;
  height: 36px;
}
.drawer-open span,
.drawer-open span:before,
.drawer-open span:after {
  content: '';
  position: absolute;
  top: 17px;
  left: 10px;
  width: 20px;
  height: 2px;
  background: var(--headerTextColor);
  transition: all 0.3s ease;
}
.drawer-open span:before {
  top: -6px;
  left: 0;
}
.drawer-open span:after {
  top: 6px;
  left: 0;
}
@media (hover: hover) {
  .drawer-open:hover span,
  .drawer-open:hover span:before,
  .drawer-open:hover span:after {
    left: 6px;
  }
}
.front_page .drawer-open span,
.front_page .drawer-open span:before,
.front_page .drawer-open span:after {
  background: var(--headerTextColor);
}

.logo {
  position: relative;
  margin: 0 30px 0 15px;
  max-width: 40%;
}
.header-type-3 .logo {
  margin: 0;
  width: 40%;
}
.logo a {
  display: block;
  height: 100%;
  text-align: center;
  transition: all 0.3s ease;
}
.logo a img {
  object-fit: contain;
  display: block;
  margin: 0 auto;
  width: auto;
  height: clamp(16px, var(--headerLogoHeight), var(--headerHeight));
  transition: all 0.3s ease;
}
.front_page.header-colortype-1.header-white-1.obverse .logo a img {
  filter: brightness(0) invert(1);
}
@media (prefers-color-scheme: dark) {
  .darkmode-1.darkmodelogowhite-1 .logo a img {
    filter: brightness(0) invert(1) !important;
  }
}

.header-menu {
  display: flex;
  align-items: center;
  gap: 50px;
  margin: 0 auto 0 50px;
  padding: 0;
  width: calc(50% - 110px);
  height: 100%;
  list-style: none;
  font-family: var(--headFontFamily);
}
.header-type-2 .header-menu,
.header-type-3 .header-menu {
  display: none;
}
.header-menu > li {
  position: relative;
}
.header-menu > li > a {
  display: block;
  height: 38px;
  color: var(--headerTextColor);
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 38px;
  text-decoration: none;
  
}
.header-category ul,
.header-btn-user ul {
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 100%;
  left: calc(50% - 90px);
  padding: 20px;
  width: 180px;
  max-height: 80vh;
  color: var(--textColor);
  list-style: none;
  background: var(--subBgColor2);
  box-shadow: 0 20px 20px -20px rgba(0, 0, 0, 0.2);
  transition: all 0.3s ease;
  transform: translateY(20px);
}
.header-btn-user ul {
  left: calc(50% - 75px);
  width: 150px;
}
.header-category.hover ul,
.header-btn-user.hover ul {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.header-category ul a,
.header-btn-user ul a {
  display: block;
  position: relative;
  padding: 8px 0;
  color: var(--textColor);
  font-size: 12px;
  text-decoration: none;
}
@media (hover: hover) {
  .header-category ul a:hover,
  .header-btn-user ul a:hover {
    opacity: 0.7;
  }
}

.header-btn {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  margin: 0 0 0 auto;
  padding: 0 3px 0 0;
}
.header-type-3 .header-btn {
  margin: 0;
  width: 30%;
}
.header-btn > div {
  position: relative;
}
.header-btn > div > span,
.header-btn > div > a {
  cursor: pointer;
  display: grid;
  place-items: center;
  position: relative;
  width: 38px;
  height: 38px;
  transition: all 0.3s ease;
}
@media (hover: hover) {
  .header-btn > div > span:hover,
  .header-btn > div > a:hover {
    opacity: 0.7;
  }
}
.header-btn > div > span svg,
.header-btn > div > a svg {
  width: 19px;
  fill: var(--headerTextColor);
  transition: all 0.3s ease;
}
.header-btn-cart span span {
  position: absolute;
  top: 0;
  right: -6px;
  padding: 1px 0 0 0;
  width: 18px;
  height: 18px;
  color: var(--headerCartTextColor);
  font-size: 11px;
  line-height: 16px;
  letter-spacing: 0;
  text-align: center;
  background: var(--headerCartBgColor);
  border-radius: 50%;
  transition: all 0.3s ease;
}
.header-btn-cart span span.empty {
  display: none;
}

@media (max-width: 1000px) {
  .header-menu {
    display: none;
  }
}
@media (max-width: 768px) {
  .header {
    padding: 0 10px;
  }
  .drawer-open-wrap {
    width: 20%;
  }
  .logo {
    margin: 0 auto;
    width: 60%;
    max-width: 60%;
  }
  .logo a img {
    height: clamp(12px, var(--headerLogoHeightSp), var(--headerHeight));
  }
  .header-btn {
    width: 20%;
  }
  .header-btn-search {
    display: none;
  }
}
@media (max-width: 400px) {
  .header-btn-user {
    display: none;
  }
}

.header-cart-bg {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.7);
  transition: all 0.4s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 10002;
}
.header-cart-bg.open {
  opacity: 1;
  visibility: visible;
  transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.header-cart {
  overflow: auto;
  position: fixed;
  top: 0;
  right: 0;
  width: min(80%, 320px);
  height: 100vh;
  color: var(--textColor);
  background: var(--subBgColor);
  z-index: 10003;
  transform: translateX(100%);
  transition: all 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.header-cart.open {
  transform: translateX(0);
  transition: all 0.4s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.ec-cartNavi {
  align-items: center;
  padding: 15px 20px;
  height: auto;
  min-width: 100%;
  color: var(--accentTextColor);
  background: var(--accentBgColor);
  border-radius: 0;
}
.ec-cartNavi .ec-cartNavi__icon {
  display: flex;
  align-items: center;
  font-size: 14px;
  font-style: normal;
}
.ec-cartNavi .ec-cartNavi__badge {
  position: relative;
  top: auto;
  left: auto;
  padding: 0;
  height: auto;
  color: var(--accentTextColor);
  font-size: 14px;
  font-weight: bold;
  line-height: 1;
  vertical-align: baseline;
  background: none;
}
.ec-cartNavi .ec-cartNavi__badge:after {
  content: '点';
  margin: 0 0 0 3px;
}
.ec-cartNavi .ec-cartNavi__price {
  line-height: 1;
  vertical-align: baseline;
}
.ec-cartNaviIsset {
  overflow: auto;
  display: block;
  margin: 0;
  padding: 20px;
  min-width: 100%;
  max-width: 100%;
  background: none;
}
.ec-cartNaviIsset:before {
  display: none;
}
.ec-cartNaviIsset .ec-cartNaviIsset__cart {
  position: relative;
  margin: 0 0 15px 0;
  padding: 0 0 15px 0;
  border: none;
}
.ec-cartNaviIsset .ec-cartNaviIsset__cart:before {
  content: '';
  opacity: 0.1;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--textColor);
}
.ec-cartNaviIsset .ec-cartNaviIsset__cartImage {
  width: 25%;
}
.ec-cartNaviIsset .ec-cartNaviIsset__cartContent {
  width: 75%;
}
.ec-cartNaviIsset .ec-cartNaviIsset__cartContentTax {
  font-size: 11px;
}
.ec-cartNaviIsset .ec-cartNaviIsset__cartContentNumber {
  margin: 8px 0 0 0;
  font-size: 12px;
}
.ec-cartNaviNull {
  display: block;
  position: relative;
  top: auto;
  margin: 0;
  padding: 0;
  min-width: 100%;
  max-width: 100%;
  background: none;
}
.ec-cartNaviNull:before {
  display: none;
}
.ec-cartNaviNull .ec-cartNaviNull__message {
  margin: 30px 0 0 0;
  padding: 0;
  color: var(--textColor);
  font-size: 14px;
  font-weight: normal;
  background: none;
  border: none;
}

/* footer
------------------------------------------*/
.footer-info {
  overflow: hidden;
  position: relative;
}
.footer-info .image {
  opacity: 0;
  overflow: hidden;
  width: 100%;
  height: 60vh;
  min-height: 500px;
  transform: scale(1.2);
  filter: blur(20px);
  transition: all 1s ease;
}
.footer-info.viewed .image {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
}
.footer-info .image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.footer-info .text {
  opacity: 0;
  position: absolute;
  bottom: var(--padding);
  right: var(--padding);
  padding: var(--padding);
  width: 35vw;
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.footer-info.viewed .text {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.footer-info .text:before {
  content: '';
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--subBgColor);
  transition: all 0.6s ease;
  z-index: -1;
}
.footer-info.viewed .text:before {
  opacity: 0.8;
}
.footer-info .text .title {
  margin: 0 0 25px 0;
  font-size: 18px;
}
.footer-info .text p {
  font-size: 13px;
  line-height: var(--bodyLineHeight2);
}
.footer-info .text .btn-normal {
  margin: 30px 0 0 0;
}
@media (max-width: 768px) {
  .footer-info .image {
    height: 32vh;
    min-height: 0;
  }
  .footer-info .text {
    position: relative;
    bottom: auto;
    right: auto;
    padding: min(var(--margin), 60px) var(--padding);
    width: 100%;
    z-index: 1;
  }
  .footer-info.viewed .text:before {
    opacity: 1;
  }
}

.footer-guide-wrap {
  opacity: 0;
  margin: var(--margin) 0 0 0;
  background: var(--subBgColor2);
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.front_page .footer-guide-wrap {
  margin: -1px 0 0 0;
}
.footer-guide-wrap.viewed {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.footer-guide {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  position: relative;
  margin: 0 auto;
  padding: min(var(--margin), 60px) var(--padding);
  max-width: var(--maxWidth);
  width: 100%;
}
.footer-guide-once {
  position: relative;
  padding: 0 30px;
  text-align: center;
}
.footer-guide-once:not(:last-child):after {
  content: '';
  opacity: 0.1;
  position: absolute;
  top: 50%;
  right: 0;
  width: 1px;
  height: 50%;
  background: var(--textColor);
  transform: translateY(-50%);
}
.footer-guide-once .image {
  margin: 0 auto;
  width: 50px;
}
.footer-guide-once .title {
  margin: 15px auto;
  font-size: 14px;
}
.footer-guide-once p {
  opacity: 0.7;
  margin: 0;
  font-size: 12px;
  line-height: var(--bodyLineHeight2);
}
@media (max-width: 768px) {
  .footer-guide {
    grid-template-columns: repeat(1, 1fr);
    gap: var(--padding);
  }
  .footer-guide-once {
    padding: 0 0 0 70px;
    text-align: left;
  }
  .footer-guide-once:not(:last-child):after {
    display: none;
  }
  .footer-guide-once .image {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
  }
  .footer-guide-once .title {
    margin: 0 0 10px 0;
  }
}
@media (prefers-color-scheme: dark) {
  body.darkmode-1 .footer-guide-once .image img {
    filter: brightness(0) invert(1) !important;
  }
}

.footer {
  opacity: 0;
  color: var(--textColor);
  background: var(--subBgColor);
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s 0.2s ease;
  margin: 8vh 0 calc(50% - var(--vw) * 50)  calc(50% - var(--vw) * 50);
}
.front_page .footer{
  margin: 0;
}
.footer.viewed {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.footer a {
  color: var(--textColor);
  text-decoration: none;
}
.footer-top {
  display: flex;
  gap: var(--padding);
  margin: 0 auto;
  padding: min(var(--margin), 60px) var(--padding);
  max-width: var(--maxWidth);
  line-height: 2;
}
.footer-about {
  width: 25%;
}
.footer-menu {
  width: 100%;
  font-family: var(--headFontFamily);

}
.footer-top h3 {
  margin: 0 0 20px 0;
  font-size: 14px;
}
.footer-top h3 span{
  font-size: 11px;
}
.footer-about p {
  margin: 0 0 12px 0;
  font-size: 11px;
}
.footer-about p:last-child {
  margin: 0;
}
.footer-menu ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 50px;
  margin: 0 auto 0 0;
  justify-content: center;
  flex-wrap: wrap;
}
.footer-menu ul li {
  margin: 0 0 3px 0;
  font-size: 12px;
}
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  margin: 0 auto;
  padding: min(var(--margin), 20px) var(--padding);
  max-width: var(--maxWidth);
}
.footer-bottom:before {
  content: '';
  opacity: 0.1;
  position: absolute;
  top: 0;
  left: var(--padding);
  width: calc(100% - var(--padding) - var(--padding));
  height: 1px;
  background: var(--textColor);
}
.footer-copyright ul {
  display: flex;
  gap: 10px;
  margin: 0 0 5px 0;
  padding: 0;
  list-style: none;
  font-family: var(--headFontFamily);

}
.footer-copyright ul li a {
  font-size: 10px;
}
.footer-copyright p {
  opacity: 0.7;
  margin: 0;
  font-size: 10px;
}
.footer-sns {
  display: flex;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.footer-sns a {
  display: block;
  width: 24px;
}
.footer-sns a svg {
  width: 24px;
  fill: var(--textColor);
}

@media (max-width: 768px) {
  .footer-top {
    flex-direction: column;
  }
  .footer-top h3 {
    position: relative;
    padding: 0 0 10px 0;
  }
  .footer-top h3:before,
  .footer-top h3:after {
    content: '';
    opacity: 0.15;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: var(--textColor);
  }
  .footer-top h3:before {
    opacity: 1;
    width: 50px;
  }
  .footer-about,
  .footer-menu {
    width: 100%;
  }
  .footer-bottom {
    padding-top: 0;
    flex-direction: column-reverse;
    text-align: center;
  }
  .footer-bottom:before {
    display: none;
  }
  .footer-copyright ul {
    justify-content: center;
  }
  .footer-sns {
    margin: 0 0 var(--margin) 0;
    justify-content: center;
  }
}

/* common, mypage, order
------------------------------------------*/
.ec-rectHeading .h1,
.ec-rectHeading .h2,
.ec-rectHeading .h3,
.ec-rectHeading .h4,
.ec-rectHeading .h5,
.ec-rectHeading .h6,
.ec-rectHeading h1,
.ec-rectHeading h2,
.ec-rectHeading h3,
.ec-rectHeading h4,
.ec-rectHeading h5,
.ec-rectHeading h6 {
  margin: 40px 0 20px 0;
  padding: 0 0 10px 0;
  font-size: calc(var(--bodyFontSize) + 6px);
  background: none;
  border-bottom: #8c8c8c 1px solid;
}
.ec-birth p,
.ec-halfInput p,
.ec-input p,
.ec-numberInput p,
.ec-select p,
.ec-telInput p,
.ec-zipInput p {
  line-height: var(--bodyLineHeight);
}
.ec-color-red {
  color: var(--noticeColor);
}
.ec-link,
.ec-link:hover {
  color: var(--textColor);
  text-decoration: underline;
}
.ec-para-normal {
  margin: 0;
}
.ec-borderedDefs {
  border-top: var(--subBorderColor) 1px solid;
}
.ec-borderedDefs dl {
  padding: 20px 0 12px 0;
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-required {
  color: var(--noticeColor);
}
.ec-zipInputHelp .ec-zipInputHelp__icon {
  display: none;
}
.ec-zipInputHelp span {
  margin: 0;
  color: var(--textColor);
  text-decoration: underline;
}
.ec-pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  margin: 50px 0 0 0;
  padding: 0;
}
.ec-pager .ec-pager__item,
.ec-pager .ec-pager__item--active {
  padding: 0;
  min-width: auto;
  background: none;
}
.ec-pager .ec-pager__item a,
.ec-pager .ec-pager__item--active a {
  padding: 8px 12px;
  font-size: 13px;
  line-height: 1;
  border: #8c8c8c 1px solid;
  border-radius: var(--inputBorderRadius);
}
.ec-pager .ec-pager__item--active a {
  color: var(--bgColor);
  background: var(--textColor);
}

.ec-alert-warning {
  background: var(--noticeColor);
}
.ec-alert-warning .ec-alert-warning__text {
  font-size: var(--bodyFontSize);
}
.ec-alert-warning .ec-alert-warning__icon img {
  display: none;
}
.ec-alert-warning .ec-alert-warning__icon:before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%20-0.5%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M13.7744%201.41218L23.4802%2020.0771C23.9898%2021.0571%2023.6085%2022.2646%2022.6285%2022.7742C22.3435%2022.9224%2022.027%2022.9998%2021.7058%2022.9998H2.29425C1.18968%2022.9998%200.29425%2022.1044%200.29425%2020.9998C0.29425%2020.6786%200.371621%2020.3621%200.519817%2020.0771L10.2256%201.41218C10.7352%200.432187%2011.9427%200.0508554%2012.9227%200.560452C13.2874%200.75009%2013.5848%201.04749%2013.7744%201.41218ZM10.5%209.49981V13.9998C10.5%2014.8282%2011.1716%2015.4998%2012%2015.4998C12.8284%2015.4998%2013.5%2014.8282%2013.5%2013.9998V9.49981C13.5%208.67138%2012.8284%207.99981%2012%207.99981C11.1716%207.99981%2010.5%208.67138%2010.5%209.49981ZM12%2019.9998C12.8284%2019.9998%2013.5%2019.3282%2013.5%2018.4998C13.5%2017.6714%2012.8284%2016.9998%2012%2016.9998C11.1716%2016.9998%2010.5%2017.6714%2010.5%2018.4998C10.5%2019.3282%2011.1716%2019.9998%2012%2019.9998Z%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center center / 18px;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%20-0.5%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M13.7744%201.41218L23.4802%2020.0771C23.9898%2021.0571%2023.6085%2022.2646%2022.6285%2022.7742C22.3435%2022.9224%2022.027%2022.9998%2021.7058%2022.9998H2.29425C1.18968%2022.9998%200.29425%2022.1044%200.29425%2020.9998C0.29425%2020.6786%200.371621%2020.3621%200.519817%2020.0771L10.2256%201.41218C10.7352%200.432187%2011.9427%200.0508554%2012.9227%200.560452C13.2874%200.75009%2013.5848%201.04749%2013.7744%201.41218ZM10.5%209.49981V13.9998C10.5%2014.8282%2011.1716%2015.4998%2012%2015.4998C12.8284%2015.4998%2013.5%2014.8282%2013.5%2013.9998V9.49981C13.5%208.67138%2012.8284%207.99981%2012%207.99981C11.1716%207.99981%2010.5%208.67138%2010.5%209.49981ZM12%2019.9998C12.8284%2019.9998%2013.5%2019.3282%2013.5%2018.4998C13.5%2017.6714%2012.8284%2016.9998%2012%2016.9998C11.1716%2016.9998%2010.5%2017.6714%2010.5%2018.4998C10.5%2019.3282%2011.1716%2019.9998%2012%2019.9998Z%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center center / 18px;
  background-color: #fff;
}

/* breadcrumbs */
.breadcrumbs {
  display: none;
}
.breadcrumbs.moving {
  display: block;
}
.breadcrumbs ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 15px 0;
  padding: 0;
  font-size: 11px;
  list-style: none;
}
.breadcrumbs ul li {
  display: flex;
  align-items: center;
}
.breadcrumbs ul li:not(:last-child):after {
  content: '/';
  margin: 0 8px;
}
.breadcrumbs ul li a {
  text-decoration: none;
}
.image-title-white-1 .ec-categoryHeader .breadcrumbs,
.image-title-white-1 .ec-categoryHeader .breadcrumbs a {
  color: #fff;
}

/* pageHeader */
.ec-pageHeader,
.ec-categoryHeader {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin: 0 calc(50% - var(--vw) * 50) 8vh calc(50% - var(--vw) * 50);
  height: var(--pageTitleHeight);
  width: calc(var(--vw) * 100);
  background: var(--subBgColor);
}
.ec-categoryHeader {
  margin: 0 calc(50% - var(--vw) * 50) 6vh calc(50% - var(--vw) * 50);
  height: var(--imageTitleHeight);
  background: no-repeat center center / cover;
}
.image-title-position-1 .ec-categoryHeader {
  padding: var(--padding);
  justify-content: flex-end;
  align-items: flex-start;
}
.ec-pageHeader h1,
.ec-categoryHeader h1 {
  margin: 0 !important;
  padding: 0 !important;
  color: var(--textColor);
  font-size: var(--headFontSizeL);
  font-weight: var(--headFontWeight);
  font-family: var(--headFontFamily);
  line-height: var(--bodyLineHeight);
  letter-spacing: var(--headLetterSpacing);
  text-indent: var(--headLetterSpacing);
  border: none;
}
.image-title-white-1 .ec-categoryHeader h1 {
  color: #fff;
}


.ec-off1Grid .ec-off1Grid__cell,
.ec-off2Grid .ec-off2Grid__cell,
.ec-cartRole,
.ec-cartCompleteRole,
.ec-contactConfirmRole,
.ec-contactCompleteRole,
.ec-contactRole,
.ec-login,
.ec-registerRole,
.ec-registerCompleteRole,
.ec-forgotRole,
.ec-forgetCompleteRole,
.ec-mypageRole,
.ec-orderRole,
.ec-withdrawRole,
.ec-shelfRole,
#page_shopping_login .ec-grid3 {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  max-width: 1100px;
  color: var(--textColor);
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight);
}
.ec-login {
  max-width: 600px;
}
.ec-cartRole .ec-cartRole__cart,
.ec-forgotRole .ec-forgotRole__form {
  margin: 0;
}

.ec-RegisterRole__actions {
  margin: 40px 0 0 0;
}

/* contact */
.ec-contactRole p.ec-para-normal,
.ec-contactConfirmRole p {
  margin: 0 0 40px 0;
  line-height: 1.8;
}
.ec-contactRole .ec-borderedDefs p {
  font-size: 12px;
}
.ec-contactConfirmRole .ec-RegisterRole__actions {
  margin: 40px 0 0 0;
}
.ec-contactConfirmRole .ec-blockBtn--action {
  margin: 0 0 10px 0;
}

/* login */
.ec-login {
  padding: 0;
  background: none;
}
.ec-login__icon {
  display: none;
}
.ec-login .ec-login__link {
  margin: 3px 20px;
}

.ec-guest {
  margin: 0 0 0 40px;
  background: var(--subBgColor);
}
@media (max-width: 768px) {
  .ec-login .ec-login__link {
    margin: 12px 0;
  }
  .ec-guest {
    margin: 50px 0 0 0;
  }
}

/* entry */
.ec-registerRole .ec-blockBtn--action {
  margin: 0 0 10px 0;
}
.ec-registerRole form p {
  margin: 0 0 40px 0;
  line-height: 1.8;
}
.ec-registerRole .ec-registerRole__actions {
  padding: 20px 0 0 0;
}
.ec-registerRole .ec-registerRole__actions .ec-checkbox label {
  margin: 0 0 20px 0;
}

/* foget */
.ec-forgotRole .ec-forgotRole__intro {
  margin: 0 0 40px 0;
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight2);
}
.ec-forgotRole .ec-off4Grid {
  margin: 40px 0 0 0;
}

/* complete */
.ec-reportHeading,
.ec-reportHeading h2 {
  margin: 0;
  padding: 0;
  font-size: var(--headFontSize);
  font-weight: var(--headFontWeight);
  border: none;
}
.ec-reportHeading {
  margin: 0 0 20px 0;
}
.ec-reportDescription {
  margin: 0 0 30px 0;
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight2);
}
.ec-cartCompleteRole .ec-off3Grid .ec-off3Grid__cell,
.ec-contactCompleteRole .ec-off3Grid .ec-off3Grid__cell,
.ec-registerCompleteRole .ec-off3Grid .ec-off3Grid__cell,
.ec-forgetCompleteRole .ec-off3Grid .ec-off3Grid__cell {
  margin: 0;
  width: 100%;
}

/* cart */
.ec-progress {
  margin: 0 auto 6vh auto;
}
@media (max-width: 768px) {
  .ec-progress {
    margin: 0 auto 20px auto;
  }
}
.ec-progress .ec-progress__number,
.ec-progress .ec-progress__item:after {
  color: var(--bgColor);
  line-height: 40px;
  background: var(--textColor);
  border: var(--textColor) 2px solid;
}
.ec-progress .ec-progress__item:after {
  top: 20px;
  height: 2px;
  border: none;
}
.ec-progress .is-complete .ec-progress__number {
  color: var(--textColor);
  background: var(--bgColor);
  border: var(--textColor) 2px solid;
}
.ec-progress .is-complete .ec-progress__label {
  color: var(--subBtnBgColor);
}
@media (max-width: 768px) {
  .ec-progress .ec-progress__number {
    line-height: 28px;
  }
  .ec-progress .ec-progress__item:after {
    top: 14px;
  }
  .ec-cartTable {
    border-top: var(--subBorderColor) 1px solid;
  }
}
.ec-cartHeader .ec-cartHeader__label {
  padding: 10px;
  background: var(--subBgColor);
}
.ec-cartRow .ec-cartRow__delColumn {
  width: 60px;
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-cartRow .ec-cartRow__delColumn .ec-icon {
  display: block;
  margin: 0;
  padding: 0;
  width: 60px;
  height: 60px;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2045.75%2045.75%22%3E%3Cg%3E%3Cpath%20d%3D%22m25.88%2C22.87L45.13%2C3.63c.83-.83.83-2.18%2C0-3.01-.83-.83-2.18-.83-3.01%2C0l-19.25%2C19.25L3.63.62C2.8-.21%2C1.45-.21.62.62-.21%2C1.45-.21%2C2.8.62%2C3.63l19.25%2C19.25L.62%2C42.12c-.83.83-.83%2C2.18%2C0%2C3.01s2.18.83%2C3.01%2C0l19.25-19.25%2C19.25%2C19.25c.83.83%2C2.18.83%2C3.01%2C0s.83-2.18%2C0-3.01l-19.25-19.25Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  -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%2045.75%2045.75%22%3E%3Cg%3E%3Cpath%20d%3D%22m25.88%2C22.87L45.13%2C3.63c.83-.83.83-2.18%2C0-3.01-.83-.83-2.18-.83-3.01%2C0l-19.25%2C19.25L3.63.62C2.8-.21%2C1.45-.21.62.62-.21%2C1.45-.21%2C2.8.62%2C3.63l19.25%2C19.25L.62%2C42.12c-.83.83-.83%2C2.18%2C0%2C3.01s2.18.83%2C3.01%2C0l19.25-19.25%2C19.25%2C19.25c.83.83%2C2.18.83%2C3.01%2C0s.83-2.18%2C0-3.01l-19.25-19.25Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  background-color: var(--textColor);
}
.ec-cartRow .ec-cartRow__delColumn .ec-icon img {
  display: none;
}
.ec-cartRow .ec-cartRow__summary {
  font-weight: normal;
}
.ec-cartRow .ec-cartRow__contentColumn,
.ec-cartRow .ec-cartRow__amountColumn,
.ec-cartRow .ec-cartRow__subtotalColumn {
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-cartRole .ec-cartRole__actions {
  margin: 0;
}
.ec-cartRole .ec-cartRole__totalAmount {
  color: var(--textColor);
}
.ec-cartRow__amountUpDown span {
  display: none;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountDownButton,
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountDownButtonDisabled,
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountUpButton {
  border: none;
  background: var(--textColor);
}
.ec-cartRow__amountDownButton:before,
.ec-cartRow__amountDownButtonDisabled:before,
.ec-cartRow__amountUpButton:before,
.ec-cartRow__amountUpButton:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  background: var(--bgColor);
  transform: translate(-50%, -50%);
}
.ec-cartRow__amountUpButton:after {
  width: 2px;
  height: 12px;
}
.ec-cartRow__amountDownButtonDisabled {
  opacity: 0.5;
}

/* お届け先の複数指定 */
.ec-AddAddress .ec-AddAddress__add {
  border-top: var(--subBorderColor) 1px solid;
}
.ec-AddAddress .ec-AddAddress__item {
  background: var(--subBgColor);
}
.ec-AddAddress .ec-AddAddress__selectAddress label,
.ec-AddAddress .ec-AddAddress__selectNumber label {
  font-size: var(--bodyFontSize);
  font-weight: normal;
}
.ec-AddAddress .ec-AddAddress__selectNumber {
  margin: 0 20px;
}
.ec-AddAddress .ec-AddAddress__selectNumber input {
  display: inline-block;
  margin: 0 0 0 10px;
  width: 80px;
}

/* mypage */
.ec-navlistRole .ec-navlistRole__navlist {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin: 0 0 30px 0;
  border: none;
}
.ec-navlistRole .ec-navlistRole__item {
  width: 100%;
  border: none;
}
.ec-navlistRole .ec-navlistRole__item:hover {
  background: none;
}
.ec-navlistRole .ec-navlistRole__item a {
  display: block;
  padding: 18px 2px;
  background: var(--bgColor);
  border: #8c8c8c 1px solid;
  border-radius: var(--inputBorderRadius);
}
.ec-navlistRole .active a {
  color: inherit;
  color: var(--bgColor);
  background: var(--textColor);
  border: #8c8c8c 1px solid;
}
.ec-welcomeMsg {
  margin: 0 0 30px 0;
  padding: 0 0 30px 0;
  color: var(--textColor);
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight2);
  border-bottom: #8c8c8c 1px solid;
}

@media (max-width: 768px) {
  .ec-navlistRole .ec-navlistRole__navlist {
    grid-template-columns: repeat(3, 1fr);
    font-size: 12px;
  }
}

/* ご注文履歴 */
.ec-historyRole .ec-historyRole__contents {
  margin: 20px 0 0 0;
  padding: 20px 0 0 0;
  color: var(--textColor);
  border-top: var(--subBorderColor) 1px solid;
}
.ec-historyListHeader .ec-historyListHeader__action {
  margin: 15px 0 0 0;
}
.ec-imageGrid {
  margin: 10px 0 0 0;
  padding: 10px 0 0 0;
  border-top: var(--subBorderColor) 1px solid;
}
.ec-historyRole .ec-historyRole__detail .ec-imageGrid:nth-of-type(1) {
  margin: 0;
  padding: 0;
  border: none;
}
.ec-imageGrid .ec-imageGrid__img {
  padding: 0;
}
.ec-imageGrid .ec-imageGrid__content {
  padding: 0 0 0 20px;
}
.ec-historyRole .ec-historyRole__detail .ec-historyRole__detailTitle,
.ec-historyRole .ec-historyRole__detail .ec-historyRole__detailPrice {
  margin: 5px 0;
  font-size: var(--bodyFontSize);
}

/* ご注文履歴詳細, shopping */
.ec-orderRole .ec-orderRole__detail {
  padding: 0;
}
.ec-orderRole .ec-orderRole__summary {
  position: relative;
  margin: 0 !important;
  padding: 0 0 0 30px;
}
@media (max-width: 768px) {
  .ec-orderRole .ec-orderRole__summary {
    padding: 0;
  }
}
.ec-orderRole .ec-orderRole__summary .ec-totalBox {
  position: sticky;
  top: 100px;
  left: 0;
  padding: 20px;
  width: 100%;
  background: var(--subBgColor);
  border-radius: 6px;
}
.ec-totalBox .ec-totalBox__total,
.ec-totalBox .ec-totalBox__paymentTotal {
  font-size: var(--bodyFontSize);
  border-top: var(--subBorderColor) 1px solid;
}
.ec-totalBox .ec-totalBox__taxRate {
  font-size: 11px;
}
.ec-totalBox .ec-totalBox__taxRate dt {
  margin: 0 4px 0 0;
}
.ec-totalBox .ec-totalBox__paymentTotal .ec-totalBox__price,
.ec-totalBox .ec-totalBox__paymentTotal .ec-totalBox__taxLabel {
  color: var(--noticeColor);
}
.ec-totalBox .ec-totalBox__pointBlock {
  padding: 15px 0 5px 0;
  background: none;
  border-top: var(--subBorderColor) 1px solid;
}
.ec-totalBox .ec-totalBox__btn .ec-blockBtn--cancel {
  margin: 10px 0 0 0;
}
.ec-orderAccount .ec-rectHeading h2 {
  margin-top: 0;
}
.ec-orderAccount .ec-orderAccount__account {
  margin: 0;
  line-height: var(--bodyLineHeight2);
}
.ec-orderRole .ec-borderedList {
  margin: 0 0 10px 0;
  padding: 0 0 10px 0;
  border-top: none;
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-orderRole .ec-borderedList li {
  border: none;
}
.ec-orderDelivery .ec-orderDelivery__address {
  margin: 20px 0;
  line-height: var(--bodyLineHeight2);
}
.ec-orderPayment p {
  margin: 0 0 10px 0;
}
.ec-orderConfirm .ec-input {
  line-height: var(--bodyLineHeight2);
}
.ec-orderMail__close {
  margin: 20px 0 0 0;
}
.ec-orderMail {
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-orderMail .ec-orderMail__link a,
.ec-orderMail .ec-orderMail__link a:hover,
.ec-orderMail .ec-orderMail__close a,
.ec-orderMail .ec-orderMail__close a:hover {
  color: var(--textColor);
  text-decoration: underline;
}

/* お気に入り */
.ec-favoriteRole .ec-favoriteRole__header {
  margin: 0 0 20px 0;
}
.ec-favoriteRole .ec-favoriteRole__itemList {
  display: grid;
  grid-template-columns: repeat(var(--itemNum), 1fr);
  gap: var(--itemMarginV) var(--itemMarginH);
}
.ec-favoriteRole .ec-favoriteRole__item {
  margin: 0;
  padding: 0;
  width: 100%;
  text-align: center;
}
.ec-favoriteRole .ec-favoriteRole__item .ec-closeBtn--circle .ec-icon {
  display: none;
}
.ec-favoriteRole .ec-favoriteRole__item .ec-closeBtn--circle {
  top: 0;
  right: 0;
  background: var(--textColor);
  border-radius: 0;
  z-index: 1;
}
.ec-favoriteRole .ec-favoriteRole__item .ec-closeBtn--circle:before {
  content: "";
  position: absolute;
  top: 0;
  left: 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%2045.75%2045.75%22%3E%3Cg%3E%3Cpath%20d%3D%22m25.88%2C22.87L45.13%2C3.63c.83-.83.83-2.18%2C0-3.01-.83-.83-2.18-.83-3.01%2C0l-19.25%2C19.25L3.63.62C2.8-.21%2C1.45-.21.62.62-.21%2C1.45-.21%2C2.8.62%2C3.63l19.25%2C19.25L.62%2C42.12c-.83.83-.83%2C2.18%2C0%2C3.01s2.18.83%2C3.01%2C0l19.25-19.25%2C19.25%2C19.25c.83.83%2C2.18.83%2C3.01%2C0s.83-2.18%2C0-3.01l-19.25-19.25Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  -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%2045.75%2045.75%22%3E%3Cg%3E%3Cpath%20d%3D%22m25.88%2C22.87L45.13%2C3.63c.83-.83.83-2.18%2C0-3.01-.83-.83-2.18-.83-3.01%2C0l-19.25%2C19.25L3.63.62C2.8-.21%2C1.45-.21.62.62-.21%2C1.45-.21%2C2.8.62%2C3.63l19.25%2C19.25L.62%2C42.12c-.83.83-.83%2C2.18%2C0%2C3.01s2.18.83%2C3.01%2C0l19.25-19.25%2C19.25%2C19.25c.83.83%2C2.18.83%2C3.01%2C0s.83-2.18%2C0-3.01l-19.25-19.25Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  background-color: var(--bgColor);
  transition: all 0.3s ease;
}
.ec-favoriteRole .ec-favoriteRole__item-image {
  overflow: hidden;
  margin: 0 0 15px 0;
}
.ec-favoriteRole .ec-favoriteRole__item img {
  aspect-ratio: var(--itemListImageAspectRatio);
  object-fit: cover;
}
.ec-favoriteRole .ec-favoriteRole__itemTitle {
  margin: 0 0 5px 0;
}
.ec-favoriteRole .ec-favoriteRole__itemPrice {
  margin: 0;
  font-weight: normal;
}

/* お届け先一覧 */
.ec-addressRole .ec-addressRole__actions {
  margin: 20px 0 0 0;
  padding: 0 0 30px 0;
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-addressList .ec-addressList__item {
  display: flex;
  border-bottom: var(--subBorderColor) 1px solid;
}
.ec-addressList .ec-addressList__remove input {
  margin: 22px 0 0 0;
}
.ec-mypageRole .ec-addressList .ec-addressList__remove .ec-icon {
  display: none;
}
.ec-mypageRole .ec-addressList .ec-addressList__remove {
  margin: 0;
  padding: 0;
  width: 50px;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2045.75%2045.75%22%3E%3Cg%3E%3Cpath%20d%3D%22m25.88%2C22.87L45.13%2C3.63c.83-.83.83-2.18%2C0-3.01-.83-.83-2.18-.83-3.01%2C0l-19.25%2C19.25L3.63.62C2.8-.21%2C1.45-.21.62.62-.21%2C1.45-.21%2C2.8.62%2C3.63l19.25%2C19.25L.62%2C42.12c-.83.83-.83%2C2.18%2C0%2C3.01s2.18.83%2C3.01%2C0l19.25-19.25%2C19.25%2C19.25c.83.83%2C2.18.83%2C3.01%2C0s.83-2.18%2C0-3.01l-19.25-19.25Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  -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%2045.75%2045.75%22%3E%3Cg%3E%3Cpath%20d%3D%22m25.88%2C22.87L45.13%2C3.63c.83-.83.83-2.18%2C0-3.01-.83-.83-2.18-.83-3.01%2C0l-19.25%2C19.25L3.63.62C2.8-.21%2C1.45-.21.62.62-.21%2C1.45-.21%2C2.8.62%2C3.63l19.25%2C19.25L.62%2C42.12c-.83.83-.83%2C2.18%2C0%2C3.01s2.18.83%2C3.01%2C0l19.25-19.25%2C19.25%2C19.25c.83.83%2C2.18.83%2C3.01%2C0s.83-2.18%2C0-3.01l-19.25-19.25Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  background-color: var(--textColor);
}
.ec-addressList .ec-addressList__address {
  margin: 0;
  width: 100%;
}
.ec-addressList .ec-addressList__action {
  display: flex;
  align-items: center;
  top: 0;
}

/* 退会手続き */
.ec-withdrawRole .ec-off3Grid .ec-off3Grid__cell,
.ec-withdrawConfirmRole .ec-off3Grid .ec-off3Grid__cell {
  margin: 0;
  width: 100%;
}
.ec-withdrawRole .ec-withdrawRole__title,
.ec-withdrawConfirmRole .ec-withdrawConfirmRole__title {
  font-size: calc(var(--bodyFontSize) + 6px);
  text-align: center;
}
.ec-withdrawRole .ec-withdrawRole__description,
.ec-withdrawConfirmRole .ec-withdrawConfirmRole__description {
  margin: 0 auto 30px auto;
  max-width: 500px;
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight2);
  text-align: center;
}
.ec-withdrawConfirmRole .ec-withdrawConfirmRole__cancel {
  margin: 0 0 10px 0;
}
.ec-withdrawRole .ec-icon img,
.ec-withdrawConfirmRole .ec-icon img {
  display: none;
}
.ec-withdrawRole .ec-icon:before,
.ec-withdrawConfirmRole .ec-icon:before {
  content: "";
  display: block;
  margin: 0 auto 30px auto;
  width: 80px;
  height: 80px;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%20-0.5%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M13.7744%201.41218L23.4802%2020.0771C23.9898%2021.0571%2023.6085%2022.2646%2022.6285%2022.7742C22.3435%2022.9224%2022.027%2022.9998%2021.7058%2022.9998H2.29425C1.18968%2022.9998%200.29425%2022.1044%200.29425%2020.9998C0.29425%2020.6786%200.371621%2020.3621%200.519817%2020.0771L10.2256%201.41218C10.7352%200.432187%2011.9427%200.0508554%2012.9227%200.560452C13.2874%200.75009%2013.5848%201.04749%2013.7744%201.41218ZM10.5%209.49981V13.9998C10.5%2014.8282%2011.1716%2015.4998%2012%2015.4998C12.8284%2015.4998%2013.5%2014.8282%2013.5%2013.9998V9.49981C13.5%208.67138%2012.8284%207.99981%2012%207.99981C11.1716%207.99981%2010.5%208.67138%2010.5%209.49981ZM12%2019.9998C12.8284%2019.9998%2013.5%2019.3282%2013.5%2018.4998C13.5%2017.6714%2012.8284%2016.9998%2012%2016.9998C11.1716%2016.9998%2010.5%2017.6714%2010.5%2018.4998C10.5%2019.3282%2011.1716%2019.9998%2012%2019.9998Z%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center center / 80px;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%20-0.5%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M13.7744%201.41218L23.4802%2020.0771C23.9898%2021.0571%2023.6085%2022.2646%2022.6285%2022.7742C22.3435%2022.9224%2022.027%2022.9998%2021.7058%2022.9998H2.29425C1.18968%2022.9998%200.29425%2022.1044%200.29425%2020.9998C0.29425%2020.6786%200.371621%2020.3621%200.519817%2020.0771L10.2256%201.41218C10.7352%200.432187%2011.9427%200.0508554%2012.9227%200.560452C13.2874%200.75009%2013.5848%201.04749%2013.7744%201.41218ZM10.5%209.49981V13.9998C10.5%2014.8282%2011.1716%2015.4998%2012%2015.4998C12.8284%2015.4998%2013.5%2014.8282%2013.5%2013.9998V9.49981C13.5%208.67138%2012.8284%207.99981%2012%207.99981C11.1716%207.99981%2010.5%208.67138%2010.5%209.49981ZM12%2019.9998C12.8284%2019.9998%2013.5%2019.3282%2013.5%2018.4998C13.5%2017.6714%2012.8284%2016.9998%2012%2016.9998C11.1716%2016.9998%2010.5%2017.6714%2010.5%2018.4998C10.5%2019.3282%2011.1716%2019.9998%2012%2019.9998Z%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center center / 80px;
  background-color: var(--textColor);
}

.ec-orderCoupon p {
  margin: 15px 0 0 0;
}

#page_help_about .ec-borderedDefs dt,
#page_help_tradelaw .ec-borderedDefs dt {
  padding: 0;
  line-height: var(--bodyLineHeight2);
}
#page_help_about .ec-borderedDefs dd,
#page_help_tradelaw .ec-borderedDefs dd {
  line-height: var(--bodyLineHeight2);
}

#page_help_privacy .ec-off1Grid__cell :first-child {
  margin-top: 0;
}
#page_help_privacy h2 {
  margin: 40px 0 20px 0;
  font-size: calc(var(--bodyFontSize) + 6px);
}
#page_help_privacy p {
  margin: 20px 0;
  line-height: var(--bodyLineHeight2);
}
#page_help_privacy ol {
  margin: 20px 0;
  line-height: var(--bodyLineHeight2);
}

.guide-wrap {
  display: flex;
}
.guide-nav {
  width: 180px;
}
.guide-nav ul {
  position: sticky;
  top: 100px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.guide-nav ul li a {
  display: block;
  margin: 0 0 2px 0;
  padding: 12px;
  text-decoration: none;
  background: var(--subBgColor);
}
.guide-content {
  margin: 0 0 0 auto;
  width: calc(100% - 220px);
}
.guide-content > :first-child {
  margin-top: 0;
}
.guide-content h2 {
  margin: 40px 0 20px 0;
  padding: 0 0 10px 0;
  font-size: calc(var(--bodyFontSize) + 6px);
  font-weight: normal;
  border-bottom: #8c8c8c 1px solid;
}
.guide-content h3 {
  margin: 40px 0 20px 0;
  padding: 12px;
  font-size: calc(var(--bodyFontSize) + 3px);
  background: var(--subBgColor);
}
.guide-content h2 + h3 {
  margin: 20px 0;
}
.guide-content p {
  margin: 20px 0;
  line-height: var(--bodyLineHeight2);
}
.guide-content p.sub {
  opacity: 0.7;
  font-size: calc(var(--bodyFontSize) - 2px);
}
.guide-content img.guide-card {
  max-width: 280px;
}
.guide-content dl {
  margin: 20px 0;
  line-height: var(--bodyLineHeight2);
}
.guide-content dl dt,
.guide-content dl dd {
  position: relative;
  margin: 0 0 8px 0;
  padding: 0 0 0 40px;
}
.guide-content dl dd {
  margin: 0 0 20px 0;
  padding: 0 0 20px 40px;
  border-bottom: var(--subBorderColor) 1px solid;
}
.guide-content dl dt:before,
.guide-content dl dd:before {
  content: "Q";
  position: absolute;
  top: 0;
  left: 0;
  width: 24px;
  height: 24px;
  color: var(--bgColor);
  font-weight: bold;
  text-align: center;
  line-height: 24px;
  background: var(--textColor);
}
.guide-content dl dd:before {
  content: "A";
  color: var(--textColor);
  background: var(--subBgColor);
  border: var(--subBorderColor) 1px solid;
}

@media (max-width: 768px) {
  .guide-wrap {
    display: block;
  }
  .guide-nav {
    margin: 0 0 40px 0;
    width: 100%;
  }
  .guide-content {
    width: 100%;
  }
}

.ec-404Role {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100vh;
  text-align: center;
}
.ec-404Role__icon img {
  display: none;
}
.ec-404Role__icon:before {
  content: "";
  display: block;
  margin: 0 auto 30px auto;
  width: 80px;
  height: 80px;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%20-0.5%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M13.7744%201.41218L23.4802%2020.0771C23.9898%2021.0571%2023.6085%2022.2646%2022.6285%2022.7742C22.3435%2022.9224%2022.027%2022.9998%2021.7058%2022.9998H2.29425C1.18968%2022.9998%200.29425%2022.1044%200.29425%2020.9998C0.29425%2020.6786%200.371621%2020.3621%200.519817%2020.0771L10.2256%201.41218C10.7352%200.432187%2011.9427%200.0508554%2012.9227%200.560452C13.2874%200.75009%2013.5848%201.04749%2013.7744%201.41218ZM10.5%209.49981V13.9998C10.5%2014.8282%2011.1716%2015.4998%2012%2015.4998C12.8284%2015.4998%2013.5%2014.8282%2013.5%2013.9998V9.49981C13.5%208.67138%2012.8284%207.99981%2012%207.99981C11.1716%207.99981%2010.5%208.67138%2010.5%209.49981ZM12%2019.9998C12.8284%2019.9998%2013.5%2019.3282%2013.5%2018.4998C13.5%2017.6714%2012.8284%2016.9998%2012%2016.9998C11.1716%2016.9998%2010.5%2017.6714%2010.5%2018.4998C10.5%2019.3282%2011.1716%2019.9998%2012%2019.9998Z%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center center / 80px;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%20-0.5%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M13.7744%201.41218L23.4802%2020.0771C23.9898%2021.0571%2023.6085%2022.2646%2022.6285%2022.7742C22.3435%2022.9224%2022.027%2022.9998%2021.7058%2022.9998H2.29425C1.18968%2022.9998%200.29425%2022.1044%200.29425%2020.9998C0.29425%2020.6786%200.371621%2020.3621%200.519817%2020.0771L10.2256%201.41218C10.7352%200.432187%2011.9427%200.0508554%2012.9227%200.560452C13.2874%200.75009%2013.5848%201.04749%2013.7744%201.41218ZM10.5%209.49981V13.9998C10.5%2014.8282%2011.1716%2015.4998%2012%2015.4998C12.8284%2015.4998%2013.5%2014.8282%2013.5%2013.9998V9.49981C13.5%208.67138%2012.8284%207.99981%2012%207.99981C11.1716%207.99981%2010.5%208.67138%2010.5%209.49981ZM12%2019.9998C12.8284%2019.9998%2013.5%2019.3282%2013.5%2018.4998C13.5%2017.6714%2012.8284%2016.9998%2012%2016.9998C11.1716%2016.9998%2010.5%2017.6714%2010.5%2018.4998C10.5%2019.3282%2011.1716%2019.9998%2012%2019.9998Z%22%2F%3E%3C%2Fsvg%3E")
    no-repeat center center / 80px;
  background-color: var(--textColor);
}

/* mv
------------------------------------------*/
.mv-wrap {
  overflow: hidden;
  position: relative;
  margin: 0 auto;
}
.header-colortype-1 .mv-wrap {
  margin-top: calc(var(--headerHeight) * -1);
}
.mv-full-1 .mv-wrap {
  height: calc(100vh - var(--headerHeight));
  max-width: 100%;
}
.mv-full-1 .mv-wrap.information-1 {
  height: calc(100vh - var(--headerHeight) - 40px);
  max-width: 100%;
}
.header-colortype-1.mv-full-1 .mv-wrap {
  height: 100vh;
}
.header-colortype-1.mv-full-1.information-1 .mv-wrap {
  height: calc(100vh - 40px);
}
@media (max-width: 768px) {
  .header-colortype-1.mv-full-1.information-1 .mv-wrap {
      height: auto;
    }
}

.mv {
  overflow: hidden;
  opacity: 0;
  transform: scale(1.2);
  filter: blur(100px);
  transition: all 1s ease;
}
.viewed .mv {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
}
.mv-full-1 .mv-wrap .mv {
  height: 100%;
}
.mv .bg img {
  width: 100%;
}
.mv .bg img.sp {
  display: none;
}
.mv-full-1 .mv-wrap .bg {
  height: 100%;
}
.mv-full-1 .mv-wrap .bg img {
  object-fit: cover;
  height: 100%;
}
.mv .swiper-slide-active img {
  animation: fadeZoom 1.5s ease both;
}
@keyframes fadeZoom {
  0% { transform: scale(1.15); }
  100% { transform: scale(1); }
}

.mv .text {
  position: absolute;
  top: var(--padding);
  bottom: var(--padding);
  left: var(--padding);
  right: var(--padding);
  margin: auto 0;
  padding: 0;
  width: fit-content;
  height: fit-content;
  color: #fff;
  text-align: left;
}
.header-colortype-1 .mv .text {
  transform: translateY(var(--headerHeight) / 3);
}
.position-2 .mv .text { margin: auto auto auto 0; text-align: left; }
.position-2 .mv .text .btn-image a { margin: 0 auto 0 0 !important; transform-origin: center left; }
.position-3 .mv .text { margin: auto 0 auto auto; text-align: right; }
.position-3 .mv .text .btn-image a { margin: 0 0 0 auto !important; transform-origin: center right; }
.position-4 .mv .text { margin: auto auto var(--padding) 0; text-align: left; }
.position-4 .mv .text .btn-image a { margin: 0 auto 0 0 !important; transform-origin: center left; }
.position-5 .mv .text { margin: auto 0 var(--padding) auto; text-align: right; }
.position-5 .mv .text .btn-image a { margin: 0 0 0 auto !important; transform-origin: center right; }

.mv .text:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.bg-2 .mv .text { padding: var(--padding); color: var(--textColor); }
.bg-2 .mv .text:before { background: var(--subBgColor); }
.bg-3 .mv .text { padding: var(--padding); color: var(--accentTextColor); }
.bg-3 .mv .text:before { background: var(--accentBgColor); }
.bg-4 .mv .text { padding: var(--padding); color: var(--accentBgColor); }
.bg-4 .mv .text:before { background: var(--accentTextColor); }

.mv .text:before {
  animation: textBgZoomOut 0.6s ease both;
}
@keyframes textBgZoomOut {
  0% { opacity: var(--mvTextBgOpacity); transform: scale(1); }
  100% { opacity: 0; transform: scale(1.2); }
}
.mv .swiper-slide-active .text:before {
  animation: textBgZoomIn 1s 1.2s ease both;
}
@keyframes textBgZoomIn {
  0% { opacity: 0; transform: scale(1.2); }
  100% { opacity: var(--mvTextBgOpacity); transform: scale(1); }
}

.mv .text .sub {
  margin: 20px 0 0 0;
  font-size: 16px;
  animation: textZoomOut 0.6s ease both;
}
.mv .text .title {
  font-size: var(--headFontSizeL);
  animation: textZoomOut 0.6s ease both;
  font-weight: normal;
  line-height: 1.5;
  font-family: var(--headFontFamily);

}
.mv .text .title span{
 
}
.mv .text p {
  margin: 25px 0 0 0;
  line-height: var(--bodyLineHeight2);
  animation: textZoomOut 0.6s ease both;
}
.mv .text .btn-image {
  animation: textZoomOut 0.6s ease both;
}
@keyframes textZoomOut {
  0% { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.2); }
}
.mv .swiper-slide-active .text .sub {
  animation: textZoomIn 0.6s 1.2s ease both;
}
.mv .swiper-slide-active .text .title {
  animation: textZoomIn 0.6s 1.3s ease both;
}
.mv .swiper-slide-active .text p {
  animation: textZoomIn 0.6s 1.4s ease both;
}
.mv .swiper-slide-active .text .btn-image {
  animation: textZoomIn 0.6s 1.5s ease both;
}
@keyframes textZoomIn {
  0% { opacity: 0; transform: scale(1.2); }
  100% { opacity: 1; transform: scale(1); }
}
@media (max-width: 768px) {
  .mv .text .sub {
    margin: 30px 0 0 0;
  }
  .mv .bg img.pc {
    display: none;
  }
  .mv .bg img.sp {
    display: block;
  }
}

.mv .swiper-pagination {
  display: flex;
  justify-content: center;
  gap: 5px;
  bottom: 30px;
}
.mv .swiper-pagination-bullet {
  opacity: 0.2;
  width: 6px;
  height: 6px;
  background: #fff;
  transition: all 0.3s ease;
}
.mv .swiper-pagination-bullet-active {
  opacity: 0.8;
  background: #fff;
}
.mv .swiper-pagination-bullet:only-child {
  display: block !important;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .mv .swiper-pagination {
    bottom: 20px;
  }
  .position-sp-1 .mv .text { margin: auto; text-align: center; }
  .position-sp-1 .mv .text .btn-image a { margin: auto !important; transform-origin: center; }
  .position-sp-2 .mv .text { margin: auto auto auto 0; text-align: left; }
  .position-sp-2 .mv .text .btn-image a { margin: 0 auto 0 0 !important; transform-origin: center left; }
  .position-sp-3 .mv .text { margin: auto 0 auto auto; text-align: right; }
  .position-sp-3 .mv .text .btn-image a { margin: 0 0 0 auto !important; transform-origin: center right; }
  .position-sp-4 .mv .text { margin: auto auto var(--padding) 0; text-align: left; }
  .position-sp-4 .mv .text .btn-image a { margin: 0 auto 0 0 !important; transform-origin: center left; }
  .position-sp-5 .mv .text { margin: auto 0 var(--padding) auto; text-align: right; }
  .position-sp-5 .mv .text .btn-image a { margin: 0 0 0 auto !important; transform-origin: center right; }
}

/* home
------------------------------------------*/
.sec-title {
  margin: 0 0 var(--titleMargin) 0;
  text-align: center;
}
.sec-title h2 {
  opacity: 0;
  display: flex;
  gap: .25em;
  position: relative;
  margin: 0 auto;
  padding: 0 0 10px 0;
  text-indent: var(--headFontLs);
  transform: translateY(20px);
  transition: all 0.6s ease;
  text-align: left;
  align-items: center;
  flex-wrap: wrap;
}
@media (max-width: 768px) {
  .sec-title h2 {
  font-size: 1.5em;
  }
}
.viewed .sec-title h2 {
  opacity: 1;
  transform: translateY(0);
}

.sec-title__jp {
  font-size: .5em;
  top: .5em;
  position: relative;
}
.sec-title h2:after {
  content: '';
  opacity: 0;
  width: 0;
  height: 1px;
  background: #8c8c8c;
  transition: all 0.6s 0.6s;
  position: absolute;
  left: 0;
  bottom: 0;
}
@media (max-width: 768px) {
  .sec-title h2:after {
    display: none;
  }
}
.viewed .sec-title h2:after {
  opacity: 1;
  width: 2em;
}

.slideitem {
  margin: 0 auto var(--margin) auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
}
.slideitem .swiper-container {
  opacity: 0;
  visibility: hidden;
  position: relative;
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.slideitem.viewed .swiper-container {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  filter: blur(0);
}
.slideitem .swiper-button-prev,
.slideitem .swiper-button-next {
  left: -22px;
  right: auto;
  width: 44px;
  height: 44px;
  color: var(--imageBtnTextColor);
  background: var(--imageBtnBgColor);
  border-radius: 50%;
  box-shadow: 0 10px 10px -5px rgba(0, 0, 0, 0.2);
  transition: all 0.3s ease;
}
.slideitem .swiper-button-next {
  left: auto;
  right: -22px;
}
.slideitem .swiper-button-prev::after,
.slideitem .swiper-button-next::after {
  font-size: 15px;
}

@media (max-width: 768px) {
  .slideitem .swiper {
    overflow: visible;
  }
  .slideitem .swiper-button-prev,
  .slideitem .swiper-button-next {
    display: none;
  }
}

.slideitem a {
  display: block;
  text-align: center;
  text-decoration: none;
}
.slideitem a:hover {
  opacity: 1;
}
.slideitem a .rank {
  display: grid;
  place-items: center;
  position: absolute;
  top: 0;
  left: 0;
  width: 28px;
  height: 28px;
  font-size: 12px;
  color: var(--accentTextColor);
  background: var(--accentBgColor);
  z-index: 1;
}
.slideitem a .image {
  overflow: hidden;
  margin: 0 0 15px 0;
}
.slideitem a .image img {
  aspect-ratio: var(--itemListImageAspectRatio);
  object-fit: cover;
  width: 100%;
  max-height: 320px;
  transition: all 0.4s ease;
  border: 1px solid #eee;
}
@media (hover: hover) {
  .slideitem a:hover .image img {
    transform: scale(1.1);
  }
}
.slideitem a .name {
  margin: 0 0 5px 0;
}
.slideitem a .comment {
  opacity: 0.7;
  margin: 10px 0 0 0;
  font-size: calc(var(--bodyFontSize) - 2px);
  line-height: var(--bodyLineHeight2);
}

.concept {
  margin: 0 0 var(--margin) 0;
  padding: var(--margin) 0;
  background: var(--subBgColor);
}
.concept:first-child {
  margin-top: calc(var(--margin) * -1);
}
.concept .text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin: 0 auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
  text-align: center;
}
.concept .text .sub {
  opacity: 0;
  margin: 0 0 25px 0;
  font-size: 13px;
  transform: translateY(20px);
  transition: all 0.6s 0.1s ease;
}
.concept .text .title {
  opacity: 0;
  margin: 0 0 40px 0;
  transform: translateY(20px);
  transition: all 0.6s 0.2s ease;
}
.concept .text p {
  opacity: 0;
  margin: 0;
  line-height: var(--bodyLineHeight2);
  transform: translateY(20px);
  transition: all 0.6s 0.3s ease;
}
.concept .text .btn-normal {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.6s 0.4s ease;
}
.concept .text .btn-normal a {
  margin: 0 auto;
}
.concept.viewed .text .sub,
.concept.viewed .text .title,
.concept.viewed .text p,
.concept.viewed .text .btn-normal {
  opacity: 1;
  transform: translateY(0);
}

.bannerlist {
  margin: 30px 0 var(--margin) 0;
  padding: 0 var(--padding);
}
.bannerlist ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--itemMarginH);
  padding: 0;
  list-style: none;
}
.bannerlist li {
  opacity: 0;
  background: #000;
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.bannerlist.viewed li {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.bannerlist li:nth-child(2) { transition-delay: 0.1s }
.bannerlist li:nth-child(3) { transition-delay: 0.2s }
.bannerlist li:nth-child(4) { transition-delay: 0.3s }

.bannerlist li a {
  overflow: hidden;
  display: block;
  position: relative;
  height: min(11vw, 500px);
}
@media (max-width: 600px) {
  .bannerlist li a {
    height: min(20vw, 500px);
  }
}
.bannerlist li a .image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.bannerlist li a .image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: all 0.6s ease;
}
@media (hover: hover) {
  .bannerlist li a:hover {
    opacity: 1;
  }
  .bannerlist li a:hover .image img {
    opacity: 0.7;
    transform: scale(1.1);
  }
}
.bannerlist li a h2 {
  position: absolute;
  top: 50%;
  left: 0;
  margin: 0;
  padding: 0 20px;
  width: 100%;
  color: #fff;
  font-size: 18px;
  text-align: center;
  transform: translateY(-50%);
}
.bannerlist.type-1 li a {
  height: 280px;
}
.bannerlist.type-2 ul {
  grid-template-columns: repeat(2, 1fr);
}
.bannerlist.type-3 ul {
  grid-template-columns: repeat(3, 1fr);
}
.bannerlist.type-3 li:nth-child(1) { grid-column: 1 / 3; }
.bannerlist.type-3 li:nth-child(2) { grid-column: 3 / 4; }
.bannerlist.type-3 li:nth-child(3) { grid-column: 1 / 2; }
.bannerlist.type-3 li:nth-child(4) { grid-column: 2 / 4; }

.bannerlist.type-4 ul {
  grid-template-columns: repeat(3, 1fr);
}
.bannerlist.type-4 li:nth-child(1) { grid-column: 1 / 4; }

@media (max-width: 1000px) {
  .bannerlist ul {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .bannerlist li {
    grid-column: auto !important;
  }
}
@media (max-width: 600px) {
  .bannerlist ul {
    grid-template-columns: repeat(1, 1fr) !important;
  }
  .bannerlist.type-3 li:nth-child(3) { order: 4 }
  .bannerlist.type-3 li:nth-child(3) { order: 3 }
}

.youtube {
  position: relative;
  margin: 0 0 var(--margin) 0;
  height: 70vh;
}
.youtube-bg-movie {
  opacity: 0;
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.youtube.viewed .youtube-bg-movie {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.mbYTP_wrapper:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.05);
  background-image: radial-gradient(rgba(0 ,0, 0, 0.1) 30%, transparent 31%), radial-gradient(rgba(0, 0, 0, 0.1) 30%, transparent 31%);
  background-size: 4px 4px;
  background-position: 0 0, 2px 2px;
}
.youtube .text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  margin: 0 auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
  height: 100%;
  color: #fff;
  text-align: center;
  z-index: 1;
}
.youtube .text .sub {
  opacity: 0;
  margin: 0 0 25px 0;
  font-size: 1.3rem;
  white-space: pre-line;
  transform: translateY(20px);
  transition: all 0.6s 0.1s ease;
}
.youtube .text .title {
  opacity: 0;
  font-size: var(--headFontSizeL);
  white-space: pre-line;
  transform: translateY(20px);
  transition: all 0.6s 0.2s ease;
}
.youtube .text .btn-image {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.6s 0.3s ease;
}
.youtube.viewed .text .sub,
.youtube.viewed .text .title,
.youtube.viewed .text .btn-image {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 768px) {
  .youtube .text .sub {
    margin: 0 0 15px 0;
  }
}

.news {
  margin: 0 auto var(--margin) auto;
  padding: 0 var(--padding);
  max-width: 800px;
  width: fit-content;
}
.news ul {
  display: flex;
  flex-direction: column;
  gap: 40px;
  margin: 0 auto;
  padding: 0;
  width: fit-content;
  list-style: none;
}
.news ul li {
  opacity: 0;
  display: flex;
  position: relative;
  transform: translateY(20px);
  transition: all 0.6s ease;
}
.news ul li:nth-child(2) { transition-delay: 0.1s }
.news ul li:nth-child(3) { transition-delay: 0.2s }

.news.viewed ul li {
  opacity: 1;
  transform: translateY(0);
}
.news ul li .date {
  opacity: 0.5;
  width: 150px;
}
.news ul li .text {
  width: calc(100% - 150px);
}
.news ul li .text a {
  text-decoration: underline;
}
.news ul li .text p {
  margin: 15px 0 0 0;
  font-size: 11px;
  line-height: var(--bodyLineHeight2);
}
.news ul li .text p:empty {
  margin: 0;
}
@media (max-width: 768px) {
  .news ul li {
    display: block;
  }
  .news ul li .date {
    margin: 0 0 8px 0;
    font-size: 11px;
  }
  .news ul li .text {
    width: 100%;
  }
}

.message-wrap {
  overflow: hidden;
  margin: 0 0 var(--margin) 0;
}
.message {
  position: relative;
}
.message-inner {
  display: flex;
  flex-direction: row-reverse;
  position: relative;
  margin: 0 auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
}
.left .message-inner {
  flex-direction: row;
}
.message-inner .image {
  overflow: hidden;
  flex: 1;
  position: relative;
  margin: 0 calc(50% - var(--vw) * 50) 0 0;
  min-height: 460px;
}
.left .message-inner .image {
  margin: 0 0 0 calc(50% - var(--vw) * 50);
}
.message-inner .image img {
  opacity: 0;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(1.2);
  filter: blur(20px);
  transition: all 1s ease;
}
.message.viewed .message-inner .image img {
  opacity: 1;
  transform: scale(1);
  filter: blur(0);
}
.message-inner .text {
  align-self: center;
  padding: var(--messagePadding) var(--messagePadding) var(--messagePadding) 0;
  width: 50%;
}
.left .message-inner .text {
  padding: var(--messagePadding) 0 var(--messagePadding) var(--messagePadding);
}
.message-inner .text h2 {
  opacity: 0;
  margin: 0 0 25px 0;
  transform: translateY(20px);
  transition: all 0.6s 0.1s ease;
}
@media (max-width: 768px) {
  .message-inner .text h2 {
    font-size: 1.5em;
    margin-bottom: .5em;
  }
}
.message-inner .text p {
  opacity: 0;
  line-height: var(--bodyLineHeight2);
  transform: translateY(20px);
  transition: all 0.6s 0.2s ease;
}
.message-inner .text .btn-normal {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.6s 0.3s ease;
}
.message-inner .text .btn-normal a {
  margin: 0 !important;
}
.message.viewed .text h2,
.message.viewed .text p,
.message.viewed .text .btn-normal {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 1580px) {
  .message-inner {
    padding: 0;
    max-width: 100%;
  }
  .message-inner .text,
  .left .message-inner .text {
    padding: var(--messagePadding);
  }
}
@media (max-width: 768px) {
  .message-wrap {
    margin: 0;
  }
  .message-inner {
    display: block;
  }
  .message-inner .image {
    margin: 0;
    min-height: 34vh;
  }
  .message-inner .text,
  .left .message-inner .text {
    padding: var(--padding) var(--padding) var(--margin) var(--padding);
    width: 100%;
  }
  .message-inner .text .btn-normal a {
    margin: 0 auto !important;
  }
}

.categorylist {
  margin: 0 auto var(--margin) auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
  --categorylistGap: 40px;
}
.categorylist ul {
  opacity: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--categorylistGap);
  padding: 0;
  list-style: none;
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.categorylist.viewed ul {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.categorylist ul li {
  width: calc((100% / 4) - (var(--categorylistGap) * (4 - 1) / 4));
  min-width: 280px;
}
.categorylist ul li a {
  text-decoration: none;
  display: flex;
    align-items: center;
    gap: .5em;
    text-align: left;
    border: 1px solid #eee;
    padding-right: 4em;
    position: relative;
    line-height: 1.3;
    font-size: 13.5px;
}
.categorylist ul li a:after {
  content: "";
  width: 2em;
  position: absolute;
  height: 2em;
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2243.859%22%20height%3D%227.673%22%20viewBox%3D%220%200%2043.859%207.673%22%3E%3Cpath%20d%3D%22M1677.25%2C2291.293h-43.859v-1h41.329l-6.344-5.943.684-.73Z%22%20transform%3D%22translate(-1633.391%20-2283.62)%22%20fill%3D%22%23a2998f%22%2F%3E%3C%2Fsvg%3E') 50%/100% auto no-repeat;
  right: 1em;
  bottom: 0;
  top: 0;
  margin: auto;
  transition: all 0.2s ease;
}
.categorylist ul li .image {
  overflow: hidden;
  width: 30%;
  flex-shrink: 0;
}
.categorylist ul li .image img {
  aspect-ratio: 1 / 1;
  width: 100%;
  transition: all 0.2s ease;
}
@media (hover: hover) {
  .categorylist li a:hover {
    opacity: 1;
  }
  .categorylist li a:hover .image img {
    opacity: 0.7;
    transform: scale(1.1);
  }
    .categorylist ul li a:hover:after {
      right: .75em;
    }
}
@media (max-width: 768px) {
  .categorylist ul {
    gap: 20px;
  }
  .categorylist ul li {
  /*  width: calc((100% / 3) - (var(--categorylistGap) * (3 - 1) / 3));*/
    width: 100%;
  }
    .categorylist ul li .image {
      width: 25%;
    }
}

.instagram {
  margin: 0 auto var(--margin) auto;
  padding: 0 var(--padding);
  max-width: var(--maxWidth);
}
.instagram .code {
  opacity: 0;
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.instagram.viewed .code {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.instagram .btn-normal {
  opacity: 0;
  transform: translateY(20px);
  filter: blur(20px);
  transition: all 1s ease;
}
.instagram.viewed .btn-normal {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.instagram .btn-normal a {
  margin: 0 auto;
}

/* list
------------------------------------------*/
.ec-categoryChildren {
  display: flex;
  gap: 5px;
  margin: 0 0 20px 0;
  padding: 0;
  list-style: none;
}
.ec-categoryChildren li {
  margin: 0;
}
.ec-categoryChildren li a {
  display: block;
  padding: 8px 12px;
  font-size: 12px;
  text-decoration: none;
  background: var(--subBgColor);
}
.ec-searchResult {
  margin: 0 0 20px 0;
  padding: 12px;
  font-size: 12px;
  background: var(--subBgColor);
  border-radius: var(--inputBorderRadius);
}
.ec-sortBtnArea {
  display: flex;
  justify-content: space-between;
  align-items: center;
  align-items: center;
  margin: 0 0 min(4vh, 40px) 0;
}
.ec-sortBtnArea p {
  margin: 0;
}
.ec-sortBtnArea p span {
  margin: 0 3px 0 0;
  font-weight: bold;
}
.ec-sortBtn {
  display: flex;
  gap: 15px;
}
.ec-sortBtnArea select,
.ec-sortBtnArea select:focus {
  margin: 0 !important;
  padding: 5px 19px 5px 5px !important;
  background: linear-gradient(45deg, transparent 50%, var(--textColor) 50%)
      no-repeat center right 9px / 4px 4px,
    linear-gradient(-45deg, transparent 50%, var(--textColor) 50%) no-repeat
      center right 5px / 4px 4px;
  border: none !important;
  border-bottom: #8c8c8c 1px solid !important;
  border-radius: 0 !important;
}
.ec-noItems {
  display: grid;
  place-items: center;
  height: 200px;
}
.ec-shelfRole {
  max-width: 100%;
}
.ec-shelfGrid {
  display: grid;
  grid-template-columns: repeat(var(--itemNum), 1fr);
  gap: var(--itemMarginV) var(--itemMarginH);
  margin: 0;
  text-align: center;
}
.ec-shelfGrid .ec-shelfGrid__item {
  margin: 0;
  padding: 0 !important;
  width: 100%;
}
.ec-shelfGrid .ec-shelfGrid__item a:hover {
  opacity: 1;
}
.ec-shelfGrid .ec-shelfGrid__item p {
  margin: 0 0 5px 0;
}
.ec-shelfGrid .ec-shelfGrid__item p.ec-shelfGrid__item-image {
  overflow: hidden;
  margin: 0 0 15px 0;
  border: 1px solid #eee;
}
.ec-shelfGrid .ec-shelfGrid__item p.ec-shelfGrid__item-image img {
  aspect-ratio: var(--itemListImageAspectRatio);
  object-fit: cover;
  width: 100%;
  max-height: 220px;
  transition: all 0.4s ease;
}
@media (hover: hover) {
  .ec-shelfGrid .ec-shelfGrid__item a:hover p.ec-shelfGrid__item-image img {
    transform: scale(1.1);
  }
}
.ec-shelfGrid .ec-shelfGrid__item p.price02-default {
  margin: 0;
}
/* detail
------------------------------------------*/
.ec-productRole {
  color: var(--textColor);
  padding: 50px 0 0 0;
  max-width: 100%;
}
.ec-productRole .ec-grid2 {
  display: flex;
}
.ec-productRole .ec-grid2 .ec-grid2__cell {
  position: relative;
  padding: 0 var(--padding) 0 0;
  width: 60%;
}
.ec-productRole .ec-grid2 .ec-grid2__cell:nth-child(2) {
  padding: 0;
  width: 40%;
}
.ec-sliderItemRole {
  margin: 0;
  padding: 0;
  max-width: 100%;
}
.iv .swiper-pagination {
  display: none;
}
.iv-thumbnail {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 5px;
  margin: 10px 0 0 0;
}
.iv-thumbnail div {
  cursor: pointer;
  transition: all 0.3s ease;
}
@media (hover: hover) {
  .iv-thumbnail div:hover {
    opacity: 0.7;
  }
}
.ec-productRole .ec-productRole__profile {
  margin: 0;
  padding: 0;
}
.ec-productRole .ec-productRole__tags {
  display: flex;
  gap: 8px;
  margin: 0 0 15px 0;
  padding: 0;
  border: none;
}
.ec-productRole .ec-productRole__tag {
  padding: 8px;
  font-size: 11px;
  line-height: 1;
  color: var(--textColor);
  background: none;
  border: #8c8c8c 1px solid;
  border-radius: 2px;
}
.ec-productRole .ec-productRole__title .ec-headingTitle {
  margin: 0 0 20px 0;
  padding: 0;
  color: var(--textColor);
  font-size: var(--headFontSize);
  font-weight: var(--headFontWeight);
  letter-spacing: 0.08em;
}
.ec-productRole .ec-productRole__priceRegular {
  margin: 0 0 5px 0;
  padding: 0;
  font-size: var(--bodyFontSize);
}
.ec-productRole .ec-productRole__price {
  display: flex;
  margin: 0 0 30px 0;
  padding: 0;
  color: var(--itemDetailPriceColor);
  font-size: calc(var(--headFontSize) - 6px);
  border: none;
}
.ec-productRole .ec-productRole__price .ec-price__price {
  padding: 0;
  font-weight: var(--headFontWeight);
}

.ec-productRole .ec-productRole__actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 30px 0;
  padding: 0;
}
.ec-productRole .ec-productRole__actions .ec-select {
  margin: 0;
}
.ec-productRole .ec-productRole__actions .mb-3 {
  margin: 0 !important;
}
.ec-productRole .ec-productRole__actions .mb-3 label {
  display: block;
  margin: 0 0 5px 0;
  font-size: var(--bodyFontSize);
}
.ec-productRole .ec-productRole__actions .mb-3 select {
  margin: 0;
  width: 100%;
}

.ec-productRole .ec-productRole__btn {
  display: flex;
  gap: 8px;
  margin: 0;
  width: 100%;
  min-width: 100%;
}
.number-area {
  display: flex;
  padding: 0 5px;
  border: #8c8c8c 1px solid;
  border-radius: var(--inputBorderRadius);
}
.ec-productRole .ec-productRole__btn .number-area input {
  padding: 0;
  width: max(38px, 4vw);
  height: 100%;
  text-align: center;
  border: none;
  appearance: none;
  -moz-appearance: textfield;
}
.number-area input::-webkit-inner-spin-button,
.number-area input::-webkit-outer-spin-button {
  margin: 0;
  appearance: none;
}
.number-area .number-control {
  cursor: pointer;
  position: relative;
  width: 30px;
  height: 100%;
}
@media (hover: hover) {
  .number-area .number-control:hover {
    opacity: 0.7;
  }
}
.number-area .number-control:before,
.number-area .number-control:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  background: var(--textColor);
  transform: translate(-50%, -50%);
}
.number-area .number-up:after {
  width: 2px;
  height: 12px;
}
.ec-productRole .ec-productRole__btn .ec-blockBtn--action {
  padding: 20px 5px;
  color: var(--accentTextColor) !important;
  font-size: calc(var(--btnFontSize) + 2px) !important;
  background: var(--accentBgColor) !important;
  border: none !important;
}
@media (prefers-color-scheme: dark) {
  body.darkmode-1 .ec-productRole .ec-productRole__btn .ec-blockBtn--action {
    color: var(--bgColor) !important;
    background: var(--textColor) !important;
  }
}

.ec-productRole__sub {
  margin: 30px 0;
  padding: 20px;
  background: var(--subBgColor);
  border-radius: var(--inputBorderRadius);
}
.ec-productRole .ec-productRole__code,
.ec-productRole .ec-productRole__category {
  display: flex;
  padding: 0;
  font-size: 12px;
  border: none;
}
.ec-productRole__sub > div:not(:last-child) {
  margin: 0 0 8px 0;
}
.ec-productRole__sub > div > div {
  opacity: 0.5;
  width: 90px;
  font-weight: bold;
}
.ec-productRole .ec-productRole__category ul {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ec-productRole .ec-productRole__category ul li {
  display: flex;
  flex-wrap: wrap;
}
.ec-productRole .ec-productRole__category ul li a {
  color: var(--textColor);
  text-decoration: none;
}
.ec-productRole .ec-productRole__category ul li span {
  margin: 0 3px;
}

.ec-productRole__sns {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 30px 0 0 0;
}
.ec-productRole__sns .title {
  margin: 0 10px 0 0;
  padding: 0 0 0 2px;
  font-size: 11px;
  font-weight: bold;
  border-bottom: #8c8c8c 1px solid;
}
.ec-productRole__sns div a {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  background: var(--bgColor);
  border: #8c8c8c 1px solid;
  border-radius: 50%;
}
.ec-productRole__sns div a svg {
  width: 20px;
  fill: var(--textColor);
}

.ec-productRole__sns form {
  margin: 0 0 0 auto;
}
button#favorite {
  display: grid;
  place-items: center;
  position: relative;
  padding: 0;
  width: 36px;
  height: 36px;
  background: var(--bgColor) !important;
  border: #8c8c8c 1px solid;
  border-radius: 50%;
}
button#favorite:hover {
  opacity: 1;
}
button#favorite svg {
  margin: 2px 0 0 0;
  width: 18px;
  fill: var(--textColor);
}
button#favorite:disabled {
  opacity: 0.5;
}
button#favorite span {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: -55px;
  left: 50%;
  padding: 10px 0;
  width: 110px;
  color: var(--textColor);
  font-size: 11px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.02em;
  background: var(--bgColor);
  transform: translateX(-50%);
  border-radius: 3px;
  box-shadow: 0 1px 8px 0 rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
}
button#favorite.hover span {
  opacity: 1;
  visibility: visible;
  top: -45px;
}
button#favorite span:after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 50%;
  border-style: solid;
  border-width: 8px 5px 0 5px;
  border-color: var(--bgColor) transparent transparent transparent;
  transform: translateX(-50%);
}

.ec-productRole .ec-productRole__description {
  margin: 40px 0;
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight2);
}
.ec-productRole__freearea {
  margin: 40px 0;
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight2);
}
.ec-productRole__freearea dl {
  position: relative;
}
.ec-productRole__freearea dl:before {
  content: '';
  opacity: 0.1;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--textColor);
}
.ec-productRole__freearea dl dt {
  user-select: none;
  cursor: pointer;
  position: relative;
  padding: 15px 45px 15px 0;
}
.ec-productRole__freearea dl dt:before {
  content: '';
  opacity: 0.1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--textColor);
}
.ec-productRole__freearea dl dt span {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 30px;
  height: 30px;
  transform: translateY(-50%);
}
.ec-productRole__freearea dl dt span:before,
.ec-productRole__freearea dl dt span:after {
  content: "";
  position: absolute;
  top: 14px;
  left: 9px;
  width: 12px;
  height: 2px;
  background: var(--textColor);
  transition: all 0.3s ease;
}
.ec-productRole__freearea dl dt span:after {
  top: 9px;
  left: 14px;
  width: 2px;
  height: 12px;
}
.ec-productRole__freearea dl dt.open span:before,
.ec-productRole__freearea dl dt.open span:after {
  transform: rotate(90deg);
}
.ec-productRole__freearea dl dt.open span:before {
  opacity: 0;
}
.ec-productRole__freearea dl dd {
  display: none;
  margin: 0;
  padding: 0 0 20px 0;
}

@media (max-width: 768px) {
  .ec-productRole {
    padding: 0;
  }
  .ec-productRole .ec-grid2 {
    display: block;
  }
  .ec-productRole .ec-grid2 .ec-grid2__cell,
  .ec-productRole .ec-grid2 .ec-grid2__cell:nth-child(2) {
    padding: 0;
    width: 100%;
  }
  .ec-sliderItemRole {
    margin: 0 calc(50% - var(--vw) * 50) 40px calc(50% - var(--vw) * 50);
    padding: 0 0 30px 0;
    width: calc(var(--vw) * 100);
    max-width: 200%;
  }
  .iv {
    overflow: visible;
  }
  .iv .swiper-pagination {
    display: block;
    bottom: -30px;
  }
  .iv .swiper-pagination-bullet {
    opacity: 0.2;
    width: 5px;
    height: 5px;
    background: var(--textColor);
  }
  .iv .swiper-pagination-bullet-active {
    opacity: 0.8;
    background: var(--textColor);
  }
  .iv .swiper-pagination-bullet:only-child {
    display: block !important;
    margin: 0 auto;
  }
  .iv-thumbnail {
    display: none;
  }
}

#product_review_area {
  display: none !important;
}
.ec-layoutRole__main #product_review_area {
  display: block !important;
  margin: 0 auto;
  padding: var(--margin) 0 0 0;
  border-top: none;
}
.ec-layoutRole__main #product_review_area .ec-rectHeading {
  display: flex;
  justify-content: center;
  position: relative;
  margin: 0 0 30px 0;
  padding: 20px;
  background: var(--subBgColor);
  border-radius: var(--inputBorderRadius);
}
.ec-layoutRole__main #product_review_area .ec-rectHeading:after {
  content: "";
  position: absolute;
  top: 15px;
  right: 15px;
  width: 30px;
  height: 30px;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2046.35%2026.18%22%3E%3Cg%3E%3Cpath%20d%3D%22m.62.62h0c-.83.83-.83%2C2.18%2C0%2C3.01l22.55%2C22.55h0s0%2C0%2C0%2C0L45.72%2C3.63c.83-.83.83-2.18%2C0-3.01h0c-.83-.83-2.18-.83-3.01%2C0l-19.54%2C19.54L3.63.62c-.83-.83-2.18-.83-3.01%2C0Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  -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%2046.35%2026.18%22%3E%3Cg%3E%3Cpath%20d%3D%22m.62.62h0c-.83.83-.83%2C2.18%2C0%2C3.01l22.55%2C22.55h0s0%2C0%2C0%2C0L45.72%2C3.63c.83-.83.83-2.18%2C0-3.01h0c-.83-.83-2.18-.83-3.01%2C0l-19.54%2C19.54L3.63.62c-.83-.83-2.18-.83-3.01%2C0Z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    no-repeat center center / 12px;
  background-color: var(--textColor);
  transition: all 0.3s ease;
}
.ec-layoutRole__main #product_review_area .ec-rectHeading.is_active:after {
  transform: rotate(180deg);
}
.ec-layoutRole__main #product_review_area .ec-rectHeading h4 {
  margin: 0;
  padding: 0;
  font-size: var(--bodyFontSize);
  font-weight: bold;
  background: none;
  border: none;
}
.ec-layoutRole__main #product_review_area .ec-rectHeading h4 span {
  font-weight: normal;
}
.ec-layoutRole__main #product_review_area .recommend_average {
  color: var(--itemDetailReviewColor);
}
.ec-layoutRole__main #product_review_area .ec-role .ec-inlineBtn--action {
  margin: 0 auto;
  max-width: 160px;
}
.ec-layoutRole__main #product_review_area #reviewContent {
  margin: 30px 0;
}
.ec-layoutRole__main #product_review_area .review_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.ec-layoutRole__main #product_review_area .review_list .review_date {
  margin: 0 0 12px 0;
  font-size: 12px;
  font-weight: normal;
}
.ec-layoutRole__main #product_review_area .review_list .recommend_name {
  margin: 0 0 0 8px;
}
.ec-layoutRole__main #product_review_area .review_list .recommend_level {
  margin: 0 0 0 8px;
  color: var(--itemDetailReviewColor);
  font-size: var(--bodyFontSize);
}
.ec-layoutRole__main #product_review_area .review_list strong {
  display: block;
  margin: 0 0 12px 0;
  font-size: 16px;
}
.ec-layoutRole__main #product_review_area .review_list p {
  font-size: var(--bodyFontSize);
  line-height: var(--bodyLineHeight2);
}

@media (max-width: 768px) {
  .ec-layoutRole__main #product_review_area .ec-rectHeading {
    justify-content: flex-start;
  }
}

#RelatedProduct-product_area {
  margin: var(--margin) 0 0 0;
}


/* custom add */
.ec-searchnavRole .ec-searchnavRole__infos{
  max-width: 100%;
}
@media only screen and (min-width: 768px) {
  .ec-searchnavRole {
    max-width: 100%;
  }
}
.ec-topicpath .ec-topicpath__item a{
 color: var(--themeAccentBgColor); 
}
.ec-blogsRole__image{
  margin: 0 auto 30px;
}
.ec-blogsRole__profile img{
  width: auto;
}