@charset "utf-8";

/*------------------------------------------------------------------------------
reset
------------------------------------------------------------------------------*/

html {
  color: #333;
  background: #fff;
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, sans-serif;
  font-size: 14px;
  line-height: 1.6;
  word-break: break-all;
}

/* IE10以降 游ゴシック文字ずれ対応 */

@media all and (-ms-high-contrast: none) {
  html {
    font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, Osaka, sans-serif, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic;
  }
}

body {
  background: #fff;
  margin: 0;
}

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

img {
  border: 0;
  margin: 0;
  vertical-align: top;
  max-width: 100%;
}

p {
  margin: 0 0 1em;
  padding: 0;
}

p:last-child {
  margin-bottom: 0;
}

a {
  color: #333;
  text-decoration: none;
}

input,
textarea,
select,
button {
  font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, sans-serif;
}

input[type="submit"],
input[type="text"],
select,
textarea,
button {
  -webkit-appearance: none;
  -webkit-box-shadow: none;
  box-shadow: none;
  outline: none;
}

::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: #bdbdbd;
  opacity: 1; /* Firefox */
}

:-ms-input-placeholder { /* Internet Explorer 10-11 */
  color: #bdbdbd;
}

::-ms-input-placeholder { /* Microsoft Edge */
  color: #bdbdbd;
}

select::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
}

button {
  border: none;
  cursor: pointer;
}

label {
  cursor: pointer;
}

table {
  border-collapse: collapse;
}

ul,
dl {
  list-style: none;
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 14px;
  font-weight: normal;
  margin: 0;
  padding: 0;
}

dd {
  margin: 0;
}

.outer-block {
  min-width: 1240px;
}

.inner-block {
  margin: 0 auto;
  padding: 0;
  position: relative;
  width: 1200px;
}

#wrapper {
  position: relative;
  min-width: 1240px;
}

@media screen and (min-width: 641px) {
  #wrapper {
    min-height: 100vh;
  }
}

.pc {
  display: block !important;
}

.pc-ib {
  display: inline-block !important;
}

.sp {
  display: none !important;
}

.sp-ib {
  display: none !important;
}

@media screen and (min-width: 641px) {
  a,
  a:after,
  a:before,
  a img:hover,
  button {
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
  }

  a:hover,
  button:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
  }
}

.display-none {
  display: none!important;
}


/*------------------------------------------------------------------------------
common
------------------------------------------------------------------------------*/

/* header sub-page
----------------------------------------*/
.sub-page header .user-menu-list > li {
  display: inline-block;
  background-color: #f5f5f5;
}

/* btn
----------------------------------------*/
.common-btn {
  display: inline-block;
  position: relative;
}

.common-btn a {
  display: block;
  background-color: #fff;
  border: solid 1px #e5e5e5;
  border-radius: 20px;
  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  color: #999;
  font-size: 16px;
  font-weight: bold;
  line-height: 40px;
  padding: 0 20px;
  min-width: 300px;
}

.common-btn a:after {
  content: "";
  background: url(../img/common/arrow_right_gray.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 6px;
  height: 10px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  right:20px;
}

@media screen and (min-width: 641px) {
  .common-btn a:hover {
    background-color: #d12248;
    border-color: #d12248;
    color: #fff;
    opacity: 1.0;
  }

  .common-btn a:hover:after {
    background-image: url(../img/common/arrow_right.svg);
  }
}

/* category-tag
----------------------------------------*/
.category-tag {
  display: inline-block;
  float: left;
  border-radius: 10px;
  font-size: 0;
  text-align: center;
  min-width: 50px;
  margin-right: 10px;
}

.all {
  background-color: #333;
}

.new {
  background-color: #d62249;
}

.speedy {
  background-color: #3399cc;
}

.hot {
  background-color: #bcc70c;
}

.popular {
  background-color: #f6ae35;
}

@media (min-width: 641px) {
  .speedy {
    padding: 0 9px;
  }
  .hot {
    padding: 0 5px;
  }
}

/* num-badge
----------------------------------------*/
.num-badge {
  background-color: #d12248;
  border-radius: 50%;
  font-size: 12px;
  text-align: center;
  line-height: 22px;
  width: 22px;
  height: 22px;

  position: absolute;
  top: -7px;
  right: -7px;
  z-index: 1;
}

/* border-bottom
----------------------------------------*/
.border-bottom {
  display: inline-block;
  font-size: 0;
  position: relative;
}

.border-bottom:after {
  background-color: #dc1943;
  background-position: bottom;
  content: "";
  display: block;
  width: 100%;
  height: 3px;
  margin-top: 5px;
}

/* select-menu
----------------------------------------*/
.select-menu-wrap {
  position: relative;
  display: inline-block;
}

.select-menu-wrap select,
.select-menu-wrap input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: white;
  display: inline-block;
  font-size: 14px;
  border: solid 1px #bdbdbd;
  border-radius: 3px;
  text-indent: 1em;
  width: 188px;
  height: 36px;
}

.select-menu-wrap select,
.select-menu-wrap input {
  cursor: pointer;
}

.select-menu-wrap:after {
  content: "";
  display: block;
  width: 8px;
  height: 6px;
  background: url(../img/common/arrow_select_bottom.svg) no-repeat;
  background-size: contain;
  background-position: right center;
  pointer-events: none;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  right: 10px;
}

.select-menu-wrap.num,
.select-menu-wrap.num select,
.select-menu-wrap.num input {
  width: 80px;
  text-align: right;
}

/* selectメニュー内部 */
/*the container must be positioned relative:*/
.select-menu-wrap {
  position: relative;
  width: 188px;
}
.select-menu-wrap select {
  display: none; /*hide original SELECT element:*/
}
.select-selected {
  background-color: #fff;
  border: solid 1px #bdbdbd;
  border-radius: 3px;
}

/*point the arrow upwards when the select box is open (active):*/
.select-selected.select-arrow-active:after {
  border-color: transparent transparent #fff transparent;
  top: 7px;
}
/*style the items (options), including the selected item:*/
.select-items div,
.select-selected {
  cursor: pointer;
  padding: 6px 30px 6px 14px;
}

.select-items div {
  padding: 2px 13px 2px 14px;
}
/*style items (options):*/
.select-items {
  position: absolute;
  background-color: #fff;
  border: solid 1px #bcc70c;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 99;
  overflow-y: scroll;
  max-height: 50vh;
}
/*hide the items when the select box is closed:*/
.select-hide {
  display: none;
}

.select-items div:hover, .same-as-selected {
  background-color: #bcc70c;
  color: #fff;
}

/* .block-ttl
----------------------------------------*/
.block-ttl {
  margin-bottom: 20px;
}

.block-ttl img {
  display: inline-block;
  border-bottom: solid 3px #dc1943;
  padding-bottom: 17px;
  height: 50px;
}

/* .info-txt-ttl
----------------------------------------*/
.info-txt-ttl {
  font-size: 18px;
  font-weight: bold;
  background-color: #f5f5f5;
  padding: 10px 20px;
}

/* .info-txt-block
----------------------------------------*/
.info-txt-block {
  margin-bottom: 40px;
}

.info-txt-block:last-child {
  margin-bottom: 0;
}

.info-txt-block p {
  margin-top: 30px;
  margin-bottom: 0;
}

.info-txt-block .red-l {
  color: #dc1943;
  font-weight: bold;
}

/* paging-block
----------------------------------------*/
.paging-block {
  font-size: 0;
}

.paging-block .page-numbers {
  display: inline-block;
  background-color: #f5f5f5;
  border-radius: 5px;
  font-size: 14px;
  text-align: center;
  line-height: 30px;
  min-width: 30px;
  height: 30px;
  padding: 0 5px;
  margin-bottom: 10px;
  vertical-align: middle;
}

.paging-block .page-numbers:not(.next) {
  margin-right: 10px;
}

.paging-block .page-numbers.current {
  background-color: #c33f5b;
  color: #fff;
}

.paging-block .prev,
.paging-block .next {
  position: relative;
}

.paging-block .prev:after,
.paging-block .next:after {
  content: "";
  display: inline-block;
  background: url(../img/common/arrow_paging.svg) center center no-repeat;
  background-size: contain;
  text-align: center;
  width: 6px;
  height: 10px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;

  -webkit-transform: translateX(-50%);
  -ms-transform:  translateX(-50%);
  -o-transform:  translateX(-50%);
  transform:  translateX(-50%);
}

.paging-block .prev:after {
  -webkit-transform: translateX(-50%) rotate(180deg);
  -ms-transform: translateX(-50%) rotate(180deg);
  -o-transform: translateX(-50%) rotate(180deg);
  transform: translateX(-50%) rotate(180deg);
}

/* cap-list
----------------------------------------*/
.cap-list li {
  margin-bottom: 30px;
}

.cap-list li:last-child {
  margin-bottom: 0;
}


/*------------------------------------------------------------------------------
header
------------------------------------------------------------------------------*/
#header {
  padding: 20px 0;
  position: relative;
  z-index: 100;
}

header .header-desc{
  background:#d12248;
  margin-bottom: 10px;
  margin-top:-20px;
}

header img {
  vertical-align: middle;
}

header .logo-wrap {
  display: inline-block;
  vertical-align: middle;

  position: absolute;
  top: 50%;
  bottom: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
}

