@charset "UTF-8";
:root {
  --gj-color-light-black: #222;
  --gj-color-light-black-2: #2d2d2d;
  --gj-color-grey-1: #566c7b;
  --gj-color-grey-2: #757575;
  --gj-color-grey-3: #d7d7d7;
  --gj-color-white: #fff;
  --gj-color-blue: #00b3d6;
  --gj-color-blue-2: #039be5;
  --gj-color-blue-bg: #f2fbfd;
  --gj-color-orange: #ff873c;
  --gj-color-red: #e60000;
  --gj-color-gold: #a08200;
  --gj-color-disabled: #c0c0c0;
  --gj-color-pink: #fd0061;
  --gj-color-light-grey: #96acbb;
  --gj-text-color: var(--gj-color-light-black);
  --gj-text-color-light: var(--gj-color-grey-1);
  --gj-text-color-invert: var(--gj-color-white);
  --gj-text-color-link: var(--gj-color-blue-2);
  --gj-bg-color: var(--gj-color-white);
  --gj-border-color: #dadedf;
}
.l-theme.is-dark {
  --gj-text-color: var(--gj-color-white);
  --gj-text-color-light: var(--gj-color-grey-3);
  --gj-text-color-invert: var(--gj-color-light-black);
  background-color: #2d2d2d;
}
.l-even-width-blocks {
  display: flex;
}
.l-even-width-blocks > * {
  flex: 1 1 0;
}
/* || Buttons */
/**
 * 横方向に連結して並べられるボタンのデザイン。
 * 左右両端のボタンは角丸、それ以外は角丸なし。
 * `is-active` class が付与されたボタンは背景色が変わる。
 * `is-full-width` を指定することで、ボタンの幅を親要素いっぱいに広げることができる。
 */
.c-adjacent-buttons {
  --c-adjacent-button-color: var(--gj-color-orange);
  display: flex;
  height: 36px;
}
.c-adjacent-buttons .c-adjacent-buttons_item {
  display: grid;
  place-content: center;
  padding: 0 16px;
  border: 1px solid var(--c-adjacent-button-color);
  color: var(--c-adjacent-button-color);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  background-color: transparent;
}
.c-adjacent-buttons .c-adjacent-buttons_item.is-active {
  color: var(--gj-text-color-invert);
  background-color: var(--c-adjacent-button-color);
}
.c-adjacent-buttons .c-adjacent-buttons_item:first-of-type {
  border-radius: 8px 0 0 8px;
}
.c-adjacent-buttons .c-adjacent-buttons_item:not(:first-of-type) {
  border-left: none;
}
.c-adjacent-buttons .c-adjacent-buttons_item:last-of-type {
  border-radius: 0 8px 8px 0;
}
.c-adjacent-buttons .c-adjacent-buttons_item a {
  color: unset;
}
.c-adjacent-buttons.is-positive {
  --c-adjacent-button-color: var(--gj-color-blue);
}
.c-adjacent-buttons.is-full-width {
  width: 100%;
}
.c-adjacent-buttons.is-full-width .c-adjacent-buttons_item {
  flex: 1 1 auto;
}
/**
 * トグルボタンを表すコンポーネント。
 * `is-active` class が付与されたボタンは背景色が変わる。
 */
.c-toggle-buttons {
  display: flex;
}
.c-toggle-buttons .c-toggle-buttons_item {
  display: block;
  width: 50px;
  height: 34px;
  padding: 4px 8px;
  border: 1px solid var(--gj-color-blue);
  color: var(--gj-color-blue);
  background-color: var(--gj-color-white);
  cursor: pointer;
}
.c-toggle-buttons .c-toggle-buttons_item.is-active {
  color: var(--gj-color-white);
  background-color: var(--gj-color-blue);
}
.c-toggle-buttons .c-toggle-buttons_item:first-of-type {
  padding-left: 16px;
  border-radius: 30px 0 0 30px;
}
.c-toggle-buttons .c-toggle-buttons_item:last-of-type {
  padding-right: 16px;
  border-radius: 0 30px 30px 0;
}
/**
 * 角丸のボタンを表すコンポーネント。
 * .is-positive, .is-negative などのclassを付与することで色を変更することができる。
 * また、 .is-small を設定してサイズを変更することも可能。
 * --btn-min-width を指定することで、ボタンの最小幅を指定することができる。
 */
.c-round-btn {
  --c-round-btn-color: var(--gj-color-orange);
  display: grid;
  place-content: center;
  min-width: var(--btn-min-width, max-content);
  height: 34px;
  margin: 0;
  padding: 8px 16px;
  border-width: 0;
  border-radius: 30px;
  color: var(--gj-color-white);
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
  text-decoration: none;
  background-color: var(--c-round-btn-color);
  text-align: center;
  cursor: pointer;
}
.c-round-btn.is-positive {
  --c-round-btn-color: var(--gj-color-blue);
}
.c-round-btn.is-negative {
  --c-round-btn-color: var(--gj-color-grey-1);
}
.c-round-btn.is-alert {
  --c-round-btn-color: var(--gj-color-red);
}
.c-round-btn.is-white {
  --c-round-btn-color: var(--gj-color-white);
  color: var(--gj-color-light-black);
}
.c-round-btn .is-blue {
  color: #039be5;
  font-weight: 400;
}
.c-round-btn.is-dark {
  --c-round-btn-color: var(--gj-color-grey-2);
}
.c-round-btn.is-transparent {
  border: 1px solid var(--c-round-btn-color);
  color: var(--c-round-btn-color);
  background-color: transparent;
}
.c-round-btn.is-bg-white {
  border: 1px solid var(--c-round-btn-color);
  color: var(--c-round-btn-color);
  background-color: var(--gj-color-white);
}
.c-round-btn.is-shrink {
  width: max-content;
  font-size: 10px;
}
.c-round-btn.is-small {
  height: 24px;
  padding: 5.5px 8px;
  font-size: 10px;
}
.c-round-btn.is-big {
  margin-right: 20px;
  height: 52px;
  padding: 5.5px 8px;
  width: 190px;
}
@media screen and (max-width: 767px) {
  .c-round-btn.is-big {
    width: 48%;
    margin-right: 3%;
    min-width: 138px;
  }
}
.c-round-btn.is-full-width {
  width: 100%;
}
.c-round-btn.is-disabled {
  border: 1px solid var(--gj-color-disabled);
  color: var(--gj-color-white);
  font-weight: 400;
  background-color: var(--gj-color-disabled);
  cursor: default;
  pointer-events: none;
  user-select: none;
}
.c-round-btn.is-with-icon {
  --icon-size: 16px;
  display: flex;
  align-items: center;
  gap: 2px;
}
/**
 * リンクボタンコンポーネントのスタイル。
 */
.c-link-btn {
  color: var(--gj-text-color);
  font-size: 11px;
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
}
/**
 * セレクトボタン(ドロップボタン)コンポーネントのスタイル。
 */
.c-select-btn {
  --height: 28px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: var(--height);
  padding: 2px 4px 2px 12px;
  border: 1px solid #00b3d6;
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
}
.c-select-btn::after {
  --arrow-size: 24px;
  position: absolute;
  top: 0;
  right: 8px;
  content: "";
  width: var(--arrow-size);
  height: var(--arrow-size);
  background-image: url(/src/assets/img/common/icon-stroke-down.svg);
  transform: translateY(calc((var(--height) - var(--arrow-size)) / 2));
}
/* || Inputs */
/**
 * テキスト入力フィールドのスタイル。
 */
input[type=text].c-input-text {
  box-sizing: border-box;
  padding: 8px 16px;
  border: 1px solid var(--gj-border-color);
  background-color: var(--gj-color-white);
  font-size: 13px;
}
input[type=text].c-input-text::placeholder {
  color: var(--gj-color-light-grey);
  font-size: 13px;
}
/**
 * ラジオボタンのスタイル。
 */
