@charset "UTF-8";
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
var,
button,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  outline: 0;
  border: 0;
  background-color: transparent;
  vertical-align: baseline;
  font-size: 100%;
}

article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary {
  display: block;
}

figure {
  line-height: 1;
}

figcaption {
  color: #666;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  outline: none;
  border: 0;
  background-color: transparent;
  vertical-align: baseline;
  font-size: 100%;
}

p {
  margin-bottom: 1em;
}

ul {
  list-style: none;
}

ol {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
}

address {
  font-style: normal;
}

hr {
  height: 0;
  margin: 20px;
  padding: 0;
  border: 0;
  border-top: 1px solid #b7b7b7;
}

hr.print {
  margin-bottom: 0;
  padding-top: 0;
  border-top: none;
}

.disp-sp-br {
  display: none;
}

@media screen and (min-width: 768px) {
  hr.pc-none {
    display: none;
  }

  .sp-br-none {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  br.none {
    display: none;
  }
  .disp-sp-br {
    display: inline;
  }
}

::selection {
  background: #b5b6b6;
  color: #fff;
}

::-moz-selection {
  background: #b5b6b6;
  color: #fff;
}

body {
  background: #b5b6b6;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-size: #333;
  letter-spacing: 1.5px;
  font-feature-settings: "palt" 1;
  font-kerning: auto;
  line-height: 1.75;
  -webkit-text-size-adjust: 100%;
}

html {
  box-sizing: border-box;
  overflow-y: scroll;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

* html body {
  font-family: "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  background: url(null) fixed;
}

* {
  -webkit-appearance: none;
  border-radius: 0;
}

a {
  color: #333;
}

a:link {
  color: #333;
  text-decoration: underline;
}

a:hover {
  color: #b5b6b6;
  text-decoration: none;
}

a img:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
}

.clearfix,
.l-header-inner {
  *zoom: 1;
}

.clearfix:after,
.l-header-inner:after {
  display: block;
  visibility: hidden;
  clear: both;
  height: 0;
  content: ".";
}

header {
  width: 100%;
}

.l-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 70px;
  background: #fff;
  font-size: 12px;
  font-size: 0.75rem;
  border-bottom: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 100;
}

.l-header a {
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  .l-header {
    font-size: 10px;
    font-size: 0.625rem;
    height: 70px;
  }
}

.l-header-inner {
  margin: 0 auto;
  padding: 17px 15px 0 65px;
  max-width: 1280px;
}

.header-logo {
  float: left;
  margin-top: 10px;
  width: 184px;
  line-height: 0;
}

.header-logo img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .l-header-inner {
    padding: 20px 20px 0;
  }
  .header-logo {
    width: 165px;
    margin-top: 8px;
  }
}

.header-global-nav {
  float: right;
  width: auto;
}

.header-global-nav li {
  position: relative;
  display: inline-block;
  margin-right: 25px;
  padding-top: 31px;
  line-height: 0;
}

.header-global-nav li:last-child {
  cursor: pointer;
  margin-right: 0;
}

.header-global-nav .icon-login:before {
  z-index: 1;
  position: absolute;
  left: 15px;
  top: 10px;
  content: "\f296";
  font-family: "IonIcons";
  font-size: 28px;
  -webkit-transform: rotate(-125deg);
  -moz-transform: rotate(-125deg);
  -ms-transform: rotate(-125deg);
  -o-transform: rotate(-125deg);
  transform: rotate(-125deg);
}

.header-global-nav .icon-cart:before {
  z-index: 1;
  position: absolute;
  left: 5px;
  top: 10px;
  content: "\f3f7";
  font-family: "IonIcons";
  font-size: 28px;
}

.header-global-nav .icon-menu:before {
  z-index: 1;
  position: absolute;
  left: 9px;
  top: 10px;
  content: "\f394";
  font-family: "IonIcons";
  font-size: 28px;
}

.header-global-nav .icon-menu:hover {
  color: #b5b6b6;
}

@media screen and (max-width: 768px) {
  .header-global-nav li {
    margin-right: 10px;
    padding-top: 30px;
  }

  .header-global-nav li:last-child {
    margin-right: 0;
  }
  .header-global-nav .icon-login:before,
  .header-global-nav .icon-cart:before,
  .header-global-nav .icon-menu:before {
    font-size: 23px;
  }
  .header-global-nav .icon-menu:before {
    top: 11px;
  }
}

.l-menu {
  display: none;
  position: absolute;
  width: 100%;
  height: 100%;
  background: #f3f3f3;
  color: #000;
  z-index: 999;
}

.l-menu a {
  color: #000;
  text-decoration: none;
}

.l-menu-inner {
  overflow: auto;
  position: relative;
  margin: 0 auto;
  padding: 70px 20px 30px 70px;
  max-width: 1000px;
  height: 100%;
  -webkit-overflow-scrolling: touch;
}

@media screen and (max-width: 768px) {
  .l-menu-inner {
    padding: 35px 25px 35px;
  }
}

.icon-menu-close {
  position: absolute;
  right: 23px;
  top: -5px;
  font-size: 40px;
  cursor: pointer;
  color: #000;
}

.icon-menu-close:hover {
  color: #b5b6b6;
}

@media screen and (max-width: 768px) {
  .icon-menu-close {
    right: 27px;
    top: 5px;
    font-size: 30px;
  }
}

.menu-1st-list {
  margin-bottom: 35px;
  width: 70%;
}

.menu-1st-list li {
  border-bottom: 1px solid #c1c1c1;
}

.menu-1st-list li a {
  display: block;
  padding: 9px 0;
  font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 20px;
  font-size: 1.25rem;
}

.menu-1st-list li a span {
  display: inline-block;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  padding-left: 10px;
  font-size: 10px;
  font-size: 0.625rem;
}

@media screen and (max-width: 768px) {
  .menu-1st-list {
    width: 100%;
    margin-top: 10px;
  }
  .menu-1st-list li a {
    padding: 7px 0;
    font-size: 18px;
    font-size: 1.2rem;
  }
}

.menu-2st-list {
  margin-bottom: 40px;
}

.menu-2st-list li {
  display: block;
  margin-right: 45px;
  padding: 8px 0;
  font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 16px;
  font-size: 1rem;
}

.menu-2st-list li a span {
  display: inline-block;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  padding-left: 10px;
  font-size: 10px;
  font-size: 0.625rem;
}

@media screen and (max-width: 768px) {
  .menu-2st-list {
    margin-bottom: 30px;
  }
  .menu-2st-list li {
    display: block;
    margin-right: 0;
    font-size: 14px;
    font-size: 1rem;
  }
  .menu-2st-list li a {
    display: block;
    padding: 0px 0;
  }
}

.menu-sns-list {
  margin-bottom: 20px;
}

.menu-sns-list li {
  display: inline-block;
  margin-right: 45px;
  font-size: 24px;
}

@media screen and (max-width: 768px) {
  .menu-sns-list li {
    margin-right: 25px;
  }
}

.menu-copyright {
  display: block;
  font-size: 12px;
  font-size: 0.75rem;
}

@media screen and (max-width: 768px) {
  .menu-copyright {
    font-size: 10px;
    font-size: 0.625rem;
  }
}

.width-normal .l-header,
.width-small .l-header {
  border-bottom: 0;
}

.l-contents {
  padding: 70px 0 60px;
  width: 100%;
  background: #fff;
}

.l-contents .lv01 {
  margin: 0 auto;
  padding: 25px 20px;
  max-width: 1000px;
  line-height: 0;
}

.l-contents .lv01 b {
  display: inline-block;
  max-width: 560px;
}

.l-contents .lv01 img {
  width: 100%;
}

.l-contents .lv02 {
  margin-bottom: 30px;
  font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: normal;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .l-contents {
    padding: 70px 0;
  }
  .l-contents .lv01 {
    padding-bottom: 10px;
  }
  .l-contents .lv02 {
    font-size: 18px;
    font-size: 1.125rem;
    margin-bottom: 10px;
  }
}

.section {
  margin: 0 auto;
  padding: 0 20px;
  max-width: 1000px;
}

.width-normal .l-contents,
.width-small .l-contents {
  padding-top: 93px;
}

.width-normal .lv02,
.width-small .lv02 {
  margin: 0 auto 30px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.width-normal .lv02 span,
.width-small .lv02 span {
  display: block;
  font-size: 16px;
  font-size: 1rem;
}

@media screen and (max-width: 768px) {
  .width-normal .l-contents,
  .width-small .l-contents {
    padding-top: 73px;
  }
  .width-normal .lv02,
  .width-small .lv02 {
    margin-bottom: 20px;
  }
  .width-normal .lv02 span,
  .width-small .lv02 span {
    display: block;
    font-size: 14px;
    font-size: 0.875rem;
  }
}

.width-small .section {
  max-width: 808px;
}

footer {
  width: 100%;
}

.l-footer {
  background: #b5b6b6;
  font-size: 12px;
  font-size: 0.75rem;
  color: #fff;
}

.l-footer a {
  color: #fff;
  text-decoration: none;
}

.l-footer-inner {
  margin: 0 auto;
  padding: 40px 15px;
  max-width: 1030px;
}

@media screen and (max-width: 768px) {
  .l-footer-inner {
    padding: 55px 15px;
  }
}

.footer-sns-list,
.footer-nav-list,
.footer-logo-list {
  display: block;
  margin-bottom: 30px;
  text-align: center;
}

.footer-sns-list a:hover,
.footer-nav-list a:hover,
.footer-logo-list a:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
}

.footer-sns-list {
  padding: 0 5px;
}

.footer-sns-list li {
  display: inline-block;
  padding: 0 15px;
  font-size: 28px;
  line-height: 0;
}

@media screen and (max-width: 768px) {
  .footer-sns-list li {
    font-size: 20px;
  }
}

.footer-nav-list {
  padding: 0 5px;
}

.footer-nav-list ul:first-child {
  margin-bottom: 15px;
}

.footer-nav-list li {
  display: inline-block;
  margin-right: 10px;
}

.footer-nav-list li:last-child {
  margin-right: 0;
}

@media screen and (max-width: 768px) {
  .footer-nav-list {
    display: flex;
    justify-content: space-between;
    width: 90%;
    margin: 0 auto 30px;
  }
  .footer-nav-list ul {
    width: 50%;
  }
  .footer-nav-list ul:first-child {
    margin-bottom: 0px;
  }
  .footer-nav-list li {
    margin-right: 0;
    margin-left: 5%;
    width: 100%;
    text-align: left;
  }
  .footer-nav-list li a {
    display: block;
    padding: 5px 0;
  }
}

.footer-logo-list {
  margin-bottom: 35px;
}

.footer-logo-list li {
  display: inline-block;
  margin-right: 20px;
  width: 156px;
  line-height: 1;
}

.footer-logo-list li img {
  border: 1px solid #fff;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.footer-logo-list li:last-child {
  margin-right: 0;
}

.footer-logo-list li:last-child img {
  border: none;
}

.footer-logo-list li img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .footer-logo-list {
    overflow: hidden;
  }
  .footer-logo-list ul {
    margin: -5px 0 0 -5px;
  }
  .footer-logo-list li {
    margin: 0;
    padding: 5px 5px 5px;
    width: 48%;
    text-align: left;
  }
}

.footer-copyright {
  margin-bottom: 0;
  display: block;
  text-align: center;
  line-height: 0;
}

@media screen and (max-width: 768px) {
  .footer-copyright {
    font-size: 10px;
    font-size: 0.625rem;
  }
}

/* Content
----------------------------------------------- */
.left {
  text-align: left;
}

.center {
  text-align: center;
}

.right {
  text-align: right;
}

.border {
  border: 1px solid #ccc;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.important {
  color: #ea6136;
}

.important a {
  color: #ea6136;
}

.important a:link {
  color: #ea6136;
}

.important a:hover {
  color: #f29d83;
}

.disc {
  list-style-type: disc;
  margin-left: 1.5em;
}

@media screen and (min-width: 769px) {
  .pc-none {
    display: none;
  }
}

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

.two-columm,
.three-columm,
.four-columm,
.five-columm,
.six-columm {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  text-align: center;
  justify-content: left;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -40px;
}

.two-columm li,
.three-columm li,
.four-columm li,
.five-columm li,
.six-columm li {
  margin-top: 40px;
  padding: 0 20px;
}

.two-columm li img,
.three-columm li img,
.four-columm li img,
.five-columm li img,
.six-columm li img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .two-columm,
  .three-columm,
  .four-columm,
  .five-columm,
  .six-columm {
    margin-top: -20px;
    text-align: left;
    justify-content: left;
  }
  .two-columm li,
  .three-columm li,
  .four-columm li,
  .five-columm li,
  .six-columm li {
    margin-top: 20px;
    padding: 0 10px;
  }
}

.two-columm li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 50%;
  flex-basis: 50%;
  max-width: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .two-columm li {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
}

.three-columm li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 33.3%;
  flex-basis: 33.3%;
  max-width: 33.3%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .three-columm li {
    -webkit-flex-basis: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }
}

.four-columm li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 25%;
  flex-basis: 25%;
  max-width: 25%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .four-columm li {
    -webkit-flex-basis: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }
}

.five-columm li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 20%;
  flex-basis: 20%;
  max-width: 20%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .five-columm li {
    -webkit-flex-basis: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }
}

.six-columm li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 16.6%;
  flex-basis: 16.6%;
  max-width: 16.6%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .six-columm li {
    -webkit-flex-basis: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }
}

select::-ms-expand {
  display: none;
}

.select {
  position: relative;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.select:before {
  z-index: 1;
  position: absolute;
  right: 10px;
  bottom: 0;
  -webkit-transform: translateY(-8px);
  transform: translateY(-8px);
  content: "\f123";
  font-family: "IonIcons";
  pointer-events: none;
  color: #b7b7b7;
}

/* 2019.03.31 前田 */
/* .select:before {
  z-index: 1;
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f123";
  font-family: "IonIcons";
  pointer-events: none;
  color: #b7b7b7;
} */

select {
  display: block;
  outline: none;
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: "";
  background: #fff;
  vertical-align: middle;
  font-size: inherit;
  color: inherit;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 10px;
  border: 1px solid #b7b7b7;
  width: 100%;
  font-size: 12px;
  font-size: 0.75rem;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

input[type="text"] {
  padding: 10px;
  font-size: 12px;
  font-size: 0.75rem;
  border: 1px solid #b7b7b7;
  width: 100%;
}

input[type="password"] {
  padding: 10px;
  font-size: 12px;
  font-size: 0.75rem;
  border: 1px solid #b7b7b7;
  width: 100%;
}

.submit,
input[type="submit"],
input[type="button"] {
  padding: 10px;
  background: #b7b7b7;
  width: 100%;
  font-size: 14px;
  font-size: 0.875rem;
  color: #fff;
  text-align: center;
  border: none;
  cursor: pointer;
}

.postbtn {
  padding: 12px !important;
}

/* Firefoxハック */
@-moz-document url-prefix() {
  .postbtn {
    padding: 13px !important;
  }
}

.submit:hover,
input[type="submit"]:hover,
input[type="button"]:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
}

.arrow-list {
  margin-bottom: 1em;
}

.arrow-list a {
  position: relative;
  display: inline-block;
  padding-right: 20px;
  text-decoration: none;
  cursor: pointer;
}

.arrow-list a:before {
  z-index: 1;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f125";
  font-family: "IonIcons";
  color: #b7b7b7;
}

.arrow-list .important a:before {
  color: #f29d83;
}

.button-list {
  overflow: hidden;
  padding: 0 20px;
}

.button-list ul {
  display: -webkit-flex;
  display: flex;
  text-align: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  align-items: stretch;
  margin-top: -20px;
}

.button-list li {
  margin-top: 20px;
  padding: 0 20px;
}

.button-list li a {
  display: block;
  padding: 10px 20px;
  text-decoration: none;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.button-list .button01 a {
  background: #b7b7b7;
  color: #fff;
}

.button-list .button01 a:hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
}

@media screen and (max-width: 768px) {
  .button-list {
    padding: 0;
  }
  .button-list li a {
    padding: 7px 10px;
  }
}

.js-modal {
  position: fixed;
  display: block;
  display: flex;
  justify-content: center;
  align-items: center;
  top: -200%;
  opacity: 0;
  transition: top 0s 0.3s, opacity 0.3s;
  -webkit-tap-highlight-color: transparent;
}

.js-modal.is-show {
  top: 0;
  opacity: 1;
  transition: top 0s, opacity 0.3s;
}

.js-modal > * {
  margin: 0;
}

.modal {
  display: none;
  position: absolute;
  left: 0;
  top: 0;
  padding: 20px;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  z-index: 999;
}

@media screen and (max-width: 768px) {
  .modal {
    padding: 20px;
  }
}

.modal-inner {
  overflow: auto;
  position: relative;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  margin: 0 auto;
  padding: 60px 20px 25px;
  background: #fff;
  max-width: 768px;
  -webkit-overflow-scrolling: touch;
}

@media screen and (max-width: 768px) {
  .modal-inner {
    padding: 40px 20px 1px;
  }
}

.icon-modal-close {
  position: absolute;
  right: 20px;
  top: 20px;
  font-size: 20px;
  color: #b7b7b7;
  line-height: 0;
  cursor: pointer;
}

.icon-modal-close:hover {
  color: #b5b6b6;
}

.calendar {
  position: relative;
}

.calendar-head {
  margin: 0 auto 10px;
  max-width: 320px;
  border-bottom: 1px solid #b7b7b7;
}

.calendar-head ul {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}

.calendar-head li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 33.3%;
  flex-basis: 33.3%;
  max-width: 33.3%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  text-align: center;
}

.calendar-head .calendar-prev a,
.calendar-head .calendar-next a {
  display: inline-block;
  width: 23px;
  height: 23px;
  background: #f5f5f5;
  color: #b7b7b7;
  text-decoration: none;
}

.calendar-month {
  font-size: 20px;
  font-size: 1.25rem;
}

.calendar-title {
  display: block;
  margin: 0;
  font-size: 12px;
  font-size: 0.75rem;
  text-align: center;
}

.calendar-body {
  display: none;
  margin: 0 auto;
  max-width: 320px;
}

.calendar-body.is-current {
  display: block;
}

.calendar-body table {
  margin: 0 auto 30px;
  width: 100%;
  border-spacing: 0;
  border-collapse: separate;
}

.calendar-body th,
.calendar-body td {
  padding: 3px 0;
  background: #fff;
  text-align: center;
}

.calendar-body th {
  width: 14.3%;
  padding: 3px 0;
  font-weight: normal;
}

.calendar-body th:last-child {
  color: #ce2727;
}

.calendar-body td {
  width: 14.3%;
  vertical-align: top;
}

.calendar-body td:last-child,
.calendar-body td.calendar-holiday {
  color: #ce2727;
}

.calendar-body i {
  display: block;
  padding: 0 3px;
  font-style: normal;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .calendar-body table {
    margin-bottom: 20px;
  }
}

.calendar-annotation-list {
  margin-bottom: 1em;
  padding: 0 80px;
}

@media screen and (max-width: 768px) {
  .calendar-annotation-list {
    padding: 0;
  }
}

.calendar-next,
.calendar-prev {
  transition: opacity 0.3s;
}

.calendar-next.is-disabled,
.calendar-prev.is-disabled {
  opacity: 0.2;
  cursor: default;
}

.calendar-next.is-disabled a,
.calendar-prev.is-disabled a {
  cursor: default;
}

.width-small .submit,
.width-small input[type="text"],
.width-small select {
  padding: 8px;
  font-size: 16px;
  font-size: 1rem;
  border: none;
}

@media screen and (max-width: 768px) {
  .width-small .submit,
  .width-small input[type="text"],
  .width-small select {
    padding: 10px;
    font-size: 14px;
    font-size: 0.875rem;
  }
}

/* top
----------------------------------------------- */
.main-visual {
  margin-bottom: 60px;
  width: 100%;
}

.main-visual .js-slider-contents {
  margin: 0 auto;
}

.main-visual .js-slider-contents li {
  width: 100%;
  line-height: 0;
}

.main-visual img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .main-visual ul {
    max-width: 1280px;
  }
}

@media screen and (max-width: 768px) {
  .main-visual {
    margin-bottom: 20px;
  }
  .main-visual ul {
    max-width: 100%;
  }
}

.appeal {
  margin-bottom: 50px;
  width: 100%;
}

.appeal .section {
  padding: 0;
}

@media screen and (max-width: 768px) {
  .appeal {
    margin-bottom: 0;
  }
  .appeal .section {
    padding: 0 10px;
  }
}

.appeal-list {
  margin: 0 auto;
  max-width: 1000px;
}

.appeal-list li {
  line-height: 0;
}

.appeal-list li img {
  width: 100%;
}

.top-products {
  margin-bottom: 50px;
  width: 100%;
}

.top-products .section {
  padding: 0;
}

@media screen and (max-width: 768px) {
  .top-products {
    margin-bottom: 40px;
  }
  .top-products .section {
    padding: 0 10px;
  }
}

.top-products-list {
  overflow: hidden;
}

