@charset "UTF-8";
/* rank アイコンv */
.label--exclusive.-sticker, .label--exclusive.-rectangle {
  background: #ad0003;
  color: #ffffff;
  font-weight: bold;
  line-height: 1;
}
.label--exclusive.-sticker:hover, .label--exclusive.-rectangle:hover {
  text-decoration: none;
}

.label--exclusive.-rectangle {
  padding: 5px 0;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 14px;
}

.label--exclusive.-sticker, .label--exclusive.-rectangle {
  background: #ad0003;
  color: #ffffff;
  font-weight: bold;
  line-height: 1;
}
.label--exclusive.-sticker:hover, .label--exclusive.-rectangle:hover {
  text-decoration: none;
}

.label--exclusive.-sticker {
  position: absolute;
  top: 6px;
  left: 6px;
  font-size: 12px;
  padding: 5px;
  border-radius: 50%;
}

.card-product {
  display: flex;
  flex-direction: column;
  height: calc(100% - 4px);
  position: relative;
  background: #fff;
  box-shadow: 0 2px 0 0 #e5e5e5;
  border-radius: 4px;
  border: 1px solid #e5e5e5;
  overflow: hidden;
  /* pickup */
  /* 準備中・品切れ・受付終了サイン */
}
.card-product__link {
  min-height: 0%;
  flex-grow: 1;
  display: flex;
  width: 100%;
  flex-direction: column;
}
.card-product__link:hover .card-product__img {
  opacity: 0.85;
}
.card-product__link:hover .card-product__title,
.card-product__link:hover .card-product__txt {
  color: #1e50a2;
  text-decoration: underline;
}
.card-product__image {
  position: relative;
}
.card-product__img {
  width: 100%;
  max-height: 100%;
  border-bottom: 0;
  display: block;
}
.card-product__title {
  color: #2b2b2b;
  font-weight: normal;
  font-size: 16px;
  letter-spacing: 0;
  margin: -1px;
  border-radius: 4px 4px 0 0;
}
.card-product__status {
  position: absolute;
  z-index: 1;
}
.card-product__contents {
  padding: 12px 8px;
}
.card-product__contents .lst-icon {
  margin-top: 4px;
  display: none;
}
.card-product__contents .lst-icon.none {
  margin: 0;
}
.card-product__img {
  text-align: center;
}
.card-product__status {
  position: absolute;
}
.card-product__subtitle {
  margin-top: 8px;
}
.card-product__subtitle-inner {
  padding: 8px;
  font-size: 16px;
  font-weight: bold;
  color: #ad0003;
  box-sizing: border-box;
}
.card-product__price-text {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  align-items: center;
}
.card-product__price {
  margin-right: 4px;
}
.card-product__point {
  font-size: 12px;
  color: #16160e;
  font-weight: normal;
}
.card-product__price-option {
  color: #16160e;
  font-weight: normal;
}
.card-product__price-option img {
  height: 14px;
  min-width: 73px;
}
.card-product__price-option span {
  vertical-align: middle;
  font-size: 12px;
}
.card-product .sts-type3 {
  background: #d59300;
  color: #fff;
  padding: 2px 8px;
  border-radius: 0 4px 4px 0;
  position: absolute;
  left: -1px;
  bottom: 4px;
  font-size: 10px;
}
.card-product .sts-type4,
.card-product .sts-type5,
.card-product .sts-type6 {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.5);
  color: #fff;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  border-radius: 3px 3px 0 0;
  font-size: 18px;
  text-align: center;
  position: absolute;
  opacity: 1;
  top: 0;
  left: 0;
  -webkit-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.card-product .sts-type7 {
  text-align: center;
  line-height: 1;
  top: 0;
  left: 0;
  font-size: 14px;
}
.card-product .sts-type7:before {
  content: "";
  height: 0;
  width: 0;
  position: absolute;
  left: 0;
  border-top: 20px solid #d3d3d3;
  border-left: 20px solid #d3d3d3;
  border-bottom: 20px solid transparent;
  border-right: 20px solid transparent;
}
.card-product .sts-type7 .icn-ranking {
  display: none;
}
.card-product .sts-type7 span {
  position: absolute;
  min-width: 24px;
  top: 6px;
  font-weight: bold;
  white-space: nowrap;
}
.card-product .sts-type7.item-rank1 {
  background-color: #b78c00;
}
.card-product .sts-type7.item-rank1::before {
  border-color: #b78c00;
}
.card-product .sts-type7.item-rank2 {
  background-color: #557088;
}
.card-product .sts-type7.item-rank2::before {
  border-color: #557088;
}
.card-product .sts-type7.item-rank3 {
  background-color: #bc7421;
}
.card-product .sts-type7.item-rank3::before {
  border-color: #bc7421;
}
.card-product .sts-type7.item-rank1, .card-product .sts-type7.item-rank2, .card-product .sts-type7.item-rank3 {
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
  align-items: center;
  color: #ffffff;
  width: 26px;
  top: 0;
  left: 10px;
}
.card-product .sts-type7.item-rank1 .icn-ranking, .card-product .sts-type7.item-rank2 .icn-ranking, .card-product .sts-type7.item-rank3 .icn-ranking {
  display: block;
  font-size: 14px;
  margin: 2px 0 4px;
  font-size: 0.9em;
}
.card-product .sts-type7.item-rank1 .icn-ranking::before, .card-product .sts-type7.item-rank2 .icn-ranking::before, .card-product .sts-type7.item-rank3 .icn-ranking::before {
  position: relative;
  top: 3px;
}
.card-product .sts-type7.item-rank1 span, .card-product .sts-type7.item-rank2 span, .card-product .sts-type7.item-rank3 span {
  position: static;
  -webkit-transform: none;
          transform: none;
  z-index: 1;
  line-height: 1;
}
.card-product .sts-type7.item-rank1::before, .card-product .sts-type7.item-rank2::before, .card-product .sts-type7.item-rank3::before {
  content: "";
  position: absolute;
  bottom: -11px;
  border-width: 13px;
  border-bottom: 4px solid transparent;
}
.card-product__text {
  color: #6b6b6b;
  font-size: 14px;
  margin-top: 8px;
  display: none;
}
.card-product__text.none {
  margin: 0;
}
.card-product__text .txt {
  font-size: inherit;
}
.card-product__txt {
  font-size: inherit;
  max-height: 168px;
  overflow: hidden;
}
.card-product__code {
  color: #6b6b6b;
  margin: 8px 0 0 auto;
  font-size: 12px;
  order: 1;
  display: none;
}
.card-product__comment {
  color: #1e50a2;
  font-size: 14px;
  padding: 0 10px 10px;
  width: 100%;
}
.card-product__comment:hover {
  text-decoration: underline;
}
.card-product__comment::before {
  color: #1e50a2;
  display: inline-block;
  margin-right: 4px;
  vertical-align: middle;
}
.card-product__icn-message {
  position: relative;
  padding-left: 20px;
}
.card-product__icn-message:before {
  color: #1e50a2;
  position: absolute;
  margin-left: -16px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.card-product__heart {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  background: none;
  border: 0;
  margin: 0;
  padding: 8px;
}
.card-product__heart > img {
  width: 28px;
}
.card-product__city {
  display: flex;
  height: 40px;
  padding: 8px;
  border-top: 1px solid #e5e5e5;
  box-sizing: content-box;
  color: #1e50a2;
  font-size: 14px;
  align-items: center;
}
.card-product__city:hover {
  text-decoration: underline;
}
.card-product__city:hover img {
  opacity: 0.85;
}
.card-product__city > img {
  border-radius: 2px;
  border: 1px solid #e5e5e5;
  width: 38px;
  height: 38px;
  margin-right: 7px;
}
.card-product__city > span {
  display: inline-block;
  letter-spacing: 0;
  margin-right: 5px;
}
.card-product__city .award-label {
  margin-left: auto;
  flex-shrink: 0;
}
.card-product .speed-shipping-label__wrap {
  padding: 0 10px 16px;
}
.card-product .speed-shipping-label__wrap .speed-shipping-label {
  margin: 0 0 1px 0;
}
.card-product .speed-shipping-label__wrap .speed-shipping-label__sub {
  color: #6b6b6b;
  font-size: 12px;
  padding: 0;
}
.card-product .sendiconlist {
  display: block;
}

.choice-icon-color {
  color: #d59300;
}

.choicepay-icon-color {
  color: #239dda;
}

.card-product__delete {
  background: none;
  border: 0;
  cursor: pointer;
  position: absolute;
  top: 0;
  right: 0;
}
.card-product__delete > svg {
  display: inline-block;
  vertical-align: top;
}

.card-product__category {
  font-size: 14px;
  background-color: #f2f2f2;
  text-align: center;
  line-height: 1;
  padding: 6px 0;
}

[data-layout-product=all] .card-product__text {
  display: block;
}
[data-layout-product=all] .card-product__contents .lst-icon {
  display: block;
}
[data-layout-product=all] .speed-shipping-label__wrap .card-product__code {
  display: block;
}

[data-layout-product=part] .sendiconlist {
  display: none;
}

.card-product__text + .speed-shipping-label, .card-product__text + .speed-shipping-label__sub {
  margin-top: 8px;
}

.card-project {
  display: flex;
  flex-direction: column;
  height: calc(100% - 4px);
  position: relative;
  background: #fff;
  box-shadow: 0 2px 0 0 #e5e5e5;
  border-radius: 4px;
  border: 1px solid #e5e5e5;
  overflow: hidden;
}
.card-project__link {
  min-height: 0%;
  flex-grow: 1;
  display: flex;
  width: 100%;
  flex-direction: column;
}
.card-project__link:hover .card-project__img {
  opacity: 0.85;
}
.card-project__link:hover .card-project__title,
.card-project__link:hover .card-project__txt {
  color: #1e50a2;
  text-decoration: underline;
}
.card-project__image {
  position: relative;
}
.card-project__img {
  width: 100%;
  max-height: 100%;
  border-bottom: 0;
  display: block;
}
.card-project__title {
  color: #2b2b2b;
  font-weight: normal;
  font-size: 16px;
  letter-spacing: 0;
  margin: -1px;
  border-radius: 4px 4px 0 0;
}
.card-project__status {
  position: absolute;
  z-index: 1;
}
.card-project__contents {
  padding: 12px 8px;
}
.card-project__contents .lst-icon {
  margin-top: 4px;
  display: none;
}
.card-project__contents .lst-icon.none {
  margin: 0;
}
.card-project:before {
  content: "";
  display: block;
  height: 0;
  order: 1;
  width: 48%;
}
.card-project .article-sld:hover {
  text-decoration: none;
  color: #16160e;
  opacity: 0.85;
}
.card-project .article-sld:hover .card-project__name {
  text-decoration: underline;
}
.card-project__img.lazyload, .card-project__img.lazyloading {
  height: 115px;
}
.card-project__col {
  background-color: #ffffff;
  position: relative;
  margin: 40px 0 0 0;
  width: 100%;
  box-sizing: border-box;
  /* プロジェクト終了時 */
}
.card-project__col:nth-child(1), .card-project__col:nth-child(2) {
  margin: 0;
}
.card-project__col.is-end .card-project__progress > div:first-child,
.card-project__col.is-end .card-project__favorite-button,
.card-project__col.is-end .card-project__target-amount,
.card-project__col.is-end .card-project__row:not(:first-child),
.card-project__col.is-end .chart-bar {
  display: none;
}
.card-project__col.is-end .card-project__text--pref {
  width: 100%;
}
.card-project__col.is-end .card-project__end-button {
  cursor: default;
  display: block;
}
.card-project__col .card-project__complete {
  position: absolute;
  top: 12px;
  left: 4px;
  height: 40px;
  width: 40px;
  z-index: 1;
}
.card-project__col .card-project__soon {
  position: absolute;
  top: 8px;
  left: 4px;
  width: 63px;
  height: 21px;
  border-radius: 0 0 4px 4px;
}
.card-project__label {
  box-sizing: border-box;
  position: relative;
  background: #e5e5e5;
  width: 100%;
  height: 18px;
  margin: 0 auto -8px;
  padding: 4px;
  text-align: center;
  z-index: 1;
}
.card-project__label .card-project__text {
  font-size: 10px;
  letter-spacing: 0;
}
.card-project__image {
  overflow: hidden;
  position: relative;
  text-align: center;
}
.card-project__title {
  height: 4.3em;
  overflow: hidden;
}
.card-project__remind--complete, .card-project__remind--soon {
  display: block;
  float: left;
  font-size: 12px;
  width: 76px;
  text-align: center;
  margin-right: 8px;
  color: #16160e;
}
.card-project__remind--complete {
  border-top: solid 1px #f2b02d;
  border-bottom: solid 1px #f2b02d;
  background: #fcf2df;
}
.card-project__remind--soon {
  border-top: solid 1px #93ca76;
  border-bottom: solid 1px #93ca76;
  background: #edf5e9;
}
.card-project__name {
  display: block;
  font-size: 14px;
  letter-spacing: 0.01em;
}
.card-project__pref {
  font-size: 10px;
  line-height: 1;
}
.card-project__pref .icn-office {
  margin-right: 4px;
}
.card-project__target-amount {
  font-size: 12px;
  width: 100%;
}
.card-project__time-left {
  font-weight: bold;
  font-size: 12px;
  margin-top: 4px;
}
.card-project__total {
  width: 100%;
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  align-items: baseline;
}
.card-project__text {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.2;
}
.card-project__badge {
  box-sizing: border-box;
  background-color: #e5e5e5;
  border-radius: 10px;
  display: inline-block;
  font-size: 10px;
  font-weight: bold;
  margin-right: 8px;
  padding: 2px 4px;
  text-align: center;
}
.card-project__quantity {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: -0.4px;
}
.card-project__quantity.deadline {
  color: #e8000a;
}
.card-project__unit {
  font-size: 12px;
}
.card-project__progress {
  margin-top: 8px;
}
.card-project__progress > div:first-child {
  flex: 1;
  margin-right: 4px;
}
.card-project__progress > div:nth-child(2) {
  flex: 1;
  min-width: 98px;
}
.card-project__progress .gcf-cht-bar {
  margin-top: 8px;
}
.card-project__limit {
  font-size: 14px;
  line-height: 1.2;
  text-align: center;
}
.card-project__favorite-button {
  background-color: #ffffff;
  border: 2px solid #ad0003;
  border-radius: 4px;
  color: #ad0003;
  font-size: 10px;
  line-height: 1.8em;
  height: 26px;
  outline: none;
  padding: 1px 0 0;
  text-align: center;
  vertical-align: text-bottom;
  width: 100%;
}
.card-project__favorite-button:hover {
  cursor: pointer;
  opacity: 0.85;
}
.card-project__favorite-button .icn-heart,
.card-project__favorite-button .icn-heart2 {
  margin-right: 4px;
  vertical-align: middle;
}
.card-project__favorite-button .icn-heart {
  display: none;
}
.card-project__favorite-button .icn-heart2:before {
  font-weight: bold;
  vertical-align: top;
}
.card-project__favorite-button.on .icn-heart {
  display: inline-block;
  vertical-align: middle;
  line-height: 14px;
}
.card-project__favorite-button.on .icn-heart2 {
  display: none;
}
.card-project__end-button {
  border-radius: 4px;
  box-sizing: border-box;
  color: #ffffff;
  display: none;
  font-size: 10px;
  height: 22px;
  margin-top: 8px;
  padding-top: 4px;
  text-align: center;
  width: 100%;
}
.card-project__value {
  display: inline;
}
.card-project__end {
  font-size: 10px;
  margin-left: 5px;
  display: inline;
}
.card-project__list {
  margin-top: 4px;
}
.card-project__lead span {
  text-align: center;
  width: 56px;
  padding: 5px 8px;
  background: #f6f6f6;
  font-size: 10px;
  font-weight: bold;
  border-radius: 30px;
  line-height: 1;
}
.card-project .goods-col_name {
  height: 4.5em;
  margin-top: 12px;
}
.card-project .chart-bar {
  margin: 8px 0;
}

/* progress bar chart */
.gcf-cht-bar {
  background: #e5e5e5;
  width: 100%;
  height: 24px;
  margin-bottom: 8px;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
}
.gcf-cht-bar__graph {
  background-color: #93ca76;
  width: 0;
  height: 24px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
}
.gcf-cht-bar__graph2 {
  background-color: #f2b02d;
  width: 0;
  height: 24px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
}
.gcf-cht-bar__number {
  width: 100%;
  height: 24px;
  line-height: 24px;
  font-size: 12px;
  font-weight: bold;
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9;
}
.grid-7 .card-product__contents {
  padding: 0;
}
.grid-7 .card-product__subtitle {
  margin-top: 0;
  background: transparent;
}
.grid-7 .card-product__subtitle-inner {
  padding: 4px;
  justify-content: center;
  font-weight: normal;
}
.grid-7 .card-product__price {
  font-size: 12px;
}
.grid-7 .card-product__point {
  margin: 0 auto;
}
.grid-7 .card-product__price {
  margin: 0 auto;
}
.grid-7 .card-product__city, .grid-7 .card-product__title, .grid-7 .card-product__heart {
  display: none;
}
.grid-col .card-product {
  border: none;
  box-shadow: none;
  border-radius: 0;
  height: auto;
}
.grid-col .card-product__link {
  display: flex;
  flex-direction: row;
}
.grid-col .card-product__image {
  width: 97px;
  min-width: 97px;
  height: 60px;
  min-height: 60px;
  border: 1px solid #c8c8c8;
}
.grid-col .card-product__img {
  border: none;
  margin: inherit;
  border-radius: 0;
}
.grid-col .card-product__contents {
  padding: 0;
  margin-left: 12px;
}
.grid-col .card-product__title {
  font-size: 14px;
}
.grid-col .card-product__subtitle {
  background-color: transparent;
  margin: 0;
}
.grid-col .card-product__subtitle-inner {
  padding: 0;
  margin: 0;
}
.grid-col .card-product__city {
  display: none;
}
.grid-col .card-product__heart {
  display: none;
}
.grid-col .card-product .sts-type7.item-rank1, .grid-col .card-product .sts-type7.item-rank2, .grid-col .card-product .sts-type7.item-rank3 {
  left: 0;
}

.card-city {
  display: flex;
  flex-direction: column;
  height: calc(100% - 4px);
  position: relative;
  background: #fff;
  box-shadow: 0 2px 0 0 #e5e5e5;
  border-radius: 4px;
  border: 1px solid #e5e5e5;
  overflow: hidden;
}
.card-city__link {
  min-height: 0%;
  flex-grow: 1;
  display: flex;
  width: 100%;
  flex-direction: column;
}
.card-city__link:hover .card-city__img {
  opacity: 0.85;
}
.card-city__link:hover .card-city__title,
.card-city__link:hover .card-city__txt {
  color: #1e50a2;
  text-decoration: underline;
}
.card-city__image {
  position: relative;
}
.card-city__img {
  width: 100%;
  max-height: 100%;
  border-bottom: 0;
  display: block;
}
.card-city__title {
  color: #2b2b2b;
  font-weight: normal;
  font-size: 16px;
  letter-spacing: 0;
  margin: -1px;
  border-radius: 4px 4px 0 0;
}
.card-city__status {
  position: absolute;
  z-index: 1;
}
.card-city__contents {
  padding: 12px 8px;
}
.card-city__contents .lst-icon {
  margin-top: 4px;
  display: none;
}
.card-city__contents .lst-icon.none {
  margin: 0;
}
.card-city__image {
  height: 104px;
  overflow: hidden;
  display: flex;
  justify-content: center;
}
.card-city__img {
  max-width: initial;
  width: auto !important;
  height: 100%;
}
.card-city__title {
  position: relative;
  border-bottom: solid 1px #e5e5e5;
  padding-bottom: 8px;
  margin-top: 16px;
}
.card-city__cityimg {
  width: 40px;
  border: solid 1px #e5e5e5;
  border-radius: 4px;
}
.card-city__name {
  text-align: center;
  font-size: 14px;
}
.card-city__info {
  font-size: 14px;
  padding: 8px 0 16px;
}
.card-city__info dl {
  display: flex;
  flex-wrap: wrap;
}
.card-city__info dl dt,
.card-city__info dl dd {
  padding: 4px 0;
}
.card-city__info dl dt {
  width: 20%;
  letter-spacing: 0;
}
.card-city__info small {
  font-size: 12px;
  text-align: right;
  display: block;
  margin-top: 8px;
}
.card-city__info .emphasis {
  font-weight: bold;
}
.card-city__category {
  font-size: 14px;
}
.card-city__category h4 {
  font-size: 14px;
  font-weight: normal;
  margin-bottom: 8px;
}
.card-city__category p {
  font-weight: bold;
  font-size: 14px;
  margin-bottom: 8px;
}
.card-city__category p span:not(:last-child):after {
  content: "、";
}
.card-city__description {
  font-size: 14px;
  padding-top: 8px;
  border-top: solid 1px #e5e5e5;
  overflow: hidden;
  height: 84px;
}

.card-article {
  display: flex;
  flex-direction: column;
  height: calc(100% - 4px);
  position: relative;
  background: #fff;
  box-shadow: 0 2px 0 0 #e5e5e5;
  border-radius: 4px;
  border: 1px solid #e5e5e5;
  overflow: hidden;
  height: 100%;
}
.card-article__link {
  min-height: 0%;
  flex-grow: 1;
  display: flex;
  width: 100%;
  flex-direction: column;
}
.card-article__link:hover .card-article__img {
  opacity: 0.85;
}
.card-article__link:hover .card-article__title,
.card-article__link:hover .card-article__txt {
  color: #1e50a2;
  text-decoration: underline;
}
.card-article__image {
  position: relative;
}
.card-article__img {
  width: 100%;
  max-height: 100%;
  border-bottom: 0;
  display: block;
}
.card-article__title {
  color: #2b2b2b;
  font-weight: normal;
  font-size: 16px;
  letter-spacing: 0;
  margin: -1px;
  border-radius: 4px 4px 0 0;
}
.card-article__status {
  position: absolute;
  z-index: 1;
}
.card-article__contents {
  padding: 12px 8px;
}
.card-article__contents .lst-icon {
  margin-top: 4px;
  display: none;
}
.card-article__contents .lst-icon.none {
  margin: 0;
}
.card-article .sts-type7 {
  text-align: center;
  line-height: 1;
  top: 0;
  left: 0;
  font-size: 14px;
}
.card-article .sts-type7:before {
  content: "";
  height: 0;
  width: 0;
  position: absolute;
  left: 0;
  border-top: 20px solid #d3d3d3;
  border-left: 20px solid #d3d3d3;
  border-bottom: 20px solid transparent;
  border-right: 20px solid transparent;
}
.card-article .sts-type7 .icn-ranking {
  display: none;
}
.card-article .sts-type7 span {
  position: absolute;
  min-width: 24px;
  top: 6px;
  font-weight: bold;
  white-space: nowrap;
}
.card-article .sts-type7.item-rank1 {
  background-color: #b78c00;
}
.card-article .sts-type7.item-rank1::before {
  border-color: #b78c00;
}
.card-article .sts-type7.item-rank2 {
  background-color: #557088;
}
.card-article .sts-type7.item-rank2::before {
  border-color: #557088;
}
.card-article .sts-type7.item-rank3 {
  background-color: #bc7421;
}
.card-article .sts-type7.item-rank3::before {
  border-color: #bc7421;
}
.card-article .sts-type7.item-rank1, .card-article .sts-type7.item-rank2, .card-article .sts-type7.item-rank3 {
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
  align-items: center;
  color: #ffffff;
  width: 26px;
  top: 0;
  left: 10px;
}
.card-article .sts-type7.item-rank1 .icn-ranking, .card-article .sts-type7.item-rank2 .icn-ranking, .card-article .sts-type7.item-rank3 .icn-ranking {
  display: block;
  font-size: 14px;
  margin: 2px 0 4px;
  font-size: 0.9em;
}
.card-article .sts-type7.item-rank1 .icn-ranking::before, .card-article .sts-type7.item-rank2 .icn-ranking::before, .card-article .sts-type7.item-rank3 .icn-ranking::before {
  position: relative;
  top: 3px;
}
.card-article .sts-type7.item-rank1 span, .card-article .sts-type7.item-rank2 span, .card-article .sts-type7.item-rank3 span {
  position: static;
  -webkit-transform: none;
          transform: none;
  z-index: 1;
  line-height: 1;
}
.card-article .sts-type7.item-rank1::before, .card-article .sts-type7.item-rank2::before, .card-article .sts-type7.item-rank3::before {
  content: "";
  position: absolute;
  bottom: -11px;
  border-width: 13px;
  border-bottom: 4px solid transparent;
}
.card-article__image {
  height: 166px;
}
.card-article__title {
  font-size: 14px;
  margin-bottom: 4px;
  height: 42px;
  overflow: hidden;
}
.card-article__contents {
  padding: 20px 8px 8px;
}
.card-article__contents p:not(.card-article__title) {
  font-size: 14px;
  height: 21px;
  overflow: hidden;
  margin-bottom: 4px;
}
.card-article__contents p:not(.card-article__title) small {
  font-size: 12px;
}

/*
新グリッド用クラス。
`layout-column-2__main` (左ナビありレイアウト)の場合は合わせて幅が変わります。
*/
.grid {
  display: flex;
  flex-wrap: wrap;
}
.grid-3 .grid__block {
  width: 252px;
  box-sizing: border-box;
}
.grid-3 .grid__block:not(:nth-child(3n)) {
  margin-right: 20px;
}
.grid-col .grid__block {
  padding: 12px 0;
  border-bottom: 1px solid #e5e5e5;
  width: 100%;
}
.grid-col .grid__block:first-child {
  padding-top: 0;
}

.row-gap--12-24 {
  margin-bottom: -12px;
}
.row-gap--12-24 > .grid__block {
  margin-bottom: 12px;
}
.row-gap--16 {
  margin-bottom: -16px;
}
.row-gap--16 > .grid__block {
  margin-bottom: 16px;
}
.row-gap--20--28 {
  margin-bottom: -20px;
}
.row-gap--20--28 li {
  margin-bottom: 20px;
}

.mf {
  vertical-align: middle;
}
.mf :not(:last-child) {
  margin-right: 6px;
}

.contents-inner {
  margin: 0 16px;
}

.section-block {
  margin-bottom: 24px;
}
.section-block--gray {
  padding: 24px 0;
  background-color: #f6f6f6;
}

.section-title--icon {
  font-size: 20px;
  margin-bottom: 16px;
  display: flex;
  align-items: flex-start;
}
.section-title--icon i {
  margin-right: 4px;
}

@-webkit-keyframes fadeIn {
  0% {
    display: none;
    opacity: 0;
  }
  1% {
    display: inherit;
    opacity: 0;
  }
  100% {
    display: inherit;
    opacity: 1;
  }
}

@keyframes fadeIn {
  0% {
    display: none;
    opacity: 0;
  }
  1% {
    display: inherit;
    opacity: 0;
  }
  100% {
    display: inherit;
    opacity: 1;
  }
}
/*
もっと見るボタン
*/
.js-more-list__item--hide {
  display: none;
  opacity: 0;
}
.js-more-list__wrap.is-open .js-more-list__item--hide {
  -webkit-animation-name: fadeIn;
          animation-name: fadeIn;
  -webkit-animation-duration: 0.3s;
          animation-duration: 0.3s;
  display: block;
  opacity: 1;
}
.js-more-list__wrap.is-open .js-more-list__button::before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  top: 1px;
}
.js-more-list__button {
  display: block;
  box-sizing: border-box;
  width: 50%;
  padding: 12px;
  margin: 16px auto 0;
  font-size: 14px;
}
.js-more-list__button:focus {
  outline: none;
}
.js-more-list__button::before {
  content: "";
  height: 7px;
  width: 7px;
  border-top: 2px solid #16160e;
  border-left: 2px solid #16160e;
  display: inline-block;
  position: relative;
  top: -3px;
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
  margin-right: 8px;
}

