﻿@charset "UTF-8";

/* ----トピック---- */
div:active,a:active,b:active,span:active,button:active,
div:focus,a:focus,b:focus,span:focus,button:focus {
  outline: none;
  -webkit-tap-highlight-color:rgba(0,0,0,0);
}

.block-top-topic--header {
  font-size: 28px;
  text-align: center;
  line-height: 1.2;
  border-top: #444 2px solid;
  padding: 19px 0 30px;
}

.block-top-topic--header span {
  display: block;
  font-size: 11px;
}

.block-top-topic--body {
  margin-bottom: 60px;
}

.block-top-topic--items li {
  border-bottom: 1px solid #ddd;
  padding: 10px 0;
}

.block-top-topic--items dl,
.block-top-topic--items dt,
.block-top-topic--items dd {
  display: inline;
}

.block-top-topic--items dt {
  margin-right: 10px;
}

.block-top-topic--next-page {
  text-align: right;
  margin-top: 20px;
}

.block-top-topic--next-page a {
  color: #6fb4c3;
  text-decoration: underline;
  font-size: 14px;
}

.block-top-topic--items img {
  vertical-align: middle;
}

.block-topic-page--article-icon {
  vertical-align: middle;
}

.block-topic-page--article figure {
  font-size: 0;
}

.block-topic-page--article figure img {
  padding-bottom: 10px;
}

.block-topic-details--items dl,
.block-topic-details--items dt,
.block-topic-details--items dd {
  display: inline;
}

.block-topic-details--items dt {
  margin-right: 10px;
}

.block-topic-details--items img {
  vertical-align: middle;
}

.block-topic-details--items li {
  border-bottom: #ddd 1px solid;
  padding: 10px 0;
}

/* ----最近見た商品---- */

.block-recent-item {
  width: 900px;
}

.block-recent-item--header {
  font-size: 28px;
  text-align: center;
  border-top: #444 2px solid;
  padding: 19px 0 30px;
}

.block-recent-item--items {
  width: 900px;
}

.block-recent-item--keep-history {
  text-align: right;
  margin-top: 20px;
}

.block-recent-item--keep-history a {
  color: #6fb4c3;
  text-decoration: underline;
  font-size: 14px;
}

/* ----最近チェックした商品(ブランド)---- */

.block-brand-recent-item {
  width: 900px;
}

.block-brand-recent-item--header {
  font-size: 28px;
  text-align: center;
  border-top: #444 2px solid;
  padding: 19px 0 30px;
}

.block-brand-recent-item--items {
  width: 900px;
}

.block-brand-recent-item--keep-history {
  text-align: right;
  margin-top: 20px;
}

.block-brand-recent-item--keep-history a {
  color: #6fb4c3;
  text-decoration: underline;
  font-size: 14px;
}

/* ----最近チェックした商品(カート)---- */

.block-cart-recent-item {
  width: 1110px;
}

.block-cart-recent-item--header {
  font-size: 22px;
  text-align: center;
  border-top: #444 2px solid;
  padding: 30px 0 30px;
}

.block-cart-recent-item--items {
  width: 1110px;
}

.block-cart-recent-item--keep-history {
  text-align: right;
  margin-top: 20px;
}

.block-cart-recent-item--keep-history a {
  color: #6fb4c3;
  text-decoration: underline;
  font-size: 14px;
}

/* ----検索サジェスト---- */

.block-search-suggest {
  position: absolute;
  display: block;
  z-index: 1000;
  text-align: left;
  padding: 5px;
  width: 370px;
  background-color: #fff;
  border: 1px solid #000;
}

.block-search-suggest--keyword {
  padding: 2px;
}

.block-search-suggest--keyword-entry {
  display: block;
  text-decoration: none;
}

.block-search-suggest--goods {
  min-height: 60px;
  padding: 2px;
  display: block;
  clear: both;
}

.block-search-suggest--goods-img {
  display: block;
  /*float: left;*/
  width: 60px;
  margin-right: 10px;
}

.block-search-suggest--goods-img img {
  width: 60px;
  height: 60px;
}

.block-search-suggest--goods-name,
.block-search-suggest--goods-comment,
.block-search-suggest--goods-price-items {
  width: 100%;
}

.block-search-suggest--keyword:hover,
.block-search-suggest--goods:hover {
  background-color: #dedede;
  cursor: pointer;
}

/* ----パンくず---- */

.block-topic-path {
  width: 1110px;
  margin: 0 auto;
  padding: 5px 0 7px 0;
}

.block-topic-path--list li {
  display: inline-block;
  padding-right: 10px;
}

.block-topic-path--list li:not(:first-of-type) span {
  padding-left: 10px;
}

.block-topic-path--list a {
  color: #fff;
  font-size: 12px;
  text-decoration: none;
}

.block-topic-path--list a:hover {
  text-decoration: underline;
}



/* ----左メニューブロック共通---- */

.pane-left-menu h2 {
  font-size: 16px;
  border-top: #444 1px solid;
  padding: 16px 0;
  font-weight: bold;
  margin-bottom: 0;
}