.news-banner {
  width: 100%;
}

.news-banner-inner {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.news {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 100%;
  flex-basis: 100%;
  max-width: 100%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-right: 0px;
}

.news-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.news .lv02 {
  margin-bottom: 0;
  text-align: left;
}

.news a {
  position: relative;
  display: block;
  padding: 15px 20px 15px 0;
  text-decoration: none;
}

.news-list a:before {
  z-index: 1;
  position: absolute;
  right: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f125";
  font-family: "IonIcons";
  color: #b7b7b7;
}

@media screen and (max-width: 768px) {
  .news-title {
    justify-content: center;
  }
  .news {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding-right: 0;
  }
  .news .lv02 {
    text-align: center;
  }
  .news a {
    padding: 5px 20px 5px 0;
  }
  .news-list a:before {
    right: 0;
  }
  .news-title .news-archive {
    display: none;
  }
}

.news-list {
  border-bottom: 1px solid #b7b7b7;
}

.news-list li {
  border-top: 1px solid #b7b7b7;
}

.news-list li .news-day {
  margin-right: 10px;
}

@media screen and (max-width: 768px) {
  .news-list {
    margin-top: 10px;
  }
  .news-list .news-day {
    display: block;
    margin-right: 0;
    font-size: 12px;
    font-size: 0.75rem;
  }
}

.news-archive {
  margin-bottom: 0;
  text-align: right;
}

.news-archive a {
  color: #7e7b7a;
  padding: 0;
}

@media screen and (max-width: 768px) {
  .news-archive {
    font-size: 14px !important;
    font-size: 0.75rem;
    margin-top: 10px;
  }
}

.banner {
  padding-top: 40px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 380px;
  flex-basis: 380px;
  max-width: 380px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .banner {
    padding-top: 20px;
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
}

.banner-list {
  overflow: hidden;
}

.banner-list ul {
  margin-top: -25px;
}

.banner-list li {
  margin-top: 25px;
  font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
}

.banner-list li a {
  display: -webkit-flex;
  display: flex;
  text-align: left;
  -webkit-justify-content: left;
  justify-content: left;
  -webkit-align-items: center;
  align-items: center;
  position: relative;
  color: #fff;
}

.banner-list li span {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  padding-right: 15px;
  font-size: 24px;
  font-size: 1.5rem;
}

.banner-list li span:before {
  z-index: 1;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f125";
  font-family: "IonIcons";
  font-size: 14px;
}

.banner-list li img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .banner-list li span {
    padding-right: 15px;
    font-size: 18px;
    font-size: 1.125rem;
  }
}

/* cart
----------------------------------------------- */
.shopping-summary {
  margin: 0 auto 30px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.shopping-summary span {
  display: block;
  font-size: 16px;
  font-size: 1rem;
}

@media screen and (max-width: 768px) {
  .shopping-summary {
    margin-bottom: 20px;
  }
  .shopping-summary span {
    display: block;
    font-size: 14px;
    font-size: 0.875rem;
  }
}

.cart-list {
  margin-bottom: 50px;
}

@media screen and (max-width: 768px) {
  .cart-list {
    margin-bottom: 30px;
  }
}

.cart-list-item {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  padding: 20px 10px;
  border-top: 1px solid #b7b7b7;
}

.cart-list-item dl {
  padding: 0 10px;
}

.cart-list-item dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 160px;
  flex-basis: 160px;
  max-width: 160px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.cart-list-item dt img {
  width: 100%;
}

.cart-list-item dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 160px);
  flex-basis: calc(100% - 160px);
  max-width: calc(100% - 160px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 10px;
}

.cart-list-item h2 {
  margin-bottom: 1em;
}

.cart-list-item p {
  margin-bottom: 0;
}

.cart-list-item a {
  text-decoration: none;
}

.cart-list-item .ion-close,
.cart-list-item .ion-plus-round,
.cart-list-item .ion-minus {
  display: inline-block;
  width: 19px;
  height: 19px;
  background: #fff;
  font-size: 12px;
  color: #b7b7b7;
  text-align: center;
  letter-spacing: 0;
  line-height: 1.5;
  border: 1px solid #b7b7b7;
}

@media screen and (max-width: 768px) {
  .cart-list-item {
    align-items: start;
    padding: 20px 0;
  }
  .cart-list-item dl,
  .cart-list-item .img {
    padding: 0;
  }
  .cart-list-item dt {
    -webkit-flex-basis: 110px;
    flex-basis: 110px;
    max-width: 110px;
  }
  .cart-list-item dd {
    flex-grow: 0;
    flex-shrink: 1;
    -webkit-flex-basis: calc(100% - 110px);
    flex-basis: calc(100% - 110px);
    max-width: calc(100% - 110px);
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
    padding-left: 5px;
  }
  .cart-list-item .ion-plus-round,
  .cart-list-item .ion-minus {
    width: 24px;
    height: 24px;
    background: #fff;
    line-height: 1.75;
  }
}

.cart-list-item-inner {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .cart-list-item-inner {
    align-items: start;
  }
}

.cart-delete {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 60px;
  flex-basis: 60px;
  max-width: 60px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
  text-align: center;
}

.cart-delete span {
  display: block;
}

.cart-delete a {
  color: #b7b7b7;
}

@media screen and (max-width: 768px) {
  .cart-delete {
    -webkit-flex-basis: 50px;
    flex-basis: 50px;
    max-width: 50px;
    padding-left: 0;
  }
}

.cart-img {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 100px;
  flex-basis: 100px;
  max-width: 100px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 0;
}

.cart-img img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .cart-img {
    -webkit-flex-basis: 60px;
    flex-basis: 60px;
    max-width: 60px;
  }
}

.cart-description {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 28%;
  flex-basis: 28%;
  max-width: 28%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
}

@media screen and (max-width: 768px) {
  .cart-description {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0 0 0 5px;
  }
}

.cart-price {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 22%;
  flex-basis: 22%;
  max-width: 22%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
  text-align: right;
}

@media screen and (max-width: 768px) {
  .cart-price {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0 0 0 5px;
    text-align: left;
  }
}

.cart-quantity {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 28%;
  flex-basis: 28%;
  max-width: 28%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
}

.cart-quantity p {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 70px);
  flex-basis: calc(100% - 70px);
  max-width: calc(100% - 70px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  text-align: right;
}

@media screen and (max-width: 768px) {
  .cart-quantity {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0 0 0 5px;
  }
  .cart-quantity p {
    -webkit-flex-basis: auto;
    flex-basis: auto;
    max-width: auto;
    text-align: left;
  }
}

.cart-quantity-inner {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  text-align: center;
}

.cart-quantity-button {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 70px;
  flex-basis: 70px;
  max-width: 70px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 10px;
}

.cart-quantity-button ul {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  text-align: center;
}

.cart-quantity-button li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 50%;
  flex-basis: 50%;
  max-width: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .cart-quantity-button {
    -webkit-flex-basis: 100px;
    flex-basis: 100px;
    max-width: 100px;
    padding-left: 20px;
  }
}

.cart-sub-total {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 22%;
  flex-basis: 22%;
  max-width: 22%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
  text-align: right;
}

@media screen and (max-width: 768px) {
  .cart-sub-total {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0 0 0 5px;
    text-align: left;
  }
}

.cart-list-total {
  padding: 20px 20px 0;
  text-align: right;
  border-top: 1px solid #b7b7b7;
}

@media screen and (max-width: 768px) {
  .cart-list-total {
    padding: 20px 0 0 0;
  }
}

.cart-total-annotation li {
  display: block;
  text-align: right;
}

/* gift
----------------------------------------------- */
.gift {
  width: 100%;
}

.gift .section {
  padding: 0;
}

@media screen and (max-width: 768px) {
  .gift .section {
    padding: 0 10px;
  }
}

.gift-tag-list {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 20px;
  width: 100%;
}

.gift-tag-list-main {
  width: 50%;
  padding: 0 20px;
}

.gift-tag-list-main img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .gift-tag-list-main {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-bottom: 5px;
    padding: 0 10px;
  }
}

.gift-tag-list-sub {
  width: 50%;
  overflow: hidden;
}

.gift-tag-list-sub ul {
  margin-top: -20px;
}

.gift-tag-list-sub li {
  margin-top: 20px;
}

@media screen and (max-width: 768px) {
  .gift-tag-list-sub {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
  .gift-tag-list-sub li {
    flex-grow: 0;
    flex-shrink: 1;
    -webkit-flex-basis: 50%;
    flex-basis: 50%;
    max-width: 50%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
  }
}

.gift-products-list {
  overflow: hidden;
}

.gift-archive-main-visual {
  margin-bottom: 25px;
  width: 100%;
}

.gift-archive-main-visual ul {
  margin: 0 auto;
}

.gift-archive-main-visual ul li {
  width: 100%;
  line-height: 0;
}

.gift-archive-main-visual img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .gift-archive-main-visual ul {
    max-width: 1280px;
  }
}

@media screen and (max-width: 768px) {
  .gift-archive-main-visual {
    margin-bottom: 20px;
  }
  .gift-archive-main-visual ul {
    max-width: 100%;
  }
}

/* gift-archive
----------------------------------------------- */
.gift-archive {
  width: 100%;
}

.gift-archive .section {
  padding: 0;
}

.gift-archive h2 {
  margin: 0 auto 40px;
  padding: 0 10px;
  max-width: 768px;
  text-align: center;
}

.gift-archive h2 img {
  margin-bottom: 5px;
  width: 100%;
}

.gift-archive h2 span {
  display: block;
  font-weight: bold;
  margin-top: 35px;
}

.gift-archive p {
  font-size: 14px;
  line-height: 28px;
  text-align: center;
  margin-top: 35px;
}

.gift-archive h3 {
  font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  width: 100%;
  padding: 0 20px;
  color: #7e7b7a;
  margin: 100px auto 40px;
  display: flex;
  align-items: center;
  font-weight: normal;
  font-size: 21px;
}

.gift-archive h3:before,
.gift-archive h3:after {
  content: "";
  height: 1px;
  flex-grow: 1;
  background-color: #7e7b7a;
}

.gift-archive h3:before {
  margin-right: 30px;
}

.gift-archive h3:after {
  margin-left: 30px;
}

.gift-archive-note {
  text-align: center;
}

.gift-archive-note p:nth-of-type(2) {
  margin-top: 20px;
}

.gift-archive-note dt,
.gift-archive-note dd {
  display: inline;
}

.gift-archive-list-title {
  margin: 55px auto 40px !important;
}

@media screen and (max-width: 768px) {
  .gift-archive .section {
    padding: 0 10px;
  }
  .gift-archive h2 {
    margin-bottom: 30px;
    text-align: left;
    padding: 0;
  }
  .gift-archive h2 span {
    margin-top: 20px;
    font-weight: normal;
  }
  .gift-archive p {
    margin-top: 20px;
    text-align: left;
  }
  .gift-archive hr {
    margin: 0 10px 20px;
  }
  .gift-archive h3 {
    font-size: 18px;
    margin: 50px auto 25px;
    padding: 0 10px;
  }
  .gift-archive h3:before {
    margin-right: 20px;
  }
  .gift-archive h3:after {
    margin-left: 20px;
  }

  .gift-archive-note p {
    text-align: center;
    margin-top: 25px;
    margin-bottom: 10px;
  }

  .gift-archive-note {
    position: relative;
    margin-bottom: 30px;
  }

  .gift-archive-list-title {
    margin: 30px auto 30px !important;
  }

  .gift-archive-note dl {
    width: 290px;
    margin: 0 auto 5px;
    display: flex;
    justify-content: flex;
    text-align: left;
  }

  .gift-archive-note dt {
    width: 80px;
  }

  .gift-archive-note dd {
    width: 210px;
  }
}

.gift-archive-list {
  overflow: hidden;
}

.gift-archive-list ul {
  display: -webkit-flex;
  display: flex;
  text-align: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  align-items: stretch;
}

.gift-archive-list li {
  text-align: left;
}

.gift-archive-list dt {
  display: block;
}

.gift-archive-list span {
  display: block;
  margin-bottom: 1em;
}

.gift-archive-list a {
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  .gift-archive-list li {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0;
  }
  .gift-archive-list dl {
    display: -webkit-flex;
    display: flex;
    margin: 0 auto;
    max-width: 100%;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .gift-archive-list dt,
  .gift-archive-list dd {
    padding: 0 10px;
    width: 50%;
  }
}

/* gift-details
----------------------------------------------- */
.gift-details .gift-img-description {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: flex-start;
}

.gift-details .gift-img-list {
  position: relative;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 400px);
  flex-basis: calc(100% - 400px);
  max-width: calc(100% - 400px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-bottom: 40px;
}

.gift-details .gift-img-list > .js-slider-contents li {
  width: 100%;
  line-height: 0;
}

.gift-details .gift-img-list > .js-slider-dots {
  padding-bottom: 0;
}

.gift-details .gift-img-list img {
  width: 100%;
}

.gift-details .gift-description {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 400px;
  flex-basis: 400px;
  max-width: 400px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 50px;
}

.gift-details .gift-description h2 {
  padding: 15px 0;
  line-height: 0;
  border-top: 1px solid #b7b7b7;
  border-bottom: 1px solid #b7b7b7;
}

.gift-details .gift-description h2 img {
  width: 100%;
}

.gift-details .gift-description h3 {
  margin-bottom: 10px;
  padding: 10px 0;
  font-weight: normal;
  border-bottom: 1px solid #b7b7b7;
}

.gift-details .gift-price {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 25px;
  padding: 10px 0;
  font-size: 12px;
  font-size: 0.75rem;
  border-top: 1px solid #b7b7b7;
  border-bottom: 1px solid #b7b7b7;
}

.gift-details .gift-price dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 50px;
  flex-basis: 50px;
  max-width: 50px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.gift-details .gift-price dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 50px);
  flex-basis: calc(100% - 50px);
  max-width: calc(100% - 50px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.gift-details .gift-select {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 25px;
}

.gift-details .gift-select dt {
  margin-bottom: 10px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 50px;
  flex-basis: 50px;
  max-width: 50px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.gift-details .gift-select dd {
  margin-bottom: 10px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 50px);
  flex-basis: calc(100% - 50px);
  max-width: calc(100% - 50px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.gift-details .gift-annotation {
  margin-bottom: 25px;
}

.gift-details .gift-other-box {
  margin-top: -1px;
  border-top: 1px solid #b7b7b7;
  border-bottom: 1px solid #b7b7b7;
}

.gift-details .gift-other-box > p {
  margin-bottom: 0;
}

.gift-details .gift-other-box > p span,
.gift-details .gift-other-box > p a {
  position: relative;
  display: block;
  padding: 10px 20px 10px 0;
  cursor: pointer;
}

.gift-details .gift-other-box > p span:before,
.gift-details .gift-other-box > p a:before {
  z-index: 1;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f218";
  font-family: "IonIcons";
  color: #b7b7b7;
}

.gift-details .gift-other-box > p span:before {
  right: 0;
  content: "\f218";
}

.gift-details .gift-other-box > p span:hover {
  color: #b5b6b6;
  text-decoration: none;
}

.gift-details .gift-other-box > p a {
  text-decoration: none;
}

.gift-details .gift-other-box > p.is-hidden span:before {
  right: 0;
  content: "\f209";
}

.gift-details .gift-other-box > p a:before {
  right: 2px;
  content: "\f125";
}

.gift-details .gift-other-box .show {
  display: none;
}

.gift-details .gift-other-box .show p {
  margin: -3px 0 10px;
  font-size: 12px;
  font-size: 0.75rem;
}

.gift-details .gift-relation {
  display: block;
  margin-top: 40px;
  padding: 20px 0;
  border-top: 1px solid #b7b7b7;
  border-bottom: 1px solid #b7b7b7;
}

.gift-details .gift-relation a {
  position: relative;
  text-decoration: none;
}

.gift-details .gift-relation dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 auto;
  width: 100%;
}

.gift-details .gift-relation dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 115px;
  flex-basis: 115px;
  max-width: 115px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.gift-details .gift-relation dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 115px);
  flex-basis: calc(100% - 115px);
  max-width: calc(100% - 115px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 20px;
}

.gift-details .gift-relation dd img {
  width: 100%;
  margin-bottom: 10px;
}

.gift-details .gift-relation dd i {
  margin-left: 0.5em;
  color: #b7b7b7;
}

@media screen and (max-width: 768px) {
  .gift-details .gift-img-list,
  .gift-details .gift-description {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0;
  }
  .gift-details .gift-img-list {
    padding: 0;
  }
  .gift-details .gift-img-list > .js-slider-dots {
    padding-bottom: 20px;
  }
}

/* products
----------------------------------------------- */
.products-archive-main-visual {
  margin-bottom: 25px;
  width: 100%;
}

.products-archive-main-visual ul {
  margin: 0 auto;
}

.products-archive-main-visual ul li {
  width: 100%;
  line-height: 0;
}

.products-archive-main-visual img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .products-archive-main-visual ul {
    max-width: 1280px;
  }
}

@media screen and (max-width: 768px) {
  .products-archive-main-visual {
    margin-bottom: 20px;
  }
  .products-archive-main-visual ul {
    max-width: 100%;
  }
}

.products-archive {
  width: 100%;
}

.products-archive .section {
  padding: 0;
}

.products-archive p {
  margin: 0 auto 40px;
  padding: 0 20px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .products-archive p {
    text-align: left;
  }
}

.products-archive .products-relation {
  display: block;
  margin: 80px 20px;
  padding: 20px 0;
  border-top: 1px solid #b7b7b7;
  border-bottom: 1px solid #b7b7b7;
}

.products-archive .products-relation a {
  position: relative;
  text-decoration: none;
}

.products-archive .products-relation dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 auto;
  max-width: 728px;
}

.products-archive .products-relation dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 115px;
  flex-basis: 115px;
  max-width: 115px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.products-archive .products-relation dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 115px);
  flex-basis: calc(100% - 115px);
  max-width: calc(100% - 115px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 45px;
}

.products-archive .products-relation dd img {
  width: 100%;
  margin-bottom: 10px;
}

.products-archive .products-relation dd i {
  margin-left: 0.5em;
  color: #b7b7b7;
}

@media screen and (max-width: 768px) {
  .products-archive .products-relation dd {
    padding-left: 20px;
  }
}

.products-archive-list {
  margin-bottom: 100px;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .products-archive-list {
    margin-bottom: 40px;
    padding: 10px;
  }
}

/* shopping
----------------------------------------------- */
.shopping-flow {
  margin: 0 auto 40px;
  padding: 0 20px;
  max-width: 808px;
}

.shopping-flow ul {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.shopping-flow li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 25%;
  flex-basis: 25%;
  max-width: 25%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 0;
}

.shopping-flow li img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .shopping-flow {
    margin-bottom: 30px;
  }
}

.shopping-summary {
  margin-bottom: 30px;
}

.shopping-arrow-list {
  margin-bottom: 30px;
}

.shopping-arrow-list a {
  position: relative;
  display: inline-block;
  padding-right: 20px;
  text-decoration: none;
  cursor: pointer;
}

.shopping-arrow-list a:before {
  z-index: 1;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f125";
  font-family: "IonIcons";
  color: #b7b7b7;
}

.shopping-arrow-list .important a:before {
  color: #f29d83;
}

@media screen and (max-width: 768px) {
  .shopping-arrow-list {
    margin-bottom: 1em;
  }
}

.shopping-box {
  margin-bottom: 40px;
  padding: 40px 40px 25px;
  background: #f5f5f5;
}

.shopping-box .lv02 {
  color: #666;
}

@media screen and (max-width: 768px) {
  .shopping-box {
    margin-bottom: 20px;
    padding: 15px 10px 5px;
  }
  .shopping-box .lv02 {
    margin-bottom: 10px;
  }
}

.shopping-form {
  overflow: hidden;
  margin-bottom: 30px;
}

.shopping-form dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin-top: -20px;
}

.shopping-form dt {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 210px;
  flex-basis: 210px;
  max-width: 210px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-form dd {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 210px);
  flex-basis: calc(100% - 210px);
  max-width: calc(100% - 210px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

#card_no {
  margin-top: 2px;
}

#last_name,
#first_name {
  margin-top: 7px;
}