header .logo-wrap .logo {
  position: absolute;
  top: -100%;
  bottom: -100%;
  left: 0;
  margin: auto;
  height: 61px;
  width: 203px;
  display: block;
}

header .desc {
  display: inline-block;
  /*margin: -70px 0 0 0;*/
  vertical-align: middle;
  font-size: 10px;
  color:#fff;
  padding: 5px 0;
}

header .user-menu-list {
  display: inline-block;
  background-color: #fff;
  border-radius: 3px;
  -webkit-box-shadow: 0 1px 0px rgba(0,0,0,0.1);
  box-shadow: 0 1px 0px rgba(0,0,0,0.1);
  float: right;
  font-size: 0;
}

header .user-menu-list > li {
  display: inline-block;
}

header .user-menu-list li > a,
header .user-menu-list .mypage-btn {
  color: #fff;
  background-color: #fff;
  display: inline-block;
  padding: 0 30px 0 50px;
  line-height: 60px;
  cursor: pointer;
}

header .user-menu-list .delivery {
  background: url(../img/common/delivary_desc.svg) 56px center no-repeat;
  border-radius: 3px 0 0 3px;
  width: 300px;
  height: 60px;
  vertical-align: middle;

  position: relative;
}

header .user-menu-list .delivery:before {
  content: "";
  background: url(../img/common/truck.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 24px;
  height: 18px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: 26px;
}

header .user-menu-list .register {
  background-color: #bad02d;
}

header .user-menu-list .login {
  background-color: #d12248;
}

header .user-menu-list .register span,
header .user-menu-list .login span {
  position: relative;
  display: inline-block;
}

header .user-menu-list .register span:before {
  content: "";
  background: url(../img/common/user.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 16px;
  height: 17px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: -26px;
}

header .user-menu-list .login span:before {
  content: "";
  background: url(../img/common/login.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 11px;
  height: 14px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: -26px;
}

header .user-menu-list .cart {
  background-color: #fff;
  background: url(../img/common/cart.svg) 47% 18px no-repeat;
  border-radius: 0 3px 3px 0;
  padding: 0;
  position: relative;
  width: 60px;
  height: 60px;
  vertical-align: middle;
}

@media screen and (min-width: 641px) {
  header .user-menu-list a {
    opacity: 1;
  }
  header .user-menu-list .delivery:hover {
    background-color: #febd30;
    background-image: url(../img/common/delivary_desc_white.svg);
  }

  header .delivery:hover:before {
    background-image: url(../img/common/truck_white.svg);
  }
  header .user-menu-list .register:hover {
    background-color: #a0b900;
  }
  header .user-menu-list .login:hover {
    background-color: #b7082e;
  }
  header .user-menu-list .cart:hover {
    background-color: #febd30;
    background-image: url(../img/common/cart_white.svg);
  }

  header .user-menu-list .delivery,
  header .user-menu-list .delivery:before {
    -webkit-transition: none;
    transition: none;
  }

}

/*------------------------------------------------------------------------------
header (after login)
------------------------------------------------------------------------------*/

/* header mypage-menu
----------------------------------------*/
header .user-name {
  float: right;
  border-bottom: solid 1px #999;
  color: #999;
  font-size: 15px;
  text-align: center;
  margin: 0 20px 0 0;
  padding: 18px;
}

header .user-menu-list .mypage-btn span:before {
  background-image: url(../img/common/mypage_user_white.svg);
  width: 14px;
  height: 15px;
}

#header-mypage-menu {
  border-radius: 0 0 3px 3px;
  -webkit-box-shadow: 0 0 2px 0 rgba(0,0,0,0.1);
  box-shadow: 0 0 2px 0 rgba(0,0,0,0.1);
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

#header-mypage-menu .category {
  margin-bottom: 0;
}

#header-mypage-menu .logout-btn {
  padding: 20px;
}

#header-mypage-menu .logout-btn a {
  min-width: 172px;
}

#header-mypage-menu .common-btn a:after {
  background: none;
}

#header-mypage-menu .category-list li a {
  line-height: inherit;
}

#header-mypage-menu .category-list a:hover {
  color: #d12248;
  opacity: 1.0;
  filter: alpha(opacity=100);
}

#header-mypage-menu .category-list a:hover:after {
  background-image: url(../img/common/arrow_right_pink.svg);
}

/* header mypage-menu animation
----------------------------------------*/
header #header-mypage-menu {
  font-size: 14px;
  width: 212px;
  padding-top: 60px;
  overflow: auto;

  position: absolute;
  top: 0;
  left: auto;
  right: 0;

  opacity: 1.0;
  filter: alpha(opacity=100);
  z-index: 999;

  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

header .mypage-menu-wrapper #header-mypage-menu {
  display: none;
  pointer-events: auto;
  z-index: -1;
}

header .mypage-menu-wrapper:hover #header-mypage-menu {
  display: inline-block;
  -webkit-transform: translateY(0);
  transform: translateY(0);
  background-color: #fff;
}

/*------------------------------------------------------------------------------
mv-block
------------------------------------------------------------------------------*/

.mv-block {
  overflow: hidden;
  position: relative;
  top: -100px;
  margin-bottom: -100px;
}

.mv-block .slider li:not(:first-child) {
  display: none;
}

.bx-wrapper li {
  z-index: 1 !important;
}

.mv-block .slider li img {
  width: 100%;
}

.mv-block .slider-box .bx-pager {
  position: absolute;
  bottom: 25px;
  text-align: center;
  right: 0;
  left: 0;
  margin: auto;
  z-index: 2;
}

.mv-block .slider-box .bx-pager .bx-pager-item {
  display: inline-block;
  width: 12px;
  height: 12px;
  text-indent: -9999px;
  margin: 0 7px;
  vertical-align: text-bottom;
}

.mv-block .slider-box .bx-pager .bx-pager-item a {
  display: block;
  height: 100%;
  background: #fff;
  border-radius: 50%;
}

.mv-block .slider-box .bx-pager .bx-pager-item a.active {
  background: #dc1943;
}

/*------------------------------------------------------------------------------
breadcrumb
------------------------------------------------------------------------------*/

#breadcrumb {
  background-color: #f5f5f5;
  font-size: 14px;
}

#breadcrumb ul {
  padding: 19px 0;
}

#breadcrumb ul li {
  display: inline-block;
}

#breadcrumb li + li:before {
  content: "/";
  color: #bdbdbd;
  display: inline-block;
  margin: 0 20px;
}

/*------------------------------------------------------------------------------
main-block
------------------------------------------------------------------------------*/
main {
  padding-bottom: 235px;
  display: block;
}

.contents-block {
  padding: 50px 0 80px;
}

.top-page .contents-block {
  padding-top: 30px;
}

@media (min-width: 641px) {
  .main-block {
    float: left;
    width: 900px;
  }
}

/* news
----------------------------------------*/
.news-block {
  width: 100%;
  background-color: #ffefd4;
  border-radius: 0 3px 3px 0;
  border-collapse: separate;
  display: table;
  margin-bottom: 40px;
}
.news-block .news-ttl {
  display: table-cell;
  background: #febd30;
  border-radius: 3px 0 0 3px;
  font-size: 0;
  width: 70px;
  text-align: center;
  vertical-align: middle;
  margin-right: 10px;

  border-collapse: separate;
  border-spacing: 3px 0;
}

.news-block .news-desc {
  display: table-cell;
  font-size: 13px;
  padding: 11px 15px;
}

/* recommend
----------------------------------------*/
.recommend-block {
  text-align: center;
}

.recommend-block .recommend-ttl {
  vertical-align: middle;
  text-align: center;
  padding: 24px 0 20px;

  position: relative;
}

.recommend-block .recommend-ttl:after {
  content: "";
  display: block;
  width: 66px;
  height: 3px;
  background-color: #dc1943;

  position: absolute;
  bottom: 0;
  left: 50%;

  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
}

.recommend-block .item-list {
  margin: 30px auto 10px;
}

.recommend-block .item-list li {
  float: left;
  font-size: 0;
  width: calc((100% - 60px) / 4);
  margin: 0 20px 34px 0;
  vertical-align: top;
}

.recommend-block .item-list li:nth-child(4n) {
  margin-right: 0;
}

.recommend-block .item-list li a {
  display: block;
}

.recommend-block .item-list .thumbnail {
  background: center center no-repeat;
  background-size: cover;
  display: inline-block;
  width: 100%;
  height: auto;
  padding: 100% 0 0;
  border: solid 1px #f3f3f3;
  margin-bottom: 12px;
  overflow: hidden;
}

.recommend-block .item-list .item-ttl {
  font-weight: bold;
  margin-bottom: 6px;
  text-align: left;
  line-height: 1.5;
}

.recommend-block .item-list .price {
  color: #666;
  float: right;
  font-size: 16px;
  font-weight: bold;
  text-align: right;
  padding-top: 1px;
}

.recommend-block .item-list .price .tax {
  font-size: 11px;
  font-weight: normal;
}

.recommend-block {
  width: 100%;
  margin: 0 auto;
}

.recommend-block .more-btn {
  text-align: center;
}

/*------------------------------------------------------------------------------
side-menu-block
------------------------------------------------------------------------------*/

@media (min-width: 641px) {
  .side-menu-block {
    float: right;
    width: 250px;
    margin-left: 50px;
  }
}

.side-menu-block {
  position: relative;
}

/* search-box
----------------------------------------*/
.menu-block .search-box {
  padding: 0 0 25px;

  position: relative;
}