.pane-left-menu h3 {
  font-size: 14px;
  padding: 8px 0;
  font-weight: bold;
  border-bottom: #eee 1px solid;
  margin-bottom: 5px;
  cursor: pointer;
}

/* ----キーワード検索ブロック---- */

.block-search-box--search-detail a {
  color: #6fb4c3;
  text-decoration: underline;
}

.block-search-box--form {
  background-color: #eee;
  display: flex;
}

.block-search-box--keyword:hover,
.block-search-box--keyword {
  border: none;
  background-color: transparent;
  flex-grow: 1;
}

.block-search-box--search-submit {
  border: none;
  background-color: transparent;
  width: 33px;
}

.block-search-box--search-detail {
  margin: 5px 0;
}

/* ----Ajaxカートブロック---- */

.block-jscart--items {
  border-bottom: #eee 1px solid;
  margin-bottom: 5px;
}
.block-jscart--items dd {
  text-align: right;
}
.block-jscart--delete {
  text-align: right;
  margin-bottom: 5px;
}
.block-jscart--cart-to-order {
  text-align: center;
  margin-top: 15px;
}

/* ----エラー画面---- */

.block-validation-alert {
  text-align: center;
  margin: 100px auto;
  padding: 30px;
  width: 500px;
  border: 1px solid #808080;
}

.block-validation-alert--title {
  font-weight: bold;
  margin-bottom: 10px;
}

.block-validation-alert--link {
  display: block;
  margin-top: 10px;
}

.block-common-alert {
  margin-top: 40px;
  margin-bottom: 10px;
  padding: 10px;
  border: 1px solid #ebccd1;
  color: #a94442;
  background-color: #f2dede;
}

.block-common-alert--link {
  display: block;
  margin-top: 10px;
}

.block-common-alert-list {
  margin-bottom: 10px;
  padding: 10px;
  border: 1px solid #666;
  background-color: #fff;
}

.block-common-alert-list--items {
  color: #a94442;
}

/* ----郵便番号サジェスト---- */

.block-ziplist--ziplist-frame {
  z-index: 2000;
}

/* ----サイクル情報編集---- */

.block-regular-cycle--cycle-sub-type {
  margin-bottom: 10px;
  padding: 10px;
  background: #f8f8f8;
  border: 1px solid #ccc;
}

.block-regular-cycle--deliv_date {
  width: 100%;
  margin: 20px 0;
}
.block-regular-cycle--deliv_date--prev-expected-dt {
  border-top: 1px dotted #ccc;
  border-left: 1px dotted #ccc;
  border-right: 1px dotted #ccc;
}

.block-regular-cycle--deliv_date--next-expected-dt {
  border: 1px dotted #ccc;
}

.block-regular-cycle--deliv_date--prev-expected-dt-title,
.block-regular-cycle--deliv_date--next-expected-dt-title {
  padding: 8px;
  text-align: center;
  font-weight: bold;
  vertical-align: top;
  background-color: #f8f8f8;
  border-bottom: 1px dotted #ccc;
}

.block-regular-cycle--deliv_date--prev-expected-dt-date,
.block-regular-cycle--deliv_date--next-expected-dt-date {
  padding: 8px;
  text-align: center;
  font-weight: bold;
  vertical-align: top;
}

.footer_aside .footer_aside_inner {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50%;
  background: #fff;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  padding: 50px 0;
}

.footer_aside .footer_sns_area,
.footer_aside .footer_point_area {
  display: inline-block;
}

.footer_aside .footer_sns_area a,
.footer_aside .footer_point_area a {
  padding: 3px;
  transition: .3s;
}

.footer_sns_area a img,
.footer_point_area a img {
  width: 50px;
  height: 50px;
}

.footer_aside .footer_sns_area a:hover,
.footer_aside .footer_point_area a:hover {
  opacity: .7;
  text-decoration: none;
}

.footer_aside .footer_aside_inner span {
  display: inline-block;
  font-size: 22px;
  font-weight: 700;
  font-family: 'qs_font';
}

.footer_aside .footer_aside_inner:first-of-type {
  border-right: 1px solid #ccc;
}
.footer_aside .footer_aside_inner:first-of-type span {
  width: 80px;
}

.footer_aside .footer_aside_inner:nth-of-type(2) span {
  width: 190px;
}

#footer_nav {
  position: relative;
  background: #8c8c8c;
  min-height: 320px;
  z-index: 1;
}

@media screen and (max-width: 1150px) {
  #footer_nav {
    min-height: 460px;
  }
}

#footer_nav ul {
  max-width: 750px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
}

#footer_nav div.footer_nav_inner {
  width: calc(100vw - 480px);
  padding-bottom: 30px;
}
#footer_nav ul li {
  margin: 40px 30px 0 30px;
}

#footer_nav ul li a {
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  padding-bottom: 5px;
  border-bottom: 1px solid #fff;
}

#footer_nav ul li a:hover {
  text-decoration: none;
  border-bottom: 1px dotted #fff;
}

#footer_confirm_status {
  display: block;
  width: 100%;
  min-height: 140px;
  background: url(../../img/usr/common/bg_confirm_status.jpg);
  z-index: 0;
  transition: .3s;
}