.shopping-form ul {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.shopping-form li {
  display: inline-block;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(50% - 10px);
  flex-basis: calc(50% - 10px);
  max-width: calc(50% - 10px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  margin-right: 20px;
}

.shopping-form li:last-child {
  margin-right: 0;
}

.shopping-form li > div {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}

.shopping-form li .select {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 80%;
  flex-basis: 80%;
  max-width: 80%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-form li span {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 20%;
  flex-basis: 20%;
  max-width: 20%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 10px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .shopping-form {
    margin-bottom: 20px;
  }
  .shopping-form dl {
    margin-top: -10px;
  }
  .shopping-form dt,
  .shopping-form dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 10px;
  }
  .shopping-form li {
    flex-grow: 0;
    flex-shrink: 1;
    -webkit-flex-basis: calc(50% - 5px);
    flex-basis: calc(50% - 5px);
    max-width: calc(50% - 5px);
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
    margin-right: 10px;
  }
}

.shopping-button-list {
  overflow: hidden;
  margin-bottom: 35px;
}

.shopping-button-list ul {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
  margin-top: -20px;
}

.shopping-button-list .icon-plus {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(50% - 20px);
  flex-basis: calc(50% - 20px);
  max-width: calc(50% - 20px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-button-list .icon-plus a {
  position: relative;
  display: block;
  padding: 8px 20px 8px 50px;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-button-list .icon-plus a:before {
  z-index: 1;
  position: absolute;
  left: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f218";
  font-family: "IonIcons";
  color: #b7b7b7;
}

.shopping-button-list .radio {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(50% - 20px);
  flex-basis: calc(50% - 20px);
  max-width: calc(50% - 20px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-button-list .radio input[type="radio"] {
  display: none;
}

.shopping-button-list .radio input[type="radio"] + label {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  display: block;
  position: relative;
  padding: 10px 20px 10px 60px;
  cursor: pointer;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-button-list .radio input[type="radio"] + label:before {
  content: "";
  display: block;
  position: absolute;
  left: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: white;
  border: 1px solid #b7b7b7;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-button-list .radio input[type="radio"] + label:hover {
  color: #b5b6b6;
}

.shopping-button-list .radio input[type="radio"] + label p {
  margin-bottom: 0;
}

.shopping-button-list .radio input[type="radio"]:checked + label {
  color: #fff;
  background: #666;
  border-color: #666;
}

.shopping-button-list .radio input[type="radio"]:checked + label:before {
  border-color: #666;
}

.shopping-button-list .radio input[type="radio"]:checked + label:after {
  content: "";
  display: block;
  position: absolute;
  left: 25px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: #666;
  border-radius: 50%;
}

@media screen and (max-width: 768px) {
  .shopping-button-list {
    margin-bottom: 30px;
    padding: 0;
  }
  .shopping-button-list .icon-plus,
  .shopping-button-list .radio {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
  .shopping-button-list .icon-plus a,
  .shopping-button-list .radio a {
    padding: 7px 10px 7px 40px;
  }
  .shopping-button-list .icon-plus a:before,
  .shopping-button-list .radio a:before {
    left: 15px;
  }
  .shopping-button-list .icon-plus input[type="radio"] + label,
  .shopping-button-list .radio input[type="radio"] + label {
    display: block;
    position: relative;
    padding: 7px 10px 7px 40px;
  }
  .shopping-button-list .icon-plus input[type="radio"] + label:before,
  .shopping-button-list .radio input[type="radio"] + label:before {
    left: 10px;
  }
  .shopping-button-list .icon-plus input[type="radio"]:checked + label:after,
  .shopping-button-list .radio input[type="radio"]:checked + label:after {
    left: 15px;
  }
}

/* deliv
----------------------------------------------- */
.deliv-list {
  margin-bottom: 40px;
}

.deliv-list-item {
  position: relative;
  margin-bottom: 20px;
}

.deliv-list-item input[type="radio"] {
  display: none;
}

.deliv-list-item input[type="radio"] + label {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  display: block;
  position: relative;
  padding: 20px 175px 20px 60px;
  cursor: pointer;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.deliv-list-item input[type="radio"] + label:before {
  content: "";
  display: block;
  position: absolute;
  left: 20px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: white;
  border: 1px solid #b7b7b7;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.deliv-list-item input[type="radio"]:disabled + label:before {
  opacity: 0;
}

.deliv-list-item input[type="radio"] + label:hover {
  color: #b5b6b6;
}

.deliv-list-item input[type="radio"] + label p {
  margin-bottom: 0;
}

.deliv-list-item input[type="radio"]:checked + label {
  color: #fff;
  background: #666;
  border-color: #666;
}

.deliv-list-item input[type="radio"]:checked + label:before {
  border-color: #666;
}

.deliv-list-item input[type="radio"]:checked + label:after {
  content: "";
  display: block;
  position: absolute;
  left: 25px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: #666;
  border-radius: 50%;
}

@media screen and (max-width: 768px) {
  .deliv-list-item input[type="radio"] + label {
    display: block;
    position: relative;
    padding: 15px 75px 15px 40px;
  }
  .deliv-list-item input[type="radio"] + label:before {
    left: 10px;
  }
  .deliv-list-item input[type="radio"]:checked + label:after {
    left: 15px;
  }
}

.deliv-button {
  position: absolute;
  top: calc(50% - 21px);
  right: 20px;
}

.deliv-button ul {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 150px;
}

.deliv-button li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 50%;
  flex-basis: 50%;
  max-width: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 10px;
  text-align: center;
}

.deliv-button li a {
  display: block;
  padding: 8px 15px;
  background: #fff;
  text-decoration: none;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .deliv-button {
    top: calc(50% - 32px);
    right: 15px;
  }
  .deliv-button ul {
    width: 50px;
  }
  .deliv-button li {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    font-size: 12px;
    font-size: 0.75rem;
    padding: 0 0 5px 0;
  }
  .deliv-button li a {
    padding: 3px 10px;
  }
}

/* payment
----------------------------------------------- */
.payment .shopping-form {
  padding: 0 80px;
}

.payment dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 150px;
  flex-basis: 150px;
  max-width: 150px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.payment dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 150px);
  flex-basis: calc(100% - 150px);
  max-width: calc(100% - 150px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .payment .shopping-form {
    padding: 0;
  }
  .payment dt,
  .payment dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
}

.payment-annotation-list {
  margin-bottom: 1em;
  padding: 0 80px;
}

@media screen and (max-width: 768px) {
  .payment-annotation-list {
    padding: 0;
  }
}

/* confirm
----------------------------------------------- */
@media screen and (max-width: 768px) {
  .confirm .shopping-box {
    padding: 20px 10px 0;
  }
}

.confirm-list {
  overflow: hidden;
}

.confirm-list .confirm-list-inner {
  margin: -1px 0 20px;
  background: #fff;
}

.confirm-list dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 20px;
  padding: 20px 0;
  border-top: 1px solid #b7b7b7;
}

.confirm-list dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 130px;
  flex-basis: 130px;
  max-width: 130px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 20px;
}

.confirm-list dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 130px);
  flex-basis: calc(100% - 130px);
  max-width: calc(100% - 130px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 20px;
}

.confirm-list .dt-none dt {
  display: none;
}

.confirm-list .dt-none dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 100%;
  flex-basis: 100%;
  max-width: 100%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.confirm-list.total {
  font-weight: bold;
}

.confirm-list.total dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 130px);
  flex-basis: calc(100% - 130px);
  max-width: calc(100% - 130px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  text-align: right;
}

.confirm-list.total dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 130px;
  flex-basis: 130px;
  max-width: 130px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  text-align: right;
}

@media screen and (max-width: 768px) {
  .confirm-list .confirm-list-inner {
    margin-bottom: 5px;
  }
  .confirm-list dl {
    margin: 0 10px;
    padding: 10px 0;
  }
  .confirm-list dt,
  .confirm-list dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0 10px;
  }
}

.confirm-list-item {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  background: #fff;
  margin-bottom: 20px;
  padding: 20px;
}

.confirm-list-item dl {
  padding: 0 10px;
}

.confirm-list-item dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 100px;
  flex-basis: 100px;
  max-width: 100px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.confirm-list-item dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 100px);
  flex-basis: calc(100% - 100px);
  max-width: calc(100% - 100px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 10px;
}

.confirm-list-item h3 {
  margin-bottom: 1em;
}

.confirm-list-item p {
  margin-bottom: 0;
}

.confirm-list-item .confirm-list-item-inner {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}

.confirm-list-item .confirm-img {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 100px;
  flex-basis: 100px;
  max-width: 100px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 0;
}

.confirm-list-item .confirm-img img {
  width: 100%;
}

.confirm-list-item .confirm-description {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 150px);
  flex-basis: calc(100% - 150px);
  max-width: calc(100% - 150px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
}

.confirm-list-item .confirm-other {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 150px;
  flex-basis: 150px;
  max-width: 150px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
}

@media screen and (max-width: 768px) {
  .confirm-list-item {
    align-items: start;
    margin-bottom: 10px;
    padding: 10px;
  }
  .confirm-list-item dt {
    -webkit-flex-basis: 60px;
    flex-basis: 60px;
    max-width: 60px;
  }
  .confirm-list-item dd {
    flex-grow: 0;
    flex-shrink: 1;
    -webkit-flex-basis: calc(100% - 60px);
    flex-basis: calc(100% - 60px);
    max-width: calc(100% - 60px);
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
    padding-left: 5px;
  }
  .confirm-list-item .confirm-img {
    -webkit-flex-basis: 60px;
    flex-basis: 60px;
    max-width: 60px;
  }
  .confirm-list-item .confirm-description,
  .confirm-list-item .confirm-other {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0 0 0 5px;
  }
}

/* finish
----------------------------------------------- */
.finish-message {
  margin-bottom: 50px;
  padding: 0 40px;
}

.finish-message p {
  margin-bottom: 40px;
  line-height: 2.75;
}

.finish-message p:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 768px) {
  .finish-message {
    margin-bottom: 40px;
    padding: 0;
  }
  .finish-message p {
    margin-bottom: 25px;
    line-height: 2;
  }
}

/* menu, modal
----------------------------------------------- */
/* .js-menu,
.js-modal {
  position: fixed;
  opacity: 0;
  top: 100%;
  display: block;
  transition: opacity 0.3s, top 0s 0.3s;
}

.js-menu.is-show,
.js-modal.is-show {
  opacity: 1;
  top: 0;
  transition: opacity 0.3s, top 0s;
} */

.js-menu,
.js-modal {
  display: block;
  position: fixed;
  right: 0;
  width: 55%;
  opacity: 0;
  top: 100%;
  /* opacity: 1;
  top: 0; */
  transition: opacity 0.3s, top 0s 0.3s;
}

.js-menu.is-show,
.js-modal.is-show {
  opacity: 1;
  top: 0;
  transition: opacity 0.3s, top 0s;
}

@media screen and (max-width: 768px) {
  .js-menu,
  .js-modal {
    width: 100%;
  }
}

/* accordion
----------------------------------------------- */
.js-accordion .show.is-active {
  display: block;
  overflow: hidden;
  transition: height 0.3s;
}

/* slider
----------------------------------------------- */
.js-slider {
  position: relative;
}

.js-slider-contents {
  white-space: nowrap;
  overflow: hidden;
}

.js-slider-contents li {
  display: inline-block;
  vertical-align: middle;
}

.js-slider-contents li.is-return-move {
  transition: transform 0.3s;
}

.js-slider-dots {
  text-align: center;
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding-bottom: 20px;
  max-width: none !important;
}

.js-slider-dots li {
  display: inline-block;
  vertical-align: middle;
  width: 12px;
  height: 12px;
  border-radius: 6px;
  background: #b5b6b6;
  cursor: pointer;
  margin-right: 10px;
  transition: background-color 0.5s;
}

.js-slider-dots li:last-child {
  margin-right: 0;
}

.js-slider-dots li.is-now {
  background: #333;
  cursor: default;
}

/* ifx180903
----------------------------------------------- */
/* login
----------------------------------------------- */
.login-box {
  width: 412px;
  margin: 0 auto;
  padding: 35px 10px 25px;
  background: #f5f5f5;
}
.login-box h2 {
  color: #666;
  margin: 0 auto 30px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 24px;
  font-weight: normal;
  text-align: center;
}
.login_label {
  display: block;
  position: relative;
  padding-left: 25px;
  margin: 20px 2px 30px;
  font-size: 15px;
  color: rgba(33, 23, 20, 0.7);
}
.login-remember-button input[type="checkbox"] {
  display: none;
}
.login_label:hover:after {
  border-color: #0171bd;
}
.login_label:after,
.login_label:before {
  position: absolute;
  content: "";
  display: block;
  top: 50%;
}
.login_label:after {
  left: 0;
  margin-top: -7px;
  width: 12px;
  height: 13px;
  border: 1px solid #ccc;
}
.login_label:before {
  left: 3px;
  margin-top: -4px;
  width: 6px;
  height: 7px;
  background-color: #666;
  opacity: 0;
}
.login-remember-button input[type="checkbox"]:checked + .login_label:before {
  opacity: 1;
}
.login-box-input {
  border: none !important;
  padding: 20px 0 20px 15px !important;
  font-size: 17px !important;
  color: #666;
}
.login-box-input::placeholder {
  color: #adadad;
}
.login-submit {
  display: block;
  font-size: 17px !important;
  width: 330px !important;
  margin: 30px auto;
}
.login-guide {
  list-style: none;
  font-size: 17px;
  color: #666;
}
.login-guide a {
  color: #666;
}
.login-guide li {
  flex-basis: 100%;
  max-width: 100%;
}
.login-guide li:first-child {
  margin-bottom: 27px;
}
.login-register-box {
  width: 412px;
  margin: 0 auto;
  padding: 35px 10px 25px;
  background: #f5f5f5;
}
.login-register-box-2 {
  width: 900px;
  margin: 0 auto;
  padding: 35px 150px 40px;
  background: #f5f5f5;
}
.login-register-box h2,
.login-register-box-2 h2 {
  color: #666;
  margin: 0 auto 30px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 24px;
  font-weight: normal;
  text-align: center;
}
.login-register-box-2 h2 {
  margin: 0 auto 5px !important;
}
.login-register-caution {
  font-size: 15px !important;
  color: #cf0000 !important;
  text-align: center;
}
.login-register-box p,
.login-register-box-2 p {
  font-size: 17px;
  color: #666;
  margin-bottom: 35px;
  /*letter-spacing: 1px;*/
}
.login-register-p {
  text-align: left;
  margin-bottom: 10px !important;
}

.login-register-box a {
  background: #b7b7b7;
  width: 330px !important;
  margin: 0 auto;
  text-align: center;
  font-size: 17px;
  color: #fff;
  display: block;
  padding: 10px 20px;
  text-decoration: none;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.login-register-input {
  display: block;
  width: 400px !important;
  margin: 0 auto;
}
.login-register-submit {
  margin: 15px auto 40px !important;
}

.login-register-2col {
  width: 400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.login-register-2col > .login-register-submit {
  margin: auto !important;
  width: 110px !important;
  padding: 16px;
}

.login-register-2col > input[type="text"] {
  width: 255px !important;
}

@media screen and (max-width: 768px) {
  .login-box,
  .login-register-box,
  .login-register-box-2 {
    width: 100%;
  }
  .login-submit,
  .login-register-box a,
  .login-register-box-2 a {
    width: 85% !important;
  }
  .login-box h2,
  .login-register-box h2,
  .login-register-box-2 h2 {
    font-size: 15px;
  }
  .login-box-input,
  .login-submit,
  .login-guide li,
  .login-register-box p,
  .login-register-box a,
  .login-register-box-2 a,
  .login-register-box-2 p {
    font-size: 12px !important;
  }
  .login-register-input {
    width: 100% !important;
  }
  .login-submit {
    margin: 20px auto;
  }
  .login_label {
    font-size: 11px;
    margin: 12px 1px 25px;
  }
  .login-register-box,
  .login-register-box-2,
  .login-box {
    padding: 25px 10px;
  }
  .login-register-2col {
    width: 100%;
    flex-wrap: wrap;
  }
  .login-register-2col > input[type="text"] {
    width: 100% !important;
  }
  .login-register-2col > .login-register-submit {
    width: 85% !important;
    padding: 10px;
    margin: 15px auto 0px !important;
  }
}
/* ifx180903
----------------------------------------------- */
/* payment 修正
----------------------------------------------- */
.shopping-box p,
.shopping-arrow-list ul li:first-child a,
.shopping-form dl dt,
.payment-annotation-list li {
  color: #666;
}
/* ifx180904
----------------------------------------------- */
/* マイページ mypage/index.html
----------------------------------------------- */
.mypage-box {
  color: #666;
}
.mypage-title {
  font-size: 1.5rem;
  font-weight: normal;
  text-align: center;
  margin: 0 auto 30px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.mypage-title span {
  display: block;
  font-size: 1rem;
  font-weight: normal;
  text-align: center;
}
.mypage-user {
  line-height: 50px;
  font-size: 16px;
  font-weight: normal;
  text-align: center;
  border: 1px solid #666;
}
.mypage-menu {
  display: flex;
  justify-content: space-around;
  margin: 30px 0 50px;
}
.mypage-menu a {
  color: #666;
  font-size: 16px;
}
.purchase-history {
  position: relative;
  margin-bottom: 40px;
  padding: 30px 30px 60px;
  background: #f5f5f5;
}
.purchase-history h2 {
  font-size: 21px;
  font-weight: normal;
  text-align: center;
  margin: 5px auto 40px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.purchase-number {
  font-size: 14px;
}
.purchase-number span {
  color: #ea6136;
}
.purchase-list {
  width: 100%;
  min-height: 300px;
  background-color: #fff;
}
.purchase-list table {
  width: 95%;
  margin: 0 auto;
}
.purchase-list table,
.purchase-list th,
.purchase-list td {
  border-collapse: collapse;
}
.purchase-list table thead tr th {
  padding: 20px 0;
  font-weight: normal;
}
.purchase-list table tbody tr td {
  border-top: 1px solid #666;
  text-align: center;
  font-size: 14px;
  padding: 15px 0;
}
.purchase-list table tbody tr td a {
  padding: 3px 6px;
  border: 1px solid #666;
  text-align: center;
  text-decoration: none;
}
.purchase-pager {
  display: flex;
  width: 93%;
  justify-content: flex-end;
  flex-wrap: wrap;
  margin-top: 25px;
}
.purchase-pager a {
  padding-right: 20px;
  text-decoration: none;
}
.purchase-pager-next {
  padding-right: 0 !important;
}
.purchase-caution h2 {
  color: #ea6136;
  font-weight: normal;
  font-size: 14px;
}
.purchase-caution p {
  font-size: 14px;
  margin-bottom: 0;
}

/* 250123 ヘルプポップアップ導入 */
.add-help {
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}

.add-help img{
  width: 20px;
  height: 20px;
}

.add-help .help-button{
  width: 20px;
  height: 20px;
  margin-left: 3px;
}

.add-help-history .help-button{
  margin-left: 2px;
}

.history-help-button{
  width: 20px;
  height: 20px;
  margin-left: 2px;
}

.dilg-help-close{
  left: auto!important;
  right: 15px!important;
}

#dlg-help{
  width: 90%;
  max-width: 700px;
}

#dlg-help h3{
  font-weight: normal;
}

#dlg-help .tm-content{
  padding: 0 40px;
}

.dlg-help-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 20px;
  padding: 0 20px;
}
.dlg-help-table th,
.dlg-help-table td {
  border-top: 1px solid #9d9d9d;
  border-bottom: 1px solid #9d9d9d;
  padding: 18px;
  vertical-align: top;
  line-height: 26px;
}
.dlg-help-table th {
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
  background-color: #f8f8f8;
}

@media screen and (max-width: 768px) {
  /* 250123 ヘルプポップアップ導入 */
  .add-help.add-help-history{
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }

  .add-help .help-button{
    margin-left: 2px;
  }

  .add-help img,
  .add-help .help-button,
  .history-help-button{
    width: 16px;
    height: 16px;
  }

  #dlg-help.tm-modal{
    height: 80vh;
  }

  #dlg-help.tm-modal .tm-wrapper{
    overflow: auto;
  }

  #dlg-help .tm-content,
  #dlg-help .tm-content .dlg-help-table{
    overflow: visible;
    overflow-y: visible;
    overflow-x: visible;
  }

  #dlg-help .tm-title{
    box-shadow: none!important;
  }

  #dlg-help h3{
    font-size: 18px;
    margin-top: 0px;
  }

  #dlg-help .tm-content{
    padding: 0 30px;
    height: auto;
  }

  #dlg-help .tm-content:after{
    content: "";
    padding-bottom: 0!important;
  }

  .dlg-help-table{
    margin: 0;
  }

  .dlg-help-table tr{
    display: flex;
    flex-wrap: wrap;
  }

  .dlg-help-table th,
  .dlg-help-table td {
    width: 100%;
    padding: 12px 0;
  }

  .dlg-help-table th{
    border-bottom: none;
  }

  .dlg-help-table td{
    color: #737373;
    border-top: none;
    border-bottom: none;
    padding-bottom: 30px;
  }


  .dlg-help-table th {
    text-align: center;
  }

  .mypage-title {
    font-size: 15px;
    margin: 0 auto 15px;
  }
  .mypage-title span {
    font-size: 11px;
  }
  .mypage-user {
    font-size: 12px;
    line-height: 35px;
  }
  .mypage-menu {
    flex-direction: column;
    text-align: center;
    margin-bottom: 10px;
  }
  .mypage-menu li {
    margin-bottom: 15px;
  }
  .mypage-menu li a {
    font-size: 12px;
  }
  .purchase-history {
    padding: 25px 10px 20px;
    margin-bottom: 15px;
  }
  .purchase-history h2 {
    margin-bottom: 25px;
  }
  .purchase-list table {
    width: 99%;
  }
  .purchase-list table thead tr th {
    font-size: 10px;
    padding: 15px 0;
  }
  .purchase-list table tbody tr td {
    font-size: 10px;
  }
  .purchase-list table tbody tr td a {
    padding: 3px 3px;
  }
  .purchase-pager {
    width: 99%;
    margin-top: 10px;
    font-size: 10px;
  }
  .purchase-pager a {
    padding-right: 15px;
  }
  .purchase-caution p {
    font-size: 12px;
    line-height: 26px;
    margin-bottom: 0;
  }
  .purchase-caution h2 {
    font-size: 12px;
  }
}