input[type=radio].c-input-radio {
  position: relative;
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  border: 1px solid #b7c5cb;
  border-radius: 50%;
  appearance: none;
  cursor: pointer;
  opacity: 1;
  pointer-events: unset;
}
input[type=radio].c-input-radio:checked {
  border-color: var(--gj-color-blue);
}
input[type=radio].c-input-radio:checked::after {
  position: absolute;
  top: 50%;
  left: 50%;
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background-color: var(--gj-color-blue);
  transform: translate(-50%, -50%);
}
input[type=radio].c-input-radio:disabled {
  opacity: 0.5;
  cursor: default;
  pointer-events: none;
}
input[type=radio].c-input-radio:disabled:checked {
  border-color: #b7c5cb;
}
input[type=radio].c-input-radio:disabled:checked::after {
  background-color: #b7c5cb;
}
/* || Texts */
/**
 * テキストリンクを表すコンポーネント。
 */
.c-link-text {
  color: var(--gj-text-color-link);
  text-decoration-line: underline;
  display: inline;
}
/**
 * ラベル (タグ) を表すオブジェクト。
 * `is-new` class などを付与することで、色を変えることができる。
 */
.c-label {
  display: inline-block;
  min-width: 34px;
  max-width: 100%;
  height: 17px;
  padding: 2px 4px;
  border-radius: 2px;
  overflow: hidden;
  color: #fff;
  font-size: 10px;
  font-weight: 300;
  line-height: 13.5px;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-right: 4px;
  margin-bottom: 4px;
}
@media screen and (max-width: 768px) {
  .c-label {
    margin-bottom: 4px;
  }
}
.c-label.is-new, .c-label.is-pink {
  background: #fd0061;
}
.c-label.is-up, .c-label.is-yellow {
  background: #e5a500;
}
.c-label.is-high-resolution, .c-label.is-brown {
  background: #a08200;
}
.c-label.is-gravure, .c-label.is-gray {
  background: #808080;
}
.c-label.is-photos, .c-label.is-green {
  background: #00aea4;
}
.c-label.is-limited, .c-label.is-blue {
  background: #0071b0;
}
.c-label.is-weekly, .c-label.is-orange {
  background: #e47931;
}
.c-label.is-light-orange {
  background: #FF873C;
}
.c-label.is-shupule, .c-label.is-blue-green {
  background: #0199ad;
}
.c-label.is-discount {
  min-width: 100px;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  background: #fd0061;
}
.c-label.has-wide-padding {
  padding: 2px 8px;
}
/* || Headings */
.c-page-title {
  display: block;
  color: var(--gj-color-blue);
  font-size: 30px;
  font-weight: 600;
  letter-spacing: initial;
  text-align: center;
}
.c-section-title {
  --line-color: var(--gj-color-blue);
  display: block;
  margin-bottom: 8px;
  color: var(--gj-text-color);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: initial;
  text-align: center;
  text-decoration: underline 4px;
  text-decoration-color: var(--line-color);
  text-underline-offset: 8px;
}
.c-section-title.is-left {
  margin-bottom: initial;
  padding-left: 8px;
  border-left: 5px solid var(--gj-color-orange);
  line-height: 100%;
  text-align: start;
  text-decoration: none;
}
.c-section-title.has-arrow-left {
  position: relative;
  padding-left: 16px;
  margin-left: 0;
  color: var(--gj-text-color);
  font-size: 18px;
  font-weight: var(--gj-font-weight-600);
  line-height: 100%;
  text-align: left;
  text-decoration: none;
}
.c-section-title.has-arrow-left::before {
  --arrow-height: 18px;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 10px;
  height: var(--arrow-height);
  background-image: url(/src/assets/img/common/triangle-right.svg);
  background-repeat: no-repeat;
}
.c-section-title::before, .c-section-title:not(.plain)::before {
  width: 0;
  height: 0;
}
/* || Icons */
.c-icon {
  display: inline-block;
  width: var(--icon-size, 24px);
  min-width: var(--icon-size, 24px);
  height: var(--icon-size, 24px);
  min-height: var(--icon-size, 24px);
}
.c-icon.is-account {
  --image-url: url(/src/assets/img/common/icon-account.svg);
}
.c-icon.is-beginner {
  --image-url: url(/src/assets/img/common/icon-beginner.svg);
}
.c-icon.is-cart {
  --image-url: url(/src/assets/img/common/icon-cart.svg);
}
.c-icon.is-change {
  --image-url: url(/src/assets/img/common/icon-change.svg);
}
.c-icon.is-creditcard {
  --image-url: url(/src/assets/img/common/icon-creditcard.svg);
}
.c-icon.is-delete {
  --image-url: url(/src/assets/img/common/icon-delete.svg);
}
.c-icon.is-guide {
  --image-url: url(/src/assets/img/common/icon-guide.svg);
}
.c-icon.is-logout {
  --image-url: url(/src/assets/img/common/icon-logout.svg);
}
.c-icon.is-question {
  --image-url: url(/src/assets/img/common/icon-question.svg);
}
.c-icon.is-add-white {
  --image-url: url(/src/assets/img/common/icon-add-white.svg);
}
.c-icon.is-stroke-right {
  --image-url: url(/src/assets/img/common/icon-stroke-right.svg);
}
.c-icon.is-stroke-down {
  --image-url: url(/src/assets/img/common/icon-stroke-down-.svg);
}
.c-icon.is-check {
  --image-url: url(/src/assets/img/common/icon-check.svg);
}
.c-icon.is-time {
  --image-url: url(/src/assets/img/common/icon-time.svg);
}
.c-icon.is-list-view {
  --image-url: url(/src/assets/img/common/icon-list-view.svg);
}
.c-icon.is-grid-view {
  --image-url: url(/src/assets/img/common/icon-grid-view.svg);
}
.c-icon.is-notification {
  --image-url: url(/src/assets/img/common/icon-notification.svg);
}
.c-icon.is-coupon {
  --image-url: url(/src/assets/img/common/icon-coupon.svg);
}
.c-icon.is-close {
  --image-url: url(/src/assets/img/common/icon-close.svg);
}
.c-icon.is-twitter {
  --image-url: url(/src/assets/img/common/icon-twitter.svg);
}
.c-icon.is-facebook {
  --image-url: url(/src/assets/img/common/icon-facebook.svg);
}
.c-icon.is-line {
  --image-url: url(/src/assets/img/common/icon-line.svg);
}
.c-icon.is-tiktok {
  --image-url: url(/src/assets/img/common/icon-tiktok.svg);
}
.c-icon.is-triangle-down {
  --image-url: url(/src/assets/img/common/icon-triangle-down.svg);
}
.c-icon.is-x {
  --image-url: url(/src/assets/img/common/icon-x.svg);
}
.c-icon:not(.is-current-color) {
  background-image: var(--image-url);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
.c-icon.is-current-color {
  background-color: currentcolor;
  -webkit-mask-image: var(--image-url);
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-image: var(--image-url);
  mask-position: center;
  mask-size: contain;
  mask-repeat: no-repeat;
}
/* || UI Parts */
.c-share-icons-block {
  --icon-size: 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.c-share-icons-block .c-share-icons-block__text {
  color: var(--gj-text-color);
  font-size: 12px;
  font-weight: 600;
  line-height: 130%;
}
.c-share-icons-block .c-share-icons-block__icons {
  display: flex;
  gap: 8px;
}
@media (min-width: 768px) {
  .c-share-icons-block {
    --icon-size: 32px;
  }
}
.c-menu-link {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 24px;
  row-gap: 24px;
  max-width: 256px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .c-menu-link {
    column-gap: 8px;
  }
}
.c-menu-link .c-menu-link__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--gj-text-color);
  font-size: 12px;
  font-weight: 600;
  text-align: center;
}
.c-menu-link .c-menu-link__item a {
  display: grid;
  place-items: center;
  width: 100%;
  max-width: 104px;
  aspect-ratio: 1/1;
  border: 1px solid #dadedf;
  border-radius: 50%;
  background: var(--gj-color-white);
}
.c-menu-link .c-menu-link__item a img {
  width: 85%;
}
.c-menu-link .c-menu-link__item span {
  margin-inline: -2px;
}
.c-menu-link-bar {
  --border-color: #dadedf;
  position: relative;
  display: flex;
  align-items: center;
  justify-items: flex-end;
  gap: 5px;
  padding: 16px 15px;
  border-top: 1px solid var(--border-color);
  color: var(--gj-text-color);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
}
.c-menu-link-bar.has-border-bottom {
  border-bottom: 1px solid var(--border-color);
}
.c-menu-link-bar::after {
  position: relative;
  top: 0;
  right: 0;
  content: "";
  min-width: 24px;
  height: 24px;
  margin-left: auto;
  background-image: url(/src/assets/img/common/icon-stroke-right.svg);
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .c-menu-link-bar {
    --icon-size: 20px;
    padding: 4px 4px 4px 15px;
    font-size: 13px;
  }
}
.c-user-profile {
  display: grid;
  grid-template-columns: minmax(100px, max-content) 1fr;
  column-gap: 16px;
  row-gap: 16px;
  margin-left: var(--user-profile-margin-left, 0);
}
.c-user-profile dt {
  color: var(--gj-text-color-light);
  font-size: 13px;
  font-weight: 300;
  line-height: 130%;
}
.c-user-profile dd {
  margin: 0;
  overflow-x: hidden;
  color: var(--gj-text-color);
  font-size: 16px;
  font-weight: 300;
  line-height: 130%;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.c-sidebar {
  width: 100%;
}
@media (min-width: 768px) {
  .c-sidebar {
    max-width: 230px;
  }
}
.c-sidebar .c-sidebar__user {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 16px;
}
.c-sidebar .c-sidebar__user .c-sidebar__nickname {
  margin-bottom: 4px;
  color: var(--gj-text-color);
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
}
.c-sidebar .c-sidebar__user .c-sidebar__member-id {
  margin-bottom: 16px;
  color: var(--gj-text-color-light);
  font-size: 13px;
  font-weight: 300;
  line-height: 130%;
}
.c-sidebar .c-spacer {
  height: 24px;
}
.c-sidebar .c-sidebar__spacer {
  padding: 8px 15px;
  color: var(--gj-text-color-invert);
  font-size: 12px;
  font-weight: 600;
  line-height: 130%;
  background: #879ba9;
}
.c-sidebar .c-sidebar__links {
  background-color: #f2fbfd;
}
.c-sidebar .c-sidebar__links .c-sidebar__content-links {
  padding: 16px;
}
.c-subscription-block {
  display: flex;
  gap: 11px;
  line-height: 130%;
  font-weight: 300;
  text-align: start;
}
.c-subscription-block img {
  width: 30%;
  aspect-ratio: 104/159;
  object-fit: contain;
  object-position: top;
}
.c-subscription-block .c-subscription-block__info {
  width: 100%;
  display: flex;
  flex-direction: column;
}
.c-subscription-block .c-subscription-block__name {
  font-size: 12px;
  color: var(--gj-text-color-light);
  line-height: 130%;
}
.c-subscription-block .c-subscription-block__title {
  font-weight: 600;
  font-size: 16px;
  margin-top: 4px;
  line-height: 130%;
}
.c-subscription-block .c-subscription-block__status {
  font-size: 12px;
  color: var(--gj-text-color);
  margin-top: 8px;
  line-height: 130%;
}
.c-subscription-block .c-subscription-block__sub-info {
  font-size: 10px;
  line-height: 130%;
  margin-top: 0;
  color: var(--gj-text-color-light);
}
.c-subscription-block .c-subscription-block__sub-info:first-of-type {
  margin-top: 4px;
}
.c-subscription-block .c-subscription-block__sub-info_black {
  font-size: 10px;
  line-height: 130%;
  margin-top: 0;
}
.c-subscription-block .c-subscription-block__sub-info_black:first-of-type {
  margin-top: 4px;
}
.c-subscription-block .c-subscription-block__btn-wrapper {
  height: 100%;
  width: 100%;
  display: flex;
  align-items: flex-end;
}
.c-subscription-block .c-subscription-block__btn {
  margin-top: 8px;
  width: 100%;
}
.c-subscription-block.is-sidebar {
  flex-direction: column;
  gap: 0;
  padding-inline: 15px;
}
.c-subscription-block.is-sidebar img {
  width: 104px;
  margin-inline: auto;
}
.c-subscription-block.is-sidebar .c-subscription-block__name {
  font-size: 13px;
}
.c-subscription-block.is-sidebar .c-subscription-block__title {
  font-size: 18px;
}
.c-subscription-block.is-sidebar .c-subscription-block__status {
  margin-top: 8px;
  font-size: 13px;
}
.c-subscription-block.is-status {
  max-width: 345px;
}
.c-subscription-block.is-status img {
  width: 99px;
}
.c-subscription-block.is-status .c-subscription-block__name {
  font-size: 13px;
}
.c-subscription-block.is-status .c-subscription-block__title {
  font-size: 18px;
}
.c-subscription-block.is-status .c-subscription-block__status {
  margin-top: 8px;
  font-size: 13px;
}
.c-breadcrumb {
  display: none;
  padding: 20px 0 40px;
}
@media (min-width: 768px) {
  .c-breadcrumb {
    display: block;
  }
}
.c-breadcrumb .c-breadcrumb__item {
  display: inline-block;
  margin-right: 20px;
  font-size: 12px;
}
.c-breadcrumb .c-breadcrumb__item a {
  position: relative;
  color: #00b3d6;
}
.c-breadcrumb .c-breadcrumb__item a::after {
  position: absolute;
  top: 0;
  right: -20px;
  content: ">";
  width: 12px;
  height: 12px;
  color: #222;
  font-size: 12px;
  line-height: 10px;
}
.c-breadcrumb .c-breadcrumb__item a:hover {
  opacity: 0.5;
}
.c-breadcrumb .c-breadcrumb__item:first-child a {
  color: #039be5;
}
.c-breadcrumb .c-breadcrumb__item:last-child {
  margin-right: 0;
  max-width: 40em;
  text-overflow: ellipsis;
  overflow: hidden;
}
.c-breadcrumb .c-breadcrumb__item:last-child a {
  color: var(--gj-text-color);
  pointer-events: none;
}
.c-breadcrumb .c-breadcrumb__item:last-child a::after {
  display: none;
}
.c-price-and-tax {
  --price-font-size: 16px;
  --tax-font-size: 10px;
  --price-color: var(--gj-text-color);
  --tax-color: var(--gj-text-color);
  color: var(--price-color);
  font-size: var(--price-font-size);
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
  display: flex;
  align-items: baseline;
  gap: 2px;
}
.c-price-and-tax .c-price_tax {
  color: var(--gj-text-color);
  font-size: var(--tax-font-size);
  font-weight: 300;
}
.c-price-and-tax .c-label {
  translate: 0 -2px;
  margin: 0;
}
.c-price-and-tax.is-crossed .c-price_value,
.c-price-and-tax.is-crossed .c-price_tax {
  text-decoration: line-through;
}
@media (min-width: 768px) {
  .c-price-and-tax.is-dynamic {
    --price-font-size: 20px;
    --tax-font-size: 11px;
  }
}
.c-price-and-tax.is-small {
  --price-font-size: 12px;
  --tax-font-size: 10px;
}
@media (min-width: 768px) {
  .c-price-and-tax.is-small.is-dynamic {
    --price-font-size: 16px;
    --tax-font-size: 10px;
  }
}
.c-price-and-tax.is-big {
  --price-font-size: 20px;
  --tax-font-size: 11px;
}
.c-price-and-tax.is-subtle {
  --price-color: var(--gj-text-color-light);
  --tax-color: var(--gj-text-color-light);
}
.c-price-and-tax.is-orange {
  --price-color: var(--gj-color-orange);
}
.c-price-and-tax.is-pink {
  --price-color: var(--gj-color-pink);
}
li.c-discount-message {
  display: grid;
  grid-template-columns: 14px auto;
  align-items: start;
  color: var(--gj-text-color);
  font-size: 11px;
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
  margin-bottom: 4px;
}
li.c-discount-message:last-child {
  margin-bottom: 0px;
}
li.c-discount-message .c-discount-message__plus_extra_message .c-icon {
  display: none;
}
li.c-discount-message .asterisk-icon {
  --icon-size: 14px;
  text-align: center;
  color: var(--gj-color-orange);
}
li.c-discount-message .c-discount-message_emphasize {
  color: var(--gj-color-red);
}
.c-discount-expires {
  display: flex;
  gap: 2px;
  color: var(--gj-text-color-light);
  font-size: 11px;
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
}
.is-sp > .c-breadcrumb {
  display: block;
}
@media (min-width: 768px) {
  .is-sp > .c-breadcrumb {
    display: none;
  }
}
.has-no-padding > .c-breadcrumb {
  padding: initial;
}
#sp-bread-crumbs-on-header .c-breadcrumb,
#sp-bread-crumbs-on-footer .c-breadcrumb {
  display: none;
  padding: 20px 0 40px;
}
@media (max-width: 768px) {
  #sp-bread-crumbs-on-header .c-breadcrumb,
  #sp-bread-crumbs-on-footer .c-breadcrumb {
    padding: 10px 0 18px 0;
    display: block;
    line-height: 2em;
  }
  #sp-bread-crumbs-on-header .c-breadcrumb .c-breadcrumb__list,
  #sp-bread-crumbs-on-footer .c-breadcrumb .c-breadcrumb__list {
    display: flex;
    overflow: auto;
    -ms-overflow-style: none; /* IE & Edge */
    scrollbar-width: none; /* Firefox */
  }
  #sp-bread-crumbs-on-header .c-breadcrumb .c-breadcrumb__list::-webkit-scrollbar,
  #sp-bread-crumbs-on-footer .c-breadcrumb .c-breadcrumb__list::-webkit-scrollbar {
    display: none; /* Safari */
  }
  #sp-bread-crumbs-on-header .c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item,
  #sp-bread-crumbs-on-footer .c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item {
    height: 15px;
    white-space: nowrap;
    overflow: unset;
  }
  #sp-bread-crumbs-on-header .c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item a::after,
  #sp-bread-crumbs-on-footer .c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item a::after {
    top: 3px;
  }
  #sp-bread-crumbs-on-header .c-breadcrumb .c-breadcrumb__list .slash a::after,
  #sp-bread-crumbs-on-footer .c-breadcrumb .c-breadcrumb__list .slash a::after {
    content: "/";
  }
}
/* || テキストカラー */
.u-font-color-normal {
  color: var(--gj-text-color);
}
.u-font-color-subtle {
  color: var(--gj-text-color-light);
}
.u-font-color-invert {
  color: var(--gj-text-color-invert);
}
/* || フォントサイズ */
.u-font-size-10 {
  font-size: 10px;
}
.u-font-size-11 {
  font-size: 11px;
}
.u-font-size-12 {
  font-size: 12px;
}
.u-font-size-13 {
  font-size: 13px;
}
.u-font-size-14 {
  font-size: 14px;
}
.u-font-size-15 {
  font-size: 15px;
}
.u-font-size-16 {
  font-size: 16px;
}
.u-font-size-17 {
  font-size: 17px;
}
.u-font-size-18 {
  font-size: 18px;
}
.u-font-size-19 {
  font-size: 19px;
}
.u-font-size-20 {
  font-size: 20px;
}
.u-font-size-21 {
  font-size: 21px;
}
.u-font-size-22 {
  font-size: 22px;
}
.u-font-size-23 {
  font-size: 23px;
}
.u-font-size-24 {
  font-size: 24px;
}
.u-font-size-25 {
  font-size: 25px;
}
.u-font-size-26 {
  font-size: 26px;
}
.u-font-size-27 {
  font-size: 27px;
}
.u-font-size-28 {
  font-size: 28px;
}
.u-font-size-29 {
  font-size: 29px;
}
.u-font-size-30 {
  font-size: 30px;
}
.u-font-size-31 {
  font-size: 31px;
}
.u-font-size-32 {
  font-size: 32px;
}
.u-font-size-33 {
  font-size: 33px;
}
.u-font-size-34 {
  font-size: 34px;
}
.u-font-size-35 {
  font-size: 35px;
}
.u-font-size-36 {
  font-size: 36px;
}
.u-font-size-37 {
  font-size: 37px;
}
.u-font-size-38 {
  font-size: 38px;
}
.u-font-size-39 {
  font-size: 39px;
}
.u-font-size-40 {
  font-size: 40px;
}
.u-font-size-41 {
  font-size: 41px;
}
.u-font-size-42 {
  font-size: 42px;
}
.u-font-size-43 {
  font-size: 43px;
}
.u-font-size-44 {
  font-size: 44px;
}
.u-font-size-45 {
  font-size: 45px;
}
.u-font-size-46 {
  font-size: 46px;
}
.u-font-size-47 {
  font-size: 47px;
}
.u-font-size-48 {
  font-size: 48px;
}
.u-font-size-49 {
  font-size: 49px;
}
.u-font-size-50 {
  font-size: 50px;
}
/* || フォントウェイト */
.u-font-weight-semibold {
  font-weight: 600;
}
.u-font-weight-normal {
  font-weight: 400;
}
.u-font-weight-light {
  font-weight: 300;
}
/* || テキスト */
.u-text-subtle {
  color: var(--gj-text-color-light);
  font-size: 12px;
  font-weight: 300;
}
.u-text-emphasize {
  color: var(--gj-text-color);
  font-size: 14px;
  font-weight: 600;
}
.u-text-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.u-text-ellipsis.has-2-lines {
  display: -webkit-box;
  white-space: unset;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.u-text-ellipsis.has-3-lines {
  display: -webkit-box;
  white-space: unset;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.u-text-ellipsis.has-4-lines {
  display: -webkit-box;
  white-space: unset;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}
.u-text-ellipsis.has-5-lines {
  display: -webkit-box;
  white-space: unset;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
}
/* || レイアウト */
.u-w-full {
  width: 100%;
}
.u-h-full {
  height: 100%;
}
/* || 配置 */
.u-place-center-x {
  display: grid;
  justify-content: end;
}
.u-place-center-y {
  display: grid;
  align-content: end;
}
.u-place-center {
  display: grid;
  place-content: center;
}
.u-place-right {
  display: grid;
  justify-content: end;
}
.u-place-left {
  display: grid;
  justify-content: flex-start;
}
.u-place-top {
  display: grid;
  align-content: flex-start;
}
.u-place-bottom {
  display: grid;
  align-content: end;
}
.u-position-absolute-top-right {
  position: absolute;
  top: 0;
  right: 0;
}
.u-position-absolute-top-left {
  position: absolute;
  top: 0;
  left: 0;
}
.u-position-absolute-bottom-right {
  position: absolute;
  bottom: 0;
  right: 0;
}
.u-position-absolute-bottom-left {
  position: absolute;
  bottom: 0;
  left: 0;
}
.u-position-absolute-middle-right {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
.u-position-absolute-middle-left {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.u-position-absolute-top-middle {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.u-position-absolute-bottom-middle {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
/* || Margin, Padding */
.u-mt-0 {
  margin-top: 0rem;
}
.u-mr-0 {
  margin-right: 0rem;
}
.u-mb-0 {
  margin-bottom: 0rem;
}
.u-mi-0 {
  margin-inline: 0rem;
}
.u-ml-0 {
  margin-left: 0rem;
}
.u-pt-0 {
  padding-top: 0rem;
}
.u-pr-0 {
  padding-right: 0rem;
}
.u-pb-0 {
  padding-bottom: 0rem;
}
.u-pl-0 {
  padding-left: 0rem;
}
.u-pi-0 {
  padding-inline: 0rem;
}
.u-mt-1 {
  margin-top: 0.25rem;
}
.u-mr-1 {
  margin-right: 0.25rem;
}
.u-mb-1 {
  margin-bottom: 0.25rem;
}
.u-mi-1 {
  margin-inline: 0.25rem;
}
.u-ml-1 {
  margin-left: 0.25rem;
}
.u-pt-1 {
  padding-top: 0.25rem;
}
.u-pr-1 {
  padding-right: 0.25rem;
}
.u-pb-1 {
  padding-bottom: 0.25rem;
}
.u-pl-1 {
  padding-left: 0.25rem;
}
.u-pi-1 {
  padding-inline: 0.25rem;
}
.u-mt-2 {
  margin-top: 0.5rem;
}
.u-mr-2 {
  margin-right: 0.5rem;
}
.u-mb-2 {
  margin-bottom: 0.5rem;
}
.u-mi-2 {
  margin-inline: 0.5rem;
}
.u-ml-2 {
  margin-left: 0.5rem;
}
.u-pt-2 {
  padding-top: 0.5rem;
}
.u-pr-2 {
  padding-right: 0.5rem;
}
.u-pb-2 {
  padding-bottom: 0.5rem;
}
.u-pl-2 {
  padding-left: 0.5rem;
}
.u-pi-2 {
  padding-inline: 0.5rem;
}
.u-mt-3 {
  margin-top: 0.75rem;
}
.u-mr-3 {
  margin-right: 0.75rem;
}
.u-mb-3 {
  margin-bottom: 0.75rem;
}
.u-mi-3 {
  margin-inline: 0.75rem;
}
.u-ml-3 {
  margin-left: 0.75rem;
}
.u-pt-3 {
  padding-top: 0.75rem;
}
.u-pr-3 {
  padding-right: 0.75rem;
}
.u-pb-3 {
  padding-bottom: 0.75rem;
}
.u-pl-3 {
  padding-left: 0.75rem;
}
.u-pi-3 {
  padding-inline: 0.75rem;
}
.u-mt-4 {
  margin-top: 1rem;
}
.u-mr-4 {
  margin-right: 1rem;
}
.u-mb-4 {
  margin-bottom: 1rem;
}
.u-mi-4 {
  margin-inline: 1rem;
}
.u-ml-4 {
  margin-left: 1rem;
}
.u-pt-4 {
  padding-top: 1rem;
}
.u-pr-4 {
  padding-right: 1rem;
}
.u-pb-4 {
  padding-bottom: 1rem;
}
.u-pl-4 {
  padding-left: 1rem;
}
.u-pi-4 {
  padding-inline: 1rem;
}
.u-mt-5 {
  margin-top: 1.25rem;
}
.u-mr-5 {
  margin-right: 1.25rem;
}
.u-mb-5 {
  margin-bottom: 1.25rem;
}
.u-mi-5 {
  margin-inline: 1.25rem;
}
.u-ml-5 {
  margin-left: 1.25rem;
}
.u-pt-5 {
  padding-top: 1.25rem;
}
.u-pr-5 {
  padding-right: 1.25rem;
}
.u-pb-5 {
  padding-bottom: 1.25rem;
}
.u-pl-5 {
  padding-left: 1.25rem;
}
.u-pi-5 {
  padding-inline: 1.25rem;
}
.u-mt-6 {
  margin-top: 1.5rem;
}
.u-mr-6 {
  margin-right: 1.5rem;
}
.u-mb-6 {
  margin-bottom: 1.5rem;
}
.u-mi-6 {
  margin-inline: 1.5rem;
}
.u-ml-6 {
  margin-left: 1.5rem;
}
.u-pt-6 {
  padding-top: 1.5rem;
}
.u-pr-6 {
  padding-right: 1.5rem;
}
.u-pb-6 {
  padding-bottom: 1.5rem;
}
.u-pl-6 {
  padding-left: 1.5rem;
}
.u-pi-6 {
  padding-inline: 1.5rem;
}
.u-mt-7 {
  margin-top: 1.75rem;
}
.u-mr-7 {
  margin-right: 1.75rem;
}
.u-mb-7 {
  margin-bottom: 1.75rem;
}
.u-mi-7 {
  margin-inline: 1.75rem;
}
.u-ml-7 {
  margin-left: 1.75rem;
}
.u-pt-7 {
  padding-top: 1.75rem;
}
.u-pr-7 {
  padding-right: 1.75rem;
}
.u-pb-7 {
  padding-bottom: 1.75rem;
}
.u-pl-7 {
  padding-left: 1.75rem;
}
.u-pi-7 {
  padding-inline: 1.75rem;
}
.u-mt-8 {
  margin-top: 2rem;
}
.u-mr-8 {
  margin-right: 2rem;
}
.u-mb-8 {
  margin-bottom: 2rem;
}
.u-mi-8 {
  margin-inline: 2rem;
}
.u-ml-8 {
  margin-left: 2rem;
}
.u-pt-8 {
  padding-top: 2rem;
}
.u-pr-8 {
  padding-right: 2rem;
}
.u-pb-8 {
  padding-bottom: 2rem;
}
.u-pl-8 {
  padding-left: 2rem;
}
.u-pi-8 {
  padding-inline: 2rem;
}
.u-mt-9 {
  margin-top: 2.25rem;
}
.u-mr-9 {
  margin-right: 2.25rem;
}
.u-mb-9 {
  margin-bottom: 2.25rem;
}
.u-mi-9 {
  margin-inline: 2.25rem;
}
.u-ml-9 {
  margin-left: 2.25rem;
}
.u-pt-9 {
  padding-top: 2.25rem;
}
.u-pr-9 {
  padding-right: 2.25rem;
}
.u-pb-9 {
  padding-bottom: 2.25rem;
}
.u-pl-9 {
  padding-left: 2.25rem;
}
.u-pi-9 {
  padding-inline: 2.25rem;
}
.u-mt-10 {
  margin-top: 2.5rem;
}
.u-mr-10 {
  margin-right: 2.5rem;
}
.u-mb-10 {
  margin-bottom: 2.5rem;
}
.u-mi-10 {
  margin-inline: 2.5rem;
}
.u-ml-10 {
  margin-left: 2.5rem;
}
.u-pt-10 {
  padding-top: 2.5rem;
}
.u-pr-10 {
  padding-right: 2.5rem;
}
.u-pb-10 {
  padding-bottom: 2.5rem;
}
.u-pl-10 {
  padding-left: 2.5rem;
}
.u-pi-10 {
  padding-inline: 2.5rem;
}
.u-mt-11 {
  margin-top: 2.75rem;
}
.u-mr-11 {
  margin-right: 2.75rem;
}
.u-mb-11 {
  margin-bottom: 2.75rem;
}
.u-mi-11 {
  margin-inline: 2.75rem;
}
.u-ml-11 {
  margin-left: 2.75rem;
}
.u-pt-11 {
  padding-top: 2.75rem;
}
.u-pr-11 {
  padding-right: 2.75rem;
}
.u-pb-11 {
  padding-bottom: 2.75rem;
}
.u-pl-11 {
  padding-left: 2.75rem;
}
.u-pi-11 {
  padding-inline: 2.75rem;
}
.u-mt-12 {
  margin-top: 3rem;
}
.u-mr-12 {
  margin-right: 3rem;
}
.u-mb-12 {
  margin-bottom: 3rem;
}
.u-mi-12 {
  margin-inline: 3rem;
}
.u-ml-12 {
  margin-left: 3rem;
}
.u-pt-12 {
  padding-top: 3rem;
}
.u-pr-12 {
  padding-right: 3rem;
}
.u-pb-12 {
  padding-bottom: 3rem;
}
.u-pl-12 {
  padding-left: 3rem;
}
.u-pi-12 {
  padding-inline: 3rem;
}
.u-mt-13 {
  margin-top: 3.25rem;
}
.u-mr-13 {
  margin-right: 3.25rem;
}
.u-mb-13 {
  margin-bottom: 3.25rem;
}
.u-mi-13 {
  margin-inline: 3.25rem;
}
.u-ml-13 {
  margin-left: 3.25rem;
}
.u-pt-13 {
  padding-top: 3.25rem;
}
.u-pr-13 {
  padding-right: 3.25rem;
}
.u-pb-13 {
  padding-bottom: 3.25rem;
}
.u-pl-13 {
  padding-left: 3.25rem;
}
.u-pi-13 {
  padding-inline: 3.25rem;
}
.u-mt-14 {
  margin-top: 3.5rem;
}
.u-mr-14 {
  margin-right: 3.5rem;
}
.u-mb-14 {
  margin-bottom: 3.5rem;
}
.u-mi-14 {
  margin-inline: 3.5rem;
}
.u-ml-14 {
  margin-left: 3.5rem;
}
.u-pt-14 {
  padding-top: 3.5rem;
}
.u-pr-14 {
  padding-right: 3.5rem;
}
.u-pb-14 {
  padding-bottom: 3.5rem;
}
.u-pl-14 {
  padding-left: 3.5rem;
}
.u-pi-14 {
  padding-inline: 3.5rem;
}
.u-mt-15 {
  margin-top: 3.75rem;
}
.u-mr-15 {
  margin-right: 3.75rem;
}
.u-mb-15 {
  margin-bottom: 3.75rem;
}
.u-mi-15 {
  margin-inline: 3.75rem;
}
.u-ml-15 {
  margin-left: 3.75rem;
}
.u-pt-15 {
  padding-top: 3.75rem;
}
.u-pr-15 {
  padding-right: 3.75rem;
}
.u-pb-15 {
  padding-bottom: 3.75rem;
}
.u-pl-15 {
  padding-left: 3.75rem;
}
.u-pi-15 {
  padding-inline: 3.75rem;
}
.u-mt-16 {
  margin-top: 4rem;
}
.u-mr-16 {
  margin-right: 4rem;
}
.u-mb-16 {
  margin-bottom: 4rem;
}
.u-mi-16 {
  margin-inline: 4rem;
}
.u-ml-16 {
  margin-left: 4rem;
}
.u-pt-16 {
  padding-top: 4rem;
}
.u-pr-16 {
  padding-right: 4rem;
}
.u-pb-16 {
  padding-bottom: 4rem;
}
.u-pl-16 {
  padding-left: 4rem;
}
.u-pi-16 {
  padding-inline: 4rem;
}
.u-mt-17 {
  margin-top: 4.25rem;
}
.u-mr-17 {
  margin-right: 4.25rem;
}
.u-mb-17 {
  margin-bottom: 4.25rem;
}
.u-mi-17 {
  margin-inline: 4.25rem;
}
.u-ml-17 {
  margin-left: 4.25rem;
}
.u-pt-17 {
  padding-top: 4.25rem;
}
.u-pr-17 {
  padding-right: 4.25rem;
}
.u-pb-17 {
  padding-bottom: 4.25rem;
}
.u-pl-17 {
  padding-left: 4.25rem;
}
.u-pi-17 {
  padding-inline: 4.25rem;
}
.u-mt-18 {
  margin-top: 4.5rem;
}
.u-mr-18 {
  margin-right: 4.5rem;
}
.u-mb-18 {
  margin-bottom: 4.5rem;
}
.u-mi-18 {
  margin-inline: 4.5rem;
}
.u-ml-18 {
  margin-left: 4.5rem;
}
.u-pt-18 {
  padding-top: 4.5rem;
}
.u-pr-18 {
  padding-right: 4.5rem;
}
.u-pb-18 {
  padding-bottom: 4.5rem;
}
.u-pl-18 {
  padding-left: 4.5rem;
}
.u-pi-18 {
  padding-inline: 4.5rem;
}
.u-mt-19 {
  margin-top: 4.75rem;
}
.u-mr-19 {
  margin-right: 4.75rem;
}
.u-mb-19 {
  margin-bottom: 4.75rem;
}
.u-mi-19 {
  margin-inline: 4.75rem;
}
.u-ml-19 {
  margin-left: 4.75rem;
}
.u-pt-19 {
  padding-top: 4.75rem;
}
.u-pr-19 {
  padding-right: 4.75rem;
}
.u-pb-19 {
  padding-bottom: 4.75rem;
}
.u-pl-19 {
  padding-left: 4.75rem;
}
.u-pi-19 {
  padding-inline: 4.75rem;
}
.u-mt-20 {
  margin-top: 5rem;
}
.u-mr-20 {
  margin-right: 5rem;
}
.u-mb-20 {
  margin-bottom: 5rem;
}
.u-mi-20 {
  margin-inline: 5rem;
}
.u-ml-20 {
  margin-left: 5rem;
}
.u-pt-20 {
  padding-top: 5rem;
}
.u-pr-20 {
  padding-right: 5rem;
}
.u-pb-20 {
  padding-bottom: 5rem;
}
.u-pl-20 {
  padding-left: 5rem;
}
.u-pi-20 {
  padding-inline: 5rem;
}
/* vueの読み込み前後でガタつく件を解消 */
/* ヘッダー */
.header_wrapper {
  height: 70px;
}
@media screen and (max-width: 767px) {
  .header_wrapper {
    height: 50px;
  }
}
/* トップのスライダー */
.top_slider_wrapper {
  min-height: calc((33.3333333333vw - 12px) * 0.44 + 3px + 25px);
  margin: 0 auto 10px;
}
.top_slider_wrapper .swiper {
  margin-bottom: 0;
}
.top_slider_wrapper .p-top-slider__item {
  margin: 0;
}
@media screen and (max-width: 767px) {
  .top_slider_wrapper {
    min-height: calc((100vw - 30px) * 0.44 + 27px);
  }
  .top_slider_wrapper .swiper-slide > div {
    font-size: 0;
  }
}
/* ヘッダー：検索フォームのcss */
.header__search-input > form {
  display: flex;
}
.header__search .enterkey-submit {
  width: 0;
  height: 0;
  padding: 0;
  margin: 0;
  background: none;
  border: none;
  position: absolute;
  overflow: hidden;
}
.header__search-selectbox .select-wrapper input.select-dropdown {
  padding: 0;
  width: 165px;
  line-height: 36px;
}
@media screen and (max-width: 767px) {
  .header__search-category-item.header__search-category-item-plus a {
    border-radius: 4px;
  }
}
/* サイドバー */
.sidebar .sidebar__link1 > .sidebar__mypage-name {
  text-align: center;
}
.sidebar > .sidebar__btn-important {
  margin-bottom: 10px;
}
.sidebar > .banner {
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .header__menu > .header__menu-member > .sidebar__mypage-name {
    margin-bottom: 15px;
    text-align: center;
    font-size: 15px;
    font-weight: bold;
    color: #00b3d6;
  }
}
footer .news-logo {
  display: block;
  width: 70%;
  height: 40px;
  margin: 0 0 10px;
  padding: 9px 0 0;
}
@media screen and (max-width: 767px) {
  footer .news-logo {
    width: 204px;
    height: auto;
    margin: 0 auto 10px;
  }
}
footer .news-logo .cls-1,
footer .news-logo .cls-3 {
  fill: #ba2617;
}
footer .news-logo .cls-1,
footer .news-logo .cls-2 {
  stroke: #181311;
}
footer .news-logo .cls-1 {
  stroke-width: 2.1px;
}
footer .news-logo .cls-2 {
  fill: #181311;
  stroke-width: 4.5px;
}
footer .footer__photo-rooms a {
  display: block;
  width: 70%;
  height: 40px;
  margin: 0 0 10px;
}
@media screen and (max-width: 767px) {
  footer .footer__photo-rooms a {
    width: 184px;
    height: auto;
    margin: 0 auto 10px;
  }
}
footer .footer__photo-rooms a .cls-1 {
  fill: #898989;
}
footer .footer__photo-rooms a .cls-2 {
  fill: #231815;
}
footer .footer__photo-rooms a img {
  width: 100%;
}
footer .footer__abj-logo {
  width: 100px;
  margin: -10px 20px 0 -15px;
}
@media screen and (max-width: 767px) {
  footer .footer__abj-logo {
    margin: 0 auto;
  }
}
footer .footer__abj-logo .cls-1 {
  fill: none;
}
footer .footer__abj-logo .cls-2 {
  fill: #231815;
}
#app .c-special-offer {
  display: none;
}
#app .c-special-offer.is-show {
  display: flex;
}
/* ボタンタグ */
button {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo", "MS Pゴシック", "MS P Gothic", Osaka, sans-serif;
  cursor: pointer;
}
.c-btn-important1 button,
.c-btn-important2 button {
  background-color: #fd0061;
  border: 1px solid #fd0061;
  border-radius: 50px;
  color: #fff;
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  height: 52px;
  letter-spacing: 0.1em;
  line-height: 48px;
  margin: 0 auto;
  text-align: center;
  width: 190px;
  transition: all 0.4s ease;
}
@media screen and (max-width: 767px) {
  .c-btn-important1 button,
  .c-btn-important2 button {
    border-radius: 45px;
    font-size: 15px;
    height: 45px;
    line-height: 43px;
    width: 300px;
  }
}
.c-btn-important1 button:hover,
.c-btn-important2 button:hover {
  background-color: #fff;
  color: #fd0061;
}
.c-btn-important2 button {
  background-color: #fff;
  color: #fd0061;
}
.c-btn-important2 button:hover {
  background-color: #fd0061;
  color: #fff;
}
.c-btn-normal1 button,
.c-btn-normal2 button {
  background-color: #fff;
  border: 1px solid #00b3d6;
  border-radius: 50px;
  color: #00b3d6;
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  height: 52px;
  letter-spacing: 0.1em;
  line-height: 48px;
  text-align: center;
  width: 190px;
  transition: all 0.4s ease;
}
@media screen and (max-width: 767px) {
  .c-btn-normal1 button,
  .c-btn-normal2 button {
    border-radius: 45px;
    font-size: 15px;
    height: 45px;
    line-height: 43px;
    width: 300px;
  }
}
.c-btn-normal1 button:hover,
.c-btn-normal2 button:hover {
  background-color: #fff;
  color: #00b3d6;
}
.c-btn-normal1 button:disabled,
.c-btn-normal2 button:disabled {
  color: white;
  background-color: silver;
  border-color: silver;
  cursor: default;
}
button.c-btn-regular_inner:hover, button.c-btn-regular_inner:focus, button.c-btn-regular_inner:active {
  background: #ff0060;
}
button.c-btn-regular_inner:hover p, button.c-btn-regular_inner:focus p, button.c-btn-regular_inner:active p {
  color: #fff;
}
button.c-btn-regular_inner:hover .c-btn-regular_plus, button.c-btn-regular_inner:focus .c-btn-regular_plus, button.c-btn-regular_inner:active .c-btn-regular_plus {
  color: #fef33f;
}
button.c-btn-regular_inner:hover .c-label-off, button.c-btn-regular_inner:focus .c-label-off, button.c-btn-regular_inner:active .c-label-off {
  background: #fef33f;
  color: #ff0060;
}
@media screen and (max-width: 767px) {
  .c-thumbnail-list__item .c-btn-addcart a {
    height: 29px;
    display: grid;
  }
}
.c-btn-addcart {
  display: inline-block;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .c-btn-addcart {
    text-align: center;
  }
}
.c-btn-addcart button {
  display: grid;
  place-items: center;
  background: #fff;
  background-image: unset;
  border: 1px solid #00b3d6;
  border-radius: 30px;
  color: #00b3d6;
  height: 30px;
  width: 100%;
  letter-spacing: 0.1em;
  padding: initial;
}
@media screen and (max-width: 767px) {
  .c-btn-addcart button {
    font-size: 12px;
    height: 34px;
    line-height: 32px;
    width: 260px;
  }
  .c-btn-addcart button::before {
    content: "";
    -webkit-transform: translate(-50%, -50%);
    height: 18px;
    left: calc(50% - 55px);
    top: 50%;
    transform: translate(-50%, -50%);
    width: 18px;
    position: absolute;
    display: block;
  }
}
.c-btn-addcart button:hover {
  opacity: 0.5;
}
.c-btn-addcart a {
  display: grid;
  place-items: center;
  padding: initial;
  border: 1px solid #00b3d6;
  border-radius: 30px;
  color: #00b3d6;
  font-size: 10px;
  font-weight: 600;
  line-height: 130%;
  background: #fff;
  background-image: unset;
  height: 29px;
}
/*
 * アプリで見るボタン
 * ブラウザで見るボタンがない場合のみ
 */
.c-btn-read.app-btn-only {
  padding: 0 11px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .c-btn-read.app-btn-only {
    margin: 0 auto 5px;
    padding: 0;
    width: 95%;
  }
}
.c-btn-read.app-btn-only > a > br {
  display: none;
}
/* エラーメッセージ */
.error-msg-area {
  margin-bottom: 20px;
}
.error-msg-area > p {
  margin-bottom: 5px;
  padding: 5px 10px;
  background-color: #ff0060;
  color: #fff;
  text-align: center;
  border-radius: 4px;
}
/* フォーム要素 */
.c-input__item input[type=text],
.c-input__item input[type=email],
.c-input__item input[type=password] {
  box-sizing: border-box;
}
/* ページネーター */
/* ページが多い時に出る「…」の部分 */
.c-pager__item.disabled > span {
  font-size: 14px;
  height: 40px;
  line-height: 34px;
  margin: 0 6px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-pager__item.disabled > span {
    line-height: 28px;
  }
}
.c-slider-model__img img {
  border-radius: 0;
}
@media screen and (min-width: 768px) {
  .c-breadcrumb__item.slash {
    margin-right: 10px;
  }
  .c-breadcrumb__item.slash a::after {
    content: "/";
    right: -16px;
  }
}
body.bookend .book-error {
  text-align: center;
  margin-top: 40px;
}
body.bookend .book-error .l-content {
  margin: 0 auto;
}
body.bookend .footer {
  position: fixed;
  bottom: 0;
  width: 100%;
  padding: 0;
}
@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop, .c-thumbnail-list__img img {
    height: 100%;
    width: 100%;
  }
  *::-ms-backdrop, .search_list img {
    height: auto;
    width: auto;
  }
  *::-ms-backdrop, .search_plus_list img {
    height: auto;
  }
}
/* vueとmaterializeの相性が悪いためにセレクトボックスで不具合出たので解消 */
select.browser-default {
  display: block;
  padding-left: 1em;
  width: auto;
  height: 38px;
  background-color: #FFFFFF;
  font-size: 14px;
  border: 1px solid #000000;
}
@media screen and (max-width: 768px) {
  select.browser-default {
    height: 45px;
    font-size: 16px;
  }
}
select.browser-default:focus {
  outline: none;
}
select.browser-default > option {
  font-size: inherit;
}
.c-input__item .c-input__selectbox-wrapper select {
  display: inline-block;
  appearance: none;
  padding-left: 10px;
  background-color: #FFFFFF;
  background-image: url(/src/assets/img/common/arrow-grey-down.png);
  background-size: 12px 8px;
  background-position: right 8px center;
  background-repeat: no-repeat;
  font-size: 13px;
  border: 2px solid #dce8ec;
}
@media screen and (max-width: 768px) {
  .c-input__item .c-input__selectbox-wrapper select {
    width: 150px;
    background-size: 10px 6.5px;
    background-position: right 5px center;
    font-size: 16px;
  }
}
.c-input__item .c-input__selectbox-wrapper.c-input__selectbox-year select {
  width: 81px;
}
.c-input__item .c-input__selectbox-wrapper.c-input__selectbox-month select,
.c-input__item .c-input__selectbox-wrapper.c-input__selectbox-day select {
  width: 61px;
}
.credit-card_flex .select-wrapper {
  position: relative;
}
@media screen and (max-width: 768px) {
  .credit-card_flex .select-wrapper {
    width: 150px;
  }
}
.credit-card_flex .select-wrapper:after {
  position: absolute;
  top: 50%;
  right: 17px;
  margin-top: -2px;
  border-top: 5px solid #000000;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  content: "";
}
.credit-card_flex .select-wrapper select {
  width: 250px;
}
@media screen and (max-width: 768px) {
  .credit-card_flex .select-wrapper select {
    width: 100%;
  }
}
.c-label-plus {
  background-color: #ff873c !important;
}
.c-label-new {
  background-color: #fd0061;
  display: inline-grid;
  place-content: center;
  min-width: 34px;
  height: 17px;
  padding: 2px 4px;
  border-radius: 2px;
  color: #fff;
  font-size: 10px;
  font-weight: 300;
  margin-right: 4px;
}
.c-label-photobook {
  background-color: #00aea4;
  display: inline-grid;
  place-content: center;
  min-width: 34px;
  height: 17px;
  padding: 2px 4px;
  border-radius: 2px;
  color: #fff;
  font-size: 10px;
  font-weight: 300;
  margin-right: 4px;
}
.c-label-limited {
  background-color: #0071b0;
  display: inline-grid;
  place-content: center;
  min-width: 34px;
  height: 17px;
  padding: 2px 4px;
  border-radius: 2px;
  color: #fff;
  font-size: 10px;
  font-weight: 300;
  margin-right: 4px;
}
.c-label-entertainment {
  background-color: #feb25e;
  display: inline-grid;
  place-content: center;
  min-width: 34px;
  height: 17px;
  padding: 2px 4px;
  border-radius: 2px;
  color: #fff;
  font-size: 10px;
  font-weight: 300;
  margin-right: 4px;
}
@media screen and (max-width: 768px) {
  .c-btn-trial {
    text-align: center;
  }
}
.c-btn-trial,
.c-btn-trial2 {
  display: inline-block;
  margin: 0 auto;
  width: 164px;
}
@media screen and (max-width: 768px) {
  .c-btn-trial,
  .c-btn-trial2 {
    width: 131px;
  }
}
.c-btn-trial a,
.c-btn-trial2 a {
  background-color: #fff;
  border: 1px solid #00b3d6;
  border-radius: 30px;
  color: #00b3d6;
  display: inline-block;
  font-size: 14px;
  height: 30px;
  letter-spacing: 0.1em;
  line-height: 28px;
  position: relative;
  text-align: center;
  width: 164px;
}
@media screen and (max-width: 768px) {
  .c-btn-trial a,
  .c-btn-trial2 a {
    font-size: 12px;
    height: 34px;
    line-height: 32px;
    width: 260px;
  }
}
.c-btn-trial a:hover,
.c-btn-trial2 a:hover {
  background-color: #00b3d6;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .c-btn-trial2 a {
    margin-top: 15px;
    width: 140px;
  }
}
.preview-tag {
  height: 30px;
  position: fixed;
  bottom: 0;
  width: 100%;
  background-color: red;
  text-align: center;
  line-height: 30px;
  opacity: 0.8;
}
.preview-tag > p {
  color: white;
}
.preview-tag > p > a {
  display: inline-block;
  text-decoration: underline;
  font-weight: bold;
  color: lightgoldenrodyellow;
}
@media screen and (max-width: 768px) {
  .preview-tag {
    bottom: calc(18.666666vw + 10px);
  }
}
@media screen and (max-width: 360px) {
  .preview-tag {
    bottom: 18.666666vw;
    height: 45px;
    line-height: 15px;
  }
}
div.input-field select.browser-default {
  border-radius: 22px;
  width: 300px;
  margin: auto;
  padding-top: 0;
  padding-bottom: 0;
  height: 34px;
}
.browser-default-parent {
  border-radius: 22px;
  width: 300px;
  margin: auto;
  margin-top: 0px;
  font-size: 130%;
  text-align: center;
  text-align-last: center;
  padding-top: 0;
  padding-bottom: 0;
  position: relative;
}
.c-selectbox-own::before {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  position: absolute;
}
.c-selectbox-own {
  margin: auto;
  position: relative;
}
.c-selectbox-own::before {
  -webkit-transform: translateY(-50%);
  background-image: url(/src/assets/img/common/arrow-black-down.png);
  background-size: 8px 5px;
  height: 5px;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}
@media screen and (min-width: 768px) {
  div.input-field select.browser-default {
    border-radius: 17px;
    margin: auto;
    padding: 0;
    width: 100%;
    height: 40px;
    line-height: 40px;
    border-radius: 20px;
    margin: 0 0 0 0px;
    font-size: 13px;
    text-align: center;
    padding-right: 1em;
    padding-left: 1em;
  }
}
.campaign-banner.detail {
  border-radius: 4px;
  margin-bottom: 25px;
}
.campaign-banner.top {
  height: 100%;
}
.campaign-banner.top .campaign-banner__img {
  height: 100%;
}
.campaign-banner.top .campaign-banner__img img {
  height: 100%;
}
.top-banner__margin {
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .top-banner__margin {
    margin-bottom: 25px;
  }
}
.plus-special-img-newly,
.plus-special-img-update {
  position: relative;
  font-size: 12px;
  color: #fff;
}
.plus-special-img-newly::before,
.plus-special-img-update::before {
  border-radius: 2px;
  display: inline-block;
  padding: 2px 0;
  width: 30px;
  font-size: 11px;
  text-align: center;
  margin-right: 0.5em;
}
.plus-special-img-newly::before {
  content: "New";
  background: #fd0061;
}
.plus-special-img-update::before {
  content: "UP";
  background: #e5a500;
}
.plus-special-img-position {
  margin-bottom: 5px;
  text-align: center;
}
.grecaptcha-badge {
  visibility: hidden;
}
.c-thumbnail-list__item.c-thumbnail-list__item-2 .c-btn-trial,
.c-thumbnail-list__item.c-thumbnail-list__item-2 .c-btn-trial a, .c-thumbnail-list__item.c-thumbnail-list__item-3 .c-btn-trial,
.c-thumbnail-list__item.c-thumbnail-list__item-3 .c-btn-trial a {
  width: 100%;
}
.c-thumbnail-list__item.c-thumbnail-list__item-5 a {
  display: inline-block;
}
.c-subscription-block.is-status picture {
  width: 99px;
  aspect-ratio: 104/159;
  object-fit: contain;
  object-position: top;
}
.c-subscription-block picture {
  width: 156px;
  aspect-ratio: 104/159;
  object-fit: contain;
  object-position: top;
}
.c-subscription-block picture img {
  width: 100%;
}
picture.sidebar-webp {
  width: 104px;
  margin-inline: auto;
}
picture.inherit {
  height: inherit;
  width: inherit;
}
picture.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}
picture.border {
  border: 1px solid var(--gj-border-color);
}
.about-swiper {
  min-width: 146px;
}
.p-index__find .p-index__find__keyword__headings ul.p-index__find__keyword__list {
  margin-top: 0.5em;
  margin-bottom: 1em;
  text-align: left;
}
.p-index__find .p-index__find__keyword__headings li.p-index__find__keyword {
  display: inline-block;
  line-height: 1.8em;
  margin: 0px 4px;
  font-size: 15px;
}
.p-index__find__keyword__headings h3 {
  text-align: left;
}