.is-loading {
  opacity: 0.2;
}

.column1-inner {
  margin: 0 auto;
}
.column1-inner .sld__list {
  padding: 0 4px 0 16px;
}
.column1-inner > .ttl-h2--icon,
.column1-inner .goods-container_title {
  margin-left: 16px;
}

#recommendyou_division .column1-inner {
  padding: 24px 0;
}
#recommendyou_division .column1-inner .sld__wrap.is-mobile {
  padding-right: 0;
}

.recommend__sp-inner {
  margin-bottom: 40px;
}

.tab-navigation {
  width: 100%;
  border-bottom: 1px solid #e5e5e5;
}
.tab-navigation__list {
  display: flex;
  width: 1072px;
  margin: 24px auto 0;
}
.tab-navigation__item {
  margin-right: 40px;
}
.tab-navigation__link {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  padding-bottom: 10px;
  box-sizing: border-box;
  color: #767676;
}
.tab-navigation__link:hover {
  color: #ad0003;
}
.tab-navigation__link.is-current {
  border-bottom: 2px solid #ad0003;
  color: #ad0003;
}
.tab-navigation__link.is-current .tab-navigation__title {
  font-weight: bold;
}

[class^=icn-],
[class*=" icn-"] {
  vertical-align: middle;
}

.pdSide-16 {
  padding: 0 16px !important;
}

/**
 * フッター前コンテンツ
 */
.bottom-products {
  background-color: #f6f6f6;
  border-top: 1px solid #c8c8c8;
  border-bottom: 1px solid #c8c8c8;
  margin-top: 24px;
}
.bottom-products + .footer-global {
  margin-top: 0;
}
.bottom-products__watched:not(:first-child), .bottom-products__favorite:not(:first-child) {
  margin-top: 24px;
}
.bottom-products .sld__wrap {
  margin-top: 16px;
}
.bottom-products .ttl-h2--icon {
  margin: 0 16px;
}
.bottom-products .gcf-text {
  margin-left: 8px;
}
.bottom-products .bottom-gcf-morelink {
  text-align: right;
  margin: 12px 16px 0 0;
  color: #1e50a2;
}
.bottom-products .bottom-gcf-morelink a:hover {
  text-decoration: underline;
}

.autocomplete {
  position: absolute;
  z-index: 1000;
  background: #ffffff;
  border: solid 1px #e5e5e5;
  border-radius: 20px;
  overflow: hidden;
}
.autocomplete li {
  display: flex;
  align-items: center;
  color: #16160e;
  cursor: pointer;
  padding: 0 16px;
  border-bottom: 1px solid #efefef;
  min-height: 48px;
}
.autocomplete .autocomplete-icon {
  color: #6f6f6f;
  display: inline-flex;
  font-size: 20px;
  margin-right: 16px;
}
.autocomplete .is-focus {
  background-color: #f6f6f6;
}
.autocomplete .suggest-word {
  font-weight: 400;
}
.autocomplete .autocomplete-close {
  display: inline-block;
  height: 36px;
  width: 36px;
  margin-left: auto;
  margin-right: -10px;
  border: none;
  border-radius: 18px;
  font-size: 16px;
  position: relative;
  background-color: transparent;
  cursor: pointer;
  transition: all 0.3s;
  overflow: hidden;
}
.autocomplete .autocomplete-close:hover {
  background-color: #e5e5e5;
}
.autocomplete .autocomplete-close__icon {
  display: inline-block;
  height: 100%;
  width: 100%;
}
.autocomplete .autocomplete-close__icon::before {
  position: absolute;
  top: 10px;
  left: 10px;
}

.choice-balloon {
  display: inline-block;
  position: relative;
}
.choice-balloon__link {
  color: #767676;
  display: inline-block;
  position: relative;
  cursor: pointer;
}
.choice-balloon__link:hover {
  opacity: 0.6;
}
.choice-balloon__wrap {
  color: #ffffff;
  width: calc(100vw - 40px);
  max-width: 370px;
  background-color: #767676;
  box-shadow: 0 2px 7px 0 rgba(0, 0, 0, 0.4);
  border-radius: 4px;
  padding: 30px 16px 20px;
  position: absolute;
  left: 0;
  bottom: 38px;
  z-index: 999999;
  box-sizing: border-box;
  display: none;
}
.choice-balloon__wrap.is-active {
  display: block;
}
.choice-balloon__inner2 {
  display: flex;
}
.choice-balloon__img-area {
  width: 33%;
  margin-right: 16px;
}
.choice-balloon__arrow {
  position: absolute;
  top: 100%;
  left: 50%;
  width: 20px;
  height: 20px;
}
.choice-balloon__arrow::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
  box-shadow: 1px 1px 4px 0 rgba(0, 0, 0, 0.4);
  background-color: #767676;
}
.choice-balloon__arrow::after {
  content: "";
  position: absolute;
  top: -16px;
  left: -20px;
  display: block;
  width: 40px;
  height: 16px;
  background-color: #767676;
}
.choice-balloon__text {
  font-size: 12px;
  line-height: 1.7;
  white-space: normal;
  font-weight: normal;
}
.choice-balloon__text:not(:first-child) {
  margin-top: 10px;
}
.choice-balloon__text a {
  color: #ffffff;
  text-decoration: underline;
}
.choice-balloon__text a:hover {
  color: #ffffff;
  text-decoration: none;
}
.choice-balloon__close {
  font-size: 16px;
  position: absolute;
  top: 11px;
  right: 11px;
  color: #c8c8c8;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}
.choice-balloon__close::before {
  content: "\e025";
  font-family: "iconfont";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  text-decoration: none;
  text-transform: none;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__img {
  width: 136px;
  margin: 0 auto;
  min-width: 136px;
}
.choice-balloon.choice-balloon--kifuto .i-arrow {
  font-weight: normal;
  display: inline;
}
.choice-balloon.choice-balloon--kifuto .i-arrow:hover {
  background-color: transparent;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__wrap {
  background-color: #ffffff;
  padding: 0;
  color: #16160e;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__link:hover {
  background-color: transparent;
  color: #6b6b6b;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__top {
  padding: 24px 32px 16px 24px;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__bottom {
  padding: 32px 16px 16px;
  background-color: #fffade;
  border-radius: 0 0 4px 4px;
  font-size: 14px;
  font-weight: normal;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__bottom .bold {
  display: inline-block;
  width: 136px;
  margin: 0 16px 0 0;
  font-weight: bold;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__arrow::before, .choice-balloon.choice-balloon--kifuto .choice-balloon__arrow::after {
  background-color: #ffffff;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__close {
  font-size: 16px;
  position: absolute;
  top: 11px;
  right: 11px;
  color: #6b6b6b;
}
.choice-balloon.choice-balloon--kifuto .choice-balloon__close:hover, .choice-balloon.choice-balloon--kifuto .choice-balloon__close:focus, .choice-balloon.choice-balloon--kifuto .choice-balloon__close:active {
  color: #6b6b6b;
  background-color: transparent;
}

.after-unit {
  display: inline-block;
  white-space: nowrap;
  margin-left: 4px;
  flex-shrink: 0;
}
.after-unit + .frm-input {
  margin-left: 8px;
}

.ttl-tg--pickup {
  display: inline-block;
  background-color: #d59300;
  color: #ffffff;
  border-radius: 4px;
  font-size: 12px;
  padding: 0 12px;
  font-weight: normal;
  margin: 0 8px 4px 0;
}
.ttl-tg--pickup + span {
  display: inline-block;
  line-height: 1;
  position: relative;
  top: 1px;
}

.new-badge {
  padding: 3px 5px;
  margin-left: 8px;
  background: #008461;
  color: #ffffff;
  font-size: 12px;
  font-weight: bold;
  border-radius: 9px;
  line-height: 1;
}

.-withBadge {
  display: flex;
  align-items: center;
}

.button {
  display: inline-block;
  padding: 10px 8px 8px;
  border: 2px solid #e5e5e5;
  border-radius: 4px;
  background-color: #ffffff;
  color: #16160e;
  font-size: 14px;
  text-align: center;
  box-sizing: border-box;
  -webkit-appearance: none;
          appearance: none;
  cursor: pointer;
}
.button:hover {
  opacity: 0.85;
}
.button [class^=mf-]:first-child,
.button [class^=icn-]:first-child {
  margin-right: 2px;
}
.button [class^=mf-]:last-child,
.button [class^=icn-]:last-child {
  margin-left: 2px;
}
.button.-red {
  border-color: #ad0003;
  background-color: #ad0003;
  color: #ffffff;
}
.button.-black {
  background-color: #16160e;
  color: #ffffff;
  border-color: #16160e;
  font-weight: bold;
}
.button.-gray {
  background-color: #e5e5e5;
  border-color: #e5e5e5;
  font-weight: bold;
}
.button.-expanded {
  display: block;
}

.switch-button-list {
  margin-bottom: 8px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.switch-button-list__button {
  cursor: pointer;
  border: 1px solid #e5e5e5;
  border-radius: 4px;
  background-color: #ffffff;
  padding: 6px 11px;
  font-size: 14px;
  line-height: 1;
  margin-left: 8px;
}
.switch-button-list .is-current {
  background-color: #16160e;
  border-color: #16160e;
  color: #ffffff;
  cursor: default;
}

.button-rounded {
  border: solid 1px #c8c8c8;
  border-radius: 20px;
  text-align: center;
  padding: 7px 0;
}
.button-rounded:hover {
  opacity: 0.85;
}

.list-link {
  padding: 0 6px 8px 32px;
  font-size: 14px;
}
.list-link a {
  position: relative;
  display: flex;
  align-items: center;
}
.list-link a:hover {
  opacity: 0.85;
}
.list-link a:hover .list-link__text,
.list-link a:hover .list-link__number {
  text-decoration: underline;
  color: #1e50a2;
}
.list-link a .list-link__icon {
  display: inline-flex;
  margin: 0 0 0 auto;
}
.list-link .list-link__img {
  flex: 0 0 40px;
  width: 40px;
  margin-right: 8px;
}
.list-link .list-link__text {
  padding: 12px 0;
}
.list-link .list-link__text .list-link__number {
  display: inline-block;
}

#search-window-top {
  position: fixed;
  top: 40px;
  left: 0;
  width: 100%;
  height: 100vh;
}

.search-window-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.2);
  z-index: 100;
  overflow: hidden;
  border: 0;
}

.search-window-other-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.2);
  z-index: 2000;
  overflow: hidden;
  border: 0;
}

.search-window .autocomplete {
  position: static;
  top: auto;
  height: auto;
  border: none;
}
.search-window .autocomplete li:first-child {
  border-top: 1px solid #efefef;
}
.search-window .autocomplete.show-suggestions {
  display: block;
  position: absolute;
}
.search-window .input-border {
  display: none;
  position: absolute;
  top: 2px;
  left: 2px;
  right: 2px;
  bottom: 2px;
  border: 2px solid blue;
  pointer-events: none;
  border-radius: 30px;
}

.search-window__header.sp-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background-color: #ad0003;
  height: 75px;
  z-index: 1000;
  padding: 0 16px;
  display: flex;
  gap: 8px;
  align-items: center;
}
.search-window__header.sp-header .search-window__wrap {
  flex: 1;
}

.search-window__content {
  z-index: 1000;
  background: #ffffff;
  overflow-y: auto;
}
.search-window__content .filter-section {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin: 20px auto;
  width: 90%;
}
.search-window__content .filter-section .filter-item-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #f6f6f6;
  padding: 10px;
  border-radius: 8px;
  flex: 1;
  gap: 4px;
}
.search-window__content .filter-section .filter-item-container i {
  font-size: 20px;
  color: black;
  line-height: 1;
}
.search-window__content .filter-section .filter-item-container .filter-item {
  font-weight: bold;
  color: #16160e;
}
.search-window__content .highlighted-title {
  color: #6f6f6f;
  padding: 4px 16px;
  font-weight: bold;
}
.search-window__content .trending-words__wrap {
  overflow-x: auto;
  scrollbar-width: none;
}
.search-window__content .trending-words__wrap ul {
  display: inline-flex;
  gap: 8px;
  white-space: nowrap;
  padding: 8px 0 16px 8px;
}
.search-window__content .trending-words__wrap .trending-word {
  font-size: 14px;
  font-weight: bold;
  color: #555;
  white-space: nowrap;
}
.search-window__content .trending-words__wrap .trending-word a {
  padding: 10px 14px;
  background-color: #f6f6f6;
  border-radius: 24px;
}
.search-window__content .search-history__wrap {
  padding: 20px 20px;
}
.search-window__content .search-history__wrap .search-history__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.search-window__content .search-history__wrap .search-history-empty {
  margin: 10px 0;
  color: #888;
  font-size: 16px;
}
.search-window__content .search-history__wrap .search-history-text {
  color: #6f6f6f;
  font-weight: bold;
}
.search-window__content .search-history__wrap .delete-all-history {
  font-size: 18px;
  font-weight: bold;
  color: #1e50a2;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  text-decoration: none;
}