/* ifx180905
----------------------------------------------- */
/* マイページ mypage/index_2.html
----------------------------------------------- */
.purchase-detail {
  display: flex;
  justify-content: space-around;
  width: 95%;
  flex-wrap: wrap;
  margin: 30px auto;
}
.purchase-item,
.purchase-item-total {
  color: #000;
  background-color: #fff;
  display: -webkit-flex;
  display: flex;
  margin: 0 auto 25px;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 10px 10px;
}
.purchase-item dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
.purchase-item dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 160px;
  flex-basis: 102px;
  max-width: 102px;
}
.purchase-item dt img {
  width: 100%;
}
.purchase-item dd {
  flex-grow: 0;
  flex-shrink: 1;
  flex-basis: calc(100% - 102px);
  max-width: calc(100% - 102px);
  padding-left: 25px;
  justify-content: space-between;
}
.purchase-item-inner {
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
.purchase-item-name {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 70%;
  flex-basis: 70%;
  max-width: 70%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
}
.purchase-item-price {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 30%;
  flex-basis: 30%;
  max-width: 30%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 10px;
}
.purchase-item h3 {
  font-size: 14px;
  margin-bottom: 10px;
}
.purchase-item p {
  font-size: 14px;
  margin-bottom: 10px;
}
.purchase-item a {
  text-decoration: none;
}
.purchase-item-line td {
  border-top: 1px solid #666;
  padding: 15px 0;
}
.purchase-item-total {
  justify-content: flex-end;
  padding: 25px 30px;
}
.purchase-item-total table,
.purchase-item-total td {
  border-collapse: collapse;
  width: 100%;
}
.purchase-item-total td {
  padding-bottom: 15px;
}
.purchase-item-total table tbody tr td:first-child {
  width: 85%;
  text-align: right;
}
.purchase-item-total table tbody tr td:last-child {
  text-align: right;
  padding-right: 40px;
}
.purchase-address-title {
  margin-bottom: 30px !important;
}
.purchase-mail-title {
  margin: 40px auto 30px !important;
}
.purchase-address,
.purchase-mail-list {
  color: #000;
  background-color: #fff;
  padding: 20px 15px 0;
}
.purchase-address li,
.purchase-mail-list li {
  margin-bottom: 20px;
  line-height: 14px;
  font-size: 14px;
  padding-left: 20px;
}
.purchase-address li:last-child,
.purchase-mail-list li:last-child {
  padding-bottom: 20px;
}
.purchase-address-line,
.purchase-mail-list-line {
  border-bottom: 1px solid #666;
  padding-left: 0 !important;
}
.purchase-back-button {
  display: block;
  width: 335px;
  margin: 0 auto;
  line-height: 50px;
  border: 1px solid #000;
  text-align: center;
  text-decoration: none !important;
}
.purchase-re-order {
  display: none;
}
@media screen and (max-width: 768px) {
  .purchase-detail {
    margin: 15px 0;
  }
  .purchase-detail li {
    flex-basis: 100%;
    max-width: 100%;
  }
  .purchase-item-name {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
  .purchase-item-price {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
  .purchase-item h3,
  .purchase-item p {
    font-size: 12px;
    margin-bottom: 10px;
  }
  .purchase-item-total {
    padding: 15px;
  }
  .purchase-item-total table tbody tr td:first-child {
    width: 70%;
  }
  .purchase-item-total table tbody tr td:last-child {
    text-align: right;
    padding-right: 0;
    white-space: nowrap;
  }
  .purchase-address li,
  .purchase-mail-list li {
    line-height: 26px;
    font-size: 12px;
    padding-left: 20px;
    margin-bottom: 0;
  }
  .purchase-address-line,
  .purchase-mail-list-line {
    margin: 10px 0 !important;
  }
  .purchase-re-order {
    display: block;
    width: 165px;
    line-height: 27px;
    margin-bottom: 15px;
    text-align: center;
    text-decoration: none !important;
    color: #ffffff;
    background-color: #b3b3b3;
    border: 1px solid #b3b3b3;
  }
  .purchase-re-order:hover {
    color: #000;
    background-color: #fff;
    border: 1px solid #b3b3b3;
  }
}

/* ifx180905
----------------------------------------------- */
/* お届け先追加･変更 mypage/delivery.html
----------------------------------------------- */
.mypage-delivery-box {
  margin-bottom: 40px;
  padding: 30px 30px 25px;
  background: #f5f5f5;
}
.mypage-delivery-box h2 {
  font-size: 21px;
  font-weight: normal;
  text-align: center;
  margin: 0 auto 40px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.mypage-deliv-caution {
  list-style: disc;
  font-size: 14px;
  list-style-position: inside;
  margin-bottom: 30px;
}
.mypage-deliv-caution span {
  color: #ea6136;
}
.mypage-deliv-caution {
  margin-bottom: 40px;
}
.mypage-deliv-list-item {
  background-color: #fff;
  position: relative;
  margin-bottom: 20px;
}
.mypage-deliv-list-item-inner {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  display: block;
  position: relative;
  padding: 25px 20px 20px 25px;
  cursor: pointer;
  border: 1px solid #000;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.mypage-deliv-list-item-inner p {
  font-size: 14px;
  line-height: 28px;
  margin: 0;
}
.mypage-deliv-add-button {
  background-color: #fff;
}
.mypage-deliv-button {
  position: absolute;
  top: calc(50% - 21px);
  right: 20px;
}
.mypage-deliv-button ul {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 150px;
}
.mypage-deliv-button li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 50%;
  flex-basis: 50%;
  max-width: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 10px;
  text-align: center;
}
.mypage-deliv-button li a {
  display: block;
  padding: 8px 15px;
  background: #fff;
  text-decoration: none;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .mypage-delivery-box h2 {
    font-size: 15px;
  }
  .mypage-deliv-caution {
    margin-bottom: 27px;
  }
  .mypage-deliv-list-item-inner {
    display: block;
    position: relative;
    padding: 17px 100px 15px 15px;
  }
  .mypage-deliv-caution,
  .mypage-deliv-list-item-inner p {
    font-size: 12px;
    line-height: 24px;
  }
  .mypage-deliv-add-button {
    font-size: 12px;
  }
  .mypage-deliv-list-box {
    margin-top: -10px;
  }
  .mypage-deliv-button {
    top: calc(50% - 32px);
    right: 15px;
  }
  .mypage-deliv-button ul {
    width: 50px;
  }
  .mypage-deliv-button li {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    font-size: 12px;
    font-size: 0.75rem;
    padding: 0 0 5px 0;
  }
  .mypage-deliv-button li a {
    padding: 3px 10px;
  }
}
/* ifx180905
----------------------------------------------- */
/* お届け先追加･変更 mypage/delivery_2.html
----------------------------------------------- */
.mypage-delivery-box-2 {
  margin-bottom: 0;
  padding: 30px 70px 25px;
  background: #f5f5f5;
}

.mypage-delivery-box-3 {
  margin-bottom: 0;
  padding: 30px 30px 25px;
  background: #f5f5f5;
}

.mypage-delivery-box-2 h2 {
  font-size: 21px;
  font-weight: normal;
  text-align: center;
  margin: 0 auto 40px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.mypage-delivery-box-3 h2 {
  font-size: 21px;
  font-weight: normal;
  text-align: center;
  margin: 0 auto 40px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.mypage-deliv-form dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin-top: -20px;
}
.mypage-deliv-form dt {
  margin-top: 18px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 260px;
  flex-basis: 260px;
  max-width: 260px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.mypage-deliv-form dt span {
  color: #ea6136;
}
.mypage-deliv-form dd {
  margin-top: 15px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 260px);
  flex-basis: calc(100% - 260px);
  max-width: calc(100% - 260px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.mypage-deliv-form input {
  border: 0;
  font-size: 14px;
  line-height: 27px;
}
.mypage-form-2column {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  align-items: center;
  justify-content: space-between;
}
.mypage-form-2column input {
  -webkit-flex-basis: 48%;
  flex-basis: 48%;
  max-width: 48%;
  flex-grow: 1;
  flex-shrink: 1;
  border: none;
}
.mypage-form-2column input:first-child {
  float: left;
}
.mypage-form-2column input:last-child {
  float: right;
}
.mypage-form-address,
.mypage-form-tel,
.mypage-form-address-search {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}
.mypage-form-address input,
.mypage-form-tel input {
  height: 43px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 30%;
  flex-basis: 30%;
  max-width: 30%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  border: none;
}
.mypage-form-address span,
.mypage-form-tel span {
  width: 0;
  margin-left: -7px;
  line-height: 43px;
}
.mypage-form-address-button {
  height: 43px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 30%;
  flex-basis: 30%;
  max-width: 30%;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  padding: 12px 25px;
}
.mypage-form-address-button:hover {
  opacity: 0.8;
}
.mypage-form-address-search {
  color: #666;
  justify-content: flex-end;
}
.mypage-form-select {
  position: relative;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.mypage-form-select select {
  border: none;
  font-size: 14px;
  line-height: 27px;
}
.mypage-form-select:before {
  z-index: 1;
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f123";
  font-family: "IonIcons";
  pointer-events: none;
  color: #b7b7b7;
}
.mypage-form-submit {
  color: #fff;
  display: block;
  background-color: #b3b3b3;
  width: 50%;
  height: 45px;
  margin: 60px auto 30px;
}
@media screen and (max-width: 768px) {
  .mypage-delivery-box-2 {
    padding: 30px 7px 25px;
  }

  .mypage-delivery-box-3 {
    padding: 30px 7px 25px;
  }

  .mypage-delivery-box-2 h2 {
    font-size: 15px;
  }

  .mypage-delivery-box-3 h2 {
    font-size: 15px;
  }

  .mypage-deliv-form {
    margin-bottom: 20px;
  }

  .mypage-deliv-form dl {
    margin-top: -10px;
  }

  .mypage-deliv-form dt,
  .mypage-deliv-form dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 10px;
    font-size: 12px;
  }
  .mypage-deliv-form input {
    font-size: 12px;
    line-height: 24px;
  }
  .mypage-form-address input,
  .mypage-form-tel input {
    height: 44px;
  }
  .mypage-form-address span,
  .mypage-form-tel span {
    line-height: 44px;
  }
  .mypage-form-address input {
    -webkit-flex-basis: 32%;
    flex-basis: 32%;
    max-width: 32%;
  }
  .mypage-form-address-button {
    white-space: nowrap;
    text-align: center;
    padding: 9px 0;
    line-height: 16px;
    height: 32px;
  }
  .mypage-form-submit {
    width: 80%;
    margin: 45px auto 30px;
    font-size: 12px;
  }
}
/* ifx180905
----------------------------------------------- */
/* お届け先追加･変更 mypage/re_mypage_2.html
----------------------------------------------- */
.re-mypage-box {
  margin-bottom: 0;
  padding: 30px 140px 25px;
  background: #f5f5f5;
  color: #666;
}
.re-mypage-box h2 {
  font-size: 21px;
  font-weight: normal;
  text-align: center;
  margin: 0 auto 40px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.re-mypage-box h2 span {
  display: block;
  font-size: 16px;
}
.re-mypage-caution {
  margin-bottom: 35px;
  font-size: 14px;
}
.re-mypage-caution span {
  color: #ea6136;
}
.re-mypage-form dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin-top: -20px;
}
.re-mypage-form dt {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 235px;
  flex-basis: 235px;
  max-width: 235px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.re-mypage-form dt span {
  color: #ea6136;
}
.re-mypage-form dd {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 235px);
  flex-basis: calc(100% - 235px);
  max-width: calc(100% - 235px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.re-mypage-form input,
.re-mypage-form textarea {
  border: 0;
  width: 100%;
  font-size: 14px;
  line-height: 27px;
}
.re-mypage-form textarea {
  resize: none;
  padding: 10px;
}
.re-mypage-form-2column {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  align-items: center;
  justify-content: space-between;
}
.re-mypage-form-2column input {
  -webkit-flex-basis: 48%;
  flex-basis: 48%;
  max-width: 48%;
  flex-grow: 1;
  flex-shrink: 1;
  border: none;
}
.re-mypage-form-2column input:first-child {
  float: left;
}
.re-mypage-form-2column input:last-child {
  float: right;
}
.re-mypage-form-address,
.re-mypage-form-tel,
.re-mypage-form-address-search,
.re-mypage-form-date {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}
.re-mypage-form-address input,
.re-mypage-form-tel input {
  height: 47px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 30%;
  flex-basis: 30%;
  max-width: 30%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  border: none;
}
.re-mypage-form-address span,
.re-mypage-form-tel span {
  width: 0;
  margin-left: -7px;
  line-height: 47px;
}
.re-mypage-form-address-button {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 30%;
  flex-basis: 30%;
  max-width: 30%;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  height: 47px;
  padding: 12px 5px;
  white-space: nowrap;
}
.re-mypage-form-address-button:hover {
  opacity: 0.8;
}
.re-mypage-form-address-search {
  color: #666;
  justify-content: flex-end;
}
.re-mypage-form-select {
  position: relative;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.re-mypage-form-select select {
  border: none;
  font-size: 14px;
  line-height: 27px;
}
.re-mypage-form-select:before {
  z-index: 1;
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "\f123";
  font-family: "IonIcons";
  pointer-events: none;
  color: #b7b7b7;
}
.re-mypage-form-submit {
  color: #fff;
  display: block;
  cursor: pointer;
  background-color: #b3b3b3;
  width: 50%;
  height: 45px;
  margin: 0 auto 70px;
}
.re-mypage-radio-box {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
.re-mypage-radio-item {
  position: relative;
  width: 60px;
}
.re-mypage-radio-item:last-child {
  margin-left: 50px;
}
.re-mypage-radio-item input[type="radio"] {
  display: none;
}
.re-mypage-radio-item input[type="radio"] + label {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  display: block;
  position: relative;
  padding: 0 0 0 28px;
  cursor: pointer;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.re-mypage-radio-item input[type="radio"] + label:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: white;
  border: 1px solid #b7b7b7;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.re-mypage-radio-item input[type="radio"] + label:hover {
  color: #b5b6b6;
}
.re-mypage-radio-item input[type="radio"] + label p {
  margin-bottom: 0;
}
.re-mypage-radio-item input[type="radio"]:checked + label {
  color: #666;
  background: none;
}
.re-mypage-radio-item input[type="radio"]:checked + label:before {
  border-color: #666;
}
.re-mypage-radio-item input[type="radio"]:checked + label:after {
  content: "";
  display: block;
  position: absolute;
  left: 5px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: #666;
  border-radius: 50%;
}
.re-mypage-form-date input {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 30%;
  flex-basis: 25%;
  max-width: 30%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  border: none;
}
.re-mypage-form-date span {
  display: block;
  line-height: 47px;
}
.re-mypage-magazine-dt {
  margin-top: -28px !important;
}
.re-mypage-magazine {
  width: 100%;
  margin-left: 0 !important;
}
.re-mypage-caution-end {
  text-align: center;
  margin: 60px auto 40px;
}
.re-mypage-caution-end a {
  color: #666;
}
@media screen and (max-width: 768px) {
  .re-mypage-form-2column input {
    font-size: 12px;
    line-height: 24px;
  }
  .re-mypage-box {
    padding: 30px 7px 25px;
  }
  .re-mypage-box h2 {
    font-size: 15px;
    margin-bottom: 30px;
  }
  .re-mypage-box h2 span {
    font-size: 12px !important;
  }
  .re-mypage-caution {
    font-size: 12px;
    margin-bottom: 25px;
  }
  .re-mypage-form {
    margin-bottom: 20px;
  }
  .re-mypage-form dl {
    margin-top: -10px;
  }
  .re-mypage-form dt {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 20px;
    font-size: 12px;
  }
  .re-mypage-form dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 10px;
    font-size: 12px;
  }
  .re-mypage-form input,
  .re-mypage-form textarea {
    font-size: 12px;
    line-height: 24px;
  }
  .re-mypage-form-select select {
    border: none;
    font-size: 12px;
    line-height: 24px;
  }
  .re-mypage-form-address input {
    height: 44px;
    font-size: 12px;
    line-height: 24px;
    -webkit-flex-basis: 32%;
    flex-basis: 32%;
    max-width: 32%;
  }
  .re-mypage-form-tel input,
  .re-mypage-form-date input {
    height: 44px;
  }
  .re-mypage-form-address span,
  .re-mypage-form-tel span,
  .re-mypage-form-date span {
    line-height: 44px;
  }
  .re-mypage-form-address-button {
    white-space: nowrap;
    text-align: center;
    padding: 9px 0;
    line-height: 16px;
    height: 32px;
  }
  .re-mypage-form-submit {
    width: 80%;
    margin: 30px auto 0;
    font-size: 12px;
  }
  .re-mypage-magazine-dt {
    margin-top: 20px !important;
  }
  .re-mypage-magazine {
    width: 100%;
    margin-bottom: 20px;
  }
  .re-mypage-caution-end {
    text-align: left;
    font-size: 12px;
    margin: 50px auto 30px;
  }
  .re-mypage-no-text {
    margin-top: 0 !important;
  }
}
/* ifx180905
----------------------------------------------- */
/* お届け先追加･変更 mypage/re_mypage_3.html
----------------------------------------------- */
.terms-of-service {
  padding: 50px 0 60px;
  line-height: 28px;
  width: 100%;
  background: #fff;
  color: #666;
}
.terms-of-service h1 {
  font-size: 21px;
  font-weight: normal;
  margin-bottom: 20px;
}
.terms-of-service-icon-close {
  float: right;
  font-size: 24px;
  cursor: pointer;
  margin-top: -2px;
}
.terms-of-service h2 {
  font-size: 14px;
  font-weight: normal;
  margin-top: 40px;
}
.terms-of-service ul {
  margin-top: 40px;
}
.terms-of-service-important {
  border-top: 1px solid #666;
  border-bottom: 1px solid #666;
  line-height: 28px;
  padding: 20px 0;
}
.terms-of-service-important p {
  margin: 0;
}
.terms-of-service-block p {
  margin: 0;
}
.terms-of-service-block h3 {
  font-size: 14px;
  font-weight: normal;
  margin-top: 40px;
}
.terms-of-service-close {
  display: block;
  line-height: 45px;
  width: 335px;
  border: 1px solid #666;
  text-align: center;
  text-decoration: none !important;
  margin: 110px auto 10px;
}

@media screen and (max-width: 768px) {
  .terms-of-service h1 {
    font-size: 15px;
    margin-bottom: 15px;
  }
  .terms-of-service-icon-close {
    font-size: 18px;
    margin-right: 12px;
  }
  .terms-of-service h2 {
    font-size: 12px;
    margin-top: 20px;
  }
  .terms-of-service-important {
    padding: 15px 0;
    font-size: 12px;
    line-height: 24px;
  }
  .terms-of-service ul {
    margin-top: 20px;
    font-size: 12px;
    line-height: 24px;
  }
  .terms-of-service-block h3 {
    font-size: 12px;
    margin-top: 20px;
  }
  .terms-of-service-block p {
    font-size: 12px;
    line-height: 24px;
  }
  .terms-of-service-close {
    margin-top: 45px;
  }
}

/* ifx180905
----------------------------------------------- */
/* お届け先追加･変更 mypage/change.html
----------------------------------------------- */
.mypage-change-box {
  width: 100%;
  background-color: #fff;
  padding: 90px 40px 10px;
  margin-bottom: 35px;
}
.mypage-change-box dt span {
  color: #f76236;
}
.mypage-change-box dd {
  color: #000;
}
.mypage-change-box dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
.mypage-change-box dt {
  margin-bottom: 30px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 235px;
  flex-basis: 235px;
  max-width: 235px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.mypage-change-box dt span {
  color: #ea6136;
}
.mypage-change-box dd {
  margin-bottom: 30px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 235px);
  flex-basis: calc(100% - 235px);
  max-width: calc(100% - 235px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.mypage-change-box-paddingleft {
  padding-left: 15px;
}
.mypage-change-box-button {
  color: #fff;
  display: block;
  cursor: pointer;
  background-color: #b3b3b3;
  width: 50%;
  height: 45px;
  margin: 0 auto 5px;
}
@media screen and (max-width: 768px) {
  .mypage-change-box {
    padding: 15px 20px;
    margin-bottom: 20px;
  }

  .mypage-change-box dt {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin: 25px 0 0;
    font-size: 12px;
  }
  .mypage-change-box dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 5px;
    margin-bottom: 0;
    font-size: 12px;
  }
  .mypage-change-box-paddingleft {
    padding-left: 0;
  }
  .mypage-change-box-button {
    width: 80%;
    margin: 30px auto 0;
    font-size: 12px;
  }
}
/* ifx180905
----------------------------------------------- */
/* お届け先追加･変更 mypage/refusal.html
----------------------------------------------- */
.mypage-refusal-box {
  margin-bottom: 40px;
  padding: 30px 30px 60px;
  background: #f5f5f5;
}
.mypage-refusal-box h2 {
  font-size: 21px;
  font-weight: normal;
  text-align: center;
  margin: 0 auto 40px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.mypage-refusal-box p {
  color: #ea6136;
  text-align: center;
  font-size: 14px;
  line-height: 28px;
}
.mypage-refusal-button-yes {
  color: #fff;
  display: block;
  background-color: #b3b3b3;
  width: 50%;
  height: 45px;
  text-align: center;
  line-height: 45px;
  margin: 50px auto 20px;
}
.mypage-refusal-button-yes:hover {
  opacity: 0.8;
  color: #fff;
}
.mypage-refusal-button-no {
  color: #666;
  display: block;
  border: 1px solid #666;
  background-color: #fff;
  width: 50%;
  height: 45px;
  text-align: center;
  line-height: 45px;
  margin: 0 auto;
}
.mypage-refusal-button-no:hover {
  opacity: 0.8;
  color: #666;
}
@media screen and (max-width: 768px) {
  .mypage-refusal-box {
    margin-bottom: 40px;
    padding: 25px 9px 35px;
  }
  .mypage-refusal-box h2 {
    font-size: 15px;
  }
  .mypage-refusal-box p {
    font-size: 12px;
    line-height: 24px;
    text-align: left;
  }
  .mypage-refusal-box br {
    display: none;
  }
  .mypage-refusal-button-yes,
  .mypage-refusal-button-no {
    width: 85%;
  }
}
/* ifx180910
----------------------------------------------- */
/* お届け先追加･変更 contact/index.html
----------------------------------------------- */
.contact-box {
  color: #666;
}
.contact-box h1 {
  font-size: 21px;
  font-weight: normal;
  text-align: center;
  margin: 60px auto 40px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.contact-caution {
  width: 100%;
  /* max-width: 810px; */
  margin: 0 auto 40px;
  list-style-type: none;
  padding-left: 1.5em;
  text-indent: -1.5em;
  /* list-style-position: inside; */
  font-size: 14px;
  line-height: 28px;
}
.contact-caution li {
  padding-bottom: 20px;
}

.contact-caution span a {
  color: #ea6136;
  text-decoration: none;
}
.contact-box-inner {
  margin-bottom: 0;
  padding: 30px 0 25px;
  background: #f5f5f5;
  color: #666;
}
.contact-box-form {
  padding: 0 150px;
}
.contact-box-form dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin-top: -20px;
}
.contact-box-form dt {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 235px;
  flex-basis: 235px;
  max-width: 235px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-box-form dt span {
  color: #ea6136;
}
.contact-box-form dd {
  margin-top: 20px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 235px);
  flex-basis: calc(100% - 235px);
  max-width: calc(100% - 235px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-box-form input,
.contact-box-form textarea {
  border: 0;
  width: 100%;
  font-size: 14px;
  line-height: 27px;
}
.contact-box-form textarea {
  resize: none;
  padding: 10px;
}
.contact-textarea {
  display: table !important;
  width: 100%;
  padding-top: 50px;
}
.contact-textarea dt {
  vertical-align: top;
  width: 235px;
  display: table-cell;
}
.contact-textarea dd {
  display: table-cell;
}
.contact-box-form-caution {
  width: 90%;
  max-width: 810px;
  margin: 0 auto 40px;
  padding-left: 1.5em;
  text-indent: -1.5em;
  list-style-type: disc;
  list-style-position: inside;
  font-size: 14px;
  line-height: 28px;
}
.contact-box-form-submit {
  color: #fff;
  cursor: pointer;
  display: block;
  background-color: #b3b3b3;
  width: 50%;
  height: 45px;
  margin: 50px auto 70px;
}
@media screen and (max-width: 768px) {
  .contact-box h1 {
    font-size: 15px;
    margin: 45px auto 30px;
  }
  .contact-caution {
    font-size: 12px;
    line-height: 20px;
  }
  .contact-box-inner {
    padding-top: 0;
  }
  .contact-box-form {
    padding: 0 7px;
  }
  .contact-textarea {
    display: -webkit-flex !important;
    display: flex !important;
    margin: 0 auto;
    max-width: 100%;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: center;
    padding-top: 20px;
  }
  .contact-box-form dl,
  .contact-textarea {
    margin-top: -10px;
  }
  .contact-box-form dt,
  .contact-textarea dt {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 20px;
    font-size: 12px;
  }
  .contact-box-form dd,
  .contact-textarea dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 10px;
    font-size: 12px;
  }
  .contact-box-form input,
  .contact-box-form textarea {
    font-size: 12px;
    line-height: 24px;
  }
  .contact-box-form-caution {
    display: none;
  }
  .contact-box-form-submit {
    width: 80%;
    margin: 30px auto 5px;
  }
}
/* ifx180910
----------------------------------------------- */
/* お届け先追加･変更 contact/index_2.html
----------------------------------------------- */
.contact-box h2 {
  font-size: 17px;
  font-weight: normal;
  text-align: center;
  margin: -40px auto 50px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
.contact-box-confirm {
  padding: 30px 100px 25px;
  background: #f5f5f5;
  color: #666;
}
.contact-box-confirm-inner {
  width: 100%;
  background-color: #fff;
  padding: 40px 40px 10px;
  margin-bottom: 35px;
}
.contact-box-confirm-inner dt span {
  color: #f76236;
}
.contact-box-confirm-inner dd {
  color: #000;
}
.contact-box-confirm-inner dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
.contact-box-confirm-inner dt {
  margin-bottom: 30px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 235px;
  flex-basis: 235px;
  max-width: 235px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-box-confirm-inner dt span {
  color: #ea6136;
}
.contact-box-confirm-inner dd {
  margin-bottom: 30px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 235px);
  flex-basis: calc(100% - 235px);
  max-width: calc(100% - 235px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-box-confirm-button {
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
  width: 90%;
  max-width: 700px;
  margin: 0 auto;
}
.contact-box-confirm-button button:first-child {
  color: #fff;
  cursor: pointer;
  background-color: #b3b3b3;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 335px;
  flex-basis: 335px;
  max-width: 335px;
  height: 45px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-box-confirm-button button:last-child {
  color: #4e4e4e;
  cursor: pointer;
  background-color: #fff;
  border: 1px solid #4e4e4e;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 335px;
  flex-basis: 335px;
  max-width: 335px;
  height: 45px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.contact-box-confirm-inner-caution {
  margin-top: 30px;
  text-align: center;
}
.contact-box-confirm-caution {
  width: 90%;
  max-width: 810px;
  margin: 40px auto 0;
  padding-left: 1.5em;
  text-indent: -1.5em;
  list-style-type: disc;
  list-style-position: inside;
  font-size: 14px;
  line-height: 28px;
}
@media screen and (max-width: 768px) {
  .contact-box h2 {
    font-size: 12px;
    margin: -30px auto 20px;
  }
  .contact-box-confirm {
    padding: 30px 10px 25px;
  }
  .contact-box-confirm-inner {
    padding: 15px 15px 50px;
    margin-bottom: 20px;
  }

  .contact-box-confirm-inner dt {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin: 25px 0 0;
    font-size: 12px;
  }
  .contact-box-confirm-inner dd {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-top: 5px;
    margin-bottom: 0;
    font-size: 12px;
  }

  .contact-box-confirm-button {
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: center;
  }

  .contact-box-confirm-button button:first-child,
  .contact-box-confirm-button button:last-child {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    margin-bottom: 15px;
  }
}
/* ifx180910
----------------------------------------------- */
/* お届け先追加･変更 contact/index_3.html
----------------------------------------------- */
.contact-box-thank-box {
  width: 100%;
  max-width: 700px;
  margin: 0 auto 40px;
  font-size: 14px;
  line-height: 28px;
}
.contact-box-thank-box p {
  margin-bottom: 30px;
}
.contact-box-thank-box p:last-child {
  text-align: right;
}
.contact-box-thank-button button {
  display: block;
  color: #4e4e4e;
  cursor: pointer;
  width: 335px;
  background-color: #fff;
  border: 1px solid #4e4e4e;
  height: 45px;
  line-height: 45px;
  margin: 0 auto;
  text-align: center;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .contact-box-thank-button {
    font-size: 12px;
  }
  .contact-box-thank-box p {
    font-size: 12px;
    line-height: 24px;
  }
}

/* ifx180910
----------------------------------------------- */
/* お届け先追加･変更 contact/spraynozzle.html
----------------------------------------------- */

.contact-spray-caution {
  width: 90%;
  max-width: 810px;
  margin: -10px auto 30px;
  font-size: 14px;
  line-height: 28px;
}
.contact-spray-dt {
  margin-top: -55px !important;
}
.contact-spray-radio-box {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
.contact-spray-radio-item {
  width: 100%;
  margin-left: 0 !important;
  margin-bottom: 25px;
  position: relative;
}
.contact-spray-radio-item:last-child {
  margin-left: 50px;
}
.contact-spray-radio-item input[type="radio"] {
  display: none;
}
.contact-spray-radio-item input[type="radio"] + label {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  display: block;
  position: relative;
  padding: 0 0 0 28px;
  cursor: pointer;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-spray-radio-item input[type="radio"] + label:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: white;
  border: 1px solid #b7b7b7;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.contact-spray-radio-item input[type="radio"] + label:hover {
  color: #b5b6b6;
}
.contact-spray-radio-item input[type="radio"] + label p {
  margin-bottom: 0;
}
.contact-spray-radio-item input[type="radio"]:checked + label {
  color: #666;
  background: none;
}
.contact-spray-radio-item input[type="radio"]:checked + label:before {
  border-color: #666;
}
.contact-spray-radio-item input[type="radio"]:checked + label:after {
  content: "";
  display: block;
  position: absolute;
  left: 5px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: #666;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .contact-spray-dt {
    margin-top: 20px !important;
  }
}

.contact-spray-caution-2 {
  margin: 20px auto 0;
}

/* ifx180911
----------------------------------------------- */
/* お届け先追加･変更 products/*
----------------------------------------------- */

.products-archive-handcream-list {
  width: 660px !important;
  margin: 0 auto 100px;
  overflow: hidden;
}

.products-archive-fragrance-list {
  margin-bottom: 50px;
  overflow: hidden;
}

.products-archive-bodymilk-list,
.products-archive-haircare-list,
.products-archive-lipcream-list,
.products-archive-oil-list,
.products-archive-savon-list,
.products-archive-baby-list,
.products-archive-gauzetowel-list {
  overflow: hidden;
  margin-bottom: 100px;
}

.products-archive-bodymilk-list ul,
.products-archive-haircare-list ul,
.products-archive-lipcream-list ul,
.products-archive-oil-list ul,
.products-archive-savon-list ul,
.products-archive-fragrance-list ul,
.products-archive-baby-list ul,
.products-archive-gauzetowel-list ul {
  display: -webkit-flex;
  display: flex;
  text-align: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
  align-items: stretch;
}

.products-archive-bodymilk-list li,
.products-archive-haircare-list li,
.products-archive-lipcream-list li,
.products-archive-oil-list li,
.products-archive-savon-list li,
.products-archive-baby-list li,
.products-archive-gauzetowel-list li {
  text-align: left;
}

.products-archive-bodymilk-list dt,
.products-archive-haircare-list dt,
.products-archive-lipcream-list dt,
.products-archive-oil-list dt,
.products-archive-savon-list dt,
.products-archive-baby-list dt,
.products-archive-gauzetowel-list dt {
  display: block;
}

.products-archive-bodymilk-list span,
.products-archive-haircare-list span,
.products-archive-lipcream-list span,
.products-archive-oil-list span,
.products-archive-savon-list span,
.products-archive-baby-list span,
.products-archive-gauzetowel-list span {
  display: block;
  margin-bottom: 1em;
}

.products-archive-bodymilk-list a,
.products-archive-haircare-list a,
.products-archive-lipcream-list a,
.products-archive-oil-list a,
.products-archive-savon-list a,
.products-archive-baby-list a,
.products-archive-gauzetowel-list a {
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  .products-archive-handcream-list,
  .products-archive-fragrance-list {
    width: 100% !important;
    margin-bottom: 20px;
  }
  .products-archive-bodymilk-list,
  .products-archive-haircare-list,
  .products-archive-lipcream-list,
  .products-archive-oil-list,
  .products-archive-savon-list,
  .products-archive-baby-list,
  .products-archive-gauzetowel-list {
    margin-bottom: 20px;
  }
  .products-archive-bodymilk-list li,
  .products-archive-haircare-list li,
  .products-archive-lipcream-list li,
  .products-archive-oil-list li,
  .products-archive-savon-list li,
  .products-archive-baby-list li,
  .products-archive-gauzetowel-list li {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    padding: 0;
  }
  .products-archive-bodymilk-list dl,
  .products-archive-haircare-list dl,
  .products-archive-lipcream-list dl,
  .products-archive-oil-list dl,
  .products-archive-savon-list dl,
  .products-archive-baby-list dl,
  .products-archive-gauzetowel-list dl {
    display: -webkit-flex;
    display: flex;
    margin: 0 auto;
    max-width: 100%;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .products-archive-bodymilk-list dt,
  .products-archive-bodymilk-listt dd,
  .products-archive-haircare-list dt,
  .products-archive-haircare-list dd,
  .products-archive-lipcream-list dt,
  .products-archive-lipcream-list dd,
  .products-archive-oil-list dt,
  .products-archive-oil-list dd,
  .products-archive-savon-list dt,
  .products-archive-savon-list dd,
  .products-archive-baby-list dt,
  .products-archive-baby-list dd,
  .products-archive-gauzetowel-list dt,
  .products-archive-gauzetowel-list dd {
    padding: 0 10px;
    width: 50%;
  }
}

/* ifx180920
----------------------------------------------- */
/* フッターの編集/*
----------------------------------------------- */
@media screen and (max-width: 768px) {
  .footer-nav-list ul {
    text-align: center;
    justify-content: center;
  }
}
/* ifx180926
----------------------------------------------- */
/* 非会員購入ページ ログイン /*
----------------------------------------------- */
.shopping-login-title {
  width: 33.3%;
  margin: 0 auto 50px;
}
.shopping-login-title h1 {
  text-align: center;
  color: #666;
  font-size: 21px;
  font-weight: normal;
}
.shopping-three-columm {
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.shopping-three-columm > li {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 31%;
  flex-basis: 31%;
  max-width: 31%;
  padding: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.shopping-three-columm > li img {
  width: 100%;
}
.shopping-login-label {
  display: block;
  position: relative;
  padding-left: 25px;
  margin: 10px 2px 20px;
  font-size: 12px;
  color: rgba(33, 23, 20, 0.7);
}
.shopping-login-remember-button input[type="checkbox"] {
  display: none;
}
.shopping-login-label:hover:after {
  border-color: #0171bd;
}

.shopping-login-label:after,
.shopping-login-label:before {
  position: absolute;
  content: "";
  display: block;
  top: 50%;
}
.shopping-login-label:after {
  left: 0;
  margin-top: -7px;
  width: 12px;
  height: 13px;
  border: 1px solid #ccc;
}
.shopping-login-label:before {
  left: 3px;
  margin-top: -4px;
  width: 6px;
  height: 7px;
  background-color: #666;
  opacity: 0;
}
.shopping-login-remember-button input[type="checkbox"]:checked + .shopping-login-label:before {
  opacity: 1;
}

.shopping-login-box {
  width: 100%;
  margin: 0 auto;
  padding: 35px 10px 25px;
  background: #f5f5f5;
}
.shopping-login-box h2 {
  color: #666;
  margin: 0 auto 27px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 21px;
  font-weight: normal;
  text-align: center;
}
.shopping-login-register-box {
  width: 100%;
  margin: 0 auto;
  padding: 35px 10px 25px;
  background: #f5f5f5;
}
.shopping-login-register-box h2 {
  color: #666;
  margin: 0 auto 27px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 21px;
  font-weight: normal;
  text-align: center;
}
.shopping-login-register-box p {
  font-size: 14px;
  line-height: 28px;
  color: #666;
  margin-bottom: 35px;
  /*letter-spacing: 1px;*/
}
.shopping-login-register-box a {
  background: #b7b7b7;
  margin: 0 auto;
  text-align: center;
  font-size: 17px;
  color: #fff;
  display: block;
  padding: 10px 20px;
  text-decoration: none;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.shopping-login-submit {
  display: block;
  font-size: 17px !important;
  margin: 30px auto;
}
.shopping-login-guide {
  list-style: none;
  font-size: 14px;
  color: #666;
}
.shopping-login-guide a {
  color: #666;
}
.shopping-login-guide li {
  flex-basis: 100%;
  max-width: 100%;
}
.shopping-login-box-input {
  border: none !important;
  padding: 20px 0 20px 15px !important;
  font-size: 14px !important;
  color: #666;
}

@media screen and (max-width: 768px) {
  .shopping-login-title {
    margin-bottom: 40px;
  }
  .shopping-three-columm {
    margin-top: -20px;
  }
  .shopping-three-columm li {
    margin-top: 20px;
    padding: 0;
  }
  .shopping-three-columm li {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }
  .shopping-login-box,
  .shopping-login-register-box {
    width: 100%;
  }
  .shopping-login-register-box a {
    width: 85% !important;
  }
  .shopping-login-box h2,
  .shopping-login-register-box h2 {
    font-size: 15px;
  }
  .shopping-login-label {
    font-size: 11px;
    margin: 12px 1px 25px;
  }
  .shopping-login-register-box p,
  .shopping-login-register-box a {
    font-size: 12px !important;
  }
  .shopping-login-guide {
    font-size: 12px;
  }
  .shopping-login-register-box,
  .shopping-login-box {
    padding: 25px 10px;
  }
  .shopping-login-submit {
    width: 85% !important;
  }
}

/* FAQ /*
----------------------------------------------- */
.faq-menu-list {
  width: 100%;
  margin: 30px auto 60px;
}
.faq-menu-list ul {
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.faq-menu-list ul li {
  text-align: center;
  width: 49%;
  border: 1px solid #a7a3a1;
  margin-bottom: 30px;
}
.faq-menu-list ul li a {
  display: block;
  text-decoration: none;
  font-size: 14px;
  line-height: 36px;
}
.faq-menu-list ul .faq-col-3 {
  flex-basis: 22%;
}
.faq-menu-list ul .faq-col-6 {
  flex-basis: 50%;
}
.faq-block h1 {
  font-size: 21px;
  margin-top: 15px;
  color: #7a7675;
  background-color: #f5f5f5;
  font-weight: normal;
  text-align: center;
}
.faq-block h2 {
  font-size: 18px;
  line-height: 26px;
  margin-top: 20px;
  padding: 12px 0 12px 15px;
  border-top: 1px solid #bebbba;
  border-bottom: 1px solid #bebbba;
  color: #7a7675;
  font-weight: normal;
  text-align: left;
}
.faq-acMenu {
  margin-bottom: 45px;
}
.faq-acMenu-top {
  margin-top: 60px;
  margin-bottom: 0px !important;
}
.faq-acMenu dt {
  opacity: 0.7;
  margin-top: 20px;
  cursor: pointer;
  display: flex;
  line-height: 24px;
}
.faq-acMenu dt div:first-child {
  flex-basis: 35px;
  padding-left: 10px;
}
.faq-acMenu dd {
  color: #000;
  display: none;
  padding-left: 35px;
  margin-top: 10px;
}

.faq-acMenu dd ol li {
  list-style-type: decimal;
  margin: 0 0 10px 0em;
}

.dot-icon {
  list-style-type: disc !important;
  margin: 5px 0 5px 2em !important;
}

.faq-p-block {
  margin-top: 20px;
  color: #4b4c4c;
}

.faq-p-blcok-button {
  width: 340px;
  display: block;
  margin: 20px auto 30px;
  text-align: center;
  padding: 15px 0;
  color: #4b4c4c;
  border: 1px solid #4b4c4c;
  cursor: pointer;
  text-decoration: none !important;
}

.faq-p-blcok-button:hover {
  border: 1px solid #b5b6b6;
}

@media screen and (max-width: 768px) {
  .faq-menu-list {
    width: 100%;
    margin: 30px auto 0;
  }
  .faq-menu-list ul li {
    width: 100%;
    margin-bottom: 15px;
  }
  .faq-menu-list ul li a {
    font-size: 15px;
    line-height: 30px;
  }
  /* .faq-menu-list{
    width: 100%;
  }
  .faq-menu-list ul li{
    margin-bottom: 20px;
  } */
  .faq-menu-list ul .faq-col-3,
  .faq-menu-list ul .faq-col-6 {
    flex-basis: 100%;
  }
  .faq-block h1 {
    font-size: 15px;
    line-height: 40px;
    margin-top: 40px;
  }
  .faq-block h2 {
    font-size: 14px;
    line-height: 20px;
    text-align: center;
  }
  .faq-acMenu dt div:first-child {
    padding: 0 10px;
  }
  .faq-p-blcok-button {
    width: 240px;
    font-size: 12px;
    margin: 30px auto 0px;
    padding: 10px 0;
    color: #4b4c4c;
  }
}

/* SHOP-LIST /*
----------------------------------------------- */
.shoplist-menu-list {
  width: 690px;
  margin: 0 auto;
}
.shoplist-menu-list ul {
  display: -webkit-flex;
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
}
.shoplist-menu-list ul:first-child {
  width: 65%;
  margin: 0 auto;
}
.shoplist-menu-list ul li {
  text-align: center;
  font-size: 14px;
  margin-bottom: 20px;
}
.shoplist-menu-list ul li a {
  letter-spacing: 0.05em;
}
.shoplist-menu-list ul .shoplist-col-1 {
  flex-basis: 8%;
}
.shoplist-menu-list ul .shoplist-col-2 {
  flex-basis: 13.6%;
}
.shoplist-col-2-adjust {
  display: none;
}
.shoplist-menu-list ul .shoplist-col-4 {
  flex-basis: auto;
}
.shoplist-menu-list-brand {
  justify-content: center !important;
}
.shoplist-menu-list-brand li {
  flex-basis: auto;
}
.shoplist-menu-list-brand li:last-child {
  margin-left: 40px;
}
.shoplist-block {
  width: 755px;
  margin: 0 auto;
}
.shoplist-block h1 {
  font-size: 21px;
  margin: 15px 0 30px;
  color: #7a7675;
  background-color: #f5f5f5;
  font-weight: normal;
  text-align: center;
}
.shoplist-block .shoplist-innerblock:last-child {
  margin-bottom: 60px;
}
.shoplist-innerblock {
  display: flex;
  justify-content: space-between;
}
.shoplist-innerblock div {
  flex-basis: 48.5%;
}
.shoplist-innerblock div h3 {
  color: #585858;
  font-size: 16px;
  font-weight: normal;
}
.shoplist-innerblock div ul li {
  color: #585858;
  font-size: 14px;
  line-height: 28px;
}
.shoplist-innerblock div ul li dl {
  width: 300px;
}
.shoplist-innerblock div ul li dl::after {
  content: "";
  display: block;
  float: none;
  clear: both;
}
.shoplist-innerblock div ul li dl dt {
  float: left;
  clear: left;
  width: 75px;
}
.shoplist-innerblock div ul li dl dd {
  float: left;
  width: 225px;
}
.shoplist-innerblock div ul li a {
  color: #585858;
}
.shoplist-innerblock .shoplist-col-3 {
  flex-basis: 25%;
}
.shoplist-innerblock .shoplist-col-9 {
  flex-basis: 70%;
}
.shoplist-intro::after {
  content: "";
  display: block;
  float: none;
  clear: both;
}
.shoplist-intro p {
  color: #585858;
  display: block;
  float: right;
  width: 70%;
}
.shoplist-intro div {
  float: left;
  min-width: 180px;
  min-height: 140px;
  width: 25%;
  display: block;
  text-align: center;
}
.shoplist-intro .shoplist-col-5 {
  width: 41%;
}
.shoplist-intro .shoplist-col-7 {
  width: 58%;
}
.disp-sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .shoplist-menu-list {
    width: 100%;
    margin-bottom: 15px;
  }
  .shoplist-menu-list ul:first-child {
    width: 85%;
    margin: 0 auto 10px;
  }
  .shoplist-menu-list ul li {
    font-size: 14px;
    margin-bottom: 10px;
  }
  .shoplist-menu-list ul .shoplist-col-1 {
    flex-basis: 15%;
  }
  .shoplist-menu-list ul .shoplist-col-2 {
    flex-basis: 20%;
  }
  .shoplist-col-2-adjust {
    display: none;
    flex-basis: 20%;
  }
  .shoplist-menu-list ul .mt-30-sp {
    margin-top: 30px;
  }

  .shoplist-menu-list ul .shoplist-col-4 {
    flex-basis: 100%;
  }

  .shoplist-menu-list-brand li:last-child {
    margin-left: 0;
  }

  .shoplist-block {
    width: 100%;
  }

  .shoplist-innerblock {
    flex-wrap: wrap;
  }

  .shoplist-block h1 {
    margin: 15px 0;
  }

  .shoplist-innerblock div {
    flex-basis: 100%;
  }

  .shoplist-innerblock div img {
    width: 100%;
  }

  .shoplist-innerblock div h3 {
    font-size: 14px;
    font-weight: bold;
    line-height: 50px;
  }

  .shoplist-innerblock div ul li {
    font-size: 14px;
    line-height: 20px;
  }

  .shoplist-intro div {
    float: none;
    width: 100%;
  }

  .shoplist-intro p {
    float: none;
    width: 100%;
    font-size: 12px;
    line-height: 20px;
  }
  .shoplist-innerblock .shoplist-col-3 {
    flex-basis: 100%;
  }
  .shoplist-innerblock .shoplist-col-9 {
    flex-basis: 100%;
  }
  .shoplist-intro .shoplist-col-5 {
    width: 100%;
  }
  .shoplist-intro .shoplist-col-7 {
    width: 100%;
  }
  .disp-sp {
    display: inline;
  }
}
/* News /*
----------------------------------------------- */
.news-article-list {
}
.news-article-item {
  display: flex;
  justify-content: space-between;
  padding: 30px 0;
  border-bottom: 1px solid #dbdbdb;
}
.news-article-item div ul li {
  color: #585858;
  line-height: 24px;
}
.news-article-item div ul li h3 {
  font-size: 16px;
  margin-top: 25px;
  margin-bottom: 25px;
}
.news-article-item div:first-child {
  flex-basis: 350px;
}
.news-article-item div:last-child {
  flex-basis: 60%;
}
.news-pager {
  width: 260px;
  display: flex;
  justify-content: space-between;
  margin: 40px auto;
}
@media screen and (max-width: 959px) {
  .news-article-item div:last-child {
    padding-left: 20px;
  }
}

@media screen and (max-width: 768px) {
  .news-article-item {
    flex-wrap: wrap;
  }
  .news-article-item div ul li h3 {
    font-size: 16px;
    line-height: 28px;
    padding-bottom: 10px;
  }
  .news-article-item div:first-child {
    flex-basis: 100%;
    padding-bottom: 15px;
  }
  .news-article-item div:first-child img {
    width: 100%;
  }
  .news-article-item div:last-child {
    flex-basis: 100%;
    padding-left: 0;
  }
}

/* Order /*
----------------------------------------------- */
.order-list {
  width: 760px;
  margin: 0 auto;
  clear: both;
}
.order-item {
  display: flex;
  margin-bottom: 30px;
}
.order-item div:first-child {
  flex-basis: 180px;
  max-width: 180px;
  color: #7e7b7a;
}
.order-item div:last-child {
  flex-basis: 580px;
  max-width: 580px;
  line-height: 28px;
}
@media screen and (max-width: 768px) {
  .order-list {
    width: 100%;
  }
  .order-item {
    flex-wrap: wrap;
  }
  .order-item div:first-child {
    flex-basis: 100% !important;
    max-width: 100% !important;
  }
  .order-item div:last-child {
    flex-basis: 100% !important;
    max-width: 100% !important;
  }
}

/* About /*
----------------------------------------------- */
.about-div {
  width: 760px;
  margin: 0 auto;
}
.about-div img {
  padding-top: 20px;
}
.about-div h1 {
  line-height: 18px;
  font-size: 18px;
  color: #7e7b7a;
  text-align: center;
  margin-bottom: 25px;
}
.about-div p {
  color: #7e7b7a;
  line-height: 28px;
}
@media screen and (max-width: 768px) {
  .about-div {
    width: 100%;
    margin: 0 auto;
  }
  .about-div img {
    width: 100%;
  }
}

/* Story-index /*
----------------------------------------------- */
.story-top-columm {
  display: -webkit-flex;
  display: flex;
  padding: 0 20px;
  margin: 15px auto 0;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}
.story-top-columm li {
  flex-basis: 32.2%;
  max-width: 32.2%;
  padding: 0;
  margin-bottom: 50px;
}
.story-top-columm .disp-sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .story-top-columm .disp-pc {
    display: none;
  }
  .story-top-columm .disp-sp {
    display: block;
  }
  .story-top-columm {
    justify-content: space-around;
    padding: 0;
  }
  .story-top-columm li {
    flex-basis: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: 20px;
  }
  .story-top-columm li img {
    width: 100%;
  }
}

/* Story-inner /*
----------------------------------------------- */

.story-div {
  width: 755px;
  margin: 35px auto;
}
.story-div-title {
  text-align: center;
  padding-bottom: 25px;
}
.story-div-title-non-variable {
  text-align: center;
  padding-bottom: 25px;
}
.story-block {
  color: #7e7b7a;
  margin-bottom: 40px;
}
.story-block h2 {
  font-size: 18px;
  margin-bottom: 10px;
}
.story-mt-30 {
  margin-top: 30px;
}
.story-mt-90 {
  margin-top: 90px;
}
.story-mb-20 {
  margin-bottom: 20px;
}
.story-mb-0 {
  margin-bottom: 0;
}
.story-block-center {
  display: block;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
.story-link-block a {
  margin-bottom: 10px;
  font-weight: normal;
  color: #7e7b7a;
  text-decoration: none;
}
.story-block-2column {
  display: -webkit-flex;
  display: flex;
  margin-bottom: 20px;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}
.story-block-2column > div:first-child {
  flex-basis: 300px;
  max-width: 300px;
  margin: 0 auto;
}
.story-block-2column > div:last-child {
  flex-basis: 420px;
  max-width: 420px;
}
.story-2column-text div {
  color: #7e7b7a;
  margin-bottom: 30px;
}
.story-steps-block {
  margin-top: 15px;
}
.story-steps-block > div {
  display: -webkit-flex;
  display: flex;
  margin-bottom: 20px;
  max-width: 100%;
  justify-content: space-around;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
.story-steps-block > div > div:first-child {
  flex-basis: 50px;
  max-width: 50px;
}
.story-steps-block > div > div:last-child {
  flex-basis: 690px;
  max-width: 690px;
}
@media screen and (max-width: 768px) {
  .story-div {
    width: 100%;
  }
  .story-div-title img,
  .story-block img {
    width: 100%;
  }
  .story-block-2column > div:last-child {
    margin-top: 30px;
  }
  .story-block-2column > div {
    width: 100%;
  }
  .story-non-variable {
    width: auto !important;
  }
  .story-steps-block > div:last-child {
    margin-bottom: 0;
  }
  .story-steps-block > div > div:last-child {
    flex-basis: 300px;
    max-width: 300px;
  }
}
@media screen and (max-width: 465px) {
  .story-steps-block > div {
    justify-content: space-between;
  }
}
/* shopping guide /*
----------------------------------------------- */
.shopguide-menu-list {
  width: 100%;
  margin: 60px auto 0;
}
.shopguide-menu-list ul {
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.shopguide-menu-list ul li {
  text-align: center;
  width: 49%;
  border: 1px solid #a7a3a1;
  margin-bottom: 30px;
}
.shopguide-menu-list ul li a {
  display: block;
  text-decoration: none;
  font-size: 14px;
  line-height: 36px;
}
.shopguide-menu-list ul .shopguide-col-2 {
  flex-basis: 16.5%;
}
.shopguide-menu-list ul .shopguide-col-3 {
  flex-basis: 25%;
}
.shopguide-menu-list ul .shopguide-col-4 {
  flex-basis: 33.33%;
}
.shopguide-menu-list ul .shopguide-col-5 {
  flex-basis: 41.66%;
}
.shopguide-block h1 {
  font-size: 21px;
  margin-top: 15px;
  margin-bottom: 20px;
  color: #7a7675;
  background-color: #f5f5f5;
  font-weight: normal;
  text-align: center;
}
.shopguide-block {
  padding-bottom: 40px;
}
.shopguide-block p {
  color: #7a7675;
  margin-top: 15px;
  margin-bottom: 0;
}
.shopguide-block li {
  color: #7a7675;
}
.shopguide-block .mt-30 {
  margin-top: 30px;
}
.shopguide-block .mt-0 {
  margin-top: 0;
}
.shopguide-block .payment-table {
  border-collapse: collapse;
  border-spacing: 0;
  margin-top: 20px;
}
.shopguide-block .payment-table td {
  border: 1px solid #7a7675;
  color: #7a7675;
  padding: 5px 10px;
}
.shopguide-block .payment-table tbody tr td:last-child {
  text-align: right;
}
.shopguide-block .delivery-table {
  display: flex;
  margin-top: 20px;
  justify-content: space-between;
}
.shopguide-block .delivery-table table {
  flex-basis: 50%;
  border-collapse: collapse;
  border-spacing: 0;
}
.shopguide-block .delivery-table table td {
  color: #7a7675;
  border: 1px solid #7a7675;
  padding-left: 0px;
  text-align: center;
  vertical-align: middle;
}

.shopguide-block .delivery-table table .vt-top {
  vertical-align: top;
}

.shopguide-block .change-div h3 {
  font-weight: normal;
  color: #7a7675;
  margin-top: 30px;
}

.shopguide-block .change-div p {
  margin: 0;
  text-indent: 1rem;
}

.delivery-table-brown {
  background-color: #c0ae8c;
  color: #fff !important;
}

.delivery-table-blue {
  background-color: #97c4dc;
  color: #fff !important;
}

.delivery-table-note {
  width: 50%;
}

.delivery-table-note p {
  margin: 0;
}

.delivery-table-img {
  width: 80%;
  margin-top: 20px;
}

@media screen and (max-width: 768px) {
  .shopguide-menu-list {
    width: 100%;
    margin: 30px auto 0;
  }
  .shopguide-menu-list ul li {
    width: 100%;
    margin-bottom: 15px;
  }
  .shopguide-menu-list ul li a {
    font-size: 15px;
    line-height: 30px;
  }
  .shopguide-menu-list ul .shopguide-col-2,
  .shopguide-menu-list ul .shopguide-col-3,
  .shopguide-menu-list ul .shopguide-col-4,
  .shopguide-menu-list ul .shopguide-col-5 {
    flex-basis: 100%;
  }
  .shopguide-block {
    padding-bottom: 20px;
  }
  .shopguide-block h1 {
    font-size: 15px;
    line-height: 40px;
  }
  .shopguide-block .mt-30 {
    margin-top: 20px;
  }
  .shopguide-block .mt-0 {
    margin-top: 0;
  }
  .shopguide-block .delivery-table {
    flex-wrap: wrap;
    justify-content: space-around;
  }
  .shopguide-block .delivery-table table {
    flex-basis: 100%;
    margin-bottom: 0px;
  }
  .shopguide-block p,
  .shopguide-block li,
  .shopguide-block .payment-table td,
  .shopguide-block .delivery-table table td {
    font-size: 14px;
  }

  .delivery-table-note {
    width: 100%;
  }

  .delivery-table-img {
    width: 100%;
  }
}
/* products/index.html 1105 /*
----------------------------------------------- */
.products-index-relation {
  display: block;
  margin: 50px 20px 0;
  padding: 20px 0;
  border-top: 1px solid #b7b7b7;
  border-bottom: 1px solid #b7b7b7;
}

.products-index-relation a {
  position: relative;
  text-decoration: none;
}

.products-index-relation dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 auto;
  max-width: 728px;
}

.products-index-relation dt {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 115px;
  flex-basis: 115px;
  max-width: 115px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.products-index-relation dd {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 115px);
  flex-basis: calc(100% - 115px);
  max-width: calc(100% - 115px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  padding-left: 45px;
}

.products-index-relation dd img {
  width: 100%;
  margin-bottom: 10px;
}

.products-index-relation dd i {
  margin-left: 0.5em;
  color: #b7b7b7;
}

@media screen and (max-width: 768px) {
  .products-index-relation dd {
    padding-left: 20px;
  }
}

/* shopping/confirm.html 1109 /*
----------------------------------------------- */
.title-edit-btn-div {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  position: relative;
}
.title-edit-btn-div .title-edit-btn {
  display: block;
  position: absolute;
  right: 0;
  height: 44px;
  padding: 8px 15px;
  background: #fff;
  text-decoration: none;
  border: 1px solid #b7b7b7;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  align-items: baseline;
}

@media screen and (max-width: 768px) {
  .title-edit-btn-div .title-edit-btn {
    padding: 2.5px 15px;
    height: 33px;
  }
}

/* recruit.html 1109 /*
----------------------------------------------- */

.est-body {
  background: #fff;
}
.est-header {
  max-width: 960px;
  margin: 35px auto 15px;
}
.est-header::after {
  content: "";
  display: block;
  clear: both;
  float: none;
}
.est-header-logo {
  width: 45%;
  float: left;
}
.est-header-menu {
  width: 55%;
  float: right;
}
.est-header-menu ul {
  display: flex;
  justify-content: space-between;
}
.est-header-menu a {
  width: 32%;
  text-decoration: none;
  border-bottom: 1px solid #ccc;
}
.est-contents {
  max-width: 960px;
  margin: 35px auto 0;
}
.recruit h3,
.recruit p {
  text-align: center;
}
.recruit h3 {
  font-size: 15px;
  margin-top: 150px;
  margin-bottom: 50px;
}
.recruit p {
  line-height: 2rem;
  margin-bottom: 200px;
}
.est-footer {
  max-width: 960px;
  margin: 0 auto;
  color: #a9a7a6;
  border-top: 1px solid #a9a7a6;
}
.est-footer p {
  text-align: right;
  margin-top: 10px;
  font-size: 9px;
}
@media screen and (max-width: 768px) {
  .est-header-logo {
    width: 40%;
  }
  .est-header {
    width: 95%;
  }
  .est-header-logo img {
    width: 100%;
  }
  .est-header-menu a {
    width: 30%;
    font-size: 9px;
  }
  .est-contents {
    max-width: 95%;
  }
}
/* wrapping.html 250109 /*
----------------------------------------------- */

.wrapping-intro {
  padding-top: 20px;
}
.wrapping-intro p {
  color: #7e7b7a;
  font-size: 14px;
  padding: 10px 0 10px;
}
.wrapping-block h1 {
  font-size: 21px;
  margin-top: 15px;
  color: #7a7675;
  background-color: #f5f5f5;
  font-weight: normal;
  text-align: center;
}
.wrapping-block p {
  color: #7e7b7a;
  font-size: 14px;
  padding: 10px 0 10px;
  letter-spacing: 0.06rem;
}
.wrapping-block .wrapping-block-inner {
  width: 765px;
  margin: 0 auto;
}
.wrapping-block .wrapping-block-inner p {
  margin-top: 20px;
}
.wrapping-block .wrapping-list {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0 15px;
}
.wrapping-list-item {
  width: 161px;
  padding-bottom: 15px;
}
.wrapping-list-item p {
  font-size: 11px;
  margin-top: 0 !important;
  padding: 5px 0 0 !important;
}

.wrapping-big-item{
  display: flex;
  justify-content: space-between;
  margin: 40px auto 60px;
  padding: 0 15px;
}

.wrapping-big-item img{
  width: 48%;
}

.wrapping-big-item > div{
  width: 48%;
  font-size: 14px;
  line-height: 24px;
}

.wrapping-big-item > div p{
  font-size: 12px;
  line-height: 22px;
  margin: 10px 0 0 0!important;
  padding: 0;
}

.wrapping-block-2column {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 30px;
}
.wrapping-block-2column div:first-child {
  width: 68%;
}
.wrapping-block-2column div:first-child p {
  font-size: 14px;
  line-height: 26px;
  padding: 0;
  margin-top: 0 !important;
}
.wrapping-block-2column div:last-child {
  width: 30%;
}


@media screen and (max-width: 768px) {
  .wrapping-block-2column {
    margin-top: 20px;
  }
  .wrapping-block .wrapping-block-inner {
    width: 100%;
  }
  .wrapping-block .wrapping-block-inner p {
    margin-top: 10px;
  }
  .wrapping-block-2column div:first-child {
    width: 100%;
  }
  .wrapping-block-2column div:last-child {
    width: 100%;
    text-align: center;
    padding-bottom: 20px;
  }

  .wrapping-block .wrapping-list {
    padding: 0 10px;
  }

  .wrapping-big-item{
    flex-wrap: wrap;
    margin: 20px auto 30px;
    padding: 0 10px;
  }
  
  .wrapping-big-item > img{
    width: 100%;
  }
  
  .wrapping-big-item > div{
    width: 100%;
    text-align: center;
    font-size: 14px;
    line-height: 24px;
  }

  .wrapping-big-item > div img{
    width: 130px;
    margin: 10px auto 5px;
  }
  
  .wrapping-big-item > div p{
    margin: 0!important;
    padding: 0;
  }
}
.imeon {
  ime-mode: active;
}
.imeoff {
  ime-mode: inactive;
}

.credit-security-code {
  width: calc(50% - 10px);
}

/* キャンセルボタンのサイズ修正 */
.mypage-form-button-cancel {
  color: rgb(51, 51, 51);
  display: block;
  background-color: rgb(245, 245, 245);
  width: 50%;
  height: 45px;
  margin: 60px auto 30px;
}

/* フォームのグレーアウトを修正(Firefox) */
@-moz-document url-prefix()* {
  #delivery_pref_code:disabled {
    background-color: #ddd;
    color: #bbb;
  }
}

/* 中継料注意文章 200624 イイツカ start*/
.confirm-caution-Relay-fee {
  width: 100%;
  margin: 0;
  color: #ea6136 !important;
  padding-right: 20px;
  text-align: right;
  font-weight: normal;
}

@media screen and (max-width: 768px) {
  .confirm-caution-Relay-fee {
    padding-right: 10px;
    font-size: 11px;
  }
}

/* 中継料注意文章 200624 イイツカ end*/

/* 正規品取扱について 200727 イイツカ end*/
.genuine-products-div {
  width: 755px;
  margin: 35px auto;
  color: #7e7b7a;
}

.genuine-products-title {
  font-size: 20px;
  line-height: 40px;
  text-align: center;
}

.genuine-products-sub-title {
  font-size: 16px;
  line-height: 40px;
  text-align: center;
  margin-bottom: 20px;
}

.genuine-products-sub-title br.pc-none,
.genuine-products-link-block h2 br.pc-none {
  display: none;
}

.genuine-products-block img {
  padding-bottom: 30px;
}

.genuine-products-block .underline {
  text-decoration: underline;
  font-weight: bold;
}

.genuine-products-block > p {
  margin-bottom: 30px;
}

.genuine-products-link-block {
  padding: 10px 0 0;
}

.genuine-products-link-block h2 {
  font-size: 16px;
  text-align: center;
  margin-bottom: 15px;
}

.genuine-products-link-block-inner {
  width: 520px;
  margin: 0 auto;
  padding: 0 50px;
  border: 1px solid #828282;
}

.genuine-products-link-block-inner > p {
  margin: 15px 0;
}

@media screen and (max-width: 768px) {
  .genuine-products-div {
    width: 100%;
  }

  .genuine-products-title {
    font-size: 18px;
    line-height: 32px;
    margin-bottom: 5px;
  }

  .genuine-products-sub-title {
    font-size: 14px;
    line-height: 24px;
  }

  .genuine-products-sub-title br.pc-none,
  .genuine-products-link-block h2 br.pc-none {
    display: inline;
  }

  .genuine-products-block img {
    width: 100%;
  }

  .genuine-products-link-block h2 {
    font-size: 14px;
  }

  .genuine-products-link-block-inner {
    width: 95%;
    padding: 0 20px;
  }

  .genuine-products-link-block-inner a {
    word-break: break-all;
  }
}

@media screen and (max-width: 465px) {
  .genuine-products-link-block-inner {
    padding: 0 10px;
  }
}
/* 正規品取扱について 200727 イイツカ start*/

/* プライバシーポリシー */

.privacy-block {
  width: 760px;
  margin: 0 auto;
  clear: both;
}

.privacy-item h3 {
  font-size: 21px;
  margin-top: 45px;
  margin-bottom: 10px;
  color: #7a7675;
  font-weight: normal;
}

.privacy-item p,
.privacy-item ul li {
  line-height: 2;
}

.privacy-item .faq-p-blcok-button {
  margin: 50px auto 30px;
}

@media screen and (max-width: 768px) {
  .privacy-block {
    width: 100%;
  }
  .privacy-item h3 {
    font-size: 17px;
    line-height: 40px;
    margin-top: 40px;
  }
}

/* カートに個数制限を追加 211108 イイツカ start*/

/* プライバシーポリシー */
.cart-num-limit {
  float: right;
  padding: 15px 60px 15px;
  border: 1px solid #0e0f18;
  margin-top: 25px;
}

.cart-num-limit h4 {
  font-size: 16px;
  text-align: center;
  color: #ea6136;
  font-weight: normal;
  margin-bottom: 5px;
}

.cart-num-limit p {
  font-size: 14px;
  line-height: 28px;
  letter-spacing: 1.5px;
  text-align: center;
  color: #ea6136;
  margin-bottom: 0;
}

.cart-num-limit p a {
  color: #ea6136;
}

@media screen and (max-width: 768px) {
  .cart-list-total > .right {
    text-align: left !important;
    letter-spacing: 1px;
  }

  .cart-num-limit {
    margin-top: 30px;
    margin-bottom: 10px;
    float: none;
    padding: 15px 10px;
  }

  .cart-num-limit h4 {
    text-align: left;
  }

  .cart-num-limit p {
    text-align: left;
    letter-spacing: 1px;
  }
}

/* 新規登録画面の変更・追加 イイツカ start*/

.signup-flow {
  margin: 0 auto 40px;
  padding: 0 20px;
  max-width: 808px;
}

.signup-flow img {
  width: 100%;
}

.re-mypage-form-address-2 {
  display: -webkit-flex;
  display: flex;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

.re-mypage-form-address-2 input {
  -webkit-flex-basis: 48%;
  flex-basis: 48%;
  max-width: 48%;
  flex-grow: 1;
  flex-shrink: 1;
  border: none;
}

.re-mypage-form-address-button-2-wrap {
  -webkit-flex-basis: 48%;
  flex-basis: 48%;
  max-width: 48%;
  flex-grow: 1;
  flex-shrink: 1;
  border: none;
}

.re-mypage-form-address-button-2 {
  display: block;
  width: 60%;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  height: 47px;
  padding: 12px 5px;
  white-space: nowrap;
}

.re-mypage-form-candidate-list {
  position: absolute;
  z-index: 2000;
  left: 50%;
  transform: translate(-50%, 0%);
  -webkit-transform: translate(-50%, 0%);
  -ms-transform: translate(-50%, 0%);
  width: 460px;
  margin: 20px auto 0;
  padding: 15px 25px 20px;
  background-color: #fff;
  box-shadow: 0px 0px 12px -5px #a6a6a6;

  /* border: 1px solid #666666; */
}

.delivery-candidate-list {
  left: auto;
  transform: translate(0%, 0%);
  -webkit-transform: translate(0%, 0%);
  -ms-transform: translate(0%, 0%);
}

.re-mypage-form-candidate-list {
  display: none;
}

.re-mypage-form-candidate-list.open {
  display: block;
}

.re-mypage-form-candidate-list-close {
  position: absolute;
  top: 10px;
  right: 15px;
  line-height: 30px;
  font-size: 30px;
  cursor: pointer;
}

.re-mypage-form-candidate-list > h4 {
  font-size: 16px;
  text-align: center;
}

.re-mypage-form-candidate-list > p {
  font-size: 13px;
  text-align: center;
}

.re-mypage-form-candidate-list ul {
  height: 210px;
  overflow-y: auto;
}

.re-mypage-form-candidate-list ul li {
  display: flex;
  justify-content: start;
  align-items: center;
  margin-bottom: 10px;
}

.re-mypage-form-candidate-list ul li a {
  display: block;
  margin-right: 15px;
  width: 50px;
  font-size: 13px;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  height: 30px;
  padding: 4px 5px;
  white-space: nowrap;
}

.re-mypage-form-candidate-list ul li p {
  max-width: 80%;
  margin: 0;
  display: block;
  font-size: 13px;
  line-height: 16px;
}
.re-mypage-form-text p {
  margin: 0;
}

.login-thanks-box {
  width: 900px;
  margin: 0 auto;
  padding: 35px 150px 40px;
  background: #f5f5f5;
}
.login-thanks-box h2 {
  color: #666;
  margin: 0 auto 30px;
  padding: 0 20px;
  max-width: 808px;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 24px;
  font-weight: normal;
  text-align: center;
}
.login-thanks-box p {
  font-size: 17px;
  color: #666;
  margin-bottom: 35px;
  letter-spacing: 1px;
}
.login-thanks-box a {
  display: block;
  margin: 60px auto 30px;
  width: 50%;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  height: 47px;
  padding: 12px 5px;
  white-space: nowrap;
}

.re-mypage-form-mail-change {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.re-mypage-form-mail-change-button {
  display: block;
  width: 30%;
  font-size: 12px;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  height: 47px;
  padding: 12px 5px;
  white-space: nowrap;
}

.re-mypage-form-mail-popup {
  position: absolute;
  z-index: 2000;
  left: 50%;
  transform: translate(-50%, 0%);
  -webkit-transform: translate(-50%, 0%);
  -ms-transform: translate(-50%, 0%);
  width: 680px;
  margin: 20px auto 0;
  padding: 45px 25px 20px;
  background-color: #fff;
  box-shadow: 0px 0px 12px -5px #a6a6a6;

  /* border: 1px solid #666666; */
}

.re-mypage-form-mail-popup {
  display: none;
}

.re-mypage-form-mail-popup.open {
  display: block;
}

.re-mypage-form-mail-popup-close {
  position: absolute;
  top: 10px;
  right: 15px;
  line-height: 30px;
  font-size: 30px;
  cursor: pointer;
}

.re-mypage-form-mail-popup > p {
  font-size: 13px;
}

.mail-popup-input {
  display: flex;
  justify-content: right;
}

.mail-popup-input input {
  background-color: #f5f5f5;
  color: #333333;
}

.mail-popup-space {
  margin-bottom: 30px;
}

.mail-popup-input.mail input {
  width: 450px;
}
.mail-popup-input.code input {
  width: 225px;
  padding: 10px;
}

.mail-popup-input-wrap {
  text-align: right;
}

.mail-popup-input-wrap p {
  color: #cc0000;
  font-size: 13px;
  margin: 0;
}

.mail-popup-input a {
  display: block;
  width: 20%;
  font-size: 13px;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  height: 47px;
  padding: 12px 5px;
  white-space: nowrap;

  margin-left: 25px;
}

.deliv-list-item-error {
  color: #cc0000;
  font-size: 13px;
  margin: 0;
}

.deliv-list-item-error-border {
  border: 1px solid #9e1616 !important;
}

.address-change-popup {
  position: absolute;
  z-index: 1900;
  left: 50%;
  transform: translate(-50%, 0%);
  -webkit-transform: translate(-50%, 0%);
  -ms-transform: translate(-50%, 0%);
  width: 680px;
  margin: 20px auto 0;
  padding: 45px 25px 20px;
  background-color: #fff;
  box-shadow: 0px 0px 12px -5px #a6a6a6;

  /* border: 1px solid #666666; */
}

.address-change-popup {
  display: none;
}

.address-change-popup.open {
  display: block;
}

.address-change-close {
  position: absolute;
  top: 10px;
  right: 15px;
  line-height: 30px;
  font-size: 30px;
  cursor: pointer;
}

.address-change-popup > p {
  font-size: 13px;
}

.address-change-popup input {
  background-color: #f5f5f5;
  color: #333333;
}
.address-change-popup .alert-msg {
  color: #f00;
}
.address-change-popup-button {
  display: flex;
  justify-content: right;
  align-items: center;
  margin-top: 50px;
}
.address-change-popup-button a {
  display: block;
  width: 130px;
  font-size: 13px;
  text-align: center;
  color: #fff !important;
  cursor: pointer;
  background-color: #b3b3b3;
  text-decoration: none !important;
  height: 47px;
  padding: 12px 5px;
  white-space: nowrap;
  margin-left: 10px;
}

.address-change-popup-button a:last-of-type {
  background-color: #d1d1d1;
}

.addaddress-change-popup-adjust {
  top: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

@media screen and (max-width: 768px) {
  .re-mypage-form-address-2 input {
    height: 44px;
    font-size: 12px;
    line-height: 24px;
    -webkit-flex-basis: 48%;
    flex-basis: 48%;
    max-width: 49%;
  }
  .re-mypage-form-address-button-2 {
    height: 44px;
  }
  .re-mypage-form-candidate-list {
    width: 87%;
  }
  .re-mypage-form-candidate-list > h4 {
    font-size: 14px;
  }
  .re-mypage-form-candidate-list > p {
    font-size: 11px;
    text-align: center;
  }
  .re-mypage-form-candidate-list ul li p {
    max-width: 75%;
  }
  .re-mypage-form-candidate-list ul {
    height: 230px;
  }

  .login-thanks-box {
    width: 100%;
    padding: 25px;
  }
  .login-thanks-box h2 {
    font-size: 15px;
  }
  .login-thanks-box p {
    font-size: 12px;
  }

  .login-thanks-box a {
    width: 65%;
    margin: 20px auto;
  }
  .re-mypage-form-mail-change-button {
    width: 35%;
    font-size: 12px;
  }

  .re-mypage-form-mail-popup {
    width: 87%;
  }
  .re-mypage-form-mail-popup > p {
    font-size: 11px;
  }
  .re-mypage-form-mail-popup ul li p {
    max-width: 75%;
  }

  .mail-popup-input {
    justify-content: space-between;
  }

  .mail-popup-input-wrap {
    text-align: left;
    width: 70%;
  }

  .mail-popup-input.mail input,
  .mail-popup-input.code input {
    width: 100%;
  }
  .mail-popup-input.mail mail-popup-input-wrap,
  .mail-popup-input.code mail-popup-input-wrap {
    width: 75%;
  }

  .mail-popup-input a {
    font-size: 12px;
    width: 20%;
    margin-left: 0;
  }

  .address-change-popup {
    width: 87%;
  }
  .address-change-popup-button {
    justify-content: space-between;
  }
  .address-change-popup-button a {
    width: 47%;
    margin-left: 0;
  }
}

/* ショップリストアイコン追加 220830 イイツカ start*/

.shoplist-top-text {
  text-align: center;
  margin-top: 10px;
  margin-bottom: 15px;
}

.shoplist-icon-desc {
  margin-bottom: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.shoplist-icon-desc div a {
  display: flex;
  justify-content: center;
  align-items: center;
}

.shoplist-icon-desc div:first-child {
  margin-right: 30px;
}

.shoplist-icon-desc div a img {
  margin-right: 10px;
}

.shoplist-icon-desc div a p {
  margin: 0;
}

.shoplist-icon-li {
  margin-top: 15px;
}

.shoplist-icon-li a {
  display: flex;
  align-items: center;
  justify-self: flex-start;
  margin-bottom: 15px;
}

.shoplist-icon-li img {
  margin-right: 15px;
}

.shoplist-sub-block {
  margin-top: 30px;
}

@media screen and (max-width: 768px) {
  .shoplist-top-text {
    font-size: 12px;
    margin: 0 auto 30px;
    padding: 0;
  }

  .shoplist-icon-li img {
    width: auto !important;
  }

  .shoplist-icon-desc {
    flex-wrap: wrap;
  }

  .shoplist-icon-desc div {
    margin-bottom: 15px;
  }

  .shoplist-icon-desc div:first-child {
    margin-right: 0;
  }

  .shoplist-sub-block {
    margin-top: 25px;
    margin-bottom: 10px;
    padding-top: 20px;
    border-top: 1px solid #ccc;
    font-size: 14px !important;
    line-height: 28px !important;
  }
}

/* story-7追加 220830 イイツカ start*/

.story-block-7 {
  color: #7e7b7a;
  margin-bottom: 40px;
  padding: 30px 0 10px;
  color: #5d7a57;
  border-top: 1px solid #5b7a57;
  border-bottom: 1px solid #5b7a57;
}

.story-block-7 h3 {
  font-size: 18px;
  line-height: 24px;
  margin-bottom: 40px;
  text-align: center;
}

.story-block-7-inner {
  width: 650px;
  margin: 0 50px;
}

.story-block-7-inner > div {
  display: flex;
  justify-content: start;
  align-items: center;
  margin-bottom: 30px;
}

.story-block-7-inner > div > div {
  width: 100px;
  display: flex;
  justify-content: end;
  align-items: center;
}

.story-block-7-inner div p {
  width: 550px;
  padding-left: 30px;
  margin-bottom: 0%;
}

.story-block-7-price {
  color: #7e7b7a;
  margin-bottom: 60px;
}

.story-block-7-price p {
  text-align: center;
}

.story-block-7-shoplist > h3 {
  font-size: 16px;
  line-height: 22px;
  color: #7e7b7a;
  margin-bottom: 30px;
}

.story-block-7-shoplist > h3 span {
  font-weight: normal;
}

.story-block-7-shoplist > p {
  text-align: center;
  color: #7e7b7a;
}

@media screen and (max-width: 768px) {
  .story-block-7-inner {
    width: 100%;
    margin: 0;
  }

  .story-block-7-inner > div {
    display: flex;
    justify-content: start;
    align-items: center;
    margin-bottom: 30px;
  }

  .story-block-7-inner > div > div {
    width: 8%;
    display: flex;
    justify-content: end;
    align-items: center;
  }

  .story-block-7-inner div p {
    width: 92%;
    padding-left: 20px;
    margin-bottom: 0%;
  }

  .story-block-7-price {
    margin-bottom: 40px;
  }

  .story-block-7-price p {
    text-align: left;
    margin-bottom: 5px;
  }

  .story-block-7-shoplist > h3 {
    font-size: 14px;
    margin-bottom: 15px;
  }

  .story-block-7-shoplist > p {
    text-align: left;
  }
}

/* TOPバナーエリア */

.top-banner-area {
  max-width: 960px;
  margin: -30px auto 50px;
}

.top-banner-item {
  border-bottom: 2px solid #c1c1c1;
  padding: 15px 0;
  box-sizing: border-box;
  position: relative;
}

.top-banner-item:first-child {
  border-top: 2px solid #c1c1c1;
}

.top-banner-item h4 br,
.top-banner-item p br {
  display: inline;
}

.top-banner-item h4 {
  font-size: 16px;
  line-height: 23px;
  margin-bottom: 10px;
  color: #221815;
}

.top-banner-item p {
  font-size: 14px;
  line-height: 24px;
  margin-bottom: 5px;
}

.top-banner-item a {
  text-decoration: underline;
}

.top-banner-item br.pc-none {
  display: none !important;
}

.top-banner-toggle {
  display: none;
}

.top-banner-label {
  font-size: 14px;
  line-height: 24px;
  margin-bottom: 5px;
  position: absolute;
  bottom: 15px;
  right: 0;
  opacity: 0.6;
  z-index: 2;
}

.top-banner-label img {
  width: 25px;
  margin-top: 5px;
  transition: all 0.3s;
}

.top-banner-toggle:checked + .top-banner-label > img {
  transform: rotate(180deg) !important;
  transition: all 0.3s;
}

.top-banner-label,
.top-banner-item-inner {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}

.top-banner-item-inner {
  /* visibility: hidden; */
  overflow: hidden;
  transition: all 0.5s ease-in-out;
}

.top-banner-item-1line {
  max-height: 55px;
}

.top-banner-item-2line {
  max-height: 80px;
}

.top-banner-item-3line{
  max-height: 105px;
}

.top-banner-item-4line {
  max-height: 130px;
}

.top-banner-item-pc-1-sp-2-line {
  max-height: 55px;
}

.top-banner-toggle:checked + .top-banner-label + .top-banner-item-inner {
  max-height: 1000px;
  visibility: visible;
  transition: all 0.5s ease-in-out;
}

@media screen and (max-width: 768px) {
  .top-banner-area {
    margin: 15px auto 25px;
    padding: 0 20px;
  }

  .top-banner-item {
    width: 100%;
    padding: 20px 25px 25px 0;
    margin: 0;
    border-bottom: 1px solid #c1c1c1;
  }

  .top-banner-item:first-child {
    border-top: 1px solid #c1c1c1;
  }

  .top-banner-item h4 {
    font-size: 16px;
    line-height: 23px;
    margin-bottom: 5px;
  }

  .top-banner-item p {
    font-size: 14px;
  }

  .top-banner-item h4 br,
  .top-banner-item p br {
    display: inline;
  }

  .top-banner-item br.pc-none {
    display: inline !important;
  }

  .top-banner-item br.sp-none {
    display: none !important;
  }

  .top-banner-label {
    font-weight: bold;
  }

  .top-banner-label br {
    display: none;
  }

  .top-banner-label img {
    width: 20px;
    margin-top: 0;
  }

  .top-banner-item-inner {
  }

  .top-banner-item-pc-1-sp-2-line {
    max-height: 80px;
  }
}

/* 手提げ袋有料化 カート改修 */

.cart-list-product-total {
  text-align: right;
}

.cart-list-product-total p {
  display: inline-block;
  border-top: 1px solid #b7b7b7;
  padding: 15px 20px 15px 0;
  margin: 0;
}

.cart-list-carrier-bag {
  margin: 0 auto;
  max-width: 100%;
  padding: 20px 0px;
  border-top: 1px solid #b7b7b7;
}

.cart-list-carrier-bag-bg {
  display: -webkit-flex;
  display: flex;
  padding: 40px 0;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: flex-start;
  background-color: #f2f2f2;
}

.cart-list-carrier-bag-bg div {
  width: 630px;
  padding-left: 45px;
}

.cart-list-carrier-bag-bg img {
  width: 260px;
}

.cart-list-carrier-bag-bg h4 {
  font-size: 15px;
  margin-bottom: 5px;
}

.cart-list-carrier-bag-bg p:nth-of-type(1) {
  font-size: 14px;
  margin-bottom: 5px;
}

.cart-list-carrier-bag-bg p:nth-of-type(2) {
  font-size: 14px;
  margin-bottom: 15px;
}

.cart-list-carrier-bag-button {
  padding: 10px 80px;
  text-decoration: none !important;
  background: #b7b7b7;
  width: 100%;
  font-size: 14px;
  font-size: 0.875rem;
  color: #fff !important;
  text-align: center;
  border: none;
  cursor: pointer;
}

.cart-list-carrier-bag-bg p:last-of-type {
  margin-top: 20px;
  margin-bottom: 0;
}

@media screen and (max-width: 768px) {
  .cart-list-product-total p {
    display: block;
  }

  .cart-list-carrier-bag-bg {
    padding: 0 0 15px;
  }

  .cart-list-carrier-bag-bg div {
    padding-left: 0;
    width: 90%;
    margin: 0 auto;
  }

  .cart-list-carrier-bag-bg h4 {
    font-size: 17px;
    text-align: center;
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .cart-list-carrier-bag-bg p {
    text-align: center;
    margin-bottom: 10px;
  }

  .cart-list-carrier-bag-bg p:nth-of-type(1) {
    margin-bottom: 15px;
  }

  .cart-list-carrier-bag-bg p:nth-of-type(3) {
    margin-top: 15px;
    margin-bottom: 15px;
  }

  .cart-list-carrier-bag-bg p:nth-of-type(4) {
    text-align: left;
  }

  .cart-list-carrier-bag-bg > div > img {
    display: block;
    width: 100%;
    margin: 0 auto;
    max-width: 450px;
  }

  .cart-list-carrier-bag-button {
    display: block;
    width: 100%;
    max-width: 450px;
    margin: 15px auto;
  }
}

/* 手提げ袋有料化 モーダルウィンドウ追加 */

.add-bag-modal {
  padding: 40px 30px;
  max-height: 700px;
  border: #000 1px solid;
  margin-bottom: 0;
  background-color: #fff;
}

.add-bag-modal-title {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.add-bag-modal-title h4 {
  flex-basis: 50%;
  padding-left: 15%;
  margin: 15px 0 30px;
}

.add-bag-modal-title div {
  flex-basis: 37%;
}

.add-bag-modal-title span {
  flex-basis: 5%;
}

.add-bag-modal-title > div > a {
  display: block;
  padding: 10px 80px;
  text-decoration: none;
  background: #b7b7b7;
  width: 80%;
  margin-left: 20%;
  font-size: 14px;
  font-size: 0.875rem;
  color: #fff;
  text-align: center;
  border: none;
  cursor: pointer;
}

.add-bag-modal-title > div > input {
  width: 80%;
  margin-left: 20%;
}

.add-bag-modal-title > div > p {
  display: block;
  text-align: right;
  font-size: 13px;
  margin: 10px 0;
  color: #ff0000 !important;
}

.add-bag-modal-title-top-link {
  display: none;
}

.add-bag-modal-select form {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 70%;
  margin: 20px auto;
}

.add-bag-modal-select form > div {
  width: 30%;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.add-bag-modal-select form > div img {
  width: 100% !important;
  margin-bottom: 10px;
}

.add-bag-modal-select form > div div {
  width: 100%;
}

.add-bag-modal-select form > div p {
  font-weight: bold;
}

.add-bag-modal-select dl {
  display: -webkit-flex;
  display: flex;
  margin: 0 auto;
  max-width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}

.add-bag-modal-select dt {
  margin-bottom: 10px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 50px;
  flex-basis: 50px;
  max-width: 50px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.add-bag-modal-select dd {
  margin-bottom: 10px;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 50px);
  flex-basis: calc(100% - 50px);
  max-width: calc(100% - 50px);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.add-bag-modal-caution p {
  text-align: center;
  margin-bottom: 40px;
}

.add-bag-modal-note {
  border-top: 1px solid #c3c3c3;
  width: 70%;
  margin: 0px auto;
  padding: 40px 0;
}

.add-bag-modal-note h4 {
  font-size: 20px;
  line-height: 26px;
  text-align: center;
  margin-bottom: 12px;
}

.add-bag-modal-note > p{
  text-align: center;
  margin-bottom: 40px;
}

.add-bag-modal-note-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 50px;
}

.add-bag-modal-note-item > img {
  width: 30%;
}

.add-bag-modal-note-item > div {
  width: 67%;
}

.add-bag-modal-note-item > div > h5 {
  margin-bottom: 20px;
  font-size: 16px;
}

.add-bag-modal-note-item-last h5 {
  margin-bottom: 20px;
  font-size: 16px;
}

.add-bag-modal-go-top-button {
  display: none;
}

.add-bag-modal-note-sp-cart {
  display: none;
}

@media screen and (max-width: 768px) {
  .add-bag-modal-wrap {
    width: 90%;
    height: 80vh;
  }

  .add-bag-modal {
    padding: 15px 20px;
    max-height: unset;
  }

  .add-bag-modal-title {
    flex-wrap: wrap;
  }

  .add-bag-modal-title h4 {
    display: none;
    font-size: 15.5px;
    order: 2;
    flex-basis: 100%;
    padding-left: 0;
    text-align: center;
  }

  .add-bag-modal-title div {
    display: block;
    flex-basis: 80%;
  }

  .add-bag-modal-title > div > p {
    text-align: left;
    font-size: 15px;
    margin-top: 5px;
  }

  .add-bag-modal-title > div > input {
    width: 100%;
    margin-left: 0;
  }

  .add-bag-modal-title span {
    order: 1;
    flex-basis: 15%;
    text-align: right;
  }

  .add-bag-modal-title span img {
    width: 20px;
    margin-top: 7px;
  }

  .add-bag-modal-title-top-link {
    display: inline;
  }

  .add-bag-modal-select {
    margin-top: 20px;
  }

  .add-bag-modal-select form {
    width: 100% !important;
    flex-wrap: wrap;
    margin: 0 auto;
  }

  .add-bag-modal-select form > div {
    width: 100% !important;
    display: flex;
    justify-content: space-between;
    margin: 0 auto 5px;
  }

  .add-bag-modal-select form > div:last-of-type {
    margin: 0 auto 10px;
  }

  .add-bag-modal-select form > div p {
    font-size: 14px;
    font-weight: normal;
  }

  .add-bag-modal-select form > div img {
    /* height: 32vw; */
    /* object-fit: cover; */
    width: 42% !important;
    /* object-position: 50% 80%; */
  }

  .add-bag-modal-select form > div div {
    width: 55%;
  }

  .add-bag-modal-select dt {
    flex-basis: 35px;
    max-width: 35px;
    font-size: 13px;
  }

  .add-bag-modal-select dd {
    -webkit-flex-basis: calc(100% - 35px);
    flex-basis: calc(100% - 35px);
    max-width: calc(100% - 35px);
  }

  .add-bag-modal-select dd select {
    font-size: 12px;
  }

  .add-bag-modal-caution {
    width: 100%;
    margin: 0 auto;
  }

  .add-bag-modal-caution p {
    font-size: 14px;
    line-height: 20px;
    text-align: left;
    margin-bottom: 15px;
  }

  .add-bag-modal-note-sp-cart {
    display: block;
  }

  .add-bag-modal-note-sp-cart a {
    display: block;
    width: 90%;
    margin: 0 auto;
    padding: 10px 80px;
    text-decoration: none;
    background: #b7b7b7;
    font-size: 14px;
    font-size: 0.875rem;
    color: #fff;
    text-align: center;
    border: none;
    cursor: pointer;
  }

  .add-bag-modal-note-sp-cart p {
    display: block;
    text-align: center;
    margin: 10px 0;
    font-size: 13px;
    line-height: 20px;
    color: #ff0000 !important;
  }

  .add-bag-modal-note {
    width: 100%;
    margin: 20px 0 0;
    padding: 40px 0 0;
  }

  .add-bag-modal-note h4 {
    font-size: 15px;
    line-height: 20px;
    margin-bottom: 20px;
  }

  .add-bag-modal-note > p{
    text-align: left;
    margin-bottom: 40px;
  }

  .add-bag-modal-note-item {
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 40px;
  }

  .add-bag-modal-note-item > img {
    width: 65%;
    margin-bottom: 20px;
  }

  .add-bag-modal-note-item > div {
    width: 100%;
  }

  .add-bag-modal-note-item > div > h5 {
    text-align: center;
    font-size: 15px;
    margin-bottom: 5px;
  }

  .add-bag-modal-note-item > div > p {
    text-align: center;
    font-size: 13px;
    margin-bottom: 5px;
  }

  .add-bag-modal-note-item > div > p:last-of-type {
    text-align: center;
    font-size: 13px;
    line-height: 25px;
  }

  .add-bag-modal-note-item-last {
    border-top: 1px solid #c3c3c3;
  }

  .add-bag-modal-note-item-last h5 {
    font-size: 16px;
    margin-top: 25px;
    margin-bottom: 10px;
  }

  .add-bag-modal-note-item-last p {
    text-align: left;
    font-size: 13px;
    line-height: 28px;
    margin-bottom: 5px;
  }

  .add-bag-modal-go-top-button {
    display: block;
    margin: 30px auto 0px;
  }

  .add-bag-modal-go-top-button a {
    display: block;
    width: 100%;
    font-size: 12px;
    padding: 10px 0;
    color: #4b4c4c;
    text-align: center;
    border: 1px solid #4b4c4c;
    cursor: pointer;
    text-decoration: none !important;
  }

  .add-bag-modal-go-top-button a img {
    width: 13px;
    height: 12px;
    vertical-align: middle;
    margin-right: 10px;
  }

  .tm-content:after {
    padding-bottom: 10px;
  }
}

/* 手提げ袋有料化 選択後画面追加 */
.cart-list-bag-result {
  padding-top: 30px;
  border-top: 1px solid #b7b7b7;
}

.cart-list-bag-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  padding: 0px 25px 0 10px;
}

.cart-list-bag-item-left {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 160px;
  flex-basis: 160px;
  max-width: 160px;
  box-sizing: border-box;
  text-align: right;
}

.cart-list-bag-item-left img {
  width: 100px;
}

.cart-list-bag-item-right {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: calc(100% - 180px);
  flex-basis: calc(100% - 180px);
  max-width: calc(100% - 180px);
  box-sizing: border-box;
}

.cart-list-bag-item-right h5 {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 28%;
  flex-basis: 28%;
  max-width: 28%;
  box-sizing: border-box;
  padding: 0 10px;
}

.cart-list-bag-item-right p {
  margin-bottom: 0;
}

.cart-list-bag-item-right p:nth-of-type(1) {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 22%;
  flex-basis: 22%;
  max-width: 22%;
  box-sizing: border-box;
  padding: 0 10px;
  text-align: right;
}

.cart-list-bag-item-right p:nth-of-type(2) {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 28%;
  flex-basis: 28%;
  max-width: 28%;
  box-sizing: border-box;
  padding: 0 10px 0 30px;
  text-align: right;
}

.cart-list-bag-item-right p:nth-of-type(3) {
  flex-grow: 0;
  flex-shrink: 1;
  -webkit-flex-basis: 22%;
  flex-basis: 22%;
  max-width: 22%;
  box-sizing: border-box;
  padding: 0 10px;
  text-align: right;
}

.cart-list-bag-re-select {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.cart-list-bag-re-select div:first-of-type {
  margin-top: 10px;
  padding-left: 70px;
}

.cart-list-bag-re-select div a {
  padding: 10px 80px;
  text-decoration: none;
  background: #b7b7b7;
  width: 100%;
  font-size: 14px;
  font-size: 0.875rem;
  color: #fff;
  text-align: center;
  border: none;
  cursor: pointer;
}

.cart-list-bag-re-select div .important {
  margin-top: 20px;
  margin-bottom: 30px;
}

.cart-list-bag-re-select div:last-of-type {
  margin-top: auto;
}

@media screen and (max-width: 768px) {
  .cart-list-bag-result {
  }

  .cart-list-bag-item {
    width: 70%;
    margin: 0 auto 20px;
    padding: 0;
  }

  .cart-list-bag-item-left {
    -webkit-flex-basis: 35%;
    flex-basis: 35%;
    max-width: 35%;
  }

  .cart-list-bag-item-left img {
    width: 100%;
  }

  .cart-list-bag-item-right {
    -webkit-flex-basis: 62%;
    flex-basis: 62%;
    max-width: 62%;
    flex-wrap: wrap;
  }

  .cart-list-bag-item-right h5,
  .cart-list-bag-item-right p:nth-of-type(1),
  .cart-list-bag-item-right p:nth-of-type(2),
  .cart-list-bag-item-right p:nth-of-type(3) {
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
    text-align: left;
    padding: 0 10px;
    line-height: 28px;
  }

  .cart-list-bag-re-select {
    flex-wrap: wrap;
  }

  .cart-list-bag-re-select div:first-of-type {
    padding-left: 0;
    width: 75%;
    margin: 0 auto;
  }

  .cart-list-bag-re-select div a {
    display: block;
    padding: 10px 0px;
    width: 100%;
    max-width: 450px;
    margin: 20px auto;
  }

  .cart-list-bag-re-select div:last-of-type {
    width: 100%;
  }

  .cart-list-bag-re-select div:last-of-type p {
    padding: 15px 0 !important;
  }
}

/* top-link-list */
.top-link-list {
  margin-top: 50px;
}
.top-link-list img {
  width: 100%;
}
.top-link-list > a {
  display: block;
  margin-bottom: 30px;
}
.top-link-list-2col {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.top-link-list-2col a {
  width: 48%;
  margin-bottom: 0;
}

@media screen and (max-width: 768px) {
  .top-link-list-2col a {
    width: 100%;
    margin-bottom: 30px;
  }
}

/* about修正 230426 */
.about-link-list {
  width: 760px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 60px;
}

.about-link-list a {
  display: block;
  width: 48%;
  margin-bottom: 50px;
}

.about-link-list a img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .about-link-list {
    width: 100%;
    margin-top: 40px;
  }
  .about-link-list a {
    width: 100%;
    margin-bottom: 40px;
  }
}

.img100 {
  width: 100%;
}

.top-seasonal-banner {
  width: 100%;
  margin: 50px auto;
}

.top-seasonal-banner img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .top-seasonal-banner {
    margin: 25px auto;
  }
}

/* .x-icon追加 240130 */
.header-x-icon {
  width: 18px;
  height: 18px;
}

.footer-x-icon {
  width: 20px;
  height: 20px;
}

@media screen and (max-width: 768px) {
  .header-x-icon {
    width: 17px;
    height: 17px;
  }

  .footer-x-icon {
    width: 16px;
    height: 16px;
  }
}

.seasonal-2col {
  max-width: 1000px;
  margin: 0 auto;
  padding: 10px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

.seasonal-2col a {
  width: 48%;
  margin-bottom: 50px;
}

.seasonal-2col a img {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .seasonal-2col a {
    width: 100%;
    margin-bottom: 35px;
  }
}

/* コンビニ支払いの追加 */

.payment-cvs-summary-dl {
  display: flex;
  margin-bottom: 17.5px;
}

.payment-cvs-summary-dl dt{
  padding-right: 5px;
}

.payment-cvs-summary-dl dt,
.payment-cvs-summary-dl dd {
  color: #ea6136;
  font-size: 14px;
  line-height: 22px;
}

.payment-list-3col .shopping-button-list .radio{
  -webkit-flex-basis: calc(33% - 10px);
    flex-basis: calc(33% - 10px);
    max-width: calc(33% - 10px);
}

.payment-cvs-radio-box {
  display: -webkit-flex;
  display: flex;
  width: 100%;
  max-width: 470px;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  margin: 30px 0 10px;
}
.payment-cvs-radio-item {
  width: 33%;
  margin-left: 0 !important;
  margin-bottom: 20px;
  position: relative;
}
.payment-cvs-radio-item input[type="radio"] {
  display: none;
}
.payment-cvs-radio-item input[type="radio"] + label {
  color: #221817;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  display: block;
  position: relative;
  padding: 0 0 0 28px;
  cursor: pointer;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.payment-cvs-radio-item input[type="radio"] + label:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: white;
  border: 1px solid #b7b7b7;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
.payment-cvs-radio-item input[type="radio"] + label:hover {
  color: #b5b6b6;
}
.payment-cvs-radio-item input[type="radio"] + label p {
  margin-bottom: 0;
}
.payment-cvs-radio-item input[type="radio"]:checked + label {
  color: #666;
  background: none;
}
.payment-cvs-radio-item input[type="radio"]:checked + label:before {
  border-color: #666;
}
.payment-cvs-radio-item input[type="radio"]:checked + label:after {
  content: "";
  display: block;
  position: absolute;
  left: 5px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: #666;
  border-radius: 50%;
}

.payment-cvs-dl {
  display: flex;
  margin-bottom: 17.5px;
}

.payment-cvs-dl dt{
  padding-right: 5px;
}

.payment-cvs-dl dt,
.payment-cvs-dl dd {
  color: #666;
  font-size: 14px;
  line-height: 22px;
}

.payment-cvs-a{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
  max-width: 425px;
  margin-bottom: 25px;
}

.payment-cvs-a a{
  display: inline-block;
  padding: 0;
  line-height: 0;
  width: 48%;
  margin: 0 0 10px 0;
}

.payment-cvs-a a:hover{
  opacity: 0.8;
}

.payment-cvs-a a img{
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid #cccccc;
}

@media screen and (max-width: 768px) {
  .payment-list-3col .shopping-button-list .radio{
    -webkit-flex-basis: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }

  .payment-cvs-radio-box{
    padding-left: 30px;
    margin: 10px 0 10px;
  }

  .payment-cvs-radio-item{
    width: 100%;
  }

  .payment-cvs-a{
    width: 60%;
  }

  .payment-cvs-a a{
    width: 100%;
  }

}

/* コンビニ支払いの追加 */

.purchase-history-title {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.purchase-history-title::before {
  content: "";
  display: block;
  width: 200px;
}

.purchase-detail-button-wrap{
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 200px;
}

.cvs-check-button{
  display: block;
  width: 100%;
  margin-bottom: 10px;
  padding: 10px 25px;
  font-size: 14px;
  font-size: 0.875rem;
  text-decoration: none !important;
  text-align: center;
  background: #b7b7b7;
  color: #fff !important;
  border: none;
  cursor: pointer;
}

.purchase-detail-cancel-button{
  display: block;
  width: 100%;
  padding: 10px 25px;
  font-size: 14px;
  font-size: 0.875rem;
  text-align: center;
  background: #b3b3b3;
  border: none;
  cursor: pointer;
}

.purchase-detail-cancel-button:hover{
  opacity: 0.8;
  color: #333;
}

.check-cvs-modal{
  max-width: 750px;
}

.check-cvs-modal-content {
  padding: 40px 60px!important;
  max-height: 700px;
  background-color: #fff;
  margin: 0!important;
}

.check-cvs-modal-close{
  position: absolute;
  right: 30px;
  top: 30px;
}

.check-cvs-modal-inner {
}

.check-cvs-modal-inner h4 {
  font-size: 18px;
  line-height: 24px;
  color: #5b5b5b;
  margin-bottom: 20px;
  font-weight: normal;
}

.check-cvs-modal-inner ul{
  margin-bottom: 25px;
}

.check-cvs-modal-inner li{
  font-size: 14px;
  line-height: 30px;
  color: #585858;
}

.check-cvs-modal-inner p {
  font-size: 14px;
  line-height: 30px;
  color: #585858;
  margin-bottom: 20px;
}

.check-cvs-modal-inner p:last-child {
  margin-bottom: 0;

}

@media screen and (max-width: 768px) {
  .purchase-history-title::before {
    display: none;
  }
  .purchase-detail-button-wrap{
    position: relative;
    top: unset;
    right: unset;
    margin: 0 0 25px;
    max-width: 450px;
  }

  .cvs-check-button{
    display: inline-block;
    padding: 7px 20px;
  }

  .check-cvs-modal{
    width: 90%!important;
    height: 80vh!important;
  }

  .check-cvs-modal-content {
    padding: 75px 20px 0!important;
  }

  .check-cvs-modal-close img {
    width: 20px;
  }

  .check-cvs-modal-inner h4 {
    font-size: 18px;
    line-height: 20px;
    margin-bottom: 25px;
  }

  .check-cvs-modal-inner ul{
    margin-bottom: 30px;
  }

  .check-cvs-modal-inner li{
    font-size: 16px;
    line-height: 28px;
    color: #585858;
  }

  .check-cvs-modal-inner p {
    font-size: 16px;
    line-height: 26px;
    margin-bottom: 25px;
    color: #585858;
  }

  .check-cvs-modal-content.tm-content:after {
    padding-bottom: 0px!important;
    content: "";
    display: block;
  }

}