#footer_confirm_status:hover {
  text-decoration: none;
  opacity: .8;
}

#footer_confirm_status span.confirm_status_bg {
  display: block;
  min-height: 140px;
  background: url(../../img/usr/common/img_confirm_status.png) no-repeat left 190px bottom 0px;
  z-index: 1;
}

#footer_confirm_status span.confirm_status_bg span {
  display: block;
  padding: 25px 0 0 415px;
  color: #fff;
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 1px;
}

#footer_confirm_status span.confirm_status_bg b {
  position: relative;
  display: block;
  font-size: 36px;
  padding-bottom: 5px;
} 

#footer_confirm_status span.confirm_status_bg b:after {
  position: absolute;
  top: 15px;
  left: -40px;
  width: 29px;
  height: 31px;
  background: url(../../img/usr/common/mark_confirm_status.png);
  z-index: 2;
  content: '';
}

#footer_link_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

#footer_link_area li {
  position: relative;
  width: 33.3333333%;
  border-top: 1px solid #aaa;
  border-right: 1px solid #aaa;
  min-height: 60px;
}

#footer_link_area li:after {
  position: absolute;
  top: 50%;
  left: 30px;
  transform: translateY(-50%);
  width: 9px;
  height: 12px;
  background: #000;
  background: url(../../img/usr/common/mark_footer_arrow.png);
  content: '';
}

#footer_link_area li a {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
  padding: 15px 50px;
  text-align: center;
  color: #000;
  font-weight: 700;
  font-size: 16px;
  transition: .3s;
}

#footer_link_area li a:hover {
  background: #ddd;
}

#footer_link_area li:first-of-type,
#footer_link_area li:nth-of-type(4) {
  border-left: 1px solid #aaa;
}

#footer_calendar {
  position: absolute;
  top: 30px;
  right: 30px;
  width: 410px;
  min-height: 400px;
  background: #fff;
  padding: 0;
  margin: 0;
  z-index: 5;
  text-align: center;
  padding: 20px 0;
}

#footer_calendar .calendar_slide_area_wrapper {
  display: flex;
  width: 308px;
  margin: 0 51px;
  overflow-x: hidden;
}
#footer_calendar .calendar_slide_area {
  width: 100%;
  position: relative;
  left: 0%;
  transition: .2s;
}

@media all and (-ms-high-contrast:none){
  *::-ms-backdrop, #footer_calendar .calendar_slide_area { width: 308px !important; } /* IE11 */
}

#footer_calendar span.footer_calendar_title {
  display: inline-block;
  font-weight: 500;
  letter-spacing: 1px;
}

#footer_calendar span.footer_calendar_month {
  letter-spacing: 1px;
}

#footer_calendar span.footer_calendar_month b {
  display: inline-block;
  font-weight: bold;
  font-size: 36px;
  font-weight: 700;
  font-family: 'qs_font';
  letter-spacing: 1px;
  padding-right: 3px;
}

#footer_calendar .footer_calendar_month_area {
  width: 100%;
  position: relative;
}


@media all and (-ms-high-contrast:none){
  *::-ms-backdrop, #footer_calendar .footer_calendar_month_area { width: 308px !important; } /* IE11 */
}

#footer_calendar .footer_calendar_prev,
#footer_calendar .footer_calendar_next {
  position: absolute;
  bottom: 8px;
  font-weight: 700;
  letter-spacing: 1px;
  font-family: 'qs_font';
  font-size: 14px;
  cursor: pointer;
  transition: .3s;
}

#footer_calendar .footer_calendar_prev:hover,
#footer_calendar .footer_calendar_next:hover {
  opacity: .7;
}

#footer_calendar .footer_calendar_prev {
  display: none;
  left: 0px;
  padding-left: 20px;
  background: url(../../img/usr/common/mark_footer_arrowprev.png) no-repeat left 0 top 3px;
}

#footer_calendar .footer_calendar_next {
  right: 0px;
  padding-right: 20px;
  background: url(../../img/usr/common/mark_footer_arrow.png) no-repeat right 0 top 3px;
}

#footer_calendar table {
  width: 308px;
  text-align: center;
  margin: 0 auto;
}

#footer_calendar table tr {
  border-top: 1px solid #aaa;
}

#footer_calendar table th {
  text-align: center;
  padding: 2px 0;
}

#footer_calendar table th span {
  font-size: 12px;
  font-weight: 700;
}

#footer_calendar table td {
  height: 38px;
  text-align: center;
  padding: 0;
}

#footer_calendar table td span {
  display: inline-block;
  width: 24px;
  height: 24px;
  border-radius: 24px;
  padding-top: 2px;
  font-family: 'qs_font';
  font-weight: 300;
}
#footer_calendar table td span.closed {
  position: relative;
  color: #fff;
  background: #c40030;
}

#footer_nav p {
  font-size: 10px;
  transform: scale(0.9); 
  text-align: left;
  padding: 10px 0 0 40px;
  font-weight: 700;
}

#footer_nav p span {
  color: #c40030;
  padding-right: 3px;
}

#explanatory_text {
  padding: 10px 0;
  font-size: 12px;
  /*border-top: 1px solid #ccc;*/
}