.menu-block .search-box input {
  height: 34px;
  padding: 0 40px 0 14px;
  width: 100%;
  border-radius: 25px;
  border: solid 1px #f3f3f3;
  outline: 0;
  font-size: 14px;

  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;

  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

.menu-block .search-box input:focus {
  border-color: #f6ad31;
}

.menu-block .search-box .search-btn {
  background: #f6ad31;
  border: none;
  border-radius: 0 17px 17px 0;
  cursor: pointer;
  color: #fff;
  width: 40px;
  height: 34px;
  padding: 9px 14px 9px 10px;
  outline: 0;

  position: absolute;
  right: 0px;
  top: 0;
  bottom: 0;
}

/* category
----------------------------------------*/
.menu-block .category {
  margin-bottom: 20px;
}

.menu-block .category .category-ttl {
  padding: 18px 0;
  padding-left: 40px;
  font-size: 0;
  background: url(../img/common/border_pink.png) repeat-x left bottom;
  background-size: auto 4px;

  position: relative;
}

.menu-block .category .category-ttl:before {
  content: "";
  background: url(../img/common/medicine.svg) no-repeat;
  background-position: center center;
  background-size: contain;
  width: 22px;
  height: 18px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom:0;
  left:10px;
}

.menu-block .category .category-list li {
  border-bottom: solid 1px #f3f3f3;
}

.menu-block .category .category-list li a {
  display: block;
  background-color: #fff;
  padding: 19px 0 19px 50px;

  position: relative;
  margin: auto;
}

.menu-block .category .category-list li a img {
  background: #efefef;
  background-size: 30px;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom:0;
  left: 10px;
}

/* menu-list
----------------------------------------*/
.side-menu-block .menu-list li {
  margin-bottom: 20px;
}

.side-menu-block .menu-list a {
  display: block;
  font-size: 16px;
  width: 100%;
  text-align: center;
  background-color: #efefef;
}

.side-menu-block .calender {
  text-align: center;
}

/* contact
----------------------------------------*/
.menu-block .contact {
  background-image: url(../img/common/menu_contact_bg.png);
  padding: 8px;
  margin-bottom: 20px;
  text-align: center;
}

.menu-block .bg-white {
  padding: 10px 12px 12px;
  background: #fff;
}

.menu-block .contact .contact-ttl {
  margin: 0 0 8px;
}

.menu-block .contact .contact-ttl span {
  padding: 0 3px 8px 3px;
  border-bottom: solid 1px #bdbdbd;
}

.menu-block .contact .tel {
  margin: 0 auto 10px;
  padding: 8px 0 5px;
}

.menu-block .contact .tel .tel-num {
  color: #bcc70c;
  font-size: 24px;
  margin: 0;
  line-height: 1.0;
  padding-left: 28px;
  left: -22px;
}

.menu-block .contact .tel .tel-num span {
  position: relative;
}

.menu-block .contact .tel .tel-num span:after {
  content: "";
  background: url(../img/common/tel.svg) no-repeat;
  background-size: contain;
  width: 20px;
  height: 20px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: -28px;
}

.menu-block .contact .tel small {
  color: #333;
  font-size: 12px;
}

.menu-block .contact .contact-form {
  display: block;
  border-radius: 3px;
  background-color: #bcc70c;
  color: #fff;
  font-size: 12px;
  font-family: bold;
  height: 42px;
  line-height: 42px;
  text-align: center;
  opacity: 1;

  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);;
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);;
}

@media screen and (min-width: 641px) {
  .menu-block .contact .contact-form:hover {
    background-color: #a0b900;
  }
}

.menu-block .contact .contact-form span {
  display: inline-block;
  padding-left: 28px;

  position: relative;
}

.menu-block .contact .contact-form span:before {
  content: "";
  background: url(../img/common/mail_white.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 18px;
  height: 13px;
  margin: 15px 0 14px;

  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
}

.menu-block .contact .contact-form span img {
  padding: 15px 0;
}

#contact #kind .radio {
  display: inline-block;
}

/*------------------------------------------------------------------------------
footer
------------------------------------------------------------------------------*/
footer {
  background-color: #b91d3e;

  position: absolute;
  bottom: 0;
  width: 100%;
}

/* site-map
----------------------------------------*/
.site-map .inner-block {
  width: 100%;
  text-align: center;
  border-bottom: solid 1px #c33f5b;
}

.site-map .link-list li {
  display: inline-block;
  line-height: 74px;
  vertical-align: middle;
}

.site-map .link-list li a {
  color: #fff;
  font-size: 13px;
}

@media (min-width: 641px) {
  .site-map .link-list li a:hover {
    opacity: 1.0;
    filter: alpha(opacity=100);
    border-bottom: solid 1px #fff;
    -webkit-transition: none;
    transition: none;
  }

  .site-map .link-list li:not(:last-child) {
    margin-right: 30px;
  }
}

/* footer-menu
----------------------------------------*/
.footer-menu .menu-list {
  padding: 30px 0;
  text-align: center;
}

.footer-menu .menu-list li {
  display: inline-block;
  vertical-align: middle;
}

.footer-menu .menu-list li:not(:last-child) {
  margin-right: 30px;
  border-radius: 5px;
}

.footer-menu .menu-list li:not(.tel) a {
  display: block;
  border-radius: 5px;
  -webkit-box-shadow: 0 1px 2px 0 rgba(15,66,79,0.2);
  box-shadow: 0 1px 2px 0 rgba(15,66,79,0.2);
  background-color: #fff;
  color: #b91d3e;
  font-size: 13px;
  font-weight: bold;
  line-height: 42px;
  text-align: center;
  width: 230px;
}

.footer-menu .menu-list li.tel a {
  color: #fff;
}

.footer-menu .menu-list li a span {
  padding-left: 22px;
  position: relative;
}

.footer-menu .menu-list li a span:after {
  content: "";
  background: url(../img/common/site.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 12px;
  height: 12px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
}

@media screen and (min-width: 641px) {
  .footer-menu .menu-list li a:hover {
    background-color: #f6ae35;
    color: #fff;
    opacity: 1.0;
  }

  .footer-menu .menu-list li a:hover span:after {
    background-image: url(../img/common/site_white.svg);
  }
}

.footer-menu .menu-list li.contact a span {
  padding-left: 28px;
}

.footer-menu .menu-list li.contact a span:after {
  background: url(../img/common/mail.svg) no-repeat;
  background-size: contain;
  width: 18px;
  height: 12px;

  left: 0;
}

@media screen and (min-width: 641px) {
  .footer-menu .menu-list li.contact a:hover span:after {
    background-image: url(../img/common/mail_white.svg);
  }
}

.footer-menu .menu-list li.tel .tel-num {
  color: #fff;
  font-size: 24px;
  margin: 0;
  line-height: 1.0;
  padding-left: 28px;

  left: -22px;
}

.footer-menu .menu-list li.tel .tel-num span {
  position: relative;
}

.footer-menu .menu-list li.tel .tel-num span:after {
  content: "";
  background: url(../img/common/tel_white.svg) no-repeat;
  background-size: contain;
  width: 20px;
  height: 20px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: -28px;
}

.footer-menu li.tel small {
  color: #debcc0;
  font-size: 12px;
  white-space: nowrap;
}

/* site-map
----------------------------------------*/
.copyright {
  background: #a41a37;
}
.copyright small {
  display: block;
  color: #debcc0;
  font-size: 13px;
  text-align: center;
  line-height: 53px;
}

/*------------------------------------------------------------------------------
login-page
------------------------------------------------------------------------------*/

/* login-block
----------------------------------------*/
#login .login-form-wrapper,
#login .register-link-wrapper {
  border: solid 1px #efefef;
  border-radius: 6px;
  width: calc(50% - 20px);
}

@media screen and (min-width: 641px) {
  #login .login-form-wrapper,
  #login .register-link-wrapper {
    border: solid 1px #efefef;
    border-radius: 6px;
    width: calc(50% - 20px);
    min-height: 425px;
  }

  #login .login-form-wrapper {
    float: left;
  }
  #login .register-link-wrapper {
    float: right;
  }

  #login .login-form,
  #login .register-link {
    padding: 34px 40px;
  }
}

#login .login-form,
#login .register-link {
  text-align: center;
}

#login .ttl {
  background: url(../img/common/border_pink.png) left bottom repeat-x;
  background-size: auto 4px;
  font-size: 0;
  text-align: left;
  width: 100%;
  padding: 26px 40px;

  position: relative;
}

#login .ttl:before {
  content: "";
  background-color: #d12248;
  width: 2px;
  height: 18px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: 20px;
}

#login .desc {
  margin-bottom: 26px;
  text-align: left;
}

#login .login-form .login-table {
  margin-bottom: 30px;
  table-layout: fixed;
}

#login .login-form .login-table th {
  text-align: left;
  width: 156px;
  padding-right: 10px;
  vertical-align: middle;
}

#login .login-form .login-table td {
  vertical-align: middle;
  margin-left: auto;
  margin-right : 0;
  padding: 10px 0;
}

#login .login-form .login-table td input {
  background-color: #f5f5f5;
  border-radius: 5px;
  border: solid 1px #bdbdbd;
  width: 340px;
  height: 46px;
  padding: 0 40px 0 14px;
  outline: 0;

  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

#login .login-form .login-table td input:focus {
  border-color: #d12248;
}