.search-window-modal {
  background-color: white;
  color: #333;
  z-index: 7000;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
.search-window-modal .modal-content {
  margin-top: 60px;
  margin-bottom: 10px;
}
.search-window-modal .modal-content.category-modal-content, .search-window-modal .modal-content.select-category-content {
  height: calc(100vh - 56px);
  overflow-y: auto;
}
.search-window-modal .modal-content.price-modal-content, .search-window-modal .modal-content.city-modal-content {
  height: calc(100vh - 56px - 81px);
  overflow-y: auto;
}
.search-window-modal .modal-content .modal-header {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  border-bottom: 1px solid #e5e5e5;
  padding: 20px;
  z-index: 1;
}
.search-window-modal .modal-content .modal-header .modal-header-title {
  text-align: center;
  font-weight: bold;
  font-size: 18px;
}
.search-window-modal .modal-content .modal-header .modal-back-button {
  position: absolute;
  left: 4px;
  width: 50px;
  border: none;
  background-color: transparent;
}
.search-window-modal .modal-content .modal-header .modal-back-button i {
  font-size: 20px;
}
.search-window-modal .modal-content .modal-header .modal-close-button {
  position: absolute;
  right: 12px;
  width: 50px;
  border: none;
  background-color: transparent;
}
.search-window-modal .modal-content .modal-header .modal-close-button i {
  font-size: 20px;
}
.search-window-modal .modal-content .modal-header .modal-close-button .modal-close-button-icon {
  position: relative;
  width: 16px;
  height: 14px;
  display: block;
  margin: 0 auto;
  box-sizing: border-box;
}
.search-window-modal .modal-content .modal-header .modal-close-button .modal-close-button-icon span {
  position: absolute;
  top: 6px;
  left: 0;
  width: 100%;
  height: 2px;
  display: block;
  border-radius: 1px;
  box-sizing: border-box;
  background-color: #6b6b6b;
}
.search-window-modal .modal-content .modal-header .modal-close-button .modal-close-button-icon span:nth-child(1) {
  rotate: 45deg;
}
.search-window-modal .modal-content .modal-header .modal-close-button .modal-close-button-icon span:nth-child(2) {
  rotate: 135deg;
}
.search-window-modal .modal-content .modal-body {
  padding: 20px;
}
.search-window-modal .select-category-content .list-subcategories {
  display: -ms-grid;
  display: grid;
  gap: 18px;
}
.search-window-modal .select-category-content .list-subcategories li:first-child .list-subcategories__text {
  font-weight: bold;
}
.search-window-modal .select-category-content .list-subcategories__item {
  font-size: 16px;
  white-space: nowrap;
}
.search-window-modal .select-category-content .list-subcategories__link {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 16px;
  padding: 4px;
}
.search-window-modal .select-category-content .list-subcategories__link i {
  line-height: 1;
  font-size: 20px;
  opacity: 0.7;
}
.search-window-modal .select-category-content .list-subcategories__link .fs14 {
  opacity: 0.7;
  margin-left: 8px;
}
.search-window-modal .buttons {
  display: flex;
  justify-content: center;
  padding: 16px;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: #fff;
  border-top: 1px solid #e5e5e5;
  gap: 20px;
}
.search-window-modal .buttons .price-buttons__clear,
.search-window-modal .buttons .price-buttons__filter,
.search-window-modal .buttons .city-buttons__clear,
.search-window-modal .buttons .city-buttons__filter {
  border-radius: 30px;
}
.search-window-modal .buttons .price-buttons__clear,
.search-window-modal .buttons .city-buttons__clear {
  color: black;
  font-weight: bold;
  padding: 13px 26px;
  border-width: 2px;
  font-size: 16px;
}
.search-window-modal .buttons .price-buttons__filter,
.search-window-modal .buttons .city-buttons__filter {
  color: white;
  font-weight: bold;
}

#category-modal .product-category {
  background-color: grey;
  padding: 24px 16px;
  margin-bottom: 24px;
}
#category-modal .product-category__title {
  font-size: 18px;
}
#category-modal .category-buttons-list__wrap {
  position: relative;
}
#category-modal .category-buttons-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[4];
  grid-template-columns: repeat(4, 1fr);
}
#category-modal .category-buttons-list__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
#category-modal .category-buttons-list__item .category-select-trigger {
  display: flex;
  flex-direction: column;
  padding: 0 8px 12px;
  flex: 1;
}
#category-modal .category-buttons-list__item .category-select-trigger span {
  font-weight: bold;
  line-height: 1.28;
}
#category-modal .category-buttons-list__item .category-select-trigger img {
  padding: 8px;
  box-sizing: border-box;
  border-radius: 50%;
  background-color: #f6f6f6;
}

#price-modal .price-input-wrapper {
  display: flex;
  gap: 16px;
}
#price-modal .search-money {
  margin: 20px 0;
}
#price-modal .price-input-start-wrapper,
#price-modal .price-input-end-wrapper {
  display: flex;
  flex-direction: column;
}
#price-modal .price-input-container {
  display: flex;
  align-items: center;
  gap: 8px;
}
#price-modal .price-input-start,
#price-modal .price-input-end {
  border-radius: 30px;
  flex: 1;
  display: block;
}
#price-modal .error-message-start,
#price-modal .error-message-end {
  flex: 1;
  margin: 2px;
}
#price-modal .currency,
#price-modal .price-range-separator {
  -ms-grid-row-align: center;
      align-self: center;
}
#price-modal .list-link {
  padding: 0;
}
#price-modal .list-link .list-link__icon {
  order: 1;
}

#city-modal .frm-select {
  border-radius: 30px;
}
#city-modal .city-selection-container {
  display: flex;
  flex-direction: column;
}
#city-modal .city-selection-wrapper {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px 0;
  width: 100%;
}
#city-modal .city-selection-wrapper .city-selection {
  flex: 1;
}
#city-modal .city-selection-wrapper:not(:last-child) {
  border-bottom: 1px solid #e5e5e5;
}
#city-modal .city-selection-wrapper label {
  display: flex;
  flex-direction: row;
  align-items: center;
  white-space: nowrap;
  gap: 20px;
}
#city-modal .add-city-selection-wrapper {
  width: 100%;
  display: flex;
  margin: 16px 0;
}
#city-modal .add-city-selection-wrapper .add-city-selection-button {
  color: black;
  font-weight: bold;
  width: 40px;
  height: 40px;
  border-width: 2px;
  font-size: 20px;
  border-radius: 50%;
  border-color: #16160e;
  background-color: white;
  margin: 0 auto;
}

.header-global {
  --header-height: 44px;
  position: relative;
  width: 100%;
  z-index: 999;
  transition: top 0.16s ease-out, -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out, top 0.16s ease-out;
  transition: transform 0.3s ease-out, top 0.16s ease-out, -webkit-transform 0.3s ease-out;
}
.header-global.show-megamenu {
  top: -105px;
}
.header-global.is-app-banner-displayed.show-megamenu {
  top: -170px;
}
.header-global + * {
  margin-top: 5px !important;
}

.header-main {
  position: relative;
  background-color: #ad0003;
  color: #ffffff;
}

.header-curve {
  position: absolute;
  bottom: -5px;
  display: block;
  width: 100%;
  height: 6px;
  background-color: #ad0003;
  z-index: 10;
  border-radius: 0% 0% 50% 50%/0% 0% 100% 100%;
}

.header-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  padding: 12px 8px 0 16px;
}

.site-logo {
  display: block;
  margin-bottom: 16px;
}
.site-logo a {
  display: block;
}
.site-logo img {
  height: 40px;
}

.search-window {
  width: 82%;
  overflow: hidden;
}

.search-window__wrap {
  position: relative;
  border-radius: 30px;
  box-sizing: border-box;
  overflow: hidden;
  z-index: 100;
}

.search-window__input {
  display: block;
  width: 100%;
  height: 40px;
  padding: 0 0 2px 40px;
  border: none !important;
  -webkit-appearance: none;
          appearance: none;
  border-radius: 0;
  box-sizing: border-box;
  font-size: 16px;
  font-weight: bold;
  outline: none;
}
.search-window__input::-webkit-input-placeholder {
  color: #16160e;
  font-size: 14px;
  font-weight: normal;
}
.search-window__input:-ms-input-placeholder {
  color: #16160e;
  font-size: 14px;
  font-weight: normal;
}
.search-window__input::-ms-input-placeholder {
  color: #16160e;
  font-size: 14px;
  font-weight: normal;
}
.search-window__input::placeholder {
  color: #16160e;
  font-size: 14px;
  font-weight: normal;
}
.search-window__input:focus {
  padding: 0 64px 0 40px;
}
.search-window__input:focus + .search-window__button {
  display: block;
}
.search-window__input:focus ~ .input-border {
  display: block;
}

.search-window__button {
  display: none;
  background-color: #efefef;
  width: 60px;
  height: 40px;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  overflow: hidden;
  border: 0;
  border-radius: 0 30px 30px 0;
  transition: all 0.3s;
}
.search-window__button:hover {
  background-color: #e0e0e0;
}
.search-window__button:active, .search-window__button:focus {
  display: block;
}
.search-window__button span {
  color: #16160e;
  font-size: 14px;
  font-weight: bold;
  z-index: 1000;
}

.button-close-autocomplete {
  position: static;
  width: 50px;
  padding: 4px 0;
  background-color: #ad0003;
  border: none;
  color: #ffffff;
  font-size: 10px;
}
.button-close-autocomplete:focus {
  background-color: #9b0003;
}

.button-close-autocomplete__icon {
  position: relative;
  width: 16px;
  height: 14px;
  display: block;
  margin: 0 auto;
  box-sizing: border-box;
}
.button-close-autocomplete__icon span {
  position: absolute;
  top: 6px;
  left: 0;
  width: 100%;
  height: 2px;
  display: block;
  background-color: #ffffff;
  border-radius: 1px;
  box-sizing: border-box;
}
.button-close-autocomplete__icon span:nth-child(1) {
  rotate: 45deg;
}
.button-close-autocomplete__icon span:nth-child(2) {
  rotate: 135deg;
}

.button-close-autocomplete__label {
  display: inline-block;
  padding-top: 4px;
  font-weight: bold;
}

.nav-user {
  margin-left: 0;
}

.nav-user__menu {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
}
.nav-user__menu > li:first-child {
  margin-left: 0;
}

.nav-user__wrap--cart {
  margin-left: 4px;
  transition: all 0.16s ease-out;
}
.nav-user__wrap--cart .nav-user__list .nav-user__btn {
  margin-top: 24px;
}
.nav-user__wrap--cart .nav-user__list .nav-user__btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 190px;
  height: 48px;
  margin: 0 auto;
  padding: 0;
  border-radius: 24px;
  font-weight: bold;
  text-align: center;
  color: #ffffff;
  background-color: #ad0003;
  background-image: none;
  box-sizing: border-box;
}
.nav-user__wrap--cart .nav-user__list .nav-user__btn a:hover {
  opacity: 0.85;
}
.nav-user__wrap--cart .nav-user__list .btn-positive--icon {
  height: 40px;
}
.nav-user__wrap--cart .nav-user__txt {
  font-size: 16px;
  color: #16160e;
  white-space: normal;
}
.nav-user__wrap--cart .nav-user__txt.normal:first-of-type {
  margin-top: 14px;
}
.nav-user__wrap--cart .nav-user__txt .volume {
  color: #008461;
  font-size: 20px;
  font-weight: bold;
}
.nav-user__wrap--cart.null .nav-user__txt {
  font-weight: bold;
}
.nav-user__wrap--cart.null .nav-user__list a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 162px;
  height: 48px;
  margin: 0 auto;
  padding: 0;
  border: 2px solid #ad0003;
  border-radius: 24px;
  text-align: center;
  color: #ad0003;
  font-weight: bold;
  background-color: #ffffff;
  background-image: none;
  box-sizing: border-box;
}
.nav-user__wrap--cart.null .nav-user__list a:hover {
  opacity: 0.85;
}
.nav-user__wrap--cart.null .icn-donation {
  color: #767676;
  font-size: 31px;
}

.nav-user__link {
  display: block;
  width: 50px;
}

.nav-user__icon::before {
  display: block;
  width: 16px;
  margin: 0 auto;
  font-size: 16px;
}
.nav-user__icon._search {
  position: absolute;
  top: 10px;
  left: 16px;
  color: #6f6f6f;
  margin: 0;
}
.nav-user__icon._search::before {
  display: inline-flex;
}

.nav-user__guide .nav-user__icon {
  visibility: visible;
  opacity: 1;
  transition: all 0.32s ease-out;
}

.nav-user__guide.is-active .nav-user__icon {
  display: none;
  visibility: hidden;
  opacity: 0;
}

.nav-user__guide .nav-close {
  display: none;
  visibility: hidden;
  opacity: 0;
  position: relative;
  margin: 0 auto;
  width: 16px;
  height: 16px;
  transition: all 0.32s;
}

.nav-user__guide .nav-close span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #ffffff;
  border-radius: 1px;
}
.nav-user__guide .nav-close span:nth-child(1) {
  top: 0;
  -webkit-transform: translateY(7px) rotate(-135deg);
          transform: translateY(7px) rotate(-135deg);
}
.nav-user__guide .nav-close span:nth-child(2) {
  bottom: 0;
  -webkit-transform: translateY(-7px) rotate(135deg);
          transform: translateY(-7px) rotate(135deg);
}

.nav-user__guide.is-active .nav-close {
  display: block;
  visibility: visible;
  opacity: 1;
}

.nav-user__hamburger {
  position: relative;
  width: 16px;
  height: 14px;
  display: block;
  margin: 0 auto;
  box-sizing: border-box;
}

.nav-user__hamburger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  display: block;
  background-color: #ffffff;
  border-radius: 1px;
  box-sizing: border-box;
  transition: all 0.32s;
}
.nav-user__hamburger span:nth-child(1) {
  top: 0;
}
.nav-user__hamburger span:nth-child(2) {
  top: 6px;
}
.nav-user__hamburger span:nth-child(3) {
  bottom: 0;
}

.nav-user__link.is-active .nav-user__hamburger span:nth-child(1) {
  -webkit-transform: translateY(6px) rotate(-135deg);
          transform: translateY(6px) rotate(-135deg);
}
.nav-user__link.is-active .nav-user__hamburger span:nth-child(2) {
  opacity: 0;
}
.nav-user__link.is-active .nav-user__hamburger span:nth-child(3) {
  -webkit-transform: translateY(-6px) rotate(135deg);
          transform: translateY(-6px) rotate(135deg);
}