#login .login-form .forget-password {
  display: block;
  font-size: 12px;
}

#login .login-form .forget-password span {
  position: relative;
  padding-left: 12px;
}

#login .login-form .forget-password span:before {
  content: "";
  background: url(../img/common/arrow_right_pink.svg) no-repeat;
  background-size: contain;
  width: 5px;
  height: 8px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
}

#login .common-btn {
  text-align: left;
}

#login .common-btn a {
  text-align: center;
}

#login .login-form .common-btn {
  background-color: #fff;
  border: solid 1px #e5e5e5;
  border-radius: 20px;
  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  color: #999;
  font-size: 16px;
  font-weight: bold;
  line-height: 40px;
  padding: 0 20px;
  min-width: 300px;
  text-align: center;
}

#login .login-form .common-btn:after {
  content: "";
  background: url(../img/common/arrow_right_gray.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 6px;
  height: 10px;
  margin: auto;

  position: absolute;
  top: 0;
  bottom: 0;
  right:20px;
}

#login .login-form .common-btn {
  margin-bottom: 18px;
}

#login .register-link .common-btn a {
  background-color: #bad02d;
  color: #fff;
  border: none;
  line-height: 40px;
}

@media screen and (min-width: 641px) {
  #login .register-link .common-btn a:hover {
    background-color: #a0b900;
  }
}

#login .register-link .common-btn a:after {
  background-image: url(../img/common/arrow_right_white.svg);
}

/*------------------------------------------------------------------------------
detail-page
------------------------------------------------------------------------------*/

/* detail-block
----------------------------------------*/
#detail .detail-block {
  margin-bottom: 50px;
}

/* slider-box
----------------------------------------*/
#detail .slider-box {
  float: left;
  display: inline-block;
  width: calc(50% - 20px);
}

#detail .slider-box .img-slider .slider .bx-wrapper {
  border: solid 1px #f5f5f5;
  background-color: #f5f5f5;
  margin-bottom: 10px;
  text-align: center;
}

@media screen and (min-width: 641px) {
  #detail .slider-box .img-slider .slider .bx-controls {
    display: none !important;
  }

  #detail .slider-box .img-slider .slider .bx-pager {
    max-width: 100%;
    text-align: left;
    font-size: 0;
    overflow: hidden;
  }

  #detail .slider-box .img-slider .slider .bx-pager a {
    float: left;
    border: solid 1px #f5f5f5;
    display: inline-block;
    width: 78px;
    height: 78px;
    margin-right: 10px;
    margin-bottom: 10px;
    overflow: hidden;
  }

  #detail .slider-box .img-slider .slider .bx-pager a:nth-child(5n) {
    margin-right: 0
  }

  #detail .slider-box .img-slider .slider .bx-pager a.active img {
    border: solid 4px #f5f5f5;
    -webkit-transition: none;
    transition: none;
  }
}

/* item-info-block
----------------------------------------*/
#detail .item-info-block {
  float: right;
  display: inline-block;
  width: calc(50% - 20px);
}

#detail .item-info-block .category {
  display: block;
  margin-bottom: 20px;
}

#detail .item-info-block .item-ttl {
  display: block;
  font-size: 30px;
  line-height: 1.2;
  margin-bottom: 30px;
}

#detail .item-info-block .price {
  color: #d12248;
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 18px;
}

#detail .item-info-block .price-down {
  color: #8d8d8d;
  font-size: 16px;
  font-weight: normal;
  text-decoration: line-through;
  margin-left: 20px;
}

#detail .item-info-block .price .tax {
  font-size: 16px;
  font-weight: normal;
}

#detail .item-info-block .desc {
  font-size: 16px;
  margin-bottom: 25px;
}

#detail .item-info-block .shopping-form {
  background-color: #f5f5f5;
}

#detail .item-info-block .sub-info-list {
  margin-bottom: 30px;
  color: #8d8d8d;
}

#detail .item-info-block .sub-info-list li {
  border-top: solid 1px #f3f3f3;
  padding: 17px 0;
}

#detail .item-description-txt {
  margin-bottom: 40px;
}

@media screen and (min-width: 641px) {
  #detail .item-info-block .sub-info-list li {
    font-size: 16px;
  }
}

#detail .item-info-block .sub-info-list li:last-child {
  border-bottom: solid 1px #f3f3f3;
}

#detail .item-info-block .shopping-form {
  border-radius: 3px;
  padding: 20px;
}

@media screen and (min-width: 641px) {
  #detail .item-info-block .shopping-form .shopping-form-table {
    margin: 0 10px;
  }
}

#detail .item-info-block .shopping-form .select-menu-wrap {
  margin: 5px 0;
}

#detail .item-info-block .shopping-form input {
  width: 80px;
  text-align: right;
  padding: 0 28px 0 10px;
}

#detail .item-info-block .shopping-form th {
  color: #999;
  text-align: left;
  width: 100px;
}

#detail .item-info-block .shopping-form .add-to-cart {
  background-color: #d12248;
  border-radius: 30px;
  color: #fff;
  font-size: 0;
  width: 100%;
  height: 60px;
  margin: 15px auto auto;

  position: relative;
}

#detail .item-info-block .shopping-form .add-to-cart img {
  margin-left: 20px;
}

#detail .item-info-block .shopping-form .add-to-cart:before {
  content: "";
  background: url(../img/common/cart_white.svg) no-repeat;
  background-size: contain;
  width: 29px;
  height: 27px;
  margin: auto;
  position: absolute;

  top: 0;
  bottom: 0;
  left: 40px;
}

@media screen and (min-width: 641px) {
  #detail .item-info-block .shopping-form .add-to-cart:hover {
    background-color: #b7082e;
    opacity: 1.0;
  }
}

/* detail-tabs-block
----------------------------------------*/
#detail .tabs {
  border-bottom: 4px solid #f6ad31;
  margin-bottom: 25px;
}

#detail .tabs li {
  cursor: pointer;
  width: 120px;
  height: 40px;
  line-height: 40px;
  float: left;
  text-align: center;
  background-color: #ffead6;
  color: #f6ad31;
  font-weight: bold;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  margin-right: 4px;
}

#detail .tabs .current {
  background-color: #f6ad31;
  color: #fff;
}

#detail .sub_tabs {
  border-top: 4px solid #f6ad31;
  margin-top: 30px;
}

#detail .sub_tabs li {
  cursor: pointer;
  width: 120px;
  height: 40px;
  line-height: 40px;
  float: left;
  text-align: center;
  background-color: #ffead6;
  color: #f6ad31;
  font-weight: bold;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  margin-right: 4px;
}

#detail .sub_tabs .current {
  background-color: #f6ad31;
  color: #fff;
}

@media screen and (min-width: 641px) {
  #detail .tabs li:hover {
    opacity: 0.7;
  }
  #detail .sub_tabs li:hover {
    opacity: 0.7;
  }
  
  #detail .tabs .current:hover {
    opacity: 1;
  }
}

/* detail-description-item
----------------------------------------*/
#detail .detail-description-item-red-ttl {
  font-size: 18px;
  font-weight: bold;
  color: #d12248;
  margin-bottom: 20px;
}

#detail .detail-description-item-left-img {
  float: left;
  width: 120px;
}

#detail .detail-description-item-rigth-txt {
  float: left;
  width: 780px;
}

#detail .detail-description-item-rigth-txt-ttl {
  font-weight: bold;
  margin-bottom: 3px;
}

#detail .detail-description-item-img-txt-block {
  margin-bottom: 20px;
}

#detail .detail-description-item-red-ttl-block .detail-description-item-img-txt-block:last-of-type {
  margin-bottom: 0;
}

#detail .detail-description-item-red-ttl-detail {
  margin-bottom: 15px;
}

#detail .detail-description-item-red-ttl-block02 .detail-description-item-red-ttl {
  margin-bottom: 10px;
}

#detail .detail-description-item-outer-block {
  padding: 20px 0;
  border-bottom: 1px solid #f5f5f5;
}

#detail .detail-description-item-outer-block:first-of-type {
  padding-top: 0;
}

#detail .detail-description-item-red-ttl-block:nth-of-type(n + 2) {
  margin-top: 25px;
}

#detail .detail-description-item-green-ttl {
  color: #bcc70c;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 10px;
}

#detail .detail-description-item-green-subttl {
  display: inline;
  font-weight: bold;
  background: linear-gradient(transparent 50%, rgba(188,199,12,0.3) 0%);
  margin-bottom: 10px;
}

#detail .detail-description-item-img-txt-block {
  margin-top: 15px;
}

#detail .detail-description-item-green-subttl-list-child {
  margin: 10px 0;
}

#detail .detail-description-item-green-subttl-list-child-ttl {
  font-weight: bold;
  margin-bottom: 3px;
}

#detail .detail-description-item-point {
  background-color: #ccc;
  width: 10px;
  height: 10px;
  display: inline-block;
  border-radius: 50%;
  margin: 0 6px;
}

.detail-description-item-green-banner {
  margin-top: 15px;
}

#detail .detail-description-item-green-subttl-list-child-ttl-detail {
  margin-left: 22px;
}

#detail .detail-description-item-green-subttl-block {
  margin-top: 10px;
}

#detail .detail-description-item-green-ttl-detail {
  margin-bottom: 0;
}

#detail .detail-description-item-outer-block .detail-description-item-img-txt-block:last-of-type {
  margin-bottom: 0;
}

#detail .detail-description-item-green-subttl02 {
  margin-bottom: 20px;
}

#detail .detail-description-item-green-banner-txt {
  margin-top: 10px;
}

#detail .detail-description-item-orange-ttl {
  color: #f3b100;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 10px;
}

#detail .detail-description-item-orange-ttl-block .detail-description-item-green-subttl-list-child-ttl:last-of-type {
  margin-bottom: 0;
}

#detail .detail-description-item-orange-subttl {
  display: inline;
  font-weight: bold;
  background: linear-gradient(transparent 50%, rgba(243,177,0,0.3) 0%);
  margin: 20px 0;
}

.detail-description-item-orange-subttl-detail-ttl {
  font-weight: bold;
  margin-top: 10px;
  margin-bottom: 3px;
}

#detail .detail-description-item-emerald-ttl {
  color: #3aad83;
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 10px;
}

#detail .detail-description-item-emerald-subttl {
  font-weight: bold;
  margin-bottom: 0;
}

#detail .detail-description-item-emerald-subttl-block {
  margin-bottom: 15px;
}

#detail .detail-description-item-emerald-subttl-block:last-of-type {
  margin-bottom: 0;
}

#detail .detail-description-item-banner-ttl {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
}

#detail .detail-description-item-banner-txt {
  margin-top: 15px;
}

/* item-spec-block
----------------------------------------*/
#detail .item-spec-block {
  clear: both;
  margin-bottom: 30px;
}

#detail .item-spec-block .item-spec-ttl {
  font-size: 0;
  margin-bottom: 20px;
}

#detail .item-spec-block .item-spec-ttl .border-bottom:after {
  background-color: #bcc70c;
}

#detail .item-spec-block .item-spec-table {
  line-height: 1.8;
}

#detail .item-spec-block .item-spec-table tr {
  border-bottom: solid 1px #f5f5f5;
}

#detail .item-spec-block .item-spec-table th {
  font-weight: normal;
  text-align: left;
  width: 200px;
  padding: 16px 0;
  vertical-align: top;
}

#detail .item-spec-block .item-spec-table td {
  padding: 16px 0;
}

#detail .item-spec-block .item-spec-table tr:first-of-type th {
  padding-top: 0;
}

#detail .item-spec-block .item-spec-table tr:first-of-type td {
  padding-top: 0;
}

/* manual-block
----------------------------------------*/
#detail .manual-block {
  outline: 1px solid #f5f5f5;
  outline-offset: -1px;
  text-align: center;
  margin-bottom: 30px;
}

/* note-block
----------------------------------------*/
#detail .note-block {
  padding-bottom: 15px;
  border-bottom: solid 1px #f5f5f5;
}

#detail .note-block .note-ttl {
  font-size: 0;
  margin-bottom: 15px;
}

#detail .note-block .note-list {
  line-height: 1.8;
}

#detail .note-block .note-list li {
  text-indent: -1em;
  margin-left: 1em;
}

#detail .note-block .note-list li:not(.mark-none):before {
  content: "・";
}

#detail .note-list-ttl {
  font-weight: bold;
  margin-bottom: 0;
}

#detail-product-note-content {
  padding-top: 30px;
}

#detail .note-block:nth-of-type(n + 2) {
  padding-top: 15px;
}

#detail .note-block:last-of-type {
  margin-bottom: 30px;
}
/*------------------------------------------------------------------------------
list-page
------------------------------------------------------------------------------*/

#list .ttl {
  font-size: 30px;
  line-height: 1.5;
  margin-bottom: 32px;
}

/* category-link-list
----------------------------------------*/
#list .category-link-list {
  font-size: 0;
  margin-bottom: 10px;
}

#list .category-link-list li {
  display: inline-block;
  margin-bottom: 10px;
}

#list .category-link-list li:not(:last-child) {
  margin-right: 10px;
}

#list .category-link-list li a {
  display: inline-block;
  border-radius: 17px;
  color: #fff;
  font-size: 0;
  text-align: center;
  min-width: 100px;
  padding: 4px 25px;
}

#list .category-link-list li a:not(.active) {
  background-color: #bdbdbd;
}


#list .category-link-list li a img {
  height: 26px;
  vertical-align: middle;
}


/* search-block
----------------------------------------*/
#list .search-block {
  min-height: 74px;
  padding: 18px 0;
  border-top: solid 1px #f5f5f5;
  border-bottom: solid 1px #f5f5f5;
}

#list .search-block .search-result {
  float: left;
  font-size: 16px;
  margin: 0;
  padding: 5px 0;
}

#list .search-block .search-result .hit-num {
  font-weight: bold;
}

#list .search-block .search-config-table {
  float: right;
}

#list .search-block .search-config-table th {
  color: #999;
  text-align: left;
  font-weight: bold;
  margin-right: 4px;
}

#list .search-block .search-config-table .display-num select {
  width: 80px;
  padding-right: 28px;
  text-indent: 1.5em;
}

@media screen and (min-width: 641px) {
  #list .search-block .search-result,
  #list .search-block .search-config-table,
  #list .search-block .search-config-table tr,
  #list .search-block .search-config-table th,
  #list .search-block .search-config-table td {
    display: inline-block;
    vertical-align: middle;
  }

  #list .search-block .search-config-table tr:not(:last-child) {
    margin-right: 30px;
  }
}

/* reccomend-block
----------------------------------------*/
#list .recommend-block .item-list {
  margin: 50px auto 0px;
}

/*------------------------------------------------------------------------------
mypage
------------------------------------------------------------------------------*/
#mypage .block-ttl {
  margin-bottom: 30px;
}

#mypage dl,
#mypage dt,
#mypage dd {
  display: inline-block;
}

#mypage dt,
#mypage dd {
  float: left;
}

/* order-list
----------------------------------------*/
#mypage .order-count {
  border-top: solid 1px #f5f5f5;
  font-size: 16px;
  padding: 24px 0;
  margin-bottom: 0;
}

#mypage .order-count .hit-num {
  font-weight: bold;
}

#mypage .order-list > li {
  border: solid 4px #f5f5f5;
  padding: 30px 30px 26px;
}

#mypage .order-list > li:not(:last-child) {
  margin-bottom: 30px;
}

#mypage .order-list {
  display: inline-block;
  width: 100%;
  margin-bottom: 40px;
}

/* order-info
----------------------------------------*/
#mypage .order-info {
  display: inline-block;
  float: left;
  width: 270px;
  padding-right: 75px;
}

#mypage .order-info .status {
  display: inline-block;
  background-color: #bcc70c;
  border-radius: 3px;
  color: #fff;
  font-size: 12px;
  font-weight: bold;
  line-height: 24px;
  text-align: center;
  min-width: 67px;
  height: 24px;
  margin-bottom: 16px;
  padding: 0 10px;
}

#mypage .order-info .order-info-list {
  display: block;
  margin-bottom: 26px;
}

#mypage .order-info-list dt {
  clear: both;
}

#mypage .order-info .order-info-list dt {
  width: 72px;
}

#mypage .order-info-list dt:after {
  content: "：";
  float: right;
}

#mypage .order-info .common-btn {
  margin-bottom: 30px;
}

#mypage .order-info .common-btn a {
  min-width: 195px;
  height: 40px;
  text-align: center;
}

#mypage .order-info .common-btn a:after {
  display: none;
}

/* item-list
----------------------------------------*/
#mypage .item-list {
  display: inline-block;
  width: calc(100% - 270px);
}

#mypage .item-list > li:not(:last-child) {
  border-bottom: solid 1px #f5f5f5;
}

#mypage .item-list li a {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  min-height: 160px;
  padding: 30px 0;

  position: relative;
}

#mypage .item-list li:first-child a {
  min-height: 130px;
  padding-top: 0;
}

#mypage .item-list .thumbnail {
  border: solid 1px #bdbdbd;
  width: 100px;
  height: 100px;
  margin-right: 30px;
}

#mypage .item-list .item-info {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  max-width: calc(100% - 130px);
}

#mypage .item-list .item-info .item-ttl {
  color: #dc1943;
  font-weight: bold;
}

#mypage .item-list .item-info .price {
  font-size: 16px;
  font-weight: bold;
}

@media screen and (min-width: 641px) {
  #mypage .item-list .item-info .price {
    margin: 10px 0 0;
    align-self: flex-end;
  }
}

#mypage .item-list .item-info > * {
  width: 100%;
}

#mypage .item-list .item-info .price .tax,
#mypage .item-list .item-info .price .quantity {
  font-size: 12px;
  font-weight: normal;
}

@media screen and (min-width: 641px) {
  #mypage .item-list .item-info .price br + span:before {
    white-space: pre-wrap;
    content: " / ";
    display: inline-block;
  }
}

/* payment
----------------------------------------*/
#mypage .payment {
  clear: both;
  float: none;
  display: block;
  border-top: solid 1px #f5f5f5;
  font-size: 16px;
  padding-top: 26px;
}

@media screen and (min-width: 641px) {
  #mypage .payment dd {
    display: inline-block;
    margin-right: 60px;
  }
}

#mypage .payment .method,
#mypage .payment .amount {
  font-weight: bold;
}

/* mypage-menu
----------------------------------------*/
.mypage-menu.side-menu-block {
  text-align: center;
}