.nav-user__label {
  display: block;
  padding: 6px 0 0;
  font-size: 10px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.nav-user__count {
  position: relative;
}

.nav-user__count__num {
  background-color: #008461;
  position: absolute;
  right: 5px;
  top: -6px;
  font-size: 12px;
  padding: 2px 5px 3px 5px;
  line-height: 1;
  border-radius: 10px;
  box-shadow: 1px 1px 2px 0 rgba(0, 0, 0, 0.15);
}
.nav-profile .-mypage:empty {
  padding: 16px 0 0;
}

.header-bottom {
  position: relative;
}

.nav-global {
  box-sizing: border-box;
}

.nav-global__list {
  display: flex;
  flex-wrap: nowrap;
}
.nav-global__list li {
  box-sizing: border-box;
}
.nav-global__list li:first-child {
  padding-left: 0;
}

@-webkit-keyframes nav-slide {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}

@keyframes nav-slide {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
.nav-global__item {
  font-size: 14px;
  text-align: center;
}
.nav-global__item.is-active::before {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.nav-global__item span {
  font-size: 12px;
}

@-webkit-keyframes arrow-slide {
  0% {
    right: 8px;
    opacity: 1;
  }
  100% {
    right: -20px;
    opacity: 0;
  }
}

@keyframes arrow-slide {
  0% {
    right: 8px;
    opacity: 1;
  }
  100% {
    right: -20px;
    opacity: 0;
  }
}
.nav-list {
  display: flex;
  align-items: center;
}

.nav-list__wrapper {
  display: flex;
  align-items: center;
  height: 40px;
  padding: 6px 12px 6px;
  border-radius: 30px;
  box-sizing: border-box;
}
.nav-list__wrapper._service:hover .nav-megamenu {
  display: block;
}
.nav-list__wrapper._guide {
  position: relative;
}
.nav-list__wrapper._guide:hover .nav-guide {
  display: block;
}

.nav-megamenu__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.nav-megamenu__header .nav-megamenu__header-lead {
  font-size: 20px;
  font-weight: bold;
  line-height: 20px;
}

.nav-megamenu__top-link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 40px;
  line-height: 40px;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: bold;
  border: 2px solid #16160e;
  border-radius: 20px;
  box-sizing: border-box;
}
.nav-megamenu__top-link.-user {
  margin: 16px auto 0;
}

.nav-global__icon._arrow {
  display: inline-flex;
  align-items: center;
  font-size: 8px;
  line-height: 1;
  margin-left: 2px;
}

.nav-service-block-wrapper {
  grid-area: nav-service-block-wrapper;
  display: flex;
  flex-direction: column;
  gap: 16px;
  flex-wrap: wrap;
}

.nav-service-block {
  background-color: #f6f6f6;
  display: flex;
  height: 82px;
  border-radius: 8px;
  overflow: hidden;
  width: 100%;
  position: relative;
}

.nav-service-block__external-icon {
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: 11px;
  line-height: 1;
}

.-products .nav-service-block__image {
  width: 94px;
  min-width: 94px;
}
.-use .nav-service-block__image {
  width: 94px;
  min-width: 94px;
}
.nav-service-block__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.nav-service-block__main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  text-align: left;
  padding: 0 16px;
}

.nav-service-block__main-copy {
  font-size: 2.4vw;
}

.nav-service-block__main-logo {
  height: 6vw;
}

.nav-service-block__main-title {
  font-size: 4vw;
  margin-top: 1.8vw;
}

.-use .nav-megamenu__inner {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.-use .nav-megamenu__inner .nav-megamenu__body {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.-product .nav-megamenu__inner {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.-product .nav-megamenu__inner .nav-megamenu__body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 {
  grid-area: body2;
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin: 0 -20px;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-title {
  font-size: 16px;
  font-weight: bold;
  text-align: left;
  margin: 0 20px;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-price {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  overflow-x: auto;
  padding: 0 20px;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-price-item {
  white-space: nowrap;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-price-link {
  border: 1px solid #c8c8c8;
  border-radius: 24px;
  font-size: 14px;
  padding: 4px 24px;
  display: inline-block;
  width: 100%;
  box-sizing: border-box;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-price-link:hover {
  border: 1px solid #c8c8c8;
  background-color: #c8c8c8;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-keyword-wrapper {
  overflow-x: auto;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-keyword {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 4px;
  padding: 0 20px;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-keyword-item {
  white-space: nowrap;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-keyword-link {
  border: 1px solid #efefef;
  border-radius: 24px;
  background-color: #efefef;
  font-size: 14px;
  padding: 4px 16px;
  display: inline-block;
}
.-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-keyword-link:hover {
  opacity: 0.85;
}
._search-products .nav-megamenu::before {
  left: 73px;
}
._search-products .nav-megamenu__wrapper {
  padding: 24px 32px;
}
._search-products .nev-megamenu__popular-category {
  display: flex;
}
._search-products .nev-megamenu__popular-category .nev-megamenu__popular-category-list {
  flex-grow: 1;
}
._search-products .nev-megamenu__popular-category .nev-megamenu__popular-category-list .nev-megamenu__popular-category-item:first-child {
  font-size: 20px;
  font-weight: bold;
  margin: 0 0 7px 0;
}
._search-products .nev-megamenu__popular-category .nev-megamenu__popular-category-list .nev-megamenu__popular-category-item:first-child .nev-megamenu__popular-category-link {
  line-height: 40px;
  font-size: 20px;
}
._search-products .nev-megamenu__popular-category .nev-megamenu__popular-category-list .nev-megamenu__popular-category-item:first-child .nev-megamenu__popular-category-link:not(.-no-hover):hover {
  border-radius: 20px;
}
._search-products .nev-megamenu__popular-category .nev-megamenu__popular-category-item {
  font-size: 16px;
  text-align: left;
}
._search-products .nev-megamenu__popular-category .nev-megamenu__popular-category-link {
  display: flex;
  align-items: center;
  line-height: 32px;
  padding-left: 12px;
  box-sizing: border-box;
}
._search-products .nev-megamenu__popular-category .nev-megamenu__popular-category-link:not(.-no-hover):hover {
  border-radius: 16px;
  background: #f6f6f6;
}
._search-products .nav-megamenu__other-popular-category {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
._search-products .nav-megamenu__other-popular-category .nav-megamenu__other-popular-category-list {
  display: flex;
  gap: 16px;
}
._search-products .nav-megamenu__other-popular-category .nav-megamenu__other-popular-category-item {
  margin: 0 -12px;
}
._search-products .nav-megamenu__other-popular-category .nav-megamenu__other-popular-category-link {
  display: flex;
  align-items: center;
  padding: 0 12px;
  line-height: 32px;
  font-size: 16px;
  font-weight: bold;
  color: #1e50a2;
}
._search-products .nav-megamenu__other-popular-category .nav-megamenu__other-popular-category-link:hover .nav-megamenu__other-popular-category-link-text {
  text-decoration: underline;
}

.nav-megamenu-sp .nav-megamenu__inner {
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
html[data-script-enabled=true] .nav-megamenu-sp {
  position: fixed;
  top: 44px;
  z-index: 9000;
  width: 100%;
  height: calc(100vh - var(--header-height));
  height: calc(100dvh - var(--header-height));
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(-16px);
          transform: translateY(-16px);
  transition: all 0.16s ease-out;
}
html[data-script-enabled=true] .nav-megamenu-sp .nav-megamenu__fadein {
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
  transition: all 0.16s ease-out 0.16s;
}
html[data-script-enabled=true] .nav-megamenu-sp > .nav-megamenu__wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 0;
  box-sizing: border-box;
  padding: 24px 20px;
  overflow-y: auto;
}
html[data-script-enabled=true] .nav-megamenu-sp.is-active {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
html[data-script-enabled=true] .nav-megamenu-sp.is-active::before {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
html[data-script-enabled=true] .nav-megamenu-sp.is-active .nav-megamenu__wrapper::before {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
html[data-script-enabled=true] .nav-megamenu-sp.is-active .nav-megamenu__fadein {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
html[data-script-enabled=true] .nav-megamenu-sp .nav-megamenu__close {
  position: fixed;
  right: 16px;
  top: 8px;
  width: 42px;
  height: 42px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #ffffff;
}
html[data-script-enabled=true] .nav-megamenu-sp .nav-megamenu__close .nav-megamenu__close-icon {
  position: relative;
  width: 14px;
  height: 14px;
}
html[data-script-enabled=true] .nav-megamenu-sp .nav-megamenu__close .nav-megamenu__close-icon::before, html[data-script-enabled=true] .nav-megamenu-sp .nav-megamenu__close .nav-megamenu__close-icon::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  display: block;
  background-color: #16160e;
}
html[data-script-enabled=true] .nav-megamenu-sp .nav-megamenu__close .nav-megamenu__close-icon::before {
  top: 0;
  -webkit-transform: translateY(6px) rotate(-135deg);
          transform: translateY(6px) rotate(-135deg);
}
html[data-script-enabled=true] .nav-megamenu-sp .nav-megamenu__close .nav-megamenu__close-icon::after {
  bottom: 0;
  -webkit-transform: translateY(-6px) rotate(135deg);
          transform: translateY(-6px) rotate(135deg);
}
.nav-megamenu-sp .nav-megamenu__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 8px;
}
.nav-megamenu-sp .nav-megamenu__header .nav-megamenu__header-lead {
  font-size: 16px;
  font-weight: bold;
}
.nav-megamenu-sp .nev-megamenu__popular-category {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
}
.nav-megamenu-sp .nev-megamenu__popular-category .nev-megamenu__popular-category-list {
  display: flex;
  flex-direction: column;
  width: calc(50% - 16px);
}
.nav-megamenu-sp .nev-megamenu__popular-category .nev-megamenu__popular-category-list .nev-megamenu__popular-category-link {
  padding: 4px;
}
.nav-megamenu-sp .nev-megamenu__popular-category .nev-megamenu__popular-category-item:first-child {
  font-size: 20px;
  font-weight: bold;
}
.nav-megamenu-sp .nev-megamenu__popular-category .nev-megamenu__popular-category-item:first-child .nev-megamenu__popular-category-link {
  margin-bottom: 8px;
  font-size: 20px;
  line-height: 20px;
}
.nav-megamenu-sp .nav-megamenu__other-popular-category {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.nav-megamenu-sp .nav-megamenu__other-popular-category .nav-megamenu__other-popular-category-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.nav-megamenu-sp .nav-megamenu__other-popular-category .nav-megamenu__other-popular-category-item .nav-megamenu__other-popular-category-link {
  font-weight: bold;
  color: #1e50a2;
}
.nav-megamenu-sp .nav-megamenu__other-popular-category .nav-megamenu__other-popular-category-item .nav-megamenu__other-popular-category-link .nav-guide__icon {
  display: none;
}
.nav-megamenu-sp .nev-megamenu__popular-category-item,
.nav-megamenu-sp .nav-megamenu__other-popular-category-item {
  font-size: 14px;
  font-weight: 500;
  text-align: left;
}
.nav-megamenu-sp .nev-megamenu__popular-category-item .nev-megamenu__popular-category-link,
.nav-megamenu-sp .nev-megamenu__popular-category-item .nav-megamenu__other-popular-category-link,
.nav-megamenu-sp .nav-megamenu__other-popular-category-item .nev-megamenu__popular-category-link,
.nav-megamenu-sp .nav-megamenu__other-popular-category-item .nav-megamenu__other-popular-category-link {
  display: flex;
  align-items: center;
}
.nav-megamenu-sp .nev-megamenu__popular-category-item .nev-megamenu__popular-category-link .nav-guide__icon,
.nav-megamenu-sp .nev-megamenu__popular-category-item .nav-megamenu__other-popular-category-link .nav-guide__icon,
.nav-megamenu-sp .nav-megamenu__other-popular-category-item .nev-megamenu__popular-category-link .nav-guide__icon,
.nav-megamenu-sp .nav-megamenu__other-popular-category-item .nav-megamenu__other-popular-category-link .nav-guide__icon {
  margin-right: 8px;
}

.nav-list__label {
  display: flex;
  align-items: center;
  font-size: 14px;
  font-weight: bold;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
}

.nav-list__icon._service,
.nav-list__icon._guide {
  width: 16px;
  height: 16px;
  margin-right: 8px;
}
.nav-list__icon._service::before,
.nav-list__icon._guide::before {
  display: inline-block;
  width: 16px;
  font-size: 16px;
}

.nav-list__icon._arrow {
  display: inline-flex;
  align-items: center;
  font-size: 8px;
  line-height: 1;
}

._use {
  position: initial;
  text-align: left;
}
._use:hover .nav-megamenu.-use {
  display: block;
}
._use:hover .nav-megamenu.-use::before {
  left: calc(50% - 220px);
}

.navigation-use-list {
  display: flex;
  flex-wrap: wrap;
}

.navigation-use-list__item {
  width: 50%;
  text-align: left;
}
.navigation-use-list__item .lst-navi2__link {
  padding: 5px 8px 5px 24px;
  color: #16160e;
}
.navigation-use-list__item .nav-guide__icon {
  position: absolute;
  left: 8px;
  top: 11px;
}

.nav-megamenu {
  display: none;
  position: absolute;
  top: 40px;
  left: 50%;
  width: 1072px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 9999;
}
.nav-megamenu::before {
  content: "";
  position: absolute;
  top: -6px;
  left: calc(50% + 275px);
  display: block;
  width: 12px;
  height: 12px;
  background-color: #ffffff;
  border-radius: 50%;
  z-index: 9998;
}

.nav-megamenu__wrapper {
  position: relative;
  background-color: #ffffff;
  color: #16160e;
  text-align: center;
  border-radius: 32px;
}

.nav-megamenu__top {
  display: flex;
  padding: 24px;
}

.nav-megamenu__list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 16px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  width: 100%;
  margin-right: 16px;
}

.nav-megamenu__item {
  background-color: #f6f6f6;
  border-radius: 16px;
  box-sizing: border-box;
  transition: all 0.3s;
}
.nav-megamenu__item:hover {
  background-color: #efefef;
}

.nav-megamenu__item-link {
  display: flex;
  align-items: flex-start;
  padding: 12px 12px 16px;
}

.nav-megamenu__icon {
  display: inline-flex;
  align-items: center;
  margin-right: 12px;
  color: #ad0003;
  font-size: 32px;
}
.nav-megamenu__icon.-choicepay {
  padding-left: 4px;
}

.nav-megamenu__txt {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  height: 100%;
}

.nav-megamenu__lead {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 4px;
}

.nav-megamenu__desc {
  font-size: 13px;
}

.nav-megamenu__image {
  width: 192px;
  flex-shrink: 0;
}

.nav-megamenu__bottom {
  display: flex;
}

.nav-megamenu__gcf,
.nav-megamenu__saigai {
  width: 50%;
  color: #ffffff;
  position: relative;
  z-index: 0;
}
.nav-megamenu__gcf::before,
.nav-megamenu__saigai::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  -webkit-filter: brightness(0.48);
          filter: brightness(0.48);
  z-index: -1;
}
.nav-megamenu__gcf:hover::before,
.nav-megamenu__saigai:hover::before {
  -webkit-filter: brightness(0.4);
          filter: brightness(0.4);
}
.nav-megamenu__gcf:hover .nav-megamenu__btn,
.nav-megamenu__saigai:hover .nav-megamenu__btn {
  opacity: 0.85;
}

.nav-megamenu__gcf {
  margin-right: 1px;
}
.nav-megamenu__gcf::before {
  background-image: url(/assets/images/common/menu_gcf01.jpg);
  border-radius: 0 0 0 32px;
}

.nav-megamenu__saigai::before {
  background-image: url(/assets/images/common/menu_saigai01.jpg);
  border-radius: 0 0 32px 0;
}

.nav-megamenu__link {
  display: block;
  padding: 32px 0 40px;
}

.nav-megamenu__logo {
  margin: 0 auto 24px;
}
.nav-megamenu__logo img {
  height: 32px;
}

.nav-megamenu__gcf .nav-megamenu__desc,
.nav-megamenu__saigai .nav-megamenu__desc {
  margin-bottom: 24px;
}

.nav-megamenu__icon-gcf,
.nav-megamenu__icon-saigai {
  display: inline-flex;
  align-items: center;
  font-size: 40px;
  margin-bottom: 24px;
}

.nav-megamenu__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 200px;
  height: 48px;
  margin: 0 auto;
  color: #ffffff;
  border-radius: 26px;
}
.nav-megamenu__btn.-gcf {
  background-color: #2e792d;
}
.nav-megamenu__btn.-saigai {
  background-color: #d45700;
}

.nav-guide {
  display: none;
  position: absolute;
  z-index: 9999;
  width: 100%;
  height: 100vh;
}
.nav-guide::before {
  content: "";
  position: absolute;
  top: -6px;
  right: 86px;
  display: block;
  width: 12px;
  height: 12px;
  background-color: #ffffff;
  border-radius: 50%;
  z-index: 9998;
}

.nav-guide__list {
  height: 100vh;
  background: #ffffff;
  color: #16160e;
  padding: 0;
  white-space: nowrap;
  overflow: hidden;
  transition: all 0.3s ease-out;
}

.nav-guide__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row-reverse;
  padding: 12px 24px;
}

.nav-guide__icon {
  display: inline-flex;
  align-items: center;
  width: 10px;
  height: 10px;
  font-size: 10px;
}

.header-bg {
  position: fixed;
  display: block;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.16);
  z-index: 999;
  visibility: hidden;
  opacity: 0;
  transition: all 0.16s ease-out;
}
.header-bg.is-show {
  visibility: visible;
  opacity: 1;
}

.guide-spMenu {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 55px;
  width: 100%;
  height: 100vh;
  background-color: #ffffff;
  z-index: 9999;
  -webkit-transform: translateY(-16px);
          transform: translateY(-16px);
  transition: all 0.16s ease-out;
}
.guide-spMenu::before {
  content: "";
  position: absolute;
  top: -6px;
  right: 127px;
  display: block;
  width: 12px;
  height: 12px;
  background-color: #ffffff;
  border-radius: 50%;
  z-index: 9998;
  transition: all 0.16s 0.16s ease-out;
  -webkit-transform: translateY(6px);
          transform: translateY(6px);
}

.guide-spMenu__wrapper {
  width: 100%;
  height: 100%;
  overflow: auto;
  padding-bottom: 200px;
  box-sizing: border-box;
}

.guide-spMenu.is-active {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.guide-spMenu.is-active::before {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.guide-spMenu__list {
  padding: 12px;
}

.guide-spMenu__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 24px;
}

.guide-spMenu__icon {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
}

.info-wrap {
  background-color: #f6f6f6;
  padding: 8px 8px 0;
}
.info-wrap > a {
  display: block;
  color: #1e50a2;
}
.info-wrap > a:hover {
  text-decoration: underline;
  opacity: 0.85;
}
.info-wrap + .info-wrap {
  padding-top: 0;
}
.info-wrap:last-of-type {
  padding-bottom: 4px;
  border-bottom: 1px solid #e5e5e5;
}

.bx-info {
  display: flex;
  align-items: flex-start;
  padding: 4px 0;
  text-align: left;
  position: relative;
}
.bx-info.is-emergency .bx-info__icon {
  background-color: #e8000a;
}
.bx-info.is-saigai .bx-info__icon {
  background-color: #d45700;
}

.bx-info__icon {
  background-color: #767676;
  color: #ffffff;
  margin: 0 6px 0 0;
  padding: 1px 4px 0;
  border-radius: 2px;
  position: relative;
  font-size: 11px;
  line-height: 1.5;
  text-align: center;
  flex: none;
}

.bx-info__text {
  margin: 0;
  font-size: 14px;
  text-align: justify;
  line-height: 1.4;
}

.bx-info__link {
  margin-left: 16px;
}

.system_error {
  background-color: #fffde2;
  padding: 12px 16px;
  text-align: left;
  position: relative;
}
.system_error span.system_error_title {
  color: #e8000a;
  font-size: 12px;
  border: 1px solid #e8000a;
  padding: 3px;
  margin: 0 8px 0 0;
  border-radius: 2px;
}
.system_error::before {
  content: "";
  display: block;
  background: linear-gradient(rgba(0, 0, 0, 0.16), rgba(0, 0, 0, 0));
  width: 100%;
  height: 2px;
  position: absolute;
  top: 0;
  left: 0;
}

.saigai_support,
.saigai_support_emergency {
  background-color: #fffde2;
  padding: 12px 16px;
  text-align: left;
  position: relative;
}
.saigai_support span.saigai_support_title,
.saigai_support span.saigai_support_emergency_title,
.saigai_support_emergency span.saigai_support_title,
.saigai_support_emergency span.saigai_support_emergency_title {
  color: #d45700;
  font-size: 12px;
  border: 1px solid #d45700;
  padding: 3px;
  margin: 0 8px 0 0;
  border-radius: 2px;
}
.saigai_support span.saigai_support_emphasis,
.saigai_support span.saigai_support_emergency_emphasis,
.saigai_support_emergency span.saigai_support_emphasis,
.saigai_support_emergency span.saigai_support_emergency_emphasis {
  font-weight: bold;
}
.saigai_support::before,
.saigai_support_emergency::before {
  content: "";
  display: block;
  background: linear-gradient(rgba(0, 0, 0, 0.16), rgba(0, 0, 0, 0));
  width: 100%;
  height: 2px;
  position: absolute;
  top: 0;
  left: 0;
}
.spMenu .spMenu-wrap_inner {
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
  overflow: hidden;
}
html[data-script-enabled=true] .spMenu {
  position: fixed;
  top: 116px;
  z-index: 9000;
  width: 100%;
  height: 100vh;
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(-16px);
          transform: translateY(-16px);
  transition: all 0.16s ease-out;
}
html[data-script-enabled=true] .spMenu .spMenu-fadein {
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(-8px);
          transform: translateY(-8px);
  transition: all 0.16s 0.16s ease-out;
}
html[data-script-enabled=true] .spMenu > .spMenu-wrap {
  position: relative;
  width: 100%;
  height: 100vh;
}
html[data-script-enabled=true] .spMenu > .spMenu-wrap::before {
  content: "";
  position: absolute;
  top: -6px;
  right: 31px;
  width: 12px;
  height: 12px;
  background-color: #fff4de;
  border-radius: 50%;
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(6px);
          transform: translateY(6px);
  transition: all 0.16s 0.16s ease-out;
}
html[data-script-enabled=true] .spMenu .spMenu-body {
  position: absolute;
  top: 0;
  left: 0;
  height: 100vh;
  padding-bottom: 260px;
}
html[data-script-enabled=true] .spMenu .spMenu-body.spMenu-body_sublist {
  right: inherit;
  left: 100vw;
}
html[data-script-enabled=true] .spMenu .spMenu-body_sublist {
  transition: visibility 0.3s 0.3s ease-out, opacity 0.3s 0.3s ease-out;
}
html[data-script-enabled=true] .spMenu .spMenu-body_sublist > .head {
  display: block;
}
html[data-script-enabled=true] .spMenu .spMenu-list [data-disp] {
  display: block;
}
html[data-script-enabled=true] .spMenu .spMenu-list [data-disp] + details {
  display: none;
}
html[data-script-enabled=true] .spMenu .spMenu-search_head {
  display: flex;
}
html[data-script-enabled=true] .spMenu .spMenu-search_footer {
  display: block;
}
html[data-script-enabled=true] .spMenu .spMenuMain-head > .menu-search {
  display: block;
}
html[data-script-enabled=true] .spMenu.is-open {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
html[data-script-enabled=true] .spMenu.is-open .spMenu-wrap::before {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
html[data-script-enabled=true] .spMenu.is-open .spMenu-fadein {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
html[data-script-enabled=true] .spMenu.is-search .spMenu-body_search {
  display: block;
}
html[data-script-enabled=true] .spMenu.is-sublist .spMenu-wrap_inner {
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
}
html[data-script-enabled=true] .spMenu.is-sublist .spMenu-body_sublist {
  transition: none;
  visibility: visible;
  opacity: 1;
}
html[data-script-enabled=true] .is-app-banner-displayed .spMenu {
  top: 180px;
}

.spMenu-body {
  box-sizing: border-box;
  width: 100%;
  background: #fff;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.account-info {
  padding: 24px;
  background-color: #fff4de;
}
.account-info span {
  display: flex;
  justify-content: center;
  align-items: baseline;
}
.account-info .header-nickname {
  display: inline-block;
  font-size: 20px;
  font-weight: bold;
  overflow: hidden;
  max-width: 13em;
  white-space: nowrap;
  vertical-align: top;
  text-overflow: ellipsis;
}
.account-info .header-nickname__small {
  font-size: 11px;
  font-weight: bold;
}
.account-info .loginlink {
  display: flex;
  align-items: center;
  color: #1e50a2;
  font-size: 14px;
}
.account-info .loginlink-icon {
  display: inline-flex;
  align-items: center;
}
.account-info .loginlink-icon::before {
  width: 14px;
  height: 14px;
}

.account-contents {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.account-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 48%;
  height: 48px;
  font-size: 14px;
  font-weight: bold;
  border-radius: 24px;
  box-sizing: border-box;
}
.account-btn.-login {
  background-color: #ad0003;
  color: #ffffff;
}
.account-btn.-regist {
  background-color: #fff4de;
  color: #ad0003;
  border: 2px solid #ad0003;
}

.pickup-list {
  display: flex;
  justify-content: space-between;
  padding-bottom: 24px;
  background-color: #fff4de;
}
.pickup-list > .pickup-box {
  width: 33.33%;
}

.pickup-inner {
  background-color: #ffffff;
  width: calc(100% - 48px);
  margin: 0 auto;
  border-radius: 8px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.pickup-top {
  display: flex;
  justify-content: space-around;
  padding: 14px 0 8px;
}

.pickup-box {
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  width: 156px;
  height: 90px;
  line-height: 1.3;
}
.pickup-box > .icon {
  display: inline-flex;
  justify-content: center;
  font-size: 24px;
}
.pickup-box > .text {
  font-size: 12px;
  font-weight: bold;
  margin-top: 12px;
}

.pickup-bottom__inner {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid #efefef;
}

.pickup-bottom__link {
  width: 50%;
  padding: 16px 0;
  color: #1e50a2;
  font-size: 14px;
  text-align: center;
  box-sizing: border-box;
}
.pickup-bottom__link:first-child {
  border-right: 1px solid #efefef;
}

.spMenuMain-head {
  padding: 12px 16px;
  background-color: #e5e5e5;
}
.spMenuMain-head > .menu-search {
  position: relative;
  width: 100%;
  height: 32px;
  background-color: #fff;
  border: 0;
  border-radius: 4px;
  overflow: hidden;
  display: none;
  text-align: left;
}
.spMenuMain-head > .menu-search > .searchText {
  overflow: hidden;
  padding: 0 8px;
  font-size: 14px;
  line-height: 32px;
  white-space: nowrap;
  display: block;
}
.spMenuMain-head > .menu-search > .searchButton {
  position: absolute;
  top: 0;
  right: 0;
  width: 32px;
  height: 32px;
  background-color: #f6f6f6;
  text-align: center;
  line-height: 32px;
  display: block;
}

.spMenu-service {
  background-color: #fff4de;
}

.spMenu-service__inner {
  padding: 24px 24px 40px;
}

.spMenu-service__title {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 16px;
}
.spMenu-service__title::before, .spMenu-service__title::after {
  content: "";
  border: 1px solid #16160e;
  flex-grow: 1;
}
.spMenu-service__title::before {
  margin-right: 8px;
}
.spMenu-service__title::after {
  margin-left: 8px;
}

.spMenu-service__list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.spMenu-service__item {
  width: 49%;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}
.spMenu-service__item:nth-child(even) {
  margin-left: 2%;
}
.spMenu-service__item:nth-child(n+3) {
  margin-top: 16px;
}
.spMenu-service__item:empty {
  background-color: rgba(0, 0, 0, 0.02);
  box-shadow: none;
}

.spMenu-service__link {
  display: block;
  padding: 12px 0 16px;
  text-align: center;
}
.spMenu-service__link.-gcf, .spMenu-service__link.-saigai {
  display: flex;
  align-items: center;
  padding: 24px;
}

.spMenu-service__icon {
  display: inline-flex;
  justify-content: center;
  color: #ad0003;
  font-size: 20px;
}
.spMenu-service__icon.-gcf, .spMenu-service__icon.-saigai {
  font-size: 34px;
}
.spMenu-service__icon.-gcf {
  color: #2e792d;
}
.spMenu-service__icon.-saigai {
  color: #d45700;
}

.spMenu-service__txt {
  font-size: 12px;
  font-weight: bold;
}

.spMenu-service__main {
  background-color: #ffffff;
  margin-top: 16px;
  border-radius: 8px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.spMenu-service__contents {
  margin-left: 16px;
  text-align: left;
}

.spMenu-service__lead {
  font-weight: bold;
  margin-bottom: 4px;
}

.spMenu-service__detail {
  font-size: 12px;
}

.spMenu-service__about-concept {
  margin-top: 16px;
  text-align: center;
}
.spMenu-service__about-concept p {
  font-weight: bold;
  font-size: 12px;
}
.spMenu-service__about-concept .link-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 16px auto 0;
  font-weight: bold;
  border: 2px solid #ad0003;
  color: #ad0003;
  background-color: #ffffff;
  border-radius: 20px;
  box-sizing: border-box;
  width: 214px;
  height: 38px;
  line-height: 38px;
  font-size: 14px;
}

.spMenu-service__banner {
  margin-top: 40px;
  text-align: center;
}

.spMenu-list {
  display: block;
  padding: 40px 24px 0;
}
.spMenu-list > li > a,
.spMenu-list > li > label,
.spMenu-list > li > details > summary {
  position: relative;
  display: block;
  padding: 12px 16px;
  font-size: 16px;
}
.spMenu-list > li .spMenu-list__summary .spMenu-list__arrow {
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.spMenu-list > li details[open] .spMenu-list__summary .spMenu-list__arrow {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
.spMenu-list > li:first-child {
  margin-bottom: 40px;
}
.spMenu-list .controll {
  display: none;
}
.spMenu-list .inner-list {
  font-size: 14px;
  padding-top: 16px;
}
.spMenu-list .inner-list > li > a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0 12px 22px;
  line-height: 1;
}
.spMenu-list .inner-list > li > a[data-disp] {
  display: none;
}
.spMenu-list .inner-list > li > details > ul > li {
  padding: 12px 16px 12px 32px;
}
.spMenu-list [data-disp] {
  display: none;
}
.spMenu-list [data-disp] summary > .spMenu-list__arrow {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.spMenu-list [data-disp][open] summary > .spMenu-list__arrow {
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}

.spMenu-list__lead {
  display: flex;
  align-items: center;
  color: #6f6f6f;
  font-size: 12px;
  padding-bottom: 16px;
}

.spMenu-list__icon {
  display: inline-flex;
  font-size: 24px;
  margin-right: 16px;
  line-height: 1;
}

.spMenu-list__inner {
  border-top: 1px solid #efefef;
}

.spMenu-list__item {
  padding: 16px 0;
  border-bottom: 1px solid #efefef;
}

.spMenu-list__detail {
  padding: 8px;
}

.spMenu-list__summary {
  font-size: 16px;
  font-weight: bold;
}
.spMenu-list__summary span {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.spMenu-list__arrow {
  display: inline-flex;
  font-size: 14px;
  line-height: 1;
}

.spMenu-body_sublist {
  visibility: hidden;
  opacity: 0;
}
.spMenu-body_sublist a,
.spMenu-body_sublist button {
  display: block;
  padding: 8px 16px;
}
.spMenu-body_sublist button {
  border: 0;
  background: none;
}
.spMenu-body_sublist > .head {
  display: none;
  position: relative;
  border-bottom: 1px solid #e5e5e5;
}
.spMenu-body_sublist > .head > a,
.spMenu-body_sublist > .head > button {
  padding: 12px 16px 12px 30px;
  font-size: 16px;
}
.spMenu-body_sublist > .head > a:before,
.spMenu-body_sublist > .head > button:before {
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  width: 28px;
  height: 48px;
  line-height: 48px;
  text-align: center;
  font-size: 14px;
}
.spMenu-body_sublist .sublist-list {
  display: none;
  padding-top: 12px;
  font-size: 14px;
}

#js-sublist-body.on-product .disp-product {
  display: block;
}
#js-sublist-body.on-money .disp-money {
  display: block;
}
#js-sublist-body.on-use .disp-use {
  display: block;
}
#js-sublist-body.on-my_point .disp-my_point {
  display: block;
}
#js-sublist-body.on-my_account .disp-my_account {
  display: block;
}

.spMenu-body_search {
  display: none;
  position: relative;
}

.spMenu-search_head {
  background-color: #ad0003;
  display: none;
  padding: 0 16px 12px 0;
}
.spMenu-search_head > .backbutton {
  color: #fff;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  width: 44px;
  height: 36px;
  line-height: 36px;
  margin-top: 12px;
  text-align: center;
  overflow: hidden;
  background: none;
  border: 0;
}
.spMenu-search_head > .backbutton > span {
  font-size: 10px;
  position: absolute;
  z-index: -1;
  opacity: 0;
}
.spMenu-search_head > .search-window {
  flex: 1;
}
.spMenu-search_head > .search-window .autocomplete {
  width: calc(100% - 62px);
}

.spMenu-search_history > h3 {
  padding: 18px 18px 8px;
  font-weight: 800;
  font-size: 16px;
}
.spMenu-search_history > ul {
  border-bottom: 1px solid #e5e5e5;
}
.spMenu-search_history > ul > li {
  border-top: 1px solid #e5e5e5;
}
.spMenu-search_history > ul > li > a {
  display: block;
  padding: 8px 18px;
  font-size: 14px;
}

.spMenu-search_footer {
  position: fixed;
  left: 0;
  bottom: 0;
  box-sizing: border-box;
  width: 100%;
  padding: 12px;
  background-color: #fff;
  border-top: 1px solid #e5e5e5;
  display: none;
}
.spMenu-search_footer > .footer-button {
  display: block;
  width: 100%;
  height: 38px;
  line-height: 38px;
  text-align: center;
  color: #fff;
  border-radius: 4px;
  border: 0;
  background-color: #ad0003;
  -webkit-appearance: none;
          appearance: none;
}

.pagetop {
  display: block;
  background-color: #f6f6f6;
  margin: 0;
  padding: 27px 0;
  font-size: 13px;
  line-height: 18px;
  text-align: center;
}
.pagetop:first-letter {
  font-size: 11px;
}

.footer-global {
  margin-top: 80px;
}

.footer-button {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 160px;
  height: 40px;
  line-height: 40px;
  font-size: 14px;
  font-weight: bold;
  border: 2px solid #16160e;
  border-radius: 20px;
  box-sizing: border-box;
}
.footer-button.-service {
  width: 280px;
}
.footer-button.-service i {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
}

.footer-nav {
  padding: 56px 0 40px;
}

.footer-nav__wrapper {
  position: relative;
  width: calc(100% - 32px);
  margin: 0 auto 64px;
  padding: 32px 0 40px;
  background-color: #f6f6f6;
  text-align: center;
  border-radius: 16px;
}

.footer-nav__contents:not(:last-child) {
  margin-bottom: 40px;
}

.footer-nav__icon {
  display: inline-flex;
  align-items: center;
  height: 32px;
  color: #ad0003;
  font-size: 32px;
  margin-bottom: 12px;
}

.footer-nav__title {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 16px;
}

.footer-nav__desc {
  font-size: 14px;
  margin-bottom: 24px;
}

.footer-achievement {
  margin-bottom: 64px;
  color: #8e6f00;
  text-align: center;
}

.footer-achievement__lead {
  margin-bottom: 16px;
  font-size: 20px;
  font-weight: bold;
}

.footer-achievement__wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 16px 16px;
}

.footer-achievement__img {
  position: relative;
  width: 135px;
}
.footer-achievement__img:not(:last-child) {
  margin-right: 8px;
}
.footer-achievement__img p {
  position: absolute;
  left: 50%;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100%;
  font-size: 12px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0;
}
.footer-achievement__img span {
  align-self: flex-start;
  font-size: 10px;
}

.footer-achievement__note {
  display: flex;
  justify-content: center;
  font-size: 12px;
  color: #16160e;
}

.footer-about-choice-concept {
  text-align: center;
}
.footer-about-choice-concept .text {
  font-size: 14px;
}
.footer-about-choice-concept .link-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  font-size: 14px;
  font-weight: bold;
  border: 2px solid #16160e;
  border-radius: 20px;
  box-sizing: border-box;
}
.footer-about-choice-concept .link-btn:hover {
  background-color: #16160e;
  color: #ffffff;
}

.footer-sns__wrapper {
  margin-bottom: 32px;
}

.footer-sns__list {
  display: flex;
  justify-content: center;
}

.footer-sns__item:not(:last-child) {
  margin-right: 24px;
}

.footer-sns__item a {
  display: block;
  height: 32px;
  transition: all 0.3s;
}
.footer-sns__item a:hover {
  opacity: 0.85;
}

.footer-sns__icon {
  display: inline-flex;
  align-items: center;
  line-height: 1;
  font-size: 32px;
}

.footer-service__wrapper {
  margin-bottom: 32px;
}

.footer-service__list {
  display: flex;
  align-items: center;
  flex-direction: column;
}

.footer-service__item {
  display: flex;
  align-items: center;
}
.footer-service__item:not(:last-child) {
  margin-bottom: 16px;
}

.footer-service__icon {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 16px;
  margin-right: 8px;
  color: #ffffff;
  font-size: 8px;
  border-radius: 50%;
}
.footer-service__icon::before {
  display: inline-flex;
  align-items: center;
  width: 9px;
  height: 16px;
}
.footer-service__icon.-choice {
  background-color: #ad0003;
}
.footer-service__icon.-gcf {
  background-color: #2e792d;
}
.footer-service__icon.-saigai {
  background-color: #d45700;
}
.footer-service__icon.-enterprise {
  background-color: #006dcc;
}

.footer-service__link {
  font-weight: bold;
}

.footer-info {
  overflow: hidden;
}

.footer-info__curve {
  background-color: #f6f6f6;
  border-radius: 50% 50% 0% 0%/4% 4% 0% 0%;
}

.footer-info__wrapper {
  padding: 46px 0 40px;
}

.footer-info__top {
  display: flex;
  flex-direction: column;
  width: 276px;
  margin: 0 auto 48px;
}

.footer-info__img {
  display: flex;
  justify-content: space-between;
  margin-bottom: 16px;
}
.footer-info__txt p {
  font-size: 10px;
}

.footer-info__logo {
  width: 192px;
  margin: 0 auto 32px;
  text-align: center;
}
.footer-info__logo a {
  display: block;
}

.footer-info__list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  justify-content: center;
  margin-bottom: 16px;
  margin-inline: auto;
}

.footer-info__item {
  font-size: 14px;
}

.footer-info__en {
  font-size: 14px;
  margin-bottom: 40px;
  text-align: center;
}
.footer-info__link:hover {
  text-decoration: underline;
}

.footer-info__privacy {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 130px;
  background-color: #ffffff;
  text-align: center;
}

.footer-info__copyright {
  display: block;
  color: #6f6f6f;
  font-size: 11px;
  text-align: center;
}

[data-modal-id=guide] .modal-component--new__x,
[data-modal-id=opinion] .modal-component--new__x {
  top: 20px;
  right: 16px;
  z-index: 99;
}
[data-modal-id=guide] .modal-component--new__x::before,
[data-modal-id=guide] .modal-component--new__x::after,
[data-modal-id=opinion] .modal-component--new__x::before,
[data-modal-id=opinion] .modal-component--new__x::after {
  height: 16px;
  background-color: #16160e;
}
[data-modal-id=guide] .modal-component--new__body,
[data-modal-id=opinion] .modal-component--new__body {
  border-radius: 32px;
}
[data-modal-id=guide] .modal-component--new__header,
[data-modal-id=opinion] .modal-component--new__header {
  border-bottom: 1px solid #efefef;
}
[data-modal-id=guide] .modal-component--new__header-title,
[data-modal-id=opinion] .modal-component--new__header-title {
  font-size: 16px;
}
[data-modal-id=guide] .modal-component--new__scroll-icon,
[data-modal-id=opinion] .modal-component--new__scroll-icon {
  border-radius: 0 0 32px 32px;
}

[data-modal-id=guide] .modal-component--new__main {
  padding: 69px 0 40px;
}
[data-modal-id=guide] .modal-component--new__header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 57px;
  background-color: #ffffff;
  border-radius: 32px 32px 0 0;
  z-index: 9;
}
[data-modal-id=guide] .modal-component--new__header-title {
  display: flex;
  justify-content: center;
  align-items: center;
}
[data-modal-id=guide] .footer-guide__icon {
  display: inline-flex;
  align-items: center;
  width: 16px;
  height: 16px;
  color: #ad0003;
  font-size: 16px;
  margin-right: 8px;
}
[data-modal-id=guide] .footer-guide__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row-reverse;
  padding: 12px 24px;
}
[data-modal-id=guide] .footer-guide__arrow {
  display: inline-flex;
  align-items: center;
  width: 10px;
  height: 10px;
  font-size: 10px;
}

[data-modal-id=opinion] .modal-component--new__body {
  min-height: 428px;
}
[data-modal-id=opinion] .modal-component--new__header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 57px;
  background-color: #ffffff;
  border-radius: 32px 32px 0 0;
  z-index: 9;
}
[data-modal-id=opinion] .modal-component--new__main .is-hide {
  display: none;
}
[data-modal-id=opinion] .modal-component--new__main {
  padding: 57px 0 0;
}
[data-modal-id=opinion] .goiken-form__box {
  position: relative;
  padding: 24px;
}
[data-modal-id=opinion] .goiken-form__success {
  font-size: 14px;
  text-align: center;
  margin-top: 90px;
  line-height: 1.6;
}
[data-modal-id=opinion] .goiken-form__textarea {
  display: block;
  width: 100%;
  height: 125px;
  padding: 8px;
  color: #16160e;
  font-size: 16px;
  border: 1px solid #e0e0e0;
  border-radius: 16px;
  box-sizing: border-box;
}
[data-modal-id=opinion] .goiken-form__textarea:focus::-webkit-input-placeholder {
  color: transparent;
}
[data-modal-id=opinion] .goiken-form__textarea:focus:-ms-input-placeholder {
  color: transparent;
}
[data-modal-id=opinion] .goiken-form__textarea:focus::-ms-input-placeholder {
  color: transparent;
}
[data-modal-id=opinion] .goiken-form__textarea:focus::placeholder {
  color: transparent;
}
[data-modal-id=opinion] .goiken-form__error {
  display: none;
  position: absolute;
  top: -8px;
  left: 0;
  width: 100%;
  text-align: center;
  background-color: #6b6b6b;
  border-radius: 4px;
  color: #ffffff;
  font-size: 12px;
  padding: 2px 0;
  z-index: 99;
}
[data-modal-id=opinion] .goiken-form__error::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  height: 10px;
  width: 10px;
  background-color: #6b6b6b;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
[data-modal-id=opinion] .goiken-form__desc p {
  font-size: 14px;
}
[data-modal-id=opinion] .goiken-form__desc p:first-child {
  margin-bottom: 12px;
}
[data-modal-id=opinion] .goiken-form__content.-top {
  padding: 0 24px 40px;
}
[data-modal-id=opinion] .goiken-form__content.-bottom {
  background-color: #f6f6f6;
  padding: 40px 24px;
}
[data-modal-id=opinion] .goiken-form__desc {
  text-align: center;
  font-weight: bold;
  margin-bottom: 16px;
  font-size: 14px;
}
[data-modal-id=opinion] .goiken-form__desc.-note {
  margin-bottom: 8px;
  font-size: 16px;
  color: #e8000a;
}
[data-modal-id=opinion] .goiken-form__agree {
  text-align: center;
  margin-bottom: 16px;
}
[data-modal-id=opinion] .goiken-form__agree__label {
  border-radius: 99px;
  padding: 10px 16px;
  display: inline-block;
  position: relative;
  cursor: pointer;
}
[data-modal-id=opinion] .goiken-form__agree__label:hover {
  background-color: #f6f6f6;
}
[data-modal-id=opinion] .goiken-form__agree__checkbox {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
[data-modal-id=opinion] .goiken-form__agree__text {
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
[data-modal-id=opinion] .goiken-form__agree__text::before {
  content: "";
  display: inline-block;
  border-radius: 4px;
  width: 18px;
  height: 18px;
  margin-right: 8px;
  border: 2px solid #6f6f6f;
  background: #ffffff;
  box-sizing: border-box;
  flex-shrink: 0;
}
[data-modal-id=opinion] .goiken-form__agree__text::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 5px;
  display: inline-block;
  width: 8px;
  height: 12px;
  border: solid #ffffff;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin-top: -8px;
  box-sizing: border-box;
}
[data-modal-id=opinion] .goiken-form__agree__checkbox:checked + .goiken-form__agree__text::before {
  background-color: #16160e;
  border-color: #16160e;
}
[data-modal-id=opinion] .goiken-form__agree__checkbox:checked + .goiken-form__agree__text::after {
  border-color: #ffffff;
}
[data-modal-id=opinion] .goiken-form__button {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 100%;
  height: 48px;
  line-height: 48px;
  background-color: #ad0003;
  color: #ffffff;
  font-size: 14px;
  border: none;
  border-radius: 24px;
  box-sizing: border-box;
  cursor: pointer;
}
[data-modal-id=opinion] .goiken-form__button:hover {
  opacity: 0.85;
}
[data-modal-id=opinion] .goiken-form__button.-close, [data-modal-id=opinion] .goiken-form__button.-faq {
  background-color: #ffffff;
  color: #ad0003;
  border: 2px solid #ad0003;
}
[data-modal-id=opinion] .goiken-form__button.-submit {
  background-color: #ad0003;
  color: #ffffff;
  cursor: pointer;
}
[data-modal-id=opinion] .goiken-form__button.-submit:disabled {
  background-color: #c8c8c8;
  cursor: default;
  pointer-events: none;
}
[data-modal-id=opinion] .goiken-form__button.-close {
  margin-top: 92px;
}

.footer-account {
  background-color: #ad0003;
  color: #fff;
  height: 36px;
  margin-top: 16px;
  line-height: 36px;
  font-size: 11px;
  text-align: center;
}

.footer-single {
  margin-top: 126px;
}

.footer-single-sign {
  box-sizing: border-box;
  background: #f6f6f6;
  margin: 0 auto;
  padding: 16px;
}

.footer-single-sign__inner {
  background: #ffffff;
  padding: 16px;
}
.footer-single-sign__inner span:first-of-type {
  display: block;
  min-width: 130px;
  width: 130px;
  height: 66px;
  margin: 0 auto;
}
.footer-single-sign__inner img {
  min-width: 130px;
}

.footer-single-sign__text {
  margin-top: 8px;
  line-height: 1.5;
}

.footer-single-sign__seal {
  display: flex;
  justify-content: center;
}

.footer-single__ssl {
  padding: 0 16px;
  text-align: center;
}
.footer-single__ssl + .footer-single__policy {
  margin-top: 16px;
}

.footer-single__policy {
  padding: 0 16px;
  margin-top: 24px;
}
.footer-single__policy .txt {
  text-align: center;
}

.footer-single__note {
  background-color: #ad0003;
  color: #ffffff;
  height: 36px;
  margin-top: 16px;
  line-height: 36px;
  font-size: 11px;
  text-align: center;
}

.policy-list {
  background-color: #ffffff;
  width: 100%;
  margin-bottom: 16px;
  box-sizing: border-box;
  font-size: 0px;
  text-align: center;
}

.policy-list__item {
  display: inline-block;
  margin-right: 10px;
  padding-right: 10px;
  border-right: 1px solid #020202;
  font-size: 12px;
}
.policy-list__item:last-child {
  margin-right: 0;
  padding-right: 0;
  border-right: none;
}

@-webkit-keyframes scroll-icon {
  0% {
    bottom: 24px;
  }
  33% {
    bottom: 16px;
  }
  100% {
    bottom: 24px;
  }
}

@keyframes scroll-icon {
  0% {
    bottom: 24px;
  }
  33% {
    bottom: 16px;
  }
  100% {
    bottom: 24px;
  }
}
.modal-component--new {
  z-index: 10000;
  visibility: hidden;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  transition: opacity 0.25s, visibility 0.25s;
}
.modal-component--new.-opened {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.5s, visibility 0.5s;
}
.modal-component--new.-opened .modal-component--new__header,
.modal-component--new.-opened .modal-component--new__main,
.modal-component--new.-opened .modal-component--new__footer,
.modal-component--new.-opened .modal-component--new__scroll-icon {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.25s 0.5s, visibility 0.25s 0.5s;
}
.modal-component--new.not-available {
  z-index: 10001;
}
.modal-component--new.-header-fixed .modal-component--new__header-buffer {
  height: 60px;
}
.modal-component--new.-header-fixed .modal-component--new__header {
  background-color: #ffffff;
  border-radius: 6px 6px 0 0;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1;
}
.modal-component--new.-footer-fixed .modal-component--new__footer-buffer {
  height: 88px;
}
.modal-component--new.-footer-fixed .modal-component--new__main {
  padding-bottom: 0;
}
.modal-component--new.-footer-fixed .modal-component--new__footer {
  background-color: #ffffff;
  border-radius: 0 0 6px 6px;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  padding-top: 20px;
}

.modal-component--new__wrapper {
  display: none;
}

.modal-component--new__overlay {
  background: rgba(0, 0, 0, 0.6);
  border: 0;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}
.modal-component--new__overlay > span {
  position: absolute;
  z-index: -1;
  opacity: 0;
  font-size: 10px;
  white-space: nowrap;
}

.modal-component--new__container {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.modal-component--new__x {
  background: none;
  border: 0;
  position: absolute;
  padding: 16px;
  right: 0;
  top: -36px;
  cursor: pointer;
  overflow: hidden;
}
.modal-component--new__x::before, .modal-component--new__x::after {
  content: "";
  height: 32px;
  width: 2px;
  position: absolute;
  background-color: #fff;
  right: 12px;
  top: 0;
}
.modal-component--new__x::before {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.modal-component--new__x::after {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.modal-component--new__x > span {
  font-size: 10px;
  white-space: nowrap;
  position: absolute;
  z-index: -1;
  opacity: 0;
}

.modal-component--new__body {
  background: #fff;
  border-radius: 6px;
  box-sizing: border-box;
  overflow-y: auto;
  width: calc(100vw - 32px);
  max-height: calc(100vh - 112px);
}

.modal-component--new__header {
  padding: 16px;
  border-bottom: 1px solid #e5e5e5;
  position: relative;
  box-sizing: border-box;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s;
}

.modal-component--new__header-title {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}

.modal-component--new__main {
  padding: 16px 20px;
  position: relative;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s;
}
.modal-component--new__main > :first-child {
  margin-top: 0 !important;
}
.modal-component--new__main > :last-child {
  margin-bottom: 0 !important;
}

.modal-component--new__footer {
  padding: 0 16px 20px;
  box-sizing: border-box;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s;
  overflow: hidden;
}
.modal-component--new__footer > :first-child {
  margin-top: 0 !important;
}
.modal-component--new__footer > :last-child:not(.modal-component--new__button-wrap) {
  margin-bottom: 0 !important;
}

.modal-component--new__button-wrap {
  display: flex;
  justify-content: center;
  margin: 0 -16px -16px 0;
}
.modal-component--new__button-wrap.-type-vertical {
  flex-direction: column;
}
.modal-component--new__button-wrap.-type-vertical .modal-component--new__button {
  flex-shrink: 0;
  width: calc(100% - 16px);
}
.modal-component--new__button-wrap.-type-vertical.-type-select {
  flex-direction: column-reverse;
}
.modal-component--new__button-wrap .modal-component--new__button {
  margin: 0 16px 16px 0;
  margin-right: 16px;
  margin-bottom: 16px;
  flex-grow: 1;
  flex-basis: 100%;
  width: auto;
}

.modal-component--new__scroll-icon {
  pointer-events: none;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  transition: opacity 0.25s, visibility 0.25s;
  z-index: 2;
  display: block;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #ffffff);
  height: 64px;
  border-radius: 0 0 6px 6px;
}
.modal-component--new__scroll-icon.is-hidden {
  visibility: hidden !important;
  opacity: 0 !important;
  transition: opacity 0.25s, visibility 0.25s !important;
}
.modal-component--new__scroll-icon::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border: solid #000;
  border-width: 0 2px 2px 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  opacity: 0.5;
  position: absolute;
  bottom: 24px;
  left: calc(50% - 8.5px);
  z-index: 1;
  -webkit-animation: scroll-icon 0.6s infinite;
          animation: scroll-icon 0.6s infinite;
}
.modal-component--new__scroll-icon > span {
  position: absolute;
  z-index: -1;
  opacity: 0;
  font-size: 10px;
  white-space: nowrap;
}

.modal-component--new[data-modal-id=ex-link] .modal-component--new__x,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__x {
  top: 20px;
  right: 16px;
  z-index: 99;
}
.modal-component--new[data-modal-id=ex-link] .modal-component--new__x::before, .modal-component--new[data-modal-id=ex-link] .modal-component--new__x::after,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__x::before,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__x::after {
  height: 16px;
  background-color: #16160e;
}
.modal-component--new[data-modal-id=ex-link] .modal-component--new__body,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__body {
  border-radius: 32px;
}
.modal-component--new[data-modal-id=ex-link] .modal-component--new__main,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__main {
  padding: 24px 0 40px;
}
.modal-component--new[data-modal-id=ex-link] .modal-component--new__footer,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__footer {
  padding: 0 24px 24px;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__title,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__title {
  font-size: 16px;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__text,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__text {
  margin-top: 16px;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__description,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__description {
  font-size: 14px;
  text-align: center;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__description-meibutsu,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__description-meibutsu {
  display: inline-block;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__note,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__note {
  margin-top: 4px;
  color: #e8000a;
  font-size: 14px;
  text-align: center;
}
.modal-component--new[data-modal-id=ex-link] .meibutsu-content.-hidden,
.modal-component--new[data-modal-id=ex-link-meibutsu] .meibutsu-content.-hidden {
  display: none;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__button,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__button {
  text-align: center;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__link,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__link {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 100%;
  height: 48px;
  background-color: #ad0003;
  color: #ffffff;
  line-height: 48px;
  font-size: 14px;
  font-weight: bold;
  border-radius: 24px;
  transition: all 0.3s;
  box-sizing: border-box;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__link i,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__link i {
  display: inline-flex;
  align-items: center;
  margin-left: 4px;
}
.modal-component--new[data-modal-id=ex-link] .modal-ex-link__link:hover,
.modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__link:hover {
  opacity: 0.85;
}

/*
 外ボーダーなしカード
*/
.card-simple__link {
  min-height: 0%;
  flex-grow: 1;
  display: flex;
  width: 100%;
  flex-direction: column;
}
.card-simple__link:hover .card-simple__img {
  opacity: 0.85;
}
.card-simple__link:hover .card-simple__title,
.card-simple__link:hover .card-simple__txt {
  color: #1e50a2;
  text-decoration: underline;
}
.card-simple__image {
  position: relative;
  border: 1px solid #e5e5e5;
  margin-bottom: 4px;
}
.card-simple__title {
  font-size: 14px;
  font-weight: normal;
}
.card-simple p {
  font-size: 12px;
}

.ttl-h1--icon {
  margin-top: 32px;
}

.nv-switch-item {
  display: flex;
  align-items: center;
}
.nv-switch-item__label {
  font-size: 14px;
  display: inline-block;
  margin-right: 4px;
}
.nv-switch-item__item {
  display: inline-block;
  color: #16160e;
  padding: 2px 8px;
  border: #e5e5e5 1px solid;
  background-color: #ffffff;
  position: relative;
  font-size: 14px;
  line-height: 20px;
  cursor: pointer;
}
.nv-switch-item__item:first-child {
  border-radius: 4px 0 0 4px;
}
.nv-switch-item__item:last-child {
  border-radius: 0 4px 4px 0;
}
.nv-switch-item__item:hover {
  background-color: #c8c8c8;
  border-color: #c8c8c8;
}
.nv-switch-item__item.is-current {
  background-color: #16160e;
  color: #fff;
  border-color: #16160e;
}
.nv-switch-item__item.is-current {
  cursor: default;
}
.nv-switch-item__icon {
  font-size: 20px;
  display: inline-block;
}
.nv-switch-item__icon:before {
  vertical-align: sub;
}

/**
 * spアコーディオン
 */
.block-accordion__title {
  position: relative;
}

.header__banner {
  text-align: center;
}
.header__banner:hover {
  opacity: 0.85;
}
.header__banner.-maff {
  background: #f6f7eb;
}
.header__banner.-seisansha-ouen {
  background: #e3d5b2;
}

.footer-donation-navi {
  background-color: #fdf5e5;
  padding: 40px 0 45px;
  margin-bottom: 24px;
  margin-top: 12px;
}
.footer-donation-navi h2 {
  text-align: center;
  margin-bottom: 56px;
  position: relative;
}
.footer-donation-navi h2::before, .footer-donation-navi h2::after {
  position: absolute;
  bottom: 0px;
  content: "";
  background-image: url(/assets/images/pages/top/lively.png);
  background-repeat: no-repeat;
  background-size: 100%;
  width: 19px;
  height: 30px;
}
.footer-donation-navi h2::after {
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
  right: calc(50% - 124px);
}
.footer-donation-navi h2::before {
  left: calc(50% - 124px);
}
.footer-donation-navi h2 em {
  color: #ad0003;
  font-size: 28px;
}
.footer-donation-navi .donation-navi__menu {
  position: relative;
}
.footer-donation-navi .donation-navi__menu:nth-child(1) {
  grid-area: menu-1;
}
.footer-donation-navi .donation-navi__menu:nth-child(2) {
  grid-area: menu-2;
}
.footer-donation-navi .donation-navi__menu:nth-child(3) {
  grid-area: menu-3;
}
.footer-donation-navi .donation-navi__menu img {
  position: absolute;
  right: 0;
  left: 0;
  margin: auto;
  top: -34px;
}
.footer-donation-navi .donation-navi__menu .-title-popular img {
  width: 63px;
  top: -40px;
}
.footer-donation-navi .donation-navi__menu .-title-osusume img {
  width: 57px;
}
.footer-donation-navi .donation-navi__menu .-title-price_range img {
  width: 33px;
}
.footer-donation-navi .donation-navi__menu .-title-popular-feature img {
  width: 58px;
}
.footer-donation-navi .donation-navi__menu h3 .-title {
  text-align: center;
  width: 100%;
  font-weight: bold;
  color: #fff;
  background-color: #ad0003;
  font-size: 12px;
  border-radius: 8px 8px 0 0;
  border: none;
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 60px;
}
.footer-donation-navi .donation-navi__menu h3 .-title em {
  font-size: 14px;
}
.footer-donation-navi .donation-navi__menu.-popular-feature ul {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
}
.footer-donation-navi .donation-navi__menu.-popular-feature ul li:nth-child(2n) {
  border-left: solid 1px #e5e5e5;
}
.footer-donation-navi .donation-navi__menu.-popular-feature ul li:nth-child(5) {
  border-bottom: none;
}
.footer-donation-navi .donation-navi__menu.-price_range li {
  height: 45px !important;
}
.footer-donation-navi .donation-navi__menu.-price_range li a {
  height: 45px !important;
}
.footer-donation-navi .donation-navi__menu .-content {
  background-color: #fff;
  border-radius: 0 0 8px 8px;
}
.footer-donation-navi .donation-navi__menu .-content li {
  display: flex;
  align-items: center;
  border-bottom: solid 1px #e5e5e5;
  height: 60px;
}
.footer-donation-navi .donation-navi__menu .-content li:last-child {
  border-bottom: none;
}
.footer-donation-navi .donation-navi__menu .-content a {
  position: relative;
  font-size: 13px;
  font-weight: bold;
  display: flex;
  flex-direction: column;
  justify-content: center;
  line-height: 1.3;
  width: 100%;
  padding: 0 32px 0 10px;
  height: 60px;
  letter-spacing: 0px;
}
.footer-donation-navi .donation-navi__menu .-content a:hover {
  opacity: 0.85;
}
.footer-donation-navi .donation-navi__menu .-content a::after, .footer-donation-navi .donation-navi__menu .-content a::before {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  margin: auto;
}
.footer-donation-navi .donation-navi__menu .-content a::after {
  width: 14px;
  height: 14px;
  background-color: #ad0003;
  border-radius: 50%;
  right: 10px;
}
.footer-donation-navi .donation-navi__menu .-content a::before {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 2px 0 2px 4px;
  border-color: transparent transparent transparent #fff;
  z-index: 1;
  right: 14px;
}
.footer-donation-navi .donation-navi__menu .-content a span {
  font-size: 10px;
}
@media only screen and (max-width: 834px) and (max-device-width: 834px) {
  .label--exclusive.-sticker {
    top: 3px;
    left: 3px;
    font-size: 10px;
  }
  .card-product__title.is-over {
    max-height: 4.5em;
    overflow: hidden;
    position: relative;
  }
  .card-product__title.is-over:after {
    content: "...";
    color: transparent;
    display: inline-block;
    width: 3em;
    background: linear-gradient(-90deg, #fff, rgba(255, 255, 255, 0));
    position: absolute;
    bottom: 0;
    right: 0;
  }
  .card-product .sts-type4,
  .card-product .sts-type5,
  .card-product .sts-type6 {
    font-size: 12px;
  }
  .card-product .sts-type7 {
    font-size: 12px;
  }
  .card-product .sts-type7:before {
    border-width: 16px;
  }
  .card-product .sts-type7 span {
    top: 4px;
    left: -2px;
  }
  .card-product .sts-type7.item-rank1, .card-product .sts-type7.item-rank2, .card-product .sts-type7.item-rank3 {
    left: 8px;
    width: 22px;
  }
  .card-product .sts-type7.item-rank1::before, .card-product .sts-type7.item-rank2::before, .card-product .sts-type7.item-rank3::before {
    border-width: 11px;
    border-bottom: 4px solid transparent;
  }
  .card-product__comment {
    display: inline-block;
    padding: 0 8px 12px;
  }
  .card-product__heart {
    top: -2px;
  }
  .card-product__heart > img {
    line-height: 1;
    width: 24px;
  }
  .card-product .city-symbol {
    display: none;
  }
  .gcf-cht-bar.gcf-cht-bar--right {
    height: 8px;
    margin: 2px 0 0;
  }
  .gcf-cht-bar.gcf-cht-bar--right .gcf-cht-bar__graph,
  .gcf-cht-bar.gcf-cht-bar--right .gcf-cht-bar__graph2 {
    height: 8px;
  }
  .gcf-cht-bar.gcf-cht-bar--right .gcf-cht-bar__number {
    font-size: 10px;
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
    height: 9px;
    line-height: 9px;
  }
  .transform-layout {
    box-shadow: none;
    border: none;
    border-bottom: solid 1px #e5e5e5;
    border-radius: 0;
  }
  .transform-layout .card-product__link {
    flex-direction: row;
  }
  .transform-layout .card-product__contents {
    padding: 0 0 0 16px;
  }
  .transform-layout .card-product__title {
    font-size: 14px;
  }
  .transform-layout .card-product__image {
    width: 100px;
    min-height: 0;
    flex-shrink: 0;
  }
  .transform-layout .card-product__img {
    height: auto;
  }
  .transform-layout .card-product__subtitle {
    background: none;
  }
  .transform-layout .card-product__subtitle-inner {
    padding: 0;
  }
  .transform-layout .card-product__complement {
    margin: 8px 0 0 116px;
  }
  .transform-layout .card-product__city {
    display: inline-block;
    height: auto;
    padding: 0;
    border-top: none;
    font-size: 12px;
    margin: 8px 0;
  }
  .transform-layout .card-product__city span {
    display: flex;
    justify-content: flex-end;
    align-items: center;
  }
  .transform-layout .card-product__city span:after {
    content: "";
    width: 4px;
    height: 4px;
    margin-left: 4px;
    border-top: solid 1px;
    border-right: solid 1px;
    border-color: #1e50a2;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .card-city {
    height: 100%;
  }
  .card-city__title {
    display: flex;
    align-items: center;
    padding: 8px;
    margin-top: 0;
  }
  .card-city .card-city__cityimage {
    width: 42px;
    height: 42px;
    margin-right: 8px;
    flex-shrink: 0;
  }
  .card-city__name {
    font-size: 14px;
    letter-spacing: 0;
    text-align: left;
  }
  .card-city__info {
    font-size: 12px;
    padding: 8px;
    border-bottom: solid 1px #e5e5e5;
  }
  .card-city__info dl dt {
    width: 30%;
  }
  .card-city__info dl dd {
    width: 66%;
    padding-left: 4%;
  }
  .card-city__category {
    padding: 8px;
  }
  .card-city__category p {
    margin-bottom: 4px;
  }
  .card-article .sts-type7 {
    font-size: 12px;
  }
  .card-article .sts-type7:before {
    border-width: 16px;
  }
  .card-article .sts-type7 span {
    top: 4px;
    left: -2px;
  }
  .card-article .sts-type7.item-rank1, .card-article .sts-type7.item-rank2, .card-article .sts-type7.item-rank3 {
    left: 8px;
    width: 22px;
  }
  .card-article .sts-type7.item-rank1::before, .card-article .sts-type7.item-rank2::before, .card-article .sts-type7.item-rank3::before {
    border-width: 11px;
    border-bottom: 4px solid transparent;
  }
  .card-article__link {
    flex-direction: row !important;
  }
  .card-article__img {
    border-radius: 0 !important;
  }
  .card-article__image {
    height: auto;
    width: 160px;
    flex-shrink: 0;
  }
  .card-article__contents {
    padding: 12px 8px;
  }
  .grid .grid__block {
    width: 50%;
    box-sizing: border-box;
  }
  .grid-2--sp {
    justify-content: space-between;
  }
  .grid-2--sp .grid__block {
    width: calc(50% - 6px);
  }
  .grid-2--sp .grid__block:not(:nth-child(-n+2)) {
    margin-top: 16px;
  }
  .grid-3.sld__list .grid__block {
    width: 212px;
    margin-right: 12px;
  }
  .grid-4.sld__list .grid__block {
    width: 212px;
    margin-right: 12px;
  }
  .grid-6.sld__list .grid__block {
    width: 161px;
    margin-right: 12px;
  }
  .grid-7.sld__list .grid__block {
    width: 88px;
    margin-right: 12px;
  }
  .grid-col .grid__block {
    width: 100%;
  }
  .grid-col--sp .grid__block {
    width: 100%;
  }
  .grid-feature .grid__block {
    width: calc(50% - 6px);
    margin-right: 12px;
  }
  .grid-feature .grid__block:nth-child(2n+1) {
    margin-right: 0;
  }
  .grid-feature .grid__block:first-child {
    width: 100%;
  }
  .grid-feature .grid__block:last-child {
    display: none;
  }
  .grid-ranking .grid__block {
    width: calc(50% - 6px);
    margin-right: 12px;
  }
  .grid-ranking .grid__block:nth-child(2n+1) {
    margin-right: 0;
  }
  .grid-ranking .grid__block:first-child {
    width: 100%;
  }
  .layout-column-2__main .grid-3.sld__list .grid__block {
    width: 161px;
    margin-right: 12px;
  }
  .layout-column-2__main .grid-3:not(.sld__list) .grid__block {
    width: calc(50% - 6px);
    margin-right: 12px;
  }
  .layout-column-2__main .grid-3:not(.sld__list) .grid__block:nth-child(2n) {
    margin-right: 0;
  }
  .section-title--h3 {
    font-size: 16px;
  }
  .recommend__sp-inner {
    padding: 16px;
    margin-bottom: 0;
  }
  .tab-navigation__list {
    width: 100%;
  }
  .tab-navigation__item {
    margin-right: 0;
    flex-grow: 1;
  }
  .tab-navigation__link {
    flex-direction: column;
  }
  .bottom-products__inner {
    padding: 24px 0;
  }
  .bottom-products .gcf-text {
    font-size: 14px;
  }
  .autocomplete {
    width: 100%;
    height: 100vh;
    top: 112px;
    left: 0;
    border-radius: 0;
  }
  .autocomplete .autocomplete-icon {
    margin-right: 8px;
  }
  .choice-balloon__wrap {
    max-width: 390px;
  }
  .button-rounded {
    font-size: 14px;
    padding: 0 16px;
    white-space: nowrap;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    height: 24px;
  }
  .search-window-modal__overlay {
    display: none;
  }
  .search-window-other-modal__overlay {
    display: none;
  }
  .search-window .autocomplete {
    padding-bottom: 64px;
  }
  .search-window .autocomplete.show-suggestions {
    height: 100vh;
  }
  .search-window__content {
    width: 100%;
    min-height: calc(100vh - 75px);
    height: 100%;
    position: absolute;
    top: 75px;
    left: 0;
  }
  .search-window__content .trending-words__wrap .pc-list {
    display: none;
  }
  .search-window__content .trending-words__wrap .sp-list {
    display: inline-flex;
  }
  .search-window-modal .modal-content .modal-header {
    background-color: white;
  }
  .search-window-modal .modal-content .modal-body {
    padding: 20px 16px;
    padding-bottom: 64px;
  }
  .search-window-modal .select-category-content .list-subcategories {
    margin-bottom: 20px;
  }
  .search-window-modal .select-category-content .list-subcategories__link i {
    order: 1;
  }
  .search-window-modal .select-category-content .list-subcategories__link .fs14 {
    margin: 0 0 0 auto;
  }
  .search-window-modal .buttons .price-buttons__filter,
  .search-window-modal .buttons .city-buttons__filter {
    flex: 1;
  }
  #category-modal .product-category {
    margin-top: 32px;
  }
  #price-modal .list-link .list-link__icon {
    font-size: 22px;
    opacity: 0.5;
  }
  .header-global {
    top: 0;
  }
  .header-global .autocomplete {
    border-left: none;
    border-right: none;
  }
  .header-top {
    position: relative;
  }
  .site-logo img {
    height: 34px;
  }
  .search-window {
    order: 2;
    margin-bottom: 4px;
  }
  .nav-user {
    order: 1;
    margin-bottom: 16px;
  }
  .nav-user__wrap .nav-user__list {
    display: none;
  }
  .nav-user__wrap--cart .nav-user__list {
    display: none;
  }
  .nav-user__label {
    letter-spacing: 0.025em;
  }
  .nav-menu {
    order: 3;
    margin-right: 4px;
  }
  .header-bottom {
    overflow: hidden;
  }
  .nav-global {
    padding: 0 16px;
  }
  .nav-global__list {
    justify-content: space-between;
    white-space: nowrap;
  }
  .nav-global__list li:last-child {
    padding-right: 48px;
  }
  .nav-global__list.nav-slide {
    -webkit-animation: nav-slide 1.2s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
            animation: nav-slide 1.2s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
  }
  .nav-global__list.is-hide {
    opacity: 0;
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  .nav-global__list.is-show {
    overflow-x: scroll;
    overflow-y: hidden;
  }
  .nav-global__item {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    height: 46px;
    padding: 0 16px;
    letter-spacing: 0;
    position: relative;
  }
  .nav-global__item::before {
    content: "";
    position: absolute;
    bottom: -3px;
    left: calc(50% - 6px);
    width: 12px;
    height: 12px;
    background-color: #ffffff;
    border-radius: 50%;
    visibility: hidden;
    opacity: 0;
    -webkit-transform: translateY(6px);
            transform: translateY(6px);
    transition: -webkit-transform 0.16s 0.16s ease-out;
    transition: transform 0.16s 0.16s ease-out;
    transition: transform 0.16s 0.16s ease-out, -webkit-transform 0.16s 0.16s ease-out;
  }
  .nav-global__item.is-active .nav-global__icon._arrow {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .nav-arrow {
    position: absolute;
    top: 15px;
    right: 8px;
    display: inline-flex;
    z-index: 999;
  }
  .nav-arrow.arrow-slide {
    -webkit-animation: arrow-slide 0.8s ease-in 0.4s infinite;
            animation: arrow-slide 0.8s ease-in 0.4s infinite;
  }
  .footer-nav__icon.icon-position {
    position: absolute;
    top: -16px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    margin-bottom: 0;
  }
  .footer-achievement__wrapper {
    max-width: 300px;
    margin: 0 auto 16px;
  }
  .footer-achievement__img:nth-child(2) {
    margin-right: 0;
  }
  .footer-achievement__img:nth-child(n+3) {
    margin-top: 16px;
  }
  .footer-achievement__note {
    flex-direction: column;
    align-items: flex-start;
    width: calc(100% - 48px);
    margin: 0 auto;
  }
  .footer-achievement__note li {
    text-align: left;
  }
  .footer-about-choice-concept {
    padding: 0 16px;
    margin: 0 auto 96px;
  }
  .footer-about-choice-concept .text {
    margin-top: 16px;
  }
  .footer-about-choice-concept .link-btn {
    width: 254px;
    height: 41px;
    line-height: 41px;
    margin-top: 24px;
  }
  .footer-info__list {
    max-width: 430px;
  }
  .nv-switch-item__item {
    font-size: 12px;
  }
  .block-accordion--sp .block-accordion__title .mf-arrow01-down {
    position: absolute;
    top: 15px;
    right: 15px;
    color: #767676;
  }
  .block-accordion--sp .block-accordion__box {
    display: none;
  }
  .block-accordion--sp.is-open .block-accordion__title .mf-arrow01-down {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
    top: 10px;
  }
  .block-accordion--sp.is-open .block-accordion__box {
    display: block;
  }
  .footer-donation-navi {
    padding: 32px 16px 40px;
    margin-top: 32px;
    margin-bottom: 8px;
  }
  .footer-donation-navi h2 {
    margin-bottom: 48px;
  }
  .footer-donation-navi h2 em {
    font-size: 20px;
  }
  .footer-donation-navi .donation-navi__menu:not(:first-child) {
    margin-top: 50px;
  }
  .footer-donation-navi + .footer-global {
    margin-top: 0;
  }
}
@media all and (-ms-high-contrast: none) {
  .card-product__image {
    min-height: 1px;
  }
  .card-product__price-option p {
    line-height: 1;
  }
  .card-project__image {
    min-height: 1px;
  }
  .card-city__image {
    min-height: 1px;
  }
  .card-article__image {
    min-height: 1px;
  }
}
@media only screen and (min-width: 835px), (min-device-width: 835px) {
  .card-product__title {
    line-height: 1.38;
    font-size: 16px;
  }
  .card-product__contents {
    padding: 20px 10px 16px;
  }
  .card-product__contents .lst-icon {
    margin-top: 8px;
  }
  .card-product__subtitle {
    margin-top: 16px;
  }
  .card-product__subtitle-inner {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    align-content: flex-start;
  }
  .card-product__text {
    margin-top: 16px;
  }
  .card-product__code {
    margin-top: 16px;
  }
  .card-product__heart {
    display: inline-block;
  }
  .card-product__city > img {
    border-radius: 4px;
    margin-right: 10px;
  }
  .card-product__city > span {
    letter-spacing: 0;
    margin-right: 15px;
  }
  .card-product__city > span > br {
    display: none;
  }
  .card-product__complement {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    align-content: flex-start;
  }
  .card-project__title {
    line-height: 1.38;
    font-size: 16px;
  }
  .card-project__contents {
    padding: 20px 10px 16px;
  }
  .card-project__contents .lst-icon {
    margin-top: 8px;
  }
  .card-project:before {
    max-width: 244px;
    width: 32%;
  }
  .card-project__img.lazyload, .card-project__img.lazyloading {
    height: 138px;
  }
  .card-project__col {
    margin: 68px 0 0 0;
    max-width: 244px;
    width: 100%;
    box-sizing: border-box;
  }
  .card-project__col:nth-child(1), .card-project__col:nth-child(2) {
    margin-top: 0;
  }
  .card-project__col:nth-child(3) {
    margin-top: 0;
  }
  .card-project__col .card-project__complete {
    height: 70px;
    width: 70px;
    left: 8px;
  }
  .card-project__col .card-project__soon {
    top: 8px;
    left: 11px;
    width: 88px;
    height: 30px;
    border-radius: 0 0 8px 8px;
  }
  .card-project__label {
    width: 235px;
    height: 30px;
    padding: 8px;
  }
  .card-project__label .card-project__text {
    font-size: 14px;
  }
  .card-project a:hover .card-project__image {
    opacity: 0.85;
  }
  .card-project a:hover .card-project__name {
    color: #1e50a2;
    text-decoration: underline;
  }
  .card-project__remind--complete, .card-project__remind--soon {
    line-height: 1.7;
  }
  .card-project__name {
    font-size: 16px;
  }
  .card-project__detail {
    max-width: 100%;
  }
  .card-project__pref {
    font-size: 14px;
  }
  .card-project__total {
    font-size: 14px;
  }
  .card-project__text {
    font-size: 18px;
    font-weight: bold;
    margin-top: 2px;
  }
  .card-project__badge {
    width: 56px;
    height: 18px;
  }
  .card-project__quantity {
    font-size: 20px;
    letter-spacing: 0;
  }
  .card-project__progress {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    overflow: hidden;
  }
  .card-project__progress > div:first-child {
    flex: none;
  }
  .card-project__progress > div:nth-child(2) {
    flex: none;
    min-width: 130px;
  }
  .card-project__favorite-button {
    border-radius: 5px;
    font-size: 16px;
    height: 40px;
    box-sizing: border-box;
  }
  .card-project__end-button {
    border-radius: 5px;
    font-size: 14px;
    height: 32px;
    margin-top: 20px;
    padding-top: 6px;
  }
  .card-project__end {
    font-size: 14px;
    margin-left: 5px;
  }
  .card-project__row {
    display: flex;
    align-items: center;
  }
  .card-project__lead {
    display: inline-block;
    width: 64px;
  }
  .card-project .goods-col_name {
    margin-top: 10px;
  }
  .card-project .chart-bar {
    margin: 12px 0 16px 0;
  }
  .grid-6 .card-product__contents {
    padding: 14px 10px 10px;
  }
  .grid-6 .card-product__city img {
    display: none;
  }
  .grid-6 .sts-type4,
  .grid-6 .sts-type5,
  .grid-6 .sts-type6 {
    font-size: 16px;
  }
  .grid-7 .card-product__subtitle {
    margin: 0;
  }
  .grid-7 .card-product__subtitle-inner {
    margin: 0;
  }
  .grid-7 .card-product__price {
    font-size: 14px;
  }
  .grid-7 .card-product .sts-type4,
  .grid-7 .card-product .sts-type5,
  .grid-7 .card-product .sts-type6 {
    font-size: 16px;
  }
  .grid-ranking .grid__block:nth-child(n+4) .card-product__contents {
    padding: 14px 10px 10px;
  }
  .card-city__title {
    line-height: 1.38;
    font-size: 16px;
  }
  .card-city__contents {
    padding: 20px 10px 16px;
  }
  .card-city__contents .lst-icon {
    margin-top: 8px;
  }
  .card-city__image {
    height: 166px;
  }
  .card-city__cityimg {
    position: absolute;
    top: -86px;
    right: 0;
    left: 0;
    margin: auto;
    width: 78px;
  }
  .card-city__info dl dt,
  .card-city__info dl dd {
    padding: 8px 0;
    border-bottom: solid 1px #e5e5e5;
  }
  .card-city__info dl dd {
    width: 73%;
    padding-left: 7%;
  }
  .card-article__title {
    line-height: 1.38;
    font-size: 16px;
  }
  .card-article__contents {
    padding: 20px 10px 16px;
  }
  .card-article__contents .lst-icon {
    margin-top: 8px;
  }
  .sidebar-right .card--special-list {
    margin: 0;
  }
  .sidebar-right .card--special {
    width: 100%;
    margin: 20px 0 0;
  }
  .grid-3--pc {
    justify-content: space-between;
  }
  .grid-3--pc .grid__block {
    width: calc(33.3333333333% - 13.333px);
  }
  .grid-3--pc .grid__block:not(:nth-child(-n+3)) {
    margin-top: 16px;
  }
  .grid-3--pc:after {
    content: "";
    display: block;
    width: calc(33.3333333333% - 13.333px);
  }
  .grid-4 {
    margin-right: -20px;
  }
  .grid-4 .grid__block {
    width: 253px;
    margin-right: 20px;
  }
  .grid-4 .grid__block {
    box-sizing: border-box;
    margin-top: 28px;
  }
  .grid-6 {
    margin-right: -20px;
  }
  .grid-6 .grid__block {
    width: 162px;
    margin-right: 20px;
  }
  .grid-7 {
    margin-right: -20px;
  }
  .grid-7 .grid__block {
    width: 136px;
    margin-right: 20px;
  }
  .grid-feature {
    margin-right: -20px;
  }
  .grid-feature .grid__block {
    width: 344px;
    margin-right: 20px;
  }
  .grid-ranking {
    margin-right: -20px;
  }
  .grid-ranking .grid__block {
    margin-right: 20px;
  }
  .grid-ranking .grid__block:nth-child(-n+3) {
    width: 344px;
  }
  .grid-ranking .grid__block:nth-child(n+4) {
    width: 162px;
  }
  .layout-column-2__main .grid-3 {
    margin-right: -20px;
  }
  .layout-column-2__main .grid-3 .grid__block {
    width: 252px;
    margin-right: 20px;
  }
  .layout-column-2__main .grid-3 .card-product__image {
    min-height: 153px;
  }
  .row-gap--12-24 {
    margin-bottom: -24px;
  }
  .row-gap--12-24 > .grid__block {
    margin-bottom: 24px;
  }
  .row-gap--20--28 {
    margin-bottom: -28px;
  }
  .row-gap--20--28 li {
    margin-bottom: 28px;
  }
  .contents-inner {
    width: 1072px;
    margin: 0 auto;
  }
  .section-block {
    margin-bottom: 40px;
  }
  .section-block--gray {
    padding: 40px 0;
  }
  .section-title--icon {
    font-size: 22px;
    margin-bottom: 24px;
  }
  .js-more-list__button {
    display: block;
    margin: 32px auto 0;
    width: 220px;
  }
  .column1-inner {
    width: 1072px;
  }
  .column1-inner .sld__list {
    padding: 0;
  }
  .column1-inner > .ttl-h2--icon,
  .column1-inner .goods-container_title {
    margin-left: 0;
  }
  .tab-navigation__icon {
    margin-right: 6px;
  }
  .pdSide-pc-0 {
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  .bottom-products {
    margin-top: 40px;
  }
  .bottom-products {
    border-bottom: none;
  }
  .bottom-products__watched:not(:first-child), .bottom-products__favorite:not(:first-child) {
    margin-top: 40px;
  }
  .bottom-products .sld__wrap {
    margin-top: 24px;
  }
  .bottom-products__gcf .btn-sld {
    top: 56px;
  }
  .bottom-products__favorite .btn-sld {
    top: 36px;
  }
  .bottom-products__watched .btn-sld {
    top: 36px;
  }
  .bottom-products__inner {
    width: 1072px;
    margin: 0 auto;
    padding: 40px 0;
  }
  .bottom-products .ttl-h2--icon {
    margin: 0;
  }
  .bottom-products .gcf-text {
    font-size: 18px;
  }
  .bottom-products .bottom-gcf-morelink {
    margin: 24px 0 0;
  }
  .autocomplete {
    width: 480px;
  }
  .autocomplete li:hover, .autocomplete li:focus {
    background-color: #f6f6f6;
  }
  .choice-balloon__wrap {
    padding: 37px 23px;
    cursor: default;
  }
  .choice-balloon__text {
    font-size: 14px;
  }
  .choice-balloon.choice-balloon--kifuto .choice-balloon__wrap {
    max-width: 528px;
  }
  .choice-balloon.choice-balloon--kifuto .choice-balloon__text {
    margin: 0 0 0 16px;
  }
  .choice-balloon.choice-balloon--kifuto .choice-balloon__top {
    display: flex;
    align-items: flex-start;
  }
  .choice-balloon.choice-balloon--kifuto .choice-balloon__bottom {
    padding: 24px 32px 24px 24px;
  }
  .choice-balloon.choice-balloon--kifuto .choice-balloon__bottom li + li {
    margin-top: 16px;
  }
  .choice-balloon.choice-balloon--kifuto .choice-balloon__arrow::before, .choice-balloon.choice-balloon--kifuto .choice-balloon__arrow::after {
    background-color: #fffade;
  }
  .new-badge.-minusMargin {
    margin-right: -30px;
  }
  .button {
    padding: 8px 16px 6px;
  }
  .switch-button-list__button {
    margin-left: 6px;
  }
  .button-rounded.-expanded {
    display: block;
  }
  .search-window .autocomplete.show-suggestions {
    height: auto;
    border-radius: 20px;
  }
  #search-window-old-modal .search-window__content {
    height: auto;
  }
  .search-window__content {
    width: 480px;
    position: absolute;
    top: 56px;
    border-radius: 16px;
    max-height: min(80vh, 580px);
    height: auto;
    overflow-y: auto;
  }
  .search-window__content .filter-section .filter-item-container {
    flex-direction: row;
    gap: 8px;
  }
  .search-window__content .filter-section .filter-item-container:hover {
    background-color: #e5e5e5;
  }
  .search-window__content .trending-words__wrap ul {
    width: 100%;
    gap: 20px;
  }
  .search-window__content .trending-words__wrap {
    overflow-x: hidden;
  }
  .search-window__content .trending-words__wrap .pc-list {
    display: inline-flex;
    flex-wrap: wrap;
  }
  .search-window__content .trending-words__wrap .sp-list {
    display: none;
  }
  .search-window__content .trending-words__wrap .trending-word a:hover {
    background-color: #e5e5e5;
  }
  .search-window-modal {
    border-radius: 32px;
    width: auto;
    height: auto;
    top: 76px;
    left: 50%;
    -webkit-transform: translate(-50%);
            transform: translate(-50%);
  }
  .search-window-modal#category-modal, .search-window-modal#select-child-modal, .search-window-modal#select-grandson-modal {
    width: 70%;
  }
  .search-window-modal .modal-content {
    margin-top: 0;
  }
  .search-window-modal .modal-content.category-modal-content, .search-window-modal .modal-content.select-category-content {
    height: auto;
  }
  .search-window-modal .modal-content.price-modal-content, .search-window-modal .modal-content.city-modal-content {
    height: auto;
  }
  .search-window-modal .modal-content .modal-header {
    position: static;
  }
  .search-window-modal .modal-content .modal-header .modal-back-button {
    top: 20px;
  }
  .search-window-modal .modal-content .modal-header .modal-close-button {
    top: 20px;
  }
  .search-window-modal .select-category-content .list-subcategories {
    -ms-grid-columns: 1fr 0 1fr 0 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px 0;
  }
  .search-window-modal .select-category-content .list-subcategories li:first-child {
    -ms-grid-column-span: 3;
    grid-column: span 3;
    width: 33%;
    margin-bottom: 8px;
  }
  .search-window-modal .select-category-content .list-subcategories__link:hover {
    background-color: #f6f6f6;
  }
  .search-window-modal .select-category-content .list-subcategories__link i {
    order: -1;
  }
  .search-window-modal .buttons {
    position: static;
    border: none;
  }
  .search-window-modal .buttons button {
    width: 140px !important;
  }
  #category-modal .product-category {
    padding: 40px 0;
  }
  #category-modal .product-category__title {
    font-size: 22px;
  }
  #category-modal .category-buttons-list {
    -ms-grid-columns: (minmax(60px, 1fr))[9];
    grid-template-columns: repeat(9, minmax(60px, 1fr));
  }
  #category-modal .category-buttons-list__item .category-select-trigger:hover span {
    text-decoration: underline;
  }
  #category-modal .category-buttons-list__item .category-select-trigger:hover img {
    background-color: #e5e5e5;
  }
  #price-modal .price-input-start,
  #price-modal .price-input-end {
    width: 200px;
  }
  #price-modal .error-message-start,
  #price-modal .error-message-end {
    width: 200px;
  }
  #price-modal .list-link {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 16px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 16px;
  }
  #price-modal .list-link li {
    border-radius: 36px;
    padding: 0 8px;
  }
  #price-modal .list-link li .list-link__text {
    padding: 6px 0;
  }
  #price-modal .list-link li:hover {
    background-color: #f6f6f6;
  }
  #price-modal .list-link a:hover {
    opacity: 0.85;
  }
  #price-modal .list-link a:hover .list-link__text,
  #price-modal .list-link a:hover .list-link__number {
    text-decoration: none;
    color: unset;
  }
  #price-modal .list-link .list-link__icon {
    order: -1;
    margin: 0;
  }
  #city-modal .frm-select {
    width: 180px;
  }
  #city-modal .city-selection-wrapper {
    flex-direction: row;
    gap: 20px;
  }
  .header-global.is-fixed {
    position: fixed;
  }
  .header-global.is-fixed + .info-wrap {
    margin-top: 0 !important;
    padding-top: 130px;
  }
  .header-global.is-fixed + .header-space {
    margin-top: 0 !important;
    padding-top: 120px;
  }
  .header-global.is-hide {
    -webkit-transform: translateY(-120px);
            transform: translateY(-120px);
  }
  .header-global.is-hide .header-bg.is-show {
    top: 120px;
  }
  .header-global + * {
    margin-top: 10px !important;
  }
  .header-main {
    z-index: 9000;
    overflow: visible;
  }
  .header-curve {
    bottom: -10px;
    height: 10px;
  }
  .header-inner {
    overflow: visible;
    padding: 8px 0 0;
  }
  .header-top {
    flex-wrap: nowrap;
    width: 912px;
    margin: 0 auto 6px;
    padding: 0;
  }
  .site-logo {
    margin-bottom: 0;
  }
  .search-window {
    width: 480px;
    overflow: hidden;
  }
  .search-window__input {
    padding: 0 40px;
    text-align: center;
    font-size: 18px;
  }
  .search-window__input::-webkit-input-placeholder {
    font-size: 18px;
  }
  .search-window__input:-ms-input-placeholder {
    font-size: 18px;
  }
  .search-window__input::-ms-input-placeholder {
    font-size: 18px;
  }
  .search-window__input::placeholder {
    font-size: 18px;
  }
  .button-close-autocomplete {
    display: none;
  }
  .nav-user__menu > li:nth-child(n+2) {
    margin-left: 0;
  }
  .nav-user__wrap {
    display: flex;
    align-items: center;
    padding: 0 16px;
    position: relative;
  }
  .nav-user__wrap:hover .nav-user__list {
    display: block;
  }
  .nav-user__wrap .nav-user__list {
    display: none;
    background: #ffffff;
    padding: 32px 40px;
    box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.16);
    position: absolute;
    top: 74px;
    right: 0;
    white-space: nowrap;
    z-index: 9999;
  }
  .nav-user__wrap .nav-user__list li {
    font-size: 14px;
    margin-top: 12px;
  }
  .nav-user__wrap .nav-user__list li:first-child {
    margin-top: 0;
  }
  .nav-user__wrap .nav-user__list a {
    display: block;
    background-image: url(/img/icon/title/icon_list_menu.png);
    background-repeat: no-repeat;
    background-position: left center;
    background-size: 4px;
    padding-left: 12px;
  }
  .nav-user__wrap--cart {
    padding: 0;
  }
  .nav-user__wrap--cart:hover .nav-user__list {
    display: block;
  }
  .nav-user__wrap--cart .nav-user__list {
    display: none;
    background: #ffffff;
    position: absolute;
    top: 57px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    box-sizing: border-box;
    border-radius: 16px;
    text-align: center;
    padding: 24px;
    font-size: 14px;
    width: 270px;
    white-space: nowrap;
    box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.16);
    z-index: 9999;
  }
  .nav-user__wrap--cart .nav-user__list::before {
    content: "";
    position: absolute;
    top: -6px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    display: block;
    width: 12px;
    height: 12px;
    background-color: #ffffff;
    border-radius: 50%;
    z-index: 9998;
  }
  .nav-user__link {
    width: 64px;
    padding: 8px 0;
    border-radius: 8px;
  }
  .nav-user__link:hover, .nav-user__link:focus {
    background: rgba(0, 0, 0, 0.1);
  }
  .nav-user__icon::before {
    width: 20px;
    font-size: 20px;
  }
  .nav-user__icon._search {
    top: 0;
    left: 0;
    width: 50px;
    height: 40px;
  }
  .nav-user__icon._search::before {
    position: absolute;
    top: 10px;
    left: 16px;
  }
  .nav-user__label {
    padding: 8px 0 0;
    font-size: 12px;
  }
  .nav-user__count__num {
    right: 12px;
    top: 0;
  }
  .nav-user__mypage {
    font-size: 14px;
    padding: 0 12px;
    white-space: nowrap;
  }
  .nav-user__mypage span {
    border-left: 1px solid #d3898a;
    display: inline-block;
    background-color: #d3898a;
    height: 14px;
    margin: 0 8px;
  }
  .nav-user__mypage .nav-user__mypage__logout {
    font-size: 12px;
  }
  .nav-user__mypage a {
    display: inline-block;
    position: relative;
    vertical-align: middle;
  }
  .nav-profile {
    position: relative;
  }
  .nav-profile .-mypage {
    display: flex;
    justify-content: center;
    align-items: baseline;
    font-weight: bold;
    padding: 24px 0;
  }
  .nav-profile .header-nickname {
    font-size: 20px;
    display: inline-block;
    max-width: 16em;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }
  .nav-profile .header-nickname__small {
    font-size: 11px;
    padding-left: 2px;
  }
  .nav-profile .header-nickname__small:empty {
    font-size: 0;
    padding-left: 0;
  }
  .nav-profile__wrapper {
    display: none;
    position: absolute;
    top: 57px;
    right: -80px;
    width: 408px;
    padding: 0 16px 16px;
    background-color: #fff4de;
    color: #16160e;
    border-radius: 16px;
    box-sizing: border-box;
    z-index: 9999;
  }
  .nav-profile__wrapper::before {
    content: "";
    position: absolute;
    top: -6px;
    right: 106px;
    display: block;
    width: 12px;
    height: 12px;
    background-color: #fff4de;
    border-radius: 50%;
    z-index: 9998;
    transition: all 0.24s ease-out;
  }
  .nav-profile:not(.is-logout):hover .nav-profile__wrapper {
    display: block;
  }
  .nav-profile__content {
    background-color: #ffffff;
    border-radius: 8px;
  }
  .nav-profile__top {
    display: flex;
    padding: 8px 8px 16px;
    border-bottom: 1px solid #efefef;
  }
  .nav-profile__item {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    width: 180px;
    height: 90px;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    border-radius: 4px;
    transition: all 0.3s;
  }
  .nav-profile__item:last-child {
    display: inline-flex;
    justify-content: flex-end;
  }
  .nav-profile__item:hover {
    background-color: #f6f6f6;
  }
  .nav-profile__icon {
    display: inline-flex;
    margin-bottom: 8px;
    font-size: 24px;
  }
  .nav-profile__bottom {
    display: flex;
    justify-content: space-between;
  }
  .nav-profile__link {
    width: 50%;
    padding: 16px 0;
    color: #1e50a2;
    text-align: center;
    box-sizing: border-box;
    transition: all 0.3s;
  }
  .nav-profile__link:first-child {
    border-right: 1px solid #efefef;
  }
  .nav-profile__link:hover {
    background-color: #f6f6f6;
  }
  .header-bottom {
    width: 1072px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto;
  }
  .nav-global {
    display: flex;
    align-items: center;
  }
  .nav-global__item {
    position: relative;
    display: inline-flex;
    align-items: center;
    height: 40px;
    padding: 6px 12px 6px;
    font-size: 16px;
    font-weight: bold;
    box-sizing: border-box;
    border-radius: 20px;
  }
  .nav-global__item._large {
    font-size: 18px;
    align-items: baseline;
  }
  .nav-global__item:hover, .nav-global__item:focus {
    background: rgba(0, 0, 0, 0.1);
    cursor: pointer;
  }
  .nav-list__wrapper:hover .nav-list__icon._arrow {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .nav-megamenu__top-link {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    height: 42px;
    line-height: 42px;
    transition: all 0.3s;
    cursor: pointer;
  }
  .nav-megamenu__top-link:hover {
    background-color: #16160e;
    color: #ffffff;
  }
  .nav-service-block-wrapper {
    flex-wrap: nowrap;
    flex-direction: row;
  }
  .nav-service-block {
    max-width: none;
  }
  ._search-products .nav-service-block {
    height: 80px;
  }
  ._use .nav-service-block {
    height: 100px;
  }
  .nav-service-block:hover {
    opacity: 0.85;
  }
  .nav-service-block__external-icon {
    top: 12px;
    right: 12px;
    font-size: 15px;
  }
  .-products .nav-service-block__image {
    width: 74px;
    min-width: 74px;
  }
  .-use .nav-service-block__image {
    width: 138px;
    min-width: 138px;
  }
  .nav-service-block__main-copy {
    font-size: 12px;
  }
  .nav-service-block__main-logo {
    height: 24px;
  }
  .-use .nav-service-block__main-logo {
    height: 28px;
  }
  .nav-service-block__main-title {
    font-size: 20px;
    margin-top: 6px;
  }
  .-product .nav-megamenu__inner {
    display: -ms-grid;
    display: grid;
        grid-template-areas: "body body2" "nav-service-block-wrapper body2";
    -ms-grid-columns: 1fr 320px;
    grid-template-columns: 1fr 320px;
  }
  .nav-service-block-wrapper {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body {
    grid-area: body;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body2 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body2 {
    margin: 0;
    padding-left: 32px;
    border-left: 1px solid #e5e5e5;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-title {
    margin: 0;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-price {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
    padding: 0;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-price-link {
    font-size: 16px;
  }
  .-product .nav-megamenu__inner .nav-megamenu__body2 .nav-megamenu__search-keyword {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
  }
  ._search-products:hover .nav-global__icon._arrow {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  ._search-products:hover .nav-megamenu {
    display: block;
  }
  html[data-script-enabled=true] .nav-megamenu-sp > .nav-megamenu__wrapper::before {
    content: "";
    position: absolute;
    top: -6px;
    left: 44px;
    width: 12px;
    height: 12px;
    background-color: #ffffff;
    border-radius: 50%;
    visibility: hidden;
    opacity: 0;
    -webkit-transform: translateY(6px);
            transform: translateY(6px);
    transition: all 0.16s ease-out 0.16s;
  }
  ._use:hover .nav-global__icon._arrow {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  ._use .nav-megamenu__body {
    padding: 32px;
  }
  .navigation-use-list__item {
    width: 25%;
  }
  .navigation-use-list__item .lst-navi2__link {
    padding: 4px 8px 4px 28px;
  }
  .navigation-use-list__item .lst-navi2__link:hover {
    border-radius: 16px;
    text-decoration: none;
    background-color: #f6f6f6;
  }
  .navigation-use-list__item .nav-guide__icon {
    left: 12px;
  }
  .nav-guide {
    width: 358px;
    height: auto;
    top: 40px;
    right: 0;
    border-radius: 32px;
    overflow: hidden;
    padding: 12px 0;
    background: #ffffff;
    box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.16);
  }
  .nav-guide__list {
    height: auto;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
  }
  .nav-guide__link {
    justify-content: flex-start;
    flex-direction: row;
  }
  .nav-guide__link:hover {
    background-color: #f6f6f6;
  }
  .nav-guide__icon {
    margin-right: 8px;
  }
  .info-wrap {
    padding: 4px 0 0;
  }
  .bx-info {
    width: 1072px;
    margin: 0 auto;
  }
  .bx-info__icon {
    display: block;
    min-width: 85px;
    box-sizing: border-box;
    white-space: nowrap;
    font-size: 12px;
    padding: 0 4px;
  }
  .bx-info__text {
    overflow: hidden;
  }
  .spMenu {
    display: none;
  }
  .pagetop {
    display: none;
  }
  .footer-global {
    padding: 0;
  }
  .footer-button {
    width: 172px;
    height: 38px;
    line-height: 38px;
    transition: all 0.3s;
    cursor: pointer;
  }
  .footer-button:hover {
    background-color: #16160e;
    color: #ffffff;
  }
  .footer-nav {
    padding: 0 0 64px;
  }
  .footer-nav__wrapper {
    position: static;
    display: flex;
    width: 1072px;
    padding: 0;
    background-color: #ffffff;
  }
  .footer-nav__contents {
    flex: 1;
    position: relative;
    padding: 32px 0 40px;
    background-color: #f6f6f6;
    border-radius: 16px;
    box-sizing: border-box;
  }
  .footer-nav__contents:not(:last-child) {
    margin-right: 24px;
    margin-bottom: 0;
  }
  .footer-nav__icon {
    position: absolute;
    top: -16px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .footer-achievement__img {
    max-width: 167px;
  }
  .footer-achievement__img:not(:last-child) {
    margin-right: 16px;
  }
  .footer-achievement__img p {
    font-size: 15px;
  }
  .footer-achievement__note li:not(:first-child) {
    margin-left: 12px;
  }
  .footer-about-choice-concept {
    width: 976px;
    position: relative;
    margin: 0 auto 64px;
  }
  .footer-about-choice-concept .text {
    position: absolute;
    top: 174px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 520px;
  }
  .footer-about-choice-concept .link-btn {
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 296px;
    height: 37px;
    line-height: 37px;
    transition: all 0.3s;
  }
  .footer-service__list {
    justify-content: center;
    flex-direction: row;
  }
  .footer-service__item:not(:last-child) {
    margin-right: 40px;
    margin-bottom: 0;
  }
  .footer-service__link {
    position: relative;
  }
  .footer-service__link:hover {
    text-decoration: underline;
  }
  .footer-info__curve {
    border-radius: 50% 50% 0% 0%/8% 8% 0% 0%;
  }
  .footer-info__wrapper {
    padding: 52px 0 40px;
  }
  .footer-info__top {
    justify-content: space-between;
    flex-direction: row;
    width: 568px;
    margin: 0 auto 64px;
  }
  .footer-info__img {
    margin-bottom: 0;
  }
  .footer-info__txt {
    width: 276px;
  }
  .footer-info__txt p {
    line-height: 1.6;
  }
  .footer-info__logo {
    width: 250px;
  }
  .footer-info__link {
    position: relative;
  }
  .footer-info__privacy {
    margin-left: 16px;
  }
  [data-modal-id=guide] .modal-component--new__x,
  [data-modal-id=opinion] .modal-component--new__x {
    top: 22px;
  }
  [data-modal-id=guide] .modal-component--new__main {
    padding: 73px 0 40px;
  }
  [data-modal-id=guide] .modal-component--new__header {
    height: 61px;
  }
  [data-modal-id=guide] .footer-guide__link {
    justify-content: flex-start;
    flex-direction: row;
  }
  [data-modal-id=guide] .footer-guide__link:hover {
    background-color: #f6f6f6;
  }
  [data-modal-id=guide] .footer-guide__arrow {
    margin-right: 8px;
  }
  [data-modal-id=opinion] .modal-component--new__body {
    min-height: 382px;
  }
  [data-modal-id=opinion] .goiken-form__desc p:first-child {
    margin-bottom: 4px;
  }
  [data-modal-id=opinion] .goiken-form__content.-top {
    padding: 0 0 24px;
  }
  [data-modal-id=opinion] .goiken-form__content.-bottom {
    padding: 24px 0;
  }
  [data-modal-id=opinion] .goiken-form__button.-submit, [data-modal-id=opinion] .goiken-form__button.-close {
    width: 104px;
  }
  [data-modal-id=opinion] .goiken-form__button.-faq {
    width: 166px;
  }
  .footer-account {
    margin-top: 120px;
  }
  .footer-single-sign {
    width: 796px;
  }
  .footer-single-sign__inner {
    display: flex;
  }
  .footer-single-sign__inner span:first-of-type {
    margin: 0;
  }
  .footer-single-sign__text {
    margin: 0 0 0 24px;
  }
  .footer-single__policy {
    padding: 0;
  }
  .modal-component--new.-header-fixed .modal-component--new__header-buffer {
    height: 68px;
  }
  .modal-component--new.-footer-fixed .modal-component--new__footer-buffer {
    height: 96px;
  }
  .modal-component--new.-footer-fixed .modal-component--new__footer {
    padding-top: 24px;
  }
  .modal-component--new__body {
    width: auto;
  }
  .modal-component--new__body.-size-s {
    width: 410px;
  }
  .modal-component--new__body.-size-m {
    width: 660px;
  }
  .modal-component--new__body.-size-l {
    width: 964px;
  }
  .modal-component--new__header {
    padding: 18px 24px;
  }
  .modal-component--new__main {
    padding: 24px;
  }
  .modal-component--new__footer {
    padding: 0 24px 24px;
  }
  .modal-component--new[data-modal-id=ex-link] .modal-component--new__x,
  .modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__x {
    top: 22px;
  }
  .modal-component--new[data-modal-id=ex-link] .modal-component--new__body.-size-s,
  .modal-component--new[data-modal-id=ex-link-meibutsu] .modal-component--new__body.-size-s {
    width: 480px;
  }
  .modal-component--new[data-modal-id=ex-link] .modal-ex-link__link,
  .modal-component--new[data-modal-id=ex-link-meibutsu] .modal-ex-link__link {
    width: 200px;
  }
  .layout-column-2 {
    display: flex;
    flex-direction: row-reverse;
    margin: 0 auto;
    width: 1072px;
  }
  .layout-column-2__main {
    width: 796px;
  }
  .layout-column-2__left {
    width: 244px;
    margin-right: auto;
  }
  .block-accordion--sp .block-accordion__title .mf-arrow01-down {
    display: none;
  }
  .block-accordion--pc .block-accordion__title {
    cursor: pointer;
  }
  .block-accordion--pc .block-accordion__box {
    display: none;
  }
  .footer-donation-navi h2::before, .footer-donation-navi h2::after {
    width: 27px;
    height: 43px;
  }
  .footer-donation-navi h2::after {
    right: calc(50% - 195px);
  }
  .footer-donation-navi h2::before {
    left: calc(50% - 195px);
  }
  .footer-donation-navi .-grid-layout {
    display: -ms-grid;
    display: grid;
    -ms-grid-rows: auto;
    -ms-grid-columns: 1fr 20px 1fr 20px 1fr 20px 1fr;
        grid-template: "menu-1 menu-2 menu-3 menu-4"/1fr 1fr 1fr 1fr;
    grid-gap: 20px;
  }
  .footer-donation-navi .donation-navi__menu:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .footer-donation-navi .donation-navi__menu:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .footer-donation-navi .donation-navi__menu:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 5;
  }
}
@media only screen and (max-width: 599px) and (max-device-width: 599px) {
  .nav-global {
    position: relative;
    padding: 0;
  }
  .nav-global::after {
    content: "";
    position: absolute;
    top: -7px;
    right: 0;
    display: block;
    width: 48px;
    height: 46px;
    background-image: url(/assets/images/choice/bg_gradation_red.png);
    background-size: 48px 46px;
    background-repeat: no-repeat;
    z-index: 99;
  }
  .nav-service-block__main-copy {
    font-size: 3.4vw;
  }
  .nav-service-block__main-title {
    margin-top: 1.4vw;
  }
}
@media only screen and (min-device-width: 600px) {
  .nav-global__list li:last-child {
    padding-right: 0;
  }
  .nav-arrow {
    display: none;
  }
  .system_error {
    padding: 12px 0;
    text-align: center;
  }
  .saigai_support,
  .saigai_support_emergency {
    padding: 12px 0;
    text-align: center;
  }
  html[data-script-enabled=true] .spMenu .spMenu-body.spMenu-body_sublist {
    left: 380px;
  }
  .footer-achievement__note {
    align-items: center;
  }
}
@media only screen and (max-device-width: 320px) {
  html[data-script-enabled=true] .spMenu .spMenu-body.spMenu-body_sublist {
    left: calc(100vw - 46px);
  }
  .account-info .header-nickname {
    max-width: 10em;
  }
}
@media screen and (min-width: 768px) {
  .modal-component--new__button-wrap {
    flex-wrap: wrap;
    width: auto;
  }
  .modal-component--new__button-wrap.-type-vertical {
    flex-direction: row;
  }
  .modal-component--new__button-wrap.-type-vertical .modal-component--new__button {
    width: auto;
  }
  .modal-component--new__button-wrap.-type-vertical.-type-select {
    flex-direction: row;
  }
  .modal-component--new__button-wrap .modal-component--new__button {
    flex-grow: 0;
    flex-basis: auto;
    min-width: 152px;
  }
}