.mypage-menu.menu-block .category {
  text-align: left;
  margin-bottom: 30px;
}
.mypage-menu.menu-block .category .category-ttl:before {
  background-image: url(../img/common/mypage_user.svg);
  width: 24px;
  height: 24px;
}

.mypage-menu.menu-block .category .category-list li a {
  color: #333;
  padding: 20px 46px 20px 20px;
}

.mypage-menu.menu-block .category .category-list li a:before {
  background: none;
}

.mypage-menu.menu-block .category .category-list li a:after {
  content: "";
  background: url(../img/common/arrow_right_gray.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 6px;
  height: 10px;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
}

.mypage-menu.menu-block .common-btn a {
  text-align: center;
  min-width: 195px;
}

/*------------------------------------------------------------------------------
mypage-history
------------------------------------------------------------------------------*/

/* order-info
----------------------------------------*/
#mypage.mypage-history .order-info {
  float: none;
  background-color: #f5f5f5;
  border-radius: 3px;
  width: 100%;
  padding: 30px 30px 22px;
  margin-bottom: 30px;
}

#mypage.mypage-history .order-info .status-wrap,
#mypage.mypage-history .order-info .order-info-list {
  vertical-align: middle;
}

#mypage.mypage-history .order-info .status-wrap {
  float: left;
  display: inline-block;
  width: 300px;
}

#mypage.mypage-history .order-info .status {
  font-size: 16px;
  line-height: 34px;
  min-width: 87px;
  height: 34px;
}

#mypage.mypage-history .order-info .order-info-list {
  display: inline-block;
  margin-bottom: 0;
}

#mypage.mypage-history .order-info .order-info-list dt {
  width: 120px;
}

/* info-detail
----------------------------------------*/
#mypage.mypage-history .info-detail > li {
  display: table;
  border-top: solid 1px #f3f3f3;
  width: 100%;
}

#mypage.mypage-history .info-detail .info-detail-ttl,
#mypage.mypage-history .info-detail .info-detail-list {
  display: table-cell;
  vertical-align: middle;
  padding: 25px 30px 25px 0;
}

#mypage.mypage-history .info-detail .info-detail-ttl {
  font-size: 16px;
  font-weight: bold;
  width: 300px;
}

@media screen and (min-width: 641px) {
  #mypage.mypage-history .info-detail .info-detail-ttl {
    padding-left: 30px;
  }

  #mypage.mypage-history .info-detail .info-detail-list:not(.item-list) li:not(:last-child) {
    padding-bottom: 6px;
  }
}

#mypage.mypage-history .info-detail .info-detail-list.item-list {
  padding: 30px 0 0;
}

/* payment
----------------------------------------*/
#mypage.mypage-history .payment {
  border-bottom: solid 1px #f5f5f5;
  padding: 26px 30px;
  margin-bottom: 30px;
}

#mypage.mypage-history .payment dl {
  float: left;
}

#mypage.mypage-history .payment dl,
#mypage.mypage-history .payment .common-btn {
  vertical-align: middle;
}

#mypage.mypage-history .payment dt {
  width: 140px;
  clear: both;
}

@media screen and (min-width: 641px) {
  #mypage.mypage-history .payment dd:not(:last-child) {
    padding-bottom: 6px;
  }

  #mypage.mypage-history .payment .common-btn {
    float: right;
    padding: 34px 0;
  }
}

#mypage.mypage-history .payment .amount {
  font-weight: bold;
}

#mypage.mypage-history .payment dd.amount {
  color: #dc1943;
}

#mypage.mypage-history .payment .common-btn a {
  background-color: #d12248;
  border: none;
  color: #fff;
  font-size: 0;
  text-align: center;
  min-width: 230px;
  padding: 0 35px;
}

#mypage.mypage-history .payment .common-btn a:after {
  display: none;
}

#mypage.mypage-history .payment .common-btn a img {
  vertical-align: middle;
}

@media screen and (min-width: 641px) {
  #mypage.mypage-history .payment .common-btn a:hover {
    background-color: #b7082e;
  }
}

/* back common-btn
----------------------------------------*/
#mypage.mypage-history .back.common-btn a {
  line-height: 38px;
  text-align: center;
}

#mypage.mypage-history .back.common-btn a:after {
  display: none;
}

/*------------------------------------------------------------------------------
withdraw
------------------------------------------------------------------------------*/

.withdraw-caution {
  width: 70px;
  margin: 0 auto 30px;
}

.withdraw-txt01 {
  margin-bottom: 25px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}

p.withdraw-txt02 {
  text-align: center;
  margin-bottom: 30px;
}

.withdraw .common-btn-outer {
  text-align: center;
  font-size: 0;
}

.withdraw .common-btn a {
  background-color: #f6ae35;
  line-height: 40px;
  min-width: 230px;
  border: none;
  color: #fff;
}

@media screen and (min-width: 641px){
  .withdraw .common-btn a:hover {
    background-color: #df9e30;
  }
}

.withdraw .common-btn a:after {
  display: none;  
}

.withdraw-main-block {
  border-top: 1px solid #f5f5f5;
  border-bottom: 1px solid #f5f5f5;
  padding: 30px 0;
}

.withdraw .contents-block {
  padding-top: 50px;
}

/* confirm
----------------------------------------*/
.withdraw-confirm .common-btn:last-of-type a {
  margin-left: 20px;
  background-color: #fff;
  border: solid 1px #e5e5e5;
  color: #999;
  line-height: 38px;
}

@media screen and (min-width: 641px){
  .withdraw-confirm  .common-btn:last-of-type a:hover {
    background-color: #d12248;
    border-color: #d12248;
    color: #fff;
    opacity: 1.0;
  }
}

/*------------------------------------------------------------------------------
mypage-delivery
------------------------------------------------------------------------------*/

#mypage.mypage-delivery .order-count {
  border: 0;
}

#mypage.mypage-delivery .delivery-order-block {
  border-bottom: solid 1px #f5f5f5;
  border-top: solid 1px #f5f5f5;
}

#mypage.mypage-delivery .delivery-more-btn {
  font-size: 16px;
  color: #fff;
  background-color: #bad02d;
  width: 340px;
  margin: 0 auto;
  border-radius: 20px;
  line-height: 40px;
  text-align: center;
  font-weight: bold;
  position: relative;
  cursor: pointer;
  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

@media screen and (min-width: 641px) {
  #mypage.mypage-delivery .delivery-more-btn:hover {
    background-color: #a0b900;
  }

  #mypage.mypage-delivery .delivery-change:hover, 
  #mypage.mypage-delivery .delivery-delete:hover {
    background-color: #d12248;
    border-color: #d12248;
    color: #fff;
  }
}

#mypage.mypage-delivery .delivery-more-btn:after {
  position: absolute;
  display: block;
  content: '';
  background: url(../img/common/plus.svg) no-repeat;
  background-size: contain;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  right: 20px;
}

#mypage.mypage-delivery .delivery-more-btn-outer {
  padding: 30px 0;
  border-bottom: solid 1px #f5f5f5;
}

#mypage.mypage-delivery .delivery-btn-area {
  font-size: 0;
  width: 300px;
  float: left;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  padding-left: 30px;
}

#mypage.mypage-delivery .delivery-change,
#mypage.mypage-delivery .delivery-delete {
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  color: #999;
  line-height: 30px;
  background-color: #fff;
  border: 1px solid #e5e5e5;
  border-radius: 15px;
  text-align: center;
  cursor: pointer;
  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

#mypage.mypage-delivery .delivery-change {
  width: 100px;
  margin-right: 10px;
}

#mypage.mypage-delivery .delivery-delete {
  width: 80px;
}

#mypage.mypage-delivery .delivery-txt-area {
  float: right;
  width: 600px;
}

#mypage.mypage-delivery .delivery-txt-area-txt {
  line-height: 28px;
}

#mypage.mypage-delivery .delivery-parts-block {
  padding: 30px 0;
  border-bottom: solid 1px #f5f5f5;
  position: relative;
}

#mypage.mypage-delivery .contents-block {
  padding-top: 50px;
}
/*------------------------------------------------------------------------------
mypage-change
------------------------------------------------------------------------------*/

#mypage-change .mypage-change-table {
  font-size: 16px;
}

#mypage-change .mypage-change-table tr {
  padding: 15px 0;
  border-bottom: 1px solid #f5f5f5;
  display: block;
}

#mypage-change .mypage-change-table tr:first-of-type {
  border-top: 1px solid #f5f5f5;
}

#mypage-change .mypage-change-table th {
  width: 270px;
  text-align: left;
}

#mypage-change .mypage-change-table td {
  width: 630px;
  font-size: 0;
}

#mypage-change .mypage-change-table th .required {
  background-color: #d62249;
  width: 54px;
  border-radius: 10px;
  display: inline-block;
  text-align: center;
  line-height: 20px;
  float: right;
  margin-right: 30px;
}

#mypage-change .mypage-change-table th .required img {
  width: 24px;
  margin-top: 5px;
}

#mypage-change input[type="text"],
#mypage-change input[type="tel"],
#mypage-change input[type="email"],
#mypage-change input[type="password"],
#mypage-change select {
  border-radius: 5px;
  border: solid 1px #bdbdbd;
  padding-left: 20px;
  height: 46px;
  font-size: 16px;
  background-color: #fff;
  -webkit-appearance: none; 
  appearance: none; 
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  background-color: #ffeded;
}

#mypage-change #mypage-change-address .not-required  {
  background-color: #f5f5f5 ;
}

#mypage-change input[type="text"]:focus,
#mypage-change input[type="tel"]:focus,
#mypage-change select:focus {
  border-color: #d12248;
}

#mypage-change .name-text input[type="text"],
#mypage-change .name-text input[type="tel"] {
  width: 250px;
}

#mypage-change .name-text span {
  font-size: 16px;
  display: inline-block;
  width: 50px;
}

#mypage-change .name-text .name-block {
  float: left;
}

#mypage-change .name-text .name-block:last-of-type {
  float: right;
}

#mypage-change .birth input {
  width: 136px;
  padding-right: 20px;
}

#mypage-change .long-text{
  width: 100%;
}

#mypage-change .post-mark {
  font-size: 16px;
  padding-right: 13px;
}

#mypage-change .hyphen {
  font-size: 16px;
  padding: 0 20px;
}

#mypage-change .post-block input {
  width: 100px;
}

#mypage-change .post-block input:last-of-type {
  width: 110px;
}

#mypage-change .post-search {
  font-size: 14px;
  color: #999;
  margin-left: 30px;
  position: relative;
}

#mypage-change .link-img {
  width: 16px;
  display: inline-block;
  margin-left: 10px;
}

#mypage-change .link-img img {
  vertical-align: middle;
  margin-bottom: 4px;
}

#mypage-change .post-btn {
  font-size: 14px;
  color: #999;
  width: 195px;
  height: 40px;
  line-height: 40px;
  border: 1px solid #e5e5e5;
  border-radius: 20px;
  text-align: center;
  margin-bottom: 14px;
  cursor: pointer;
  background-color: #fff;
  display: block;
  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
}

#mypage-change .post-block {
  margin-bottom: 14px;
}

#mypage-change .address {
  vertical-align: top;
  padding-top: 10px;
}

#mypage-change .pref {
  width: 180px;
  cursor: pointer;
}

#mypage-change .select-pref-block {
  width: 180px;
  height: 46px;
  margin-bottom: 14px;
  position: relative;
}

#mypage-change .select-menu-wrap {
  width: 180px;
}

#mypage-change .select-items div,#mypage-change .select-selected {
  padding: 0 0 0 20px;
  line-height: 46px;
  height: 46px;
}

#mypage-change .select-menu-wrap {
  margin-bottom: 14px;
}

#mypage-change .birth .select-menu-wrap {
  width: 100%;
}

#mypage-change .select-pref-block:after {
  position: absolute;
  display: block;
  content: "";
  background: url(../img/common/under_arrow_black.svg);
  background-size: contain;
  width: 8px;
  height: 6px;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  pointer-events: none;
}

#mypage-change .post-text p {
  font-size: 12px;
  color: #999;
  margin: 5px 0 10px;
}

#mypage-change .post-text p:last-of-type {
  margin-bottom: 0;
}

#mypage-change .tel input {
  width: 100px;
}

#mypage-change .gender input[type=radio] {
  display: none;
}

#mypage-change .gender-input + label {
  font-size: 16px;
  padding-left: 30px;
  position:relative;
  margin-right: 40px;
}

#mypage-change .gender-input + label:before {
  content: "";
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
  width: 18px;
  height: 18px;
  border: 1px solid #bdbdbd;
  border-radius: 50%;
}

#mypage-change .gender-input:checked + label:after {
  content: "";
  display: block;
  position: absolute;
  top: 4px;
  left: 5px;
  width: 10px;
  height: 10px;
  background: #666;
  border-radius: 50%;
}

#mypage-change .birth select {
  width: 100px;
  cursor: pointer;
  line-height: 1;
  vertical-align: baseline;
}

#mypage-change .birth-select-block {
  width: 100px;
  border-radius: 5px;
  height: 46px;
  position: relative;
  display: inline-block;
}

#mypage-change .birth span {
  margin: 0 20px 0 10px;
  font-size: 16px;
}

#mypage-change .pas input {
  width: 100%;
}

#mypage-change input:focus {
  outline: 0;
}

#mypage-change .pas p {
  font-size: 12px;
  color: #999;
  margin-top: 5px;
}

#mypage-change .select-menu-wrap {
  font-size: 16px;
}

#mypage-change .contents-block {
  padding-top: 50px;
}

#mypage-change .pas-th {
  vertical-align: top;
  padding-top: 13px;
}

#mypage-change span.name-block {
  width: auto;
}

#mypage-change .birth-select-block-second {
  display: inline-block;
}

#mypage-change .common-btn-outer {
  margin-top: 50px;
}

#mypage-change .common-btn.mypage-chang-btn {
  border-radius: 20px;
}

#mypage-change .common-btn.mypage-chang-btn button {
  background-color: #bad02d;
  color: #fff;
  border: 0;
  display: block;
  background-color: #fff;
  border: solid 1px #e5e5e5;
  border-radius: 20px;
  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  color: #999;
  font-size: 16px;
  font-weight: bold;
  line-height: 40px;
  padding: 0 20px;
  min-width: 300px;
  background-color: #bad02d;
  color: #fff;
  border: 0;
}

#mypage-change .common-btn.mypage-chang-btn:after {
  background: url(../img/common/arrow_right_white.svg) no-repeat;
  content: "";
  background-size: contain;
  display: inline-block;
  width: 6px;
  height: 10px;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
}

@media screen and (min-width: 641px) {
  #mypage-change .common-btn.mypage-chang-btn button:hover {
    background-color: #a0b900;
  }

  #mypage-change .common-btn.mypage-chang-btn button:hover {
    opacity: 1;
  }

  #mypage-change .post-btn:hover {
    background-color: #d12248;
    border-color: #d12248;
    color: #fff;
    opacity: 1;
  }
}
/*------------------------------------------------------------------------------
help-delivery
------------------------------------------------------------------------------*/
#help-delivery p {
  text-align: justify;
}

#help-delivery .info-txt-block img {
  margin: 30px 0;
}

#help-delivery ul.cap-list li {
  text-indent: -1em;
  margin-left: 1em;
  text-align: justify;
}


/*------------------------------------------------------------------------------
help-cancel
------------------------------------------------------------------------------*/
#help-cancel p {
  text-align: justify;
}

#help-cancel ul.cap-list {
  list-style-type: none;
  margin-left: 1.5em;
  margin-top: 20px;
}

#help-cancel ul.cap-list li {
  margin-bottom: 0;
  text-align: justify;
}

#help-cancel ul.cap-list li:last-child {
  margin-bottom: 0;
}

#help-cancel ul.cap-list li:before {
  position: relative;
  top: -2px;
  left: -1em;
  display: inline-block;
  width: 5px;
  height: 5px;
  content: '';
  border-radius: 100%;
  background: #777;
}

#help-cancel ul.cap-list.no-marker {
  margin-left: 0;
}

#help-cancel ul.cap-list.no-marker li:before {
  content: none;
  margin-left: 0;
}


/*------------------------------------------------------------------------------
help-privacy
------------------------------------------------------------------------------*/
#help-privacy p {
  text-align: justify;
}

#help-privacy .lead-txt {
  margin-bottom: 30px;
}

#help-privacy ul.cap-list {
  list-style-type: none;
  margin-left: 1.5em;
  margin-top: 20px;
}

#help-privacy ul.cap-list li {
  margin-bottom: 0;
  text-indent: -5px;
  text-align: justify;
}

#help-privacy ul.cap-list li:last-child {
  margin-bottom: 0;
}

#help-privacy ul.cap-list li:before {
  position: relative;
  top: -2px;
  left: -1em;
  display: inline-block;
  width: 5px;
  height: 5px;
  content: '';
  border-radius: 100%;
  background: #777;
}

#help-privacy ul.cap-list.no-marker {
  margin-left: 0;
}

#help-privacy ul.cap-list.no-marker li {
  text-indent: -1em;
  margin-left: 1em;
}

#help-privacy ul.cap-list.no-marker li:before {
  content: none;
  margin-left: 0;
}

#help-privacy .txt-link-red {
  color: #d12248;
}

/*------------------------------------------------------------------------------
help-about
------------------------------------------------------------------------------*/
/* comment
----------------------------------------*/

/*------------------------------------------------------------------------------
help-tradelaw
------------------------------------------------------------------------------*/
#help-tradelaw p {
  text-align: justify;
}

#help-tradelaw .cap-list li {
  margin-bottom: 10px;
  text-align: justify;
}

#help-tradelaw .cap-list.mb-0 li{
  margin-bottom: 0;
}

#help-tradelaw .box-ttl {
  margin-bottom: 20px;
}

#help-tradelaw .info-txt-block .box-ttl:last-child {
  margin-bottom: 0;
}

#help-tradelaw .box-list {
  margin-top: 20px;
}

#help-tradelaw .box-list dt {
  font-weight: bold;
}

#help-tradelaw .box-list dd {
  margin-bottom: 15px;
  text-align: justify;
}

#help-tradelaw .price-table {
  width: 360px;
  margin-top: 10px;
  table-layout: fixed;
}

#help-tradelaw .price-table th,
#help-tradelaw .price-table td {
  border: solid 1px #999;
  padding: 10px;
}

#help-tradelaw .price-table th {
  font-weight: normal;
}

#help-tradelaw .price-table thead th {
  background-color: #999;
  font-weight: bold;
  color: #fff;
}

#help-tradelaw .price-table thead th:first-child {
  border-right: solid 1px #fff;
}

#help-tradelaw .price-table tbody th {
  text-align: left;
}

#help-tradelaw .txt-bold {
  font-weight: bold;
}

#help-tradelaw .txt-link-red {
  color: #d12248;
}

/*------------------------------------------------------------------------------
voice
--------------------------- ---------------------------------------------------*/
.voice-main-parts-block {
  margin-bottom: 40px;
}

.voice-main-parts-block:last-of-type {
  margin-bottom: 0;
}

#voice .balloon-block {
  position: relative;
  background: #fff3f7;
  border: 2px solid #d12248;
  font-size: 18px;
  font-weight: bold;
  color: #d12248;
  border-radius: 3px;
}

#voice .balloon-block:after, #voice .balloon-block:before {
  top: 100%;
  left: 30px;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
}

#voice .balloon-block:after {
  border-color: rgba(255, 243, 247, 0);
  border-top-color: #fff3f7;
  border-width: 12px 7px;
  margin-left: -12px;
}

#voice .balloon-block:before {
  border-color: rgba(209, 34, 72, 0);
  border-top-color: #d12248;
  border-width: 15px 10px;
  margin-left: -15px;
}

#voice .balloon-txt {
  margin: 0 30px;
  padding: 15px 0;
}

#voice .voice-txt-img-block {
  margin: 30px 0 20px;
}

#voice .voice-interview-left {
  float: left;
  width: 500px;
}

#voice .voice-interview-name {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
}

#voice .voice-interview-right {
  float: right;
  width: 370px;
}

#voice .voice-item-detail-block {
  background-color: #f5f5f5;
  padding: 20px;
  position: relative;
  border-radius: 3px;
}

#voice .voice-item-detail-left {
  float: left;
  width: 150px;
  margin-right: 20px
}

#voice .voice-item-detail-right {
  float: right;
  width: 690px;
}

#voice .voice-item-detail-right .voice-item-detail-txt-block {
  float: left;
  width: 430px;
}

#voice .voice-item-detail-ttl {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 20px;
}

#voice .voice-item-detail-b-left {
  font-size: 0;
}

#voice .voice-item-detail-red-price {
  color: #d12248;
  font-weight: bold;
  font-size: 20px;
}

#voice .voice-item-detail-tax-price {
  font-size: 12px; 
  margin-right: 20px;
}

#voice .voice-item-detail-before-price {
  font-size: 14px;
  color: #8d8d8d;
  text-decoration: line-through;
}

#voice .voice-item-detail-bottom {
}

#voice .voice-item-detail-bottom-txt {
  float: left;
  margin-bottom: 0;
  line-height: 33px;
}

#voice .voice-item-detail-bottom-btn {
  width: 240px;
  background-color: #d12248;
  color: #fff;
  font-weight: bold;
  height: 36px;
  text-align: center;
  border-radius: 18px;
  display: block;
}

#voice .voice-item-detail-bottom-btn.read-more-btn,
#voice .voice-item-detail-bottom-btn.read-close-btn {
  cursor: pointer;
  margin: 20px auto;
  width: 160px;
}
#voice .voice-item-detail-bottom-btn.read-more-btn img,
#voice .voice-item-detail-bottom-btn.read-close-btn img {
  width: 75px;
}

#voice .voice-item-detail-bottom-btn.kuchikomi-btn {
  margin-top: 20px;
  background-color: #bcc70c;
}
#voice .voice-item-detail-bottom-btn.kuchikomi-btn img {
  width: 120px;
}

#voice .voice-item-detail-bottom-btn img {
  width: 140px;
  margin-top: 11px;
}

#voice .voice-interview-txt-more-btn {
  display: none;
}

#voice .voice-item-detail-txt {
  min-height: 49px;
  margin-bottom: 20px;
}

#voice .voice-item-detail-bottom-btn-block {
  float: right;
}

#voice .read-more-body {
  display: none;
}

#voice .kuchikomi-explain {
  display: block;
  font-size: 12px;
  margin: 5px 0 0;
}

@media screen and (min-width: 641px) {
  #voice .voice-item-detail-bottom-btn:hover {
    background-color: #b7082e;
    opacity: 1;
  }
  #voice .voice-item-detail-bottom-btn.kuchikomi-btn:hover {
    background-color: #a0b900;
    opacity: 1;
  }
}

/*------------------------------------------------------------------------------
forgot
------------------------------------------------------------------------------*/
#login.forgot .login-form-wrapper {
  float: none;
  width: 100%;
}

.forgot-txt {
  margin-bottom: 35px;
}

.forgot-txt .txt01 {
  display: block;
  margin-bottom: 0.5em;
}

.forget-block .forget-password {
  display: block;
  padding-bottom: 15px;
}

.forget-block .forget-password span {
  position: relative;
  padding-left: 12px;
}

.forget-block .forget-password span:before {
  content: "";
  background: url(../img/common/arrow_right_pink.svg) no-repeat;
  background-size: contain;
  width: 5px;
  height: 8px;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
}

.forgot-email-txt {
  float: left;
  margin: 14px 0 0;
  width: 20%;
  font-weight: bold;
}

.forgot-email-input {
  float: left;
  width: 80%;
  background-color: #f5f5f5;
  border-radius: 5px;
  border: solid 1px #bdbdbd;
  height: 46px;
  padding: 0 40px 0 14px;
  outline: 0;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

.forgot-email-input:focus {
  border-color: #d12248;
}

.forgot-email-block-outer-block {
  position: relative;
  position: relative;
  width: 70%;
  margin: 0 auto;
}

.forgot-common-btn-outer {
  text-align: center;
}

#login.forgot .common-btn {
  margin-top: 30px;
  text-align: start;
  border-radius: 20px;
}

#login.forgot .common-btn button {
  background-color: #fff;
  border: solid 1px #e5e5e5;
  border-radius: 20px;
  -webkit-box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  box-shadow: 0 1px 0 0 rgba(0,0,0,0.1);
  color: #999;
  font-size: 16px;
  font-weight: bold;
  line-height: 38px;
  padding: 0 20px;
  min-width: 300px;

}

#login.forgot .common-btn:after {
  content: "";
  background: url(../img/common/arrow_right_gray.svg) no-repeat;
  background-size: contain;
  display: inline-block;
  width: 6px;
  height: 10px;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

#login.forgot .login-form-wrapper {
  min-height: auto;
}

.forgot-form-block {
  padding: 34px 40px;
}

.forgot .forget-block {
  padding: 50px 0 80px;
}

@media screen and (min-width: 641px) {
  #login.forgot .common-btn button:hover {
    background-color: #d12248;
    border-color: #d12248;
    color: #fff;
    opacity: 1.0;
  }

  #login.forgot .common-btn:hover:after {
    background: url(../img/common/arrow_right.svg);
  }
}

/*------------------------------------------------------------------------------
complete
------------------------------------------------------------------------------*/
.complete .forgot-txt .txt01 {
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 20px;
}

#login.complete .common-btn {
  margin-top: 0;
}

.complete .forgot-txt .txt02 {
  display: block;
  margin-bottom: 10px;
}

.complete .forgot-form-wrapper {
  padding: 34px 0;
}

.complete .forgot-txt {
  text-align: center;
}

.common-btn-outer {
  text-align: center;
}

/*------------------------------------------------------------------------------
pagetop
------------------------------------------------------------------------------*/

#pagetop {
  text-align: center;
  margin: auto;
}

#pagetop a {
  display: inline-block;
  width: 50px;
  height: 50px;
  background: #f6ae35;
  padding: 0;
  z-index: 1;

  -webkit-transition-property: background;
  transition-property: background;
}

@media screen and (min-width: 641px) {
  #pagetop a:hover {
    background-color: #fbc078;
    opacity: 1.0;
    filter: alpha(opacity=100);
  }
}

#pagetop img {
  vertical-align: middle;
  width: 16px;
  height: 50px;
}

/*------------------------------------------------------------------------------
テストサイト用
------------------------------------------------------------------------------*/
.test-site-display {
  background: yellow;
  border-bottom: 1px solid red;
  color: red;
  font-size: 20px;
  font-weight: bold;
  padding: 10px 0;
  text-align: center;
}

/*------------------------------------------------------------------------------
clearfix
------------------------------------------------------------------------------*/

.clearfix:after,
.inner-block:after,
.header-sub-block:after,
header:after,
.recommend-block:after,
.item-list:after,
.main-block:after,
.side-menu-block:after,
.recommend-block .item-list li a:after,
.detail-block:after,
.slider-box:after,
.item-info-block:after,
.item-info-block .category:after,
#list .search-block:after,
#mypage .item-list li:after,
#mypage .item-list li:first-child a:after,
#mypage .item-list .item-info .price:after,
#mypage .order-info-list:after,
#mypage .payment:after,
#mypage.mypage-history .info-detail li:after,
#mypage.mypage-history .order-info:after,
#mypage.mypage-history .payment:after
{
  clear: both;
  content: "";
  display: block;
  height: 0px;
  font-size: 0;
  visibility: hidden;
}

/*------------------------------------------------------------------------------
print
------------------------------------------------------------------------------*/

@media print {
  .recommend-block li .thumbnail img {
    display: block !important;
  }

  .recommend-block .item-list .thumbnail {
    padding: 0;
  }

  .recommend-block .item-list .thumbnail img {
    max-height: 210px;
  }
}